Browse Source

Re-use our input component for apps list

master
meriadec 7 years ago
parent
commit
c596982a57
No known key found for this signature in database GPG Key ID: 1D2FC2305E2CB399
  1. 91
      src/components/ManagerPage/AppSearchBar.js
  2. 28
      src/components/ManagerPage/AppsList.js

91
src/components/ManagerPage/AppSearchBar.js

@ -1,14 +1,12 @@
// @flow
import React, { PureComponent } from 'react'
import styled from 'styled-components'
import { color, fontSize, space } from 'styled-system'
import fontFamily from 'styles/styled/fontFamily'
import type { LedgerScriptParams } from 'helpers/common'
import React, { PureComponent, Fragment } from 'react'
import { ff } from 'styles/helpers'
import type { LedgerScriptParams } from 'helpers/common'
import Box from 'components/base/Box'
import Space from 'components/base/Space'
import Input from 'components/base/Input'
import Search from 'components/base/Search'
import SearchIcon from 'icons/Search'
@ -24,53 +22,13 @@ type State = {
focused: boolean,
}
const SearchBarWrapper = styled(Box).attrs({
horizontal: true,
borderRadius: 4,
})`
height: 42px;
width: 100%;
margin: 0 0 20px 0;
background-color: white;
padding: 0 13px;
${p =>
p.focused
? `
border: 1px solid #6490f1;
`
: 'border: 1px solid white;'};
`
const Input = styled.input.attrs({
ff: 'Open Sans|SemiBold',
color: 'dark',
mx: 3,
fontSize: 4,
})`
${space};
${fontFamily};
${fontSize};
${color};
border: 0;
flex: 1;
outline: none;
background: transparent;
&::placeholder {
color: ${p => p.theme.colors.fog};
${() => ff('Open Sans|Regular')};
}
`
class AppSearchBar extends PureComponent<Props, State> {
state = {
query: '',
focused: false,
}
handleChange = (e: any) => this.setState({ query: e.target.value })
handleChange = (query: string) => this.setState({ query })
handleFocus = (bool: boolean) => () => this.setState({ focused: bool })
@ -88,20 +46,29 @@ class AppSearchBar extends PureComponent<Props, State> {
const color = focused ? 'black' : 'grey'
return (
<Box>
<SearchBarWrapper align="center" focused={focused}>
<SearchIcon size={16} style={{ color }} />
<Input
innerRef={c => (this.input = c)}
type="text"
value={query}
onChange={this.handleChange}
onFocus={this.handleFocus(true)}
onBlur={this.handleFocus(false)}
placeholder={'Search app'}
/>
{!!query && <CrossIcon size={16} cursor="pointer" onClick={this.reset} />}
</SearchBarWrapper>
<Fragment>
<Input
innerRef={c => (this.input = c)}
type="text"
value={query}
onChange={this.handleChange}
onFocus={this.handleFocus(true)}
onBlur={this.handleFocus(false)}
placeholder={'Search app'}
renderLeft={
<Box pl={3} justify="center">
<SearchIcon size={16} style={{ color }} />
</Box>
}
renderRight={
query ? (
<Box justify="center" cursor="pointer" onClick={this.reset} px={3}>
<CrossIcon size={16} />
</Box>
) : null
}
/>
<Space of={30} />
<Search
fuseOptions={{
threshold: 0.5,
@ -111,7 +78,7 @@ class AppSearchBar extends PureComponent<Props, State> {
items={list}
render={items => children(items)}
/>
</Box>
</Fragment>
)
}
}

28
src/components/ManagerPage/AppsList.js

@ -21,7 +21,7 @@ import Spinner from 'components/base/Spinner'
import Button from 'components/base/Button'
import TranslatedError from 'components/TranslatedError'
import ExclamationCircle from 'icons/ExclamationCircle'
import IconInfoCircle from 'icons/InfoCircle'
import ExclamationCircleThin from 'icons/ExclamationCircleThin'
import Update from 'icons/Update'
import Trash from 'icons/Trash'
@ -246,19 +246,19 @@ class AppsList extends PureComponent<Props, State> {
return (
<Box flow={6}>
<Box>
<Box mb={4} color="dark" ff="Museo Sans" fontSize={5} flow={2} horizontal>
<span>{t('app:manager.apps.all')}</span>
<span>
<Tooltip
render={() => (
<Box ff="Open Sans|SemiBold" fontSize={2}>
{t('app:manager.apps.help')}
</Box>
)}
>
<ExclamationCircle size={12} />
</Tooltip>
</span>
<Box mb={4} color="dark" ff="Museo Sans" fontSize={5} flow={2} horizontal align="center">
<span style={{ lineHeight: 1 }}>{t('app:manager.apps.all')}</span>
<Tooltip
render={() => (
<Box ff="Open Sans|SemiBold" fontSize={2}>
{t('app:manager.apps.help')}
</Box>
)}
>
<Box color="grey">
<IconInfoCircle size={12} />
</Box>
</Tooltip>
</Box>
{this.renderList()}
</Box>

Loading…
Cancel
Save