From 9e84876240d16ec81a58e237bad36e5cc949bf8b Mon Sep 17 00:00:00 2001 From: ram Date: Mon, 22 Feb 2021 11:51:29 +0530 Subject: [PATCH 1/8] Fix for plugin announcements --- web/src/actions/appActions.js | 2 +- web/src/components/Sidebar/index.js | 2 +- web/src/containers/MobileHome/index.js | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/web/src/actions/appActions.js b/web/src/actions/appActions.js index 82e08fbfab..2dd330d68f 100644 --- a/web/src/actions/appActions.js +++ b/web/src/actions/appActions.js @@ -308,7 +308,7 @@ export const getWaveAuction = () => { export const getAnnouncement = () => (dispatch) => { return axios - .get(`${PLUGIN_URL}/plugins/announcement`) + .get(`${PLUGIN_URL}/plugins/announcements`) .then((res) => { if (res.data && res.data.data) { dispatch({ diff --git a/web/src/components/Sidebar/index.js b/web/src/components/Sidebar/index.js index 25200832ec..81364c0ed5 100644 --- a/web/src/components/Sidebar/index.js +++ b/web/src/components/Sidebar/index.js @@ -31,7 +31,7 @@ const Sidebar = ({ })} > - {enabledPlugins.includes('announcement') ? ( + {enabledPlugins.includes('announcements') ? (
{STRINGS['TRADE_TAB_POSTS'].toUpperCase()} diff --git a/web/src/containers/MobileHome/index.js b/web/src/containers/MobileHome/index.js index eea214cc5b..db271802b5 100644 --- a/web/src/containers/MobileHome/index.js +++ b/web/src/containers/MobileHome/index.js @@ -92,7 +92,7 @@ class Home extends Component { } */}
{STRINGS['TRADE_TAB_POSTS']}
- {enabledPlugins.includes('announcement') ? ( + {enabledPlugins.includes('announcements') ? ( ) : null}
From f9ccc47a50efc551e783dbfc158650cce756512f Mon Sep 17 00:00:00 2001 From: ram Date: Wed, 24 Feb 2021 12:35:20 +0530 Subject: [PATCH 2/8] Changes for check deposit status issue --- web/src/actions/walletActions.js | 12 +-- .../CheckDeposit/_CheckDeposit.scss | 2 +- web/src/components/CheckDeposit/index.js | 75 +++++++++++++------ web/src/config/lang/en.js | 6 +- .../TransactionsHistory/HistoryDisplay.js | 43 ++++------- .../containers/TransactionsHistory/index.js | 28 +------ web/src/index.css | 28 +++---- web/src/reducers/walletReducer.js | 8 -- 8 files changed, 87 insertions(+), 115 deletions(-) diff --git a/web/src/actions/walletActions.js b/web/src/actions/walletActions.js index 0ab984835b..99970eef31 100644 --- a/web/src/actions/walletActions.js +++ b/web/src/actions/walletActions.js @@ -25,7 +25,6 @@ export const ACTION_KEYS = { WITHDRAWAL_CANCEL_PENDING: 'WITHDRAWAL_CANCEL_PENDING', WITHDRAWAL_CANCEL_FULFILLED: 'WITHDRAWAL_CANCEL_FULFILLED', WITHDRAWAL_CANCEL_REJECTED: 'WITHDRAWAL_CANCEL_REJECTED', - DEPOSIT_STATUS_SUCCESS: 'DEPOSIT_STATUS_SUCCESS', }; const ENDPOINTS = { @@ -39,6 +38,7 @@ const ENDPOINTS = { WITHDRAW_FEE: (currency) => `/user/withdrawal?currency=${currency}`, CANCEL_WITHDRAWAL: '/user/withdrawal', CONFIRM_WITHDRAWAL: '/user/confirm-withdrawal', + CHECK_TRANSACTION: '/user/check-transaction', }; export const performWithdraw = (currency, values) => { @@ -353,13 +353,7 @@ export const performConfirmWithdrawal = (token) => { return axios.post(ENDPOINTS.CONFIRM_WITHDRAWAL, { token }); }; -export const searchUserDeposits = (params) => { +export const searchTransaction = (params) => { const query = querystring.stringify(params); - return axios.get(`${ENDPOINTS.DEPOSITS}?${query}`); -}; - -export const setDeposit = (deposit) => { - return (dispatch) => { - dispatch({ type: ACTION_KEYS.DEPOSIT_STATUS_SUCCESS, payload: deposit }); - }; + return axios.get(`${ENDPOINTS.CHECK_TRANSACTION}?${query}`); }; diff --git a/web/src/components/CheckDeposit/_CheckDeposit.scss b/web/src/components/CheckDeposit/_CheckDeposit.scss index f16468206e..a0672d8f8d 100644 --- a/web/src/components/CheckDeposit/_CheckDeposit.scss +++ b/web/src/components/CheckDeposit/_CheckDeposit.scss @@ -10,7 +10,7 @@ border-top: 1px solid $colors-border; margin-top: 3rem; padding: 10px 0; - span { + .field-header { color: $colors-black; } .success-msg { diff --git a/web/src/components/CheckDeposit/index.js b/web/src/components/CheckDeposit/index.js index cb4be85414..cae88225ef 100644 --- a/web/src/components/CheckDeposit/index.js +++ b/web/src/components/CheckDeposit/index.js @@ -7,6 +7,7 @@ import { Button } from '../../components'; import { STATIC_ICONS } from 'config/icons'; import renderFields from '../../components/Form/factoryFields'; import withConfig from 'components/ConfigProvider/withConfig'; +import { required } from '../Form/validations'; const FORM_NAME = 'CheckDeposit'; @@ -15,35 +16,55 @@ const CheckDeposit = ({ requestDeposit, isLoading, message, - successMsg, + handleSubmit, + coins, + pristine, + submitting, + valid, error, - handleSearch = () => {}, ...props }) => { - const handleItemSearch = () => { - handleSearch(props.formValues); - }; + const coinOptions = []; + Object.keys(coins).forEach((data) => { + let temp = coins[data]; + if (temp) { + coinOptions.push({ + label: `${temp.fullname} (${temp.symbol})`, + value: data, + }); + } + }); const formFields = { transaction_id: { type: 'text', placeholder: STRINGS['DEPOSIT_STATUS.SEARCH_FIELD_LABEL'], + label: STRINGS['DEPOSIT_STATUS.TRANSACTION_ID'], + validate: [required], + fullWidth: true, + }, + currency: { + type: 'select', + placeholder: STRINGS['DEPOSIT_STATUS.CURRENCY_FIELD_LABEL'], + label: STRINGS['COINS'], + options: coinOptions, + validate: [required], + fullWidth: true, + }, + address: { + type: 'text', + placeholder: STRINGS['DEPOSIT_STATUS.ADDRESS_FIELD_LABEL'], + label: + STRINGS[ + 'USER_VERIFICATION.USER_DOCUMENTATION_FORM.FORM_FIELDS.ADDRESS_LABEL' + ], + validate: [required], fullWidth: true, - notification: { - stringId: 'DEPOSIT_STATUS.SEARCH', - text: isLoading - ? STRINGS['DEPOSIT_STATUS.SEARCHING'] - : STRINGS['DEPOSIT_STATUS.SEARCH'], - iconPath: isLoading - ? props.icons['CONNECT_LOADING'] - : STATIC_ICONS.SEARCH, - onClick: handleItemSearch, - }, }, }; return ( -
+
{STRINGS['DEPOSIT_STATUS.CHECK_DEPOSIT_STATUS']}
- {STRINGS['DEPOSIT_STATUS.CHECK_DEPOSIT_STATUS']} + + {STRINGS['DEPOSIT_STATUS.CHECK_DEPOSIT_STATUS']} +
{STRINGS['DEPOSIT_STATUS.STATUS_DESCRIPTION']}
- {STRINGS['DEPOSIT_STATUS.TRANSACTION_ID']} {renderFields(formFields)} - {message === successMsg ? ( + {message ? (

{message}

- ) : ( -

{message}

- )} + ) : null} + {error &&
{error}
}
-
-
); @@ -81,10 +106,12 @@ const CheckDeposit = ({ const CheckDepositForm = reduxForm({ form: FORM_NAME, + enableReinitialize: true, })(CheckDeposit); const mapStateToProps = (state) => ({ formValues: getFormValues(FORM_NAME)(state), + coins: state.app.coins, }); export default connect(mapStateToProps)(withConfig(CheckDepositForm)); diff --git a/web/src/config/lang/en.js b/web/src/config/lang/en.js index e115577473..a425c74c8a 100644 --- a/web/src/config/lang/en.js +++ b/web/src/config/lang/en.js @@ -1408,9 +1408,9 @@ const nestedContent = { STATUS_DESCRIPTION: 'You can check the status of your deposit by passing the transaction ID (hash) below.', TRANSACTION_ID: 'Transaction ID (hash)', - SEARCH_SUCCESS: 'Transaction found!', - SEARCH_ERROR: - 'Transaction not found. Please check the ID and try again. If your believe there is a problem please contact support.', + SEARCH_SUCCESS: 'Search complete', // new + ADDRESS_FIELD_LABEL: 'Paste your address', // new + CURRENCY_FIELD_LABEL: 'Select the currency', // new }, CANCEL_ORDERS: { HEADING: 'Cancel orders', diff --git a/web/src/containers/TransactionsHistory/HistoryDisplay.js b/web/src/containers/TransactionsHistory/HistoryDisplay.js index f4179d5a30..e1834aefd0 100644 --- a/web/src/containers/TransactionsHistory/HistoryDisplay.js +++ b/web/src/containers/TransactionsHistory/HistoryDisplay.js @@ -9,12 +9,13 @@ import { Dialog, } from '../../components'; import classnames from 'classnames'; +import { SubmissionError } from 'redux-form'; import STRINGS from '../../config/localizedStrings'; import { EditWrapper } from 'components'; import withConfig from 'components/ConfigProvider/withConfig'; import { STATIC_ICONS } from 'config/icons'; -import { searchUserDeposits } from 'actions/walletActions'; +import { searchTransaction } from 'actions/walletActions'; import CheckDeposit from '../../components/CheckDeposit'; const HistoryDisplay = (props) => { @@ -31,47 +32,31 @@ const HistoryDisplay = (props) => { handleDownload, icons: ICONS, activeTab, - setDeposit = () => {}, - setDepositStatusPage = () => {}, } = props; const [dialogIsOpen, setDialogOpen] = useState(false); const [isLoading, setLoading] = useState(false); - const [message, setMessage] = useState(''); + const [statusMessage, setMessage] = useState(''); + const [initialValue, setInitialValues] = useState({}); const requestDeposit = (params = {}) => { setLoading(true); - searchUserDeposits(params) + setInitialValues(params); + setMessage(''); + return searchTransaction(params) .then((res) => { setLoading(false); - if (res.data.data.length === 0) { - setMessage(STRINGS['DEPOSIT_STATUS.SEARCH_ERROR']); - } else if (res && res.data && res.data.data && res.data.data.length) { - let statusTempData = res.data.data[0]; - setDeposit({ ...statusTempData, is_new: true }); - setDepositStatusPage(statusTempData.transaction_id); + if (res) { setMessage(STRINGS['DEPOSIT_STATUS.SEARCH_SUCCESS']); } }) .catch((err) => { + let _error = err && err.data ? err.data.message : err.message; setLoading(false); + throw new SubmissionError({ _error }); }); }; - const handleSearch = (values) => { - if (values && values.transaction_id) { - const filterData = data.filter( - (item) => item.transaction_id === values.transaction_id - ); - if (filterData.length !== 0) { - setDepositStatusPage(values.transaction_id); - setMessage(STRINGS['DEPOSIT_STATUS.SEARCH_SUCCESS']); - } else { - requestDeposit(values); - } - } - }; - const openDialog = () => { setDialogOpen(true); }; @@ -136,12 +121,10 @@ const HistoryDisplay = (props) => { > diff --git a/web/src/containers/TransactionsHistory/index.js b/web/src/containers/TransactionsHistory/index.js index c1ddffe8e7..d1f8dfc687 100644 --- a/web/src/containers/TransactionsHistory/index.js +++ b/web/src/containers/TransactionsHistory/index.js @@ -11,7 +11,6 @@ import { getUserWithdrawals, withdrawalCancel, downloadUserTrades, - setDeposit, } from '../../actions/walletActions'; import { @@ -33,7 +32,7 @@ import { } from './utils'; import TradeAndOrderFilters from './components/TradeAndOrderFilters'; import DepositAndWithdrawlFilters from './components/DepositAndWithdrawlFilters'; -import { RECORD_LIMIT, TABLE_PAGE_SIZE } from './constants'; +import { RECORD_LIMIT } from './constants'; import HistoryDisplay from './HistoryDisplay'; import STRINGS from '../../config/localizedStrings'; @@ -244,21 +243,6 @@ class TransactionsHistory extends Component { this.onCloseDialog(); }; - setDepositStatusPage = (transactionId) => { - const { deposits } = this.props; - const index = deposits.data.findIndex( - (element) => element.transactionId === transactionId - ); - const page = index / TABLE_PAGE_SIZE; - if (this.state.jumpToPage === parseInt(page)) { - this.setState({ jumpToPage: 0 }, () => { - this.setState({ jumpToPage: parseInt(page) }); - }); - } else { - this.setState({ jumpToPage: parseInt(page) }); - } - }; - handleNext = (pageCount, pageNumber) => { const { orders, trades, deposits, withdrawals } = this.props; const { params } = this.state; @@ -390,14 +374,7 @@ class TransactionsHistory extends Component { return
; } - return ( - - ); + return ; }; render() { @@ -563,7 +540,6 @@ const mapDispatchToProps = (dispatch) => ({ downloadUserDeposit: () => dispatch(downloadUserTrades('deposit')), downloadUserWithdrawal: () => dispatch(downloadUserTrades('withdrawal')), downloadUserOrders: () => dispatch(downloadUserTrades('orders')), - setDeposit: (params) => dispatch(setDeposit(params)), }); export default connect( diff --git a/web/src/index.css b/web/src/index.css index e65a5d4ed2..f22e15b752 100644 --- a/web/src/index.css +++ b/web/src/index.css @@ -329,13 +329,13 @@ table th { height: auto; flex: 1; } .app_container.layout-mobile .app_container-content { - min-height: calc( 100vh - 10rem); - max-height: calc( 100vh - 10rem); + min-height: calc( 100vh - 10rem); + max-height: calc( 100vh - 10rem); max-width: 100vw; overflow-y: scroll; } .app_container.layout-mobile .content-with-bar { - min-height: calc( 100vh - 17rem); - max-height: calc( 100vh - 17rem); + min-height: calc( 100vh - 17rem); + max-height: calc( 100vh - 17rem); max-width: 100vw; padding: 1rem; margin: 0; @@ -916,8 +916,8 @@ table th { height: calc(100% - 4rem) !important; } .layout-mobile.home_container .app_container-content { - min-height: calc( 100vh - 4rem); - max-height: calc( 100vh - 4rem); } + min-height: calc( 100vh - 4rem); + max-height: calc( 100vh - 4rem); } .home_container { background-repeat: no-repeat; @@ -2171,8 +2171,8 @@ table th { .layout-mobile .quote-container { background-color: transparent; overflow-y: scroll; - min-height: calc( 100vh - 17rem); - max-height: calc( 100vh - 17rem); } + min-height: calc( 100vh - 17rem); + max-height: calc( 100vh - 17rem); } .layout-mobile .quote-container .quick_trade-wrapper { flex: 1; min-width: 100vw; @@ -2259,7 +2259,7 @@ table th { .layout-mobile .presentation_container.verification_container { padding-top: 0 !important; - max-height: calc( 100vh - 10rem); } + max-height: calc( 100vh - 10rem); } .layout-mobile .presentation_container.verification_container .header-content { font-size: 12px !important; } @@ -6263,14 +6263,14 @@ table th { right: 0 !important; min-width: 100vw; max-width: 100vw; - min-height: calc( 100vh - 4rem); - max-height: calc( 100vh - 4rem); + min-height: calc( 100vh - 4rem); + max-height: calc( 100vh - 4rem); border-radius: 0 !important; padding: 0 !important; } .layout-mobile .ReactModal__Content .dialog-mobile-content { padding: 2.5rem !important; - min-height: calc( 100vh - 8rem); - max-height: calc( 100vh - 8rem); + min-height: calc( 100vh - 8rem); + max-height: calc( 100vh - 8rem); display: flex; } .layout-mobile.LogoutModal .ReactModal__Content { @@ -8905,7 +8905,7 @@ foreignObject { border-top: 1px solid var(--calculated_secondary-border); margin-top: 3rem; padding: 10px 0; } - .check-deposit-modal-wrapper .inner-content span { + .check-deposit-modal-wrapper .inner-content .field-header { color: var(--labels_secondary-inactive-label-text-graphics); } .check-deposit-modal-wrapper .inner-content .success-msg { width: 320px; diff --git a/web/src/reducers/walletReducer.js b/web/src/reducers/walletReducer.js index 8c94e28095..9cf957b0bb 100644 --- a/web/src/reducers/walletReducer.js +++ b/web/src/reducers/walletReducer.js @@ -287,14 +287,6 @@ export default function reducer(state = INITIAL_STATE, { type, payload }) { loading: false, }, }; - case ACTION_KEYS.DEPOSIT_STATUS_SUCCESS: - return { - ...state, - trades: { - ...state.trades, - data: [payload, ...state.trades.data], - }, - }; case 'LOGOUT': return INITIAL_STATE; default: From ec89e61a796811e9a4bd5850104d7d8acf071c42 Mon Sep 17 00:00:00 2001 From: ram Date: Wed, 24 Feb 2021 13:48:35 +0530 Subject: [PATCH 3/8] Fix for donut chart and mobile sidebar icon design issues --- web/src/components/Sidebar/_Sidebar.scss | 3 +++ web/src/containers/Summary/_Summary.scss | 14 ++++++-------- web/src/index.css | 24 ++++++++++++------------ 3 files changed, 21 insertions(+), 20 deletions(-) diff --git a/web/src/components/Sidebar/_Sidebar.scss b/web/src/components/Sidebar/_Sidebar.scss index 5f66828f7d..a0af14d05d 100644 --- a/web/src/components/Sidebar/_Sidebar.scss +++ b/web/src/components/Sidebar/_Sidebar.scss @@ -154,6 +154,9 @@ $row--size: calc(#{$row--height} - #{$sidebar-sections-padding}); fill: transparent; } } + img.sidebar-bottom-icon { + @include size(3rem); + } } } diff --git a/web/src/containers/Summary/_Summary.scss b/web/src/containers/Summary/_Summary.scss index 67095888b7..b0f320b1dd 100644 --- a/web/src/containers/Summary/_Summary.scss +++ b/web/src/containers/Summary/_Summary.scss @@ -70,6 +70,7 @@ $trade-tab--arrow-size: 0.4rem; // width: 17rem; } .assets-wrapper { + margin-top: 40px; .price-text { font-size: $font-size-mobile-txt !important; } @@ -152,7 +153,7 @@ $trade-tab--arrow-size: 0.4rem; font-weight: bold; } .summary-section_1 { - height: 26rem; + height: 30rem; .assets-wrapper { .donut-container { @@ -678,9 +679,6 @@ $trade-tab--arrow-size: 0.4rem; .summary-content-txt { font-size: 1.2rem !important; } - .assets-wrapper { - margin-top: 40px; - } } } @media (min-width: 1920px) { @@ -714,9 +712,9 @@ $trade-tab--arrow-size: 0.4rem; .requirement-wrapper { width: 65% !important; } - .summary-section_1 { - height: 29rem !important; - } + // .summary-section_1 { + // height: 31rem !important; + // } .summary-section_2 { height: 43rem !important; } @@ -736,7 +734,7 @@ $trade-tab--arrow-size: 0.4rem; font-size: 0.9rem; } .summary-section_1 { - height: 29rem !important; + height: 31rem !important; } .summary-section_2 { height: 44rem !important; diff --git a/web/src/index.css b/web/src/index.css index f22e15b752..5a8b4b8c24 100644 --- a/web/src/index.css +++ b/web/src/index.css @@ -2360,11 +2360,12 @@ table th { .layout-mobile .summary-container .summary-content-txt { font-size: 12px !important; } -.layout-mobile .summary-container .assets-wrapper .price-text { - font-size: 12px !important; } - -.layout-mobile .summary-container .assets-wrapper .donut-container { - height: 30rem; } +.layout-mobile .summary-container .assets-wrapper { + margin-top: 40px; } + .layout-mobile .summary-container .assets-wrapper .price-text { + font-size: 12px !important; } + .layout-mobile .summary-container .assets-wrapper .donut-container { + height: 30rem; } .layout-mobile .summary-container .account-details-wrapper .account-type-menu { height: auto !important; } @@ -2411,7 +2412,7 @@ table th { color: var(--specials_buttons-links-and-highlights); font-weight: bold; } .summary-container .summary-section_1 { - height: 26rem; } + height: 30rem; } .summary-container .summary-section_1 .assets-wrapper .donut-container { height: 16rem; width: 100%; } @@ -2796,9 +2797,7 @@ table th { .summary-container .summary-block-secondaryTitle { font-size: 1.8rem; } .summary-container .summary-content-txt { - font-size: 1.2rem !important; } - .summary-container .assets-wrapper { - margin-top: 40px; } } + font-size: 1.2rem !important; } } @media (min-width: 1920px) { .summary-container { @@ -2819,8 +2818,6 @@ table th { .summary-container .trading-volume-wrapper, .summary-container .requirement-wrapper { width: 65% !important; } - .summary-container .summary-section_1 { - height: 29rem !important; } .summary-container .summary-section_2 { height: 43rem !important; } .fee-limits-wrapper .content-txt { @@ -2833,7 +2830,7 @@ table th { .summary-container .trader-account-wrapper { font-size: 0.9rem; } .summary-container .summary-section_1 { - height: 29rem !important; } + height: 31rem !important; } .summary-container .summary-section_2 { height: 44rem !important; } .fee-limits-wrapper .content-txt { @@ -3941,6 +3938,9 @@ table th { height: 3rem; stroke: var(--labels_secondary-inactive-label-text-graphics); fill: transparent; } + .sidebar-bottom-wrapper .sidebar-bottom-button img.sidebar-bottom-icon { + width: 3rem; + height: 3rem; } .direction_ltr .sidebar-row .cell-wrapper:not(:last-child) { border-right: 1px solid var(--calculated_secondary-border); } From 81038e67b7bee159bec858605cde61f1d1ed7f8e Mon Sep 17 00:00:00 2001 From: ram Date: Wed, 24 Feb 2021 20:58:17 +0530 Subject: [PATCH 4/8] fix for kit refinement bugs --- .../components/Notification/InviteFriends.js | 10 +++ .../containers/Admin/General/FooterConfig.js | 66 +++++++++++-------- web/src/containers/Admin/MoveToDash/index.js | 2 +- web/src/containers/App/App.js | 6 +- 4 files changed, 54 insertions(+), 30 deletions(-) diff --git a/web/src/components/Notification/InviteFriends.js b/web/src/components/Notification/InviteFriends.js index 3b392cd765..daa162dc21 100644 --- a/web/src/components/Notification/InviteFriends.js +++ b/web/src/components/Notification/InviteFriends.js @@ -8,6 +8,7 @@ import DumbField from '../Form/FormFields/DumbField'; import Button from '../Button'; import STRINGS from '../../config/localizedStrings'; import { getUserReferralCount } from '../../actions/userAction'; +import { setSnackNotification } from '../../actions/appActions'; import { EditWrapper } from 'components'; const RenderDumbField = (props) => ; @@ -24,6 +25,14 @@ class InviteFriends extends Component { this.props.getUserReferralCount(); } + handleCopy = () => { + const { icons: ICONS, setSnackNotification } = this.props; + setSnackNotification({ + icon: ICONS.COPY_NOTIFICATION, + content: STRINGS['COPY_SUCCESS_TEXT'], + }); + }; + render() { const { affiliation_code } = this.props.data; const { affiliation, icons: ICONS } = this.props; @@ -96,6 +105,7 @@ const mapStateToProps = (store) => ({ const mapDispatchToProps = (dispatch) => ({ getUserReferralCount: bindActionCreators(getUserReferralCount, dispatch), + setSnackNotification: bindActionCreators(setSnackNotification, dispatch), }); export default connect(mapStateToProps, mapDispatchToProps)(InviteFriends); diff --git a/web/src/containers/Admin/General/FooterConfig.js b/web/src/containers/Admin/General/FooterConfig.js index 82650eef6f..0bdef25a2c 100644 --- a/web/src/containers/Admin/General/FooterConfig.js +++ b/web/src/containers/Admin/General/FooterConfig.js @@ -1,5 +1,5 @@ import React, { Component } from 'react'; -import { Modal } from 'antd'; +import { message, Modal } from 'antd'; import { PlusOutlined } from '@ant-design/icons'; import _isEqual from 'lodash/isEqual'; @@ -322,35 +322,45 @@ class FooterConfig extends Component { }; handleAddLink = (formProps) => { - const custom_fields = { ...this.state.custom_fields }; - let currentField = custom_fields[this.state.currentSection]; - let currentFieldContent = currentField.content || {}; - let currentFieldHeader = currentField.header || {}; - let currentContentFields = currentFieldContent.fields || {}; - custom_fields[this.state.currentSection] = { - ...currentField, - content: { - ...currentFieldContent, - fields: { - ...currentContentFields, - [formProps.link.toLowerCase()]: { - type: 'input', - label: formProps.link, - placeholder: 'http://', - isClosable: true, - closeCallback: () => - this.handleRemoveLinks( - currentFieldHeader.fields, - formProps.link.toLowerCase() - ), + let initialCustom = { ...this.state.initialCustom }; + if ( + formProps.link && + Object.keys(initialCustom).includes(formProps.link.toLowerCase()) + ) { + message.warn('Link already exist'); + } else { + const custom_fields = { ...this.state.custom_fields }; + let currentField = custom_fields[this.state.currentSection]; + let currentFieldContent = currentField.content || {}; + let currentFieldHeader = currentField.header || {}; + let currentContentFields = currentFieldContent.fields || {}; + custom_fields[this.state.currentSection] = { + ...currentField, + content: { + ...currentFieldContent, + fields: { + ...currentContentFields, + [formProps.link.toLowerCase()]: { + type: 'input', + label: formProps.link, + placeholder: 'http://', + isClosable: true, + closeCallback: () => + this.handleRemoveLinks( + currentFieldHeader.fields, + formProps.link.toLowerCase() + ), + }, }, }, - }, - }; - this.setState({ - custom_fields, - }); - this.onCancel(); + }; + initialCustom[formProps.link.toLowerCase()] = ''; + this.setState({ + initialCustom, + custom_fields, + }); + this.onCancel(); + } }; handleSubmitLinks = (formProps) => { diff --git a/web/src/containers/Admin/MoveToDash/index.js b/web/src/containers/Admin/MoveToDash/index.js index 8efa7cc0fc..adeb40882d 100644 --- a/web/src/containers/Admin/MoveToDash/index.js +++ b/web/src/containers/Admin/MoveToDash/index.js @@ -17,7 +17,7 @@ const MoveToDash = () => { />
- + {ReactDOM.createPortal( + , + document.getElementsByTagName('body')[0] + )}
Date: Thu, 25 Feb 2021 16:01:37 +0900 Subject: [PATCH 5/8] can pass transaction_id in mint/burn --- server/api/controllers/admin.js | 18 ++++++++++++------ server/api/swagger/swagger.yaml | 4 +++- 2 files changed, 15 insertions(+), 7 deletions(-) diff --git a/server/api/controllers/admin.js b/server/api/controllers/admin.js index 2abc303734..dda1ccf7ef 100644 --- a/server/api/controllers/admin.js +++ b/server/api/controllers/admin.js @@ -610,7 +610,8 @@ const mintAsset = (req, res) => { user_id, currency, amount, - description + description, + transaction_id } = req.swagger.params.data.value; loggerAdmin.info( @@ -620,7 +621,9 @@ const mintAsset = (req, res) => { 'currency', currency, 'amount', - amount + amount, + 'transaction_id', + transaction_id ); toolsLib.user.getUserByKitId(user_id) @@ -628,7 +631,7 @@ const mintAsset = (req, res) => { if (!user) { throw new Error(USER_NOT_FOUND); } - return toolsLib.wallet.mintAssetByNetworkId(user.network_id, currency, amount, description); + return toolsLib.wallet.mintAssetByNetworkId(user.network_id, currency, amount, description, transaction_id); }) .then(() => { return res.json({ message: 'Success' }); @@ -649,7 +652,8 @@ const burnAsset = (req, res) => { user_id, currency, amount, - description + description, + transaction_id } = req.swagger.params.data.value; loggerAdmin.info( @@ -659,7 +663,9 @@ const burnAsset = (req, res) => { 'currency', currency, 'amount', - amount + amount, + 'transaction_id', + transaction_id ); toolsLib.user.getUserByKitId(user_id) @@ -667,7 +673,7 @@ const burnAsset = (req, res) => { if (!user) { throw new Error(USER_NOT_FOUND); } - return toolsLib.wallet.burnAssetByNetworkId(user.network_id, currency, amount, description); + return toolsLib.wallet.burnAssetByNetworkId(user.network_id, currency, amount, description, transaction_id); }) .then(() => { return res.json({ message: 'Success' }); diff --git a/server/api/swagger/swagger.yaml b/server/api/swagger/swagger.yaml index 13b28fe609..205ae65c1b 100644 --- a/server/api/swagger/swagger.yaml +++ b/server/api/swagger/swagger.yaml @@ -4274,4 +4274,6 @@ definitions: type: string amount: type: number - format: double \ No newline at end of file + format: double + transaction_id: + type: string \ No newline at end of file From a46432938a86715d63e9d21db695910b0de30f09 Mon Sep 17 00:00:00 2001 From: Amir Hossein Salar Date: Fri, 26 Feb 2021 08:09:08 +0330 Subject: [PATCH 6/8] fix initialization parsing issue --- web/src/index.js | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/web/src/index.js b/web/src/index.js index e89ab1dbc2..92f99488cc 100644 --- a/web/src/index.js +++ b/web/src/index.js @@ -65,7 +65,7 @@ const getConfigs = async () => { const kitData = await getKitData(); const { - meta: { versions: remoteVersions = {} } = {}, + meta: { versions: remoteVersions = {}, sections = {} } = {}, valid_languages = '', info: { initialized }, setup_completed, @@ -73,6 +73,8 @@ const getConfigs = async () => { logo_image, } = kitData; + kitData['sections'] = sections; + const promises = {}; Object.keys(remoteVersions).forEach((key) => { const localVersion = localVersions[key]; From 2e1f74c7c071eb540bd62747a81b1d9307bcbabd Mon Sep 17 00:00:00 2001 From: Amir Hossein Salar Date: Fri, 26 Feb 2021 11:52:13 +0330 Subject: [PATCH 7/8] changes for scientific notation issue --- web/src/components/Form/validations.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/web/src/components/Form/validations.js b/web/src/components/Form/validations.js index 41d2af0518..72a99220d9 100644 --- a/web/src/components/Form/validations.js +++ b/web/src/components/Form/validations.js @@ -229,7 +229,7 @@ export const normalizeInt = (value) => { }; export const normalizeFloat = (value) => { if (validator.isFloat(value)) { - return validator.toFloat(value); + return math.format(validator.toFloat(value), { notation: 'fixed' }); } else if (value === '0' || value === 0) { return 0; } else { From 4f5a0f52d704eee1ee2db93d14145f0c270650b4 Mon Sep 17 00:00:00 2001 From: user Date: Fri, 26 Feb 2021 17:48:51 +0900 Subject: [PATCH 8/8] version update --- server/api/swagger/swagger.yaml | 2 +- server/package.json | 2 +- version | 2 +- web/package.json | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/server/api/swagger/swagger.yaml b/server/api/swagger/swagger.yaml index 1ed9c4c022..b76d1d2fce 100644 --- a/server/api/swagger/swagger.yaml +++ b/server/api/swagger/swagger.yaml @@ -1,6 +1,6 @@ swagger: "2.0" info: - version: "2.0.7" + version: "2.0.8" title: HollaEx Kit host: api.hollaex.com basePath: /v2 diff --git a/server/package.json b/server/package.json index 1e608e9766..c5247e4680 100644 --- a/server/package.json +++ b/server/package.json @@ -1,5 +1,5 @@ { - "version": "2.0.7", + "version": "2.0.8", "private": false, "description": "HollaEx Kit", "keywords": [ diff --git a/version b/version index 6a0ca2d59d..e8f41f06d0 100644 --- a/version +++ b/version @@ -1 +1 @@ -2.0.7 \ No newline at end of file +2.0.8 \ No newline at end of file diff --git a/web/package.json b/web/package.json index 24f2ea4ad9..f2e9fc28f8 100644 --- a/web/package.json +++ b/web/package.json @@ -1,6 +1,6 @@ { "name": "hollaex-kit", - "version": "2.0.7", + "version": "2.0.8", "private": true, "dependencies": { "@ant-design/compatible": "1.0.5",