From 5aaa2d679b00a7a78338b9b72fa72397ad945b35 Mon Sep 17 00:00:00 2001 From: Chi Kei Chan Date: Sun, 24 Sep 2017 23:27:08 -0700 Subject: [PATCH] Add ShapeShift UI --- .eslintrc | 2 + app/images/caret-right.svg | 76 +++++++ .../src/app/first-time/buy-ether-screen.js | 208 ++++++++++++------ mascara/src/app/first-time/index.css | 129 ++++++++++- package.json | 2 +- yarn.lock | 24 +- 6 files changed, 357 insertions(+), 84 deletions(-) create mode 100644 app/images/caret-right.svg diff --git a/.eslintrc b/.eslintrc index 01f568618..39a505d90 100644 --- a/.eslintrc +++ b/.eslintrc @@ -17,6 +17,8 @@ }, }, + "extends": ["eslint:recommended", "plugin:react/recommended"], + "env": { "es6": true, "node": true, diff --git a/app/images/caret-right.svg b/app/images/caret-right.svg new file mode 100644 index 000000000..8981ac254 --- /dev/null +++ b/app/images/caret-right.svg @@ -0,0 +1,76 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/mascara/src/app/first-time/buy-ether-screen.js b/mascara/src/app/first-time/buy-ether-screen.js index 8077b134c..44141db64 100644 --- a/mascara/src/app/first-time/buy-ether-screen.js +++ b/mascara/src/app/first-time/buy-ether-screen.js @@ -14,17 +14,17 @@ class BuyEtherScreen extends Component { }; static OPTIONS = [ + { + name: 'Direct Deposit', + value: BuyEtherScreen.OPTION_VALUES.QR_CODE, + }, { name: 'Buy with Dollars', - value: BuyEtherScreen.OPTION_VALUES.COINBASE + value: BuyEtherScreen.OPTION_VALUES.COINBASE, }, { - name: 'Buy with Bitcoin', - value: BuyEtherScreen.OPTION_VALUES.SHAPESHIFT - }, - { - name: 'Deposit Ether', - value: BuyEtherScreen.OPTION_VALUES.QR_CODE + name: 'Buy with Cryptos', + value: BuyEtherScreen.OPTION_VALUES.SHAPESHIFT, }, ]; @@ -35,69 +35,67 @@ class BuyEtherScreen extends Component { } state = { - selectedOption: BuyEtherScreen.OPTION_VALUES.COINBASE, - justCopied: false + selectedOption: BuyEtherScreen.OPTION_VALUES.QR_CODE, + justCopied: false, } copyToClipboard = () => { - const { address } = this.props; + const { address } = this.props this.setState({ justCopied: true }, () => copyToClipboard(address)) setTimeout(() => this.setState({ justCopied: false }), 1000) } - renderSkip() { + renderSkip () { const {showAccountDetail, address} = this.props return (
showAccountDetail(address)} > -
- Do it later -
+ Do it later
) } - renderCoinbaseLogo() { + renderCoinbaseLogo () { return ( - - - - - - - - - - - + + + + + + + + + + + - ); - } - - renderShapeShiftLogo() { - return ( -
) } - renderCoinbaseForm() { - const {goToCoinbase, address} = this.props; + renderShapeShiftLogo () { + return ( +
+ ) + } + + renderCoinbaseForm () { + const {goToCoinbase, address} = this.props return ( -
+
{this.renderCoinbaseLogo()}
-
Coinbase is the world’s most popular way to buy and sell bitcoin, ethereum, and litecoin.
- What is Ethereum? -
+
Coinbase is the world’s most popular way to buy and sell bitcoin, ethereum, and litecoin.
+ What is Ethereum? +
@@ -130,17 +197,14 @@ class BuyEtherScreen extends Component {
) case OPTION_VALUES.QR_CODE: - const qrImage = qrcode(4, 'M') - qrImage.addData(address) - qrImage.make() return ( -
+
-
Deposit Ether directly into your account.
-
(This is the account address that MetaMask created for you to recieve funds.)
-
+
Deposit Ether directly into your account.
+
(This is the account address that MetaMask created for you to recieve funds.)
+
) default: - return null; + return null } } - render() { - const { OPTIONS } = BuyEtherScreen; - const { selectedOption } = this.state; + render () { + const { OPTIONS } = BuyEtherScreen + const { selectedOption } = this.state return ( -
+
-
Buy Ether
-
+
Deposit Ether
+
MetaMask works best if you have Ether in your account to pay for transaction gas fees and more. To get Ether, choose from one of these methods.
-
-
Purchasing Options
-
-
+
+
+
Deposit Options
+ {this.renderSkip()} +
+
+
{OPTIONS.map(({ name, value }) => (
this.setState({ selectedOption: value })} > -
{name}
+
{name}
{value === selectedOption && ( - - + + )}
))} - {this.renderSkip()}
-
+
{this.renderContent()}
@@ -199,7 +265,7 @@ class BuyEtherScreen extends Component { export default connect( ({ metamask: { selectedAddress } }) => ({ - address: selectedAddress + address: selectedAddress, }), dispatch => ({ goToCoinbase: address => dispatch(buyEth({ network: '1', address, amount: 0 })), diff --git a/mascara/src/app/first-time/index.css b/mascara/src/app/first-time/index.css index 483bda212..50d0d2fb7 100644 --- a/mascara/src/app/first-time/index.css +++ b/mascara/src/app/first-time/index.css @@ -343,6 +343,13 @@ button.backup-phrase__confirm-seed-option:hover { margin-top: 31px; } +.buy-ether__content-headline-wrapper { + display: flex; + flex-flow: row nowrap; + align-items: center; + justify-content: space-between; +} + .buy-ether__content-headline { color: #1B344D; font-family: Montserrat Light; @@ -350,6 +357,13 @@ button.backup-phrase__confirm-seed-option:hover { line-height: 23px; } +.buy-ether__do-it-later { + color: #1B344D; + font-size: 16px; + line-height: 23px; + cursor: pointer; +} + .buy-ether__content { margin-top: 12px; display: flex; @@ -361,8 +375,7 @@ button.backup-phrase__confirm-seed-option:hover { flex-flow: column nowrap; } -.buy-ether__side-panel-item, -.buy-ether__side-panel-exit { +.buy-ether__side-panel-item { display: flex; flex-flow: row nowrap; align-items: center; @@ -375,9 +388,6 @@ button.backup-phrase__confirm-seed-option:hover { min-width: 140px; } -.buy-ether__side-panel-exit { - color: #FF001F; -} .buy-ether__side-panel-item { border-bottom: 1px solid #CDCDCD; @@ -527,6 +537,12 @@ button.first-time-flow__button--tertiary:hover { font-family: Montserrat UltraLight; } +.icon { + background-repeat: no-repeat; + background-size: contain; + background-position: center; +} + .shapeshift-logo { background: url(''); width: 161px; @@ -535,3 +551,106 @@ button.first-time-flow__button--tertiary:hover { background-repeat: no-repeat; background-position: 50%; } + +.shapeshift-form { + width: 360px; + border-radius: 8px; + background-color: rgba(0, 0, 0, .05); + padding: 17px 15px; +} + +.shapeshift-form__selectors { + display: flex; + flex-flow: row nowrap; + align-items: center; + padding-bottom: 17px; +} + +.shapeshift-form__caret { + width: 40px; + height: 40px; + flex: 0 0 auto; + width: 120px; + margin-top: 24px; +} + +.shapeshift-form__selector { + flex: 1 0 auto; +} + +.shapeshift-form__selector-label { + color: #757575; + color: rgba(0, 0, 0, 0.45); + font-family: Montserrat Light; + font-weight: 300; + line-height: 19px; + padding-bottom: 6px; +} + +.shapeshift-form__selector-input { + color: #5B5D67; + font-size: 16px; + font-weight: 300; + line-height: 21px; + border: 1px solid #D8D8D8; + background-color: #FFFFFF; + text-align: center; + width: 100%; + height: 45px; +} + +.shapeshift-form__address-input-wrapper { + padding-bottom: 24px; +} + +.shapeshift-form__address-input-label { + color: #757575; + font-size: 14px; + font-weight: 500; + line-height: 18px; + padding-bottom: 6px; + font-family: Montserrat Light; +} + +.shapeshift-form__address-input { + border: 1px solid #D8D8D8; + background-color: #FFFFFF; + font-size: 16px; + font-weight: 300; + line-height: 21px; + padding: 15px; + width: 100%; +} + +.shapeshift-form__metadata { + display: flex; + flex-flow: row wrap; + color: #9B9B9B; + font-family: Montserrat Light; + font-size: 10px; + line-height: 16px; +} + +.shapeshift-form__metadata-wrapper { + flex: 1 0 50%; + display: flex; + flex-flow: row nowrap; + overflow: hidden; + white-space: nowrap; +} + +.shapeshift-form__metadata-wrapper:nth-child(odd) { + padding-right: 24px; +} + +.shapeshift-form__metadata-label { + flex: 1 0 65%; +} + +.shapeshift-form__metadata-value { + flex: 0 0 40%; + overflow: hidden; + color: #000; + text-overflow: ellipsis; + white-space: nowrap; +} diff --git a/package.json b/package.json index f396160db..693f3a11c 100644 --- a/package.json +++ b/package.json @@ -67,7 +67,7 @@ "dnode": "^1.2.2", "end-of-stream": "^1.1.0", "ensnare": "^1.0.0", - "eslint-plugin-react": "^7.3.0", + "eslint-plugin-react": "^7.4.0", "eth-bin-to-ops": "^1.0.1", "eth-block-tracker": "^2.2.0", "eth-contract-metadata": "^1.1.4", diff --git a/yarn.lock b/yarn.lock index 7fe7883b7..ad5cefec3 100644 --- a/yarn.lock +++ b/yarn.lock @@ -3036,9 +3036,9 @@ eslint-plugin-mocha@^4.9.0: dependencies: ramda "^0.24.1" -eslint-plugin-react@^7.3.0: - version "7.3.0" - resolved "https://registry.yarnpkg.com/eslint-plugin-react/-/eslint-plugin-react-7.3.0.tgz#ca9368da36f733fbdc05718ae4e91f778f38e344" +eslint-plugin-react@^7.4.0: + version "7.4.0" + resolved "https://registry.yarnpkg.com/eslint-plugin-react/-/eslint-plugin-react-7.4.0.tgz#300a95861b9729c087d362dd64abcc351a74364a" dependencies: doctrine "^2.0.0" has "^1.0.1" @@ -5249,7 +5249,7 @@ jsmin@1.x: version "1.0.1" resolved "https://registry.yarnpkg.com/jsmin/-/jsmin-1.0.1.tgz#e7bd0dcd6496c3bf4863235bf461a3d98aa3b98c" -json-rpc-engine@^3.0.1, json-rpc-engine@^3.1.0: +json-rpc-engine@^3.0.1: version "3.1.0" resolved "https://registry.yarnpkg.com/json-rpc-engine/-/json-rpc-engine-3.1.0.tgz#09285363372857569d75f61df6591b1b0afb0758" dependencies: @@ -5257,16 +5257,26 @@ json-rpc-engine@^3.0.1, json-rpc-engine@^3.1.0: babel-preset-env "^1.3.2" babelify "^7.3.0" +json-rpc-engine@^3.2.0: + version "3.2.0" + resolved "https://registry.yarnpkg.com/json-rpc-engine/-/json-rpc-engine-3.2.0.tgz#d34dff106c8339c337a894da801f73b1f77b1bc8" + dependencies: + async "^2.0.1" + babel-preset-env "^1.3.2" + babelify "^7.3.0" + json-rpc-error "^2.0.0" + json-rpc-error@^2.0.0: version "2.0.0" resolved "https://registry.yarnpkg.com/json-rpc-error/-/json-rpc-error-2.0.0.tgz#a7af9c202838b5e905c7250e547f1aff77258a02" dependencies: inherits "^2.0.1" -json-rpc-middleware-stream@^1.0.0: - version "1.0.0" - resolved "https://registry.yarnpkg.com/json-rpc-middleware-stream/-/json-rpc-middleware-stream-1.0.0.tgz#84d0faefe123ce9cfc7a9753e6e5236b9a104522" +json-rpc-middleware-stream@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/json-rpc-middleware-stream/-/json-rpc-middleware-stream-1.0.1.tgz#c9b8a005c80af32e6df8bb88e6bdd1300484a4ed" dependencies: + end-of-stream "^1.4.0" eth-block-tracker "^2.1.2" ethjs-query "^0.2.9" json-rpc-engine "^3.0.1"