From 2398228cb5eb836b0f1654d63e5bfd12c2e192b8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ga=C3=ABtan=20Renaudeau?= Date: Sun, 17 Jun 2018 19:19:04 +0200 Subject: [PATCH] remove LegacySelect NB: when using select, don't .map() to generate options. just pass-in the array and implement the getOptionValue --- src/components/SelectAccount/index.js | 8 +- src/components/base/InputCurrency/index.js | 26 +- src/components/base/LegacySelect/index.js | 347 ------------------ src/components/base/LegacySelect/stories.js | 117 ------ src/components/base/Select/index.js | 4 +- .../modals/AccountSettingRenderBody.js | 14 +- 6 files changed, 26 insertions(+), 490 deletions(-) delete mode 100644 src/components/base/LegacySelect/index.js delete mode 100644 src/components/base/LegacySelect/stories.js diff --git a/src/components/SelectAccount/index.js b/src/components/SelectAccount/index.js index 50220742..3c1fe001 100644 --- a/src/components/SelectAccount/index.js +++ b/src/components/SelectAccount/index.js @@ -56,14 +56,16 @@ type Props = { t: T, } +const getOptionValue = account => account.id + const RawSelectAccount = ({ accounts, onChange, value, t, ...props }: Props) => { - const options = accounts.map(a => ({ ...a, value: a.id, label: a.name })) - const selectedOption = value ? options.find(o => o.value === value.id) : null + const selectedOption = value ? accounts.find(o => o.id === value.id) : null return ( diff --git a/src/components/base/LegacySelect/index.js b/src/components/base/LegacySelect/index.js deleted file mode 100644 index 7dd4745a..00000000 --- a/src/components/base/LegacySelect/index.js +++ /dev/null @@ -1,347 +0,0 @@ -// @flow - -import React, { PureComponent } from 'react' -import Downshift from 'downshift' -import styled from 'styled-components' -import { space } from 'styled-system' -import { translate } from 'react-i18next' - -import type { T } from 'types/common' - -import Box from 'components/base/Box' -import GrowScroll from 'components/base/GrowScroll' -import Input from 'components/base/Input' -import Search from 'components/base/Search' -import Text from 'components/base/Text' - -import IconCheck from 'icons/Check' - -type Props = { - bg?: string, - flatLeft?: boolean, - flatRight?: boolean, - fakeFocusRight?: boolean, - fuseOptions?: Object, - highlight?: boolean, - items: Array, - itemToString?: Function, - keyProp?: string, - maxHeight?: number, - onChange?: Function, - placeholder?: string, - renderHighlight?: string => React$Node, - renderItem?: (*) => React$Node, - renderSelected?: any => React$Node, - searchable?: boolean, - value?: *, - disabled: boolean, - small?: boolean, - t: T, -} - -const Container = styled(Box).attrs({ relative: true, color: 'graphite' })`` - -const TriggerBtn = styled(Box).attrs({ - alignItems: 'center', - ff: p => (p.small ? 'Open Sans' : 'Open Sans|SemiBold'), - flow: 2, - fontSize: p => (p.small ? 3 : 4), - horizontal: true, - px: 3, -})` - ${space}; - height: ${p => (p.small ? '34' : '40')}px; - background: ${p => (p.disabled ? p.theme.colors.lightGrey : p.bg || p.theme.colors.white)}; - border-bottom-left-radius: ${p => (p.flatLeft ? 0 : p.theme.radii[1])}px; - border-bottom-right-radius: ${p => (p.flatRight ? 0 : p.theme.radii[1])}px; - border-top-left-radius: ${p => (p.flatLeft ? 0 : p.theme.radii[1])}px; - border-top-right-radius: ${p => (p.flatRight ? 0 : p.theme.radii[1])}px; - border: 1px solid ${p => p.theme.colors.fog}; - color: ${p => p.theme.colors.graphite}; - cursor: ${p => (p.disabled ? 'cursor' : 'pointer')}; - display: flex; - width: 100%; - - &:focus { - outline: none; - ${p => - p.disabled - ? '' - : ` - border-color: ${p.theme.colors.wallet}; - box-shadow: rgba(0, 0, 0, 0.05) 0 2px 2px;`}; - } - - ${p => { - const c = p.theme.colors.wallet - return p.fakeFocusRight - ? ` - border-top: 1px solid ${c}; - border-right: 1px solid ${c}; - border-bottom: 1px solid ${c}; - ` - : '' - }}; -` - -const Item = styled(Box).attrs({ - alignItems: 'center', - fontSize: 4, - ff: p => `Open Sans|${p.selected ? 'SemiBold' : 'Regular'}`, - px: 3, - py: 2, - color: 'dark', -})` - background: ${p => (p.highlighted ? p.theme.colors.lightGrey : p.theme.colors.white)}; - - ${p => - p.first && - ` - border-top-left-radius: ${p.theme.radii[1]}px; - border-top-right-radius: ${p.theme.radii[1]}px; - `} ${p => - p.last && - ` - border-bottom-left-radius: ${p.theme.radii[1]}px; - border-bottom-right-radius: ${p.theme.radii[1]}px; - `}; -` - -const Dropdown = styled(Box).attrs({ - mt: 1, -})` - border-radius: ${p => p.theme.radii[1]}px; - border: 1px solid ${p => p.theme.colors.fog}; - box-shadow: rgba(0, 0, 0, 0.05) 0 2px 2px; - left: 0; - position: absolute; - right: 0; - top: 100%; - z-index: 1; -` - -const IconSelected = styled(Box).attrs({ - color: 'wallet', - alignItems: 'center', - justifyContent: 'center', -})` - height: 12px; - width: 12px; - opacity: ${p => (p.selected ? 1 : 0)}; -` - -const AngleDown = props => ( - - - - - -) - -const renderSelectedItem = ({ selectedItem, renderSelected, placeholder }: any) => - selectedItem && renderSelected ? ( - renderSelected(selectedItem) - ) : ( - {placeholder} - ) - -class LegacySelect extends PureComponent { - static defaultProps = { - bg: undefined, - disabled: false, - small: false, - fakeFocusRight: false, - flatLeft: false, - flatRight: false, - itemToString: (item: Object) => item && item.name, - keyProp: undefined, - maxHeight: 300, - } - - _scrollToSelectedItem = true - _oldHighlightedIndex = 0 - _useKeyboard = false - _children = {} - - renderItems = (items: Array, selectedItem: any, downshiftProps: Object) => { - const { renderItem, maxHeight, keyProp, t } = this.props - const { getItemProps, highlightedIndex } = downshiftProps - - const selectedItemIndex = items.indexOf(selectedItem) - - return ( - - {items.length ? ( - { - const currentHighlighted = this._children[highlightedIndex] - const currentSelectedItem = this._children[selectedItemIndex] - - if (this._useKeyboard && currentHighlighted) { - scrollbar.scrollIntoView(currentHighlighted, { - alignToTop: highlightedIndex < this._oldHighlightedIndex, - offsetTop: -1, - onlyScrollIfNeeded: true, - }) - } else if (this._scrollToSelectedItem && currentSelectedItem) { - window.requestAnimationFrame(() => - scrollbar.scrollIntoView(currentSelectedItem, { - offsetTop: -1, - }), - ) - - this._scrollToSelectedItem = false - } - - this._oldHighlightedIndex = highlightedIndex - }} - > - {items.map((item, i) => ( - (this._children[i] = n)} - {...getItemProps({ item })} - > - - - {renderItem ? ( - renderItem(item) - ) : ( - {item.name_highlight || item.name} - )} - - - - - - - - - ))} - - ) : ( - - {t('app:error.noResults')} - - )} - - ) - } - - render() { - const { - disabled, - fakeFocusRight, - flatLeft, - flatRight, - fuseOptions, - highlight, - items, - itemToString, - onChange, - placeholder, - renderHighlight, - renderSelected, - searchable, - value, - small, - ...props - } = this.props - - return ( - { - if (!isOpen) { - this._scrollToSelectedItem = true - } - - if (disabled) { - return ( - - - {renderSelectedItem({ selectedItem, renderSelected, placeholder })} - - - ) - } - - return ( - (this._useKeyboard = true)} - onKeyUp={() => (this._useKeyboard = false)} - > - {searchable ? ( - - } - {...getInputProps({ placeholder })} - /> - - ) : ( - - - {renderSelectedItem({ selectedItem, renderSelected, placeholder })} - - - - )} - - - ) - }} - /> - ) - } -} - -export default translate()(LegacySelect) diff --git a/src/components/base/LegacySelect/stories.js b/src/components/base/LegacySelect/stories.js deleted file mode 100644 index a5b2d475..00000000 --- a/src/components/base/LegacySelect/stories.js +++ /dev/null @@ -1,117 +0,0 @@ -// @flow - -import React, { PureComponent } from 'react' -import { storiesOf } from '@storybook/react' -import { boolean } from '@storybook/addon-knobs' - -import Box from 'components/base/Box' -import LegacySelect from 'components/base/LegacySelect' -import Text from 'components/base/Text' - -const stories = storiesOf('Components/base/LegacySelect', module) - -const itemsChessPlayers = [ - { key: 'aleksandr-grichtchouk', name: 'Aleksandr Grichtchouk' }, - { key: 'fabiano-caruana', name: 'Fabiano Caruana' }, - { key: 'garry-kasparov', name: 'Garry Kasparov' }, - { key: 'hikaru-nakamura', name: 'Hikaru Nakamura' }, - { key: 'levon-aronian', name: 'Levon Aronian' }, - { key: 'magnus-carlsen', name: 'Magnus Carlsen' }, - { key: 'maxime-vachier-lagrave', name: 'Maxime Vachier-Lagrave' }, - { key: 'shakhriyar-mamedyarov', name: 'Shakhriyar Mamedyarov' }, - { key: 'veselin-topalov', name: 'Veselin Topalov' }, - { key: 'viswanathan-anand', name: 'Viswanathan Anand' }, - { key: 'vladimir-kramnik', name: 'Vladimir Kramnik' }, -] - -type State = { - item: Object | null, -} - -class Wrapper extends PureComponent { - state = { - item: null, - } - - handleChange = item => this.setState({ item }) - - render() { - const { children } = this.props - const { item } = this.state - return ( -
- {children(this.handleChange)} - {item && ( - -
-              {'You selected:'}
-              {JSON.stringify(item)}
-            
-
- )} -
- ) - } -} - -stories.add('basic', () => ( - - {onChange => ( - item.name} - onChange={onChange} - /> - )} - -)) - -stories.add('searchable', () => ( - (item ? item.name : '')} - renderHighlight={(text, key) => ( - - {text} - - )} - /> -)) - -const itemsColors = [ - { key: 'absolute zero', name: 'Absolute Zero', color: '#0048BA' }, - { key: 'acid green', name: 'Acid Green', color: '#B0BF1A' }, - { key: 'aero', name: 'Aero', color: '#7CB9E8' }, - { key: 'aero blue', name: 'Aero Blue', color: '#C9FFE5' }, - { key: 'african violet', name: 'African Violet', color: '#B284BE' }, - { key: 'air force blue (usaf)', name: 'Air Force Blue (USAF)', color: '#00308F' }, - { key: 'air superiority blue', name: 'Air Superiority Blue', color: '#72A0C1' }, -] - -stories.add('custom render', () => ( - (item ? item.name : '')} - renderHighlight={(text, key) => ( - - {text} - - )} - renderItem={item => ( - - - {item.name_highlight || item.name} - - )} - /> -)) diff --git a/src/components/base/Select/index.js b/src/components/base/Select/index.js index f5c5e232..9de8bad0 100644 --- a/src/components/base/Select/index.js +++ b/src/components/base/Select/index.js @@ -1,6 +1,6 @@ // @flow -import React, { Component } from 'react' +import React, { PureComponent } from 'react' import ReactSelect from 'react-select' import { translate } from 'react-i18next' @@ -34,7 +34,7 @@ export type Option = { data: any, } -class Select extends Component { +class Select extends PureComponent { handleChange = (value, { action }) => { const { onChange } = this.props if (action === 'select-option') { diff --git a/src/components/modals/AccountSettingRenderBody.js b/src/components/modals/AccountSettingRenderBody.js index 95bb68fa..8e02f6b0 100644 --- a/src/components/modals/AccountSettingRenderBody.js +++ b/src/components/modals/AccountSettingRenderBody.js @@ -19,7 +19,8 @@ import CryptoCurrencyIcon from 'components/CryptoCurrencyIcon' import Box from 'components/base/Box' import Button from 'components/base/Button' import Input from 'components/base/Input' -import Select from 'components/base/LegacySelect' +import Select from 'components/base/Select' + import { ModalBody, ModalTitle, @@ -44,6 +45,9 @@ type Props = { data: any, } +const unitGetOptionValue = unit => unit.magnitude +const renderUnitItemCode = item => item.data.code + const mapDispatchToProps = { setDataModal, updateAccount, @@ -166,12 +170,12 @@ class HelperComp extends PureComponent {