|
@ -15,7 +15,6 @@ import { developerModeSelector } from 'reducers/settings' |
|
|
import installApp from 'commands/installApp' |
|
|
import installApp from 'commands/installApp' |
|
|
import uninstallApp from 'commands/uninstallApp' |
|
|
import uninstallApp from 'commands/uninstallApp' |
|
|
import Box from 'components/base/Box' |
|
|
import Box from 'components/base/Box' |
|
|
import Space from 'components/base/Space' |
|
|
|
|
|
import Modal, { ModalBody, ModalFooter, ModalTitle, ModalContent } from 'components/base/Modal' |
|
|
import Modal, { ModalBody, ModalFooter, ModalTitle, ModalContent } from 'components/base/Modal' |
|
|
import Tooltip from 'components/base/Tooltip' |
|
|
import Tooltip from 'components/base/Tooltip' |
|
|
import Text from 'components/base/Text' |
|
|
import Text from 'components/base/Text' |
|
@ -39,15 +38,35 @@ const mapStateToProps = state => ({ |
|
|
|
|
|
|
|
|
const List = styled(Box).attrs({ |
|
|
const List = styled(Box).attrs({ |
|
|
horizontal: true, |
|
|
horizontal: true, |
|
|
m: -3, |
|
|
|
|
|
})` |
|
|
})` |
|
|
flex-wrap: wrap; |
|
|
flex-wrap: wrap; |
|
|
|
|
|
|
|
|
|
|
|
> * { |
|
|
|
|
|
width: calc(50% - 10px); |
|
|
|
|
|
margin-bottom: 20px; |
|
|
|
|
|
&:nth-child(even) { |
|
|
|
|
|
margin-left: 20px; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@media (max-width: 1000px) { |
|
|
|
|
|
width: 100%; |
|
|
|
|
|
&:nth-child(even) { |
|
|
|
|
|
margin-left: 0; |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
` |
|
|
` |
|
|
|
|
|
|
|
|
const ICONS_FALLBACK = { |
|
|
const ICONS_FALLBACK = { |
|
|
bitcoin_testnet: 'bitcoin', |
|
|
bitcoin_testnet: 'bitcoin', |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
const CATALOG_INFO_ICON = ( |
|
|
|
|
|
<Box color="grey"> |
|
|
|
|
|
<IconInfoCircle size={12} /> |
|
|
|
|
|
</Box> |
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
type Status = 'loading' | 'idle' | 'busy' | 'success' | 'error' |
|
|
type Status = 'loading' | 'idle' | 'busy' | 'success' | 'error' |
|
|
type Mode = 'home' | 'installing' | 'uninstalling' |
|
|
type Mode = 'home' | 'installing' | 'uninstalling' |
|
|
|
|
|
|
|
@ -79,6 +98,20 @@ const LoadingApp = () => ( |
|
|
|
|
|
|
|
|
const loadingApp = <LoadingApp /> |
|
|
const loadingApp = <LoadingApp /> |
|
|
|
|
|
|
|
|
|
|
|
const FAKE_LIST = ( |
|
|
|
|
|
<List> |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
</List> |
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
class AppsList extends PureComponent<Props, State> { |
|
|
class AppsList extends PureComponent<Props, State> { |
|
|
state = { |
|
|
state = { |
|
|
status: 'loading', |
|
|
status: 'loading', |
|
@ -276,48 +309,30 @@ class AppsList extends PureComponent<Props, State> { |
|
|
)} |
|
|
)} |
|
|
</AppSearchBar> |
|
|
</AppSearchBar> |
|
|
{this.renderModal()} |
|
|
{this.renderModal()} |
|
|
{!appsLoaded && ( |
|
|
{!appsLoaded && FAKE_LIST} |
|
|
<Fragment> |
|
|
|
|
|
<Space of={30} /> |
|
|
|
|
|
<List> |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
{loadingApp} |
|
|
|
|
|
</List> |
|
|
|
|
|
</Fragment> |
|
|
|
|
|
)} |
|
|
|
|
|
</Box> |
|
|
</Box> |
|
|
) |
|
|
) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
render() { |
|
|
renderTooltip = () => { |
|
|
const { t } = this.props |
|
|
const { t } = this.props |
|
|
return ( |
|
|
return ( |
|
|
<Box flow={6}> |
|
|
|
|
|
<Box> |
|
|
|
|
|
<Box mb={4} color="dark" ff="Museo Sans" fontSize={5} flow={2} horizontal align="center"> |
|
|
|
|
|
<span style={{ lineHeight: 1 }}>{t('manager.apps.all')}</span> |
|
|
|
|
|
<Tooltip |
|
|
|
|
|
render={() => ( |
|
|
|
|
|
<Box ff="Open Sans|SemiBold" fontSize={2}> |
|
|
<Box ff="Open Sans|SemiBold" fontSize={2}> |
|
|
{t('manager.apps.help')} |
|
|
{t('manager.apps.help')} |
|
|
</Box> |
|
|
</Box> |
|
|
)} |
|
|
) |
|
|
> |
|
|
} |
|
|
<Box color="grey"> |
|
|
|
|
|
<IconInfoCircle size={12} /> |
|
|
render() { |
|
|
</Box> |
|
|
const { t } = this.props |
|
|
</Tooltip> |
|
|
return ( |
|
|
|
|
|
<Box> |
|
|
|
|
|
<Box mb={4} color="dark" ff="Museo Sans" fontSize={5} flow={2} horizontal align="center"> |
|
|
|
|
|
<span>{t('manager.apps.all')}</span> |
|
|
|
|
|
<Tooltip render={this.renderTooltip}>{CATALOG_INFO_ICON}</Tooltip> |
|
|
</Box> |
|
|
</Box> |
|
|
{this.renderList()} |
|
|
{this.renderList()} |
|
|
</Box> |
|
|
</Box> |
|
|
</Box> |
|
|
|
|
|
) |
|
|
) |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|