diff options
author | kumavis <kumavis@users.noreply.github.com> | 2017-08-08 01:51:18 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-08-08 01:51:18 +0800 |
commit | 57abc58d623b66a091987a944d8c45737f4feabe (patch) | |
tree | 546623f2e7f98dc745afe924e3937da722894820 /ui/app/components/dropdown.js | |
parent | 2ba5737728d2539fc3bc9015e440f37341219cdc (diff) | |
parent | 50fc9c965842f023180630267ecd8dc4f47e9cd6 (diff) | |
download | tangerine-wallet-browser-57abc58d623b66a091987a944d8c45737f4feabe.tar tangerine-wallet-browser-57abc58d623b66a091987a944d8c45737f4feabe.tar.gz tangerine-wallet-browser-57abc58d623b66a091987a944d8c45737f4feabe.tar.bz2 tangerine-wallet-browser-57abc58d623b66a091987a944d8c45737f4feabe.tar.lz tangerine-wallet-browser-57abc58d623b66a091987a944d8c45737f4feabe.tar.xz tangerine-wallet-browser-57abc58d623b66a091987a944d8c45737f4feabe.tar.zst tangerine-wallet-browser-57abc58d623b66a091987a944d8c45737f4feabe.zip |
Merge pull request #1835 from MetaMask/NewUI
Begin UI Refactor with Responsiveness & New Menus
Diffstat (limited to 'ui/app/components/dropdown.js')
-rw-r--r-- | ui/app/components/dropdown.js | 94 |
1 files changed, 94 insertions, 0 deletions
diff --git a/ui/app/components/dropdown.js b/ui/app/components/dropdown.js new file mode 100644 index 000000000..34c7149ee --- /dev/null +++ b/ui/app/components/dropdown.js @@ -0,0 +1,94 @@ +const Component = require('react').Component +const PropTypes = require('react').PropTypes +const h = require('react-hyperscript') +const MenuDroppo = require('./menu-droppo') +const extend = require('xtend') + +const noop = () => {} + +class Dropdown extends Component { + render () { + const { isOpen, onClickOutside, style, innerStyle, children, useCssTransition } = this.props + + const innerStyleDefaults = extend({ + borderRadius: '4px', + padding: '8px 16px', + background: 'rgba(0, 0, 0, 0.8)', + boxShadow: 'rgba(0, 0, 0, 0.15) 0px 2px 2px 2px', + }, innerStyle) + + return h( + MenuDroppo, + { + useCssTransition, + isOpen, + zIndex: 11, + onClickOutside, + style, + innerStyle: innerStyleDefaults, + }, + [ + h( + 'style', + ` + li.dropdown-menu-item:hover { color:rgb(225, 225, 225); } + li.dropdown-menu-item { color: rgb(185, 185, 185); } + ` + ), + ...children, + ] + ) + } +} + +Dropdown.defaultProps = { + isOpen: false, + onClick: noop, + useCssTransition: false, +} + +Dropdown.propTypes = { + isOpen: PropTypes.bool.isRequired, + onClick: PropTypes.func.isRequired, + children: PropTypes.node, + style: PropTypes.object.isRequired, +} + +class DropdownMenuItem extends Component { + render () { + const { onClick, closeMenu, children, style } = this.props + + return h( + 'li.dropdown-menu-item', + { + onClick: () => { + onClick() + closeMenu() + }, + style: Object.assign({ + listStyle: 'none', + padding: '8px 0px 8px 0px', + fontSize: '18px', + fontStyle: 'normal', + fontFamily: 'Montserrat Regular', + cursor: 'pointer', + display: 'flex', + justifyContent: 'flex-start', + alignItems: 'center', + }, style), + }, + children + ) + } +} + +DropdownMenuItem.propTypes = { + closeMenu: PropTypes.func.isRequired, + onClick: PropTypes.func.isRequired, + children: PropTypes.node, +} + +module.exports = { + Dropdown, + DropdownMenuItem, +} |