summaryrefslogtreecommitdiffhomepage
path: root/app/components/Account.js
blob: 4ec57aaf1ed63d59d69032587396e7058f62dd4e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
// @flow
import moment from 'moment';
import React from 'react';
import { Component, Text, View } from 'reactxp';
import { Button, RedButton, GreenButton, Label } from './styled';
import { Layout, Container } from './Layout';
import styles from './AccountStyles';
import Img from './Img';
import { formatAccount } from '../lib/formatters';

import type { AccountReduxState } from '../redux/account/reducers';

export type AccountProps = {
  account: AccountReduxState;
  onLogout: () => void;
  onClose: () => void;
  onBuyMore: () => void;
};

export default class Account extends Component {
  props: AccountProps;

  render() {
    const expiry = moment(this.props.account.expiry);
    const formattedAccountToken = formatAccount(this.props.account.accountToken || '');
    const formattedExpiry = expiry.format('hA, D MMMM YYYY').toUpperCase();
    const isOutOfTime = expiry.isSameOrBefore(moment());

    return (
      <Layout>
        <Container>
          <View style={styles.account}>
            <Button style={styles.account__close}
              onPress={ this.props.onClose }
              testName='account__close'>
              <Img height={24} width={24} style={styles.account__close_icon} source="icon-back" />
              <Text style={styles.account__close_title}>Settings</Text>
            </Button>
            <View style={styles.account__container}>

              <View style={styles.account__header}>
                <Text style={styles.account__title}>Account</Text>
              </View>

              <View style={styles.account__content}>
                <View style={styles.account__main}>

                  <View style={styles.account__row}>
                    <Text style={styles.account__row_label}>Account ID</Text>
                    <Text style={styles.account__row_value}>{ formattedAccountToken }</Text>
                  </View>

                  <View style={styles.account__row}>
                    <Text style={styles.account__row_label}>Paid until</Text>
                    { isOutOfTime ?
                      <Text style={styles.account__out_of_time} testName='account__out_of_time'>OUT OF TIME</Text>
                      :
                      <Text style={styles.account__row_value}>{ formattedExpiry }</Text>
                    }
                  </View>

                  <View style={styles.account__footer}>
                    <GreenButton
                      onPress={ this.props.onBuyMore }
                      text='Buy more credit'
                      icon='icon-extLink'
                      testName='account__buymore'>
                      <Label>Buy more credit</Label>
                      <Img source='icon-extLink' height={16} width={16} />
                    </GreenButton>
                    <RedButton
                      onPress={ this.props.onLogout }
                      testName='account__logout'>
                      Log out
                    </RedButton>
                  </View>

                </View>
              </View>
            </View>
          </View>
        </Container>
      </Layout>
    );
  }
}