├── .env ├── .eslintignore ├── .eslintrc.js ├── .gitignore ├── .prettierrc ├── README.md ├── config ├── env.js ├── jest │ ├── cssTransform.js │ └── fileTransform.js ├── paths.js ├── webpack.config.dev.js ├── webpack.config.prod.js └── webpackDevServer.config.js ├── package.json ├── pm2.json ├── public ├── assets │ └── images │ │ ├── bg-main.png │ │ ├── bg-sidebar.jpg │ │ ├── img-icon-success.svg │ │ └── logo.png ├── favicon.ico ├── index.html └── manifest.json ├── scripts ├── build.js ├── start.js └── test.js ├── server.js └── src ├── component ├── FormInput │ ├── index.js │ └── style.scss ├── Header │ └── index.js ├── Modal │ ├── ModalSuccessWrapper.js │ └── index.js ├── PoolKyc │ └── index.js ├── Sidebar │ └── index.js └── index.js ├── feature ├── App │ ├── Container.js │ ├── Routes.js │ ├── api.js │ └── index.js ├── ChangePassword │ ├── Container.js │ ├── api.js │ ├── component │ │ ├── Form │ │ │ ├── index.js │ │ │ └── validation.js │ │ └── Modal │ │ │ ├── ModalSuccess.js │ │ │ └── index.js │ └── index.js ├── ForgotPassword │ ├── Container.js │ ├── api.js │ ├── component │ │ ├── ForgotForm │ │ │ ├── index.js │ │ │ └── validation.js │ │ └── Modal │ │ │ ├── ModalSuccess.js │ │ │ └── index.js │ └── index.js ├── Kyc │ ├── Container.js │ ├── api.js │ ├── component │ │ └── KycFormRender │ │ │ └── index.js │ ├── index.js │ ├── redux │ │ ├── action.js │ │ └── reducer.js │ ├── style.scss │ └── util.js ├── Loading │ ├── Container.js │ ├── index.js │ ├── redux │ │ ├── action.js │ │ └── reducer.js │ └── style.scss ├── Login │ ├── Container.js │ ├── api.js │ ├── component │ │ ├── LoginForm │ │ │ ├── index.js │ │ │ └── validation.js │ │ └── Modal │ │ │ ├── ModalFails.js │ │ │ └── index.js │ ├── index.js │ └── redux │ │ ├── action.js │ │ └── reducer.js ├── Profile │ ├── Container.js │ └── index.js ├── Register │ ├── Container.js │ ├── api.js │ ├── component │ │ ├── Modal │ │ │ ├── ModalSuccess.js │ │ │ └── index.js │ │ └── RegisterForm │ │ │ ├── index.js │ │ │ └── validation.js │ └── index.js ├── ResetPassword │ ├── Container.js │ ├── api.js │ ├── component │ │ ├── Modal │ │ │ ├── ModalSuccess.js │ │ │ └── index.js │ │ └── ResetForm │ │ │ ├── index.js │ │ │ └── validation.js │ └── index.js └── index.js ├── index.js ├── lib ├── PoolKyc │ └── index.js ├── helper.js └── validation.js ├── reducer.js ├── scss ├── components │ ├── _component.activities.scss │ ├── _component.button.scss │ ├── _component.card.scss │ ├── _component.form.scss │ ├── _component.header.scss │ ├── _component.heading.scss │ ├── _component.loading.scss │ ├── _component.modal.scss │ ├── _component.panel.scss │ ├── _component.row.scss │ ├── _component.sidebar.scss │ └── _component.text.scss ├── elements │ ├── _element.link.scss │ └── _element.page.scss ├── generics │ ├── _generic.box-sizing.scss │ ├── _generic.normalize.scss │ └── _generic.reset.scss ├── index.scss ├── objects │ └── _objects.container.scss ├── settings │ └── _settings.core.scss ├── tools │ └── _tools.font-family.scss └── utilities │ ├── _utilities.hidden.scss │ └── _utilities.margin.scss ├── service ├── index.js ├── kycHttp.js └── urlApi.js └── serviceWorker.js /.env: -------------------------------------------------------------------------------- 1 | PORT=9000 2 | NODE_PATH=src/ 3 | KYC_API=http://localhost:3032/api/customer/ 4 | USER_STORAGE=user 5 | COOKIE_NAME=__sid -------------------------------------------------------------------------------- /.eslintignore: -------------------------------------------------------------------------------- 1 | !.eslintrc.js 2 | **/node_modules/* 3 | /public/plugins 4 | 5 | -------------------------------------------------------------------------------- /.eslintrc.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | env: { 3 | browser: true, 4 | jest: true, 5 | }, 6 | settings: { 7 | 'import/resolver': { 8 | node: { 9 | paths: ['src'], 10 | }, 11 | }, 12 | }, 13 | extends: ['airbnb'], 14 | parser: 'babel-eslint', 15 | globals: { 16 | document: true, 17 | window: true, 18 | }, 19 | rules: { 20 | no_underscore_dangle: 0, 21 | strict: 0, 22 | 'no-unused-vars': 1, 23 | 'no-nested-ternary': 0, 24 | 'no-console': 0, 25 | 'no-shadow': 0, 26 | 'object-curly-newline': 0, 27 | 'global-require': 0, 28 | 'new-cap': 0, 29 | 'function-paren-newline': 0, 30 | 'guard-for-in': 0, 31 | 'max-len': 0, 32 | 'class-methods-use-this': 0, 33 | 'react/jsx-filename-extension': 0, 34 | 'react/prefer-stateless-function': 0, 35 | 'react/forbid-prop-types': 0, 36 | 'jsx-a11y/label-has-for': 0, 37 | 'import/prefer-default-export': 0, 38 | 'import/no-extraneous-dependencies': 0, 39 | 'import/imports-first': 0, 40 | 'operator-linebreak': ['off'], 41 | 'implicit-arrow-linebreak': ['off'], 42 | 'arrow-parens': ['off'], 43 | }, 44 | parserOptions: { 45 | ecmaFeatures: { 46 | legacyDecorators: true, 47 | }, 48 | }, 49 | }; 50 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # See https://help.github.com/articles/ignoring-files/ for more about ignoring files. 2 | 3 | # dependencies 4 | /node_modules 5 | 6 | # testing 7 | /coverage 8 | 9 | # production 10 | /build 11 | 12 | # misc 13 | .DS_Store 14 | 15 | npm-debug.log* 16 | yarn-debug.log* 17 | yarn-error.log* 18 | package-lock.json 19 | -------------------------------------------------------------------------------- /.prettierrc: -------------------------------------------------------------------------------- 1 | { 2 | "singleQuote": true, 3 | "trailingComma": "all", 4 | "tabWidth": 2, 5 | "semi": true, 6 | "printWidth": 150 7 | } 8 | -------------------------------------------------------------------------------- /config/env.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const fs = require('fs'); 4 | const path = require('path'); 5 | const paths = require('./paths'); 6 | 7 | // Make sure that including paths.js after env.js will read .env variables. 8 | delete require.cache[require.resolve('./paths')]; 9 | 10 | const NODE_ENV = process.env.NODE_ENV; 11 | if (!NODE_ENV) { 12 | throw new Error( 13 | 'The NODE_ENV environment variable is required but was not specified.', 14 | ); 15 | } 16 | 17 | // https://github.com/bkeepers/dotenv#what-other-env-files-can-i-use 18 | const dotenvFiles = [ 19 | `${paths.dotenv}.${NODE_ENV}.local`, 20 | `${paths.dotenv}.${NODE_ENV}`, 21 | // Don't include `.env.local` for `test` environment 22 | // since normally you expect tests to produce the same 23 | // results for everyone 24 | NODE_ENV !== 'test' && `${paths.dotenv}.local`, 25 | paths.dotenv, 26 | ].filter(Boolean); 27 | 28 | // Load environment variables from .env* files. Suppress warnings using silent 29 | // if this file is missing. dotenv will never modify any environment variables 30 | // that have already been set. Variable expansion is supported in .env files. 31 | // https://github.com/motdotla/dotenv 32 | // https://github.com/motdotla/dotenv-expand 33 | dotenvFiles.forEach((dotenvFile) => { 34 | if (fs.existsSync(dotenvFile)) { 35 | require('dotenv-expand')( 36 | require('dotenv').config({ 37 | path: dotenvFile, 38 | }), 39 | ); 40 | } 41 | }); 42 | 43 | // We support resolving modules according to `NODE_PATH`. 44 | // This lets you use absolute paths in imports inside large monorepos: 45 | // https://github.com/facebook/create-react-app/issues/253. 46 | // It works similar to `NODE_PATH` in Node itself: 47 | // https://nodejs.org/api/modules.html#modules_loading_from_the_global_folders 48 | // Note that unlike in Node, only *relative* paths from `NODE_PATH` are honored. 49 | // Otherwise, we risk importing Node.js core modules into an app instead of Webpack shims. 50 | // https://github.com/facebook/create-react-app/issues/1023#issuecomment-265344421 51 | // We also resolve them to make sure all tools using them work consistently. 52 | const appDirectory = fs.realpathSync(process.cwd()); 53 | process.env.NODE_PATH = (process.env.NODE_PATH || '') 54 | .split(path.delimiter) 55 | .filter(folder => folder && !path.isAbsolute(folder)) 56 | .map(folder => path.resolve(appDirectory, folder)) 57 | .join(path.delimiter); 58 | 59 | // Grab NODE_ENV and REACT_APP_* environment variables and prepare them to be 60 | // injected into the application via DefinePlugin in Webpack configuration. 61 | const REACT_APP = /^REACT_APP_/i; 62 | 63 | function getClientEnvironment(publicUrl) { 64 | const raw = Object.keys(process.env) 65 | .filter(key => REACT_APP.test(key)) 66 | .reduce( 67 | (env, key) => { 68 | env[key] = process.env[key]; 69 | return env; 70 | }, 71 | { 72 | // Useful for determining whether we’re running in production mode. 73 | // Most importantly, it switches React into the correct mode. 74 | NODE_ENV: process.env.NODE_ENV || 'development', 75 | // Useful for resolving the correct path to static assets in `public`. 76 | // For example, . 77 | // This should only be used as an escape hatch. Normally you would put 78 | // images into the `src` and `import` them in code to get their paths. 79 | PUBLIC_URL: publicUrl, 80 | KYC_API: process.env.KYC_API, 81 | USER_STORAGE: process.env.USER_STORAGE, 82 | PORT: process.env.PORT, 83 | COOKIE_NAME: process.env.COOKIE_NAME, 84 | }, 85 | ); 86 | // Stringify all values so we can feed into Webpack DefinePlugin 87 | const stringified = { 88 | 'process.env': Object.keys(raw).reduce((env, key) => { 89 | env[key] = JSON.stringify(raw[key]); 90 | return env; 91 | }, {}), 92 | }; 93 | 94 | return { raw, stringified }; 95 | } 96 | 97 | module.exports = getClientEnvironment; 98 | -------------------------------------------------------------------------------- /config/jest/cssTransform.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | // This is a custom Jest transformer turning style imports into empty objects. 4 | // http://facebook.github.io/jest/docs/en/webpack.html 5 | 6 | module.exports = { 7 | process() { 8 | return 'module.exports = {};'; 9 | }, 10 | getCacheKey() { 11 | // The output is always the same. 12 | return 'cssTransform'; 13 | }, 14 | }; 15 | -------------------------------------------------------------------------------- /config/jest/fileTransform.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const path = require('path'); 4 | 5 | // This is a custom Jest transformer turning file imports into filenames. 6 | // http://facebook.github.io/jest/docs/en/webpack.html 7 | 8 | module.exports = { 9 | process(src, filename) { 10 | const assetFilename = JSON.stringify(path.basename(filename)); 11 | 12 | if (filename.match(/\.svg$/)) { 13 | return `module.exports = { 14 | __esModule: true, 15 | default: ${assetFilename}, 16 | ReactComponent: (props) => ({ 17 | $$typeof: Symbol.for('react.element'), 18 | type: 'svg', 19 | ref: null, 20 | key: null, 21 | props: Object.assign({}, props, { 22 | children: ${assetFilename} 23 | }) 24 | }), 25 | };`; 26 | } 27 | 28 | return `module.exports = ${assetFilename};`; 29 | }, 30 | }; 31 | -------------------------------------------------------------------------------- /config/paths.js: -------------------------------------------------------------------------------- 1 | 'use strict'; 2 | 3 | const path = require('path'); 4 | const fs = require('fs'); 5 | const url = require('url'); 6 | 7 | // Make sure any symlinks in the project folder are resolved: 8 | // https://github.com/facebook/create-react-app/issues/637 9 | const appDirectory = fs.realpathSync(process.cwd()); 10 | const resolveApp = relativePath => path.resolve(appDirectory, relativePath); 11 | 12 | const envPublicUrl = process.env.PUBLIC_URL; 13 | 14 | function ensureSlash(inputPath, needsSlash) { 15 | const hasSlash = inputPath.endsWith('/'); 16 | if (hasSlash && !needsSlash) { 17 | return inputPath.substr(0, inputPath.length - 1); 18 | } else if (!hasSlash && needsSlash) { 19 | return `${inputPath}/`; 20 | } else { 21 | return inputPath; 22 | } 23 | } 24 | 25 | const getPublicUrl = appPackageJson => 26 | envPublicUrl || require(appPackageJson).homepage; 27 | 28 | // We use `PUBLIC_URL` environment variable or "homepage" field to infer 29 | // "public path" at which the app is served. 30 | // Webpack needs to know it to put the right