Browse Source

Add some translations

master
meriadec 7 years ago
parent
commit
d7545d06fd
No known key found for this signature in database GPG Key ID: 1D2FC2305E2CB399
  1. 11
      src/components/AccountPage.js
  2. 18
      src/components/IsUnlocked/index.js
  3. 13
      src/components/UpdateNotifier.js
  4. 2
      src/components/Wrapper.js
  5. 23
      src/components/modals/AddAccount/index.js
  6. 14
      static/i18n/en/translation.yml
  7. 14
      static/i18n/fr/translation.yml

11
src/components/AccountPage.js

@ -82,18 +82,23 @@ class AccountPage extends PureComponent<Props> {
<Fragment>
<Box horizontal flow={3}>
<Box grow>
<Card title="Balance" style={{ height: 435 }} align="center" justify="center">
<Card
title={t('AccountPage.balance')}
style={{ height: 435 }}
align="center"
justify="center"
>
<Text fontSize={5}>{formatBTC(accountData.balance)}</Text>
</Card>
</Box>
<Box style={{ width: 300 }}>
<Card title="Receive" flow={3}>
<Card title={t('AccountPage.receive')} flow={3}>
<ReceiveBox address={accountData.address} />
</Card>
</Box>
</Box>
<Card title="Last operations">
<Card title={t('AccountPage.lastOperations')}>
<TransactionsList transactions={accountData.transactions} />
</Card>
</Fragment>

18
src/components/IsUnlocked/index.js

@ -2,10 +2,12 @@
import React, { PureComponent } from 'react'
import { connect } from 'react-redux'
import { compose } from 'redux'
import { translate } from 'react-i18next'
import bcrypt from 'bcryptjs'
import type { MapStateToProps } from 'react-redux'
import type { Settings, Accounts } from 'types/common'
import type { Settings, Accounts, T } from 'types/common'
import get from 'lodash/get'
@ -24,6 +26,7 @@ type InputValue = {
}
type Props = {
t: T,
accounts: Accounts,
fetchAccounts: Function,
isLocked: boolean,
@ -108,7 +111,7 @@ class IsUnlocked extends PureComponent<Props, State> {
render() {
const { inputValue } = this.state
const { isLocked, render } = this.props
const { isLocked, render, t } = this.props
if (isLocked) {
return (
@ -118,7 +121,7 @@ class IsUnlocked extends PureComponent<Props, State> {
<Input
autoFocus
innerRef={(n: any) => (this._input = n)}
placeholder="Password"
placeholder={t('IsUnlocked.password')}
type="password"
onChange={this.handleChangeInput('password')}
value={inputValue.password}
@ -133,6 +136,9 @@ class IsUnlocked extends PureComponent<Props, State> {
}
}
export default connect(mapStateToProps, mapDispatchToProps, null, {
pure: false,
})(IsUnlocked)
export default compose(
connect(mapStateToProps, mapDispatchToProps, null, {
pure: false,
}),
translate(),
)(IsUnlocked)

13
src/components/UpdateNotifier.js

@ -1,6 +1,8 @@
// @flow
import React, { PureComponent } from 'react'
import { translate } from 'react-i18next'
import { compose } from 'redux'
import { Motion, spring } from 'react-motion'
import { connect } from 'react-redux'
import type { MapStateToProps } from 'react-redux'
@ -14,7 +16,10 @@ import type { UpdateStatus } from 'reducers/update'
import Box from 'components/base/Box'
import Text from 'components/base/Text'
import type { T } from 'types/common'
type Props = {
t: T,
updateStatus: UpdateStatus,
}
@ -40,7 +45,7 @@ const Container = styled(Box).attrs({
class UpdateNotifier extends PureComponent<Props> {
renderStatus() {
const { updateStatus } = this.props
const { updateStatus, t } = this.props
switch (updateStatus) {
case 'idle':
case 'checking':
@ -52,12 +57,12 @@ class UpdateNotifier extends PureComponent<Props> {
case 'downloaded':
return (
<Box horizontal flow={2}>
<Text fontWeight="bold">{'A new version is ready to be installed.'}</Text>
<Text fontWeight="bold">{t('update.newVersionReady')}</Text>
<Text
style={{ cursor: 'pointer' }}
onClick={() => sendEvent('msg', 'updater.quitAndInstall')}
>
{'Re-launch app now'}
{t('update.relaunch')}
</Text>
</Box>
)
@ -82,4 +87,4 @@ class UpdateNotifier extends PureComponent<Props> {
}
}
export default connect(mapStateToProps, null)(UpdateNotifier)
export default compose(connect(mapStateToProps, null), translate())(UpdateNotifier)

2
src/components/Wrapper.js

@ -36,7 +36,7 @@ class Wrapper extends Component<{}> {
<Box shrink grow bg="cream" color="grey" relative>
<TopBar />
{__PROD__ && <UpdateNotifier />}
<UpdateNotifier />
<GrowScroll p={3} style={{ paddingTop: 80 }}>
<Route path="/" exact component={DashboardPage} />
<Route path="/settings" component={SettingsPage} />

23
src/components/modals/AddAccount/index.js

@ -2,12 +2,14 @@
import React, { PureComponent } from 'react'
import { connect } from 'react-redux'
import { compose } from 'redux'
import { translate } from 'react-i18next'
import { ipcRenderer } from 'electron'
import { MODAL_ADD_ACCOUNT } from 'constants'
import type { MapStateToProps } from 'react-redux'
import type { Accounts, Device } from 'types/common'
import type { Accounts, Device, T } from 'types/common'
import { closeModal } from 'reducers/modals'
import { canCreateAccount, getAccounts } from 'reducers/accounts'
@ -38,9 +40,9 @@ const Steps = {
<form onSubmit={props.onSubmit}>
<Box flow={3}>
<Box flow={1}>
<Label>Currency</Label>
<Label>{props.t('common.currency')}</Label>
<Select
placeholder="Choose a wallet..."
placeholder={props.t('common.chooseWalletPlaceholder')}
onChange={item => props.onChangeInput('wallet')(item.key)}
renderSelected={item => item.name}
items={currencies}
@ -49,7 +51,7 @@ const Steps = {
</Box>
<Box horizontal justify="flex-end">
<Button primary type="submit">
Add account
{props.t('addAccount.title')}
</Button>
</Box>
</Box>
@ -97,12 +99,14 @@ type InputValue = {
type Step = 'chooseWallet' | 'connectDevice' | 'inProgress' | 'listAccounts'
type Props = {
t: T,
accounts: Accounts,
addAccount: Function,
canCreateAccount: boolean,
closeModal: Function,
currentDevice: Device | null,
}
type State = {
inputValue: InputValue,
step: Step,
@ -184,25 +188,29 @@ class AddAccountModal extends PureComponent<Props, State> {
}
getStepProps() {
const { currentDevice, canCreateAccount } = this.props
const { currentDevice, canCreateAccount, t } = this.props
const { inputValue, step, progress, accounts } = this.state
const props = (predicate, props) => (predicate ? props : {})
return {
...props(step === 'chooseWallet', {
t,
value: inputValue,
onSubmit: this.handleSubmit,
onChangeInput: this.handleChangeInput,
}),
...props(step === 'connectDevice', {
t,
connected: currentDevice !== null,
wallet: inputValue.wallet,
}),
...props(step === 'inProgress', {
t,
progress,
}),
...props(step === 'listAccounts', {
t,
accounts,
canCreateAccount,
onAddAccount: this.handleAddAccount,
@ -280,6 +288,7 @@ class AddAccountModal extends PureComponent<Props, State> {
render() {
const { step } = this.state
const { t } = this.props
const Step = Steps[step]
@ -291,7 +300,7 @@ class AddAccountModal extends PureComponent<Props, State> {
render={({ onClose }) => (
<ModalBody onClose={onClose} flow={3}>
<Text fontSize={4} color="steel">
{'Add account'}
{t('addAccount.title')}
</Text>
<Step {...this.getStepProps()} />
</ModalBody>
@ -301,4 +310,4 @@ class AddAccountModal extends PureComponent<Props, State> {
}
}
export default connect(mapStateToProps, mapDispatchToProps)(AddAccountModal)
export default compose(connect(mapStateToProps, mapDispatchToProps), translate())(AddAccountModal)

14
static/i18n/en/translation.yml

@ -1,6 +1,8 @@
common:
ok: Okay
cancel: Cancel
chooseWalletPlaceholder: Choose a wallet...
currency: Currency
language:
en: English
@ -46,3 +48,15 @@ settings:
SelectAccount:
placeholder: Select a account
AccountPage:
balance: Balance
receive: Receive
lastOperations: Last operations
update:
newVersionReady: A new version is ready to be installed.
relaunch: Re-launch app now
IsUnlocked:
password: Password

14
static/i18n/fr/translation.yml

@ -1,6 +1,8 @@
common:
ok: Okay
cancel: Annuler
chooseWalletPlaceholder: Choisir un portefeuille...
currency: Monnaie
language:
en: Anglais
@ -46,3 +48,15 @@ settings:
SelectAccount:
placeholder: Sélectionner un compte
AccountPage:
balance: Balance
receive: Recevoir
lastOperations: Dernières opérations
update:
newVersionReady: Une nouvelle version est prête à être installée
relaunch: Redémarrer l'application maintenant
IsUnlocked:
password: Mot de passe

Loading…
Cancel
Save