1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00
Fix lint error breaking gulp build

Add presentational options menus
This commit is contained in:
sdtsui 2017-07-14 00:53:54 -07:00
parent d01b5c927d
commit 433fb4d242
5 changed files with 108 additions and 33 deletions

View File

@ -13,6 +13,7 @@ function EditableLabel () {
EditableLabel.prototype.render = function () { EditableLabel.prototype.render = function () {
const props = this.props const props = this.props
const state = this.state const state = this.state
console.log("editing:", state.isEditingLabel);
if (state && state.isEditingLabel) { if (state && state.isEditingLabel) {
return h('div.editable-label', [ return h('div.editable-label', [
@ -30,6 +31,8 @@ EditableLabel.prototype.render = function () {
} else { } else {
return h('div.name-label', { return h('div.name-label', {
onClick: (event) => { onClick: (event) => {
debugger;
console.log("event", event.target);
this.setState({ isEditingLabel: true }) this.setState({ isEditingLabel: true })
}, },
}, this.props.children) }, this.props.children)

View File

@ -18,6 +18,8 @@ const EditableLabel = require('./components/editable-label')
const Tooltip = require('./components/tooltip') const Tooltip = require('./components/tooltip')
const TabBar = require('./components/tab-bar') const TabBar = require('./components/tab-bar')
const TokenList = require('./components/token-list') const TokenList = require('./components/token-list')
const AccountOptionsMenus = require('./components/account-options-menus').AccountOptionsMenus;
console.log("AOM",AccountOptionsMenus);
module.exports = connect(mapStateToProps)(AccountDetailScreen) module.exports = connect(mapStateToProps)(AccountDetailScreen)
@ -51,6 +53,8 @@ AccountDetailScreen.prototype.render = function () {
var identity = props.identities[selected] var identity = props.identities[selected]
var account = props.accounts[selected] var account = props.accounts[selected]
const { network, conversionRate, currentCurrency } = props const { network, conversionRate, currentCurrency } = props
console.log("identity:", identity);
console.log("result:", identity && identity.name);
return ( return (
@ -99,7 +103,10 @@ AccountDetailScreen.prototype.render = function () {
// What is shown when not editing + edit text: // What is shown when not editing + edit text:
h('label.editing-label', [h('.edit-text', 'edit')]), h('label.editing-label', [h('.edit-text', 'edit')]),
h('h2.font-medium.color-forest', {name: 'edit'}, identity && identity.name), h('h2.font-medium.color-forest', {name: 'edit'}, [
identity && identity.name,
h(AccountOptionsMenus, { style: { marginLeft: '35%' }}, []),
]),
]), ]),
h('.flex-row', { h('.flex-row', {
style: { style: {

View File

@ -26,6 +26,7 @@ const Loading = require('./components/loading')
const SandwichExpando = require('sandwich-expando') const SandwichExpando = require('sandwich-expando')
const MenuDroppo = require('menu-droppo') const MenuDroppo = require('menu-droppo')
const DropMenuItem = require('./components/drop-menu-item') const DropMenuItem = require('./components/drop-menu-item')
import { Dropdown, DropdownMenuItem } from './components/dropdown';
const NetworkIndicator = require('./components/network') const NetworkIndicator = require('./components/network')
const Tooltip = require('./components/tooltip') const Tooltip = require('./components/tooltip')
const BuyView = require('./components/buy-button-subview') const BuyView = require('./components/buy-button-subview')
@ -295,7 +296,7 @@ App.prototype.renderDropdown = function () {
const state = this.state || {} const state = this.state || {}
const isOpen = state.isMainMenuOpen const isOpen = state.isMainMenuOpen
return h(MenuDroppo, { return h(Dropdown, {
isOpen: isOpen, isOpen: isOpen,
zIndex: 11, zIndex: 11,
onClickOutside: (event) => { onClickOutside: (event) => {
@ -306,43 +307,27 @@ App.prototype.renderDropdown = function () {
right: 0, right: 0,
top: '36px', top: '36px',
}, },
innerStyle: { innerStyle: {},
background: 'white',
boxShadow: '1px 1px 2px rgba(0,0,0,0.1)',
},
}, [ // DROP MENU ITEMS }, [ // DROP MENU ITEMS
h('style', ` h(DropdownMenuItem, {
.drop-menu-item:hover { background:rgb(235, 235, 235); }
.drop-menu-item i { margin: 11px; }
`),
h(DropMenuItem, {
label: 'Settings',
closeMenu: () => this.setState({ isMainMenuOpen: !isOpen }), closeMenu: () => this.setState({ isMainMenuOpen: !isOpen }),
action: () => this.props.dispatch(actions.showConfigPage()), onClick: () => this.props.dispatch(actions.showConfigPage()),
icon: h('i.fa.fa-gear.fa-lg'), }, 'Settings'),
}),
h(DropMenuItem, { h(DropdownMenuItem, {
label: 'Import Account',
closeMenu: () => this.setState({ isMainMenuOpen: !isOpen }), closeMenu: () => this.setState({ isMainMenuOpen: !isOpen }),
action: () => this.props.dispatch(actions.showImportPage()), onClick: () => this.props.dispatch(actions.showImportPage()),
icon: h('i.fa.fa-arrow-circle-o-up.fa-lg'), }, 'Import Account'),
}),
h(DropMenuItem, { h(DropdownMenuItem, {
label: 'Lock',
closeMenu: () => this.setState({ isMainMenuOpen: !isOpen }), closeMenu: () => this.setState({ isMainMenuOpen: !isOpen }),
action: () => this.props.dispatch(actions.lockMetamask()), onClick: () => this.props.dispatch(actions.lockMetamask()),
icon: h('i.fa.fa-lock.fa-lg'), }, 'Lock'),
}),
h(DropMenuItem, { h(DropdownMenuItem, {
label: 'Info/Help',
closeMenu: () => this.setState({ isMainMenuOpen: !isOpen }), closeMenu: () => this.setState({ isMainMenuOpen: !isOpen }),
action: () => this.props.dispatch(actions.showInfoPage()), onClick: () => this.props.dispatch(actions.showInfoPage()),
icon: h('i.fa.fa-question.fa-lg'), }, 'Info/Help'),
}),
]) ])
} }

View File

@ -0,0 +1,77 @@
const Component = require('react').Component;
const PropTypes = require('react').PropTypes;
const h = require('react-hyperscript');
const Dropdown = require('./dropdown').Dropdown;
const DropdownMenuItem = require('./dropdown').DropdownMenuItem;
class AccountOptionsMenus extends Component {
constructor(props) {
super(props);
this.state = {
overflowMenuActive: false,
switchingMenuActive: false,
};
console.log("state:", this.state);
}
render() {
console.log("RENDERING AcountOptionsMenus");
return h(
'span',
{
style: this.props.style,
},
[
h(
'i.fa.fa-angle-down',
{
onClick: (event) => {
event.stopPropagation();
this.setState({ switchingMenuActive: !this.state.switchingMenuActive })
}
},
[
h(
Dropdown,
{
isOpen: this.state.switchingMenuActive,
onClickOutside: () => { this.setState({ switchingMenuActive: false})}
},
[
h(DropdownMenuItem, {
}, 'Settings'),
]
)
],
),
h(
'i.fa.fa-ellipsis-h',
{
style: { 'marginLeft': '10px'},
onClick: () => { this.setState({ switchingMenuActive: !this.state.switchingMenuActive }) }
},
[
h(
Dropdown,
{
isOpen: this.state.overflowMenuActive,
onClickOutside: (event) => {
event.stopPropagation();
this.setState({ overflowMenuActive: false})
}
},
[
h(DropdownMenuItem, {
}, 'Settings'),
]
)
]
)
]
)
}
}
module.exports = {
AccountOptionsMenus,
};

View File

@ -30,12 +30,15 @@ EditableLabel.prototype.render = function () {
} else { } else {
return h('div.name-label', { return h('div.name-label', {
onClick: (event) => { onClick: (event) => {
this.setState({ isEditingLabel: true }) if (event.target.getAttribute('name') === 'edit') {
this.setState({ isEditingLabel: true })
}
}, },
}, this.props.children) }, this.props.children)
} }
} }
// class = edit-text
// name = edit
EditableLabel.prototype.saveIfEnter = function (event) { EditableLabel.prototype.saveIfEnter = function (event) {
if (event.key === 'Enter') { if (event.key === 'Enter') {
this.saveText() this.saveText()