+ {data?.show_mid_purchase ? (
-
-
{data?.middleDisplayText}
+
+
{data?.middle_display_text}
{localize('Stake')}:
- {data?.middleAmount} {displayCurrency(data?.middleAmount)}
+ {data?.middle_amount} {displayCurrency(data?.middle_amount)}
{localize('Multiplier')}:
- {data?.middleMultiplier} {displayCurrency(data?.middleMultiplier)}
+ {data?.middle_multiplier} {displayCurrency(data?.middle_multiplier)}
- {ButtonTooltipWrapper(
@@ -134,60 +136,48 @@ const Purchase = () => {
) : (
<>
-
-
-
-
-
{data?.topDisplayText}
-
-
-
-
- {localize('Stake')}:
- {data?.topAmount} {displayCurrency(data?.topAmount)}
-
-
- {localize('Payout')}:
- {data?.topPayoutAmount} {displayCurrency(data?.topPayoutAmount)}
-
-
-
- {ButtonTooltipWrapper( triggerClick('#purchase_button_top')} color='purchase' size='lg' label={localize('Purchase')} fullWidth disabled={data?.topPurchaseDisabled} />,data?.topDescription)}
-
-
-
-
- {parseData(data.topComment)}
-
-
-
-
-
-
-
{data?.bottomDisplayText}
-
-
-
-
-
{localize('Stake')}:
-
{data?.bottomAmount} {displayCurrency(data?.bottomAmount)}
+ {purchase_positions.map(position => {
+ const contract_type = data?.[`${position}_contract_type`];
+ const display_text = data?.[`${position}_display_text`];
+ const amount = data?.[`${position}_amount`];
+ const amount_classname = data?.[`${position}_amount_classname`];
+ const payout_amount_classname = data?.[`${position}_payout_amount_classname`];
+ const payout_amount = data?.[`${position}_payout_amount`];
+ const purchase_disabled = data?.[`${position}_purchase_disabled`];
+ const description = data?.[`${position}_description`];
+ const comment = data?.[`${position}_comment`];
+
+ return (
+
+
+
+
+
+
+
+ {localize('Stake')}:
+ {amount} {displayCurrency(amount)}
+
+
+ {localize('Payout')}:
+ {payout_amount} {displayCurrency(payout_amount)}
+
+
+
+ {ButtonTooltipWrapper( triggerClick(`#purchase_button_${position}`)} color='purchase' size='lg' label={localize('Purchase')} fullWidth disabled={purchase_disabled} />,description)}
+
+
-
-
{localize('Payout')}:
-
{data?.bottomPayoutAmount} {displayCurrency(data?.bottomPayoutAmount)}
+
+ {parseData(comment)}
-
- {ButtonTooltipWrapper( triggerClick('#purchase_button_bottom')} color='sell' size='lg' label={localize('Purchase')} fullWidth disabled={data?.bottomPurchaseDisabled} />,data?.bottomDescription)}
-
-
-
-
-
- {parseData(data.bottomComment)}
-
-
-
+
+ );
+ })}
>
)}
@@ -221,7 +211,7 @@ const Purchase = () => {
variant='primary'
size='lg'
label={localize('Open a free account')}
- onClick={() => window.location.href = data?.error.signupUrl}
+ onClick={() => window.location.href = data?.error.signup_url}
/>
{localize('Already have an account?')}
triggerClick('#authorization_error_btn_login')} />
@@ -279,29 +269,29 @@ const Purchase = () => {
{data?.pr_description}
- {data?.pr_tablePayoutValue && (
+ {data?.pr_table_payout_value && (
- {data?.pr_tablePayout}
- {parseData(data.pr_tablePayoutValue)}
+ {data?.pr_table_payout}
+ {parseData(data.pr_table_payout_value)}
)}
- { data?.pr_tableCostValue && (
+ { data?.pr_table_cost_value && (
- {data?.pr_tableCost}
- {parseData(data.pr_tableCostValue)}
+ {data?.pr_table_cost}
+ {parseData(data.pr_table_cost_value)}
)}
- { data?.pr_tableProfitValue && data?.pr_showTableProfit && (
+ { data?.pr_table_profit_value && data?.pr_show_table_profit && (
- {data?.pr_tableProfit}
- {parseData(data.pr_tableProfitValue)}
+ {data?.pr_table_profit}
+ {parseData(data.pr_table_profit_value)}
)}
{data?.pr_barrier && {parseData(data.pr_barrier)}}
{data?.pr_reference && {parseData(data.pr_reference)}}
- {data?.pr_showBtn && {
@@ -319,7 +309,7 @@ const Purchase = () => {
{data?.pr_balance}
- {parseData(data.pr_balanceValue)}
+ {parseData(data.pr_balance_value)}
);
diff --git a/src/javascript/app/pages/trade/update_values.js b/src/javascript/app/pages/trade/update_values.js
index b9f8a168920..c6a3ebf4838 100644
--- a/src/javascript/app/pages/trade/update_values.js
+++ b/src/javascript/app/pages/trade/update_values.js
@@ -14,24 +14,24 @@ const updatePurchaseStatus = (final_price, pnl, profit, localized_contract_statu
$cost.html($('
', { text: localize('Final price') }).append($('
', { html: formatMoney(currency, final_price) })));
dataManager.setPurchase({
pr_heading : localized_contract_status,
- pr_tablePayout : localize('Buy price') ,
- pr_tablePayoutValue: formatMoney(currency, Math.abs(pnl)),
- pr_tableCost : localize('Final price'),
- pr_tableCostValue : formatMoney(currency, final_price),
+ pr_table_payout : localize('Buy price') ,
+ pr_table_payout_value: formatMoney(currency, Math.abs(pnl)),
+ pr_table_cost : localize('Final price'),
+ pr_table_cost_value : formatMoney(currency, final_price),
});
if (!final_price) {
$profit.html($('
', { text: localize('Loss') }).append($('
', { html: formatMoney(currency, pnl) })));
dataManager.setPurchase({
- pr_tableProfit : localize('Loss'),
- pr_tableProfitValue: formatMoney(currency, pnl),
+ pr_table_profit : localize('Loss'),
+ pr_table_profit_value: formatMoney(currency, pnl),
});
} else {
$profit.html($('
', { text: localize('Profit') }).append($('
', { html: formatMoney(currency, profit) })));
updateContractBalance(Client.get('balance'));
dataManager.setPurchase({
- pr_tableProfit : localize('Profit'),
- pr_tableProfitValue: formatMoney(currency, profit),
+ pr_table_profit : localize('Profit'),
+ pr_table_profit_value: formatMoney(currency, profit),
});
}
@@ -41,7 +41,7 @@ const updateContractBalance = (balance) => {
$('#contract_purchase_balance').html(localize('Account balance:')).append($('
', { html: formatMoney(Client.get('currency'), balance) }));
dataManager.setPurchase({
pr_balance : localize('Account balance:'),
- pr_balanceValue: formatMoney(Client.get('currency'), balance),
+ pr_balance_value: formatMoney(Client.get('currency'), balance),
});
};
diff --git a/src/javascript/app/pages/user/view_popup/view_popup.js b/src/javascript/app/pages/user/view_popup/view_popup.js
index 330281843b0..a7ed2702b3f 100644
--- a/src/javascript/app/pages/user/view_popup/view_popup.js
+++ b/src/javascript/app/pages/user/view_popup/view_popup.js
@@ -64,8 +64,8 @@ const ViewPopup = (() => {
getContract();
dataManager.setPurchase({
- showContractDetailsPopup: true,
- cd_description : null,
+ show_contract_details_popup: true,
+ cd_description : null,
});
};
@@ -161,7 +161,7 @@ const ViewPopup = (() => {
ViewPopupUI.repositionConfirmation();
dataManager.setPurchase({
- cd_contractType : ContractTypeDisplay()[contract.contract_type],
+ cd_contract_type : ContractTypeDisplay()[contract.contract_type],
cd_purchasePrice: formatMoney(contract.currency, contract.buy_price),
cd_multiplier : formatMoney(contract.currency, multiplier, false, 3, 2),
cd_payout : Lookback.isLookback(contract.contract_type) ?
@@ -181,15 +181,15 @@ const ViewPopup = (() => {
$('#trade_details_start_date').parent().setVisibility(0);
containerSetText('trade_details_purchase_time', epochToDateTime(contract.purchase_time), '', true);
dataManager.setPurchase({
- cd_purchaseTime: epochToDateTime(contract.purchase_time),
- soldBeforeStart: true,
+ cd_purchase_time: epochToDateTime(contract.purchase_time),
+ sold_before_start: true,
});
} else {
$('#trade_details_purchase_time').parent().setVisibility(0);
containerSetText('trade_details_start_date', epochToDateTime(contract.date_start), '', true);
dataManager.setPurchase({
- cd_startTime : epochToDateTime(contract.date_start),
- soldBeforeStart: false,
+ cd_start_time : epochToDateTime(contract.date_start),
+ sold_before_start: false,
});
}
@@ -202,7 +202,7 @@ const ViewPopup = (() => {
containerSetText('trade_details_barrier_low', is_sold_before_start ? '-' : addComma(contract.low_barrier), '', true);
dataManager.setPurchase({
cd_barrier : is_sold_before_start ? '-' : addComma(contract.high_barrier),
- cd_barrierLow: is_sold_before_start ? '-' : addComma(contract.low_barrier),
+ cd_barrier_low: is_sold_before_start ? '-' : addComma(contract.low_barrier),
});
} else if (contract.barrier) {
const formatted_barrier = addComma(contract.barrier);
@@ -237,7 +237,7 @@ const ViewPopup = (() => {
dataManager.setPurchase({
cd_barrier : is_sold_before_start ? '-' : contract.entry_spot_display_value,
- cd_barrierReset: contract.entry_tick_time && is_sold_before_start ? '-' : (barrier_prefix + formatted_barrier),
+ cd_barrier_reset: contract.entry_tick_time && is_sold_before_start ? '-' : (barrier_prefix + formatted_barrier),
});
}
}
@@ -283,15 +283,15 @@ const ViewPopup = (() => {
containerSetText('trade_details_indicative_price', indicative_price ? formatMoney(contract.currency, indicative_price) : '-');
dataManager.setPurchase({
- cd_transaction_ids: contract.transaction_ids,
- cd_indicativePrice: indicative_price ? formatMoney(contract.currency, indicative_price) : '-',
+ cd_transaction_ids : contract.transaction_ids,
+ cd_indicative_price: indicative_price ? formatMoney(contract.currency, indicative_price) : '-',
});
if (is_ended && !contract.sell_price) {
containerSetText('trade_details_profit_loss', localize('Waiting for contract settlement.'), { class: 'pending' });
dataManager.setPurchase({
- cd_profitLoss : localize('Waiting for contract settlement.'),
- cd_profitLossClass: 'pending',
+ cd_profit_loss : localize('Waiting for contract settlement.'),
+ cd_profit_loss_class: 'pending',
});
} else if (contract.sell_price || contract.bid_price) {
containerSetText('trade_details_profit_loss',
@@ -299,14 +299,14 @@ const ViewPopup = (() => {
{ class: (contract.profit >= 0 ? 'profit' : 'loss') }
);
dataManager.setPurchase({
- cd_profitLoss : `${formatMoney(contract.currency, contract.profit)}
(${(contract.profit_percentage > 0 ? '+' : '')}${addComma(contract.profit_percentage, 2)}%)`,
- cd_profitLossClass: (contract.profit >= 0 ? 'profit' : 'loss'),
+ cd_profit_loss : `${formatMoney(contract.currency, contract.profit)}
(${(contract.profit_percentage > 0 ? '+' : '')}${addComma(contract.profit_percentage, 2)}%)`,
+ cd_profit_loss_class: (contract.profit >= 0 ? 'profit' : 'loss'),
});
} else {
containerSetText('trade_details_profit_loss', '-', { class: 'loss' });
dataManager.setPurchase({
- cd_profitLoss : '-',
- cd_profitLossClass: 'loss',
+ cd_profit_loss : '-',
+ cd_profit_loss_class: 'loss',
});
}
@@ -330,20 +330,20 @@ const ViewPopup = (() => {
containerSetText('trade_details_entry_spot > span', '-');
containerSetText('trade_details_message', localize('Contract has not started yet'));
dataManager.setPurchase({
- cd_entrySpot: '-',
- cd_infoMsg : localize('Contract has not started yet'),
+ cd_entry_spot: '-',
+ cd_info_msg : localize('Contract has not started yet'),
});
} else {
if (contract.entry_spot > 0) {
// only show entry spot if available and contract was not sold before start time
containerSetText('trade_details_entry_spot > span', is_sold_before_start ? '-' : contract.entry_spot_display_value);
dataManager.setPurchase({
- cd_entrySpot: is_sold_before_start ? '-' : contract.entry_spot_display_value,
+ cd_entry_spot: is_sold_before_start ? '-' : contract.entry_spot_display_value,
});
}
containerSetText('trade_details_message', contract.validation_error && !is_unsupported_contract ? contract.validation_error : ' ');
dataManager.setPurchase({
- cd_infoMsg: contract.validation_error && !is_unsupported_contract ? contract.validation_error : null,
+ cd_info_msg: contract.validation_error && !is_unsupported_contract ? contract.validation_error : null,
});
if (is_unsupported_contract) {
const redirect = `
`;
@@ -404,7 +404,7 @@ const ViewPopup = (() => {
Clock.setExternalTimer(); // stop timer
dataManager.setPurchase({
- cd_remainingTime: '-',
+ cd_remaining_time: '-',
});
} else {
$container.find('#notice_ongoing').setVisibility(1);
@@ -427,7 +427,7 @@ const ViewPopup = (() => {
const now = Math.max(Math.floor((window.time || 0) / 1000), contract.current_spot_time || 0);
containerSetText('trade_details_live_date', epochToDateTime(now));
dataManager.setPurchase({
- cd_currentTime: epochToDateTime(now),
+ cd_current_time: epochToDateTime(now),
});
Clock.showLocalTimeOnHover('#trade_details_live_date');
@@ -436,7 +436,7 @@ const ViewPopup = (() => {
if (!is_started || contract.status !== 'open' || remained < 0) {
containerSetText('trade_details_live_remaining', '-');
dataManager.setPurchase({
- cd_remainingTime: '-',
+ cd_remaining_time: '-',
});
} else {
let days = 0;
@@ -449,8 +449,8 @@ const ViewPopup = (() => {
(days > 0 ? `${days} ${days > 1 ? localize('days') : localize('day')}, ` : '') + moment((remained) * 1000).utc().format('HH:mm:ss'));
dataManager.setPurchase({
- cd_remainingTime: (days > 0 ? `${days} ${days > 1 ? localize('days') : localize('day')}, ` : '') + moment((remained) * 1000).utc().format('HH:mm:ss'),
- cd_contractEnded: false,
+ cd_remaining_time: (days > 0 ? `${days} ${days > 1 ? localize('days') : localize('day')}, ` : '') + moment((remained) * 1000).utc().format('HH:mm:ss'),
+ cd_contract_ended: false,
});
}
};
@@ -466,33 +466,33 @@ const ViewPopup = (() => {
containerSetText('trade_details_profit_loss_label', localize('Profit/loss'));
dataManager.setPurchase({
- cd_currentLabel : localize('Contract result'),
- cd_indicativeLabel: localize('Payout'),
- cd_profitLossLabel: localize('Profit/loss'),
- cd_contractEnded : true,
+ cd_current_label : localize('Contract result'),
+ cd_indicative_label : localize('Payout'),
+ cd_profit_loss_label: localize('Profit/loss'),
+ cd_contract_ended : true,
});
if (contract.status === 'sold') {
containerSetText('trade_details_end_label', localize('Exit time'));
containerSetText('trade_details_end_date', epochToDateTime(contract.sell_time), '', true);
dataManager.setPurchase({
- cd_endLabel: localize('Exit time'),
- cd_endDate : epochToDateTime(contract.sell_time),
+ cd_end_label: localize('Exit time'),
+ cd_end_date : epochToDateTime(contract.sell_time),
});
}
if (Lookback.isLookback(contract.contract_type)) {
containerSetText('trade_details_spot_label', localize('Close'));
containerSetText('trade_details_spottime_label', localize('Close time'));
dataManager.setPurchase({
- cd_spotLabel : localize('Close'),
- cd_spotTimeLabel: localize('Close time'),
+ cd_spot_label : localize('Close'),
+ cd_spot_time_label: localize('Close time'),
});
} else {
containerSetText('trade_details_spot_label', localize('Exit spot'));
containerSetText('trade_details_spottime_label', localize('Exit spot time'));
dataManager.setPurchase({
- cd_spotLabel : localize('Exit spot'),
- cd_spotTimeLabel: localize('Exit spot time'),
+ cd_spot_label : localize('Exit spot'),
+ cd_spot_time_label: localize('Exit spot time'),
});
}
@@ -540,12 +540,12 @@ const ViewPopup = (() => {
if (show) {
setAuditVisibility(1);
dataManager.setPurchase({
- cd_showAudit: true,
+ cd_show_audit: true,
});
} else {
setAuditButtonsVisibility(1);
dataManager.setPurchase({
- cd_showAudit: false,
+ cd_show_audit: false,
});
}
return;
@@ -724,7 +724,7 @@ const ViewPopup = (() => {
createAuditHeader(contract_starts.table);
appendAuditLink('trade_details_entry_spot');
dataManager.setPurchase({
- cd_showAuditBtn: true,
+ cd_show_audit_buton: true,
});
} else {
contract_starts.div.remove();
@@ -737,7 +737,7 @@ const ViewPopup = (() => {
createAuditHeader(contract_ends.table);
appendAuditLink('trade_details_current_spot');
dataManager.setPurchase({
- cd_showAuditBtn: true,
+ cd_show_audit_buton: true,
});
} else {
contract_ends.div.remove();
@@ -756,7 +756,7 @@ const ViewPopup = (() => {
appendAuditLink('trade_details_entry_spot');
appendAuditLink('trade_details_current_spot');
dataManager.setPurchase({
- cd_showAuditBtn: true,
+ cd_show_audit_buton: true,
});
} else {
contract_details.div.remove();
@@ -838,20 +838,20 @@ const ViewPopup = (() => {
// Pass all contract details to new quill contract detail popup
// cd_ prefix is Contract Details
dataManager.setPurchase({
- cd_description : longcode,
- cd_showEntrySpot : should_show_entry_spot,
- cd_showBarrier : should_show_barrier,
- cd_showBarrierReset: Reset.isReset(contract.contract_type),
- cd_showBarrierLow : contract.barrier_count > 1 ,
- cd_barrierLabel : barrier_text,
- cd_spotLabel : localize('Spot'),
- cd_lowBarrierText : low_barrier_text,
- cd_payoutLabel : Callputspread.isCallputspread(contract.contract_type) ? localize('Maximum payout') : localize('Potential payout'),
- cd_chartId : (contract.tick_count ? id_tick_chart : 'analysis_live_chart'),
- cd_currentLabel : localize('Current'),
- cd_spotTimeLabel : localize('Spot time'),
- cd_indicativeLabel : localize('Indicative'),
- cd_profitLossLabel : localize('Potential profit/loss'),
+ cd_description : longcode,
+ cd_show_entry_spot : should_show_entry_spot,
+ cd_show_barrier : should_show_barrier,
+ cd_show_barrier_reset: Reset.isReset(contract.contract_type),
+ cd_show_barrier_low : contract.barrier_count > 1 ,
+ cd_barrier_label : barrier_text,
+ cd_spot_label : localize('Spot'),
+ cd_low_barrier_text : low_barrier_text,
+ cd_payout_label : Callputspread.isCallputspread(contract.contract_type) ? localize('Maximum payout') : localize('Potential payout'),
+ cd_chart_id : (contract.tick_count ? id_tick_chart : 'analysis_live_chart'),
+ cd_current_label : localize('Current'),
+ cd_spot_time_label : localize('Spot time'),
+ cd_indicative_label : localize('Indicative'),
+ cd_profit_loss_label : localize('Potential profit/loss'),
});
return $(`#${wrapper_id}`);
@@ -885,7 +885,7 @@ const ViewPopup = (() => {
}
} else if ($loading) {
dataManager.setContract({
- hidePageLoader: true,
+ hide_page_loader: true,
});
if ($loading.length) {
@@ -921,7 +921,7 @@ const ViewPopup = (() => {
const is_started = !contract.is_forward_starting || contract.current_spot_time > contract.date_start;
const $sell_wrapper = $container.find('#contract_sell_wrapper');
dataManager.setPurchase({
- cd_showSell: true,
+ cd_show_sell: true,
});
if (is_exist) {
@@ -929,7 +929,7 @@ const ViewPopup = (() => {
addSellNote($sell_wrapper);
$sell_wrapper.find(`#${sell_button_id}`).text(localize('Sell at market'));
dataManager.setPurchase({
- cd_sellLabel: localize('Sell at market'),
+ cd_sell_label: localize('Sell at market'),
});
}
return;
@@ -943,7 +943,7 @@ const ViewPopup = (() => {
}
dataManager.setPurchase({
- cd_sellLabel: is_started ? localize('Sell at market') : localize('Sell'),
+ cd_sell_label: is_started ? localize('Sell at market') : localize('Sell'),
});
$container.find(`#${sell_button_id}`).unbind('click').click((e) => {
@@ -958,7 +958,7 @@ const ViewPopup = (() => {
});
} else {
dataManager.setPurchase({
- cd_showSell: false,
+ cd_show_sell: false,
});
if (!is_exist) return;
@@ -974,8 +974,8 @@ const ViewPopup = (() => {
.append($('', { text: localize('Contract will be sold at the prevailing market price when the request is received by our servers. This price may differ from the indicated price.') })));
dataManager.setPurchase({
- cd_sellInfo: `${localize('Note')}: ${localize('Contract will be sold at the prevailing market price when the request is received by our servers. This price may differ from the indicated price.')}`,
- cd_showSell: true,
+ cd_sellInfo : `${localize('Note')}: ${localize('Contract will be sold at the prevailing market price when the request is received by our servers. This price may differ from the indicated price.')}`,
+ cd_show_sell: true,
});
};
@@ -1001,7 +1001,7 @@ const ViewPopup = (() => {
} else {
$container.find('#errMsg').text(response.error.message).setVisibility(1);
dataManager.setPurchase({
- cd_errorMsg: response.error.message,
+ cd_error_msg: response.error.message,
});
}
sellSetVisibility(true);
@@ -1018,7 +1018,7 @@ const ViewPopup = (() => {
${localize('Your transaction reference number is [_1]', response.sell.transaction_id)}`);
dataManager.setPurchase({
- cd_sellMsg: `${localize('You have sold this contract at [_1] [_2]', [formatted_sell_price, getCurrencyDisplayCode(contract.currency)])}
+ cd_sell_msg: `${localize('You have sold this contract at [_1] [_2]', [formatted_sell_price, getCurrencyDisplayCode(contract.currency)])}
${localize('Your transaction reference number is [_1]', response.sell.transaction_id)}`,
});