Browse Source

Integrate font-awesome. Use it in SideBar.

master
meriadec 7 years ago
parent
commit
502c8bba67
No known key found for this signature in database GPG Key ID: 1D2FC2305E2CB399
  1. 12
      src/components/SideBar/Item.js
  2. 16
      src/components/SideBar/index.js
  3. 16
      src/components/base/Icon.js
  4. 8
      src/renderer/head.js
  5. 1
      src/renderer/index.js

12
src/components/SideBar/Item.js

@ -15,6 +15,7 @@ import type { Location } from 'react-router'
import Box from 'components/base/Box' import Box from 'components/base/Box'
import Text from 'components/base/Text' import Text from 'components/base/Text'
import Icon from 'components/base/Icon'
const mapStateToProps: MapStateToProps<*, *, *> = (state, { modal }: any) => ({ const mapStateToProps: MapStateToProps<*, *, *> = (state, { modal }: any) => ({
// connect router here only to make components re-render // connect router here only to make components re-render
@ -33,6 +34,7 @@ const Container = styled(Box).attrs({
align: 'center', align: 'center',
color: 'lead', color: 'lead',
p: 2, p: 2,
flow: 2,
})` })`
cursor: pointer; cursor: pointer;
color: ${p => (p.isActive ? p.theme.colors.white : '')}; color: ${p => (p.isActive ? p.theme.colors.white : '')};
@ -46,12 +48,6 @@ const Container = styled(Box).attrs({
} }
` `
const IconWrapper = styled(Box)`
width: 25px;
height: 25px;
border: 2px solid ${p => (p.isActive ? p.theme.colors.blue : 'rgba(255, 255, 255, 0.1)')};
`
type Props = { type Props = {
children: string, children: string,
linkTo?: string | null, linkTo?: string | null,
@ -86,9 +82,7 @@ function Item({
} }
isActive={isActive} isActive={isActive}
> >
<IconWrapper isActive={isActive} mr={2}> {icon && <Icon fontSize={3} color={isActive ? 'blue' : void 0} name={icon} />}
{icon || null}
</IconWrapper>
<div> <div>
<Text fontWeight="bold" fontSize={1}> <Text fontWeight="bold" fontSize={1}>
{children} {children}

16
src/components/SideBar/index.js

@ -67,10 +67,18 @@ class SideBar extends PureComponent<Props> {
<Box flow={2}> <Box flow={2}>
<CapsSubtitle>{'Menu'}</CapsSubtitle> <CapsSubtitle>{'Menu'}</CapsSubtitle>
<div> <div>
<Item linkTo="/">{'Dashboard'}</Item> <Item icon="bar-chart" linkTo="/">
<Item modal="send">{'Send'}</Item> {'Dashboard'}
<Item modal="receive">{'Receive'}</Item> </Item>
<Item linkTo="/settings">{'Settings'}</Item> <Item icon="upload" modal="send">
{'Send'}
</Item>
<Item icon="download" modal="receive">
{'Receive'}
</Item>
<Item icon="cog" linkTo="/settings">
{'Settings'}
</Item>
</div> </div>
</Box> </Box>
<Box flow={2}> <Box flow={2}>

16
src/components/base/Icon.js

@ -0,0 +1,16 @@
// @flow
import React from 'react'
import styled from 'styled-components'
import { fontSize, color } from 'styled-system'
const Container = styled.div`
${fontSize};
${color};
`
export default ({ name, ...props }: { name: string }) => (
<Container {...props}>
<i className={`fa fa-${name}`} />
</Container>
)

8
src/renderer/head.js

@ -0,0 +1,8 @@
const list = ['https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css']
list.forEach(href => {
const tag = document.createElement('link')
tag.setAttribute('rel', 'stylesheet')
tag.setAttribute('href', href)
document.head.appendChild(tag)
})

1
src/renderer/index.js

@ -17,6 +17,7 @@ import { getLanguage } from 'reducers/settings'
import App from 'components/App' import App from 'components/App'
import 'styles/global' import 'styles/global'
import 'renderer/head'
if (__PROD__ && __SENTRY_URL__) { if (__PROD__ && __SENTRY_URL__) {
Raven.config(__SENTRY_URL__, { allowSecretKey: true }).install() Raven.config(__SENTRY_URL__, { allowSecretKey: true }).install()

Loading…
Cancel
Save