, fieldName: string) => void;\r\n checkField: (\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n form: any,\r\n field: IFormField,\r\n ) => IValidationData;\r\n}\r\n\r\nexport function withFormGeneratorValidation(\r\n WrappedComponent: React.ComponentType
,\r\n getFieldsFromOuterScope: () => IFormField[],\r\n) {\r\n const inputsTables: Record> = {};\r\n const setInputsTableProp = (classComponent: InstanceType, fieldName: string) =>\r\n (inputsTables[fieldName] = classComponent);\r\n\r\n const InnerComponent: React.FC = (props) => {\r\n const { forwardRef, ...rest } = props;\r\n\r\n const initValidation = (fields: IFormField[]): IValidationState => {\r\n return fields.reduce((acc, field) => {\r\n if (field.type === 'section') {\r\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\r\n acc[field.name] = initValidation(field.fields!);\r\n } else {\r\n acc[field.name] = { valid: true, message: '' };\r\n }\r\n\r\n return acc;\r\n }, {});\r\n };\r\n\r\n const [validationState, setValidationState] = useState(() => initValidation(getFieldsFromOuterScope()));\r\n\r\n const handleSetInitialValidationState = (fields: IFormField[]) => {\r\n setValidationState(initValidation(fields));\r\n };\r\n\r\n const startsWithPath = (path: string, pathToCheck: string | string[]) => {\r\n const pathSegments = path.split('.');\r\n\r\n if (Array.isArray(pathToCheck)) {\r\n return pathToCheck.some((pathToCheck) => {\r\n const pathToCheckSegments = pathToCheck.split('.');\r\n\r\n return pathToCheckSegments.every((segment, i) => {\r\n return segment === pathSegments[i];\r\n });\r\n });\r\n } else {\r\n const pathToCheckSegments = pathToCheck.split('.');\r\n\r\n return pathToCheckSegments.every((segment, i) => {\r\n return segment === pathSegments[i];\r\n });\r\n }\r\n };\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n const checkField = (form: any, field: IFormField) => {\r\n if (field.required) {\r\n if (form[field.name] === '' || form[field.name] === null || form[field.name] === undefined) {\r\n return { valid: false, message: keyMap.formsValidationRequiredError };\r\n }\r\n\r\n if (field.type === 'multiselect' && !form[field.name].length) {\r\n return { valid: false, message: keyMap.formsValidationRequiredError };\r\n }\r\n\r\n if (field.confirm && form[field.name] !== form[field.confirm]) {\r\n const message = field.validationMessage || keyMap.formsValidationConfirmError;\r\n\r\n return { valid: false, message };\r\n }\r\n }\r\n\r\n if (field.onlyEng) {\r\n const validator = validators.onlyEngAndDigits;\r\n const params = { ...field };\r\n\r\n if (!validator.check(form[field.name], params)) {\r\n return { valid: false, message: validator.message };\r\n }\r\n }\r\n\r\n if (field.onlyEngLetters) {\r\n const validator = validators.onlyEngLetters;\r\n const params = { ...field };\r\n\r\n if (!validator.check(form[field.name], params)) {\r\n return { valid: false, message: validator.message };\r\n }\r\n }\r\n\r\n if (field.type && validators[field.type]) {\r\n const validator = validators[field.type];\r\n const params = { ...field, form };\r\n\r\n // @ts-ignore\r\n if (!validator.check(form[field.name], params)) {\r\n return { valid: false, message: validator.message };\r\n }\r\n }\r\n\r\n if (field.validator) {\r\n const { validator } = field;\r\n const params = { ...field, form };\r\n\r\n if (!validator.check(form[field.name], params)) {\r\n return { valid: false, message: validator.message, placeholders: validator.placeholders };\r\n }\r\n }\r\n\r\n if (field.type === 'array') {\r\n if (inputsTables[field.name] && !inputsTables[field.name].validate()) {\r\n return { valid: false, message: keyMap.formsValidationMapError };\r\n }\r\n }\r\n\r\n return { valid: true, message: '' };\r\n };\r\n\r\n const getValidation = (\r\n fields: IFormField[],\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n form: any,\r\n sectionPath: string | null,\r\n validationPath?: string,\r\n ): IValidationState => {\r\n return fields.reduce((validation, field) => {\r\n const path = sectionPath ? [sectionPath, field.name].join('.') : field.name;\r\n\r\n if (field.type === 'section') {\r\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\r\n validation[field.name] = getValidation(field.fields!, form[field.name], path, validationPath);\r\n } else if (validationPath && !startsWithPath(path, validationPath)) {\r\n validation[field.name] = { valid: true, message: '' };\r\n } else {\r\n validation[field.name] = checkField(form, field);\r\n }\r\n\r\n return validation;\r\n }, {});\r\n };\r\n\r\n const getIsValid = (fields: IFormField[], validation: IValidationState): boolean => {\r\n return fields.reduce((_isValid, field) => {\r\n let isValid = _isValid;\r\n\r\n if (isValid === false) {\r\n return isValid;\r\n }\r\n\r\n if (isHidden({ props }, field)) {\r\n return true;\r\n }\r\n\r\n if (field.type === 'hidden') {\r\n return true;\r\n }\r\n\r\n if (field.type === 'section') {\r\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\r\n isValid = getIsValid(field.fields!, validation[field.name] as IValidationState);\r\n } else {\r\n isValid = validation[field.name].valid as boolean;\r\n }\r\n\r\n return isValid;\r\n }, true);\r\n };\r\n\r\n const validate = (validationPath?: string): boolean => {\r\n const fields = getFieldsFromOuterScope();\r\n const { form } = props;\r\n const validation = getValidation(fields, form, null, validationPath);\r\n const isValid = getIsValid(fields, validation);\r\n\r\n setValidationState(validation);\r\n\r\n if (!isValid) {\r\n scrollToFirstError(fields, validation);\r\n }\r\n\r\n return isValid;\r\n };\r\n\r\n return (\r\n \r\n );\r\n };\r\n\r\n return React.forwardRef((props: P, ref) => );\r\n}\r\n\r\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\r\nexport const isHidden = (ctx: { props: any }, field: IFormField) => {\r\n return field.isHidden === true || (typeof field.isHidden === 'function' && field.isHidden(ctx));\r\n};\r\n\r\nconst scrollToFirstError = (fields: IFormField[], validation: IValidationState) => {\r\n const getInvalidFieldName = (fields: IFormField[], validation: IValidationState): string => {\r\n return fields.reduce((name, field) => {\r\n if (name) {\r\n return name;\r\n }\r\n\r\n if (field.type === 'section') {\r\n return getInvalidFieldName(field.fields as IFormField[], validation[field.name] as IValidationState) as string;\r\n }\r\n\r\n if (!validation[field.name].valid) {\r\n return field.name;\r\n }\r\n\r\n return name;\r\n }, '');\r\n };\r\n\r\n const invalidFiledName = getInvalidFieldName(fields, validation);\r\n const element = document.querySelector(`[data-fieldname=${invalidFiledName}]`) as HTMLElement | null;\r\n\r\n if (element) {\r\n const closestParentModalNode = element.closest('.modal');\r\n\r\n // ScrollTo is not supported for old mobile browsers.\r\n // ScrollIntoView has better support, but still not perfect\r\n\r\n if (closestParentModalNode) {\r\n if (closestParentModalNode.scrollTo) {\r\n closestParentModalNode.scrollTo({\r\n top: element.offsetTop,\r\n behavior: 'smooth',\r\n });\r\n } else if (closestParentModalNode.scrollIntoView) {\r\n closestParentModalNode.scrollIntoView();\r\n }\r\n } else {\r\n const boundingClientRect = element.getBoundingClientRect();\r\n\r\n if (window.scrollTo) {\r\n window.scrollTo({\r\n top: window.pageYOffset + boundingClientRect.top - 80,\r\n behavior: 'smooth',\r\n });\r\n } else if (element.scrollIntoView) {\r\n element.scrollIntoView();\r\n }\r\n }\r\n }\r\n};\r\n","import { KeyMapKeys } from '@locales/lokalise/keyMap';\r\nimport { ENUM_CONSTANTS } from 'components/shared/enum.constants';\r\nimport { CAPTCHA_PROVIDERS, ENUM_LOCALE_CODE, LANGUAGE_CODE_TO_LOCALE_CODE } from 'global.enums';\r\nimport { LanguageType } from 'global.interfaces';\r\nimport i18next from 'i18next';\r\nimport { IEnumConstant } from './enum.constants.interface';\r\nimport { EmptyObject } from './shared.interfaces';\r\n\r\nexport interface ILocaleStructure {\r\n key: ENUM_LOCALE_CODE;\r\n title: string;\r\n i18n: string;\r\n}\r\n\r\nexport interface ILocalesEnum {\r\n name: string;\r\n value: ENUM_LOCALE_CODE;\r\n}\r\n\r\ninterface IExcludeOptions {\r\n exclude?: boolean;\r\n ignoreValue?: string | null;\r\n}\r\n\r\nexport type LocalMapType = {\r\n [key in LanguageType]: ILocaleStructure;\r\n};\r\n\r\nconst SETTINGS = window.settings as ISystemSettings;\r\n\r\nexport class GENERAL_CONSTANTS {\r\n static get LOCALES(): LocalMapType | EmptyObject {\r\n if (!SETTINGS || !SETTINGS.language || SETTINGS.language.length === 0) {\r\n return {};\r\n }\r\n\r\n const localeMap: LocalMapType = SETTINGS.language\r\n .sort((a, b) => a.order - b.order)\r\n .filter((lang) => !lang.exclude)\r\n .reduce((acc, lang) => {\r\n const key = lang.code.replace('-', '_').toLocaleUpperCase() as LanguageType;\r\n\r\n const i18nTranslationKey = `enum.language.${lang.key.toLowerCase()}`;\r\n\r\n acc[key] = {\r\n key: lang.code as ENUM_LOCALE_CODE,\r\n title: i18next.t(i18nTranslationKey as KeyMapKeys),\r\n i18n: i18nTranslationKey,\r\n };\r\n\r\n return acc;\r\n }, {} as LocalMapType);\r\n\r\n return localeMap;\r\n }\r\n\r\n static get DEFAULT_LOCALE(): ENUM_LOCALE_CODE {\r\n const locales = this.LOCALES;\r\n\r\n const localesKeys = Object.keys(locales);\r\n\r\n if (localesKeys.length == 0) {\r\n return LANGUAGE_CODE_TO_LOCALE_CODE.en;\r\n }\r\n\r\n return locales[localesKeys[0] as LanguageType].key;\r\n }\r\n\r\n static get LOCALES_ENUM(): ILocalesEnum[] {\r\n const locales = this.LOCALES;\r\n\r\n return Object.keys(locales).map((lang) => ({\r\n name: locales[lang as LanguageType].i18n,\r\n value: locales[lang as LanguageType].key,\r\n }));\r\n }\r\n\r\n static get COUNTRY(): IEnumConstant[] {\r\n return this.getCountryList();\r\n }\r\n\r\n static get COUNTRY_WITH_EXCLUDED(): IEnumConstant[] {\r\n return this.getCountryList({ exclude: false });\r\n }\r\n\r\n static get COUNTRY_WITH_ALL_NOT_ALLOWED_AND_EXCLUDED(): IEnumConstant[] {\r\n return this.getGeneralEnumList('country', 'COUNTRY', { exclude: false });\r\n }\r\n\r\n static get COUNTRY_WITH_ALL_AND_EXCLUDED(): IEnumConstant[] {\r\n return this.getGeneralEnumList('country', 'COUNTRY', { exclude: false }).filter(\r\n (c) => c.name !== 'enum.country.notAllowed',\r\n );\r\n }\r\n\r\n static get DEFAULT_COUNTRY(): string | undefined {\r\n const countries = this.PREFERRED_COUNTRIES;\r\n\r\n return countries.length > 0 ? countries[0] : undefined;\r\n }\r\n\r\n static get PREFERRED_COUNTRIES(): string[] {\r\n if (!SETTINGS || !SETTINGS.country) {\r\n return [];\r\n }\r\n\r\n return SETTINGS.country\r\n .filter((x) => x.preferred)\r\n .sort((a, b) => a.order - b.order)\r\n .map((x) => x.code.toLowerCase());\r\n }\r\n\r\n static get EXCLUDE_COUNTRIES(): string[] {\r\n if (!SETTINGS || !SETTINGS.country) {\r\n return [];\r\n }\r\n\r\n return SETTINGS.country.filter((x) => x.exclude).map((x) => x.code.toLowerCase());\r\n }\r\n\r\n static get PSP_CURRENCY(): IEnumConstant[] {\r\n return this.getGeneralEnumList('currency', 'PSP_CURRENCY');\r\n }\r\n\r\n static get DEFAULT_CURRENCY(): string {\r\n const currency = this.PSP_CURRENCY;\r\n\r\n if (currency.length > 0) {\r\n return currency[0].value;\r\n }\r\n\r\n return '';\r\n }\r\n\r\n static get WALLET_OPERATION_CATEGORY(): IEnumConstant[] {\r\n return this.getGeneralEnumList('walletOperationCategory', 'WALLET_OPERATION_CATEGORY');\r\n }\r\n\r\n static get GROUP_MAPPING(): IEnumConstant[] {\r\n return this.getGeneralEnumList('groupMapping', 'GROUP_MAPPING');\r\n }\r\n\r\n static get DEFAULT_NUMBER_PRECISION(): number {\r\n if (!SETTINGS?.numberPrecision) {\r\n return 4;\r\n }\r\n\r\n return SETTINGS.numberPrecision;\r\n }\r\n\r\n static get ID_HASH_SUFFIX(): string {\r\n if (!SETTINGS?.gtmSettings?.idHashSuffix) {\r\n return '';\r\n }\r\n\r\n return SETTINGS.gtmSettings.idHashSuffix;\r\n }\r\n\r\n static get CAPTCHA_PROVIDER(): CAPTCHA_PROVIDERS | null {\r\n if (!SETTINGS?.captchaSettings?.provider) {\r\n return null;\r\n }\r\n\r\n return SETTINGS.captchaSettings.provider.toLowerCase() === CAPTCHA_PROVIDERS.HCAPTCHA\r\n ? CAPTCHA_PROVIDERS.HCAPTCHA\r\n : CAPTCHA_PROVIDERS.RECAPTCHA;\r\n }\r\n\r\n static get CAPTCHA_SETTINGS_KEY(): string {\r\n if (!SETTINGS?.captchaSettings?.siteKey) {\r\n return '';\r\n }\r\n\r\n return SETTINGS.captchaSettings.siteKey;\r\n }\r\n\r\n static get CAPTCHA_SIGNIN_PROTECTION(): boolean {\r\n if (!SETTINGS?.captchaSettings?.signInProtection) {\r\n return false;\r\n }\r\n\r\n return SETTINGS.captchaSettings.signInProtection;\r\n }\r\n\r\n static get CAPTCHA_WIDGET_SETTINGS() {\r\n if (!SETTINGS?.captchaSettings?.widgetSettings) {\r\n return {};\r\n }\r\n\r\n return SETTINGS.captchaSettings.widgetSettings;\r\n }\r\n\r\n static get MEASUREMENT_SETTINGS(): ISystemMeasurementSetting[] {\r\n if (!SETTINGS?.measurementSettings) {\r\n return [];\r\n }\r\n\r\n return SETTINGS.measurementSettings;\r\n }\r\n\r\n static getGeneralEnumList(\r\n globalProperty: keyof ISystemSettings,\r\n enumName: keyof typeof ENUM_CONSTANTS,\r\n excludeOptions?: IExcludeOptions,\r\n ): IEnumConstant[] {\r\n if (!SETTINGS) {\r\n return [];\r\n }\r\n\r\n const list = SETTINGS[globalProperty];\r\n\r\n if (!Array.isArray(list)) {\r\n return [];\r\n }\r\n\r\n const fullEnumList = ENUM_CONSTANTS[enumName];\r\n const resultList: Array = [];\r\n const exclude = excludeOptions?.exclude ?? true;\r\n\r\n list\r\n .sort((a, b) => a.order - b.order)\r\n .forEach((item) => {\r\n if (exclude && item.exclude && excludeOptions?.ignoreValue !== item.key) {\r\n return;\r\n }\r\n\r\n // @ts-ignore\r\n const it = fullEnumList.find((x) => x.value === item.key);\r\n\r\n if (it) {\r\n resultList.push(it);\r\n }\r\n });\r\n\r\n return resultList;\r\n }\r\n\r\n static getCountryList(excludeOptions?: IExcludeOptions): IEnumConstant[] {\r\n return this.getGeneralEnumList('country', 'COUNTRY', excludeOptions).filter(\r\n (c) => c.name !== 'enum.country.notAllowed' && c.name !== 'enum.country.allCountries',\r\n );\r\n }\r\n\r\n static getSystemSettingsCountryByKey(key: string): ISystemSettingsCountry | undefined {\r\n return SETTINGS.country.find((x) => x.key === key);\r\n }\r\n}\r\n","import { enrichGoogleAnalyticsSuffix } from 'components/shared/utils/enrichGoogleAnalyticsSuffix';\r\nimport { CURRENCY } from 'global.enums';\r\n\r\nconst sendGoogleEvent = (event: Record) => {\r\n if (!Array.isArray(window.dataLayer)) return;\r\n\r\n window.dataLayer.push(event);\r\n};\r\n\r\nexport const pushTicketStartEvent = (): void => {\r\n sendGoogleEvent({\r\n event: 'ticketStart',\r\n });\r\n};\r\n\r\nexport const pushTicketSubmittedEvent = (): void => {\r\n sendGoogleEvent({\r\n event: 'ticketSubmitted',\r\n });\r\n};\r\n\r\nexport const pushTicketErrorEvent = (errorMsg: string): void => {\r\n sendGoogleEvent({\r\n errorMsg,\r\n event: 'ticketError',\r\n });\r\n};\r\n\r\nexport const pushLoginSuccessfulEvent = (userIdHash: string): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n event: 'loginSuccessful',\r\n });\r\n};\r\n\r\nexport const pushLoginErrorEvent = (errorMsg: string): void => {\r\n sendGoogleEvent({\r\n errorMsg,\r\n event: 'loginError',\r\n });\r\n};\r\n\r\nexport const pushRegistrationSuccessfulEvent = (\r\n userIdHash: string,\r\n clientSourceType: number,\r\n language: string,\r\n countryCode: string,\r\n): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n clientSourceType,\r\n language,\r\n countryCode,\r\n event: 'registrationSuccessful',\r\n });\r\n};\r\n\r\nexport const pushRegistrationErrorEvent = (errorMsg: string): void => {\r\n sendGoogleEvent({\r\n errorMsg,\r\n event: 'registrationError',\r\n });\r\n};\r\n\r\nexport const pushLanguageSelectorEvent = (language: string): void => {\r\n sendGoogleEvent({\r\n language,\r\n event: 'languageSelector',\r\n });\r\n};\r\n\r\nexport const pushExportEvent = (userIdHash: string, event: string): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n event,\r\n });\r\n};\r\n\r\nexport const pushAccountsBalanceCurrencyCodeEvent = (currencyCode: string): void => {\r\n sendGoogleEvent({\r\n currencyCode,\r\n event: 'accountsBalanceCurrencyCode',\r\n });\r\n};\r\n\r\nexport const pushEWalletCurrencyCodeEvent = (currencyCode: string): void => {\r\n sendGoogleEvent({\r\n currencyCode,\r\n event: 'eWalletCurrencyCode',\r\n });\r\n};\r\n\r\nexport const pushAccountCreateErrorEvent = (errorMsg: string): void => {\r\n sendGoogleEvent({\r\n errorMsg,\r\n event: 'accountCreateError',\r\n });\r\n};\r\n\r\nexport const pushDownloadLegalDocumentEvent = (\r\n userIdHash: string,\r\n language: string,\r\n docType: string,\r\n event: string,\r\n): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n language,\r\n docType,\r\n event,\r\n });\r\n};\r\n\r\nexport const pushTradingPlatformDownloadEvent = (linkType: string): void => {\r\n sendGoogleEvent({\r\n platformDownloaded: linkType,\r\n event: 'tradingPlatformDownload',\r\n });\r\n};\r\n\r\nexport const pushMamDocUploadEvent = (userIdHash: string, docType: string): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n docType,\r\n event: 'mamDocUpload',\r\n });\r\n};\r\n\r\nexport const pushNotificationsFilterEvent = (subject: string): void => {\r\n sendGoogleEvent({\r\n subject,\r\n event: 'notificationsFilter',\r\n });\r\n};\r\n\r\nexport const pushPartnershipStartEvent = (): void => {\r\n sendGoogleEvent({\r\n event: 'partnershipStart',\r\n });\r\n};\r\n\r\nexport const pushPartnershipSubmittedEvent = (): void => {\r\n sendGoogleEvent({\r\n event: 'partnershipSubmitted',\r\n });\r\n};\r\n\r\nexport const pushPartnershipErrorEvent = (userIdHash: string, errorMsg: string): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n errorMsg,\r\n event: 'partnershipError',\r\n });\r\n};\r\n\r\nexport const pushDocumentUploadEvent = (documentType: string): void => {\r\n sendGoogleEvent({\r\n documentType,\r\n event: 'documentUpload',\r\n });\r\n};\r\n\r\nexport const pushDocumentUploadErrorEvent = (errorMsg: string): void => {\r\n sendGoogleEvent({\r\n errorMsg,\r\n event: 'documentUploadError',\r\n });\r\n};\r\n\r\nexport const pushPinPasswordUpdateEvent = (): void => {\r\n sendGoogleEvent({\r\n event: 'pinPasswordUpdate',\r\n });\r\n};\r\n\r\nexport const pushEWalletViewedEvent = (): void => {\r\n sendGoogleEvent({\r\n event: 'eWalletViewed',\r\n });\r\n};\r\n\r\nexport const pushTransferSuccessfulEvent = (\r\n accountIdHash: string | undefined,\r\n transferValue: string,\r\n transferCurrency: string,\r\n destinationAccountID: string | undefined,\r\n): void => {\r\n sendGoogleEvent({\r\n accountID: enrichGoogleAnalyticsSuffix(accountIdHash),\r\n transferValue,\r\n transferCurrency,\r\n destinationAccountID,\r\n event: 'transferSuccessful',\r\n });\r\n};\r\n\r\nexport const pushTransferErrorEvent = (accountIdHash: string | undefined, errorMsg: string): void => {\r\n sendGoogleEvent({\r\n accountID: enrichGoogleAnalyticsSuffix(accountIdHash),\r\n errorMsg,\r\n event: 'transferError',\r\n });\r\n};\r\n\r\nexport const pushWithdrawFundsSuccessfulEvent = (\r\n accountIdHash: string,\r\n withdrawIdHash: string,\r\n depositValue: number,\r\n depositCurrency: string,\r\n depositSource: string,\r\n): void => {\r\n sendGoogleEvent({\r\n accountID: enrichGoogleAnalyticsSuffix(accountIdHash),\r\n withdrawID: enrichGoogleAnalyticsSuffix(withdrawIdHash),\r\n depositValue,\r\n depositCurrency,\r\n depositSource,\r\n event: 'withdrawFundsSuccessful',\r\n });\r\n};\r\n\r\nexport const pushWithdrawFundsErrorEvent = (accountIdHash: string, errorMsg: string): void => {\r\n sendGoogleEvent({\r\n accountID: enrichGoogleAnalyticsSuffix(accountIdHash),\r\n errorMsg,\r\n event: 'withdrawFundsError',\r\n });\r\n};\r\n\r\nexport const pushAccountCreateSuccessfulEvent = (\r\n userIdHash: string,\r\n clientSourceType: number,\r\n accountIdHash: string,\r\n accountType: string,\r\n status: string,\r\n leverage?: number | string,\r\n): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n clientSourceType,\r\n accountID: enrichGoogleAnalyticsSuffix(accountIdHash),\r\n accountType,\r\n leverage,\r\n verification: status,\r\n event: 'accountCreateSuccessful',\r\n });\r\n};\r\n\r\nexport const pushStartedCopyMasterSuccessEvent = (\r\n userIdHash: string,\r\n clientSourceType: number,\r\n accountIdHash: string,\r\n accountType: string,\r\n masterTradingAccountIdHash: string,\r\n masterUserIdHash: string,\r\n): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n clientSourceType,\r\n accountID: enrichGoogleAnalyticsSuffix(accountIdHash),\r\n accountType,\r\n master_accountID: enrichGoogleAnalyticsSuffix(masterTradingAccountIdHash),\r\n master_userId: enrichGoogleAnalyticsSuffix(masterUserIdHash),\r\n event: 'started_copy_master_success',\r\n });\r\n};\r\n\r\nexport const pushStoppedCopyMasterSuccessEvent = (\r\n userIdHash: string,\r\n clientSourceType: number,\r\n accountIdHash: string,\r\n accountType: string,\r\n masterTradingAccountIdHash: string | undefined,\r\n masterUserIdHash: string | undefined,\r\n): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n clientSourceType,\r\n accountID: enrichGoogleAnalyticsSuffix(accountIdHash),\r\n accountType,\r\n master_accountID: enrichGoogleAnalyticsSuffix(masterTradingAccountIdHash),\r\n master_userId: enrichGoogleAnalyticsSuffix(masterUserIdHash),\r\n stop_copy_reason: 'byhimself',\r\n event: 'stopped_copy_master_success',\r\n });\r\n};\r\n\r\nexport const pushHowToDepositVideoEvent = (\r\n userIdHash: string,\r\n clientSourceType: number,\r\n ibUserId: string | null,\r\n verification: string,\r\n): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n clientSourceType,\r\n ib_user_id: enrichGoogleAnalyticsSuffix(ibUserId),\r\n verification,\r\n eventAction: 'click_play',\r\n event: 'how_to_deposit_video',\r\n });\r\n};\r\n\r\nexport const pushSuccessDepositEvent = (\r\n accountIdHash: string,\r\n depositIdHash: string,\r\n depositValue: number,\r\n depositAmountUSD: number,\r\n depositCurrency: CURRENCY,\r\n depositSource: string,\r\n userIdHash: string,\r\n clientSourceType: number,\r\n ibUserId: string | null,\r\n accountType: string,\r\n depositFundsType: string,\r\n verification: string,\r\n): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n clientSourceType,\r\n ib_user_id: enrichGoogleAnalyticsSuffix(ibUserId),\r\n accountID: enrichGoogleAnalyticsSuffix(accountIdHash),\r\n accountType,\r\n depositID: enrichGoogleAnalyticsSuffix(depositIdHash),\r\n depositValue,\r\n depositAmountUSD,\r\n depositCurrency,\r\n depositSource,\r\n deposit_funds_type: depositFundsType,\r\n verification,\r\n event: 'deposit_start',\r\n });\r\n};\r\n\r\nexport const pushErrorDepositEvent = (accountIdHash: string, errorMsg: string): void => {\r\n sendGoogleEvent({\r\n accountID: enrichGoogleAnalyticsSuffix(accountIdHash),\r\n errorMsg,\r\n event: 'deposit_start_error',\r\n });\r\n};\r\n\r\nexport const pushDepositPreStartEvent = (\r\n userIdHash: string,\r\n clientSourceType: number,\r\n ibUserId: string | null,\r\n accountIdHash: string,\r\n accountType: string,\r\n depositValue: number,\r\n depositCurrency: CURRENCY,\r\n depositAmountUSD: number,\r\n depositSource: string,\r\n depositFundsType: string,\r\n verification: string,\r\n): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n clientSourceType,\r\n ib_user_id: enrichGoogleAnalyticsSuffix(ibUserId),\r\n accountID: enrichGoogleAnalyticsSuffix(accountIdHash),\r\n accountType,\r\n depositValue,\r\n depositCurrency,\r\n depositAmountUSD,\r\n depositSource,\r\n deposit_funds_type: depositFundsType,\r\n verification,\r\n event: 'deposit_pre_start',\r\n });\r\n};\r\n\r\nexport const pushQuickDepositClickBtnEvent = (\r\n userIdHash: string,\r\n clientSourceType: number,\r\n ibUserId: string | null,\r\n verification: string,\r\n): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n clientSourceType,\r\n ib_user_id: enrichGoogleAnalyticsSuffix(ibUserId),\r\n verification,\r\n event: 'quick_deposit_clck_btn',\r\n });\r\n};\r\n\r\nexport const pushAccountCardDepositClickEvent = (\r\n userIdHash: string,\r\n clientSourceType: number,\r\n ibUserId: string | null,\r\n accountIdHash: string,\r\n accountType: string,\r\n verification: string,\r\n event: string,\r\n): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n clientSourceType,\r\n ib_user_id: enrichGoogleAnalyticsSuffix(ibUserId),\r\n accountID: enrichGoogleAnalyticsSuffix(accountIdHash),\r\n accountType,\r\n verification,\r\n event,\r\n });\r\n};\r\n\r\nexport const pushSelectDepositFundsCategoryEvent = (\r\n userIdHash: string,\r\n clientSourceType: number,\r\n ibUserId: string | null,\r\n verification: string,\r\n depositFundsType: string | undefined,\r\n): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n clientSourceType,\r\n ib_user_id: enrichGoogleAnalyticsSuffix(ibUserId),\r\n verification,\r\n deposit_funds_type: depositFundsType,\r\n event: 'deposit_funds_type_start',\r\n });\r\n};\r\n\r\nexport const pushDepositPaymentSourceEvent = (\r\n userIdHash: string,\r\n clientSourceType: number,\r\n ibUserId: string | null,\r\n verification: string,\r\n depositFundsType: string | undefined,\r\n depositSource: string,\r\n): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n clientSourceType,\r\n ib_user_id: enrichGoogleAnalyticsSuffix(ibUserId),\r\n verification,\r\n deposit_funds_type: depositFundsType,\r\n depositSource,\r\n eventAction: 'psp_click',\r\n event: 'deposit_payment_source',\r\n });\r\n};\r\n\r\nexport const pushAuthorizedBankingMethodEvent = (\r\n userIdHash: string,\r\n clientSourceType: number,\r\n ibUserId: string | null,\r\n depositFundsType: string | undefined,\r\n verification: string,\r\n eventAction: string,\r\n): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n clientSourceType,\r\n ib_user_id: enrichGoogleAnalyticsSuffix(ibUserId),\r\n verification,\r\n deposit_funds_type: depositFundsType,\r\n eventAction,\r\n event: 'online_bank_transaction',\r\n });\r\n};\r\n\r\nexport const pushOpenAccountModalShowEvent = (\r\n userIdHash: string,\r\n clientSourceType: number,\r\n verification: string,\r\n): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n clientSourceType,\r\n verification,\r\n event: 'open_account_modal_window_shows',\r\n });\r\n};\r\n\r\nexport const pushOpenAccountModalCloseEvent = (\r\n userIdHash: string,\r\n clientSourceType: number,\r\n verification: string,\r\n): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n clientSourceType,\r\n verification,\r\n event: 'open_account_modal_window_closed',\r\n });\r\n};\r\n\r\nexport const pushRegistrationSuccessfulMaPageEvent = (userIdHash: string, clientSourceType: number): void => {\r\n sendGoogleEvent({\r\n userID: enrichGoogleAnalyticsSuffix(userIdHash),\r\n clientSourceType,\r\n event: 'registration_successful_ma_page',\r\n });\r\n};\r\n\r\nexport const pushGetSmsCodeEvent = (): void => {\r\n sendGoogleEvent({\r\n event: 'sms_phone_confirm_click_get_code',\r\n });\r\n};\r\n\r\nexport const pushInputSmsCodeCharacterEvent = (): void => {\r\n sendGoogleEvent({\r\n event: 'sms_phone_confirm_input_character',\r\n });\r\n};\r\n\r\nexport const pushSmsCodeResendEvent = (): void => {\r\n sendGoogleEvent({\r\n event: 'sms_phone_confirm_resend_code',\r\n });\r\n};\r\n\r\nexport const pushSmsCodeIsCorrectEvent = (): void => {\r\n sendGoogleEvent({\r\n event: 'sms_phone_confirm_success',\r\n });\r\n};\r\n\r\nexport const pushSmsCodeIsIncorrectEvent = (): void => {\r\n sendGoogleEvent({\r\n event: 'sms_phone_confirm_fail',\r\n });\r\n};\r\n\r\nexport const pushRegistrationContinueEvent = (): void => {\r\n sendGoogleEvent({\r\n event: 'ma_reg_continue_button_click',\r\n });\r\n};\r\n","import React, { useState, useRef, useEffect, FC, useCallback } from 'react';\r\nimport { Button } from '@components-library/Button';\r\nimport { IFormField } from '@components-shared/forms/formField.interface';\r\nimport ModalPortal from '@components-shared/modal/ModalPortal';\r\nimport { useModalEventObserver } from '@components-shared/modal/modalEventObserver';\r\nimport { KeyMapKeys, keyMap } from '@locales/lokalise/keyMap';\r\nimport cn from 'classnames';\r\nimport FormGenerator from 'components/shared/forms/formGenerator';\r\nimport i18next from 'i18next';\r\nimport { CloseButton } from '../shared/CloseButton';\r\n\r\nconst el = document.createElement('div');\r\nconst { body } = document;\r\n\r\nbody.appendChild(el);\r\n\r\nconst FIELDS: IFormField[] = [\r\n {\r\n name: 'commentText',\r\n title: keyMap.sharedFieldsInternalComment,\r\n type: 'textarea',\r\n attributes: { autoComplete: 'off' },\r\n required: true,\r\n },\r\n];\r\n\r\nexport type ConfirmModalProps = {\r\n className?: string;\r\n title?: string;\r\n subtitle?: string;\r\n};\r\n\r\nexport type ConfirmModalState = {\r\n content: string | React.ReactElement;\r\n action: null | ((commentText?: string) => Promise) | ((commentText?: string) => void);\r\n closeAction?: null | (() => void);\r\n needComment?: boolean;\r\n confirmBtnText?: string;\r\n cancelBtnText?: string;\r\n};\r\n\r\ninterface StaticConfirmModalProps {\r\n show: (\r\n content: ConfirmModalState['content'],\r\n action: ConfirmModalState['action'],\r\n closeAction?: ConfirmModalState['closeAction'],\r\n needComment?: ConfirmModalState['needComment'],\r\n confirmBtnText?: ConfirmModalState['confirmBtnText'],\r\n cancelBtnText?: ConfirmModalState['cancelBtnText'],\r\n ) => void;\r\n}\r\n\r\nconst Form = FormGenerator(FIELDS);\r\n\r\nconst ConfirmModal: FC & StaticConfirmModalProps = ({ className, title, subtitle }) => {\r\n const [state, setState] = useState({\r\n content: '',\r\n action: null,\r\n closeAction: null,\r\n needComment: false,\r\n confirmBtnText: '',\r\n cancelBtnText: '',\r\n });\r\n\r\n const [value, setValue] = useState({ commentText: '' });\r\n\r\n const formRef = useRef(null);\r\n\r\n const close = useCallback(() => {\r\n setState({ ...state, content: '', action: null, closeAction: null });\r\n setValue({ commentText: '' });\r\n }, [state]);\r\n\r\n useModalEventObserver(close, { condition: Boolean(state.content), ignoreEscButton: true });\r\n\r\n const show = useCallback(\r\n (\r\n content: ConfirmModalState['content'],\r\n action: ConfirmModalState['action'],\r\n closeAction: ConfirmModalState['closeAction'] = null,\r\n needComment = false,\r\n confirmBtnText: ConfirmModalState['confirmBtnText'],\r\n cancelBtnText: ConfirmModalState['cancelBtnText'],\r\n ) => {\r\n setState({ ...state, content, action, closeAction, needComment, confirmBtnText, cancelBtnText });\r\n },\r\n [state],\r\n );\r\n\r\n useEffect(() => {\r\n ConfirmModal.show = show;\r\n }, [show]);\r\n\r\n const action = async () => {\r\n const { needComment, action } = state;\r\n\r\n if (needComment && formRef.current && !formRef.current.validate()) {\r\n return;\r\n }\r\n\r\n if (action) {\r\n await action(value.commentText);\r\n }\r\n close();\r\n };\r\n\r\n const closeAction = () => {\r\n close();\r\n if (state.closeAction) {\r\n state.closeAction();\r\n }\r\n };\r\n\r\n if (!state.content) {\r\n return null;\r\n }\r\n\r\n return (\r\n \r\n \r\n
\r\n
\r\n
\r\n {title &&
{i18next.t(title as KeyMapKeys)}
}\r\n {subtitle &&
{i18next.t(subtitle as KeyMapKeys)}
}\r\n
\r\n
\r\n
\r\n
\r\n {typeof state.content === 'string' ? i18next.t(state.content as KeyMapKeys) : state.content}\r\n
\r\n {state.needComment && (\r\n
\r\n
\r\n \r\n {i18next.t((state.confirmBtnText as KeyMapKeys) || (keyMap.modalYes as KeyMapKeys))}\r\n \r\n \r\n {i18next.t((state.cancelBtnText as KeyMapKeys) || (keyMap.modalNo as KeyMapKeys))}\r\n \r\n
\r\n
\r\n
\r\n
\r\n \r\n );\r\n};\r\n\r\nConfirmModal.show = () => console.error('method show is not defined');\r\n\r\nexport { ConfirmModal };\r\n","import { useRef, useEffect, ReactNode } from 'react';\r\nimport ReactDOM from 'react-dom';\r\n\r\nconst ModalPortal = ({ children }: { children: ReactNode }) => {\r\n const portalElementRef = useRef(document.createElement('div'));\r\n\r\n useEffect(() => {\r\n const currentPortalElement = portalElementRef.current;\r\n\r\n document.body.appendChild(currentPortalElement);\r\n\r\n const modalCount = getModalCount(true);\r\n\r\n document.body.setAttribute('data-modal-open', modalCount.toString());\r\n\r\n if (modalCount === 1) {\r\n document.body.style.overflow = 'hidden';\r\n }\r\n\r\n return () => {\r\n document.body.removeChild(currentPortalElement);\r\n\r\n const modalCount = getModalCount(false);\r\n\r\n document.body.setAttribute('data-modal-open', modalCount.toString());\r\n\r\n if (modalCount === 0) {\r\n document.body.removeAttribute('data-modal-open');\r\n document.body.style.overflow = '';\r\n }\r\n };\r\n }, []);\r\n\r\n const getModalCount = (increment: boolean) => {\r\n const currentCount = Number(getDataModalOpenAttr('data-modal-open')) || 0;\r\n const newCount = increment ? currentCount + 1 : currentCount - 1;\r\n\r\n document.body.setAttribute('data-modal-open', newCount.toString());\r\n\r\n return newCount;\r\n };\r\n\r\n return ReactDOM.createPortal(children, portalElementRef.current);\r\n};\r\n\r\nexport default ModalPortal;\r\nexport const getDataModalOpenAttr = (attr: string) => document.body.getAttribute(attr);\r\n","import React, { FC, useCallback } from 'react';\r\nimport { XIcon } from '@components-library/Icons/iconsComponents';\r\nimport ModalPortal from '@components-shared/modal/ModalPortal';\r\nimport { useModalEventObserver } from '@components-shared/modal/modalEventObserver';\r\nimport { keyMap, KeyMapKeys } from '@locales/lokalise/keyMap';\r\nimport cn from 'classnames';\r\nimport i18next from 'i18next';\r\n\r\nconst ESC_KEY = 'Escape';\r\n\r\nexport interface IModalProps {\r\n rootClassName?: string;\r\n closeHandler?: () => void;\r\n children?: React.ReactNode;\r\n showModalCloseButton?: boolean;\r\n title?: string;\r\n buttonTitle?: string;\r\n subtitle?: string;\r\n header?: React.ReactNode;\r\n footer?: boolean;\r\n modalFooter?: React.ReactNode[];\r\n notification?: JSX.Element;\r\n titleTranslationOption?: Record;\r\n closeOnEscKey?: boolean;\r\n classNameContainer?: string;\r\n classNameHeader?: string;\r\n classNameFooter?: string;\r\n classNameBody?: string;\r\n classNameCloseButton?: string;\r\n}\r\n\r\nexport const Modal: FC = ({\r\n closeOnEscKey = true,\r\n closeHandler,\r\n rootClassName,\r\n children,\r\n showModalCloseButton = true,\r\n title,\r\n buttonTitle,\r\n subtitle,\r\n footer = false,\r\n header,\r\n modalFooter,\r\n notification,\r\n titleTranslationOption,\r\n classNameContainer,\r\n classNameFooter,\r\n classNameHeader,\r\n classNameBody,\r\n classNameCloseButton,\r\n}) => {\r\n const close = useCallback(\r\n (event: React.MouseEvent | Event): void => {\r\n event?.stopPropagation?.();\r\n closeHandler?.();\r\n },\r\n [closeHandler],\r\n );\r\n\r\n const handleKeyDown = useCallback(\r\n (event: KeyboardEvent): void => {\r\n if (event.key === ESC_KEY && closeOnEscKey) {\r\n close(event);\r\n }\r\n },\r\n [closeOnEscKey, close],\r\n );\r\n\r\n useModalEventObserver(handleKeyDown, { ignoreEscButton: !closeOnEscKey });\r\n\r\n const titleOptions = titleTranslationOption ? titleTranslationOption : undefined;\r\n const titleTranslation = title && (\r\n // @ts-ignore\r\n {i18next.t(title as any, titleOptions as any)}
\r\n );\r\n\r\n return (\r\n \r\n \r\n
\r\n
\r\n {header &&
{header}
}\r\n {titleTranslation}\r\n {subtitle &&
{i18next.t(subtitle as KeyMapKeys)}
}\r\n {showModalCloseButton && (\r\n
\r\n \r\n \r\n )}\r\n
\r\n {notification}\r\n
{children}
\r\n\r\n {footer && (\r\n
\r\n \r\n {i18next.t(buttonTitle ? (buttonTitle as KeyMapKeys) : (keyMap.modalClose as KeyMapKeys))}\r\n \r\n
\r\n )}\r\n\r\n {modalFooter &&
{modalFooter}
}\r\n
\r\n
\r\n \r\n );\r\n};\r\n","import React from 'react';\r\nimport { createRoot } from 'react-dom/client';\r\nimport { keyMap } from '@locales/lokalise/keyMap';\r\nimport { Notification } from 'components/library/Notification';\r\nimport { ConfirmModal } from './Confirm';\r\nimport { Modal } from './Modal';\r\nimport './style.scss';\r\n\r\nconst { body } = document;\r\n\r\nconst confirmRoot = document.createElement('div');\r\n\r\nbody.appendChild(confirmRoot);\r\nconst confirmRootInstance = createRoot(confirmRoot);\r\n\r\nconfirmRootInstance.render( );\r\n\r\nconst notificationRoot = document.createElement('div');\r\n\r\nbody.appendChild(notificationRoot);\r\nconst notificationRootContainer = createRoot(notificationRoot);\r\n\r\nnotificationRootContainer.render( );\r\n\r\nconst ConfirmDialog = ConfirmModal;\r\nconst NotificationDialog = Notification;\r\n\r\nexport { ConfirmDialog, Modal, NotificationDialog };\r\n","import { useCallback, useEffect, useRef } from 'react';\r\n\r\ntype Subscription = (e: KeyboardEvent) => void;\r\n\r\nclass ModalEventObserver {\r\n subscriptions: Subscription[] = [];\r\n\r\n constructor() {\r\n const getSubscription = (evt: KeyboardEvent) => {\r\n return this.subscriptions[this.subscriptions.length - 1]?.(evt);\r\n };\r\n\r\n document.addEventListener('keydown', getSubscription, false);\r\n }\r\n\r\n addSubscription(callback: Subscription) {\r\n this.subscriptions.push(callback);\r\n }\r\n\r\n removeSubscription(callback: Subscription) {\r\n this.subscriptions = this.subscriptions.filter((cb) => cb !== callback);\r\n }\r\n}\r\n\r\nconst modalEventObserver = new ModalEventObserver();\r\n\r\nexport const useModalEventObserver = (\r\n closeCallback: (event: KeyboardEvent) => void,\r\n options: {\r\n condition?: boolean;\r\n ignoreEscButton?: boolean;\r\n } = {},\r\n) => {\r\n const ref = useRef(closeCallback);\r\n\r\n ref.current = closeCallback;\r\n\r\n const handleClose = useCallback(\r\n (e: KeyboardEvent) => {\r\n if (options.ignoreEscButton) {\r\n return;\r\n }\r\n\r\n ref.current(e);\r\n },\r\n [options.ignoreEscButton],\r\n );\r\n\r\n useEffect(() => {\r\n if (options.condition) {\r\n return;\r\n }\r\n\r\n modalEventObserver.addSubscription(handleClose);\r\n\r\n return () => {\r\n modalEventObserver.removeSubscription(handleClose);\r\n };\r\n }, [handleClose, options.condition]);\r\n\r\n useEffect(() => {\r\n if (options.condition === undefined) {\r\n return;\r\n }\r\n\r\n if (options.condition) {\r\n modalEventObserver.addSubscription(handleClose);\r\n } else {\r\n modalEventObserver.removeSubscription(handleClose);\r\n }\r\n }, [handleClose, options.condition]);\r\n};\r\n","import React from 'react';\r\nimport { X } from 'react-feather';\r\n\r\ninterface ICloseButtonProps {\r\n onClick: () => void;\r\n className: string;\r\n testID?: string;\r\n}\r\n\r\nexport const CloseButton = (props: ICloseButtonProps) => {\r\n const { onClick, className, testID = 'modalCloseButton' } = props;\r\n\r\n return (\r\n \r\n \r\n
\r\n );\r\n};\r\n","import React from 'react';\r\nimport cn from 'classnames';\r\nimport styles from './style.module.scss';\r\n\r\nexport const Preloader = () => (\r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n);\r\n\r\nexport const FlexiblePreloader = () => (\r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n);\r\n\r\nexport const ButtonPreloader = () => (\r\n \r\n);\r\n\r\nexport const ButtonMiniPreloader = () => (\r\n \r\n);\r\n\r\nexport const CompactPreloader = () => (\r\n \r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n
\r\n);\r\n\r\nexport default Preloader;\r\n","export const NUMBER_OF_ROWS: number[] = [15, 30, 50];\r\nexport const DEFAULT_HEADER_SORT_VALUES = { sortingType: false, selectedColumn: '' };\r\nexport const TABLE_CACHE_PREFIX = '__tableSettings';\r\n","import { GENERAL_CONSTANTS } from 'components/shared/general.constants';\r\n\r\n//TODO Think about moving this logic and dataLayer.push into e.g. googleAnalyticsService\r\n\r\nexport const enrichGoogleAnalyticsSuffix = (value: string | null | undefined): string => {\r\n if (!value) {\r\n return '';\r\n }\r\n\r\n return value + GENERAL_CONSTANTS.ID_HASH_SUFFIX;\r\n};\r\n","import { CLIENT_SOURCE_TYPE } from 'global.enums';\r\n\r\nexport const getClientSourceType = (clientSourceType: CLIENT_SOURCE_TYPE): number => {\r\n return clientSourceType === CLIENT_SOURCE_TYPE.DIRECT ? 1 : 2;\r\n};\r\n","import React from 'react';\r\nimport { ErrorLayout } from '@components-shared/ErrorLayout';\r\nimport { SeverityLevel } from '@microsoft/applicationinsights-web';\r\n// @ts-ignore: remove after translating into typescript\r\nimport { getAppInsights } from 'applicationInsights/TelemetryService';\r\nimport { IError } from '../index';\r\nimport './styles.scss';\r\n\r\nconst SpareComponent: React.FC<{ error: IError | null }> = ({ error }) => {\r\n const message = error ? error.message : 'Error';\r\n const appInsightsError = new Error(message);\r\n\r\n if (error) {\r\n appInsightsError.stack = error.stack;\r\n }\r\n\r\n try {\r\n const appInsights = getAppInsights();\r\n\r\n if (appInsights) {\r\n appInsights.trackException({\r\n error: appInsightsError,\r\n severityLevel: SeverityLevel.Critical,\r\n });\r\n }\r\n } catch (e) {\r\n console.error('appInsights error');\r\n }\r\n\r\n return ;\r\n};\r\n\r\nexport default SpareComponent;\r\n","import React, { useEffect, useState } from 'react';\r\nimport { createContext } from 'react';\r\nimport { useTranslation } from 'react-i18next';\r\nimport {\r\n strengthRules,\r\n newPasswordIsDifferFromOldOneValidate,\r\n StrengthRulesType,\r\n} from '@components-shared/forms/strengthPassword';\r\nimport { keyMap, KeyMapKeys } from '@locales/lokalise/keyMap';\r\nimport cn from 'classnames';\r\nimport styles from './passwordStrengthMeter.styles.module.scss';\r\n\r\nexport const PasswordStrengthMeterContext = createContext(null);\r\n\r\nexport const PasswordStrengthMeter = React.memo(\r\n ({\r\n newPassword,\r\n oldPassword,\r\n hasOldPasswordValidation,\r\n }: {\r\n newPassword: string;\r\n oldPassword?: string;\r\n hasOldPasswordValidation?: boolean;\r\n }) => {\r\n const { i18n } = useTranslation();\r\n const [isTouched, setIsTouched] = useState(false);\r\n\r\n useEffect(() => {\r\n if (newPassword) {\r\n setIsTouched(true);\r\n } else {\r\n setIsTouched(false);\r\n }\r\n }, [newPassword]);\r\n\r\n const getHintClassName = (isValid: boolean) => {\r\n if (!isTouched) return 'form__hint';\r\n return `form__hint ${isValid ? styles.valid : styles.notValid}`;\r\n };\r\n\r\n const strengthMap: Record = {\r\n minLength: {\r\n message: keyMap.formsValidationEightCharactersLong,\r\n isValid: strengthRules.minLength.fn(newPassword),\r\n },\r\n hasUppercase: {\r\n message: keyMap.formsValidationOneUppercaseLetter,\r\n isValid: strengthRules.hasUppercase.fn(newPassword),\r\n },\r\n hasLowercase: {\r\n message: keyMap.formsValidationOneLowercaseLetter,\r\n isValid: strengthRules.hasLowercase.fn(newPassword),\r\n },\r\n hasNumber: {\r\n message: keyMap.formsValidationOneNumber,\r\n isValid: strengthRules.hasNumber.fn(newPassword),\r\n },\r\n hasSpecialCharacters: {\r\n message: keyMap.formsValidationOneSpecialSymbol,\r\n isValid: strengthRules.hasSpecialCharacters.fn(newPassword),\r\n },\r\n hasRepeatedCharacters: {\r\n message: keyMap.formsValidationRepeatedCharacters,\r\n isValid: strengthRules.hasRepeatedCharacters.fn(newPassword),\r\n },\r\n };\r\n\r\n const isPasswordDifferentFromOldOne = {\r\n message: keyMap.formsValidationNewPasswordIsDifferent,\r\n isValid: newPasswordIsDifferFromOldOneValidate(newPassword, oldPassword),\r\n };\r\n\r\n return (\r\n \r\n
\r\n \r\n {i18n.t(strengthMap['minLength'].message)}\r\n \r\n \r\n {i18n.t(strengthMap['hasUppercase'].message)}\r\n \r\n \r\n {i18n.t(strengthMap['hasLowercase'].message)}\r\n \r\n \r\n {i18n.t(strengthMap['hasNumber'].message)}\r\n \r\n \r\n {i18n.t(strengthMap['hasSpecialCharacters'].message)}\r\n \r\n \r\n {i18n.t(strengthMap['hasRepeatedCharacters'].message)}\r\n \r\n {hasOldPasswordValidation && (\r\n \r\n {i18n.t(isPasswordDifferentFromOldOne.message)}\r\n \r\n )}\r\n \r\n
\r\n );\r\n },\r\n);\r\n","import type { FieldValue } from '@components-shared/forms/formField.interface';\r\nimport {\r\n strengthValidate,\r\n newPasswordIsDifferFromOldOneValidate,\r\n isValidOnlyEngWithDigitsAndSpecialSymbols,\r\n} from '@components-shared/forms/strengthPassword';\r\nimport type {\r\n NewPasswordDifferFromOldOneType,\r\n OnlyEngWithDigitsAndSpecialSymbolsType,\r\n StrengthValidatorType,\r\n ValidParams,\r\n} from '@components-shared/forms/validators/interfaces';\r\nimport { keyMap } from '@locales/lokalise/keyMap';\r\n\r\nexport const validatePassword = () => {\r\n class ValidatorClassType {\r\n private _message = '';\r\n\r\n check = (value: FieldValue, params: ValidParams): boolean => {\r\n if (typeof value !== 'string') {\r\n return false;\r\n }\r\n\r\n if (!newPasswordIsDifferent.check(value, params)) {\r\n return false;\r\n }\r\n\r\n if (!strength.check(value)) {\r\n this._message = strength.message;\r\n return false;\r\n }\r\n\r\n if (!onlyEngWithDigitsAndSpecialSymbols.check(value, params)) {\r\n this._message = onlyEngWithDigitsAndSpecialSymbols.message;\r\n return false;\r\n }\r\n\r\n this._message = '';\r\n return true;\r\n };\r\n\r\n get message(): string {\r\n return this._message;\r\n }\r\n }\r\n\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n return new ValidatorClassType() as { check: (value: FieldValue, params?: any) => boolean; message: string };\r\n};\r\n\r\nconst newPasswordIsDifferent: NewPasswordDifferFromOldOneType = {\r\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n check: (value, params) => newPasswordIsDifferFromOldOneValidate(value, (params as any)?.form?.oldPassword),\r\n message: keyMap.formsValidationNewPasswordDifferFromOldOne,\r\n};\r\n\r\nexport const strength: StrengthValidatorType = {\r\n check: (value) => strengthValidate(value),\r\n message: keyMap.formsValidationStrengthError,\r\n};\r\n\r\nconst onlyEngWithDigitsAndSpecialSymbols: OnlyEngWithDigitsAndSpecialSymbolsType = {\r\n check: (value) => isValidOnlyEngWithDigitsAndSpecialSymbols(value),\r\n message: keyMap.formsValidationOnlyEnglishAndDigitsAndSpecialSymbolsError,\r\n};\r\n","import { ApiUrls } from '@api/apiUrls';\r\nimport { fetchApi } from '@api/fetchApi';\r\nimport { pushAccountCreateSuccessfulEvent } from '@components-shared/googleAnalyticsEvents';\r\nimport { getClientSourceType } from '@components-shared/utils/getClientSourceType';\r\nimport { IUser } from 'global.interfaces';\r\n\r\nexport interface IAccountCreatedResponse {\r\n idHash: string;\r\n accountType: string;\r\n id: number;\r\n login: number;\r\n}\r\n\r\nexport const createSelfTradeAccount = async >(\r\n form: T,\r\n user: IUser,\r\n): Promise => {\r\n const response = await fetchApi.post(\r\n ApiUrls.tradingAccountUser.selfTradeAccountCreate,\r\n form,\r\n );\r\n\r\n accountCreatedSuccessfullyEvent(response.data.idHash, form, user, response.data.accountType);\r\n\r\n return response.data;\r\n};\r\n\r\nexport const accountCreatedSuccessfullyEvent = (\r\n accountIdHash: string,\r\n form: T,\r\n user: IUser,\r\n accountType: string,\r\n): void => {\r\n pushAccountCreateSuccessfulEvent(\r\n user.idHash,\r\n getClientSourceType(user.profile.clientSourceType),\r\n accountIdHash,\r\n accountType,\r\n user.profile.status,\r\n form.leverage,\r\n );\r\n};\r\n","import {\r\n pushOpenAccountModalShowEvent,\r\n pushOpenAccountModalCloseEvent,\r\n} from '@components-shared/googleAnalyticsEvents';\r\nimport { getClientSourceType } from '@components-shared/utils/getClientSourceType';\r\nimport type { IUser } from 'global.interfaces';\r\n\r\nclass OpenAccountAnalyticsService {\r\n private getOpenAccountModalData = (userInfo: IUser) => {\r\n const { profile, idHash } = userInfo;\r\n const { clientSourceType, status } = profile;\r\n\r\n return {\r\n userIdHash: idHash,\r\n clientSourceType,\r\n verification: status,\r\n };\r\n };\r\n\r\n openAccountModalShowEvent = (user: IUser) => {\r\n const { userIdHash, clientSourceType, verification } = this.getOpenAccountModalData(user);\r\n\r\n pushOpenAccountModalShowEvent(userIdHash, getClientSourceType(clientSourceType), verification);\r\n };\r\n\r\n openAccountModalCloseEvent = (user: IUser): void => {\r\n const { userIdHash, clientSourceType, verification } = this.getOpenAccountModalData(user);\r\n\r\n pushOpenAccountModalCloseEvent(userIdHash, getClientSourceType(clientSourceType), verification);\r\n };\r\n}\r\n\r\nexport const openAccountAnalyticsService = new OpenAccountAnalyticsService();\r\n","import { PREFILL_USER_FORM_TYPE } from '@components-member/psp/withdrawal/plugins/BasePluginWithdrawal/components/BankAccountRedirectButton/constants';\r\nimport { CONSTANTS } from 'components/shared/constants';\r\nimport { CURRENCY } from 'global.enums';\r\nimport { IPSPInfo } from './pspInfo.interface';\r\n\r\nexport const getEmptyPspInfo = (): IPSPInfo => {\r\n return {\r\n currencies: [],\r\n exchange: [],\r\n exchangeRatesToDisplay: [],\r\n amount: {\r\n min: 0,\r\n max: 0,\r\n currency: CURRENCY.USD,\r\n },\r\n operationFee: {\r\n feeBrackets: [],\r\n feeCurrency: CURRENCY.USD,\r\n minFee: 0,\r\n maxFee: 0,\r\n skipOptions: {\r\n operationAmount: null,\r\n operationAmountComparison: 'Greater',\r\n },\r\n },\r\n operationFeeSkipInfo: {\r\n feeWillAlwaysBeSkipped: false,\r\n },\r\n data: null,\r\n depositAdminAction: CONSTANTS.DEPOSIT_ADMIN_ACTION.NONE,\r\n financialIdentityType: null,\r\n isHideExchangeRate: false,\r\n bankAccounts: [],\r\n digitalWalletAccounts: [],\r\n cards: [],\r\n cryptoWalletAccounts: [],\r\n id: 0,\r\n createUserFinancialIdentityType: PREFILL_USER_FORM_TYPE.NONE,\r\n userNameAliases: [],\r\n allowSelectingBeneficiaryName: false,\r\n storeLocallyNewlyCreatedAccountHolderNames: false,\r\n operationTutorial: {\r\n isEnabled: false,\r\n tutorialVideos: [],\r\n },\r\n operationTip: {\r\n isEnabled: false,\r\n position: null,\r\n tips: [],\r\n },\r\n requireBankDetails: null,\r\n consents: [],\r\n };\r\n};\r\n","import { EnumUserRoute } from '@components-member/userRoutes/enums';\r\nimport { keyMap } from '@locales/lokalise/keyMap';\r\nimport { PREAUTHORIZED_TYPE } from 'global.enums';\r\nimport type { BankAccountButtonProps } from './interfaces';\r\n\r\nexport const bankAccountRedirectLink: Record = {\r\n [PREAUTHORIZED_TYPE.BANK_ACCOUNT]: {\r\n title: keyMap.pspDepositDepositFormAddNewBankAccount,\r\n tooltip: keyMap.pspBankAccountDetailsWithdrawalHint,\r\n path: EnumUserRoute.bankAccounts,\r\n },\r\n};\r\n\r\nexport enum PREFILL_USER_FORM_TYPE {\r\n NONE = 'None',\r\n}\r\n","import React from 'react';\r\nimport { useTranslation } from 'react-i18next';\r\nimport { WarningIcon } from '@components-library/Icons/iconsComponents';\r\nimport { keyMap } from '@locales/lokalise/keyMap';\r\nimport CONSTANTS from 'components/shared/constants';\r\nimport { NotificationMessage } from 'components/shared/notification';\r\nimport { ENUM_LOCALE_CODE } from 'global.enums';\r\nimport { IBrokerParams, IUser } from 'global.interfaces';\r\nimport i18next from 'i18next';\r\nimport { i18n } from 'i18next';\r\nimport { PspOperationsNotification } from '../psp/pspOperationsNotification';\r\n\r\ninterface UserStatusData {\r\n isUserApproved: boolean;\r\n depositAllowedForUnverifiedProfile: boolean;\r\n maxTotalDepositAmountForUnverifiedProfile: number;\r\n userCanDeposit: boolean;\r\n userCanWithdraw: boolean;\r\n userIsNotApprovedAndCanDeposit: boolean;\r\n hasAnyActiveKycChecks: boolean;\r\n}\r\n\r\nexport const getUserStatusData = (userInfo?: IUser | null): UserStatusData => {\r\n if (!userInfo) {\r\n return getEmptyData();\r\n }\r\n\r\n const {\r\n isUserApproved,\r\n depositAllowedForUnverifiedProfile,\r\n maxTotalDepositAmountForUnverifiedProfile,\r\n hasAnyActiveKycChecks,\r\n } = userInfo;\r\n const userCanDeposit = isUserApproved || depositAllowedForUnverifiedProfile;\r\n const userCanWithdraw = isUserApproved;\r\n const userIsNotApprovedAndCanDeposit = !isUserApproved && depositAllowedForUnverifiedProfile;\r\n\r\n return {\r\n isUserApproved,\r\n depositAllowedForUnverifiedProfile,\r\n maxTotalDepositAmountForUnverifiedProfile,\r\n userCanDeposit,\r\n userCanWithdraw,\r\n userIsNotApprovedAndCanDeposit,\r\n hasAnyActiveKycChecks,\r\n };\r\n};\r\n\r\nconst getEmptyData = (): UserStatusData => {\r\n return {\r\n isUserApproved: false,\r\n depositAllowedForUnverifiedProfile: false,\r\n maxTotalDepositAmountForUnverifiedProfile: 0,\r\n userCanDeposit: false,\r\n userCanWithdraw: false,\r\n userIsNotApprovedAndCanDeposit: false,\r\n hasAnyActiveKycChecks: false,\r\n };\r\n};\r\n\r\ninterface DepositWarningMessageProps {\r\n userInfo: IUser;\r\n depositTabLocation: boolean;\r\n brokerParams: IBrokerParams;\r\n}\r\n\r\nexport const DepositWarningMessage = (props: DepositWarningMessageProps) => {\r\n const { i18n } = useTranslation();\r\n const userStatusData = getUserStatusData(props.userInfo);\r\n const showDepositWarningMessage = props.depositTabLocation && userStatusData.userCanDeposit;\r\n\r\n if (!showDepositWarningMessage) {\r\n return null;\r\n }\r\n\r\n const { depositWarningTitle, depositWarningMessageList } = getDepositWarningMessages(props.brokerParams, i18n);\r\n\r\n return (\r\n }\r\n />\r\n );\r\n};\r\n\r\nconst getDepositWarningMessages = (brokerParams: IBrokerParams, i18n: i18n) => {\r\n const currentLanguage = i18n.language as ENUM_LOCALE_CODE;\r\n\r\n const depositWarningTitle = keyMap.profileWarningMessageImportantInformation;\r\n const brokerName = brokerParams[currentLanguage]?.brokerName;\r\n const depositWarningMessageList = [\r\n i18n.t(keyMap.profileWarningMessageThirdPartyDeposits, { brokerName }),\r\n i18n.t(keyMap.profileWarningMessageConfirmThatPaymentsAreMadeFromRegisteredAccount, { brokerName }),\r\n i18n.t(keyMap.profileWarningMessageNameDoesNotMatch),\r\n i18n.t(keyMap.profileWarningMessageVerifyYourIdentity, { brokerName }),\r\n ...(currentLanguage === ENUM_LOCALE_CODE.zhCN\r\n ? [i18n.t(keyMap.profileWarningMessageMakeSureDescriptionIsEmptyForUnionPayOnlyCN)]\r\n : []),\r\n ];\r\n\r\n return {\r\n depositWarningTitle,\r\n depositWarningMessageList,\r\n };\r\n};\r\n\r\ninterface NeitherDepositNorWithdrawAllowedMessageProps {\r\n userInfo: IUser;\r\n depositTabLocation: boolean;\r\n withdrawalTabLocation: boolean;\r\n}\r\n\r\nexport const NeitherDepositNorWithdrawAllowedMessage = (props: NeitherDepositNorWithdrawAllowedMessageProps) => {\r\n const userStatusData = getUserStatusData(props.userInfo);\r\n const showNeitherDepositNorWithdrawAllowedMessage =\r\n !userStatusData.userCanDeposit &&\r\n !userStatusData.userCanWithdraw &&\r\n (props.depositTabLocation || props.withdrawalTabLocation);\r\n\r\n if (!showNeitherDepositNorWithdrawAllowedMessage) {\r\n return null;\r\n }\r\n\r\n return ;\r\n};\r\n\r\ninterface DepositLimitMessageProps {\r\n userInfo: IUser;\r\n depositTabLocation: boolean;\r\n}\r\n\r\nexport const DepositLimitMessage = (props: DepositLimitMessageProps) => {\r\n const userStatusData = getUserStatusData(props.userInfo);\r\n const showDepositLimitMessage = props.depositTabLocation && userStatusData.userIsNotApprovedAndCanDeposit;\r\n const { maxTotalDepositAmountForUnverifiedProfile } = userStatusData;\r\n\r\n if (!showDepositLimitMessage) {\r\n return null;\r\n }\r\n\r\n return (\r\n \r\n );\r\n};\r\n\r\ninterface WithdrawNotAllowedMessageProps {\r\n userInfo: IUser;\r\n withdrawalTabLocation: boolean;\r\n}\r\n\r\nexport const WithdrawNotAllowedMessage = (props: WithdrawNotAllowedMessageProps) => {\r\n const userStatusData = getUserStatusData(props.userInfo);\r\n const showWithdrawNotAllowedMessage = props.withdrawalTabLocation && userStatusData.userIsNotApprovedAndCanDeposit;\r\n\r\n if (!showWithdrawNotAllowedMessage) {\r\n return null;\r\n }\r\n\r\n return ;\r\n};\r\n\r\ntype PspInfoMessagesProps = NeitherDepositNorWithdrawAllowedMessageProps;\r\n\r\nexport const PspInfoMessages = (props: PspInfoMessagesProps) => {\r\n const { userInfo, depositTabLocation, withdrawalTabLocation } = props;\r\n\r\n return (\r\n \r\n \r\n\r\n \r\n\r\n \r\n \r\n );\r\n};\r\n","export type EnumUserRouteType = (typeof EnumUserRoute)[keyof typeof EnumUserRoute];\r\n\r\nexport const EnumUserRoute = {\r\n member: '/member' as const,\r\n\r\n bankAccounts: '/member/psp/bankaccounts' as const,\r\n bankAccountDetails: '/member/psp/bankaccounts/:id' as const,\r\n\r\n educationPortal: '/member/helpcenter/education' as const,\r\n educationPortalDetails: '/member/helpcenter/education/:id' as const,\r\n\r\n eWalletPage: '/member/psp/ewallet' as const,\r\n eWalletDetailsPage: '/member/psp/ewallet/:id' as const,\r\n eWalletOperationDetailsPage: '/member/psp/ewallet/operations/:id' as const,\r\n\r\n pspDeposit: '/member/psp/deposit' as const,\r\n\r\n helpCenterDocumentsPage: '/member/helpcenter/documents' as const,\r\n\r\n mamLinkPage: '/member/partnership/mammanager/links/:id' as const,\r\n\r\n masterProfilePage: '/member/socialtrading/master/:userId' as const,\r\n mastersRatingPage: '/member/socialtrading/mastersrating' as const,\r\n myInvestorsPage: '/member/socialtrading/mystatistics/statisticsdetails/followers' as const,\r\n myInvestorOperationHistory: '/member/socialtrading/mystatistics/statisticsdetails/followers/:id' as const,\r\n myMastersPage: '/member/socialtrading/mystatistics/statisticsdetails/masters' as const,\r\n myStatisticsPage: '/member/socialtrading/mystatistics' as const,\r\n\r\n cryptoWalletAccounts: '/member/psp/cryptowallets' as const,\r\n cryptoWalletAccountDetails: '/member/psp/cryptowallets/:id' as const,\r\n\r\n partnershipPage: '/member/partnership' as const,\r\n partnershipIBEwalletPage: '/member/partnership/ibewallet' as const,\r\n partnershipIBEwalletHistoryPage: '/member/partnership/ibewallet/:walletAccountId' as const,\r\n partnershipIBEwalletOperationDetails:\r\n '/member/partnership/ibewallet/:walletAccountId/operations/:operationId' as const,\r\n partnershipIBEwalletOperationDetailsLink: '/member/partnership/ibewallet/:walletAccountId/operations' as const,\r\n\r\n operationHistoryPage: '/member/socialtrading/operationhistory' as const,\r\n\r\n referralLinkPage: '/member/links/:id' as const,\r\n\r\n sales: '/member/sales' as const,\r\n salesUsers: '/member/sales/user' as const,\r\n salesUserDetails: '/member/sales/user/:id' as const,\r\n salesUserTradingAccounts: '/member/sales/tradingaccount' as const,\r\n salesUserTradingAccountDetails: '/member/sales/tradingaccount/:id' as const,\r\n salesUserDeposits: '/member/sales/deposit' as const,\r\n salesUserDepositDetails: '/member/sales/deposit/:id' as const,\r\n salesUserWithdrawals: '/member/sales/withdrawal' as const,\r\n salesUserWithdrawalDetails: '/member/sales/withdrawal/:id' as const,\r\n\r\n ticketPage: '/member/helpcenter/usertickets' as const,\r\n ticketDetailsPage: '/member/helpcenter/usertickets/:id' as const,\r\n\r\n tradingAccountsPage: '/member/tradingaccounts' as const,\r\n tradingAccountDetailsPage: '/member/tradingaccounts/:accountId' as const,\r\n tradingAccountHistoryPage: '/member/tradingaccounts/:accountId/history' as const,\r\n tradingAccountInvestorPage: '/member/tradingaccounts/:accountId/follower' as const,\r\n tradingAccountMasterPage: '/member/tradingaccounts/:accountId/master' as const,\r\n tradingAccountDepositPage: '/member/tradingaccounts/:accountId/deposit' as const,\r\n tradingAccountWithdrawalPage: '/member/tradingaccounts/:accountId/withdraw' as const,\r\n\r\n tradingContestPage: '/member/tradingcontest' as const,\r\n tradingContestDetails: '/member/tradingcontest/:traidingContestId' as const,\r\n\r\n tradingPlatforms: '/member/tradingplatforms' as const,\r\n tradingTools: '/member/tradingtools' as const,\r\n\r\n notificationsPage: '/member/notifications' as const,\r\n\r\n settingsPage: '/member/settings' as const,\r\n\r\n profilePage: '/member/profile' as const,\r\n\r\n pspPage: '/member/psp' as const,\r\n\r\n loyaltyProgramPage: '/member/loyaltyprogram' as const,\r\n loyaltyProgramDetailsPage: '/member/loyaltyprogram/:loyaltyProgramId' as const,\r\n loyaltyProgramRedeemPage: '/member/loyaltyprogram/redeem/:redeemId' as const,\r\n loyaltyProgramRedeemParticipantPage: '/member/loyaltyprogram/redeem/:participantRedeemId/participant' as const,\r\n};\r\n","import React, { forwardRef } from 'react';\r\nimport { AppContext, IAppContext } from './context';\r\n\r\nconst withContextProps = (WrappedComponent: React.ComponentType
) => {\r\n return forwardRef((props: Omit
, ref) => {\r\n return (\r\n \r\n {(languageProps) => {\r\n return ;\r\n }}\r\n \r\n );\r\n });\r\n};\r\n\r\nexport default withContextProps;\r\n","import React from 'react';\r\nimport { ENUM_LOCALE_CODE } from 'global.enums';\r\nimport { DocumentDirection } from 'global.interfaces';\r\nimport i18next from 'i18next';\r\n\r\nexport interface IAppContext {\r\n language: ENUM_LOCALE_CODE;\r\n documentDirection: DocumentDirection;\r\n setLanguage: (locale: ENUM_LOCALE_CODE) => void;\r\n i18next: typeof i18next;\r\n}\r\n\r\nexport const AppContext = React.createContext({\r\n language: ENUM_LOCALE_CODE.enUS,\r\n documentDirection: 'ltr',\r\n setLanguage: () => {\r\n console.error('setLanguage is not defined');\r\n },\r\n i18next,\r\n});\r\n","import { useCallback, useEffect, useState } from 'react';\r\nimport { ENUM_LOCALE_CODE } from 'global.enums';\r\nimport { DocumentDirection } from 'global.interfaces';\r\n\r\nexport const useDocumentDirection = (defaultLanguage: ENUM_LOCALE_CODE) => {\r\n const [documentDirection, setDocumentDirection] = useState('ltr');\r\n\r\n const htmlDocumentHandler = useCallback((locale: ENUM_LOCALE_CODE) => {\r\n const newDocumentDirection: DocumentDirection = locale === 'ar' ? 'rtl' : 'ltr';\r\n\r\n const languageCode = locale.split('-')[0];\r\n\r\n setDocumentDirection(newDocumentDirection);\r\n document.documentElement.dir = newDocumentDirection;\r\n document.documentElement.lang = languageCode;\r\n }, []);\r\n\r\n useEffect(() => {\r\n htmlDocumentHandler(defaultLanguage);\r\n }, [defaultLanguage, htmlDocumentHandler]);\r\n\r\n return documentDirection;\r\n};\r\n","import connectToContext from './connect';\r\nimport type { IAppContext } from './context';\r\nimport ContextGuard from './store';\r\n\r\nexport default ContextGuard;\r\n\r\nexport { connectToContext, IAppContext };\r\n","import React, { ReactNode, useEffect, useState } from 'react';\r\nimport { useTranslation } from 'react-i18next';\r\nimport { useHistory } from 'react-router';\r\nimport { setLanguage } from '@locales/helpers';\r\nimport { yupValidationService } from '@utils/library';\r\nimport { DateTimeService } from '@utils/library/dateTimeService';\r\nimport { reactRouterService } from '@utils/library/reactRouter.service';\r\nimport { waitAntdStylesLoad } from '@utils/waitAntdLoad';\r\nimport Preloader from 'components/shared/preloader';\r\nimport { ENUM_LOCALE_CODE } from 'global.enums';\r\nimport { observer } from 'mobx-react';\r\nimport { useMobxStore } from 'store/mobx';\r\nimport { AppContext, IAppContext } from './context';\r\nimport { useDocumentDirection } from './hooks/useDocumentDirection';\r\n\r\ninterface IProps {\r\n registration: boolean;\r\n children: ReactNode;\r\n useClientTranslation: boolean;\r\n}\r\n\r\nconst ContextGuard = ({ registration, children, useClientTranslation }: IProps) => {\r\n const { i18n } = useTranslation();\r\n const history = useHistory();\r\n const { accountStore, appSettingStore, featuresStore, clientSideTranslationStore } = useMobxStore();\r\n\r\n const { isFeaturesProcessing, fetchFeatureFlags, isFeaturesLoaded } = featuresStore;\r\n\r\n const { clientSideTranslationsLoading, fetchTranslations } = clientSideTranslationStore;\r\n\r\n const { setI18next } = appSettingStore;\r\n\r\n const [trackersInitialized, setTrackersInitialized] = useState(false);\r\n const [antdStylesLoaded, setAntdStylesLoaded] = useState(false);\r\n\r\n const language = i18n.language as ENUM_LOCALE_CODE;\r\n\r\n const {\r\n generalSettingsLoading,\r\n userInfoLoading,\r\n initialUserInfo,\r\n utcOffsetInHours,\r\n userCountryInfo,\r\n fetchUserIpInfo,\r\n } = accountStore;\r\n\r\n const documentDirection = useDocumentDirection(language);\r\n\r\n useEffect(() => {\r\n setI18next(i18n);\r\n }, [i18n, language, setI18next]);\r\n\r\n useEffect(() => {\r\n reactRouterService.initHistory(history);\r\n }, [history]);\r\n\r\n useEffect(() => {\r\n DateTimeService.setOffset(utcOffsetInHours);\r\n }, [utcOffsetInHours]);\r\n\r\n useEffect(() => {\r\n if (useClientTranslation) {\r\n void fetchTranslations(language);\r\n }\r\n }, [fetchTranslations, language, useClientTranslation]);\r\n\r\n useEffect(() => {\r\n void accountStore.fetchGeneralSettings();\r\n\r\n if (!initialUserInfo) {\r\n void accountStore.fetchUserInfo({ showLoader: true, isInitialRequest: true });\r\n }\r\n\r\n void loadAntdStyles();\r\n\r\n yupValidationService.initializeValidationMessages();\r\n // eslint-disable-next-line react-hooks/exhaustive-deps\r\n }, []);\r\n\r\n useEffect(() => {\r\n if (initialUserInfo && !isFeaturesLoaded) {\r\n void fetchFeatureFlags();\r\n }\r\n }, [fetchFeatureFlags, initialUserInfo, isFeaturesLoaded]);\r\n\r\n useEffect(() => {\r\n if (trackersInitialized || !initialUserInfo) {\r\n return;\r\n }\r\n\r\n if (registration || initialUserInfo?.id) {\r\n setTrackersInitialized(true);\r\n }\r\n }, [registration, trackersInitialized, initialUserInfo]);\r\n\r\n useEffect(() => {\r\n if (userCountryInfo) {\r\n return;\r\n }\r\n void fetchUserIpInfo();\r\n }, [fetchUserIpInfo, userCountryInfo]);\r\n\r\n const loadAntdStyles = async () => {\r\n try {\r\n await waitAntdStylesLoad();\r\n setAntdStylesLoaded(true);\r\n } catch (err) {\r\n console.error('Failed to load antd styles');\r\n }\r\n };\r\n\r\n const props: IAppContext = { language, setLanguage, documentDirection, i18next: i18n };\r\n\r\n if (\r\n generalSettingsLoading ||\r\n userInfoLoading ||\r\n isFeaturesProcessing ||\r\n !antdStylesLoaded ||\r\n clientSideTranslationsLoading\r\n ) {\r\n return ;\r\n }\r\n\r\n return {children} ;\r\n};\r\n\r\nexport default observer(ContextGuard);\r\n","import variables from 'styles/shared/variables.scss';\r\n\r\nexport enum PROFILE_STATUS {\r\n DRAFT = 'Draft',\r\n APPROVED = 'Approved',\r\n DECLINED = 'Declined',\r\n INPROCESS = 'InProcess',\r\n UPDATEREQUIRED = 'UpdateRequired',\r\n URGENTUPDATE = 'UrgentUpdate',\r\n DUPLICATED = 'Duplicated',\r\n}\r\n\r\nexport enum PSP_OPERATIONS {\r\n DEPOSIT = 'Deposit',\r\n WITHDRAWAL = 'Withdrawal',\r\n ALL = 'All',\r\n}\r\n\r\nexport enum PSP_OPERATION_STATUS {\r\n INPROGRESS = 'InProgress',\r\n FAILED = 'Failed',\r\n COMPLETED = 'Completed',\r\n PENDING = 'Pending',\r\n CANCELLED = 'Cancelled',\r\n ONHOLD = 'OnHold',\r\n TIMEOUT = 'TimeOut',\r\n}\r\n\r\nexport enum PSP_OPERATIONS_CATEGORIES {\r\n LOCAL_DEPOSIT = 'LocalDeposit',\r\n}\r\n\r\nexport enum PSP_OPERATION_FILE_ITEM_TYPE {\r\n DEPOSIT_BANK_STATEMENT = 'DepositBankStatement',\r\n DEPOSIT_DIGITAL_WALLET_STATEMENT = 'DigitalWallet',\r\n CARD_STATEMENT = 'Card',\r\n DEPOSIT_BANK_PAYSLIP = 'DepositBankPayslip',\r\n LOCAL_DEPOSIT_BANK_STATEMENT = 'LocalDepositBankStatement',\r\n LOCAL_DEPOSIT_BANK_TRANSFER = 'LocalDepositBankTransfer',\r\n LOCAL_DEPOSIT_BANK_DOCUMENTS = 'LocalDepositBankDocuments',\r\n WIRE_TRANSFER_BANK_DOCUMENTS = 'WireTransferBankDocuments',\r\n PROOF_ACCOUNT = 'ProofAccount',\r\n PROOF_TRANSACTION = 'ProofTransaction',\r\n CRYPTO_WALLET_PROOF_WALLET = 'CryptoWalletProofWallet',\r\n CRYPTO_WALLET_PROOF_ADDRESS = 'CryptoWalletProofAddress',\r\n}\r\n\r\nexport enum DEPOSIT_ADMIN_ACTION {\r\n NONE = 'None',\r\n PRE_AUTHORIZED = 'PreAuthorized',\r\n POST_TRANSACTION = 'PostTransaction',\r\n}\r\n\r\nexport enum BANNER_FILE_TYPE {\r\n REGULAR = 'Regular',\r\n POPUP = 'PopUp',\r\n}\r\n\r\nexport enum BANNER_SIZE {\r\n SMALL = 'Small',\r\n MIDDLE = 'Middle',\r\n FULL_WIDTH = 'FullWidth',\r\n}\r\n\r\nexport enum BANNER_TEXT_STYLE {\r\n BOLD = 'Bold',\r\n UNDERLINE = 'Underline',\r\n ITALIC = 'Italic',\r\n}\r\n\r\nexport enum PSP_WIZARD_STEP {\r\n ACCOUNT_STATEMENT_FORM = 'AccountCreateForm',\r\n FORM = 'form',\r\n CONFIRM = 'confirm',\r\n RESULT = 'result',\r\n ALIAS_CREATE_FORM = 'aliasCreateForm',\r\n ALIAS_ATTACH_FORM = 'aliasAttachForm',\r\n}\r\n\r\nexport enum WALLET_ACCOUNT_TYPE {\r\n REGULAR = 'Regular',\r\n TRANSIT = 'Transit',\r\n ALL = 'All',\r\n}\r\n\r\nexport enum TRADING_ACCOUNT_TYPE {\r\n DEMO = 'Demo',\r\n REAL = 'Real',\r\n}\r\n\r\nexport enum TRADING_PLATFORM_TYPE {\r\n META4 = 'Meta4',\r\n META5 = 'Meta5',\r\n GMI = 'Gmi',\r\n}\r\n\r\nexport enum TRADING_PLATFORM_SECTION_TYPE {\r\n PLATFORMS = 'Platforms',\r\n TOOLS = 'Tools',\r\n}\r\n\r\nexport enum EXECUTION_TYPE {\r\n MANUALLY = 'Manually',\r\n AUTOMATIC = 'Automatic',\r\n}\r\n\r\nexport enum WALLET_OPERATION_TRANSFER_TYPE {\r\n MANUAL_ADJUSTMENT = 'ManualAdjustment',\r\n}\r\n\r\nexport enum Q_FORM_STATUS {\r\n DRAFT = 'Draft',\r\n APPROVED = 'Approved',\r\n DECLINED = 'Declined',\r\n INPROCESS = 'InProcess',\r\n NEW = 'New',\r\n TERMINATION_IN_PROGRESS = 'TerminationInProgress',\r\n COMPLETED = 'Completed',\r\n}\r\n\r\nexport enum ROLES {\r\n ADMIN = 'Admin',\r\n USER = 'User',\r\n}\r\n\r\nexport enum DOCUMENT_STATUS {\r\n TO_VERIFY = 'ToVerify',\r\n APPROVED = 'Approve',\r\n REJECTED = 'Reject',\r\n IN_PROCESS = 'InProcess',\r\n}\r\n\r\nexport enum DOCUMENT_TYPE {\r\n NATIONAL_ID = 'NationalId',\r\n PASSPORT = 'Passport',\r\n DRIVING_LICENSE = 'DrivingLicense',\r\n UTILITY_BILL = 'UtilityBill',\r\n BANK_CARD = 'BankCard',\r\n}\r\n\r\nexport enum DOCUMENT_SUB_TYPE {\r\n FRONT_SIDE = 'FrontSide',\r\n BACK_SIDE = 'BackSide',\r\n}\r\n\r\nexport enum FILE_TYPE {\r\n IMAGE = 'Image',\r\n PDF = 'Pdf',\r\n UNKNOWN = 'Unknown',\r\n}\r\n\r\nexport enum ISSUE_STATUS {\r\n OPEN = 'Open',\r\n IN_PROGRESS = 'InProgress',\r\n RESOLVED = 'Resolved',\r\n}\r\n\r\nexport enum ITEM_TYPE {\r\n USER = 'User',\r\n QFORM = 'QForm',\r\n TRADING_ACCOUNT = 'TradingAccount',\r\n USER_DOCUMENT = 'UserDocument',\r\n ISSUE = 'Issue',\r\n COMPONENT = 'Component',\r\n NOTIFICATION_TEMPLATE = 'NotificationTemplate',\r\n PSP_OPERATION = 'PspOperation',\r\n EXTERNAL_JOB = 'ExternalJob',\r\n TRADING_ACCOUNT_TYPE = 'TradingAccountType',\r\n TRADING_ACCOUNT_TYPE_CATEGORY = 'TradingAccountTypeCategory',\r\n TRADING_GROUP = 'TradingGroup',\r\n SALES_USER = 'SalesUser',\r\n BUSINESS_MANAGER = 'BusinessManager',\r\n USER_BANK_ACCOUNT = 'UserBankAccount',\r\n USER_DIGITAL_WALLET_ACCOUNT = 'UserDigitalWalletAccount',\r\n USER_CARD_ACCOUNT = 'UserCard',\r\n SHORT_LINK = 'ShortLink',\r\n BANNER_CONFIGURATION = 'BannerConfiguration',\r\n MAM_MASTER_ACCOUNT = 'MamMasterAccount',\r\n GROUP = 'Group',\r\n AUTO_ASSIGNMENT_RULE = 'AutoAssignmentRule',\r\n URL_DOMAIN = 'UrlDomain',\r\n ONBOARDING_CONFIGURATION = 'OnboardingConfiguration',\r\n NOTIFICATION_GROUP = 'NotificationGroup',\r\n TRADING_BONUS_LINK = 'TradingBonusLink',\r\n KYT_VERIFICATION = 'KytVerification',\r\n KYT_VERIFICATION_OPERATION = 'KytVerificationOperation',\r\n TRADING_SYMBOL = 'TradingSymbol',\r\n META_SERVER = 'MetaServer',\r\n USER_NAME_ALIAS = 'UserNameAlias',\r\n VIDEO_CONFIGURATION = 'VideoConfiguration',\r\n CUSTOM_NOTIFICATION = 'CustomNotification',\r\n CUSTOM_PUSH_NOTIFICATION = 'CustomPushNotification',\r\n COMPANY_ACCOUNT = 'CompanyAccount',\r\n COMPANY_TRANSFER = 'CompanyTransfer',\r\n CONTEST = 'Contest',\r\n LOYALTY_PROGRAM = 'LoyaltyProgram',\r\n LEGAL_DOCUMENT = 'LegalDocument',\r\n EMAIL_TEMPLATE = 'EmailTemplate',\r\n PAYMENT_SYSTEM_CONSENT = 'PaymentSystemConsent',\r\n TRUSTED_DEVICE = 'TrustedDevice',\r\n DATA_CHANGE_REQUEST = 'DataChangeRequest',\r\n BANK = 'Bank',\r\n DIGITAL_WALLET = 'DigitalWallet',\r\n TRADING_PLATFORM_BRANDING_SETTINGS = 'TradingPlatformBrandingSettings',\r\n LOYALTY_PROGRAM_REDEEM = 'LoyaltyProgramRedeem',\r\n NOTIFICATION_CATEGORY = 'NotificationCategory',\r\n IMPORT_ITEM = 'ImportItem',\r\n FAQ = 'Faq',\r\n CLIENT_SIDE_TRANSLATION = 'ClientSideTranslation',\r\n DOCUMENT_CONFIGURATION = 'DocumentConfiguration',\r\n LEGAL_TRADING_PLATFORM = 'LegalTradingPlatform',\r\n}\r\n\r\nexport enum ACTION_TYPE {\r\n NOTE = 'Note',\r\n}\r\n\r\nexport enum GROUP_MAPPING {\r\n REAL_MAM_MASTER = 'RealMamMaster',\r\n REAL_MAM_MASTER_ECN = 'RealMamMasterEcn',\r\n REAL_MAM_INVESTOR = 'RealMamInvestor',\r\n REAL_PARTNER = 'RealPartner',\r\n}\r\n\r\nexport enum JOB_STATUS {\r\n INIT = 'Init',\r\n PENDING = 'Pending',\r\n START = 'Start',\r\n IN_PROGRESS = 'InProgress',\r\n COMPLETED = 'Completed',\r\n CANCELED = 'Canceled',\r\n FAILED = 'Failed',\r\n}\r\n\r\nexport enum UNIT {\r\n USD = 'Usd',\r\n PIPS = 'Pips',\r\n PERCENTAGE = 'Percentage',\r\n}\r\n\r\nexport enum KNOWN_INTERFACE {\r\n BONUS_PROGRAM = 'IBonusProgram',\r\n QFORM = 'IQForm',\r\n PSP = 'IPsp',\r\n RECURRING_JOB = 'IRecurringJob',\r\n IB_SPECIFICATION = 'IIbSpecification',\r\n JURISDICTION = 'IJurisdiction',\r\n MAIL_SENDER = 'IMailSender',\r\n SMS_SENDER = 'ISmsSender',\r\n PUSH_SENDER = 'IPushSender',\r\n KYC_PROVIDER = 'IKycProvider',\r\n KYT_PROVIDER = 'IKytProvider',\r\n SYSTEM_SETTINGS = 'ISystemSettings',\r\n AUTO_WITHDRAWALS_RULE = 'IAutoWithdrawalsRule',\r\n TRADING_ACCOUNT_ARCHIVING_RULE = 'ITradingAccountArchivingRule',\r\n BDM_ASSIGNMENT_RULE = 'IBDMAssignmentRule',\r\n}\r\n\r\nexport enum Q_FORM_TYPE {\r\n IB = 'IIbQForm',\r\n USER = 'IUserQForm',\r\n MARKUP = 'IMarkupQForm',\r\n MAM_MASTER = 'IMAMMasterQForm',\r\n MAM_INVESTOR = 'IMAMInvestorQForm',\r\n MAM_MASTER_WITH_LPOA = 'IMAMMasterWithLPOAQForm',\r\n}\r\n\r\nexport enum PAYMENT_SUMMARY_TYPE {\r\n CATEGORY = 'Category',\r\n PAYMENT_SYSTEM = 'PaymentSystem',\r\n}\r\n\r\nexport enum LEGAL_SECTION_TYPE {\r\n LEGAL = 'Legal',\r\n}\r\n\r\nexport enum CLIENT_SOURCE_TYPE {\r\n DIRECT = 'Direct',\r\n IB_TREE = 'IbTree',\r\n}\r\n\r\nexport enum TRANSFER_ACCOUNT_TYPE {\r\n WALLET = 'wallet',\r\n ACCOUNT = 'account',\r\n}\r\n\r\nexport enum DOCUMENT_CATEGORY {\r\n CategoryA = 'CategoryA',\r\n CategoryB = 'CategoryB',\r\n}\r\n\r\nexport enum USER_DOCUMENT_TYPE {\r\n Individual = 'Individual',\r\n}\r\n\r\nexport enum USER_STATEMENT_ACCOUNT_STATUS {\r\n CREATED = 'Created',\r\n VERIFIED = 'Verified',\r\n REJECTED = 'Rejected',\r\n ACTION_REQUIRED = 'ActionRequired',\r\n}\r\n\r\nexport enum SHORT_LINK_TYPE {\r\n UNKNOWN = 'Unknown',\r\n IB_INVITATION = 'IbInvitation',\r\n SALES_INVITATION = 'SalesInvitation',\r\n ADV_CAMPAIGN = 'AdvCampaign',\r\n}\r\n\r\nexport enum SHORT_LINK_VERSION {\r\n VERSION_1 = 'Version_1',\r\n VERSION_2 = 'Version_2',\r\n}\r\n\r\nexport enum MAM_MASTER_ACCOUNT_STATUS {\r\n DRAFT = 'Draft',\r\n IN_PROGRESS = 'InProgress',\r\n DECLINED = 'Declined',\r\n APPROVED = 'Approved',\r\n}\r\n\r\nexport enum SHORT_LINK_STATUS {\r\n DRAFT = 'Draft',\r\n IN_PROCESS = 'InProcess',\r\n DECLINED = 'Declined',\r\n APPROVED = 'Approved',\r\n EXPIRED = 'Expired',\r\n}\r\n\r\nexport enum ENUM_LANGUAGE_CODE {\r\n en = 'en',\r\n ru = 'ru',\r\n zh = 'zh',\r\n ms = 'ms',\r\n th = 'th',\r\n id = 'id',\r\n vi = 'vi',\r\n es = 'es',\r\n ar = 'ar',\r\n pt = 'pt',\r\n}\r\n\r\nexport enum ENUM_LOCALE_CODE {\r\n enUS = 'en-US',\r\n ru = 'ru',\r\n zhCN = 'zh-CN',\r\n msMY = 'ms-MY',\r\n thTH = 'th-TH',\r\n idID = 'id-ID',\r\n viVN = 'vi-VN',\r\n esES = 'es-ES',\r\n ar = 'ar',\r\n ptPT = 'pt-PT',\r\n}\r\n\r\nexport enum ENUM_LOCALE_CODE_UPPER {\r\n enUS = 'EN_US',\r\n ru = 'RU',\r\n zhCN = 'ZH_CN',\r\n msMY = 'MS_MY',\r\n thTH = 'TH-TH',\r\n idID = 'IS_ID',\r\n viVN = 'VI_VN',\r\n esES = 'ES_ES',\r\n ar = 'AR',\r\n ptPT = 'PT_PT',\r\n}\r\n\r\nexport const LANGUAGE_CODE_TO_LOCALE_CODE = {\r\n [ENUM_LANGUAGE_CODE.en]: ENUM_LOCALE_CODE.enUS,\r\n [ENUM_LANGUAGE_CODE.ru]: ENUM_LOCALE_CODE.ru,\r\n [ENUM_LANGUAGE_CODE.zh]: ENUM_LOCALE_CODE.zhCN,\r\n [ENUM_LANGUAGE_CODE.ms]: ENUM_LOCALE_CODE.msMY,\r\n [ENUM_LANGUAGE_CODE.th]: ENUM_LOCALE_CODE.thTH,\r\n [ENUM_LANGUAGE_CODE.id]: ENUM_LOCALE_CODE.idID,\r\n [ENUM_LANGUAGE_CODE.vi]: ENUM_LOCALE_CODE.viVN,\r\n [ENUM_LANGUAGE_CODE.es]: ENUM_LOCALE_CODE.esES,\r\n [ENUM_LANGUAGE_CODE.ar]: ENUM_LOCALE_CODE.ar,\r\n [ENUM_LANGUAGE_CODE.pt]: ENUM_LOCALE_CODE.ptPT,\r\n};\r\n\r\nexport type TYPE_LANGUAGE_CODE_TO_LOCALE_CODE = typeof LANGUAGE_CODE_TO_LOCALE_CODE;\r\n\r\nexport enum CURRENCY {\r\n USD = 'USD',\r\n EUR = 'EUR',\r\n IDR = 'IDR',\r\n RMB = 'RMB',\r\n CNY = 'CNY',\r\n CNH = 'CNH',\r\n MYR = 'MYR',\r\n GBP = 'GBP',\r\n THB = 'THB',\r\n VND = 'VND',\r\n BND = 'BND',\r\n BTC = 'BTC',\r\n USC = 'USC',\r\n USDT = 'USDT',\r\n PHP = 'PHP',\r\n ZAR = 'ZAR',\r\n}\r\n\r\nexport enum LEGAL_TYPE {\r\n CLIENT_AGREEMENT = 'ClientAgreement',\r\n PRIVACY_POLICY = 'PrivacyPolicy',\r\n}\r\n\r\nexport enum LOCATION {\r\n EWALLET = 'EWallet',\r\n TRADING_PLATFORMS = 'TradingPlatforms',\r\n TRADING_ACCOUNTS = 'TradingAccounts',\r\n NOTIFICATIONS = 'Notifications',\r\n}\r\n\r\nexport enum DEVICE_ENUM {\r\n MOBILE = 'Mobile',\r\n DESKTOP = 'Desktop',\r\n}\r\n\r\nexport enum KYC_STATUS {\r\n IN_PROCESS = 'InProcess',\r\n APPROVED = 'Approved',\r\n DECLINED = 'Declined',\r\n}\r\n\r\nexport enum SORT_TYPE {\r\n ASCENDING = 'Ascending',\r\n DESCENDING = 'Descending',\r\n DEFAULT = 'Default',\r\n}\r\n\r\nexport enum PSP_OPERATION_PROMOTE_TYPE {\r\n COMMIT = 'Commit',\r\n APPROVE = 'Approve',\r\n REJECT = 'Reject',\r\n REFUND = 'Refund',\r\n}\r\n\r\nexport enum ELEMENT_POSITION {\r\n LEFT = 'left',\r\n RIGHT = 'right',\r\n}\r\n\r\nexport enum CLIENT_APP_TYPE {\r\n WEB_APP = 'WebApp',\r\n MOBILE_APP = 'MobileApp',\r\n ALL = 'All',\r\n}\r\n\r\nexport enum KYT_VERIFICATION_STATUS {\r\n INITIATED = 'Initiated',\r\n INPROCESS = 'InProcess',\r\n FINISHED = 'Finished',\r\n ERROR = 'Error',\r\n}\r\n\r\nexport enum KYT_VERIFICATION_API_LOG_TYPE {\r\n USER = 'User',\r\n TRANSFER = 'Transfer',\r\n WITHDRAWAL_ATTEMPT = 'WithdrawalAttempt',\r\n}\r\n\r\nexport enum TRADING_ACCOUNT_FORM_TYPE {\r\n DEMO = 'Demo',\r\n SELF = 'Real',\r\n INVESTOR = 'Follower',\r\n MASTER = 'Master',\r\n}\r\n\r\nexport enum TRADING_ACCOUNT_SOURCE {\r\n DEFAULT = 'Default',\r\n SIDEBAR = 'Sidebar',\r\n}\r\n\r\nexport enum ACCOUNT_TYPE_PREFIX {\r\n STD = 'Standard',\r\n ECN = 'ECN',\r\n CENT = 'Cent',\r\n}\r\n\r\nexport enum COPY_TYPE {\r\n EQUITY = 'Equity',\r\n BALANCE = 'Balance',\r\n LOT = 'Lot',\r\n}\r\n\r\nexport enum QUERY_PARAMS {\r\n OPEN_ACCOUNT = 'openaccount',\r\n SOURCE = 'source',\r\n ACTION = 'action',\r\n COPY = 'copy',\r\n STOP = 'stop',\r\n MASTER = 'master',\r\n INVESTOR = 'investor',\r\n PLATFORM_TYPE = 'platform-type',\r\n CONTEST_ID = 'contest-id',\r\n}\r\n\r\nexport enum MASTERS_RATING_ACTION_SOURCE {\r\n EXTERNAL = 'external',\r\n DEFAULT = 'default',\r\n}\r\n\r\nexport enum OPERATION_PARAMS {\r\n GREATER_OR_EQUAL = 'GreaterOrEqual',\r\n LESS_OR_EQUAL = 'LessOrEqual',\r\n LIKE = 'Like',\r\n EQUAL = 'Equal',\r\n NOT_EQUAL = 'NotEqual',\r\n LESS = 'LESS',\r\n GREATER = 'Greater',\r\n}\r\n\r\nexport enum LIST_APPEARANCE {\r\n GRID = 'grid',\r\n LIST = 'list',\r\n}\r\n\r\nexport enum CHART_TYPE {\r\n AREA = 'area',\r\n PERCENT = 'percent',\r\n}\r\n\r\nexport enum NOTIFICATION_TYPE {\r\n WARNING = 'warning',\r\n NOTICE = 'notice',\r\n DANGER = 'danger',\r\n PSP = 'psp',\r\n}\r\n\r\nexport enum PSP_INFO_LOADING_STATUS {\r\n EMPTY = 'empty',\r\n LOADING = 'loading',\r\n LOADED_SUCCESS = 'loaded_success',\r\n LOADED_FAIL = 'loaded_fail',\r\n}\r\n\r\nexport enum CAPTCHA_PROVIDERS {\r\n RECAPTCHA = 'recaptcha',\r\n HCAPTCHA = 'hcaptcha',\r\n}\r\n\r\nexport enum MAM_LINK_STATUS {\r\n DRAFT = 'Draft',\r\n IN_PROGRESS = 'InProgress',\r\n DECLINED = 'Declined',\r\n APPROVED = 'Approved',\r\n}\r\n\r\nexport enum MAM_ALLOCATION_MODE {\r\n LOT = 'Lot',\r\n EQUITY = 'Equity',\r\n}\r\n\r\nexport enum REASSIGNMENT_TYPE {\r\n ALL_USERS = 'AllUsers',\r\n SPECIFIC_IB = 'SpecificIB',\r\n}\r\n\r\nexport enum TRADING_BONUS_STATUS {\r\n NEW = 'New',\r\n ACTIVE = 'Active',\r\n INITIATED = 'Initiated',\r\n COMPLETED = 'Completed',\r\n EXPIRED = 'Expired',\r\n}\r\n\r\nexport enum TRADING_GROUP_TYPE {\r\n PROFIT_SHARE = 'ProfitShare',\r\n PROFIT_SHARE_CONDITIONS = 'ProfitShareOnConditions',\r\n REBATE = 'Rebate',\r\n REBATE_ZERO = 'RebateZero',\r\n STANDARD = 'Standard',\r\n NO_PAYOUT = 'NoPayout',\r\n ZERO_REBATE_BY_IB_TREE = 'ZeroRebateByIbTree',\r\n ZERO_REBATE_BY_IB_SPECIFICATION = 'ZeroRebateByIbSpecification',\r\n}\r\n\r\nexport enum PREAUTHORIZED_TYPE {\r\n BANK_ACCOUNT = 'BankAccount',\r\n DIGITAL_WALLET = 'DigitalWallet',\r\n CARD = 'Card',\r\n}\r\n\r\nexport enum COMPONENT_CLASS_TAGS {\r\n RECURRING_JOB_REPORT = 'RecurringJobReport',\r\n}\r\n\r\nexport enum SCREEN_SIZE {\r\n xs = parseInt(variables.xs, 10),\r\n sm = parseInt(variables.sm, 10),\r\n md = parseInt(variables.md, 10),\r\n lg = parseInt(variables.lg, 10),\r\n xl = parseInt(variables.xl, 10),\r\n}\r\n\r\nexport enum WEB_APPLICATION_ACCESS_TYPE {\r\n USER = 'User',\r\n ADMIN = 'Admin',\r\n}\r\n\r\nexport enum COUNTRY_ACCESS_TYPE {\r\n ALLOWED = 'Allowed',\r\n FORBIDDEN = 'Forbidden',\r\n}\r\n","import { ENUM_LANGUAGE_CODE } from 'global.enums';\r\nimport { Resource } from 'i18next';\r\nimport arEnums from 'localizations/ar.enums.json';\r\nimport enEnums from 'localizations/en.enums.json';\r\nimport esEnums from 'localizations/es.enums.json';\r\nimport idEnums from 'localizations/id.enums.json';\r\nimport { ar } from 'localizations/locales/ar';\r\nimport { en } from 'localizations/locales/en';\r\nimport { es } from 'localizations/locales/es';\r\nimport { id } from 'localizations/locales/id';\r\nimport { ms } from 'localizations/locales/ms';\r\nimport { pt } from 'localizations/locales/pt';\r\nimport { ru } from 'localizations/locales/ru';\r\nimport { th } from 'localizations/locales/th';\r\nimport { vi } from 'localizations/locales/vi';\r\nimport { zh } from 'localizations/locales/zh';\r\nimport arJson from 'localizations/lokalise/locales/ar.json';\r\nimport enGBJson from 'localizations/lokalise/locales/en-GB.json';\r\nimport esESJson from 'localizations/lokalise/locales/es-ES.json';\r\nimport idIDJson from 'localizations/lokalise/locales/id-ID.json';\r\nimport msMYJson from 'localizations/lokalise/locales/ms-MY.json';\r\nimport ptPTJson from 'localizations/lokalise/locales/pt-PT.json';\r\nimport ruJson from 'localizations/lokalise/locales/ru.json';\r\nimport thTHJson from 'localizations/lokalise/locales/th-TH.json';\r\nimport viVNJson from 'localizations/lokalise/locales/vi-VN.json';\r\nimport zhCNJson from 'localizations/lokalise/locales/zh-CN.json';\r\nimport msEnums from 'localizations/ms.enums.json';\r\nimport ptEnums from 'localizations/pt.enums.json';\r\nimport ruEnums from 'localizations/ru.enums.json';\r\nimport thEnums from 'localizations/th.enums.json';\r\nimport viEnums from 'localizations/vi.enums.json';\r\nimport zhEnums from 'localizations/zh.enums.json';\r\n\r\ntype LocaleCode = {\r\n [key in ENUM_LANGUAGE_CODE]: Resource;\r\n};\r\n\r\nexport const localizationResources: LocaleCode = {\r\n [ENUM_LANGUAGE_CODE.en]: {\r\n translation: {\r\n ...en,\r\n ...enEnums,\r\n ...enGBJson,\r\n },\r\n },\r\n [ENUM_LANGUAGE_CODE.ru]: {\r\n translation: {\r\n ...ru,\r\n ...enEnums, // English used by default\r\n ...ruEnums,\r\n ...ruJson,\r\n },\r\n },\r\n [ENUM_LANGUAGE_CODE.zh]: {\r\n translation: {\r\n ...zh,\r\n ...enEnums, // English used by default\r\n ...zhEnums,\r\n ...zhCNJson,\r\n },\r\n },\r\n [ENUM_LANGUAGE_CODE.id]: {\r\n translation: {\r\n ...id,\r\n ...enEnums, // English used by default\r\n ...idEnums,\r\n ...idIDJson,\r\n },\r\n },\r\n [ENUM_LANGUAGE_CODE.ms]: {\r\n translation: {\r\n ...ms,\r\n ...enEnums, // English used by default\r\n ...msEnums,\r\n ...msMYJson,\r\n },\r\n },\r\n [ENUM_LANGUAGE_CODE.th]: {\r\n translation: {\r\n ...th,\r\n ...enEnums, // English used by default\r\n ...thEnums,\r\n ...thTHJson,\r\n },\r\n },\r\n [ENUM_LANGUAGE_CODE.vi]: {\r\n translation: {\r\n ...vi,\r\n ...enEnums, // English used by default\r\n ...viEnums,\r\n ...viVNJson,\r\n },\r\n },\r\n [ENUM_LANGUAGE_CODE.es]: {\r\n translation: {\r\n ...es,\r\n ...enEnums, // English used by default\r\n ...esEnums,\r\n ...esESJson,\r\n },\r\n },\r\n [ENUM_LANGUAGE_CODE.ar]: {\r\n translation: {\r\n ...ar,\r\n ...enEnums, // English used by default\r\n ...arEnums,\r\n ...arJson,\r\n },\r\n },\r\n [ENUM_LANGUAGE_CODE.pt]: {\r\n translation: {\r\n ...pt,\r\n ...enEnums, // English used by default\r\n ...ptEnums,\r\n ...ptPTJson,\r\n },\r\n },\r\n};\r\n","import { initReactI18next } from 'react-i18next';\r\nimport { GENERAL_CONSTANTS } from '@components-shared/general.constants';\r\nimport { localizationResources } from '@locales/constants';\r\nimport { getURLParams, numberFormat } from '@utils/helper';\r\nimport { cookieService, Cookies } from '@utils/library/cookie.service';\r\nimport { ENUM_LANGUAGE_CODE, ENUM_LOCALE_CODE, LANGUAGE_CODE_TO_LOCALE_CODE } from 'global.enums';\r\nimport i18next from 'i18next';\r\n\r\nexport const isLocaleExists = (locale: ENUM_LOCALE_CODE): boolean => {\r\n const locales = GENERAL_CONSTANTS.LOCALES;\r\n\r\n return Object.values(locales).some((l) => l.key === locale);\r\n};\r\n\r\nexport const getPresetLocale = (): ENUM_LOCALE_CODE | null => {\r\n const params = getURLParams();\r\n const { lang } = params;\r\n\r\n switch (lang) {\r\n case ENUM_LANGUAGE_CODE.en:\r\n return ENUM_LOCALE_CODE.enUS;\r\n case ENUM_LANGUAGE_CODE.ru:\r\n return ENUM_LOCALE_CODE.ru;\r\n case ENUM_LANGUAGE_CODE.zh:\r\n return ENUM_LOCALE_CODE.zhCN;\r\n case ENUM_LANGUAGE_CODE.ms:\r\n return ENUM_LOCALE_CODE.msMY;\r\n case ENUM_LANGUAGE_CODE.th:\r\n return ENUM_LOCALE_CODE.thTH;\r\n case ENUM_LANGUAGE_CODE.id:\r\n return ENUM_LOCALE_CODE.idID;\r\n case ENUM_LANGUAGE_CODE.vi:\r\n return ENUM_LOCALE_CODE.viVN;\r\n case ENUM_LANGUAGE_CODE.es:\r\n return ENUM_LOCALE_CODE.esES;\r\n case ENUM_LANGUAGE_CODE.ar:\r\n return ENUM_LOCALE_CODE.ar;\r\n case ENUM_LANGUAGE_CODE.pt:\r\n return ENUM_LOCALE_CODE.ptPT;\r\n\r\n default:\r\n return null;\r\n }\r\n};\r\n\r\nexport const setLanguage = async (locale: ENUM_LOCALE_CODE = getDefaultLocale()) => {\r\n const rootCookiePath = '/';\r\n\r\n cookieService.setCookie(Cookies.culture, locale, rootCookiePath);\r\n\r\n await i18next.changeLanguage(locale);\r\n};\r\n\r\nexport const i18nextInitialize = async (locale: ENUM_LOCALE_CODE = getDefaultLocale()) => {\r\n try {\r\n await i18next.use(initReactI18next).init({\r\n lng: locale,\r\n resources: localizationResources,\r\n interpolation: {\r\n format: (value, format, lng) => numberFormat(value, String(format), lng),\r\n },\r\n compatibilityJSON: 'v4',\r\n returnObjects: true,\r\n });\r\n } catch (e) {\r\n console.error(\r\n `An error occurred while initializing i18next for locale ${locale}.\\nError: ${e.message}. Stack trace: ${e.stack}`,\r\n );\r\n }\r\n};\r\n\r\nexport const getCulture = (): ENUM_LOCALE_CODE => {\r\n const cookieCurrentCulture = cookieService.getCookie(Cookies.culture) as ENUM_LOCALE_CODE;\r\n\r\n const locales = GENERAL_CONSTANTS.LOCALES;\r\n const localesCodes = Object.values(locales).map((l) => l.key);\r\n\r\n const codeIndex = localesCodes.findIndex((x) => x === cookieCurrentCulture);\r\n\r\n const currentCulture = codeIndex !== -1 ? localesCodes[codeIndex] : getDefaultLocale();\r\n\r\n if (i18next.isInitialized && i18next.language !== currentCulture) {\r\n void setLanguage(currentCulture);\r\n }\r\n\r\n return currentCulture;\r\n};\r\n\r\nexport const getDefaultLocale = (): ENUM_LOCALE_CODE => {\r\n const presetLocale = getPresetLocale();\r\n\r\n return presetLocale && isLocaleExists(presetLocale) ? presetLocale : GENERAL_CONSTANTS.DEFAULT_LOCALE;\r\n};\r\n\r\nexport const getCurrentLanguage = (): ENUM_LOCALE_CODE => {\r\n const { language } = i18next;\r\n\r\n const languageFromEnum = (Object.values(LANGUAGE_CODE_TO_LOCALE_CODE) as string[]).includes(language);\r\n\r\n if (languageFromEnum) {\r\n return language as ENUM_LOCALE_CODE;\r\n }\r\n\r\n return LANGUAGE_CODE_TO_LOCALE_CODE.en;\r\n};\r\n","import { ILocaleLegacy } from '@locales/interfaces';\r\n\r\n/**\r\n * @deprecated\r\n * @todo\r\n * These are legacy translations. Some of them are used silently (come from BE), while others are outdated.\r\n * Please remove keys if you are 100% sure that they are not used in the project anymore.\r\n */\r\nexport const ar = {\r\n IBCorporate: 'وسيط مُعرِفّ شركة',\r\n IBIndividual: 'وسيط مُعرِفّ فردي',\r\n MAMIndividual: 'MAM Individual',\r\n MAMMasterWithLPOA: 'MAM Individual',\r\n MarkupConfirmation: 'Markup Confirmation',\r\n UserCorporate: 'مستخدم شركة',\r\n UserIndividual: 'مستخدم فردي',\r\n UserJoint: 'مستخدم مشترك',\r\n account: {\r\n bankingDetails: 'البيانات البنكية',\r\n createANewAccount: 'إنشاء حساب جديد',\r\n register: 'تسجيل',\r\n registerSignInTitle: 'هل أنت عضو بالفعل؟',\r\n },\r\n admin: {\r\n user: {\r\n fields: {\r\n isMam: 'هو MAM',\r\n isSales: 'مستخدم مبيعات',\r\n },\r\n },\r\n tabs: {\r\n tradingSettings: {\r\n tradingAccountSettings: 'Trading Account Settings',\r\n setIBCode: 'Set IB Code',\r\n },\r\n },\r\n reports: {\r\n ftdUtmReport: {\r\n headerTitle: 'تقرير FTD_UTM',\r\n menuTitle: 'تقرير FTD_UTM',\r\n },\r\n },\r\n },\r\n adminSocialTrading: {\r\n title: 'التداول الاجتماعي',\r\n investorAccountDetails: {\r\n tradingAccountName: 'اسم حساب التداول',\r\n balance: 'الرصيد',\r\n login: 'تسجيل الدخول',\r\n },\r\n masterAccountDetails: {\r\n copyType: 'نوع النسخ',\r\n groupMappingType: 'Group Mapping Type',\r\n login: 'تسجيل الدخول',\r\n },\r\n },\r\n backgroundJobs: {\r\n recurring: {\r\n title: 'Recurring Jobs',\r\n },\r\n },\r\n bonuses: {\r\n collectBirthdayGift: 'Collect your Birthday gift',\r\n availableTable: {\r\n bonusSize: 'Bonus Size',\r\n },\r\n },\r\n errors: {\r\n shared: {\r\n recordWasNotFound: 'Record was not found',\r\n },\r\n captcha: {\r\n captchaServerIsUnavailable:\r\n 'خادم Captcha غير متاح. يرجى تحديث الصفحة والمحاولة مرة أخرى. إذا استمرت المشكلة، يرجى الاتصال بفريق الدعم عبر الدردشة الحية أو البريد الإلكتروني {{0}}',\r\n },\r\n files: {\r\n fileWasNotUploaded: 'تعذر تحميل الملف',\r\n },\r\n mam: {\r\n linkIsInactive: 'الرابط المستخدم غير نشط',\r\n },\r\n trading: {\r\n profitSharingLimitWasExceeded: 'يرجى ملاحظة أنه تم تجاوز الحد الأقصى لمشاركة الأرباح. الحد الأقصى هو {{0}}%.',\r\n notEnoughMoney:\r\n 'We apologize, but you do not have enough funds in your trading account to process the requested withdrawal. Please ensure that you have a sufficient balance available before attempting a withdrawal. Please note that in addition to the available balance, you should also consider the free margin level required for withdrawals.',\r\n },\r\n copyTrading: {\r\n equityIsLessOrEqualZero: 'The Master account is ineligible to be copied at this time, please try again later.',\r\n },\r\n securityCode: {\r\n emptyValue: 'The entered security value (password or PIN code) cannot be empty or null',\r\n invalidLength: 'The entered security value (password or PIN code) must contain {{0}} character(s)',\r\n invalidMinLength: 'The entered security value (password or PIN code) must contain at least {{0}} character(s)',\r\n invalidMaxLength: 'The entered security value (password or PIN code) must not exceed {{0}} character(s)',\r\n manyRepeatedValues:\r\n 'The entered security value (password or PIN code) must not have more than {{0}} repeated character(s)',\r\n missingNumericValues: 'The entered security value (password or PIN code) must contain numeric character(s)',\r\n containsNumericValues: 'The entered security value (password or PIN code) must not contain any numeric values',\r\n missingLowerCaseValues: 'The entered security value (password or PIN code) must contain lowercase character(s)',\r\n containsLowerCaseValues:\r\n 'The entered security value (password or PIN code) must not contain any lowercase values',\r\n missingUpperCaseValues: 'The entered security value (password or PIN code) must contain uppercase character(s)',\r\n containsUpperCaseValues:\r\n 'The entered security value (password or PIN code) must not contain any uppercase values',\r\n missingSpecialValues: 'The entered security value (password or PIN code) must contain special character(s)',\r\n containsSpecialValues:\r\n 'The entered security value (password or PIN code) must not contain any special characters',\r\n passwordChangeLimit: 'Password change attempts limit is exceeded. Please wait and try again',\r\n },\r\n user: {\r\n accountHasBeenDisabled: 'Sorry for the inconvenience, but the account {{0}} has been disabled',\r\n ageIsAboveMaxAllowed: 'We do not accept applications from anyone under {{0}} or over {{1}} years old.',\r\n ageIsUnderMinAllowed: 'We do not accept applications from anyone under {{0}} years old.',\r\n cantChangeLanguage: 'Cannot change language',\r\n fieldIsRequired: 'Field {{0}} is required',\r\n ibCodeIsIncorrect: \"The IB code '{{0}}' is incorrect. Please enter a valid IB code\",\r\n invalidCredentials: 'Invalid username {{0}} and/or password',\r\n invalidLengthOfPhoneNumber: 'The phone number length is invalid, please try again',\r\n invalidLink: 'The link is invalid',\r\n invalidPhoneNumberLength: 'The phone number length is invalid, please try again',\r\n onlyLatinCharactersAndDigitsAndSpecialSymbolsCanBeUsed:\r\n 'Only latin characters, digits and special symbols can be used for {{0}} field',\r\n onlyLatinCharactersAndDigitsCanBeUsed: 'Only latin characters and digits can be used for {{0}} field',\r\n onlyLatinCharactersCanBeUsed: 'Only latin characters can be used for {{0}} field',\r\n onlyChineseCharactersCanBeUsed: 'Only chinese characters can be used for {{0}} field',\r\n personalDataNotEntered: 'Personal data are not entered',\r\n userCannotBeRestored:\r\n 'Sorry, the record cannot be restored as the email or phone number of this profile is already in use with another profile, please delete the profile with the same email or phone number to restore this one',\r\n userDoesntExist: \"User {{0}} doesn't exist\",\r\n userEmailAlreadyExists: 'User email has been already registered in the system',\r\n userPhoneAlreadyExists: 'User phone has been already registered in the system',\r\n cantUpdateProfileActualStatus: '{{تعذر تحديث الحساب {{0}}الحالة الفعلية = {{1',\r\n },\r\n },\r\n formats: {\r\n formatFloat: '{{value, float}}',\r\n formatMoney: '{{value, money}}',\r\n },\r\n forms: {\r\n dragFile: 'أو اسحب ملفاتك هنا',\r\n exportFormat: 'تنسيق ملف التصدير',\r\n getCode: 'احصل على رمز',\r\n hide: 'إخفاء',\r\n limitMessage: '{{limit}} أحرف متبقية',\r\n resend: 'إعادة إرسال',\r\n seconds: 'ثانية',\r\n show: 'عرض',\r\n },\r\n headerWithBalance: {\r\n serverTime: 'توقيت الخادم',\r\n failedToFetchServerTime: 'تعذر إحضار توقيت الخادم',\r\n view: 'عرض',\r\n },\r\n investors: {\r\n blackList: 'القائمة السوداء',\r\n },\r\n legal: {\r\n clientAgreement: 'اتفاقية العميل',\r\n privacyPolicy: 'سياسة الخصوصية',\r\n },\r\n legalTradingPlatform: {\r\n data: 'Data',\r\n },\r\n masterProfile: {\r\n aboutMaster: 'عن الأستاذ',\r\n infoFields: {\r\n ibCode: 'رمز الوسيط المُعرِفّ',\r\n },\r\n },\r\n masters: {\r\n fields: {\r\n masterNickname: 'لقب الأستاذ',\r\n rating: 'المركز في جدول الترتيب',\r\n },\r\n },\r\n menu: {\r\n deposit: 'الإيداع',\r\n },\r\n messages: {\r\n CopyTrading: {\r\n InvestorAccountWasLinked: \"بدأ حساب المتابِع في النسخ من حساب الأستاذ '{{MasterAccountName}}'.\",\r\n InvestorAccountWasOpened:\r\n \"تم إنشاء حساب المتابِع. بدأ حساب المتابِع في النسخ من حساب الأستاذ '{{InvestorAccountName}}'.\",\r\n InvestorAccountWasUnlinked: \"توقف حساب المتابِع عن النسخ من حساب الأستاذ '{{MasterAccountName}}'.\",\r\n MasterAccountWasChanged:\r\n 'تم تعديل حساب الأستاذ. (مشاركة الأرباح = {{ProfitSharing}}، طريقة التخصيص = {{AllocationMethod}})',\r\n MasterAccountWasLinked: \"بدأ حساب المتابِع '{{InvestorAccountName}}' في النسخ من حساب الأستاذ.\",\r\n MasterAccountWasOpened:\r\n 'تم إنشاء حساب الأستاذ. (مشاركة الأرباح = {{ProfitSharing}}، طريقة التخصيص = {{AllocationMethod}})',\r\n MasterAccountWasUnlinked: \"توقف حساب المتابِع '{{InvestorAccountName}}' عن النسخ من حساب الأستاذ.\",\r\n },\r\n },\r\n modal: {\r\n error: 'خطأ',\r\n notification: 'إشعار',\r\n ok: 'موافق',\r\n },\r\n operationHistory: {\r\n filterName: 'بحث',\r\n placeholder: 'يرجى إدخال',\r\n },\r\n pageTitles: {\r\n admin: {\r\n financialIdentity: {\r\n children: {\r\n cards: 'Cards',\r\n },\r\n },\r\n },\r\n },\r\n partnership: {\r\n salesTitle: 'المبيعات',\r\n ibInfo: {\r\n detailsTitle: 'تفاصيل الوسيط المُعرِفّ',\r\n nextRebatePayment: 'دفعة الحسومات التالية',\r\n statistics: {\r\n closetTradersReport: {\r\n type: 'النوع',\r\n },\r\n tradingVolReport: {\r\n subIb: 'الوسيط المُعرِفّ الفرعي',\r\n },\r\n },\r\n },\r\n ibSettings: {\r\n referralLinkError: 'العلاوة غير صحيح! يرجى الاتصال بفريق الدعم للحصول على العلاوات الصحيحة',\r\n },\r\n salesUserInfo: {\r\n aeCode: 'كود AE',\r\n },\r\n },\r\n profile: {\r\n adult: 'عمري أكثر من 18 سنة',\r\n code: 'الرمز',\r\n country: 'الدولة',\r\n documentsUploaded: 'الوثائق المرفوعة',\r\n isAgreeWithTermsAndConditions: 'أوافق على <0> اتفاقية العميل 0> و <1> سياسة الخصوصية 1>',\r\n pleaseValidateAccountToDeposit:\r\n 'يجب أن يتحقق فريق الامتثال التنظيمي لدى {{brokerName}} من بياناتك الشخصية. قبل البدء في عملية الإيداع، يجب إرسال صورة ممسوحة ضوئيًا من بطاقة هويتك.',\r\n successChangeDescription: 'تم حفظ التغييرات!',\r\n warningMessage: {\r\n profileIsBeingVerified: 'جارِ التحقق من ملفك الشخصي، قد يستغرق الأمر بضع ثوانٍ',\r\n },\r\n },\r\n psp: {\r\n accountsFetchFailErr: 'تعذر إحضار الحسابات',\r\n confirmEveryTransaction: 'قد تستغرق عمليات الإيداع ما يصل إلى 24 ساعة حتى الانتهاء من تأكيد جميع المعاملات.',\r\n deposit: {\r\n depositForm: {\r\n accountNameTitle: 'أسم الحساب',\r\n addressLine2: 'سطر العنوان 2',\r\n beneficiaryAccountNumberTitle: 'رقم حساب المستفيد',\r\n beneficiaryBankHint: 'يُرجى تحديد رقم الحساب المصرفي',\r\n beneficiaryBankNameHint: 'اسم البنك، على سبيل المثال (Standard Charted Bank)',\r\n cardNameTitle: 'Card Name',\r\n localDepositFileHint: 'يرجى إرفاق مستند يؤكد عملية الدفع إذا لزم الأمر',\r\n },\r\n depositTitle: 'إيداع الأموال',\r\n notice: 'يُسمح بإجراء الإيداعات فقط للحسابات التي تم التحقق منها',\r\n warnToSubmitPersonalDetails:\r\n 'لإجراء الإيداع، يرجى تقديم بياناتك الشخصية، تأكد من أن هذه البيانات تتطابق مع تلك المذكورة في بطاقة هويتك',\r\n },\r\n localAgentTable: {\r\n login: 'تسجيل الدخول',\r\n },\r\n operationsFetchFailErr: 'تعذر إحضار العمليات',\r\n operationsTable: {\r\n documentTitle: 'الوثيقة',\r\n operationsTableTitle: 'العمليات الأخيرة',\r\n paymentSystemTitle: 'نظام الدفع',\r\n },\r\n pluginInfoFetchFailErr: 'تعذر إحضار معلومات البرنامج الإضافي',\r\n pluginNotFound: 'البرنامج الإضافي غير موجود',\r\n pluginsFetchFailErr: 'تعذر إحضار البرامج الإضافية',\r\n preAuthorizedBanking: 'الخدمات المصرفية المُصرح بها مسبقًا',\r\n qrCodeCryptoNotice:\r\n 'رمز الاستجابة السريعة متاح للاستخدام لمرة واحدة فقط. لا تمسح هذا الرمز ضوئيًا في تطبيق العملات المشفرة أكثر من مرة، وإلا سيتم تعليق دفعتك.',\r\n qrCodeCryptoTitle: 'رمز الاستجابة السريعة لتطبيق العملات المشفرة',\r\n resentOperationsTitle: 'العمليات الأخيرة',\r\n transfer: {\r\n transactionDetailsTitle: 'تفاصيل المعاملة',\r\n transferForm: {\r\n amountError: 'تم تجاوز مبلغ التحويل المتاح',\r\n currencyTitle: 'العملة',\r\n },\r\n },\r\n uploadBankStatementWithBankName: 'قم بتحميل كشف حساب بنكي يحتوي على اسم البنك واسمك الكامل ورقم حسابك المصرفي',\r\n uploadPayslip: 'قم بتحميل إيصال الدفع الخاص بإيداعك الصادر من البنك',\r\n uploadYourDocument: 'يرجى تأكيد إيداعك عن طريق تحميل صورة من كشف حسابك البنكي',\r\n withdrawal: {\r\n notice: 'عمليات السحب متاحة فقط للحسابات التي تم التحقق منها',\r\n withdrawalTitle: 'سحب الأموال',\r\n withdrawalForm: {\r\n bankNameTitle: 'اسم البنك',\r\n beneficiaryCryptoWalletHint: 'سيتم إرسال رقم المحفظة التي ستُرسل العملات المشفرة إليها',\r\n beneficiaryCryptoWalletTitle: 'محفظة العملات المشفرة للمستفيد',\r\n confirmTitle: 'تأكيد معلومات السحب',\r\n },\r\n },\r\n },\r\n settings: {\r\n docsForm: {\r\n documentNumberHint: 'تحقق مما إذا كان رقم التعريف هو نفسه الموجود في الصورة',\r\n documentTypeHint: 'يرجى التأكد من إرسال صورة عالية الجودة أو مسح الوثيقة ضوئيًا.',\r\n uploadedDocumentsTable: {\r\n docNameTitle: 'اسم الملف',\r\n documentNumber: 'رقم الوثيقة',\r\n typeTitle: 'نوع الوثيقة',\r\n },\r\n },\r\n profileForm: {\r\n editProfileTitle: 'تعديل الملف الشخصي',\r\n proceedToDeposit: 'متابعة الإيداع',\r\n saveUserSuccessMessage: 'تم حفظ الملف الشخصي بنجاح',\r\n userDetailsErrorMessage: 'تعذر إحضار الملف الشخصي للمستخدم',\r\n verifyPersonalDetails: 'تحقق من التفاصيل الشخصية',\r\n verifyProfileBtn: 'تحقق من الملف الشخصي',\r\n },\r\n },\r\n socialTradingModal: {\r\n copyHint: 'سيتوقف حسابك {{account}} عن النسخ من حساب الأستاذ {{oldMaster}}، وسيبدأ في النسخ من {{newMaster}}',\r\n },\r\n tradingAccounts: {\r\n accountDetailsTitle: 'حساب التداول',\r\n accountHistoryForm: {\r\n closeTimeTitle: 'وقت الإغلاق',\r\n },\r\n changeTradingAccountName: 'تغيير اسم حساب التداول',\r\n connectedAccounts: 'الحسابات المتصلة',\r\n currency: 'العملة',\r\n depositForm: {\r\n amountTitle: 'المبلغ',\r\n errorMessage: 'فشل إيداع الأموال',\r\n successMessage: 'تم الإيداع بنجاح',\r\n },\r\n descriptionPlaceholder: 'ادخِل توصية لمتابعيك',\r\n fetchServersErr: 'تعذر إحضار الخوادم',\r\n ibCode: 'الوسيط المُعرِفّ (اختياري)',\r\n notRows: 'لا توجد صفوف لعرضها',\r\n openAccountModalSubTitle: 'أكبر مجموعة من أدوات التداول: العملات والمعادن. شروط التداول القياسية.',\r\n tradingPlatforms: 'منصات التداول',\r\n transferForm: {\r\n title: 'تحويل الأموال',\r\n },\r\n withdrawForm: {\r\n amountTitle: 'المبلغ',\r\n errorMessage: 'فشل في حفظ الرافعة المالية',\r\n successMessage: 'تم السحب بنجاح',\r\n },\r\n },\r\n} satisfies ILocaleLegacy;\r\n","import { ILocaleLegacy } from '@locales/interfaces';\r\n\r\n/**\r\n * @deprecated\r\n * @todo\r\n * These are legacy translations. Some of them are used silently (come from BE), while others are outdated.\r\n * Please remove keys if you are 100% sure that they are not used in the project anymore.\r\n */\r\nexport const en = {\r\n /** In use. Please move it carefully. */\r\n IBCorporate: 'IB Corporate',\r\n IBIndividual: 'IB Individual',\r\n MAMIndividual: 'MAM Individual',\r\n MAMMasterWithLPOA: 'MAM Individual',\r\n MarkupConfirmation: 'Markup Confirmation',\r\n UserCorporate: 'User Corporate',\r\n UserIndividual: 'User Individual',\r\n UserJoint: 'User Joint',\r\n account: {\r\n bankingDetails: 'Banking Details',\r\n createANewAccount: 'Create a new account',\r\n register: 'Register',\r\n registerSignInTitle: 'Already a Member?',\r\n },\r\n admin: {\r\n user: {\r\n fields: {\r\n isMam: 'Is MAM',\r\n isSales: 'Is Sales User',\r\n },\r\n },\r\n tabs: {\r\n tradingSettings: {\r\n tradingAccountSettings: 'Trading Account Settings',\r\n setIBCode: 'Set IB Code',\r\n },\r\n },\r\n reports: {\r\n ftdUtmReport: {\r\n headerTitle: 'FTD_UTM Report',\r\n menuTitle: 'FTD_UTM Report',\r\n },\r\n },\r\n },\r\n\r\n adminSocialTrading: {\r\n title: 'Social Trading',\r\n investorAccountDetails: {\r\n tradingAccountName: 'Trading Account Name',\r\n balance: 'Balance',\r\n login: 'Login',\r\n },\r\n masterAccountDetails: {\r\n copyType: 'Copy Type',\r\n groupMappingType: 'Group Mapping Type',\r\n login: 'Login',\r\n },\r\n },\r\n backgroundJobs: {\r\n recurring: {\r\n title: 'Recurring Jobs',\r\n },\r\n },\r\n bonuses: {\r\n collectBirthdayGift: 'Collect your Birthday gift',\r\n availableTable: {\r\n bonusSize: 'Bonus Size',\r\n },\r\n },\r\n /** In use. Please move it carefully. */\r\n errors: {\r\n shared: {\r\n recordWasNotFound: 'Record was not found',\r\n },\r\n captcha: {\r\n captchaServerIsUnavailable:\r\n 'Captcha server is unavailable. Please refresh the page and try again. If the problem remains please contact support via online chat or by email {{0}}',\r\n },\r\n files: {\r\n fileWasNotUploaded: 'File was not loaded',\r\n },\r\n mam: {\r\n linkIsInactive: 'Used link is not active',\r\n },\r\n trading: {\r\n profitSharingLimitWasExceeded:\r\n 'Please note, that the max limit for profit sharing has been exceeded. The max limit is {{0}}%.',\r\n notEnoughMoney:\r\n 'We apologize, but you do not have enough funds in your trading account to process the requested withdrawal. Please ensure that you have a sufficient balance available before attempting a withdrawal. Please note that in addition to the available balance, you should also consider the free margin level required for withdrawals.',\r\n },\r\n copyTrading: {\r\n equityIsLessOrEqualZero: 'The Master account is ineligible to be copied at this time, please try again later.',\r\n },\r\n securityCode: {\r\n emptyValue: 'The entered security value (password or PIN code) cannot be empty or null',\r\n invalidLength: 'The entered security value (password or PIN code) must contain {{0}} character(s)',\r\n invalidMinLength: 'The entered security value (password or PIN code) must contain at least {{0}} character(s)',\r\n invalidMaxLength: 'The entered security value (password or PIN code) must not exceed {{0}} character(s)',\r\n manyRepeatedValues:\r\n 'The entered security value (password or PIN code) must not have more than {{0}} repeated character(s)',\r\n missingNumericValues: 'The entered security value (password or PIN code) must contain numeric character(s)',\r\n containsNumericValues: 'The entered security value (password or PIN code) must not contain any numeric values',\r\n missingLowerCaseValues: 'The entered security value (password or PIN code) must contain lowercase character(s)',\r\n containsLowerCaseValues:\r\n 'The entered security value (password or PIN code) must not contain any lowercase values',\r\n missingUpperCaseValues: 'The entered security value (password or PIN code) must contain uppercase character(s)',\r\n containsUpperCaseValues:\r\n 'The entered security value (password or PIN code) must not contain any uppercase values',\r\n missingSpecialValues: 'The entered security value (password or PIN code) must contain special character(s)',\r\n containsSpecialValues:\r\n 'The entered security value (password or PIN code) must not contain any special characters',\r\n passwordChangeLimit: 'Password change attempts limit is exceeded. Please wait and try again',\r\n },\r\n user: {\r\n accountHasBeenDisabled: 'Sorry for the inconvenience, but the account {{0}} has been disabled',\r\n ageIsAboveMaxAllowed: 'We do not accept applications from anyone under {{0}} or over {{1}} years old.',\r\n ageIsUnderMinAllowed: 'We do not accept applications from anyone under {{0}} years old.',\r\n cantChangeLanguage: 'Cannot change language',\r\n fieldIsRequired: 'Field {{0}} is required',\r\n ibCodeIsIncorrect: \"The IB code '{{0}}' is incorrect. Please enter a valid IB code\",\r\n invalidCredentials: 'Invalid username {{0}} and/or password',\r\n invalidLengthOfPhoneNumber: 'The phone number length is invalid, please try again',\r\n invalidLink: 'The link is invalid',\r\n invalidPhoneNumberLength: 'The phone number length is invalid, please try again',\r\n onlyLatinCharactersAndDigitsAndSpecialSymbolsCanBeUsed:\r\n 'Only latin characters, digits and special symbols can be used for {{0}} field',\r\n onlyLatinCharactersAndDigitsCanBeUsed: 'Only latin characters and digits can be used for {{0}} field',\r\n onlyLatinCharactersCanBeUsed: 'Only latin characters can be used for {{0}} field',\r\n onlyChineseCharactersCanBeUsed: 'Only chinese characters can be used for {{0}} field',\r\n personalDataNotEntered: 'Personal data are not entered',\r\n userCannotBeRestored:\r\n 'Sorry, the record cannot be restored as the email or phone number of this profile is already in use with another profile, please delete the profile with the same email or phone number to restore this one',\r\n userDoesntExist: \"User {{0}} doesn't exist\",\r\n userEmailAlreadyExists: 'User email has been already registered in the system',\r\n userPhoneAlreadyExists: 'User phone has been already registered in the system',\r\n cantUpdateProfileActualStatus: \"Can't update account {{0}}, actual status = {{1}}\",\r\n },\r\n },\r\n formats: {\r\n formatFloat: '{{value, float}}',\r\n formatMoney: '{{value, money}}',\r\n },\r\n forms: {\r\n dragFile: 'or drag here your files',\r\n exportFormat: 'Export Format',\r\n getCode: 'Get Code',\r\n hide: 'Hide',\r\n limitMessage: '{{limit}} Characters left',\r\n resend: 'Resend',\r\n seconds: 'sec',\r\n show: 'Show',\r\n },\r\n headerWithBalance: {\r\n serverTime: 'Server Time',\r\n failedToFetchServerTime: 'Failed to fetch server time',\r\n view: 'View',\r\n },\r\n investors: {\r\n blackList: 'Black List',\r\n },\r\n legal: {\r\n clientAgreement: 'Client Agreement',\r\n privacyPolicy: 'Privacy Policy',\r\n },\r\n legalTradingPlatform: {\r\n data: 'Data',\r\n },\r\n masterProfile: {\r\n aboutMaster: 'About Master',\r\n infoFields: {\r\n ibCode: 'IB code',\r\n },\r\n },\r\n masters: {\r\n fields: {\r\n masterNickname: 'Master Nickname',\r\n rating: 'Position in Rating',\r\n },\r\n },\r\n menu: {\r\n deposit: 'Deposit',\r\n },\r\n messages: {\r\n /** In use. Please move it carefully. */\r\n CopyTrading: {\r\n InvestorAccountWasLinked: \"Follower account started to copy Master account '{{MasterAccountName}}'.\",\r\n InvestorAccountWasOpened:\r\n \"Follower account was created. Follower account started to copy Master account '{{InvestorAccountName}}'.\",\r\n InvestorAccountWasUnlinked: \"Follower account stopped to copy Master account '{{MasterAccountName}}'.\",\r\n MasterAccountWasChanged:\r\n 'Master account was modified. (Profit sharing={{ProfitSharing}}, Allocation method={{AllocationMethod}})',\r\n MasterAccountWasLinked: \"Follower's account '{{InvestorAccountName}}' started to copy Master account.\",\r\n MasterAccountWasOpened:\r\n 'Master account was created. (Profit sharing={{ProfitSharing}}, Allocation method={{AllocationMethod}})',\r\n MasterAccountWasUnlinked: \"Follower's account '{{InvestorAccountName}}' stopped to copy Master account.\",\r\n },\r\n },\r\n modal: {\r\n error: 'Error',\r\n notification: 'Notification',\r\n ok: 'Ok',\r\n },\r\n operationHistory: {\r\n filterName: 'Search',\r\n placeholder: 'Please enter',\r\n },\r\n\r\n pageTitles: {\r\n admin: {\r\n financialIdentity: {\r\n children: {\r\n cards: 'Cards',\r\n },\r\n },\r\n },\r\n },\r\n partnership: {\r\n salesTitle: 'Sales',\r\n ibInfo: {\r\n detailsTitle: 'IB Details',\r\n nextRebatePayment: 'Next Rebate Payment',\r\n statistics: {\r\n closetTradersReport: {\r\n type: 'Type',\r\n },\r\n tradingVolReport: {\r\n subIb: 'Sub-IB',\r\n },\r\n },\r\n },\r\n ibSettings: {\r\n referralLinkError: 'Markups are incorrect! Please contact our support team to get correct markups',\r\n },\r\n salesUserInfo: {\r\n aeCode: 'AE Code',\r\n },\r\n },\r\n profile: {\r\n adult: 'I am over 18 years old',\r\n code: 'Code',\r\n country: 'Country',\r\n documentsUploaded: 'Uploaded Documents',\r\n isAgreeWithTermsAndConditions: 'I accept the <0>Client Agreement0> and the <1>Privacy Policy1>',\r\n pleaseValidateAccountToDeposit:\r\n 'Your personal details require verification by the {{brokerName}} compliance team. Before proceeding to deposit, you need to submit a scan of your ID',\r\n successChangeDescription: 'Changes are saved!',\r\n warningMessage: {\r\n profileIsBeingVerified: 'Your profile is being verified, it might take a couple of seconds',\r\n },\r\n },\r\n psp: {\r\n accountsFetchFailErr: 'Failed to fetch accounts',\r\n confirmEveryTransaction: 'Confirming all transactions, deposits can take up to 24 hours',\r\n deposit: {\r\n depositForm: {\r\n accountNameTitle: 'Account Name',\r\n addressLine2: 'Address Line 2',\r\n beneficiaryAccountNumberTitle: 'Beneficiary Account Number',\r\n beneficiaryBankHint: 'Please select the bank account number',\r\n beneficiaryBankNameHint: 'Bank Name, e.g. (Standard Charted Bank)',\r\n cardNameTitle: 'Card Name',\r\n localDepositFileHint: 'Please attach a document confirming payment if needed',\r\n },\r\n depositTitle: 'Deposit Funds',\r\n notice: 'Deposits are available only for verified accounts',\r\n warnToSubmitPersonalDetails:\r\n 'To make a deposit, please submit your personal details. Please make sure they match the data in your ID',\r\n },\r\n localAgentTable: {\r\n login: 'Login',\r\n },\r\n operationsFetchFailErr: 'Failed to fetch operations',\r\n operationsTable: {\r\n documentTitle: 'Document',\r\n operationsTableTitle: 'Recent Operations',\r\n paymentSystemTitle: 'Payment System',\r\n },\r\n pluginInfoFetchFailErr: 'Failed to fetch plugin info',\r\n pluginNotFound: 'Plugin not found',\r\n pluginsFetchFailErr: 'Failed to fetch plugins',\r\n preAuthorizedBanking: 'Pre-Authorized Banking',\r\n qrCodeCryptoNotice:\r\n 'The QR Code is for one-time use only. Do not scan this code in a Crypto application more than once, otherwise your payment will be suspended.',\r\n qrCodeCryptoTitle: 'QR Code for Crypto application',\r\n resentOperationsTitle: 'Recent Operations',\r\n transfer: {\r\n transactionDetailsTitle: 'Transaction details',\r\n transferForm: {\r\n amountError: 'Available transfer amount was exceeded',\r\n currencyTitle: 'Currency',\r\n },\r\n },\r\n uploadBankStatementWithBankName:\r\n 'Upload a bank statement which contains Bank Name, your Full Name and Bank Account Number',\r\n uploadPayslip: 'Upload the bank payslip of your deposit',\r\n uploadYourDocument: 'Please confirm your deposit by uploading your bank statement',\r\n withdrawal: {\r\n notice: 'Withdrawals are available only for verified accounts',\r\n withdrawalTitle: 'Withdraw Funds',\r\n withdrawalForm: {\r\n bankNameTitle: 'Bank Name',\r\n beneficiaryCryptoWalletHint: 'A wallet number with cryptocurrency money will be sent to',\r\n beneficiaryCryptoWalletTitle: 'Beneficiary Crypto Wallet',\r\n confirmTitle: 'Confirm withdraw information',\r\n },\r\n },\r\n },\r\n\r\n settings: {\r\n docsForm: {\r\n documentNumberHint: 'Check if Identification number is the same as on the photo',\r\n documentTypeHint: 'Please make sure you provide a high quality photo or scan of valid document',\r\n uploadedDocumentsTable: {\r\n docNameTitle: 'Document Name',\r\n documentNumber: 'Document number',\r\n typeTitle: 'Document Type',\r\n },\r\n },\r\n profileForm: {\r\n editProfileTitle: 'Edit profile',\r\n proceedToDeposit: 'Proceed to Deposit',\r\n saveUserSuccessMessage: 'Profile was successfully saved',\r\n userDetailsErrorMessage: 'Failed to fetch user profile',\r\n verifyPersonalDetails: 'Verify Personal Details',\r\n verifyProfileBtn: 'Verify Profile',\r\n },\r\n },\r\n socialTradingModal: {\r\n copyHint: 'Your Account {{account}} will stop to copy Master {{oldMaster}}, and start to copy {{newMaster}}',\r\n },\r\n tradingAccounts: {\r\n accountDetailsTitle: 'Trading Account',\r\n accountHistoryForm: {\r\n closeTimeTitle: 'Close Time',\r\n },\r\n changeTradingAccountName: 'Change trading account name',\r\n connectedAccounts: 'Connected Accounts',\r\n currency: 'Currency',\r\n depositForm: {\r\n amountTitle: 'Amount',\r\n errorMessage: 'Failed to deposit funds',\r\n successMessage: 'Deposit was successfully made',\r\n },\r\n\r\n descriptionPlaceholder: 'Enter recommendation for you followers',\r\n fetchServersErr: 'Failed to fetch servers',\r\n\r\n ibCode: 'IB (optional)',\r\n notRows: 'No rows to display',\r\n openAccountModalSubTitle: 'The widest range of trading instruments: currencies, metals. Standard trading terms.',\r\n tradingPlatforms: 'Trading Platforms',\r\n transferForm: {\r\n title: 'Transfer Funds',\r\n },\r\n withdrawForm: {\r\n amountTitle: 'Amount',\r\n errorMessage: 'Failed to save leverage',\r\n successMessage: 'Withdrawal was successfully made',\r\n },\r\n },\r\n} satisfies ILocaleLegacy;\r\n","import { ILocaleLegacy } from '@locales/interfaces';\r\n\r\n/**\r\n * @deprecated\r\n * @todo\r\n * These are legacy translations. Some of them are used silently (come from BE), while others are outdated.\r\n * Please remove keys if you are 100% sure that they are not used in the project anymore.\r\n */\r\nexport const es = {\r\n IBCorporate: 'IB corporativo',\r\n IBIndividual: 'IB individual',\r\n MAMIndividual: 'MAM individual',\r\n MAMMasterWithLPOA: 'MAM individual',\r\n MarkupConfirmation: 'Confirmación de margen',\r\n UserCorporate: 'Usuario corporativo',\r\n UserIndividual: 'Usuario individual',\r\n UserJoint: 'Usuario conjunto',\r\n account: {\r\n bankingDetails: 'Datos bancarios',\r\n createANewAccount: 'Crea una cuenta nueva',\r\n register: 'Registro',\r\n registerSignInTitle: '¿Ya es usuario?',\r\n },\r\n admin: {\r\n user: {\r\n fields: {\r\n isMam: 'Es MAM',\r\n isSales: 'Es usuario de ventas',\r\n },\r\n },\r\n tabs: {\r\n tradingSettings: {\r\n tradingAccountSettings: 'Trading Account Settings',\r\n setIBCode: 'Set IB Code',\r\n },\r\n },\r\n reports: {\r\n ftdUtmReport: {\r\n headerTitle: 'Informe FTD_UTM',\r\n menuTitle: 'Informe FTD_UTM',\r\n },\r\n },\r\n },\r\n adminSocialTrading: {\r\n title: 'Perdagangan Sosial',\r\n investorAccountDetails: {\r\n tradingAccountName: 'Nombre de la cuenta de trading',\r\n balance: 'Balance',\r\n login: 'Acceso',\r\n },\r\n masterAccountDetails: {\r\n copyType: 'Tipo de copia',\r\n groupMappingType: 'Group Mapping Type',\r\n login: 'Acceso',\r\n },\r\n },\r\n backgroundJobs: {\r\n recurring: {\r\n title: 'Recurring Jobs',\r\n },\r\n },\r\n bonuses: {\r\n collectBirthdayGift: 'Collect your Birthday gift',\r\n availableTable: {\r\n bonusSize: 'Bonus Size',\r\n },\r\n },\r\n errors: {\r\n shared: {\r\n recordWasNotFound: 'No se encuentra la página',\r\n },\r\n captcha: {\r\n captchaServerIsUnavailable:\r\n 'El servidor Captcha no está disponible. Actualice la página y vuelva a intentarlo. Si el problema persiste, póngase en contacto con soporte a través del chat en línea o por correo electrónico a {{clientSupportEmail}}',\r\n },\r\n files: {\r\n fileWasNotUploaded: 'El archivo no fue cargado',\r\n },\r\n mam: {\r\n linkIsInactive: 'El enlace usado no está activo',\r\n },\r\n trading: {\r\n profitSharingLimitWasExceeded:\r\n 'Tenga en cuenta que se ha excedido el límite máximo para el reparto de beneficios. El límite máximo es {{maxLimit}}%.',\r\n notEnoughMoney:\r\n 'We apologize, but you do not have enough funds in your trading account to process the requested withdrawal. Please ensure that you have a sufficient balance available before attempting a withdrawal. Please note that in addition to the available balance, you should also consider the free margin level required for withdrawals.',\r\n },\r\n copyTrading: {\r\n equityIsLessOrEqualZero: 'The Master account is ineligible to be copied at this time, please try again later.',\r\n },\r\n securityCode: {\r\n emptyValue: 'The entered security value (password or PIN code) cannot be empty or null',\r\n invalidLength: 'The entered security value (password or PIN code) must contain {{0}} character(s)',\r\n invalidMinLength: 'The entered security value (password or PIN code) must contain at least {{0}} character(s)',\r\n invalidMaxLength: 'The entered security value (password or PIN code) must not exceed {{0}} character(s)',\r\n manyRepeatedValues:\r\n 'The entered security value (password or PIN code) must not have more than {{0}} repeated character(s)',\r\n missingNumericValues: 'The entered security value (password or PIN code) must contain numeric character(s)',\r\n containsNumericValues: 'The entered security value (password or PIN code) must not contain any numeric values',\r\n missingLowerCaseValues: 'The entered security value (password or PIN code) must contain lowercase character(s)',\r\n containsLowerCaseValues:\r\n 'The entered security value (password or PIN code) must not contain any lowercase values',\r\n missingUpperCaseValues: 'The entered security value (password or PIN code) must contain uppercase character(s)',\r\n containsUpperCaseValues:\r\n 'The entered security value (password or PIN code) must not contain any uppercase values',\r\n missingSpecialValues: 'The entered security value (password or PIN code) must contain special character(s)',\r\n containsSpecialValues:\r\n 'The entered security value (password or PIN code) must not contain any special characters',\r\n passwordChangeLimit: 'Password change attempts limit is exceeded. Please wait and try again',\r\n },\r\n user: {\r\n accountHasBeenDisabled: 'Sorry for the inconvenience, but the account {{0}} has been disabled',\r\n ageIsAboveMaxAllowed: 'We do not accept applications from anyone under {{0}} or over {{1}} years old.',\r\n ageIsUnderMinAllowed: 'We do not accept applications from anyone under {{0}} years old.',\r\n cantChangeLanguage: 'Cannot change language',\r\n fieldIsRequired: 'Field {{0}} is required',\r\n ibCodeIsIncorrect: \"The IB code '{{0}}' is incorrect. Please enter a valid IB code\",\r\n invalidCredentials: 'Invalid username {{0}} and/or password',\r\n invalidLengthOfPhoneNumber: 'The phone number length is invalid, please try again',\r\n invalidLink: 'The link is invalid',\r\n invalidPhoneNumberLength: 'The phone number length is invalid, please try again',\r\n onlyLatinCharactersAndDigitsAndSpecialSymbolsCanBeUsed:\r\n 'Only latin characters, digits and special symbols can be used for {{0}} field',\r\n onlyLatinCharactersAndDigitsCanBeUsed: 'Only latin characters and digits can be used for {{0}} field',\r\n onlyLatinCharactersCanBeUsed: 'Only latin characters can be used for {{0}} field',\r\n onlyChineseCharactersCanBeUsed: 'Only chinese characters can be used for {{0}} field',\r\n personalDataNotEntered: 'Personal data are not entered',\r\n userCannotBeRestored:\r\n 'Sorry, the record cannot be restored as the email or phone number of this profile is already in use with another profile, please delete the profile with the same email or phone number to restore this one',\r\n userDoesntExist: \"User {{0}} doesn't exist\",\r\n userEmailAlreadyExists: 'User email has been already registered in the system',\r\n userPhoneAlreadyExists: 'User phone has been already registered in the system',\r\n cantUpdateProfileActualStatus: 'No se puede actualizar la cuenta {{0}}, estado actual = {{1}}',\r\n },\r\n },\r\n formats: {\r\n formatFloat: '{{value, float}}',\r\n formatMoney: '{{value, money}}',\r\n },\r\n forms: {\r\n dragFile: 'o arrastre aquí sus archivos',\r\n exportFormat: 'Formato de la exportación',\r\n getCode: 'Obtener código',\r\n hide: 'Ocultar',\r\n limitMessage: '{{limit}} caracteres restantes',\r\n resend: 'Reenviar',\r\n seconds: 'seg',\r\n show: 'Mostrar',\r\n },\r\n headerWithBalance: {\r\n serverTime: 'Hora del servidor',\r\n failedToFetchServerTime: 'No se pudo obtener la hora del servidor',\r\n view: 'Vista',\r\n },\r\n investors: {\r\n blackList: 'Lista negra',\r\n },\r\n legal: {\r\n clientAgreement: 'Acuerdo del cliente',\r\n privacyPolicy: 'Política de privacidad',\r\n },\r\n legalTradingPlatform: {\r\n data: 'Data',\r\n },\r\n masterProfile: {\r\n aboutMaster: 'Sobre el proveedor',\r\n infoFields: {\r\n ibCode: 'Código IB',\r\n },\r\n },\r\n masters: {\r\n fields: {\r\n masterNickname: 'Apodo del proveedor',\r\n rating: 'Posición en la clasificación',\r\n },\r\n },\r\n menu: {\r\n deposit: 'Depósito',\r\n },\r\n messages: {\r\n CopyTrading: {\r\n InvestorAccountWasLinked:\r\n \"La cuenta de seguidor comenzó a copiar la cuenta de proveedor '{{MasterAccountName}}'.\",\r\n InvestorAccountWasOpened:\r\n \"Se creó la cuenta de seguidor. La cuenta de seguidor comenzó a copiar la cuenta de proveedor '{{InvestorAccountName}}'.\",\r\n InvestorAccountWasUnlinked:\r\n \"La cuenta de seguidor dejó de copiar la cuenta de proveedor '{{MasterAccountName}}'.\",\r\n MasterAccountWasChanged:\r\n 'Se modificó la cuenta maestra. (Reparto de beneficios={{ProfitSharing}}, Método de asignación={{AllocationMethod}})',\r\n MasterAccountWasLinked:\r\n \"La cuenta de seguidor '{{InvestorAccountName}}' comenzó a copiar la cuenta de proveedor.\",\r\n MasterAccountWasOpened:\r\n 'Se creó la cuenta maestra. (Reparto de beneficios={{ProfitSharing}}, Método de asignación={{AllocationMethod}})',\r\n MasterAccountWasUnlinked:\r\n \"La cuenta de seguidor '{{InvestorAccountName}}' dejó de copiar la cuenta de proveedor.\",\r\n },\r\n },\r\n modal: {\r\n error: 'Error',\r\n notification: 'Notificación',\r\n ok: 'OK',\r\n },\r\n operationHistory: {\r\n filterName: 'Buscar',\r\n placeholder: 'Por favor, introduce',\r\n },\r\n pageTitles: {\r\n admin: {\r\n financialIdentity: {\r\n children: {\r\n cards: 'Cards',\r\n },\r\n },\r\n },\r\n },\r\n partnership: {\r\n salesTitle: 'Ventas',\r\n ibInfo: {\r\n detailsTitle: 'Detalles IB',\r\n nextRebatePayment: 'Próximo pago de rebates',\r\n statistics: {\r\n closetTradersReport: {\r\n type: 'Tipo',\r\n },\r\n tradingVolReport: {\r\n subIb: 'Sub-IB',\r\n },\r\n },\r\n },\r\n ibSettings: {\r\n referralLinkError:\r\n '¡Los márgenes son incorrectos! Póngase en contacto con nuestro equipo de soporte para obtener márgenes correctos',\r\n },\r\n salesUserInfo: {\r\n aeCode: 'Código AE',\r\n },\r\n },\r\n profile: {\r\n adult: 'Tengo mas de 18 años',\r\n code: 'Código',\r\n country: 'País',\r\n documentsUploaded: 'Documentos cargados',\r\n isAgreeWithTermsAndConditions: 'Acepto el <0>Acuerdo del cliente0> y la <1>Política de privacidad1>',\r\n pleaseValidateAccountToDeposit:\r\n 'Sus datos personales requieren verificación por parte del equipo de cumplimiento de {{brokerName}}. Antes de proceder al depósito, debe enviar un escaneo de su identificación',\r\n successChangeDescription: '¡Los cambios se han guardado!',\r\n warningMessage: {\r\n profileIsBeingVerified: 'Su perfil está siendo verificado, puede tardar un par de segundos',\r\n },\r\n },\r\n psp: {\r\n accountsFetchFailErr: 'Error al obtener cuentas',\r\n confirmEveryTransaction: 'Confirmando todas las transacciones, los depósitos pueden tardar hasta 24 horas',\r\n deposit: {\r\n depositForm: {\r\n accountNameTitle: 'Nombre de la cuenta',\r\n addressLine2: 'Dirección línea 2',\r\n beneficiaryAccountNumberTitle: 'Número de cuenta del beneficiario',\r\n beneficiaryBankHint: 'Por favor, seleccione el número de cuenta bancaria',\r\n beneficiaryBankNameHint: 'Nombre del banco, p. ej. (Banco registrado estándar)',\r\n cardNameTitle: 'Card Name',\r\n localDepositFileHint: 'Adjunte un documento que confirme el pago si es necesario',\r\n },\r\n depositTitle: 'Depositar Fondos',\r\n notice: 'Los depósitos están disponibles solo para cuentas verificadas',\r\n warnToSubmitPersonalDetails:\r\n 'Para realizar un depósito, envíe sus datos personales. Por favor, asegúrese de que coincidan con los datos de su ID',\r\n },\r\n localAgentTable: {\r\n login: 'Usuario',\r\n },\r\n operationsFetchFailErr: 'Error al obtener operaciones',\r\n operationsTable: {\r\n documentTitle: 'Documento',\r\n operationsTableTitle: 'Operaciones recientes',\r\n paymentSystemTitle: 'Sistema de pago',\r\n },\r\n pluginInfoFetchFailErr: 'No se pudo obtener la información del complemento',\r\n pluginNotFound: 'Complemento no encontrado',\r\n pluginsFetchFailErr: 'No se pudieron obtener los complementos',\r\n preAuthorizedBanking: 'Banca preautorizada',\r\n qrCodeCryptoNotice:\r\n 'El código QR es de un solo uso. No escanee este código en una aplicación cripto más de una vez, de lo contrario, se suspenderá su pago.',\r\n qrCodeCryptoTitle: 'Código QR para la aplicación cripto',\r\n resentOperationsTitle: 'Operaciones recientes',\r\n transfer: {\r\n transactionDetailsTitle: 'Datos de la transacción',\r\n transferForm: {\r\n amountError: 'Se excedió el importe de la transferencia disponible',\r\n currencyTitle: 'Divisa',\r\n },\r\n },\r\n uploadBankStatementWithBankName:\r\n 'Cargar un extracto bancario que contenga el nombre del banco, su nombre completo y el número de cuenta bancaria',\r\n uploadPayslip: 'Cargar el comprobante bancario de su depósito',\r\n uploadYourDocument: 'Confirme su depósito cargando su extracto bancario',\r\n withdrawal: {\r\n notice: 'Las retiradas están disponibles solo para cuentas verificadas',\r\n withdrawalTitle: 'Retirar Fondos',\r\n withdrawalForm: {\r\n bankNameTitle: 'Nombre del banco',\r\n beneficiaryCryptoWalletHint: 'Se enviará un número de billetera con dinero en criptomonedas a',\r\n beneficiaryCryptoWalletTitle: 'Billetera criptográfica del beneficiario',\r\n confirmTitle: 'Confirmar información de la retirada',\r\n },\r\n },\r\n },\r\n settings: {\r\n docsForm: {\r\n documentNumberHint: 'Compruebe si el número de identificación es el mismo que en la foto',\r\n documentTypeHint: 'Asegúrese de proporcionar una foto de alta calidad o un escaneo de un documento válido',\r\n uploadedDocumentsTable: {\r\n docNameTitle: 'Nombre del documento',\r\n documentNumber: 'Número del documento',\r\n typeTitle: 'Tipo de Documento',\r\n },\r\n },\r\n profileForm: {\r\n editProfileTitle: 'Editar perfil',\r\n proceedToDeposit: 'Proceder al depósito',\r\n saveUserSuccessMessage: 'El perfil se guardó con éxito',\r\n userDetailsErrorMessage: 'No se pudo obtener el perfil de usuario',\r\n verifyPersonalDetails: 'Verificar datos personales',\r\n verifyProfileBtn: 'Verificar perfil',\r\n },\r\n },\r\n socialTradingModal: {\r\n copyHint: 'Su cuenta {{account}} dejará de copiar al proveedor {{oldMaster}} y empezará a copiar a {{newMaster}}',\r\n },\r\n tradingAccounts: {\r\n accountDetailsTitle: 'Cuenta de trading',\r\n accountHistoryForm: {\r\n closeTimeTitle: 'Hora de cierre',\r\n },\r\n changeTradingAccountName: 'Cambiar el nombre de la cuenta de trading',\r\n connectedAccounts: 'Cuentas conectadas',\r\n currency: 'Divisa',\r\n depositForm: {\r\n amountTitle: 'Importe',\r\n errorMessage: 'Error al depositar fondos',\r\n successMessage: 'El depósito se realizó con éxito',\r\n },\r\n descriptionPlaceholder: 'Introduzca una recomendación para sus seguidores',\r\n fetchServersErr: 'No se pudieron obtener los servidores',\r\n ibCode: 'IB (opcional)',\r\n notRows: 'No hay filas que mostrar',\r\n openAccountModalSubTitle:\r\n 'La más amplia variedad de instrumentos de trading: divisas, metales. Condiciones operativas estándar.',\r\n tradingPlatforms: 'Plataformas de trading',\r\n transferForm: {\r\n title: 'Transferir fondos',\r\n },\r\n withdrawForm: {\r\n amountTitle: 'Importe',\r\n errorMessage: 'No se pudo guardar el apalancamiento',\r\n successMessage: 'La retirada se realizó con éxito',\r\n },\r\n },\r\n} satisfies ILocaleLegacy;\r\n","import { ILocaleLegacy } from '@locales/interfaces';\r\n\r\n/**\r\n * @deprecated\r\n * @todo\r\n * These are legacy translations. Some of them are used silently (come from BE), while others are outdated.\r\n * Please remove keys if you are 100% sure that they are not used in the project anymore.\r\n */\r\nexport const id = {\r\n IBCorporate: 'IB Perusahaan',\r\n IBIndividual: 'IB Individu',\r\n MAMIndividual: 'MAM Individu',\r\n MAMMasterWithLPOA: 'MAM Individu',\r\n MarkupConfirmation: 'Konfirmasi Kenaikan Harga',\r\n UserCorporate: 'User Corporate',\r\n UserIndividual: 'User Individual',\r\n UserJoint: 'User Joint',\r\n account: {\r\n bankingDetails: 'Rincian Perbankan',\r\n createANewAccount: 'Buat Akun Baru',\r\n register: 'Daftar',\r\n registerSignInTitle: 'Sudah menjadi Anggota?',\r\n },\r\n admin: {\r\n user: {\r\n fields: {\r\n isMam: 'Is MAM',\r\n isSales: 'Is Sales User',\r\n },\r\n },\r\n tabs: {\r\n tradingSettings: {\r\n tradingAccountSettings: 'Trading Account Settings',\r\n setIBCode: 'Set IB Code',\r\n },\r\n },\r\n reports: {\r\n ftdUtmReport: {\r\n headerTitle: 'FTD_UTM Report',\r\n menuTitle: 'FTD_UTM Report',\r\n },\r\n },\r\n },\r\n adminSocialTrading: {\r\n title: 'Perdagangan Sosial',\r\n investorAccountDetails: {\r\n tradingAccountName: 'Nama Akun Perdagangan',\r\n balance: 'Saldo',\r\n login: 'Log Masuk',\r\n },\r\n masterAccountDetails: {\r\n copyType: 'Jenis Salinan',\r\n groupMappingType: 'Group Mapping Type',\r\n login: 'Log Masuk',\r\n },\r\n },\r\n backgroundJobs: {\r\n recurring: {\r\n title: 'Recurring Jobs',\r\n },\r\n },\r\n bonuses: {\r\n collectBirthdayGift: 'Dapatkan hadiah ulang tahun Anda',\r\n availableTable: {\r\n bonusSize: 'Ukuran Bonus',\r\n },\r\n },\r\n errors: {\r\n shared: {\r\n recordWasNotFound: 'Rekaman tidak dapat ditemukan',\r\n },\r\n captcha: {\r\n captchaServerIsUnavailable:\r\n 'Server Captcha tidak tersedia. Silakan perbarui halaman ini dan coba kembali. Jika masalah tetap terjadi, silakan hubungi dukungan melalui chat online atau email ke {{0}}',\r\n },\r\n files: {\r\n fileWasNotUploaded: 'File was not loaded',\r\n },\r\n mam: {\r\n linkIsInactive: 'Used link is not active',\r\n },\r\n trading: {\r\n profitSharingLimitWasExceeded:\r\n 'Harap diperhatikan, bahwa pembagian hasil keuntungan telah melampaui batas maksimal. Batas maksimalnya adalah {{0}}%.',\r\n notEnoughMoney:\r\n 'Mohon maaf, tetapi Anda tidak memiliki dana yang cukup di akun trading Anda untuk memproses penarikan yang diminta. Harap pastikan Anda memiliki saldo yang mencukupi sebelum mencoba melakukan penarikan. Harap diperhatikan bahwa selain saldo yang tersedia, Anda juga perlu mempertimbangkan tingkat margin bebas yang diperlukan untuk penarikan.',\r\n },\r\n copyTrading: {\r\n equityIsLessOrEqualZero: 'Akun Master tidak memenuhi syarat untuk disalin pada saat ini, silakan coba lagi nanti',\r\n },\r\n securityCode: {\r\n emptyValue: 'Nilai keamanan yang dimasukkan (kata sandi atau kode PIN) tidak boleh kosong atau nol',\r\n invalidLength: 'Nilai keamanan yang dimasukkan (kata sandi atau kode PIN) harus mengandung {{0}} karakter',\r\n invalidMinLength:\r\n 'Nilai keamanan yang dimasukkan (kata sandi atau kode PIN) harus mengandung setidaknya {{0}} karakter',\r\n invalidMaxLength: 'Nilai keamanan yang dimasukkan (kata sandi atau kode PIN) tidak boleh melebihi {{0}} karakter',\r\n manyRepeatedValues:\r\n 'Nilai keamanan yang dimasukkan (kata sandi atau kode PIN) tidak boleh memiliki lebih dari {{0}} karakter yang diulang',\r\n missingNumericValues: 'Nilai keamanan yang dimasukkan (kata sandi atau kode PIN) harus mengandung karakter angka',\r\n containsNumericValues:\r\n 'Nilai keamanan yang dimasukkan (kata sandi atau kode PIN) tidak boleh mengandung nilai angka apa pun',\r\n missingLowerCaseValues:\r\n 'Nilai keamanan yang dimasukkan (kata sandi atau kode PIN) harus mengandung karakter huruf kecil',\r\n containsLowerCaseValues:\r\n 'Nilai keamanan yang dimasukkan (kata sandi atau kode PIN) tidak boleh mengandung nilai huruf kecil apa pun',\r\n missingUpperCaseValues:\r\n 'Nilai keamanan yang dimasukkan (kata sandi atau kode PIN) harus mengandung karakter huruf besar',\r\n containsUpperCaseValues:\r\n 'Nilai keamanan yang dimasukkan (kata sandi atau kode PIN) tidak boleh mengandung nilai huruf besar apa pun',\r\n missingSpecialValues:\r\n 'Nilai keamanan yang dimasukkan (kata sandi atau kode PIN) harus mengandung karakter khusus',\r\n containsSpecialValues:\r\n 'Nilai keamanan yang dimasukkan (kata sandi atau kode PIN) tidak boleh mengandung nilai karakter khusus apa pun',\r\n passwordChangeLimit: 'Password change attempts limit is exceeded. Please wait and try again',\r\n },\r\n user: {\r\n accountHasBeenDisabled: 'Mohon maaf atas ketidaknyamanan ini, tetapi akun {{0}} telah dinonaktifkan',\r\n ageIsAboveMaxAllowed:\r\n 'Kami tidak menerima aplikasi dari siapapun yang berusia dibawah {{0}} tahun ataupun diatas {{1}} tahun',\r\n ageIsUnderMinAllowed: 'Kami tidak menerima aplikasi dari siapapun yang berusia dibawah {{0}} tahun',\r\n cantChangeLanguage: 'Cannot change language',\r\n fieldIsRequired: 'Field {{0}} is required',\r\n ibCodeIsIncorrect: \"Kode IB '{{0}}' salah, silakan masukkan kode IB yang benar\",\r\n invalidCredentials: 'Nama pengguna tidak valid {{0}} dan / atau kata sandi',\r\n invalidLengthOfPhoneNumber: 'Maaf, nomor ponsel {{0}} tidak valid. Silakan masukkan nomor ponsel yang benar',\r\n invalidLink: 'Tautan tidak valid',\r\n invalidPhoneNumberLength: 'Jumlah nomor telepon tidak valid, silakan coba lagi',\r\n onlyLatinCharactersAndDigitsAndSpecialSymbolsCanBeUsed:\r\n 'Only latin characters, digits and special symbols can be used for {{0}} field',\r\n onlyLatinCharactersAndDigitsCanBeUsed: 'Only latin characters and digits can be used for {{0}} field',\r\n onlyLatinCharactersCanBeUsed: 'Only latin characters can be used for {{0}} field',\r\n onlyChineseCharactersCanBeUsed: 'Only chinese characters can be used for {{0}} field',\r\n personalDataNotEntered: 'Personal data are not entered',\r\n userCannotBeRestored:\r\n 'Sorry, the record cannot be restored as the email or phone number of this profile is already in use with another profile, please delete the profile with the same email or phone number to restore this one',\r\n userDoesntExist: 'Pengguna {{0}} tidak ditemukan',\r\n userEmailAlreadyExists: 'Email pengguna telah terdaftar di sistem',\r\n userPhoneAlreadyExists: 'Nomor ponsel pengguna telah terdaftar di sistem',\r\n cantUpdateProfileActualStatus: 'Tidak dapat memperbarui akun {{0}}, status sebenarnya = {{1}}',\r\n },\r\n },\r\n formats: {\r\n formatFloat: '{{value, float}}',\r\n formatMoney: '{{value, money}}',\r\n },\r\n forms: {\r\n dragFile: 'Atau tarik berkas Anda kesini',\r\n exportFormat: 'Format Ekspor',\r\n getCode: 'Dapatkan José',\r\n hide: 'Sembunyikan',\r\n limitMessage: 'Karakter Tersisa {{limit}}',\r\n resend: 'Kirim Ulang',\r\n seconds: 'sec',\r\n show: 'Tampilkan',\r\n },\r\n headerWithBalance: {\r\n serverTime: 'Waktu Server',\r\n failedToFetchServerTime: 'Gagal untuk mendapatkan waktu server',\r\n view: 'Tampilan',\r\n },\r\n investors: {\r\n blackList: 'Daftar Hitam',\r\n },\r\n legal: {\r\n clientAgreement: 'Perjanjian Pelanggan',\r\n privacyPolicy: 'Kebijakan Prbadi',\r\n },\r\n legalTradingPlatform: {\r\n data: 'Data',\r\n },\r\n masterProfile: {\r\n aboutMaster: 'About Master',\r\n infoFields: {\r\n ibCode: 'IB code',\r\n },\r\n },\r\n masters: {\r\n fields: {\r\n masterNickname: 'Nama panggilan Master',\r\n rating: 'Posisi dalam peringkat',\r\n },\r\n },\r\n menu: {\r\n deposit: 'Deposito',\r\n },\r\n messages: {\r\n CopyTrading: {\r\n InvestorAccountWasLinked: \"Akun pengikut mulai menyalin akun Master '{{MasterAccountName}}'.\",\r\n InvestorAccountWasOpened:\r\n \"Akun pengikut telah dibuat. Akun pengikut mulai menyalin akun Master '{{InvestorAccountName}}'.\",\r\n InvestorAccountWasUnlinked: \"Akun pengikut berhenti untuk menyalin akun Master '{{MasterAccountName}}'.\",\r\n MasterAccountWasChanged:\r\n 'Akun master telah diubah. (Bagi hasil = {{ProfitSharing}}, Metode alokasi = {{AllocationMethod}})',\r\n MasterAccountWasLinked: \"Akun pengikut'{{InvestorAccountName}}' mulai menyalin akun Master.\",\r\n MasterAccountWasOpened:\r\n 'Akun master telah dibuat. (Bagi hasil = {{ProfitSharing}}, Metode alokasi = {{AllocationMethod}})',\r\n MasterAccountWasUnlinked: \"Akun pengikut '{{InvestorAccountName}}' berhenti menyalin akun Master.\",\r\n },\r\n },\r\n modal: {\r\n error: 'Kesalahan',\r\n notification: 'Notifikasi',\r\n ok: 'OK',\r\n },\r\n operationHistory: {\r\n filterName: 'Cari',\r\n placeholder: 'Silakan masuk',\r\n },\r\n pageTitles: {\r\n admin: {\r\n financialIdentity: {\r\n children: {\r\n cards: 'Cards',\r\n },\r\n },\r\n },\r\n },\r\n partnership: {\r\n salesTitle: 'Penjualan',\r\n ibInfo: {\r\n detailsTitle: 'Rincian IB',\r\n nextRebatePayment: 'Pembayaran Rabat Selanjutnya',\r\n statistics: {\r\n closetTradersReport: {\r\n type: 'Jenis',\r\n },\r\n tradingVolReport: {\r\n subIb: 'Sub-IB',\r\n },\r\n },\r\n },\r\n ibSettings: {\r\n referralLinkError: 'Nilai salah! Silakan hubungi tim dukungan kami untuk mendapatkan Nilai yang benar',\r\n },\r\n salesUserInfo: {\r\n aeCode: 'Kode AE',\r\n },\r\n },\r\n profile: {\r\n adult: 'Saya diatas 18 tahun',\r\n code: 'Kode',\r\n country: 'Negara',\r\n documentsUploaded: 'Dokumen sudah Terunggah',\r\n isAgreeWithTermsAndConditions: 'Saya terima <0>Syarat dan Ketentuan0> dan <1>Kebijakan Pribadi1>',\r\n pleaseValidateAccountToDeposit:\r\n 'Rincian pribadi Anda perlu diverifikasi oleh tim kepatuhan {{brokerName}}. Sebelum melakukan deposit, Anda perlu menyerahkan salinan ID Anda.',\r\n successChangeDescription: 'Changes are saved!',\r\n warningMessage: {\r\n profileIsBeingVerified: 'Your profile is being verified, it might take a couple of seconds',\r\n },\r\n },\r\n psp: {\r\n accountsFetchFailErr: 'Gagal mendapatkan akun',\r\n confirmEveryTransaction: 'Konfirmasi setiap transaksi, deposit akan membutuhkan waktu sehingga 24 jam',\r\n deposit: {\r\n depositForm: {\r\n accountNameTitle: 'Nama Akun',\r\n addressLine2: 'Address Line 2',\r\n beneficiaryAccountNumberTitle: 'Nomor Rekening Penerima',\r\n beneficiaryBankHint: 'Silakan pilih nomor rekening bank',\r\n beneficiaryBankNameHint: 'Nama Bank, mis. (Standard Charted Bank)',\r\n cardNameTitle: 'Card Name',\r\n localDepositFileHint: 'Mohon lampirkan dokumen konfirmasi pembayaran jika diperlukan',\r\n },\r\n depositTitle: 'Dana Deposito',\r\n notice: 'Catatan! Penarikan hanya diperbolehkan untuk akun yang terverifikasi',\r\n warnToSubmitPersonalDetails:\r\n 'Untuk melakukan deposit, harap kirimkan data pribadi Anda. Harap pastikan cocok dengan data di ID Anda',\r\n },\r\n localAgentTable: {\r\n login: 'Log Masuk',\r\n },\r\n operationsFetchFailErr: 'Gagal mendapatkan balasan dari operasi',\r\n operationsTable: {\r\n documentTitle: 'Dokumen',\r\n operationsTableTitle: 'Operasi Terbaru',\r\n paymentSystemTitle: 'Sistem Pembayaran',\r\n },\r\n pluginInfoFetchFailErr: 'Gagal mengambil informasi plugin',\r\n pluginNotFound: 'Plugin tidak ditemukan',\r\n pluginsFetchFailErr: 'Gagal mendapatkan plugin',\r\n preAuthorizedBanking: 'Pre-Authorized Banking',\r\n qrCodeCryptoNotice:\r\n 'The QR Code is for one-time only. Do not scan this code in crypto application more than once, otherwise your payment will be suspended.',\r\n qrCodeCryptoTitle: 'QR Code for crypto application',\r\n resentOperationsTitle: 'Operasi Terbaru',\r\n transfer: {\r\n transactionDetailsTitle: 'Rincian Transaksi',\r\n transferForm: {\r\n amountError: 'Jumlah transfer yang tersedia telah melebihi',\r\n currencyTitle: 'Mata Uang',\r\n },\r\n },\r\n uploadBankStatementWithBankName:\r\n 'Unggah Rekening koran atau laporan pernyataan bank yang berisi Nama Bank, Nama Penuh dan Nomor Rekening Bank Anda',\r\n uploadPayslip: 'Upload the bank payslip of your deposit',\r\n uploadYourDocument: 'Please confirm your deposit by uploading your bank statement',\r\n withdrawal: {\r\n notice: 'Penarikan hanya tersedia untuk akun yang Terverifikasi',\r\n withdrawalTitle: 'Penarikan Dana',\r\n withdrawalForm: {\r\n bankNameTitle: 'Nama Bank',\r\n beneficiaryCryptoWalletHint: 'A wallet number with cryptocurrency money will be sent to',\r\n beneficiaryCryptoWalletTitle: 'Beneficiary Crypto Wallet',\r\n confirmTitle: 'Konfirmasikan Informasi Penarikan',\r\n },\r\n },\r\n },\r\n settings: {\r\n docsForm: {\r\n documentNumberHint: 'Silakan periksa apakah nomor identifikasi dokumen sudah sama dengan yang ada di foto',\r\n documentTypeHint: 'Mohon pastikan Anda memberikan gambar dengan kualitas terbaik atau memindai dokumen yang sah',\r\n uploadedDocumentsTable: {\r\n docNameTitle: 'Nama Dokumen',\r\n documentNumber: 'Nomor dokumen',\r\n typeTitle: 'Jenis Dokumen',\r\n },\r\n },\r\n profileForm: {\r\n editProfileTitle: 'Edit Profil',\r\n proceedToDeposit: 'Lanjutkan ke Deposit',\r\n saveUserSuccessMessage: 'Profil telah berhasil disimpan',\r\n userDetailsErrorMessage: 'Gagal mendapatkan profil pengguna',\r\n verifyPersonalDetails: 'Verifikasi Rincian Pribadi',\r\n verifyProfileBtn: 'Verifikasi Profil',\r\n },\r\n },\r\n socialTradingModal: {\r\n copyHint:\r\n 'Akun Anda {{account}} akan berhenti menyalin Master {{oldMaster}} dan akan memulai menyalin Master {{newMaster}}',\r\n },\r\n tradingAccounts: {\r\n accountDetailsTitle: 'Akun Trading',\r\n accountHistoryForm: {\r\n closeTimeTitle: 'Waktu Penutupan',\r\n },\r\n changeTradingAccountName: 'Ubah Nama Akun Perdagangan',\r\n connectedAccounts: 'Akun Terhubung',\r\n currency: 'Mata Uang',\r\n depositForm: {\r\n amountTitle: 'Jumlah',\r\n errorMessage: 'Gagal menyetorkan dana',\r\n successMessage: 'Deposito berhasil dibuat',\r\n },\r\n descriptionPlaceholder: 'Masukkan rekomendasi untuk pengikut Anda',\r\n fetchServersErr: 'Gagal mendapat balasan dari server',\r\n ibCode: 'IB (pilihan)',\r\n notRows: 'Tidak ada baris untuk ditampilkan',\r\n openAccountModalSubTitle: 'Rentang instrumen perdagangan terluas: mata uang, logam. Ketentuan perdagangan standar.',\r\n tradingPlatforms: 'Platform Perdagangan',\r\n transferForm: {\r\n title: 'Transfer Dana',\r\n },\r\n withdrawForm: {\r\n amountTitle: 'Jumlah',\r\n errorMessage: 'Gagal menyimpan Leverage',\r\n successMessage: 'Penarikan telah berhasil dibuat',\r\n },\r\n },\r\n} satisfies ILocaleLegacy;\r\n","import { ILocaleLegacy } from '@locales/interfaces';\r\n\r\n/**\r\n * @deprecated\r\n * @todo\r\n * These are legacy translations. Some of them are used silently (come from BE), while others are outdated.\r\n * Please remove keys if you are 100% sure that they are not used in the project anymore.\r\n */\r\nexport const ms = {\r\n IBCorporate: 'IB Korporat',\r\n IBIndividual: 'IB Individu',\r\n MAMIndividual: 'MAM Individu',\r\n MAMMasterWithLPOA: 'MAM Individu',\r\n MarkupConfirmation: 'Pengesahan Markup',\r\n UserCorporate: 'User Corporate',\r\n UserIndividual: 'User Individual',\r\n UserJoint: 'User Joint',\r\n account: {\r\n bankingDetails: 'Butiran Perbankan',\r\n createANewAccount: 'Buka akaun baru',\r\n register: 'Daftar',\r\n registerSignInTitle: 'Sudah mendaftar?',\r\n },\r\n admin: {\r\n user: {\r\n fields: {\r\n isMam: 'Is MAM',\r\n isSales: 'Is Sales User',\r\n },\r\n },\r\n tabs: {\r\n tradingSettings: {\r\n tradingAccountSettings: 'Trading Account Settings',\r\n setIBCode: 'Set IB Code',\r\n },\r\n },\r\n reports: {\r\n ftdUtmReport: {\r\n headerTitle: 'FTD_UTM Report',\r\n menuTitle: 'FTD_UTM Report',\r\n },\r\n },\r\n },\r\n adminSocialTrading: {\r\n title: 'Perdagangan Sosial',\r\n investorAccountDetails: {\r\n tradingAccountName: 'Nama akaun dagangan',\r\n balance: 'Baki',\r\n login: 'Log Masuk',\r\n },\r\n masterAccountDetails: {\r\n copyType: 'Jenis Salinan',\r\n groupMappingType: 'Group Mapping Type',\r\n login: 'Log Masuk',\r\n },\r\n },\r\n backgroundJobs: {\r\n recurring: {\r\n title: 'Recurring Jobs',\r\n },\r\n },\r\n bonuses: {\r\n collectBirthdayGift: 'Dapatkan hadiah hari jadi anda',\r\n availableTable: {\r\n bonusSize: 'Saiz Bonus',\r\n },\r\n },\r\n errors: {\r\n shared: {\r\n recordWasNotFound: 'Rekod tidak dijumpai',\r\n },\r\n captcha: {\r\n captchaServerIsUnavailable:\r\n 'Server Captcha tidak tersedia. Sila muat semula halaman dan cuba lagi. Sekiranya masalah masih berlaku, hubungi khidmat sokongan melalui live chat atau melalui e-mel {{0}}',\r\n },\r\n files: {\r\n fileWasNotUploaded: 'File was not loaded',\r\n },\r\n mam: {\r\n linkIsInactive: 'Used link is not active',\r\n },\r\n trading: {\r\n profitSharingLimitWasExceeded:\r\n 'Sila ambil perhatian, bahawa had maksimum untuk perkongsian keuntungan telah melebihi. Had maksimum ialah {{0}}%.',\r\n notEnoughMoney:\r\n 'Maaf, tetapi anda tidak mempunyai cukup dana dalam akaun dagangan anda untuk memproses pengeluaran yang diminta. Sila pastikan anda mempunyai baki yang mencukupi sebelum mencuba pengeluaran. Sila ambil perhatian bahawa selain daripada baki yang ada, anda juga perlu mengambil kira tahap margin percuma yang diperlukan untuk pengeluaran.',\r\n },\r\n copyTrading: {\r\n equityIsLessOrEqualZero: 'Akaun Master tidak layak untuk disalin pada masa ini, sila cuba sebentar lagi',\r\n },\r\n securityCode: {\r\n emptyValue: 'Nilai keselamatan yang dimasukkan (kata laluan atau kod PIN) tidak boleh kosong atau nol',\r\n invalidLength: 'Nilai keselamatan yang dimasukkan (kata laluan atau kod PIN) mesti mengandungi {{0}} aksara',\r\n invalidMinLength:\r\n 'Nilai keselamatan yang dimasukkan (kata laluan atau kod PIN) mesti mengandungi sekurang-kurangnya {{0}} aksara',\r\n invalidMaxLength:\r\n 'Nilai keselamatan yang dimasukkan (kata laluan atau kod PIN) tidak boleh melebihi {{0}} aksara',\r\n manyRepeatedValues:\r\n 'Nilai keselamatan yang dimasukkan (kata laluan atau kod PIN) tidak boleh mempunyai lebih daripada {{0}} aksara berulang',\r\n missingNumericValues:\r\n 'Nilai keselamatan yang dimasukkan (kata laluan atau kod PIN) mesti mengandungi aksara nombor',\r\n containsNumericValues:\r\n 'Nilai keselamatan yang dimasukkan (kata laluan atau kod PIN) tidak boleh mengandungi sebarang nilai nombor',\r\n missingLowerCaseValues:\r\n 'Nilai keselamatan yang dimasukkan (kata laluan atau kod PIN) mesti mengandungi aksara kecil',\r\n containsLowerCaseValues:\r\n 'Nilai keselamatan yang dimasukkan (kata laluan atau kod PIN) tidak boleh mengandungi sebarang nilai aksara kecil',\r\n missingUpperCaseValues:\r\n 'Nilai keselamatan yang dimasukkan (kata laluan atau kod PIN) mesti mengandungi aksara besar',\r\n containsUpperCaseValues:\r\n 'Nilai keselamatan yang dimasukkan (kata laluan atau kod PIN) tidak boleh mengandungi sebarang nilai aksara besar',\r\n missingSpecialValues:\r\n 'Nilai keselamatan yang dimasukkan (kata laluan atau kod PIN) mesti mengandungi aksara khas',\r\n containsSpecialValues:\r\n 'Nilai keselamatan yang dimasukkan (kata laluan atau kod PIN) tidak boleh mengandungi sebarang nilai aksara khas',\r\n passwordChangeLimit: 'Password change attempts limit is exceeded. Please wait and try again',\r\n },\r\n user: {\r\n accountHasBeenDisabled: 'Maaf atas kesulitan, akaun {{0}} telah dinyahaktif',\r\n ageIsAboveMaxAllowed: 'Kami tidak menerima pemohon yang berumur di bawah {{0}} tahun dan di atas {{1}} tahun.',\r\n ageIsUnderMinAllowed: 'Kami tidak menerima pemohon yang berumur di bawah {{0}} tahun.',\r\n cantChangeLanguage: 'Cannot change language',\r\n fieldIsRequired: 'Medan {{0}} diperlukan',\r\n ibCodeIsIncorrect: \"Kod IB '{{0}}' salah. Sila masukkan kod IB yang betul\",\r\n invalidCredentials: 'Nama pengguna {{0}} dan/atau kata laluan tidak sah',\r\n invalidLengthOfPhoneNumber: 'Bilangan nombor telefon tidak sah, sila cuba lagi',\r\n invalidLink: 'Pautan tidak sah',\r\n invalidPhoneNumberLength: 'Bilangan nombor telefon tidak sah, sila cuba lagi',\r\n onlyLatinCharactersAndDigitsAndSpecialSymbolsCanBeUsed:\r\n 'Only latin characters, digits and special symbols can be used for {0} field',\r\n onlyLatinCharactersAndDigitsCanBeUsed: 'Kami tidak menerima pemohon yang berumur di bawah {{0}} tahun.',\r\n onlyLatinCharactersCanBeUsed: 'Hanya aksara latin boleh digunakan untuk medan {{0}}.',\r\n onlyChineseCharactersCanBeUsed: 'Only chinese characters can be used for {{0}} field',\r\n personalDataNotEntered: 'Personal data are not entered',\r\n userCannotBeRestored:\r\n 'Sorry, the record cannot be restored as the email or phone number of this profile is already in use with another profile, please delete the profile with the same email or phone number to restore this one',\r\n userDoesntExist: 'Pengguna {{0}} tidak wujud',\r\n userEmailAlreadyExists: 'Emel telah berdaftar di dalam sistem',\r\n userPhoneAlreadyExists: 'Telefon pengguna telah berdaftar di dalam sistem',\r\n cantUpdateProfileActualStatus: 'Kemas kini akaun gagal {{0}}, status = {{1}}',\r\n },\r\n },\r\n formats: {\r\n formatFloat: '{{value, float}}',\r\n formatMoney: '{{value, money}}',\r\n },\r\n forms: {\r\n dragFile: 'atau tarik fail ke sini',\r\n exportFormat: 'Format Eksport',\r\n getCode: 'Dapatkan kod',\r\n hide: 'Sembunyi',\r\n limitMessage: '{{limit}} karakter lagi',\r\n resend: 'Hantar semula',\r\n seconds: 'sec',\r\n show: 'Tunjuk',\r\n },\r\n headerWithBalance: {\r\n serverTime: 'Waktu Pelayan',\r\n failedToFetchServerTime: 'Gagal mendapatkan waktu pelayan',\r\n view: 'Paparan',\r\n },\r\n investors: {\r\n blackList: 'Senarai Hitam',\r\n },\r\n legal: {\r\n clientAgreement: 'Perjanjian Pelanggan',\r\n privacyPolicy: 'Dasar Privasi',\r\n },\r\n legalTradingPlatform: {\r\n data: 'Data',\r\n },\r\n masterProfile: {\r\n aboutMaster: 'About Master',\r\n infoFields: {\r\n ibCode: 'IB code',\r\n },\r\n },\r\n masters: {\r\n fields: {\r\n masterNickname: 'Nama panggilan Master',\r\n rating: 'Kedudukan dalam senarai',\r\n },\r\n },\r\n menu: {\r\n deposit: 'Deposit',\r\n },\r\n messages: {\r\n CopyTrading: {\r\n InvestorAccountWasLinked: \"Akaun pengikut mula menyalin akaun Master '{{MasterAccountName}}'.\",\r\n InvestorAccountWasOpened:\r\n \"Akaun pengikut telah dibuat. Akaun pengikut mula menyalin akaun Master '{{InvestorAccountName}}'.\",\r\n InvestorAccountWasUnlinked: \"Akaun pengikut berhenti untuk menyalin akaun Master '{{MasterAccountName}}'.\",\r\n MasterAccountWasChanged:\r\n 'Akaun master telah diubah suai. (Perkongsian keuntungan={{ProfitSharing}}, Kaedah Peruntukan={{AllocationMethod}})',\r\n MasterAccountWasLinked: \"Akaun pengikut '{{InvestorAccountName}}' mula menyalin akaun Master.\",\r\n MasterAccountWasOpened:\r\n 'Akaun master telah dibuat. (Perkongsian keuntungan={{ProfitSharing}}, Kaedah Peruntukan={{AllocationMethod}})',\r\n MasterAccountWasUnlinked: \"Akaun pengikut '{{InvestorAccountName}}' berhenti untuk menyalin akaun Master.\",\r\n },\r\n },\r\n modal: {\r\n error: 'Ralat',\r\n notification: 'Notification',\r\n ok: 'Ok',\r\n },\r\n operationHistory: {\r\n filterName: 'Cari',\r\n placeholder: 'Sila masukkan',\r\n },\r\n pageTitles: {\r\n admin: {\r\n financialIdentity: {\r\n children: {\r\n cards: 'Cards',\r\n },\r\n },\r\n },\r\n },\r\n partnership: {\r\n salesTitle: 'Jualan',\r\n ibInfo: {\r\n detailsTitle: 'Butiran IB',\r\n nextRebatePayment: 'Bayaran Rebat Seterusnya',\r\n statistics: {\r\n closetTradersReport: {\r\n type: 'Jenis',\r\n },\r\n tradingVolReport: {\r\n subIb: 'Sub-IB',\r\n },\r\n },\r\n },\r\n ibSettings: {\r\n referralLinkError: 'Penanda tidak betul! Sila hubungi pasukan sokongan kami untuk mendapatkan penanda yang betul',\r\n },\r\n salesUserInfo: {\r\n aeCode: 'Kod AE',\r\n },\r\n },\r\n profile: {\r\n adult: 'Saya berumur lebih 18 tahun',\r\n code: 'Kod',\r\n country: 'Negara',\r\n documentsUploaded: 'Dokumen Yang Dimuat Naik',\r\n isAgreeWithTermsAndConditions: 'Saya bersetuju dengan <0>Terma dan Syarat0> dan <1>Dasar Privasi1>',\r\n pleaseValidateAccountToDeposit:\r\n 'Butiran peribadi anda perlu disahkan oleh pasukan pematuhan {{brokerName}}. Sebelum melakukan deposit, anda perlu menghantar satu salinan ID anda',\r\n successChangeDescription: 'Changes are saved!',\r\n warningMessage: {\r\n profileIsBeingVerified: 'Your profile is being verified, it might take a couple of seconds',\r\n },\r\n },\r\n psp: {\r\n accountsFetchFailErr: 'Gagal mendapatkan akaun',\r\n confirmEveryTransaction: 'Sahkan setiap transaksi, deposit boleh mengambil masa sehingga 24 jam',\r\n deposit: {\r\n depositForm: {\r\n accountNameTitle: 'Nama Akaun',\r\n addressLine2: 'Address Line 2',\r\n beneficiaryAccountNumberTitle: 'Nombor Akaun Bank',\r\n beneficiaryBankHint: 'Sila pilih nombor akaun bank',\r\n beneficiaryBankNameHint: 'Nama Bank, Cth. (Standard Charted Bank)',\r\n cardNameTitle: 'Card Name',\r\n localDepositFileHint: 'Sila sertakan dokumen pengesahan bayaran',\r\n },\r\n depositTitle: 'Deposit Dana',\r\n notice: 'Makluman! Pengeluaran hanya untuk akaun yang telah disahkan',\r\n warnToSubmitPersonalDetails:\r\n 'Untuk melakukan deposit, sila hantar butiran peribadi anda. Pastikan data tersebut sesuai dengan data dalam ID anda',\r\n },\r\n localAgentTable: {\r\n login: 'Log Masuk',\r\n },\r\n operationsFetchFailErr: 'Gagal mendapatkan operasi',\r\n operationsTable: {\r\n documentTitle: 'Dokumen',\r\n operationsTableTitle: 'Operasi Terkini',\r\n paymentSystemTitle: 'Sistem Pembayaran',\r\n },\r\n pluginInfoFetchFailErr: 'Gagal mendapatkan info plugin',\r\n pluginNotFound: 'Plugin tidak dijumpai',\r\n pluginsFetchFailErr: 'Gagal mendapatkan plugin',\r\n preAuthorizedBanking: 'Pre-Authorized Banking',\r\n qrCodeCryptoNotice:\r\n 'The QR Code is for one-time only. Do not scan this code in crypto application more than once, otherwise your payment will be suspended.',\r\n qrCodeCryptoTitle: 'QR Code for crypto application',\r\n resentOperationsTitle: 'Operasi Terkini',\r\n transfer: {\r\n transactionDetailsTitle: 'Butiran transaksi',\r\n transferForm: {\r\n amountError: 'Lebih dari jumlah yang boleh dipindahkan',\r\n currencyTitle: 'Mata wang',\r\n },\r\n },\r\n uploadBankStatementWithBankName:\r\n 'Muat naik penyata bank yang mengandungi Nama Bank, Nama Penuh dan Nombor Akaun Bank Anda',\r\n uploadPayslip: 'Upload the bank payslip of your deposit',\r\n uploadYourDocument: 'Please confirm your deposit by uploading your bank statement',\r\n withdrawal: {\r\n notice: 'Pengeluaran disediakan untuk akaun yang disahkan sahaja',\r\n withdrawalTitle: 'Pengeluaran Dana',\r\n withdrawalForm: {\r\n bankNameTitle: 'Nama Bank',\r\n beneficiaryCryptoWalletHint: 'A wallet number with cryptocurrency money will be sent to',\r\n beneficiaryCryptoWalletTitle: 'Beneficiary Crypto Wallet',\r\n confirmTitle: 'Sahkan Maklumat Pengeluaran',\r\n },\r\n },\r\n },\r\n settings: {\r\n docsForm: {\r\n documentNumberHint: 'Semak jika nombor pengenalan sama seperti dalam gambar',\r\n documentTypeHint:\r\n 'Sila pastikan anda menghantar satu salinan imbas atau gambar dokumen sah yang berkualiti tinggi',\r\n uploadedDocumentsTable: {\r\n docNameTitle: 'Nama Dokumen',\r\n documentNumber: 'Nombor Dokumen',\r\n typeTitle: 'Jenis Dokumen',\r\n },\r\n },\r\n profileForm: {\r\n editProfileTitle: 'Ubah profil',\r\n proceedToDeposit: 'Terus ke Deposit',\r\n saveUserSuccessMessage: 'Profil berjaya disimpan',\r\n userDetailsErrorMessage: 'Gagal mendapatkan profil pengguna',\r\n verifyPersonalDetails: 'Pengesahan maklumat peribadi',\r\n verifyProfileBtn: 'Sahkan Profil',\r\n },\r\n },\r\n socialTradingModal: {\r\n copyHint:\r\n 'Akaun {{account}} anda akan berhenti menyalin Master {{oldMaster}} dan akan mula menyalin Master {{newMaster}}',\r\n },\r\n tradingAccounts: {\r\n accountDetailsTitle: 'Akaun Dagangan',\r\n accountHistoryForm: {\r\n closeTimeTitle: 'Waktu Tutup',\r\n },\r\n changeTradingAccountName: 'Tukar nama akaun dagangan',\r\n connectedAccounts: 'Akaun Disambungkan',\r\n currency: 'Mata Wang',\r\n depositForm: {\r\n amountTitle: 'Jumlah',\r\n errorMessage: 'Deposit tidak berjaya',\r\n successMessage: 'Deposit berjaya dilakukan',\r\n },\r\n descriptionPlaceholder: 'Masukkan pengesyoran untuk pengikut anda',\r\n fetchServersErr: 'Gagal mendapatkan pelayan',\r\n ibCode: 'IB (tidak wajib)',\r\n notRows: 'Tiada baris untuk dipaparkan',\r\n openAccountModalSubTitle: 'Instrumen dagangan yang pelbagai: mata wang, logam. Terma dagangan standard.',\r\n tradingPlatforms: 'Platform Dagangan',\r\n transferForm: {\r\n title: 'Pindah Dana',\r\n },\r\n withdrawForm: {\r\n amountTitle: 'Jumlah',\r\n errorMessage: 'Gagal menyimpan leveraj',\r\n successMessage: 'Pengeluaran berjaya dilakukan',\r\n },\r\n },\r\n} satisfies ILocaleLegacy;\r\n","import { ILocaleLegacy } from '@locales/interfaces';\r\n\r\n/**\r\n * @deprecated\r\n * @todo\r\n * These are legacy translations. Some of them are used silently (come from BE), while others are outdated.\r\n * Please remove keys if you are 100% sure that they are not used in the project anymore.\r\n */\r\nexport const pt = {\r\n IBCorporate: 'IB corporativo',\r\n IBIndividual: 'IB Individual',\r\n MAMIndividual: 'MAM individual',\r\n MAMMasterWithLPOA: 'MAM individual',\r\n MarkupConfirmation: 'Confirmação de margem',\r\n UserCorporate: 'Usuário corporativo',\r\n UserIndividual: 'Usuário individual',\r\n UserJoint: 'Usuário conjunto',\r\n account: {\r\n bankingDetails: 'Dados bancários',\r\n createANewAccount: 'Criar uma nova conta',\r\n register: 'Registro',\r\n registerSignInTitle: 'Já é usuário?',\r\n },\r\n admin: {\r\n user: {\r\n fields: {\r\n isMam: 'É MAM',\r\n isSales: 'Você é um usuário de vendas',\r\n },\r\n },\r\n tabs: {\r\n tradingSettings: {\r\n tradingAccountSettings: 'Configurações da conta de negociação',\r\n setIBCode: 'Conjunto de códigos IB',\r\n },\r\n },\r\n reports: {\r\n ftdUtmReport: {\r\n headerTitle: 'Relatório FTD_UTM',\r\n menuTitle: 'Relatório FTD_UTM',\r\n },\r\n },\r\n },\r\n adminSocialTrading: {\r\n title: 'Perdagangan Social',\r\n investorAccountDetails: {\r\n tradingAccountName: 'Nome da conta de negociação',\r\n balance: 'Saldo',\r\n login: 'Acesso',\r\n },\r\n masterAccountDetails: {\r\n copyType: 'Tipo de cópia',\r\n groupMappingType: 'Tipo de mapeamento de grupo',\r\n login: 'Acesso',\r\n },\r\n },\r\n backgroundJobs: {\r\n recurring: {\r\n title: 'Empregos recorrentes',\r\n },\r\n },\r\n bonuses: {\r\n collectBirthdayGift: 'Recolha seu presente de aniversário',\r\n availableTable: {\r\n bonusSize: 'Tamanho do bônus',\r\n },\r\n },\r\n errors: {\r\n shared: {\r\n recordWasNotFound: 'Não se encontra na página',\r\n },\r\n captcha: {\r\n captchaServerIsUnavailable:\r\n 'O servidor Captcha não está disponível. Atualize a página e volte a tentar. Se o problema persistir, entre em contato com suporte por chat on-line ou por e-mail para {{clientSupportEmail}}',\r\n },\r\n files: {\r\n fileWasNotUploaded: 'O arquivo não foi carregado',\r\n },\r\n mam: {\r\n linkIsInactive: 'O link usado não está ativo',\r\n },\r\n trading: {\r\n profitSharingLimitWasExceeded:\r\n 'Observe que o limite máximo de participação nos lucros foi excedido. O limite máximo é {{maxLimit}}%.',\r\n notEnoughMoney:\r\n 'Pedimos desculpa, mas não tem fundos suficientes na sua conta de negociação para processar o saque solicitado. Certifique-se de ter saldo suficiente disponível antes de tentar um saque. Observe que, além do saldo disponível, você também deve considerar o nível de margem livre necessário para saques.',\r\n },\r\n copyTrading: {\r\n equityIsLessOrEqualZero:\r\n 'A conta Master não está qualificada para ser copiada neste momento. Tente novamente mais tarde.',\r\n },\r\n securityCode: {\r\n emptyValue: 'O valor de segurança inserido (senha ou código PIN) não pode estar vazio ou nulo',\r\n invalidLength: 'O valor de segurança inserido (senha ou código PIN) deve conter {{0}} caractere(s)',\r\n invalidMinLength: 'O valor de segurança inserido (senha ou código PIN) deve conter pelo menos {{0}} caractere(s)',\r\n invalidMaxLength: 'O valor de segurança inserido (senha ou código PIN) não deve exceder {{0}} caractere(s)',\r\n manyRepeatedValues:\r\n 'O valor de segurança inserido (senha ou código PIN) não deve ter mais de {{0}} caracteres repetidos',\r\n missingNumericValues: 'O valor de segurança inserido (senha ou código PIN) deve conter caracteres numéricos',\r\n containsNumericValues:\r\n 'O valor de segurança inserido (senha ou código PIN) não deve conter nenhum valor numérico',\r\n missingLowerCaseValues: 'O valor de segurança inserido (senha ou código PIN) deve conter caracteres minúsculos',\r\n containsLowerCaseValues: 'O valor de segurança inserido (senha ou código PIN) não deve conter valores minúsculos',\r\n missingUpperCaseValues: 'O valor de segurança inserido (senha ou código PIN) deve conter caracteres maiúsculos',\r\n containsUpperCaseValues: 'O valor de segurança inserido (senha ou código PIN) não deve conter valores maiúsculos',\r\n missingSpecialValues: 'O valor de segurança inserido (senha ou código PIN) deve conter caracteres especiais',\r\n containsSpecialValues: 'O valor de segurança inserido (senha ou código PIN) não deve conter caracteres especiais',\r\n passwordChangeLimit: 'O limite de tentativas de alteração de senha foi excedido. Aguarde e tente novamente',\r\n },\r\n user: {\r\n accountHasBeenDisabled: 'Desculpe pelo transtorno, mas a conta {{0}} foi desativada',\r\n ageIsAboveMaxAllowed: 'Não aceitamos inscrições de menores de {{0}} ou maiores de {{1}} anos.',\r\n ageIsUnderMinAllowed: 'Não aceitamos inscrições de menores de {{0}} anos.',\r\n cantChangeLanguage: 'Não é possível alterar o idioma',\r\n fieldIsRequired: 'O campo {{0}} é obrigatório',\r\n ibCodeIsIncorrect: \"O código IB '{{0}}' está incorreto. Por favor insira um código IB válido\",\r\n invalidCredentials: 'Nome de usuário {{0}} e/ou senha inválidos',\r\n invalidLengthOfPhoneNumber: 'O comprimento do número de telefone é inválido. Tente novamente',\r\n invalidLink: 'O link é inválido',\r\n invalidPhoneNumberLength: 'O comprimento do número de telefone é inválido. Tente novamente',\r\n onlyLatinCharactersAndDigitsAndSpecialSymbolsCanBeUsed:\r\n 'Apenas caracteres latinos, dígitos e símbolos especiais podem ser usados para o campo {{0}}',\r\n onlyLatinCharactersAndDigitsCanBeUsed: 'Somente caracteres latinos e dígitos podem ser usados no campo {{0}}',\r\n onlyLatinCharactersCanBeUsed: 'Apenas caracteres latinos podem ser usados no campo {{0}}',\r\n onlyChineseCharactersCanBeUsed: 'Only chinese characters can be used for {{0}} field',\r\n personalDataNotEntered: 'Dados pessoais não são inseridos',\r\n userCannotBeRestored:\r\n 'Desculpe, o registro não pode ser restaurado porque o e-mail ou número de telefone deste perfil já está em uso com outro perfil. Exclua o perfil com o mesmo e-mail ou número de telefone para restaurar este.',\r\n userDoesntExist: 'O usuário {{0}} não existe',\r\n userEmailAlreadyExists: 'O e-mail do usuário já foi cadastrado no sistema',\r\n userPhoneAlreadyExists: 'O telefone do usuário já foi cadastrado no sistema',\r\n cantUpdateProfileActualStatus: 'Não é possível atualizar a conta {{0}}, estado atual = {{1}}',\r\n },\r\n },\r\n formats: {\r\n formatFloat: '{{value, float}}',\r\n formatMoney: '{{value, money}}',\r\n },\r\n forms: {\r\n dragFile: 'ou arraste aqui seus arquivos',\r\n exportFormat: 'Formato da exportação',\r\n getCode: 'Obter código',\r\n hide: 'oculto',\r\n limitMessage: '{{limit}} caracteres restantes',\r\n resend: 'Reenviar',\r\n seconds: 'segmento',\r\n show: 'Mostrar',\r\n },\r\n headerWithBalance: {\r\n serverTime: 'Hora do servidor',\r\n failedToFetchServerTime: 'Não foi possível obter a hora do servidor',\r\n view: 'Vista',\r\n },\r\n investors: {\r\n blackList: 'Lista negra',\r\n },\r\n legal: {\r\n clientAgreement: 'Contrato do cliente',\r\n privacyPolicy: 'Política de privacidade',\r\n },\r\n legalTradingPlatform: {\r\n data: 'Dados',\r\n },\r\n masterProfile: {\r\n aboutMaster: 'Sobre o fornecedor',\r\n infoFields: {\r\n ibCode: 'Código IB',\r\n },\r\n },\r\n masters: {\r\n fields: {\r\n masterNickname: 'Apelido do fornecedor',\r\n rating: 'Posição de classificação',\r\n },\r\n },\r\n menu: {\r\n deposit: 'Depósito',\r\n },\r\n messages: {\r\n CopyTrading: {\r\n InvestorAccountWasLinked: \"A conta seguidora começou a copiar a conta mestre '{{MasterAccountName}}'.\",\r\n InvestorAccountWasOpened:\r\n \"A conta de seguidor foi criada. A conta seguidora começou a copiar a conta mestre '{{InvestorAccountName}}'.\",\r\n InvestorAccountWasUnlinked: \"A conta do seguidor foi parou de copiar a conta mestre '{{MasterAccountName}}'.\",\r\n MasterAccountWasChanged:\r\n 'A conta mestra foi modificada. (Participação nos lucros={{ProfitSharing}}, Método de alocação={{AllocationMethod}})',\r\n MasterAccountWasLinked: \"A conta do seguidor '{{InvestorAccountName}}' começou a copiar a conta mestre.\",\r\n MasterAccountWasOpened:\r\n 'A conta mestra foi criada. (Participação nos lucros={{ProfitSharing}}, Método de alocação={{AllocationMethod}})',\r\n MasterAccountWasUnlinked: \"A conta do seguidor '{{InvestorAccountName}}' parou de copiar a conta mestre.\",\r\n },\r\n },\r\n modal: {\r\n error: 'Erro',\r\n notification: 'Notificação',\r\n ok: 'OK',\r\n },\r\n operationHistory: {\r\n filterName: 'Procurar',\r\n placeholder: 'Por favor, insira',\r\n },\r\n pageTitles: {\r\n admin: {\r\n financialIdentity: {\r\n children: {\r\n cards: 'cartões',\r\n },\r\n },\r\n },\r\n },\r\n partnership: {\r\n salesTitle: 'Ventas',\r\n ibInfo: {\r\n detailsTitle: 'Detalhes IB',\r\n nextRebatePayment: 'Próximo pagamento de descontos',\r\n statistics: {\r\n closetTradersReport: {\r\n type: 'Tipo',\r\n },\r\n tradingVolReport: {\r\n subIb: 'Sub-IB',\r\n },\r\n },\r\n },\r\n ibSettings: {\r\n referralLinkError:\r\n '¡Los márgenes são incorretos! Entre em contato com nosso equipamento de suporte para obter melhores resultados',\r\n },\r\n salesUserInfo: {\r\n aeCode: 'Código AE',\r\n },\r\n },\r\n profile: {\r\n adult: 'Eu tenho mais de 18 anos',\r\n code: 'Código',\r\n country: 'País',\r\n documentsUploaded: 'Documentos enviados',\r\n isAgreeWithTermsAndConditions: 'Aceito o <0>Contrato do Cliente0> e a <1>Política de Privacidade1>',\r\n pleaseValidateAccountToDeposit:\r\n 'Seus dados pessoais exigem verificação pela equipe de conformidade da {{brokerName}}. Antes de prosseguir com o depósito, você deve enviar uma digitalização do seu documento de identidade',\r\n successChangeDescription: 'As alterações foram salvas!',\r\n warningMessage: {\r\n profileIsBeingVerified: 'Seu perfil está sendo verificado, pode demorar alguns segundos',\r\n },\r\n },\r\n psp: {\r\n accountsFetchFailErr: 'Erro ao obter contas',\r\n confirmEveryTransaction: 'Confirmando todas as transações, os depósitos podem levar até 24 horas',\r\n deposit: {\r\n depositForm: {\r\n accountNameTitle: 'Nome da conta',\r\n addressLine2: 'Endereço da linha 2',\r\n beneficiaryAccountNumberTitle: 'Número da Conta do Beneficiario',\r\n beneficiaryBankHint: 'Selecione o número da conta bancária',\r\n beneficiaryBankNameHint: 'Nome do banco, por ex. por exemplo. (Banco Registrado Padrão)',\r\n cardNameTitle: 'Nome do cartão',\r\n localDepositFileHint: 'Anexe um documento confirmando o pagamento, se necessário',\r\n },\r\n depositTitle: 'Fundos de depósito',\r\n notice: 'Os depósitos estão disponíveis apenas para contas verificadas',\r\n warnToSubmitPersonalDetails:\r\n 'Para fazer um depósito, envie seus dados pessoais. Certifique-se de que eles correspondem aos detalhes do seu ID',\r\n },\r\n localAgentTable: {\r\n login: 'Do utilizador',\r\n },\r\n operationsFetchFailErr: 'Erro ao obter operações',\r\n operationsTable: {\r\n documentTitle: 'Documento',\r\n operationsTableTitle: 'Operações recentes',\r\n paymentSystemTitle: 'Sistema de pagamento',\r\n },\r\n pluginInfoFetchFailErr: 'Não foi possível obter informações do plugin',\r\n pluginNotFound: 'Plug-in não encontrado',\r\n pluginsFetchFailErr: 'Não foi possível obter plug-ins',\r\n preAuthorizedBanking: 'Banco pré-autorizado',\r\n qrCodeCryptoNotice:\r\n 'O código QR é apenas para uso único. Não escaneie este código em um aplicativo criptográfico mais de uma vez, caso contrário seu pagamento será suspenso.',\r\n qrCodeCryptoTitle: 'Código QR para aplicativo de criptografia',\r\n resentOperationsTitle: 'Operações recentes',\r\n transfer: {\r\n transactionDetailsTitle: 'Dados de transação',\r\n transferForm: {\r\n amountError: 'Valor de transferência disponível excedido',\r\n currencyTitle: 'Distintivo',\r\n },\r\n },\r\n uploadBankStatementWithBankName:\r\n 'Faça upload de um extrato bancário contendo o nome do banco, seu nome completo e o número da conta bancária',\r\n uploadPayslip: 'Carregue o recibo bancário do seu depósito',\r\n uploadYourDocument: 'Confirme seu depósito enviando seu extrato bancário',\r\n withdrawal: {\r\n notice: 'Os Saques estão disponíveis apenas para contas verificadas',\r\n withdrawalTitle: 'Sacar fundos',\r\n withdrawalForm: {\r\n bankNameTitle: 'Nome do banco',\r\n beneficiaryCryptoWalletHint: 'Um número de carteira com dinheiro criptomoeda será enviado para',\r\n beneficiaryCryptoWalletTitle: 'Carteira Cripto Beneficiária',\r\n confirmTitle: 'Confirmar informações de Saque',\r\n },\r\n },\r\n },\r\n settings: {\r\n docsForm: {\r\n documentNumberHint: 'Verifique se o número de identificação é igual à foto',\r\n documentTypeHint: 'Certifique-se de fornecer uma foto de alta qualidade ou digitalização de um documento válido',\r\n uploadedDocumentsTable: {\r\n docNameTitle: 'Nome do Documento',\r\n documentNumber: 'Número do documento',\r\n typeTitle: 'Tipo de documento',\r\n },\r\n },\r\n profileForm: {\r\n editProfileTitle: 'Editar Perfil',\r\n proceedToDeposit: 'Prossiga para depositar',\r\n saveUserSuccessMessage: 'O perfil foi salvo com sucesso',\r\n userDetailsErrorMessage: 'Não foi possível obter o perfil do usuário',\r\n verifyPersonalDetails: 'Verifique dados pessoais',\r\n verifyProfileBtn: 'Verifique o perfil',\r\n },\r\n },\r\n socialTradingModal: {\r\n copyHint: 'Sua conta {{account}} irá parar de copiar o provedor {{oldMaster}} e começar a copiar {{newMaster}}',\r\n },\r\n tradingAccounts: {\r\n accountDetailsTitle: 'Conta de negociação',\r\n accountHistoryForm: {\r\n closeTimeTitle: 'Hora de cierre',\r\n },\r\n changeTradingAccountName: 'Alterar o nome da conta de negociação',\r\n connectedAccounts: 'Contas conectadas',\r\n currency: 'Divisa',\r\n depositForm: {\r\n amountTitle: 'Importar',\r\n errorMessage: 'Erro ao depositar fundos',\r\n successMessage: 'O depósito foi realizado com sucesso',\r\n },\r\n descriptionPlaceholder: 'Insira recomendação para seus seguidores',\r\n fetchServersErr: 'Não se poderia obter os servidores',\r\n ibCode: 'IB (opcional)',\r\n notRows: 'Não há filas que mostrem',\r\n openAccountModalSubTitle:\r\n 'A maior variedade de instrumentos de negociação: divisões, metais. Condições operacionais padrão.',\r\n tradingPlatforms: 'Plataformas de negociação',\r\n transferForm: {\r\n title: 'transferir fundos',\r\n },\r\n withdrawForm: {\r\n amountTitle: 'Quantia',\r\n errorMessage: 'Falha ao salvar alavancagem',\r\n successMessage: 'O Saque foi bem-sucedido',\r\n },\r\n },\r\n} satisfies ILocaleLegacy;\r\n","import { ILocaleLegacy } from '@locales/interfaces';\r\n\r\n/**\r\n * @deprecated\r\n * @todo\r\n * These are legacy translations. Some of them are used silently (come from BE), while others are outdated.\r\n * Please remove keys if you are 100% sure that they are not used in the project anymore.\r\n */\r\nexport const ru = {\r\n IBCorporate: 'IB Корпоративный',\r\n IBIndividual: 'IB Индивидульный',\r\n MAMIndividual: 'MAM Individual',\r\n MAMMasterWithLPOA: 'MAM Individual',\r\n MarkupConfirmation: 'Markup Confirmation',\r\n UserCorporate: 'User Corporate',\r\n UserIndividual: 'User Individual',\r\n UserJoint: 'User Joint',\r\n account: {\r\n bankingDetails: 'Banking Details',\r\n createANewAccount: 'Создать новый аккаунт',\r\n register: 'Зарегистрироваться',\r\n registerSignInTitle: 'Уже зарегистрированы?',\r\n },\r\n admin: {\r\n user: {\r\n fields: {\r\n isMam: 'Is MAM',\r\n isSales: 'Is Sales User',\r\n },\r\n },\r\n tabs: {\r\n tradingSettings: {\r\n tradingAccountSettings: 'Trading Account Settings',\r\n setIBCode: 'Set IB Code',\r\n },\r\n },\r\n reports: {\r\n ftdUtmReport: {\r\n headerTitle: 'FTD_UTM Report',\r\n menuTitle: 'FTD_UTM Report',\r\n },\r\n },\r\n },\r\n adminSocialTrading: {\r\n title: 'Social Trading',\r\n investorAccountDetails: {\r\n tradingAccountName: 'Trading Account Name',\r\n balance: 'Balance',\r\n login: 'Login',\r\n },\r\n masterAccountDetails: {\r\n copyType: 'Copy Type',\r\n groupMappingType: 'Group Mapping Type',\r\n login: 'Login',\r\n },\r\n },\r\n backgroundJobs: {\r\n recurring: {\r\n title: 'Recurring Jobs',\r\n },\r\n },\r\n bonuses: {\r\n collectBirthdayGift: 'Collect your Birthday gift',\r\n availableTable: {\r\n bonusSize: 'Bonus Size',\r\n },\r\n },\r\n errors: {\r\n shared: {\r\n recordWasNotFound: 'Record was not found',\r\n },\r\n captcha: {\r\n captchaServerIsUnavailable:\r\n 'Captcha server is unavailable. Please refresh the page and try again. If the problem remains please contact support via online chat or by email {{0}}',\r\n },\r\n files: {\r\n fileWasNotUploaded: 'File was not loaded',\r\n },\r\n mam: {\r\n linkIsInactive: 'Used link is not active',\r\n },\r\n trading: {\r\n profitSharingLimitWasExceeded:\r\n 'Please note, that the max limit for profit sharing has been exceeded. The max limit is {{0}}%.',\r\n notEnoughMoney:\r\n 'We apologize, but you do not have enough funds in your trading account to process the requested withdrawal. Please ensure that you have a sufficient balance available before attempting a withdrawal. Please note that in addition to the available balance, you should also consider the free margin level required for withdrawals.',\r\n },\r\n copyTrading: {\r\n equityIsLessOrEqualZero: 'The Master account is ineligible to be copied at this time, please try again later.',\r\n },\r\n securityCode: {\r\n emptyValue: 'The entered security value (password or PIN code) cannot be empty or null',\r\n invalidLength: 'The entered security value (password or PIN code) must contain {{0}} character(s)',\r\n invalidMinLength: 'The entered security value (password or PIN code) must contain at least {{0}} character(s)',\r\n invalidMaxLength: 'The entered security value (password or PIN code) must not exceed {{0}} character(s)',\r\n manyRepeatedValues:\r\n 'The entered security value (password or PIN code) must not have more than {{0}} repeated character(s)',\r\n missingNumericValues: 'The entered security value (password or PIN code) must contain numeric character(s)',\r\n containsNumericValues: 'The entered security value (password or PIN code) must not contain any numeric values',\r\n missingLowerCaseValues: 'The entered security value (password or PIN code) must contain lowercase character(s)',\r\n containsLowerCaseValues:\r\n 'The entered security value (password or PIN code) must not contain any lowercase values',\r\n missingUpperCaseValues: 'The entered security value (password or PIN code) must contain uppercase character(s)',\r\n containsUpperCaseValues:\r\n 'The entered security value (password or PIN code) must not contain any uppercase values',\r\n missingSpecialValues: 'The entered security value (password or PIN code) must contain special character(s)',\r\n containsSpecialValues:\r\n 'The entered security value (password or PIN code) must not contain any special characters',\r\n passwordChangeLimit: 'Password change attempts limit is exceeded. Please wait and try again',\r\n },\r\n user: {\r\n accountHasBeenDisabled: 'Sorry for the inconvenience, but the account {{0}} has been disabled',\r\n ageIsAboveMaxAllowed: 'We do not accept applications from anyone under {{0}} or over {{1}} years old.',\r\n ageIsUnderMinAllowed: 'We do not accept applications from anyone under {{0}} years old.',\r\n cantChangeLanguage: 'Cannot change language',\r\n fieldIsRequired: 'Field {{0}} is required',\r\n ibCodeIsIncorrect: \"The IB code '{{0}}' is incorrect. Please enter a valid IB code\",\r\n invalidCredentials: 'Invalid username {{0}} and/or password',\r\n invalidLengthOfPhoneNumber: 'The phone number length is invalid, please try again',\r\n invalidLink: 'The link is invalid',\r\n invalidPhoneNumberLength: 'The phone number length is invalid, please try again',\r\n onlyLatinCharactersAndDigitsAndSpecialSymbolsCanBeUsed:\r\n 'Only latin characters, digits and special symbols can be used for {{0}} field',\r\n onlyLatinCharactersAndDigitsCanBeUsed: 'Only latin characters and digits can be used for {{0}} field',\r\n onlyLatinCharactersCanBeUsed: 'Only latin characters can be used for {{0}} field',\r\n onlyChineseCharactersCanBeUsed: 'Only chinese characters can be used for {{0}} field',\r\n personalDataNotEntered: 'Personal data are not entered',\r\n userCannotBeRestored:\r\n 'Sorry, the record cannot be restored as the email or phone number of this profile is already in use with another profile, please delete the profile with the same email or phone number to restore this one',\r\n userDoesntExist: \"User {{0}} doesn't exist\",\r\n userEmailAlreadyExists: 'User email has been already registered in the system',\r\n userPhoneAlreadyExists: 'User phone has been already registered in the system',\r\n cantUpdateProfileActualStatus: \"Can't update account {{0}}, actual status = {{1}}\",\r\n },\r\n },\r\n formats: {\r\n formatFloat: '{{value, float}}',\r\n formatMoney: '{{value, money}}',\r\n },\r\n forms: {\r\n dragFile: 'or drag here your files',\r\n exportFormat: 'Формат экспорта',\r\n getCode: 'Отправить код',\r\n hide: 'Скрыть',\r\n limitMessage: '{{limit}} Characters left',\r\n resend: 'Отправить еще раз',\r\n seconds: 'sec',\r\n show: 'Показать',\r\n },\r\n headerWithBalance: {\r\n serverTime: 'Серверное время',\r\n failedToFetchServerTime: 'Не удалось получить серверное время',\r\n view: 'Просмотреть',\r\n },\r\n investors: {\r\n blackList: 'Black List',\r\n },\r\n legal: {\r\n clientAgreement: 'Client Agreement',\r\n privacyPolicy: 'Privacy Policy',\r\n },\r\n legalTradingPlatform: {\r\n data: 'Data',\r\n },\r\n masterProfile: {\r\n aboutMaster: 'About Master',\r\n infoFields: {\r\n ibCode: 'IB code',\r\n },\r\n },\r\n masters: {\r\n fields: {\r\n masterNickname: 'Master Nickname',\r\n rating: 'Position in Rating',\r\n },\r\n },\r\n menu: {\r\n deposit: 'Депозит',\r\n },\r\n messages: {\r\n CopyTrading: {\r\n InvestorAccountWasLinked: \"Follower account started to copy Master account '{{MasterAccountName}}'.\",\r\n InvestorAccountWasOpened:\r\n \"Follower account was created. Follower account started to copy Master account '{{InvestorAccountName}}'.\",\r\n InvestorAccountWasUnlinked: \"Follower account stopped to copy Master account '{{MasterAccountName}}'.\",\r\n MasterAccountWasChanged:\r\n 'Master account was modified. (Profit sharing={{ProfitSharing}}, Allocation method={{AllocationMethod}})',\r\n MasterAccountWasLinked: \"Follower's account '{{InvestorAccountName}}' started to copy Master account.\",\r\n MasterAccountWasOpened:\r\n 'Master account was created. (Profit sharing={{ProfitSharing}}, Allocation method={{AllocationMethod}})',\r\n MasterAccountWasUnlinked: \"Follower's account '{{InvestorAccountName}}' stopped to copy Master account.\",\r\n },\r\n },\r\n modal: {\r\n error: 'Ошибка',\r\n notification: 'Уведомление',\r\n ok: 'Ok',\r\n },\r\n operationHistory: {\r\n filterName: 'Search',\r\n placeholder: 'Please enter',\r\n },\r\n pageTitles: {\r\n admin: {\r\n financialIdentity: {\r\n children: {\r\n cards: 'Cards',\r\n },\r\n },\r\n },\r\n },\r\n partnership: {\r\n salesTitle: 'Sales',\r\n ibInfo: {\r\n detailsTitle: 'IB Details',\r\n nextRebatePayment: 'Next Rebate Payment',\r\n statistics: {\r\n closetTradersReport: {\r\n type: 'Type',\r\n },\r\n tradingVolReport: {\r\n subIb: 'Sub-IB',\r\n },\r\n },\r\n },\r\n ibSettings: {\r\n referralLinkError: 'Markups are incorrect! Please contact our support team to get correct markups',\r\n },\r\n salesUserInfo: {\r\n aeCode: 'AE Code',\r\n },\r\n },\r\n profile: {\r\n adult: 'Мне есть 18 лет',\r\n code: 'Код',\r\n country: 'Страна',\r\n documentsUploaded: 'Загруженные документы',\r\n isAgreeWithTermsAndConditions: 'I accept the <0>Client Agreement0> and the <1>Privacy Policy1>',\r\n pleaseValidateAccountToDeposit:\r\n 'Your personal details require verification by {{brokerName}} compliance team. Before proceeding to deposits you need to submit a scan of your ID',\r\n successChangeDescription: 'Changes are saved!',\r\n warningMessage: {\r\n profileIsBeingVerified: 'Your profile is being verified, it might take a couple of seconds',\r\n },\r\n },\r\n psp: {\r\n accountsFetchFailErr: 'Не удалось получить аккаунты',\r\n confirmEveryTransaction: 'Confirm every transaction, deposits take up to 24 hours',\r\n deposit: {\r\n depositForm: {\r\n accountNameTitle: 'Account Name',\r\n addressLine2: 'Address Line 2',\r\n beneficiaryAccountNumberTitle: 'Beneficiary Account Number',\r\n beneficiaryBankHint: 'Пожалуйста, выберите банковский аккаунт',\r\n beneficiaryBankNameHint: 'Bank Name, e.g. (Standard Charted Bank)',\r\n cardNameTitle: 'Card Name',\r\n localDepositFileHint: 'Please attach a document confirming payment if need',\r\n },\r\n depositTitle: 'Депонировать средства',\r\n notice: 'Withdrawals are available only for verified accounts',\r\n warnToSubmitPersonalDetails:\r\n 'Чтобы сделать депозит, пожалкйста заполните свои персональные данные. Пожалуйста, убедитесь, что данные совпадают с Вашими документами',\r\n },\r\n localAgentTable: {\r\n login: 'Login',\r\n },\r\n operationsFetchFailErr: 'Не удалось получить операции',\r\n operationsTable: {\r\n documentTitle: 'Document',\r\n operationsTableTitle: 'Недавние операции',\r\n paymentSystemTitle: 'Платежная система',\r\n },\r\n pluginInfoFetchFailErr: 'Не удалось получить информацию о плагине',\r\n pluginNotFound: 'Plugin not found',\r\n pluginsFetchFailErr: 'Не удалось получить плагины',\r\n preAuthorizedBanking: 'Pre-Authorized Banking',\r\n qrCodeCryptoNotice:\r\n 'The QR Code is for one-time only. Do not scan this code in crypto application more than once, otherwise your payment will be suspended.',\r\n qrCodeCryptoTitle: 'QR Code for crypto application',\r\n resentOperationsTitle: 'Недавние операции',\r\n transfer: {\r\n transactionDetailsTitle: 'Подробности транзакции',\r\n transferForm: {\r\n amountError: 'Превышена допустимая сумма перевода',\r\n currencyTitle: 'Валюта',\r\n },\r\n },\r\n uploadBankStatementWithBankName:\r\n 'Upload a bank statement which contains Bank Name, your Full Name and Bank Account Number',\r\n uploadPayslip: 'Upload the bank payslip of your deposit',\r\n uploadYourDocument: 'Please confirm your deposit by uploading your bank statement',\r\n withdrawal: {\r\n notice: 'Withdrawals are available only for verified accounts',\r\n withdrawalTitle: 'Снять средства',\r\n withdrawalForm: {\r\n bankNameTitle: 'Bank Name',\r\n beneficiaryCryptoWalletHint: 'A wallet number with cryptocurrency money will be sent to',\r\n beneficiaryCryptoWalletTitle: 'Beneficiary Crypto Wallet',\r\n confirmTitle: 'Confirm withdraw information',\r\n },\r\n },\r\n },\r\n settings: {\r\n docsForm: {\r\n documentNumberHint: 'Check if Identification number is the same as on the photo',\r\n documentTypeHint:\r\n 'Пожалуйста, убедитесь, что Вы представляете фотографию хорошего качества или скан действующего документа',\r\n uploadedDocumentsTable: {\r\n docNameTitle: 'Имя Документа',\r\n documentNumber: 'Номер Документа',\r\n typeTitle: 'Тип Документа',\r\n },\r\n },\r\n profileForm: {\r\n editProfileTitle: 'Редактировать профиль',\r\n proceedToDeposit: 'Перейти к депозиту',\r\n saveUserSuccessMessage: 'Профиль был успешно сохранен',\r\n userDetailsErrorMessage: 'Не удалось получить профиль пользователя',\r\n verifyPersonalDetails: 'Проверка персональных данных',\r\n verifyProfileBtn: 'Верифицировать Профиль',\r\n },\r\n },\r\n socialTradingModal: {\r\n copyHint: 'Your Account {{account}} will stop to copy Master {{oldMaster}}, and start to copy {{newMaster}}',\r\n },\r\n tradingAccounts: {\r\n accountDetailsTitle: 'Торговый аккаунт',\r\n accountHistoryForm: {\r\n closeTimeTitle: 'Время закрытия',\r\n },\r\n changeTradingAccountName: 'Change trading account name',\r\n connectedAccounts: 'Connected Accounts',\r\n currency: 'Валюта',\r\n depositForm: {\r\n amountTitle: 'Сумма',\r\n errorMessage: 'Не удалось депонировать средства',\r\n successMessage: 'Депозит был сделан успешно',\r\n },\r\n descriptionPlaceholder: 'Enter recommendation for you followers',\r\n fetchServersErr: 'Не удалось получить сервера',\r\n ibCode: 'IB (опционально)',\r\n notRows: 'Нет строк для отображения',\r\n openAccountModalSubTitle: 'The widest range of trading instruments: currencies, metals. Standard trading terms.',\r\n tradingPlatforms: 'Торговые платформы',\r\n transferForm: {\r\n title: 'Transfer Funds',\r\n },\r\n withdrawForm: {\r\n amountTitle: 'Сумма',\r\n errorMessage: 'Не удалось сохранить левередж',\r\n successMessage: 'Снятие средств было успешно выполнено',\r\n },\r\n },\r\n} satisfies ILocaleLegacy;\r\n","import { ILocaleLegacy } from '@locales/interfaces';\r\n\r\n/**\r\n * @deprecated\r\n * @todo\r\n * These are legacy translations. Some of them are used silently (come from BE), while others are outdated.\r\n * Please remove keys if you are 100% sure that they are not used in the project anymore.\r\n */\r\nexport const th = {\r\n IBCorporate: 'สมัคร IB ในนามองค์กร',\r\n IBIndividual: 'สมัคร IB ในนามบุคคล',\r\n MAMIndividual: 'MAM รายบุคคล',\r\n MAMMasterWithLPOA: 'MAM รายบุคคล',\r\n MarkupConfirmation: 'การยืนยัน Markup',\r\n UserCorporate: 'องค์กรผู้ใช้',\r\n UserIndividual: 'ผู้ใช้รายบุคคล',\r\n UserJoint: 'ผู้ใช้ร่วม',\r\n account: {\r\n bankingDetails: 'รายละเอียดธนาคาร',\r\n createANewAccount: 'เปิดบัญชีซื้อขาย',\r\n register: 'ลงทะเบียน',\r\n registerSignInTitle: 'เป็นสมาชิกอยู่แล้ว?',\r\n },\r\n admin: {\r\n user: {\r\n fields: {\r\n isMam: 'Is MAM',\r\n isSales: 'Is Sales User',\r\n },\r\n },\r\n tabs: {\r\n tradingSettings: {\r\n tradingAccountSettings: 'Trading Account Settings',\r\n setIBCode: 'Set IB Code',\r\n },\r\n },\r\n reports: {\r\n ftdUtmReport: {\r\n headerTitle: 'FTD_UTM Report',\r\n menuTitle: 'FTD_UTM Report',\r\n },\r\n },\r\n },\r\n adminSocialTrading: {\r\n title: 'Social Trading',\r\n investorAccountDetails: {\r\n tradingAccountName: 'ชื่อบัญชีซื้อขาย',\r\n balance: 'ยอดคงเหลือ',\r\n login: 'เลขบ้ญชีเทรด',\r\n },\r\n masterAccountDetails: {\r\n copyType: 'ชนิดในการก็อปปี้',\r\n groupMappingType: 'Group Mapping Type',\r\n login: 'เลขบ้ญชีเทรด',\r\n },\r\n },\r\n backgroundJobs: {\r\n recurring: {\r\n title: 'Recurring Jobs',\r\n },\r\n },\r\n bonuses: {\r\n collectBirthdayGift: 'รับของขวัญวันเกิดของคุณ',\r\n availableTable: {\r\n bonusSize: 'ขนาดโบนัส',\r\n },\r\n },\r\n errors: {\r\n shared: {\r\n recordWasNotFound: 'ไม่พบบันทึก',\r\n },\r\n captcha: {\r\n captchaServerIsUnavailable:\r\n 'เซิร์ฟเวอร์ Captcha ไม่สามารถใช้งานได้ในขณะนี้ กรุณารีเฟรชหน้าจอและลองใหม่อีกครั้ง หากยังพบปัญหา กรุณาติดต่อซัพพอร์ททางแชท หรือส่งอีเมลไปที่ {{0}}',\r\n },\r\n files: {\r\n fileWasNotUploaded: 'File was not loaded',\r\n },\r\n mam: {\r\n linkIsInactive: 'Used link is not active',\r\n },\r\n trading: {\r\n profitSharingLimitWasExceeded: 'โปรดทราบว่าเกินลิมิตสูงสุดสำหรับการแบ่งปันผลกำไรแล้ว ลิมิตสูงสุดคือ {{0}}%',\r\n notEnoughMoney:\r\n 'ขออภัย แต่ท่านไม่มีเงินเพียงพอในบัญชีการซื้อขายของท่านเพื่อดำเนินการถอนเงินที่ขอ กรุณาตรวจสอบว่าท่านมีค่าคงเหลือที่เพียงพอก่อนที่จะพยายามดำเนินการถอนเงิน. โปรดทราบว่านอกจากค่าคงเหลือที่มีอยู่แล้ว ท่านยังควรพิจารณาระดับมาร์จิ้นฟรีที่ต้องการสำหรับการถอนเงินด้วย',\r\n },\r\n copyTrading: {\r\n equityIsLessOrEqualZero: 'ไม่สามารถเลือกบัญชีมาสเตอร์เพื่อคัดลอกได้ในขณะนี้ กรุณาลองใหม่อีกครั้งในภายหลัง',\r\n },\r\n securityCode: {\r\n emptyValue: 'ค่าความปลอดภัยที่ป้อนเข้า (รหัสผ่านหรือรหัส PIN) ต้องไม่เป็นค่าว่างหรือค่า null',\r\n invalidLength: 'ค่าความปลอดภัยที่ป้อนเข้า (รหัสผ่านหรือรหัส PIN) ต้องมี {{0}} อักขร',\r\n invalidMinLength: 'ค่าความปลอดภัยที่ป้อนเข้า (รหัสผ่านหรือรหัส PIN) ต้องมีอย่างน้อย {{0}} อักขระ',\r\n invalidMaxLength: 'ค่าความปลอดภัยที่ป้อนเข้า (รหัสผ่านหรือรหัส PIN) ต้องไม่เกิน {{0}} อักขระ',\r\n manyRepeatedValues:\r\n 'ค่าความปลอดภัยที่ป้อนเข้า (รหัสผ่านหรือรหัส PIN) ต้องไม่มีตัวอักษรที่ซ้ำกันมากกว่า {{0}} อักขระ',\r\n missingNumericValues: 'ค่าความปลอดภัยที่ป้อนเข้า (รหัสผ่านหรือรหัส PIN) ต้องมีตัวเลข',\r\n containsNumericValues: 'ค่าความปลอดภัยที่ป้อนเข้า (รหัสผ่านหรือรหัส PIN) ต้องไม่มีค่าตัวเลขใด ๆ',\r\n missingLowerCaseValues: 'ค่าความปลอดภัยที่ป้อนเข้า (รหัสผ่านหรือรหัส PIN) ต้องมีตัวอักษรตัวเล็ก',\r\n containsLowerCaseValues: 'ค่าความปลอดภัยที่ป้อนเข้า (รหัสผ่านหรือรหัส PIN) ต้องไม่มีค่าตัวอักษรตัวเล็กใด ๆ',\r\n missingUpperCaseValues: 'ค่าความปลอดภัยที่ป้อนเข้า (รหัสผ่านหรือรหัส PIN) ต้องมีตัวอักษรตัวใหญ่',\r\n containsUpperCaseValues: 'ค่าความปลอดภัยที่ป้อนเข้า (รหัสผ่านหรือรหัส PIN) ต้องไม่มีค่าตัวอักษรตัวใหญ่ใด ๆ',\r\n missingSpecialValues: 'ค่าความปลอดภัยที่ป้อนเข้า (รหัสผ่านหรือรหัส PIN) ต้องมีตัวอักษรพิเศษ',\r\n containsSpecialValues: 'ค่าความปลอดภัยที่ป้อนเข้า (รหัสผ่านหรือรหัส PIN) ต้องไม่มีตัวอักษรพิเศษใด ๆ',\r\n passwordChangeLimit: 'Password change attempts limit is exceeded. Please wait and try again',\r\n },\r\n user: {\r\n accountHasBeenDisabled: 'ขออภัยในความไม่สะดวกบัญชี {{0}} ถูกปิดใช้งาน',\r\n ageIsAboveMaxAllowed: 'ผู้สมัครต้องมีอายุระหว่าง {{0}}-{{1}} ปีบริบูรณ์',\r\n ageIsUnderMinAllowed: 'We do not accept applications from anyone under {{0}} years old.',\r\n cantChangeLanguage: 'Cannot change language',\r\n fieldIsRequired: 'โปรดกรอกข้อมูลในช่อง {{0}}',\r\n ibCodeIsIncorrect: \"รหัส IB '{{0}}' ไม่ถูกต้อง กรุณากรอกรหัส IB ที่ถูกต้อง\",\r\n invalidCredentials: 'ชื่อผู้ใช้งานไม่ถูกต้อง {{0}} และ/หรือ รหัสผ่าน',\r\n invalidLengthOfPhoneNumber:\r\n 'ขออภัยหมายเลขโทรศัพท์มือถือ {{0}} มีความยาวไม่ถูกต้อง กรุณากรอกหมายเลขโทรศัพท์ที่ถูกต้อง',\r\n invalidLink: 'ลิงก์ไม่ถูกต้อง',\r\n invalidPhoneNumberLength: 'ความยาวของหมายเลขโทรศัพท์ไม่ถูกต้อง โปรดลองอีกครั้ง',\r\n onlyLatinCharactersAndDigitsAndSpecialSymbolsCanBeUsed:\r\n 'Only latin characters, digits and special symbols can be used for {{0}} field',\r\n onlyLatinCharactersAndDigitsCanBeUsed: 'ผู้สมัครต้องมีอายุระหว่าง {{0}} ปีบริบูรณ์',\r\n onlyLatinCharactersCanBeUsed: 'ใช้ได้เฉพาะอักขระภาษาละตินสำหรับช่อง {{0}}',\r\n onlyChineseCharactersCanBeUsed: 'Only chinese characters can be used for {{0}} field',\r\n personalDataNotEntered: 'Personal data are not entered',\r\n userCannotBeRestored:\r\n 'Sorry, the record cannot be restored as the email or phone number of this profile is already in use with another profile, please delete the profile with the same email or phone number to restore this one',\r\n userDoesntExist: 'ไม่พบผู้ใช้งาน {{0}} ',\r\n userEmailAlreadyExists: 'อีเมลของผู้ใช้งานได้รับการลงทะเบียนในระบบแล้ว',\r\n userPhoneAlreadyExists: 'โทรศัพท์ของผู้ใช้งานได้รับการลงทะเบียนในระบบแล้ว',\r\n cantUpdateProfileActualStatus: 'ไม่สามารถอัปเดทบัญชี {{0}}, สถานะจริง = {{1}}',\r\n },\r\n },\r\n formats: {\r\n formatFloat: '{{value, float}}',\r\n formatMoney: '{{value, money}}',\r\n },\r\n forms: {\r\n dragFile: 'หรือดึงไฟล์ของคุณที่นี่',\r\n exportFormat: 'รูปแบบการนำออก',\r\n getCode: 'รับรหัส',\r\n hide: 'ซ่อน',\r\n limitMessage: '{{limit}} ตัวอักษรที่เหลือ',\r\n resend: 'ส่งอีกครั้ง',\r\n seconds: 'sec',\r\n show: 'แสดง',\r\n },\r\n headerWithBalance: {\r\n serverTime: 'เวลาเซิร์ฟเวอร์',\r\n failedToFetchServerTime: 'การดึงข้อมูลเวลาเซิร์ฟเวอร์ล้มเหลว',\r\n view: 'มุมมอง',\r\n },\r\n investors: {\r\n blackList: 'แบล็คลิส',\r\n },\r\n legal: {\r\n clientAgreement: 'ข้อตกลงของลูกค้า',\r\n privacyPolicy: 'นธยบายความเป็นส่วนตัว',\r\n },\r\n legalTradingPlatform: {\r\n data: 'Data',\r\n },\r\n masterProfile: {\r\n aboutMaster: 'เกี่ยวกับ Master',\r\n infoFields: {\r\n ibCode: 'IB code',\r\n },\r\n },\r\n masters: {\r\n fields: {\r\n masterNickname: 'ชื่อเล่น มาสเตอร์',\r\n rating: 'ตำแหน่งในการจัดอันดับ',\r\n },\r\n },\r\n menu: {\r\n deposit: 'ฝากเงิน',\r\n },\r\n messages: {\r\n CopyTrading: {\r\n InvestorAccountWasLinked: \"บัญชีผู้ติดตามเริ่มคัดลอกบัญชีต้นแบบ '{{MasterAccountName}}'\",\r\n InvestorAccountWasOpened:\r\n \"บัญชีผู้ติดตามถูกสร้างขึ้น. บัญชีผู้ติดตามเริ่มคัดลอกบัญชีต้นแบบ '{{InvestorAccountName}}'\",\r\n InvestorAccountWasUnlinked: \"บัญชีผู้ติดตามหยุดเพื่อคัดลอกบัญชีต้นแบบ '{{MasterAccountName}}'\",\r\n MasterAccountWasChanged:\r\n 'บัญชีหลักได้รับการแก้ไข (ส่วนแบ่งกำไร={{ProfitSharing}} วิธีการจัดสรร={{AllocationMethod}})',\r\n MasterAccountWasLinked: \"บัญชีของผู้ติดตาม '{{InvestorAccountName}}' เริ่มคัดลอกบัญชีต้นแบบ\",\r\n MasterAccountWasOpened:\r\n 'สร้างบัญชีมาสเตอร์แล้ว (ส่วนแบ่งกำไร={{ProfitSharing}} วิธีการจัดสรร={{AllocationMethod}})',\r\n MasterAccountWasUnlinked: \"บัญชีของผู้ติดตาม '{{InvestorAccountName}}' หยุดเพื่อคัดลอกบัญชีต้นแบบ\",\r\n },\r\n },\r\n modal: {\r\n error: 'ข้อผิดพลาด',\r\n notification: 'การแจ้งเตือน',\r\n ok: 'ตกลง',\r\n },\r\n operationHistory: {\r\n filterName: 'ค้นหา',\r\n placeholder: 'กรุณาป้อน',\r\n },\r\n pageTitles: {\r\n admin: {\r\n financialIdentity: {\r\n children: {\r\n cards: 'Cards',\r\n },\r\n },\r\n },\r\n },\r\n partnership: {\r\n salesTitle: 'Sales',\r\n ibInfo: {\r\n detailsTitle: 'รายละเอียด IB',\r\n nextRebatePayment: 'การจ่ายค่ารีเบทรอบถัดไป',\r\n statistics: {\r\n closetTradersReport: {\r\n type: 'ประเภท',\r\n },\r\n tradingVolReport: {\r\n subIb: 'Sub-IB',\r\n },\r\n },\r\n },\r\n ibSettings: {\r\n referralLinkError: 'Markups ไม่ถูกต้อง! โปรดติดต่อทีมซัพพอร์ตเพื่อ markups ที่ถูกต้อง',\r\n },\r\n salesUserInfo: {\r\n aeCode: 'AE Code',\r\n },\r\n },\r\n profile: {\r\n adult: 'ฉันอายุมากกว่า 18 ปีบริบูรณ์',\r\n code: 'รหัส',\r\n country: 'ประเทศ',\r\n documentsUploaded: 'อัปโหลดเอกสาร',\r\n isAgreeWithTermsAndConditions: 'ฉันยอมรับข้อกำห<0>นดและเงื่อนไข0> และน<1>โยบายความเป็นส่วนตัว1>',\r\n pleaseValidateAccountToDeposit:\r\n 'แจ้งให้ทราบว่า คำสั่งในการฝากเงิน จะสามารถทำได้เฉพาะ บัญชีที่ยืนยันตัวตนแล้วเท่านั้น',\r\n successChangeDescription: 'บันทึกการเปลี่ยนแปลงแล้ว!',\r\n warningMessage: {\r\n profileIsBeingVerified: 'โปรไฟล์ของคุณกำลังได้รับการยืนยัน อาจใช้เวลาสองสามวินาที',\r\n },\r\n },\r\n psp: {\r\n accountsFetchFailErr: 'การเชื่อมต่อบัญชีล้มเหลว',\r\n confirmEveryTransaction: '\\nยืนยันทุกธุรกรรมการฝากเงินใช้เวลาถึง 24 ชั่วโมง',\r\n deposit: {\r\n depositForm: {\r\n accountNameTitle: 'ชื่อบัญชี',\r\n addressLine2: 'ที่อยู่บรรทัดที่ 2',\r\n beneficiaryAccountNumberTitle: 'เลขที่บัญชี',\r\n beneficiaryBankHint: 'โปรดเลือกเลขบัญชีของคุณ',\r\n beneficiaryBankNameHint: 'ชื่อธนาคาร เช่น (ธนาคารสแตนดาร์ด ชาร์เตอร์ด)',\r\n cardNameTitle: 'Card Name',\r\n localDepositFileHint: 'กรุณาอัปโหลดหลักฐานการโอนเงิน',\r\n },\r\n depositTitle: 'ฝากเงิน',\r\n notice: 'หมายเหตุ! คุณจะสามารถถอนเงินได้หลังจากบัญชีได้รับการอนุมัติเรียบร้อย',\r\n warnToSubmitPersonalDetails: 'หากต้องการฝากเงิน กรุณาส่งรายละเอียดส่วนตัวของท่าน',\r\n },\r\n localAgentTable: {\r\n login: 'เข้าสู่ระบบ',\r\n },\r\n operationsFetchFailErr: 'การดำเนินการล้มเหลว',\r\n operationsTable: {\r\n documentTitle: 'เอกสาร',\r\n operationsTableTitle: 'ประวัติการทำธุรกรรม',\r\n paymentSystemTitle: 'ช่องทางการทำธุรกรรม',\r\n },\r\n pluginInfoFetchFailErr: 'การดึงข้อมูลปลั๊กอินล้มเหลว',\r\n pluginNotFound: 'ไม่พบปลั๊กอิน',\r\n pluginsFetchFailErr: 'การดึงข้อมูลปลั๊กอินล้มเหลว',\r\n preAuthorizedBanking: 'การธนาคารที่ได้รับอนุญาตล่วงหน้า',\r\n qrCodeCryptoNotice:\r\n 'QR Code ใช้ได้เพียงครั้งเดียวเท่านั้น อย่าสแกนรหัสนี้ในแอปพลิเคชัน crypto มากกว่าหนึ่งครั้ง มิฉะนั้น การชำระเงินของคุณจะถูกระงับ',\r\n qrCodeCryptoTitle: 'QR Code สำหรับแอปพลิเคชัน crypto',\r\n resentOperationsTitle: 'ประวัติการทำธุรกรรม',\r\n transfer: {\r\n transactionDetailsTitle: 'รายละเอียดการทำธุรกรรม',\r\n transferForm: {\r\n amountError: 'ยอดคงเหลือไม่พอสำหรับการโอน',\r\n currencyTitle: 'สกุลเงิน',\r\n },\r\n },\r\n uploadBankStatementWithBankName: 'อัปโหลดรายการเดินบัญชีที่มีชื่อธนาคาร, ชื่อนามสกุล เเละหมายเลขบัญชีธนาคารของคุณ',\r\n uploadPayslip: 'อัปโหลดสลิปการฝากเงิน',\r\n uploadYourDocument: 'โปรดยืนยันการฝากเงินของคุณโดยอัปโหลดหน้าสมุดบัญชีธนาคารของคุณ',\r\n withdrawal: {\r\n notice: 'การถอนสามารถทำได้เฉพาะบัญชีที่ยืนยันตัวตนแล้วเท่านั้น',\r\n withdrawalTitle: 'ถอนเงิน',\r\n withdrawalForm: {\r\n bankNameTitle: 'ชื่อ ธนาคาร',\r\n beneficiaryCryptoWalletHint: 'หมายเลขกระเป๋าเงินพร้อมเงินดิจิตอลจะถูกส่งไปยัง',\r\n beneficiaryCryptoWalletTitle: 'ผู้รับเงิน Crypto Wallet',\r\n confirmTitle: 'อัตราแลกเปลี่ยน ในการถอน ขึ้นอยู่ กับ อัตราแลกเปลี่ยนในวันที่ เงินจากระบบถูกโอนเข้าบัญชีของคุณ',\r\n },\r\n },\r\n },\r\n settings: {\r\n docsForm: {\r\n documentNumberHint: 'กรุณาตรวจสอบว่าหมายเลขบนเอกสารของท่านตรงกับในภาพ',\r\n documentTypeHint: 'กรุณาอัปโหลดรูปหรือเอกสารที่มีรายละเอียดชัดเจนและเป็นเอกสารสี',\r\n uploadedDocumentsTable: {\r\n docNameTitle: 'ชื่อเอกสาร',\r\n documentNumber: 'หมายเลขเอกสาร',\r\n typeTitle: 'ประเภทเอกสาร',\r\n },\r\n },\r\n profileForm: {\r\n editProfileTitle: 'แก้ไขข้อมูลส่วนตัว',\r\n proceedToDeposit: 'ดำเนินการฝากเงิน',\r\n saveUserSuccessMessage: 'บันทึกข้อมูลเรียบร้อย',\r\n userDetailsErrorMessage: 'การดึงข้อมูลส่วนตัวล้มเหลว',\r\n verifyPersonalDetails: 'ยืนยันรายละเอียดส่วนบุคคล',\r\n verifyProfileBtn: 'ส่งข้อมูลการสมัครส่วนตัว',\r\n },\r\n },\r\n socialTradingModal: {\r\n copyHint: 'บัญชีของคุณ {{account}} จะหยุด กอปปี้ มาสเตอร์ {{oldMaster}} และจะเริ่ม กอปปี้ มาสเตอร์ {{newMaster}}',\r\n },\r\n tradingAccounts: {\r\n accountDetailsTitle: 'บัญชีซื้อขาย',\r\n accountHistoryForm: {\r\n closeTimeTitle: 'เวลาปิด',\r\n },\r\n changeTradingAccountName: 'เปลี่ยนชื่อบัญชีซื้อขาย',\r\n connectedAccounts: 'บัญชีเชื่อมต่อแล้ว',\r\n currency: 'สกุลเงิน',\r\n depositForm: {\r\n amountTitle: 'จำนวนเงิน',\r\n errorMessage: 'การฝากเงินล้มเหลว',\r\n successMessage: 'การฝากเงินสำเร็จ',\r\n },\r\n descriptionPlaceholder: 'ป้อนคำแนะนำสำหรับผู้ติดตามของคุณ',\r\n fetchServersErr: 'การเชื่อมต่อเซิร์ฟเวอร์ล้มเหลว',\r\n ibCode: 'IB (ไม่จำเป็น)',\r\n notRows: 'ไม่มีข้อมูล',\r\n openAccountModalSubTitle: 'ตราสารการซื้อขายที่หลากหลายที่สุด: สกุลเงินโลหะ เงื่อนไขการซื้อขายมาตรฐาน',\r\n tradingPlatforms: 'แพลตฟอร์มการเทรด',\r\n transferForm: {\r\n title: 'โอนเงิน',\r\n },\r\n withdrawForm: {\r\n amountTitle: 'จำนวน',\r\n errorMessage: 'การเปลี่ยนเลเวอเรจล้มเหลว',\r\n successMessage: 'การถอนเงินเสร็จสมบูรณ์',\r\n },\r\n },\r\n} satisfies ILocaleLegacy;\r\n","import { ILocaleLegacy } from '@locales/interfaces';\r\n\r\n/**\r\n * @deprecated\r\n * @todo\r\n * These are legacy translations. Some of them are used silently (come from BE), while others are outdated.\r\n * Please remove keys if you are 100% sure that they are not used in the project anymore.\r\n */\r\nexport const vi = {\r\n IBCorporate: 'IB hội nhóm',\r\n IBIndividual: 'IB lẻ',\r\n MAMIndividual: 'MAM cá nhân',\r\n MAMMasterWithLPOA: 'MAM cá nhân',\r\n MarkupConfirmation: 'xác nhận đánh dấu',\r\n UserCorporate: 'User Corporate',\r\n UserIndividual: 'User Individual',\r\n UserJoint: 'User Joint',\r\n account: {\r\n bankingDetails: 'Thông tin tài khoản ngân hàng',\r\n createANewAccount: 'Mở tài khoản mới',\r\n register: 'Đăng ký',\r\n registerSignInTitle: 'Đã là thành viên ?',\r\n },\r\n admin: {\r\n user: {\r\n fields: {\r\n isMam: 'Is MAM',\r\n isSales: 'Is Sales User',\r\n },\r\n },\r\n tabs: {\r\n tradingSettings: {\r\n tradingAccountSettings: 'Trading Account Settings',\r\n setIBCode: 'Set IB Code',\r\n },\r\n },\r\n reports: {\r\n ftdUtmReport: {\r\n headerTitle: 'FTD_UTM Report',\r\n menuTitle: 'FTD_UTM Report',\r\n },\r\n },\r\n },\r\n adminSocialTrading: {\r\n title: 'Social Trading',\r\n investorAccountDetails: {\r\n tradingAccountName: 'Tên tài khoản giao dịch',\r\n balance: 'số dư',\r\n login: 'đăng nhập',\r\n },\r\n masterAccountDetails: {\r\n copyType: 'Kiểu sao chép',\r\n groupMappingType: 'Group Mapping Type',\r\n login: 'đăng nhập',\r\n },\r\n },\r\n backgroundJobs: {\r\n recurring: {\r\n title: 'Recurring Jobs',\r\n },\r\n },\r\n bonuses: {\r\n collectBirthdayGift: 'Thu thập quà tặng sinh nhật của bạn',\r\n availableTable: {\r\n bonusSize: 'Kích thước tiền thưởng',\r\n },\r\n },\r\n errors: {\r\n shared: {\r\n recordWasNotFound: 'Record was not found',\r\n },\r\n captcha: {\r\n captchaServerIsUnavailable:\r\n 'Captcha server không có sẵn. Vui lòng tải lại trang và thử lại. Nếu vấn đề này lặp lại nhiều lần vui lòng liên hệ CSKH qua online chat hoặc qua email {{0}}',\r\n },\r\n files: {\r\n fileWasNotUploaded: 'File was not loaded',\r\n },\r\n mam: {\r\n linkIsInactive: 'Used link is not active',\r\n },\r\n trading: {\r\n profitSharingLimitWasExceeded:\r\n 'Xin lưu ý rằng giới hạn tối đa cho việc chia sẻ lợi nhuận đã bị vượt quá. Giới hạn tối đa là {{0}}%.',\r\n notEnoughMoney:\r\n 'Chúng tôi xin lỗi, nhưng tài khoản giao dịch của bạn không đủ số dư để thực hiện yêu cầu rút tiền. Vui lòng đảm bảo bạn có số dư đủ trước khi thực hiện yêu cầu rút tiền. Xin lưu ý rằng ngoài số dư hiện có, bạn cũng nên xem xét mức đòn bẩy tự do cần thiết cho việc rút tiền.',\r\n },\r\n copyTrading: {\r\n equityIsLessOrEqualZero: 'Tài khoản Master hiện tại không đủ điều kiện để sao chép, vui lòng thử lại',\r\n },\r\n securityCode: {\r\n emptyValue: 'Giá trị bảo mật nhập vào (mật khẩu hoặc mã PIN) không thể để trống hoặc null',\r\n invalidLength: 'Giá trị bảo mật nhập vào (mật khẩu hoặc mã PIN) phải chứa {{0}} ký tự',\r\n invalidMinLength: 'Giá trị bảo mật nhập vào (mật khẩu hoặc mã PIN) phải chứa ít nhất {{0}} ký tự',\r\n invalidMaxLength: 'Giá trị bảo mật nhập vào (mật khẩu hoặc mã PIN) không được vượt quá {{0}} ký tự',\r\n manyRepeatedValues: 'Giá trị bảo mật nhập vào (mật khẩu hoặc mã PIN) không được có nhiều hơn {{0}} ký tự lặp lại',\r\n missingNumericValues: 'Giá trị bảo mật nhập vào (mật khẩu hoặc mã PIN) phải chứa ký tự số',\r\n containsNumericValues: 'Giá trị bảo mật nhập vào (mật khẩu hoặc mã PIN) không được chứa bất kỳ giá trị số nào',\r\n missingLowerCaseValues: 'Giá trị bảo mật nhập vào (mật khẩu hoặc mã PIN) phải chứa ký tự thường',\r\n containsLowerCaseValues:\r\n 'Giá trị bảo mật nhập vào (mật khẩu hoặc mã PIN) không được chứa bất kỳ giá trị chữ thường nào',\r\n missingUpperCaseValues: 'Giá trị bảo mật nhập vào (mật khẩu hoặc mã PIN) phải chứa ký tự hoa',\r\n containsUpperCaseValues:\r\n 'Giá trị bảo mật nhập vào (mật khẩu hoặc mã PIN) không được chứa bất kỳ giá trị chữ hoa nào',\r\n missingSpecialValues: 'Giá trị bảo mật nhập vào (mật khẩu hoặc mã PIN) phải chứa ký tự đặc biệt',\r\n containsSpecialValues:\r\n 'Giá trị bảo mật nhập vào (mật khẩu hoặc mã PIN) không được chứa bất kỳ giá trị đặc biệt nào',\r\n passwordChangeLimit: 'Password change attempts limit is exceeded. Please wait and try again',\r\n },\r\n user: {\r\n accountHasBeenDisabled: 'Rất tiếc vì sự bất tiện này, nhưng tài khoản {{0}} đã bị khóa',\r\n ageIsAboveMaxAllowed: 'Chúng tôi không chấp nhận đơn đăng ký của bất kỳ ai dưới {{0}} tuổi hoặc trên {{1}} tuổi.',\r\n ageIsUnderMinAllowed: 'Chúng tôi không chấp nhận đơn đăng ký của bất kỳ ai dưới {{0}} tuổi.',\r\n cantChangeLanguage: 'Cannot change language',\r\n fieldIsRequired: 'Field {{0}} is required',\r\n ibCodeIsIncorrect: \"The IB code '{{0}}' is incorrect. Please enter a valid IB code\",\r\n invalidCredentials: 'Tên đăng nhập {{0}} hoặc mật khẩu không hợp lệ',\r\n invalidLengthOfPhoneNumber: 'The phone number length is invalid, please try again',\r\n invalidLink: 'The link is invalid',\r\n invalidPhoneNumberLength: 'Độ dài số điện thoại không hợp lệ. Vui lòng thử lại',\r\n onlyLatinCharactersAndDigitsAndSpecialSymbolsCanBeUsed:\r\n 'Only latin characters, digits and special symbols can be used for {{0}} field',\r\n onlyLatinCharactersAndDigitsCanBeUsed: 'Only latin characters and digits can be used for {{0}} field',\r\n onlyLatinCharactersCanBeUsed: 'Only latin characters can be used for {{0}} field',\r\n onlyChineseCharactersCanBeUsed: 'Only chinese characters can be used for {{0}} field',\r\n personalDataNotEntered: 'Personal data are not entered',\r\n userCannotBeRestored:\r\n 'Sorry, the record cannot be restored as the email or phone number of this profile is already in use with another profile, please delete the profile with the same email or phone number to restore this one',\r\n userDoesntExist: 'Người dùng {{0}} không tồn tại',\r\n userEmailAlreadyExists: 'Địa chỉ email đã được đăng kí trên hệ thống',\r\n userPhoneAlreadyExists: 'Điện thoại người dùng đã được đăng kí trên hệ thống',\r\n cantUpdateProfileActualStatus: \"Can't update account {{0}}, actual status = {{1}}\",\r\n },\r\n },\r\n formats: {\r\n formatFloat: '{{value, float}}',\r\n formatMoney: '{{value, money}}',\r\n },\r\n forms: {\r\n dragFile: 'đưa tệp của bạn vào đây',\r\n exportFormat: 'định dạng xuất khẩu',\r\n getCode: 'Lấy mã code',\r\n hide: 'ẩn',\r\n limitMessage: '{{limit}} Ký tự còn lại',\r\n resend: 'Gửi lại',\r\n seconds: 'sec',\r\n show: 'biểu lộ',\r\n },\r\n headerWithBalance: {\r\n serverTime: 'thời gian ở máy chủ',\r\n failedToFetchServerTime: ' lấy thời gian máy chủ thất bại',\r\n view: 'xem/lượt xem',\r\n },\r\n investors: {\r\n blackList: 'Black List',\r\n },\r\n legal: {\r\n clientAgreement: 'Hợp đồng khách hàng',\r\n privacyPolicy: 'Chính sách quyền riêng tư',\r\n },\r\n legalTradingPlatform: {\r\n data: 'Data',\r\n },\r\n masterProfile: {\r\n aboutMaster: 'Về Master',\r\n infoFields: {\r\n ibCode: 'IB code',\r\n },\r\n },\r\n masters: {\r\n fields: {\r\n masterNickname: 'Tên đăng nhập Chuyên gia',\r\n rating: 'Vị trí trong xếp hạng',\r\n },\r\n },\r\n menu: {\r\n deposit: 'tiền gửi',\r\n },\r\n messages: {\r\n CopyTrading: {\r\n InvestorAccountWasLinked:\r\n \"Tài khoảnngười theo dõi đã bắt đầu sao chép tài khoản chuyên gia '{{MasterAccountName}}'.\",\r\n InvestorAccountWasOpened:\r\n \"Tài khoản người theo dõi đã được tạo. Tài khoản người theo dõi đã bắt đầu sao chép tài khoản chuyên gia '{{InvestorAccountName}}'.\",\r\n InvestorAccountWasUnlinked:\r\n \"Tài khoản người theo dõi đã dừng sao chép tài khoản chuyên gia '{{MasterAccountName}}'.\",\r\n MasterAccountWasChanged:\r\n 'Tài khoản chuyên gia đã được sửa đổi. (Phân chia lợi nhuận ={{ProfitSharing}}, phương thức phân bổ ={{AllocationMethod}})',\r\n MasterAccountWasLinked:\r\n \"Tài khoản người theo dõi '{{InvestorAccountName}}' đã bắt đầu sao chép tài khoản chuyên gia.\",\r\n MasterAccountWasOpened:\r\n 'Tài khoản chuyên gia đã được tạo. (Phân chia lợi nhuận ={{ProfitSharing}}, phương thức phân bổ ={{AllocationMethod}})',\r\n MasterAccountWasUnlinked:\r\n \"Tài khoản người theo dõi '{{InvestorAccountName}}' đã dừng sao chép tài khoản chuyên gia.\",\r\n },\r\n },\r\n modal: {\r\n error: 'lỗi',\r\n notification: 'thông báo ',\r\n ok: 'được rồi',\r\n },\r\n operationHistory: {\r\n filterName: 'Tìm',\r\n placeholder: 'Vui lòng nhập',\r\n },\r\n pageTitles: {\r\n admin: {\r\n financialIdentity: {\r\n children: {\r\n cards: 'Cards',\r\n },\r\n },\r\n },\r\n },\r\n partnership: {\r\n salesTitle: 'doanh thu',\r\n ibInfo: {\r\n detailsTitle: 'chi tiết IB',\r\n nextRebatePayment: 'Thanh toán hoàn lại tiếp theo',\r\n statistics: {\r\n closetTradersReport: {\r\n type: 'loại',\r\n },\r\n tradingVolReport: {\r\n subIb: 'IB tầng dưới',\r\n },\r\n },\r\n },\r\n ibSettings: {\r\n referralLinkError:\r\n 'Markups không chính xác! Vui lòng liên hệ với bộ phận hỗ trợ của chúng tôi để nhận được Markups chính xác',\r\n },\r\n salesUserInfo: {\r\n aeCode: 'mã AE',\r\n },\r\n },\r\n profile: {\r\n adult: 'tôi trên 18 tuổi',\r\n code: 'Mã code',\r\n country: 'quốc gia',\r\n documentsUploaded: 'tài liệu đã tải lên',\r\n isAgreeWithTermsAndConditions:\r\n 'Bằng cách nhấp vào đây, bạn chấp nhận <0> Điều khoản và Điều kiện 0> của <1> tên sàn giao dịch 1>',\r\n pleaseValidateAccountToDeposit:\r\n 'thông tin cá nhân của bạn yêu cầu xác minh bởi nhóm tuân thủ {{brokerName}}. Trước khi tiếp tục nạp tiền, bạn cần gửi bản quét ID của mình',\r\n successChangeDescription: 'Đã lưu thay đổi!',\r\n warningMessage: {\r\n profileIsBeingVerified: 'Hồ sơ của bạn đang được xác minh, có thể mất vài giây',\r\n },\r\n },\r\n psp: {\r\n accountsFetchFailErr: 'tìm kiếm tài khoản thất bại',\r\n confirmEveryTransaction: 'Xác nhận mọi giao dịch, tiền nạp mất đến 24 giờ',\r\n deposit: {\r\n depositForm: {\r\n accountNameTitle: 'tên tài khoản',\r\n addressLine2: 'Địa chỉ dòng 2',\r\n beneficiaryAccountNumberTitle: 'số tài khoản người thụ thưởng',\r\n beneficiaryBankHint: 'ui lòng chọn số tài khoản ngân hàng',\r\n beneficiaryBankNameHint: 'Tên Ngân Hàng, ví dụ (Ngân hàng Standard Charted)',\r\n cardNameTitle: 'Card Name',\r\n localDepositFileHint: 'Vui lòng đính kèm tài liệu xác nhận thanh toán nếu cần',\r\n },\r\n depositTitle: 'nạp tiền',\r\n notice: 'tiền gửi chỉ có hiệu lực với tài khoản đã được xác minh',\r\n warnToSubmitPersonalDetails:\r\n 'Để nạp tiền, vui lòng gửi thông tin cá nhân của bạn. Hãy đảm bảo rằng chúng khớp với dữ liệu trong ID của bạn',\r\n },\r\n localAgentTable: {\r\n login: 'đăng nhập',\r\n },\r\n operationsFetchFailErr: 'tìm kiếm hoạt động thất bại',\r\n operationsTable: {\r\n documentTitle: 'tài liệu ',\r\n operationsTableTitle: 'hoạt đọng gần đây',\r\n paymentSystemTitle: 'hệ thống thanh toán',\r\n },\r\n pluginInfoFetchFailErr: 'tìm thông tin đăng nhập thất bại',\r\n pluginNotFound: 'đăng nhập không được tìm thấy',\r\n pluginsFetchFailErr: 'Không tìm nạp được plugin',\r\n preAuthorizedBanking: 'ngân hàng ủy quyền trước',\r\n qrCodeCryptoNotice:\r\n 'Mã QR chỉ dùng một lần. Không quét mã này trong ứng dụng tiền điện tử nhiều lần, nếu không thanh toán của bạn sẽ bị tạm ngưng.',\r\n qrCodeCryptoTitle: 'Mã QR cho ứng dụng tiền điện tử',\r\n resentOperationsTitle: 'hoạt động gần đây',\r\n transfer: {\r\n transactionDetailsTitle: 'chi tiết giao dịch',\r\n transferForm: {\r\n amountError: 'số tiền chuyển vượt quá hạn mức cho phép',\r\n currencyTitle: 'tiền tệ',\r\n },\r\n },\r\n uploadBankStatementWithBankName:\r\n 'taie lên sao kê ngân hàng bao gồm tên ngân hàng, họ tên bạn, số tài khoản ngân hàng',\r\n uploadPayslip: 'Tải lên phiếu thanh toán của ngân hàng về khoản tiền gửi của bạn',\r\n uploadYourDocument: ' vui lòng xác nhận tiền nạp của bạn bằng cách tải lên chứng từ ngân hàng',\r\n withdrawal: {\r\n notice: 'rút tiền chỉ có hiệu lực với tài khoản đã xác minh',\r\n withdrawalTitle: 'rút tiền',\r\n withdrawalForm: {\r\n bankNameTitle: 'tên ngân hàng',\r\n beneficiaryCryptoWalletHint: 'Một số ví chứa tiền điện tử sẽ được gửi đến',\r\n beneficiaryCryptoWalletTitle: 'Ví tiền điện tử của người thụ hưởng',\r\n confirmTitle: 'xác nhận thông tin rút tiền',\r\n },\r\n },\r\n },\r\n settings: {\r\n docsForm: {\r\n documentNumberHint: 'kiểm tra số CCCD đã trùng với ảnh chưa',\r\n documentTypeHint: 'vui lòng chắc chắn rằng bạn cung cấp hình ảnh chất lượng cao hoặc bản scan giấy tờ hợp lệ',\r\n uploadedDocumentsTable: {\r\n docNameTitle: 'Tên tài liệu',\r\n documentNumber: 'Số tài liệu nhận biết',\r\n typeTitle: 'Loại tài liệu',\r\n },\r\n },\r\n profileForm: {\r\n editProfileTitle: 'Sửa hồ sơ',\r\n proceedToDeposit: 'Nạp tiền đã được thực hiện',\r\n saveUserSuccessMessage: 'Hồ sơ được lưu thành công',\r\n userDetailsErrorMessage: 'Thất bại lấy hồ sơ người dùng',\r\n verifyPersonalDetails: 'Xác minh thông tin cá nhân',\r\n verifyProfileBtn: 'Xác minh thông tin',\r\n },\r\n },\r\n socialTradingModal: {\r\n copyHint:\r\n 'Tài khoản của bạn {{account}} sẽ dừng sao chép Chuyên gia {{oldMaster}} và bắt đầu sao chép Chuyên gia {{newMaster}}',\r\n },\r\n tradingAccounts: {\r\n accountDetailsTitle: 'Tài khoản giao dịch',\r\n accountHistoryForm: {\r\n closeTimeTitle: 'Gio đóng cửa ',\r\n },\r\n changeTradingAccountName: 'Thay đổi tài khoản giao dịch',\r\n connectedAccounts: 'Tài khoản đã liên kết',\r\n currency: 'Tiền tệ',\r\n depositForm: {\r\n amountTitle: 'Số tiền',\r\n errorMessage: 'Nạp tiền thất bại',\r\n successMessage: 'Nạp tiền đã được thực hiện thành công',\r\n },\r\n descriptionPlaceholder: 'Nhập đề xuất cho người theo dõi bạn',\r\n fetchServersErr: 'Lấy máy chủ thất bại',\r\n ibCode: 'Môi giới giới thiệu',\r\n notRows: 'không có hàng nào để hiển thị',\r\n openAccountModalSubTitle: 'Công cụ giao dịch rộng lớn : tiền tệ, kim loại ',\r\n tradingPlatforms: 'Nền tảng giao dịch',\r\n transferForm: {\r\n title: 'chuyển tiền nội bộ',\r\n },\r\n withdrawForm: {\r\n amountTitle: 'Số tiền',\r\n errorMessage: 'Chưa thể lưu đòn bẩy',\r\n successMessage: 'Rút tiền thành công',\r\n },\r\n },\r\n} satisfies ILocaleLegacy;\r\n","import { ILocaleLegacy } from '@locales/interfaces';\r\n\r\n/**\r\n * @deprecated\r\n * @todo\r\n * These are legacy translations. Some of them are used silently (come from BE), while others are outdated.\r\n * Please remove keys if you are 100% sure that they are not used in the project anymore.\r\n */\r\nexport const zh = {\r\n IBCorporate: '代理公司问卷',\r\n IBIndividual: '代理 个人问卷',\r\n MAMIndividual: '个人资管',\r\n MAMMasterWithLPOA: '个人资管',\r\n MarkupConfirmation: '加成确认',\r\n UserCorporate: '企业用户',\r\n UserIndividual: '个人用户',\r\n UserJoint: '联名用户',\r\n account: {\r\n bankingDetails: '银行卡详细信息',\r\n createANewAccount: '开立账户',\r\n register: '注册',\r\n registerSignInTitle: '已经是会员了?',\r\n },\r\n admin: {\r\n user: {\r\n fields: {\r\n isMam: 'Is MAM',\r\n isSales: 'Is Sales User',\r\n },\r\n },\r\n tabs: {\r\n tradingSettings: {\r\n tradingAccountSettings: 'Trading Account Settings',\r\n setIBCode: 'Set IB Code',\r\n },\r\n },\r\n reports: {\r\n ftdUtmReport: {\r\n headerTitle: 'FTD_UTM Report',\r\n menuTitle: 'FTD_UTM Report',\r\n },\r\n },\r\n },\r\n adminSocialTrading: {\r\n title: '跟单社区',\r\n investorAccountDetails: {\r\n tradingAccountName: '交易账户姓名',\r\n balance: '余额',\r\n login: '登录',\r\n },\r\n masterAccountDetails: {\r\n copyType: '复制类型',\r\n groupMappingType: 'Group Mapping Type',\r\n login: '登录',\r\n },\r\n },\r\n backgroundJobs: {\r\n recurring: {\r\n title: 'Recurring Jobs',\r\n },\r\n },\r\n bonuses: {\r\n collectBirthdayGift: '领取您的生日礼物',\r\n availableTable: {\r\n bonusSize: '奖金金额',\r\n },\r\n },\r\n errors: {\r\n shared: {\r\n recordWasNotFound: '无法找到记录',\r\n },\r\n captcha: {\r\n captchaServerIsUnavailable:\r\n 'Captcha 服务器不可用。请刷新页面并重试。如果问题仍然存在,请通过在线聊天或发送电子邮件至 {{0}} 联系支持人员',\r\n },\r\n files: {\r\n fileWasNotUploaded: 'File was not loaded',\r\n },\r\n mam: {\r\n linkIsInactive: 'Used link is not active',\r\n },\r\n trading: {\r\n profitSharingLimitWasExceeded: '请注意,已超过利润分成的最高限制。 最高限制为 {{0}}%',\r\n notEnoughMoney:\r\n '我们深表歉意,但您的交易账户中没有足够的资金。在尝试提款之前,请确保您有足够的可用余额。请注意,除了可用余额外,针对持仓账户有保护政策,还需要参考预付款比例要求。',\r\n },\r\n copyTrading: {\r\n equityIsLessOrEqualZero: '主帐户目前不符合复制条件,请稍后再试',\r\n },\r\n securityCode: {\r\n emptyValue: 'ค输入的安全值(密码或 PIN 码)不能为空或为 null',\r\n invalidLength: '输入的安全值(密码或 PIN 码)必须包含 {{0}} 个字符',\r\n invalidMinLength: '输入的安全值(密码或 PIN 码)必须至少包含 {{0}} 个字符',\r\n invalidMaxLength: '输入的安全值(密码或 PIN 码)不能超过 {{0}} 个字符',\r\n manyRepeatedValues: '输入的安全值(密码或 PIN 码)不能有超过 {{0}} 个重复字符',\r\n missingNumericValues: '输入的安全值(密码或 PIN 码)必须包含数字字符',\r\n containsNumericValues: '输入的安全值(密码或 PIN 码)不能包含任何数字值',\r\n missingLowerCaseValues: '输入的安全值(密码或 PIN 码)必须包含小写字符',\r\n containsLowerCaseValues: '输入的安全值(密码或 PIN 码)不能包含任何小写值',\r\n missingUpperCaseValues: '输入的安全值(密码或 PIN 码)必须包含大写字符',\r\n containsUpperCaseValues: '输入的安全值(密码或 PIN 码)不能包含任何大写值',\r\n missingSpecialValues: '输入的安全值(密码或 PIN 码)必须包含特殊字符',\r\n containsSpecialValues: '输入的安全值(密码或 PIN 码)不能包含任何特殊字符',\r\n passwordChangeLimit: 'Password change attempts limit is exceeded. Please wait and try again',\r\n },\r\n user: {\r\n accountHasBeenDisabled: '很抱歉给您带来不便,帐户 {{0}} 已被禁用',\r\n ageIsAboveMaxAllowed: 'W我们不接受任何来自未满{{0}}岁的未成年人与超过{{1}}岁的老年人申请.',\r\n ageIsUnderMinAllowed: '我们不接受任何来自未满{{0}}岁的未成年',\r\n cantChangeLanguage: 'Cannot change language',\r\n fieldIsRequired: '字段 {{0}} 是必需的',\r\n ibCodeIsIncorrect: 'IB 代码“{{0}}”不正确。 请输入有效的 IB 代码',\r\n invalidCredentials: '用户名 {{0}} 或者密码无效',\r\n invalidLengthOfPhoneNumber: '电话号码长度无效,请重试',\r\n invalidLink: '链接无效',\r\n invalidPhoneNumberLength: '电话号码长度无效,请重试',\r\n onlyLatinCharactersAndDigitsAndSpecialSymbolsCanBeUsed:\r\n 'Only latin characters, digits and special symbols can be used for {{0}} field',\r\n onlyLatinCharactersAndDigitsCanBeUsed: 'Only latin characters and digits can be used for {{0}} field',\r\n onlyLatinCharactersCanBeUsed: '{{0}} 字段只能使用拉丁字符',\r\n onlyChineseCharactersCanBeUsed: 'Only chinese characters can be used for {{0}} field',\r\n personalDataNotEntered: 'Personal data are not entered',\r\n userCannotBeRestored:\r\n 'Sorry, the record cannot be restored as the email or phone number of this profile is already in use with another profile, please delete the profile with the same email or phone number to restore this one',\r\n userDoesntExist: '用户 {{0}} 不存在',\r\n userEmailAlreadyExists: '用户电子邮箱已在系统中注册',\r\n userPhoneAlreadyExists: '用户手机号码已在系统中注册',\r\n cantUpdateProfileActualStatus: '无法更新账户 {{0}},实际状态= {{1}}',\r\n },\r\n },\r\n formats: {\r\n formatFloat: '{{value, float}}',\r\n formatMoney: '{{value, money}}',\r\n },\r\n forms: {\r\n dragFile: '或把您的文件拖至此处',\r\n exportFormat: '导出格式',\r\n getCode: '获取验证码',\r\n hide: '隐藏',\r\n limitMessage: '{{limit}} 个剩余字符',\r\n resend: '重新发送',\r\n seconds: '秒',\r\n show: '显示',\r\n },\r\n headerWithBalance: {\r\n serverTime: '服务器时间',\r\n failedToFetchServerTime: '无法取得服务器时间',\r\n view: '查看',\r\n },\r\n investors: {\r\n blackList: '黑名单',\r\n },\r\n legal: {\r\n clientAgreement: '客户协议',\r\n privacyPolicy: '隐私政策',\r\n },\r\n legalTradingPlatform: {\r\n data: 'Data',\r\n },\r\n masterProfile: {\r\n aboutMaster: '关于操盘大师',\r\n infoFields: {\r\n ibCode: 'IB代码',\r\n },\r\n },\r\n masters: {\r\n fields: {\r\n masterNickname: '操盘大师昵称',\r\n rating: '在排行榜中的排名',\r\n },\r\n },\r\n menu: {\r\n deposit: '存款',\r\n },\r\n messages: {\r\n CopyTrading: {\r\n InvestorAccountWasLinked: '追随者账户开始复制大师账户“{{MasterAccountName}}”。',\r\n InvestorAccountWasOpened: '追随者账户已创建。追随者账户开始复制大师账户“{{InvestorAccountName}}”。',\r\n InvestorAccountWasUnlinked: '追随者账户停止复制大师账户“{{MasterAccountName}}”。',\r\n MasterAccountWasChanged: '大师帐户已修改。(利润分享={{ProfitSharing}}, 分配方法={{AllocationMethod}})',\r\n MasterAccountWasLinked: '追随者账户“{{InvestorAccountName}}”开始复制大师账户。',\r\n MasterAccountWasOpened: '已创建大师帐户。(利润分享={{ProfitSharing}}, 分配方法={{AllocationMethod}})',\r\n MasterAccountWasUnlinked: '追随者账户“{{InvestorAccountName}}”停止复制大师账户。',\r\n },\r\n },\r\n modal: {\r\n error: '报错',\r\n notification: '通知',\r\n ok: '知道了',\r\n },\r\n operationHistory: {\r\n filterName: '搜索',\r\n placeholder: '请输入',\r\n },\r\n pageTitles: {\r\n admin: {\r\n financialIdentity: {\r\n children: {\r\n cards: 'Cards',\r\n },\r\n },\r\n },\r\n },\r\n partnership: {\r\n salesTitle: '销售',\r\n ibInfo: {\r\n detailsTitle: '代理详细信息',\r\n nextRebatePayment: '下次内返支付',\r\n statistics: {\r\n closetTradersReport: {\r\n type: '类型',\r\n },\r\n tradingVolReport: {\r\n subIb: '子代理',\r\n },\r\n },\r\n },\r\n ibSettings: {\r\n referralLinkError: '加点佣不正确!请联系我们的支持以获得正确的方式',\r\n },\r\n salesUserInfo: {\r\n aeCode: '销售编号',\r\n },\r\n },\r\n profile: {\r\n adult: '我已满18周岁',\r\n code: '验证码',\r\n country: '国家',\r\n documentsUploaded: '已上传文档',\r\n isAgreeWithTermsAndConditions: '我接受 <0>客户协议0> 与 <1>隐私政策1>',\r\n pleaseValidateAccountToDeposit:\r\n '您的个人详细信息需要{{brokerName}}合规团队进行核验。在进行入金之前,您需要提交身份证扫描件',\r\n successChangeDescription: '更改已保存!',\r\n warningMessage: {\r\n profileIsBeingVerified: '我们正在对您的个人资料进行审核,请稍候',\r\n },\r\n },\r\n psp: {\r\n accountsFetchFailErr: '获取账户失败',\r\n confirmEveryTransaction: '确认每笔交易,入金最多需要24小时',\r\n deposit: {\r\n depositForm: {\r\n accountNameTitle: '账户姓名',\r\n addressLine2: '地址第2行',\r\n beneficiaryAccountNumberTitle: '收款人帐号',\r\n beneficiaryBankHint: '请选择银行卡号',\r\n beneficiaryBankNameHint: '银行名, 例如 (渣打银行)',\r\n cardNameTitle: 'Card Name',\r\n localDepositFileHint: '如果需要,请附上确认付款的文件',\r\n },\r\n depositTitle: '存入资金',\r\n notice: '审核完成后即可入金',\r\n warnToSubmitPersonalDetails: '如需存款,请提交与身份证信息相符的个人资料',\r\n },\r\n localAgentTable: {\r\n login: '登录',\r\n },\r\n operationsFetchFailErr: '无法取得操作',\r\n operationsTable: {\r\n documentTitle: '文件',\r\n operationsTableTitle: '最近操作',\r\n paymentSystemTitle: '支付系统',\r\n },\r\n pluginInfoFetchFailErr: '无法取得插件信息',\r\n pluginNotFound: '无法找到插件',\r\n pluginsFetchFailErr: '无法取得插件',\r\n preAuthorizedBanking: '预授权银行业务',\r\n qrCodeCryptoNotice: '二维码仅供一次性使用。 请勿在加密应用程序中多次扫描此代码,否则您的付款将被暂停。',\r\n qrCodeCryptoTitle: '加密应用二维码',\r\n resentOperationsTitle: '最近操作',\r\n transfer: {\r\n transactionDetailsTitle: '交易细节',\r\n transferForm: {\r\n amountError: '超过可用转账金额',\r\n currencyTitle: '货币',\r\n },\r\n },\r\n uploadBankStatementWithBankName: '上传包含您的全名,银行名称和账号的银行对账单',\r\n uploadPayslip: '上传存款的银行流水',\r\n uploadYourDocument: '请上传银行对账单以确认存款',\r\n withdrawal: {\r\n notice: '审核完成的账户才能提款',\r\n withdrawalTitle: '提取资金',\r\n withdrawalForm: {\r\n bankNameTitle: '银行名称',\r\n beneficiaryCryptoWalletHint: '一个带有加密货币的钱包号码将被发送到',\r\n beneficiaryCryptoWalletTitle: '受益人加密钱包',\r\n confirmTitle: '请确认出金信息',\r\n },\r\n },\r\n },\r\n settings: {\r\n docsForm: {\r\n documentNumberHint: '检查身份证号码是否与照片相符',\r\n documentTypeHint: '请确保您提供的是清晰地图片或者有效的扫描件',\r\n uploadedDocumentsTable: {\r\n docNameTitle: '文件名',\r\n documentNumber: '文档编号',\r\n typeTitle: '文件类型',\r\n },\r\n },\r\n profileForm: {\r\n editProfileTitle: '编辑个人资料',\r\n proceedToDeposit: '开始入金',\r\n saveUserSuccessMessage: '用户个人资料保存成功',\r\n userDetailsErrorMessage: '无法取得用户个人资料',\r\n verifyPersonalDetails: '确认个人详细信息',\r\n verifyProfileBtn: '确认个人资料',\r\n },\r\n },\r\n socialTradingModal: {\r\n copyHint: '您的帐户 {{account}} 将停止复制 Master {{oldMaster}} 并将开始复制 Master {{newMaster}}',\r\n },\r\n tradingAccounts: {\r\n accountDetailsTitle: '交易账户',\r\n accountHistoryForm: {\r\n closeTimeTitle: '平仓时间',\r\n },\r\n changeTradingAccountName: '更改交易账户姓名',\r\n connectedAccounts: '关联账户',\r\n currency: '货币',\r\n depositForm: {\r\n amountTitle: '金额',\r\n errorMessage: '存入资金失败',\r\n successMessage: '存入资金成功',\r\n },\r\n descriptionPlaceholder: '输入对追随者的建议',\r\n fetchServersErr: '无法取得服务器',\r\n ibCode: '代理(可选的)',\r\n notRows: '没有要显示的行',\r\n openAccountModalSubTitle: '交易最受欢迎的交易品种:外汇、贵金属、差价合约。',\r\n tradingPlatforms: '交易平台',\r\n transferForm: {\r\n title: '转账',\r\n },\r\n withdrawForm: {\r\n amountTitle: '金额',\r\n errorMessage: '无法保存杠杆',\r\n successMessage: '提取资金成功',\r\n },\r\n },\r\n} satisfies ILocaleLegacy;\r\n","export const keyMap = Object.freeze({\r\n accountAlreadyHaveAnAccount: 'accountAlreadyHaveAnAccount',\r\n accountChangeEmailFailedToCheckLinkError: 'accountChangeEmailFailedToCheckLinkError',\r\n accountChangeEmailNotValidLink: 'accountChangeEmailNotValidLink',\r\n accountChangeEmailSuccessMessage: 'accountChangeEmailSuccessMessage',\r\n accountChoosePlatform: 'accountChoosePlatform',\r\n accountConfirmEmailChangeErrorMessage: 'accountConfirmEmailChangeErrorMessage',\r\n accountConfirmEmailChangeFailedToCheckLinkError: 'accountConfirmEmailChangeFailedToCheckLinkError',\r\n accountConfirmEmailChangeMAPassword: 'accountConfirmEmailChangeMAPassword',\r\n accountConfirmEmailChangeNotValidLink: 'accountConfirmEmailChangeNotValidLink',\r\n accountConfirmEmailChangeSuccessMessage: 'accountConfirmEmailChangeSuccessMessage',\r\n accountConfirmEmailChangeTitle: 'accountConfirmEmailChangeTitle',\r\n accountContinue: 'accountContinue',\r\n accountDontHaveAnAccountYet: 'accountDontHaveAnAccountYet',\r\n accountFailedToRegistration: 'accountFailedToRegistration',\r\n accountFailedToResetPasswordError: 'accountFailedToResetPasswordError',\r\n accountFailedToSignInError: 'accountFailedToSignInError',\r\n accountFailedToSignOutError: 'accountFailedToSignOutError',\r\n accountForgotPassword: 'accountForgotPassword',\r\n accountForgotPasswordSuccessMessage: 'accountForgotPasswordSuccessMessage',\r\n accountGoToYourMemberArea: 'accountGoToYourMemberArea',\r\n accountNext: 'accountNext',\r\n accountOneTimePasswordHint: 'accountOneTimePasswordHint',\r\n accountOpenAnAccount: 'accountOpenAnAccount',\r\n accountOtpLimitExceeded: 'accountOtpLimitExceeded',\r\n accountPasswordRecoveryErrorMessage: 'accountPasswordRecoveryErrorMessage',\r\n accountPasswordRecoveryFailedToCheckLinkError: 'accountPasswordRecoveryFailedToCheckLinkError',\r\n accountPasswordRecoveryNotValidLink: 'accountPasswordRecoveryNotValidLink',\r\n accountPasswordRecoverySuccessMessage: 'accountPasswordRecoverySuccessMessage',\r\n accountPasswordRecoveryTitle: 'accountPasswordRecoveryTitle',\r\n accountPlatformHint: 'accountPlatformHint',\r\n accountQuickDeposit: 'accountQuickDeposit',\r\n accountReferralTokenWarning: 'accountReferralTokenWarning',\r\n accountRegisterBtn: 'accountRegisterBtn',\r\n accountResetPassword: 'accountResetPassword',\r\n accountResetPinCodeErrorMessage: 'accountResetPinCodeErrorMessage',\r\n accountResetPinCodeFailedToCheckLinkError: 'accountResetPinCodeFailedToCheckLinkError',\r\n accountResetPinCodeNotValidLink: 'accountResetPinCodeNotValidLink',\r\n accountResetPinCodeSuccessMessage: 'accountResetPinCodeSuccessMessage',\r\n accountResetPinCodeTitle: 'accountResetPinCodeTitle',\r\n accountReturnToSignIn: 'accountReturnToSignIn',\r\n accountSignIn: 'accountSignIn',\r\n accountSignInHere: 'accountSignInHere',\r\n accountSignOutBtn: 'accountSignOutBtn',\r\n accountSignUp: 'accountSignUp',\r\n accountSignUpHere: 'accountSignUpHere',\r\n accountSigninFormBtn: 'accountSigninFormBtn',\r\n adminLegalTradingPlatformDeepLink: 'adminLegalTradingPlatformDeepLink',\r\n adminLegalTradingPlatformDeepLinkHint: 'adminLegalTradingPlatformDeepLinkHint',\r\n adminReportsFtdUtmReportFieldsFtdDate: 'adminReportsFtdUtmReportFieldsFtdDate',\r\n adminReportsFtdUtmReportFieldsFtdValue: 'adminReportsFtdUtmReportFieldsFtdValue',\r\n adminReportsFtdUtmReportFieldsRegistrationDate: 'adminReportsFtdUtmReportFieldsRegistrationDate',\r\n adminReportsFtdUtmReportFieldsTotalDepositValue: 'adminReportsFtdUtmReportFieldsTotalDepositValue',\r\n adminReportsFtdUtmReportFieldsUtmCampaign: 'adminReportsFtdUtmReportFieldsUtmCampaign',\r\n adminReportsFtdUtmReportFieldsUtmMedium: 'adminReportsFtdUtmReportFieldsUtmMedium',\r\n adminReportsFtdUtmReportFieldsUtmSource: 'adminReportsFtdUtmReportFieldsUtmSource',\r\n adminReportsPspOperationReportFieldsAverageDepositUSD: 'adminReportsPspOperationReportFieldsAverageDepositUSD',\r\n adminReportsPspOperationReportFieldsAverageWithdrawalUSD: 'adminReportsPspOperationReportFieldsAverageWithdrawalUSD',\r\n adminReportsPspOperationReportFieldsCallbackErrorCode: 'adminReportsPspOperationReportFieldsCallbackErrorCode',\r\n adminReportsPspOperationReportFieldsCallbackErrorDescription:\r\n 'adminReportsPspOperationReportFieldsCallbackErrorDescription',\r\n adminReportsPspOperationReportFieldsDepositedSharePercent:\r\n 'adminReportsPspOperationReportFieldsDepositedSharePercent',\r\n adminReportsPspOperationReportFieldsNetCashUsd: 'adminReportsPspOperationReportFieldsNetCashUsd',\r\n adminReportsPspOperationReportFieldsOperationTime: 'adminReportsPspOperationReportFieldsOperationTime',\r\n adminReportsPspOperationReportFieldsPspClassName: 'adminReportsPspOperationReportFieldsPspClassName',\r\n adminReportsPspOperationReportFieldsPspId: 'adminReportsPspOperationReportFieldsPspId',\r\n adminReportsPspOperationReportFieldsPspName: 'adminReportsPspOperationReportFieldsPspName',\r\n adminReportsPspOperationReportFieldsTotalDepositedUSD: 'adminReportsPspOperationReportFieldsTotalDepositedUSD',\r\n adminReportsPspOperationReportFieldsTotalDeposits: 'adminReportsPspOperationReportFieldsTotalDeposits',\r\n adminReportsPspOperationReportFieldsTotalWithdrawals: 'adminReportsPspOperationReportFieldsTotalWithdrawals',\r\n adminReportsPspOperationReportFieldsTotalWithdrawnUSD: 'adminReportsPspOperationReportFieldsTotalWithdrawnUSD',\r\n adminReportsPspOperationReportFieldsWithdrawnSharePercent:\r\n 'adminReportsPspOperationReportFieldsWithdrawnSharePercent',\r\n adminSocialTradingInvestorAccountDetailsCopyType: 'adminSocialTradingInvestorAccountDetailsCopyType',\r\n adminSocialTradingInvestorAccountDetailsGroupMappingType: 'adminSocialTradingInvestorAccountDetailsGroupMappingType',\r\n adminSocialTradingInvestorAccountDetailsLotMultiplier: 'adminSocialTradingInvestorAccountDetailsLotMultiplier',\r\n adminSocialTradingInvestorAccountInvestorAccount: 'adminSocialTradingInvestorAccountInvestorAccount',\r\n adminSocialTradingInvestorAccountInvestorName: 'adminSocialTradingInvestorAccountInvestorName',\r\n adminSocialTradingInvestorAccountMasterAccount: 'adminSocialTradingInvestorAccountMasterAccount',\r\n adminSocialTradingInvestorAccountMasterName: 'adminSocialTradingInvestorAccountMasterName',\r\n adminSocialTradingInvestorAccountSettingsChangeAllocationMethodAllowed:\r\n 'adminSocialTradingInvestorAccountSettingsChangeAllocationMethodAllowed',\r\n adminSocialTradingInvestorAccountSettingsCommonSettingsTitle:\r\n 'adminSocialTradingInvestorAccountSettingsCommonSettingsTitle',\r\n adminSocialTradingInvestorAccountSubscribedOn: 'adminSocialTradingInvestorAccountSubscribedOn',\r\n adminSocialTradingIsPositionAvailable: 'adminSocialTradingIsPositionAvailable',\r\n adminSocialTradingMasterAccountAverageDrawdown: 'adminSocialTradingMasterAccountAverageDrawdown',\r\n adminSocialTradingMasterAccountFiltersIsVisible: 'adminSocialTradingMasterAccountFiltersIsVisible',\r\n adminSocialTradingMasterAccountFiltersPeriod: 'adminSocialTradingMasterAccountFiltersPeriod',\r\n adminSocialTradingMasterAccountFiltersTradingAccount: 'adminSocialTradingMasterAccountFiltersTradingAccount',\r\n adminSocialTradingMasterAccountIsVisible: 'adminSocialTradingMasterAccountIsVisible',\r\n adminSocialTradingMasterAccountMaxDrawdown: 'adminSocialTradingMasterAccountMaxDrawdown',\r\n adminSocialTradingMasterAccountNickname: 'adminSocialTradingMasterAccountNickname',\r\n adminSocialTradingMasterAccountPosition: 'adminSocialTradingMasterAccountPosition',\r\n adminSocialTradingMasterAccountProfitSharing: 'adminSocialTradingMasterAccountProfitSharing',\r\n adminSocialTradingMasterAccountProfitability: 'adminSocialTradingMasterAccountProfitability',\r\n adminSocialTradingMasterAccountRecommendedMinDepositAmount:\r\n 'adminSocialTradingMasterAccountRecommendedMinDepositAmount',\r\n adminSocialTradingMasterAccountReturnOnInvestment: 'adminSocialTradingMasterAccountReturnOnInvestment',\r\n adminSocialTradingMasterAccountTotalDepositsUsd: 'adminSocialTradingMasterAccountTotalDepositsUsd',\r\n adminSocialTradingMasterAccountTotalFundsInUsd: 'adminSocialTradingMasterAccountTotalFundsInUsd',\r\n adminSocialTradingMasterAccountTotalManagedFundsInAccountCurrency:\r\n 'adminSocialTradingMasterAccountTotalManagedFundsInAccountCurrency',\r\n adminSocialTradingMasterAccountTotalManagedFundsInUsd: 'adminSocialTradingMasterAccountTotalManagedFundsInUsd',\r\n adminSocialTradingMasterAccountTotalOwnedFundsInAccountCurrency:\r\n 'adminSocialTradingMasterAccountTotalOwnedFundsInAccountCurrency',\r\n adminSocialTradingMasterAccountTotalOwnedFundsInUsd: 'adminSocialTradingMasterAccountTotalOwnedFundsInUsd',\r\n adminSocialTradingMasterAccountTotalWithdrawalsUsd: 'adminSocialTradingMasterAccountTotalWithdrawalsUsd',\r\n adminSocialTradingMasterAccountTradesCount: 'adminSocialTradingMasterAccountTradesCount',\r\n adminTabsAccesses: 'adminTabsAccesses',\r\n adminTabsAccessesSettingsCountryAccess: 'adminTabsAccessesSettingsCountryAccess',\r\n adminTabsAccessesSettingsLoginHistory: 'adminTabsAccessesSettingsLoginHistory',\r\n adminTabsAccessesSettingsPermission: 'adminTabsAccessesSettingsPermission',\r\n adminTabsAllowedUsers: 'adminTabsAllowedUsers',\r\n adminTabsAttachments: 'adminTabsAttachments',\r\n adminTabsAvailableCountries: 'adminTabsAvailableCountries',\r\n adminTabsBankAcc: 'adminTabsBankAcc',\r\n adminTabsBankAccounts: 'adminTabsBankAccounts',\r\n adminTabsBonuses: 'adminTabsBonuses',\r\n adminTabsCommissionHistory: 'adminTabsCommissionHistory',\r\n adminTabsCopyTradingHistory: 'adminTabsCopyTradingHistory',\r\n adminTabsCrm: 'adminTabsCrm',\r\n adminTabsCryptoAcc: 'adminTabsCryptoAcc',\r\n adminTabsCryptoWalletAccounts: 'adminTabsCryptoWalletAccounts',\r\n adminTabsDeposits: 'adminTabsDeposits',\r\n adminTabsDocuments: 'adminTabsDocuments',\r\n adminTabsEWallets: 'adminTabsEWallets',\r\n adminTabsExternalJobs: 'adminTabsExternalJobs',\r\n adminTabsFiles: 'adminTabsFiles',\r\n adminTabsFilters: 'adminTabsFilters',\r\n adminTabsFinance: 'adminTabsFinance',\r\n adminTabsFinanceSettingsAvailableBalance: 'adminTabsFinanceSettingsAvailableBalance',\r\n adminTabsFinanceSettingsCategorySummary: 'adminTabsFinanceSettingsCategorySummary',\r\n adminTabsFinanceSettingsPaymentSummary: 'adminTabsFinanceSettingsPaymentSummary',\r\n adminTabsFinanceSettingsWalletCategorySummary: 'adminTabsFinanceSettingsWalletCategorySummary',\r\n adminTabsFollowers: 'adminTabsFollowers',\r\n adminTabsForbiddenUsers: 'adminTabsForbiddenUsers',\r\n adminTabsImages: 'adminTabsImages',\r\n adminTabsLocalization: 'adminTabsLocalization',\r\n adminTabsMasters: 'adminTabsMasters',\r\n adminTabsMembers: 'adminTabsMembers',\r\n adminTabsNotes: 'adminTabsNotes',\r\n adminTabsOperations: 'adminTabsOperations',\r\n adminTabsParticipants: 'adminTabsParticipants',\r\n adminTabsPartnershipClosedTradesReport: 'adminTabsPartnershipClosedTradesReport',\r\n adminTabsPartnershipPartnerClients: 'adminTabsPartnershipPartnerClients',\r\n adminTabsPartnershipPartnerTradingAccounts: 'adminTabsPartnershipPartnerTradingAccounts',\r\n adminTabsPartnershipReferralLinks: 'adminTabsPartnershipReferralLinks',\r\n adminTabsPartnershipTradingVolumeReport: 'adminTabsPartnershipTradingVolumeReport',\r\n adminTabsProcessors: 'adminTabsProcessors',\r\n adminTabsReceivedUsers: 'adminTabsReceivedUsers',\r\n adminTabsRecipients: 'adminTabsRecipients',\r\n adminTabsRedeemItems: 'adminTabsRedeemItems',\r\n adminTabsRedeemRequests: 'adminTabsRedeemRequests',\r\n adminTabsReportHistory: 'adminTabsReportHistory',\r\n adminTabsRestrictedCountries: 'adminTabsRestrictedCountries',\r\n adminTabsSales: 'adminTabsSales',\r\n adminTabsSettings: 'adminTabsSettings',\r\n adminTabsTickets: 'adminTabsTickets',\r\n adminTabsTradingAccountTypes: 'adminTabsTradingAccountTypes',\r\n adminTabsTradingAccounts: 'adminTabsTradingAccounts',\r\n adminTabsTradingHistory: 'adminTabsTradingHistory',\r\n adminTabsTradingSettingsCommonTradingSettings: 'adminTabsTradingSettingsCommonTradingSettings',\r\n adminTabsTradingSettingsDepositWithdrawalSettings: 'adminTabsTradingSettingsDepositWithdrawalSettings',\r\n adminTabsUserSettingsArchivingSettings: 'adminTabsUserSettingsArchivingSettings',\r\n adminTabsUserSettingsChangeAECode: 'adminTabsUserSettingsChangeAECode',\r\n adminTabsUserSettingsChangeBDMCode: 'adminTabsUserSettingsChangeBDMCode',\r\n adminTabsUserSettingsChangeEmail: 'adminTabsUserSettingsChangeEmail',\r\n adminTabsUserSettingsChangeIBCode: 'adminTabsUserSettingsChangeIBCode',\r\n adminTabsUserSettingsChangeMAMCode: 'adminTabsUserSettingsChangeMAMCode',\r\n adminTabsUserSettingsChangeNickname: 'adminTabsUserSettingsChangeNickname',\r\n adminTabsUserSettingsChangeParentIB: 'adminTabsUserSettingsChangeParentIB',\r\n adminTabsUserSettingsChangePinCode: 'adminTabsUserSettingsChangePinCode',\r\n adminTabsUserSettingsCommissionTradingSettings: 'adminTabsUserSettingsCommissionTradingSettings',\r\n adminTabsUserSettingsConvertToDirect: 'adminTabsUserSettingsConvertToDirect',\r\n adminTabsUserSettingsDeleteUserAccount: 'adminTabsUserSettingsDeleteUserAccount',\r\n adminTabsUserSettingsDepositWithdrawalSettings: 'adminTabsUserSettingsDepositWithdrawalSettings',\r\n adminTabsUserSettingsOneTimePasswordSettings: 'adminTabsUserSettingsOneTimePasswordSettings',\r\n adminTabsUserSettingsOtherUserSettings: 'adminTabsUserSettingsOtherUserSettings',\r\n adminTabsUserSettingsOverrideEmail: 'adminTabsUserSettingsOverrideEmail',\r\n adminTabsUserSettingsPspFeeSettings: 'adminTabsUserSettingsPspFeeSettings',\r\n adminTabsUserSettingsRestoreUserAccount: 'adminTabsUserSettingsRestoreUserAccount',\r\n adminTabsUserSettingsSecuritySettings: 'adminTabsUserSettingsSecuritySettings',\r\n adminTabsUserSettingsStaffSettings: 'adminTabsUserSettingsStaffSettings',\r\n adminTabsUserSettingsUserTradingSettings: 'adminTabsUserSettingsUserTradingSettings',\r\n adminTabsUserSettingsWalletCategorySettings: 'adminTabsUserSettingsWalletCategorySettings',\r\n adminTabsUsers: 'adminTabsUsers',\r\n adminTabsWalletOperations: 'adminTabsWalletOperations',\r\n adminTabsWithdrawals: 'adminTabsWithdrawals',\r\n adminTradingAccountSettingsIbCodeSettingsActionName: 'adminTradingAccountSettingsIbCodeSettingsActionName',\r\n adminTradingAccountSettingsIbCodeSettingsChangeIBCodeError:\r\n 'adminTradingAccountSettingsIbCodeSettingsChangeIBCodeError',\r\n adminTradingAccountSettingsIbCodeSettingsChangeIBCodeSuccess:\r\n 'adminTradingAccountSettingsIbCodeSettingsChangeIBCodeSuccess',\r\n adminTradingAccountSettingsIbCodeSettingsTitle: 'adminTradingAccountSettingsIbCodeSettingsTitle',\r\n adminTradingPlatformBrandingSettingsPriorityOrderTooltip: 'adminTradingPlatformBrandingSettingsPriorityOrderTooltip',\r\n adminTradingPlatformBrandingSettingsTitle: 'adminTradingPlatformBrandingSettingsTitle',\r\n adminUserAliasesBankHint: 'adminUserAliasesBankHint',\r\n adminUserColumnsFinanceBlockedBalance: 'adminUserColumnsFinanceBlockedBalance',\r\n adminUserColumnsFinanceDepositAmount: 'adminUserColumnsFinanceDepositAmount',\r\n adminUserColumnsFinanceDepositCount: 'adminUserColumnsFinanceDepositCount',\r\n adminUserColumnsFinanceNetDepositAmount: 'adminUserColumnsFinanceNetDepositAmount',\r\n adminUserColumnsFinancePaymentCategory: 'adminUserColumnsFinancePaymentCategory',\r\n adminUserColumnsFinancePaymentSystem: 'adminUserColumnsFinancePaymentSystem',\r\n adminUserColumnsFinanceWithdrawAmount: 'adminUserColumnsFinanceWithdrawAmount',\r\n adminUserColumnsFinanceWithdrawCount: 'adminUserColumnsFinanceWithdrawCount',\r\n adminUserFieldsArchivingSettingsIsAllowed: 'adminUserFieldsArchivingSettingsIsAllowed',\r\n adminUserFieldsAutoapproved: 'adminUserFieldsAutoapproved',\r\n adminUserFieldsCommissionSettingsProfitShareLevel: 'adminUserFieldsCommissionSettingsProfitShareLevel',\r\n adminUserFieldsCommissionSettingsRebateLevel: 'adminUserFieldsCommissionSettingsRebateLevel',\r\n adminUserFieldsDepositWithdrawalSettingsDepositSettings: 'adminUserFieldsDepositWithdrawalSettingsDepositSettings',\r\n adminUserFieldsDepositWithdrawalSettingsInternalTransferSettings:\r\n 'adminUserFieldsDepositWithdrawalSettingsInternalTransferSettings',\r\n adminUserFieldsDepositWithdrawalSettingsIsAllowed: 'adminUserFieldsDepositWithdrawalSettingsIsAllowed',\r\n adminUserFieldsDepositWithdrawalSettingsIsAllowedOnWeekend:\r\n 'adminUserFieldsDepositWithdrawalSettingsIsAllowedOnWeekend',\r\n adminUserFieldsDepositWithdrawalSettingsWithdrawalSettings:\r\n 'adminUserFieldsDepositWithdrawalSettingsWithdrawalSettings',\r\n adminUserFieldsIsBusinessManager: 'adminUserFieldsIsBusinessManager',\r\n adminUserFieldsIsMam: 'adminUserFieldsIsMam',\r\n adminUserFieldsIsSalesUser: 'adminUserFieldsIsSalesUser',\r\n adminUserFieldsOTPSettingsBypassOtpHint: 'adminUserFieldsOTPSettingsBypassOtpHint',\r\n adminUserFieldsOTPSettingsBypassOtpSingleTimeHint: 'adminUserFieldsOTPSettingsBypassOtpSingleTimeHint',\r\n adminUserFieldsOTPSettingsBypassOtpSingleTimeTitle: 'adminUserFieldsOTPSettingsBypassOtpSingleTimeTitle',\r\n adminUserFieldsOTPSettingsBypassOtpTitle: 'adminUserFieldsOTPSettingsBypassOtpTitle',\r\n adminUserFieldsOneTimePasswordSettingsRequestOTPHint: 'adminUserFieldsOneTimePasswordSettingsRequestOTPHint',\r\n adminUserFieldsOneTimePasswordSettingsRequestOTPTitle: 'adminUserFieldsOneTimePasswordSettingsRequestOTPTitle',\r\n adminUserFieldsOtherUserSettingsIsEdgeMobileTradingEnabled:\r\n 'adminUserFieldsOtherUserSettingsIsEdgeMobileTradingEnabled',\r\n adminUserFieldsOtherUserSettingsIsEdgeWebTradingEnabled: 'adminUserFieldsOtherUserSettingsIsEdgeWebTradingEnabled',\r\n adminUserFieldsOtherUserSettingsIsSocialTradingEnabled: 'adminUserFieldsOtherUserSettingsIsSocialTradingEnabled',\r\n adminUserFieldsOtherUserSettingsTradingCentralAccess: 'adminUserFieldsOtherUserSettingsTradingCentralAccess',\r\n adminUserFieldsStaffSettingsIsStaff: 'adminUserFieldsStaffSettingsIsStaff',\r\n adminUserFieldsWalletCategorySettingsIsCheckWalletCategory:\r\n 'adminUserFieldsWalletCategorySettingsIsCheckWalletCategory',\r\n adminUserSettingsBdmCodeSettingsActionName: 'adminUserSettingsBdmCodeSettingsActionName',\r\n adminUserSettingsBdmCodeSettingsChangeBDMCodeError: 'adminUserSettingsBdmCodeSettingsChangeBDMCodeError',\r\n adminUserSettingsBdmCodeSettingsChangeBDMCodeSuccess: 'adminUserSettingsBdmCodeSettingsChangeBDMCodeSuccess',\r\n adminUserSettingsBdmCodeSettingsTitle: 'adminUserSettingsBdmCodeSettingsTitle',\r\n adminUserSettingsChangeAECodeActionName: 'adminUserSettingsChangeAECodeActionName',\r\n adminUserSettingsChangeAECodeChangeAECodeError: 'adminUserSettingsChangeAECodeChangeAECodeError',\r\n adminUserSettingsChangeAECodeChangeAECodeSuccess: 'adminUserSettingsChangeAECodeChangeAECodeSuccess',\r\n adminUserSettingsChangeAECodeTitle: 'adminUserSettingsChangeAECodeTitle',\r\n adminUserSettingsChangeEmailActionName: 'adminUserSettingsChangeEmailActionName',\r\n adminUserSettingsChangeEmailChangeEmailError: 'adminUserSettingsChangeEmailChangeEmailError',\r\n adminUserSettingsChangeEmailChangeEmailSuccess: 'adminUserSettingsChangeEmailChangeEmailSuccess',\r\n adminUserSettingsChangeEmailHint: 'adminUserSettingsChangeEmailHint',\r\n adminUserSettingsChangeEmailTitle: 'adminUserSettingsChangeEmailTitle',\r\n adminUserSettingsChangeNicknameActionName: 'adminUserSettingsChangeNicknameActionName',\r\n adminUserSettingsChangeNicknameChangeNicknameError: 'adminUserSettingsChangeNicknameChangeNicknameError',\r\n adminUserSettingsChangeNicknameChangeNicknameSuccess: 'adminUserSettingsChangeNicknameChangeNicknameSuccess',\r\n adminUserSettingsChangeNicknameTitle: 'adminUserSettingsChangeNicknameTitle',\r\n adminUserSettingsCommissionSettingsTitle: 'adminUserSettingsCommissionSettingsTitle',\r\n adminUserSettingsConvertToDirectActionConfirmationMessage:\r\n 'adminUserSettingsConvertToDirectActionConfirmationMessage',\r\n adminUserSettingsConvertToDirectActionName: 'adminUserSettingsConvertToDirectActionName',\r\n adminUserSettingsConvertToDirectDescriptionHeader: 'adminUserSettingsConvertToDirectDescriptionHeader',\r\n adminUserSettingsConvertToDirectDescriptionItemsEighth: 'adminUserSettingsConvertToDirectDescriptionItemsEighth',\r\n adminUserSettingsConvertToDirectDescriptionItemsFifth: 'adminUserSettingsConvertToDirectDescriptionItemsFifth',\r\n adminUserSettingsConvertToDirectDescriptionItemsFirst: 'adminUserSettingsConvertToDirectDescriptionItemsFirst',\r\n adminUserSettingsConvertToDirectDescriptionItemsFourth: 'adminUserSettingsConvertToDirectDescriptionItemsFourth',\r\n adminUserSettingsConvertToDirectDescriptionItemsSecond: 'adminUserSettingsConvertToDirectDescriptionItemsSecond',\r\n adminUserSettingsConvertToDirectDescriptionItemsSeventh: 'adminUserSettingsConvertToDirectDescriptionItemsSeventh',\r\n adminUserSettingsConvertToDirectDescriptionItemsSixth: 'adminUserSettingsConvertToDirectDescriptionItemsSixth',\r\n adminUserSettingsConvertToDirectDescriptionItemsThird: 'adminUserSettingsConvertToDirectDescriptionItemsThird',\r\n adminUserSettingsConvertToDirectRemoveAgentCodeHint: 'adminUserSettingsConvertToDirectRemoveAgentCodeHint',\r\n adminUserSettingsConvertToDirectRemovingAgentCodeField: 'adminUserSettingsConvertToDirectRemovingAgentCodeField',\r\n adminUserSettingsConvertToDirectTitle: 'adminUserSettingsConvertToDirectTitle',\r\n adminUserSettingsDeleteSettingsActionConfirmationMessage: 'adminUserSettingsDeleteSettingsActionConfirmationMessage',\r\n adminUserSettingsDeleteSettingsActionName: 'adminUserSettingsDeleteSettingsActionName',\r\n adminUserSettingsDeleteSettingsDeleteUserError: 'adminUserSettingsDeleteSettingsDeleteUserError',\r\n adminUserSettingsDeleteSettingsDeleteUserSuccess: 'adminUserSettingsDeleteSettingsDeleteUserSuccess',\r\n adminUserSettingsDeleteSettingsDescriptionHeader: 'adminUserSettingsDeleteSettingsDescriptionHeader',\r\n adminUserSettingsDeleteSettingsDescriptionItemsFirst: 'adminUserSettingsDeleteSettingsDescriptionItemsFirst',\r\n adminUserSettingsDeleteSettingsDescriptionItemsSecond: 'adminUserSettingsDeleteSettingsDescriptionItemsSecond',\r\n adminUserSettingsDeleteSettingsTitle: 'adminUserSettingsDeleteSettingsTitle',\r\n adminUserSettingsDepositWithdrawalSettingsTitle: 'adminUserSettingsDepositWithdrawalSettingsTitle',\r\n adminUserSettingsIbCodeSettingsActionName: 'adminUserSettingsIbCodeSettingsActionName',\r\n adminUserSettingsIbCodeSettingsChangeIBCodeError: 'adminUserSettingsIbCodeSettingsChangeIBCodeError',\r\n adminUserSettingsIbCodeSettingsChangeIBCodeSuccess: 'adminUserSettingsIbCodeSettingsChangeIBCodeSuccess',\r\n adminUserSettingsIbCodeSettingsHint: 'adminUserSettingsIbCodeSettingsHint',\r\n adminUserSettingsIbCodeSettingsTitle: 'adminUserSettingsIbCodeSettingsTitle',\r\n adminUserSettingsMamCodeSettingsActionName: 'adminUserSettingsMamCodeSettingsActionName',\r\n adminUserSettingsMamCodeSettingsChangeMAMCodeError: 'adminUserSettingsMamCodeSettingsChangeMAMCodeError',\r\n adminUserSettingsMamCodeSettingsChangeMAMCodeSuccess: 'adminUserSettingsMamCodeSettingsChangeMAMCodeSuccess',\r\n adminUserSettingsMamCodeSettingsTitle: 'adminUserSettingsMamCodeSettingsTitle',\r\n adminUserSettingsOneTimePasswordSettingsTitle: 'adminUserSettingsOneTimePasswordSettingsTitle',\r\n adminUserSettingsOtherUserSettingsTitle: 'adminUserSettingsOtherUserSettingsTitle',\r\n adminUserSettingsOverrideEmailActionName: 'adminUserSettingsOverrideEmailActionName',\r\n adminUserSettingsOverrideEmailChangeEmailError: 'adminUserSettingsOverrideEmailChangeEmailError',\r\n adminUserSettingsOverrideEmailChangeEmailSuccess: 'adminUserSettingsOverrideEmailChangeEmailSuccess',\r\n adminUserSettingsOverrideEmailHint: 'adminUserSettingsOverrideEmailHint',\r\n adminUserSettingsOverrideEmailTitle: 'adminUserSettingsOverrideEmailTitle',\r\n adminUserSettingsParentIbSettingsActionName: 'adminUserSettingsParentIbSettingsActionName',\r\n adminUserSettingsParentIbSettingsSetParenIbError: 'adminUserSettingsParentIbSettingsSetParenIbError',\r\n adminUserSettingsParentIbSettingsSetParenIbSuccess: 'adminUserSettingsParentIbSettingsSetParenIbSuccess',\r\n adminUserSettingsParentIbSettingsTitle: 'adminUserSettingsParentIbSettingsTitle',\r\n adminUserSettingsPasswordSettingsResetPasswordActionName: 'adminUserSettingsPasswordSettingsResetPasswordActionName',\r\n adminUserSettingsPasswordSettingsResetPasswordError: 'adminUserSettingsPasswordSettingsResetPasswordError',\r\n adminUserSettingsPasswordSettingsResetPasswordHint: 'adminUserSettingsPasswordSettingsResetPasswordHint',\r\n adminUserSettingsPasswordSettingsResetPasswordSuccess: 'adminUserSettingsPasswordSettingsResetPasswordSuccess',\r\n adminUserSettingsPasswordSettingsResetPasswordTitle: 'adminUserSettingsPasswordSettingsResetPasswordTitle',\r\n adminUserSettingsPasswordSettingsSetPasswordActionName: 'adminUserSettingsPasswordSettingsSetPasswordActionName',\r\n adminUserSettingsPasswordSettingsSetPasswordHint: 'adminUserSettingsPasswordSettingsSetPasswordHint',\r\n adminUserSettingsPasswordSettingsSetPasswordSetPasswordError:\r\n 'adminUserSettingsPasswordSettingsSetPasswordSetPasswordError',\r\n adminUserSettingsPasswordSettingsSetPasswordSetPasswordSuccess:\r\n 'adminUserSettingsPasswordSettingsSetPasswordSetPasswordSuccess',\r\n adminUserSettingsPasswordSettingsSetPasswordTitle: 'adminUserSettingsPasswordSettingsSetPasswordTitle',\r\n adminUserSettingsPinCodeSettingsGeneratePinCodeActionName:\r\n 'adminUserSettingsPinCodeSettingsGeneratePinCodeActionName',\r\n adminUserSettingsPinCodeSettingsGeneratePinCodeGeneratePinCodeError:\r\n 'adminUserSettingsPinCodeSettingsGeneratePinCodeGeneratePinCodeError',\r\n adminUserSettingsPinCodeSettingsGeneratePinCodeGeneratePinCodeSuccess:\r\n 'adminUserSettingsPinCodeSettingsGeneratePinCodeGeneratePinCodeSuccess',\r\n adminUserSettingsPinCodeSettingsGeneratePinCodeHint: 'adminUserSettingsPinCodeSettingsGeneratePinCodeHint',\r\n adminUserSettingsPinCodeSettingsGeneratePinCodeTitle: 'adminUserSettingsPinCodeSettingsGeneratePinCodeTitle',\r\n adminUserSettingsPinCodeSettingsResetPinCodeActionName: 'adminUserSettingsPinCodeSettingsResetPinCodeActionName',\r\n adminUserSettingsPinCodeSettingsResetPinCodeHint: 'adminUserSettingsPinCodeSettingsResetPinCodeHint',\r\n adminUserSettingsPinCodeSettingsResetPinCodeResetPinCodeError:\r\n 'adminUserSettingsPinCodeSettingsResetPinCodeResetPinCodeError',\r\n adminUserSettingsPinCodeSettingsResetPinCodeResetPinCodeSuccess:\r\n 'adminUserSettingsPinCodeSettingsResetPinCodeResetPinCodeSuccess',\r\n adminUserSettingsPinCodeSettingsResetPinCodeTitle: 'adminUserSettingsPinCodeSettingsResetPinCodeTitle',\r\n adminUserSettingsPspFeeSettingsDaysWindow: 'adminUserSettingsPspFeeSettingsDaysWindow',\r\n adminUserSettingsPspFeeSettingsFeeCurrency: 'adminUserSettingsPspFeeSettingsFeeCurrency',\r\n adminUserSettingsPspFeeSettingsNumberOfOperations: 'adminUserSettingsPspFeeSettingsNumberOfOperations',\r\n adminUserSettingsPspFeeSettingsNumberOfOperationsComparison:\r\n 'adminUserSettingsPspFeeSettingsNumberOfOperationsComparison',\r\n adminUserSettingsPspFeeSettingsOperationAmount: 'adminUserSettingsPspFeeSettingsOperationAmount',\r\n adminUserSettingsPspFeeSettingsOperationAmountComparison: 'adminUserSettingsPspFeeSettingsOperationAmountComparison',\r\n adminUserSettingsPspFeeSettingsRate: 'adminUserSettingsPspFeeSettingsRate',\r\n adminUserSettingsPspFeeSettingsTitle: 'adminUserSettingsPspFeeSettingsTitle',\r\n adminUserSettingsRemoveAECodeActionName: 'adminUserSettingsRemoveAECodeActionName',\r\n adminUserSettingsRemoveAECodeRemoveAECodeError: 'adminUserSettingsRemoveAECodeRemoveAECodeError',\r\n adminUserSettingsRemoveAECodeRemoveAECodeSuccess: 'adminUserSettingsRemoveAECodeRemoveAECodeSuccess',\r\n adminUserSettingsRemoveAECodeTitle: 'adminUserSettingsRemoveAECodeTitle',\r\n adminUserSettingsRestoreSettingsActionConfirmationMessage:\r\n 'adminUserSettingsRestoreSettingsActionConfirmationMessage',\r\n adminUserSettingsRestoreSettingsActionName: 'adminUserSettingsRestoreSettingsActionName',\r\n adminUserSettingsRestoreSettingsDescriptionHeader: 'adminUserSettingsRestoreSettingsDescriptionHeader',\r\n adminUserSettingsRestoreSettingsDescriptionItemsFirst: 'adminUserSettingsRestoreSettingsDescriptionItemsFirst',\r\n adminUserSettingsRestoreSettingsDescriptionItemsSecond: 'adminUserSettingsRestoreSettingsDescriptionItemsSecond',\r\n adminUserSettingsRestoreSettingsRestoreUserError: 'adminUserSettingsRestoreSettingsRestoreUserError',\r\n adminUserSettingsRestoreSettingsRestoreUserSuccess: 'adminUserSettingsRestoreSettingsRestoreUserSuccess',\r\n adminUserSettingsRestoreSettingsTitle: 'adminUserSettingsRestoreSettingsTitle',\r\n adminUserSettingsWalletCategorySettingsTitle: 'adminUserSettingsWalletCategorySettingsTitle',\r\n adminUserTradingAccountTypeLimitLeverages: 'adminUserTradingAccountTypeLimitLeverages',\r\n adminUserTradingAccountTypeLimitMaxNumber: 'adminUserTradingAccountTypeLimitMaxNumber',\r\n adminUserTradingAccountTypeLimitTitle: 'adminUserTradingAccountTypeLimitTitle',\r\n adminUserTradingAccountTypeLimitUserType: 'adminUserTradingAccountTypeLimitUserType',\r\n adminUserTradingAccountTypeLimitUserTypeHint: 'adminUserTradingAccountTypeLimitUserTypeHint',\r\n areYouSureYouWantToLeavePageWithoutSavingQuestion: 'areYouSureYouWantToLeavePageWithoutSavingQuestion',\r\n assignedToMe: 'assignedToMe',\r\n autoSuggestionFieldsBusinessManager: 'autoSuggestionFieldsBusinessManager',\r\n autoSuggestionFieldsIb: 'autoSuggestionFieldsIb',\r\n autoSuggestionFieldsNoMatchMessage: 'autoSuggestionFieldsNoMatchMessage',\r\n autoSuggestionFieldsSalesUser: 'autoSuggestionFieldsSalesUser',\r\n autoSuggestionFieldsUser: 'autoSuggestionFieldsUser',\r\n availableCountriesAllCountriesHintMessage: 'availableCountriesAllCountriesHintMessage',\r\n availableCountriesFieldsState: 'availableCountriesFieldsState',\r\n backgroundJobsFieldsQueue: 'backgroundJobsFieldsQueue',\r\n backgroundJobsHistoryActionsRepeat: 'backgroundJobsHistoryActionsRepeat',\r\n backgroundJobsHistoryDetailsPageTitle: 'backgroundJobsHistoryDetailsPageTitle',\r\n backgroundJobsHistoryFieldsCompletedOn: 'backgroundJobsHistoryFieldsCompletedOn',\r\n backgroundJobsHistoryFieldsDuration: 'backgroundJobsHistoryFieldsDuration',\r\n backgroundJobsHistoryFieldsError: 'backgroundJobsHistoryFieldsError',\r\n backgroundJobsHistoryFieldsExternalJobId: 'backgroundJobsHistoryFieldsExternalJobId',\r\n backgroundJobsHistoryFieldsParameters: 'backgroundJobsHistoryFieldsParameters',\r\n backgroundJobsHistoryFieldsRetryAttempt: 'backgroundJobsHistoryFieldsRetryAttempt',\r\n backgroundJobsHistoryFieldsScheduledOn: 'backgroundJobsHistoryFieldsScheduledOn',\r\n backgroundJobsHistoryFieldsStartedOn: 'backgroundJobsHistoryFieldsStartedOn',\r\n backgroundJobsHistoryGridPageTitle: 'backgroundJobsHistoryGridPageTitle',\r\n backgroundJobsHistoryMessagesFeatureDisabled: 'backgroundJobsHistoryMessagesFeatureDisabled',\r\n backgroundJobsHistoryMessagesRepeatError: 'backgroundJobsHistoryMessagesRepeatError',\r\n backgroundJobsHistoryMessagesRepeatedSuccessfully: 'backgroundJobsHistoryMessagesRepeatedSuccessfully',\r\n backgroundJobsHistoryMessagesWasNotRepeated: 'backgroundJobsHistoryMessagesWasNotRepeated',\r\n backgroundJobsHistoryTabName: 'backgroundJobsHistoryTabName',\r\n backgroundJobsRecurringFieldsLastExecution: 'backgroundJobsRecurringFieldsLastExecution',\r\n backgroundJobsRecurringFieldsNextExecution: 'backgroundJobsRecurringFieldsNextExecution',\r\n backgroundJobsRecurringFieldsSchedule: 'backgroundJobsRecurringFieldsSchedule',\r\n backgroundJobsRecurringRescheduleButtonText: 'backgroundJobsRecurringRescheduleButtonText',\r\n backgroundJobsRecurringRescheduleConfirmationText: 'backgroundJobsRecurringRescheduleConfirmationText',\r\n bonusProgram: 'bonusProgram',\r\n bonusesAvailableTableAvailableBonuses: 'bonusesAvailableTableAvailableBonuses',\r\n bonusesAvailableTableBonusName: 'bonusesAvailableTableBonusName',\r\n bonusesAvailableTableTimeLeftToDeposit: 'bonusesAvailableTableTimeLeftToDeposit',\r\n bonusesConfirmBonus: 'bonusesConfirmBonus',\r\n bonusesFileFormatHintMessage: 'bonusesFileFormatHintMessage',\r\n bonusesInfinity: 'bonusesInfinity',\r\n bonusesTitle: 'bonusesTitle',\r\n bonusesTypeTableBonusLimit: 'bonusesTypeTableBonusLimit',\r\n bonusesTypeTableBonusName: 'bonusesTypeTableBonusName',\r\n bonusesTypeTableTitle: 'bonusesTypeTableTitle',\r\n bonusesTypeTableTotalAdded: 'bonusesTypeTableTotalAdded',\r\n bonusesTypeTableTotalAvailable: 'bonusesTypeTableTotalAvailable',\r\n bonusesUserTableAvailableTill: 'bonusesUserTableAvailableTill',\r\n bonusesUserTableBonusAmount: 'bonusesUserTableBonusAmount',\r\n bonusesUserTableBonusName: 'bonusesUserTableBonusName',\r\n bonusesUserTablePaymentId: 'bonusesUserTablePaymentId',\r\n bonusesUserTablePspAmount: 'bonusesUserTablePspAmount',\r\n bonusesUserTablePspAmountUSD: 'bonusesUserTablePspAmountUSD',\r\n bonusesUserTablePublicCommentMeta: 'bonusesUserTablePublicCommentMeta',\r\n bonusesUserTableShowWithExpiration: 'bonusesUserTableShowWithExpiration',\r\n bonusesUserTableTitle: 'bonusesUserTableTitle',\r\n bonusesViewAllBonuses: 'bonusesViewAllBonuses',\r\n bulkActionStatus: 'bulkActionStatus',\r\n byCopyingNewMasterYouWillAutomaticallyStopCopyingMaster: 'byCopyingNewMasterYouWillAutomaticallyStopCopyingMaster',\r\n chartTitlesNoData: 'chartTitlesNoData',\r\n chartTitlesProfitabilityTitle: 'chartTitlesProfitabilityTitle',\r\n chartTitlesProfitabilityTooltip: 'chartTitlesProfitabilityTooltip',\r\n chartTitlesTradingTitle: 'chartTitlesTradingTitle',\r\n chartTitlesTradingVolumeLotTitle: 'chartTitlesTradingVolumeLotTitle',\r\n chartTitlesTradingVolumeLotTooltip: 'chartTitlesTradingVolumeLotTooltip',\r\n chartTitlesTradingVolumeUscTitle: 'chartTitlesTradingVolumeUscTitle',\r\n chartTitlesTradingVolumeUscTooltip: 'chartTitlesTradingVolumeUscTooltip',\r\n chartTitlesTradingVolumeUsdTitle: 'chartTitlesTradingVolumeUsdTitle',\r\n chartTitlesTradingVolumeUsdTooltip: 'chartTitlesTradingVolumeUsdTooltip',\r\n commonAccountNumber: 'commonAccountNumber',\r\n commonAction: 'commonAction',\r\n commonAll: 'commonAll',\r\n commonApply: 'commonApply',\r\n commonBalance: 'commonBalance',\r\n commonBeneficiaryBank: 'commonBeneficiaryBank',\r\n commonBeneficiaryName: 'commonBeneficiaryName',\r\n commonBlockedBalance: 'commonBlockedBalance',\r\n commonButton: 'commonButton',\r\n commonClassName: 'commonClassName',\r\n commonClose: 'commonClose',\r\n commonContent: 'commonContent',\r\n commonCredit: 'commonCredit',\r\n commonCustom: 'commonCustom',\r\n commonDate: 'commonDate',\r\n commonDearUserName: 'commonDearUserName',\r\n commonDeposit: 'commonDeposit',\r\n commonDescription: 'commonDescription',\r\n commonDigitalWallet: 'commonDigitalWallet',\r\n commonDocumentsCaps: 'commonDocumentsCaps',\r\n commonDragAndDropPlaceholder: 'commonDragAndDropPlaceholder',\r\n commonDuration: 'commonDuration',\r\n commonDurationEndsIn: 'commonDurationEndsIn',\r\n commonDurationInDays: 'commonDurationInDays',\r\n commonDurationInHours: 'commonDurationInHours',\r\n commonDurationInMinutes: 'commonDurationInMinutes',\r\n commonEWallet: 'commonEWallet',\r\n commonEnableField: 'commonEnableField',\r\n commonEndDate: 'commonEndDate',\r\n commonEquity: 'commonEquity',\r\n commonFailed: 'commonFailed',\r\n commonFreeMargin: 'commonFreeMargin',\r\n commonFrom: 'commonFrom',\r\n commonHistory: 'commonHistory',\r\n commonIPAddress: 'commonIPAddress',\r\n commonImage: 'commonImage',\r\n commonImageUploading: 'commonImageUploading',\r\n commonJoin: 'commonJoin',\r\n commonLastNdays: 'commonLastNdays',\r\n commonLeverage: 'commonLeverage',\r\n commonLink: 'commonLink',\r\n commonMargin: 'commonMargin',\r\n commonMaxSizeMb: 'commonMaxSizeMb',\r\n commonMore: 'commonMore',\r\n commonNewButton: 'commonNewButton',\r\n commonNoResults: 'commonNoResults',\r\n commonNote: 'commonNote',\r\n commonParticipant: 'commonParticipant',\r\n commonParticipants: 'commonParticipants',\r\n commonPaymentSystem: 'commonPaymentSystem',\r\n commonPlatformType: 'commonPlatformType',\r\n commonPleaseInputImageUrl: 'commonPleaseInputImageUrl',\r\n commonPleaseNote: 'commonPleaseNote',\r\n commonPreview: 'commonPreview',\r\n commonProcessor: 'commonProcessor',\r\n commonReadMore: 'commonReadMore',\r\n commonResendNow: 'commonResendNow',\r\n commonRole: 'commonRole',\r\n commonSelectRange: 'commonSelectRange',\r\n commonSendItAgainInSeconds: 'commonSendItAgainInSeconds',\r\n commonStartDate: 'commonStartDate',\r\n commonStatus: 'commonStatus',\r\n commonSuccess: 'commonSuccess',\r\n commonText: 'commonText',\r\n commonThisMonth: 'commonThisMonth',\r\n commonThisWeek: 'commonThisWeek',\r\n commonTime: 'commonTime',\r\n commonTo: 'commonTo',\r\n commonToday: 'commonToday',\r\n commonToken: 'commonToken',\r\n commonTotal: 'commonTotal',\r\n commonTrade: 'commonTrade',\r\n commonTradingSymbols: 'commonTradingSymbols',\r\n commonUrl: 'commonUrl',\r\n commonUser: 'commonUser',\r\n commonUserSignature: 'commonUserSignature',\r\n commonValueMustBeInteger: 'commonValueMustBeInteger',\r\n commonVisible: 'commonVisible',\r\n commonWarningMessageBulkOperationInfo: 'commonWarningMessageBulkOperationInfo',\r\n commonWarningMessageCommentBulkOperation: 'commonWarningMessageCommentBulkOperation',\r\n commonWithdrawal: 'commonWithdrawal',\r\n commonYesterday: 'commonYesterday',\r\n companyAccountBankName: 'companyAccountBankName',\r\n companyAccountLegalEntity: 'companyAccountLegalEntity',\r\n companyAccountLegalEntityName: 'companyAccountLegalEntityName',\r\n companyTransferBeneficiaryCurrency: 'companyTransferBeneficiaryCurrency',\r\n companyTransferDate: 'companyTransferDate',\r\n companyTransferInitialBankRequest: 'companyTransferInitialBankRequest',\r\n companyTransferIntercompanyTransfer: 'companyTransferIntercompanyTransfer',\r\n companyTransferIsBankRequestExists: 'companyTransferIsBankRequestExists',\r\n companyTransferOurResponse: 'companyTransferOurResponse',\r\n companyTransferReceiverAmount: 'companyTransferReceiverAmount',\r\n companyTransferSenderAmount: 'companyTransferSenderAmount',\r\n companyTransferSenderBank: 'companyTransferSenderBank',\r\n companyTransferSenderCurrency: 'companyTransferSenderCurrency',\r\n companyTransferSenderName: 'companyTransferSenderName',\r\n componentsClass: 'componentsClass',\r\n componentsInterface: 'componentsInterface',\r\n componentsLabel: 'componentsLabel',\r\n componentsName: 'componentsName',\r\n componentsParameters: 'componentsParameters',\r\n copyToClipboardFailed: 'copyToClipboardFailed',\r\n copyTradeAllocationModeDeterminesHowFollowersReplicate: 'copyTradeAllocationModeDeterminesHowFollowersReplicate',\r\n copyTradingAverageDrawDownTitle: 'copyTradingAverageDrawDownTitle',\r\n copyTradingAverageDrawDownTooltip: 'copyTradingAverageDrawDownTooltip',\r\n copyTradingCommissionAccount: 'copyTradingCommissionAccount',\r\n copyTradingInvestor: 'copyTradingInvestor',\r\n copyTradingIsVisible: 'copyTradingIsVisible',\r\n copyTradingMakeMinDepositAmountRequiredHint: 'copyTradingMakeMinDepositAmountRequiredHint',\r\n copyTradingMakeMinDepositAmountRequiredTitle: 'copyTradingMakeMinDepositAmountRequiredTitle',\r\n copyTradingMaster: 'copyTradingMaster',\r\n copyTradingMasterForCopy: 'copyTradingMasterForCopy',\r\n copyTradingMasterNickname: 'copyTradingMasterNickname',\r\n copyTradingMastersRating: 'copyTradingMastersRating',\r\n copyTradingMastersRatingFootnote: 'copyTradingMastersRatingFootnote',\r\n copyTradingMaxDrawDownTitle: 'copyTradingMaxDrawDownTitle',\r\n copyTradingMaxDrawDownTooltip: 'copyTradingMaxDrawDownTooltip',\r\n copyTradingMinDepositAmountTitle: 'copyTradingMinDepositAmountTitle',\r\n copyTradingProfitSharingTitle: 'copyTradingProfitSharingTitle',\r\n copyTradingProfitSharingTooltip: 'copyTradingProfitSharingTooltip',\r\n copyTradingReturnOnInvestmentTitle: 'copyTradingReturnOnInvestmentTitle',\r\n copyTradingReturnOnInvestmentTooltip: 'copyTradingReturnOnInvestmentTooltip',\r\n copyTradingSelfTrade: 'copyTradingSelfTrade',\r\n copyTradingTotalFundsTitle: 'copyTradingTotalFundsTitle',\r\n copyTradingTotalFundsTooltip: 'copyTradingTotalFundsTooltip',\r\n copying: 'copying',\r\n countrySupportGuardContinueBrowsing: 'countrySupportGuardContinueBrowsing',\r\n countrySupportGuardSubTitleOne: 'countrySupportGuardSubTitleOne',\r\n countrySupportGuardSubTitleThree: 'countrySupportGuardSubTitleThree',\r\n countrySupportGuardSubTitleTwo: 'countrySupportGuardSubTitleTwo',\r\n countrySupportGuardTitle: 'countrySupportGuardTitle',\r\n customNotificationCancelConfirmationMsg: 'customNotificationCancelConfirmationMsg',\r\n customNotificationEmailCategory: 'customNotificationEmailCategory',\r\n customNotificationFailed: 'customNotificationFailed',\r\n customNotificationRead: 'customNotificationRead',\r\n customNotificationRetryConfirmationMsg: 'customNotificationRetryConfirmationMsg',\r\n customNotificationSent: 'customNotificationSent',\r\n customNotificationTotal: 'customNotificationTotal',\r\n customPushNotificationCancelConfirmationMsg: 'customPushNotificationCancelConfirmationMsg',\r\n customPushNotificationFieldHint: 'customPushNotificationFieldHint',\r\n customPushNotificationRetryConfirmationMsg: 'customPushNotificationRetryConfirmationMsg',\r\n dashboardAdmin: 'dashboardAdmin',\r\n dataChangeRequest: 'dataChangeRequest',\r\n dataChangeRequestCurrentData: 'dataChangeRequestCurrentData',\r\n dataChangeRequestNewData: 'dataChangeRequestNewData',\r\n dataChangeRequests: 'dataChangeRequests',\r\n dataImportFileItemTooltip: 'dataImportFileItemTooltip',\r\n dataImportImportMode: 'dataImportImportMode',\r\n dataImportLogMessage: 'dataImportLogMessage',\r\n dataImportTypeTooltip: 'dataImportTypeTooltip',\r\n depositFinancialIdentityType: 'depositFinancialIdentityType',\r\n doYouReallyWantToReAsssignAllUsersToNewSalesUserQuestion: 'doYouReallyWantToReAsssignAllUsersToNewSalesUserQuestion',\r\n doYouReallyWantToReAsssignUsersToNewSalesUserQuestion: 'doYouReallyWantToReAsssignUsersToNewSalesUserQuestion',\r\n documentOpenFullSize: 'documentOpenFullSize',\r\n documentTypeConfigBankStatementTitle: 'documentTypeConfigBankStatementTitle',\r\n documentViewerLoadingError: 'documentViewerLoadingError',\r\n documentViewerPasswordError: 'documentViewerPasswordError',\r\n educationPortalAvailableLanguages: 'educationPortalAvailableLanguages',\r\n educationPortalEducationVideoTitle: 'educationPortalEducationVideoTitle',\r\n educationPortalRelatedVideos: 'educationPortalRelatedVideos',\r\n emailTemlateStyleWidth: 'emailTemlateStyleWidth',\r\n emailTemplateArchivedTemplates: 'emailTemplateArchivedTemplates',\r\n emailTemplateBottom: 'emailTemplateBottom',\r\n emailTemplateCenter: 'emailTemplateCenter',\r\n emailTemplateColumn: 'emailTemplateColumn',\r\n emailTemplateContainer: 'emailTemplateContainer',\r\n emailTemplateDesktop: 'emailTemplateDesktop',\r\n emailTemplateEditor: 'emailTemplateEditor',\r\n emailTemplateEmailTemplate: 'emailTemplateEmailTemplate',\r\n emailTemplateEmailTemplates: 'emailTemplateEmailTemplates',\r\n emailTemplateGallerySelectImage: 'emailTemplateGallerySelectImage',\r\n emailTemplateGoToEditor: 'emailTemplateGoToEditor',\r\n emailTemplateImageAlt: 'emailTemplateImageAlt',\r\n emailTemplateImagePlaceholder: 'emailTemplateImagePlaceholder',\r\n emailTemplateLeft: 'emailTemplateLeft',\r\n emailTemplateMobile: 'emailTemplateMobile',\r\n emailTemplateRight: 'emailTemplateRight',\r\n emailTemplateRow: 'emailTemplateRow',\r\n emailTemplateSaveTemplate: 'emailTemplateSaveTemplate',\r\n emailTemplateSection: 'emailTemplateSection',\r\n emailTemplateStyleBackgroundColor: 'emailTemplateStyleBackgroundColor',\r\n emailTemplateStyleBorderRadius: 'emailTemplateStyleBorderRadius',\r\n emailTemplateStyleFontColor: 'emailTemplateStyleFontColor',\r\n emailTemplateStyleFontSize: 'emailTemplateStyleFontSize',\r\n emailTemplateStyleHeight: 'emailTemplateStyleHeight',\r\n emailTemplateStyleHeightPlaceholder: 'emailTemplateStyleHeightPlaceholder',\r\n emailTemplateStylePadding: 'emailTemplateStylePadding',\r\n emailTemplateStyleTextAlign: 'emailTemplateStyleTextAlign',\r\n emailTemplateStyleWidthPlaceholder: 'emailTemplateStyleWidthPlaceholder',\r\n emailTemplateStyles: 'emailTemplateStyles',\r\n emailTemplateTop: 'emailTemplateTop',\r\n errorsCaptchaCaptchaServerIsUnavailable: 'errorsCaptchaCaptchaServerIsUnavailable',\r\n errorsUserCantChangeLanguage: 'errorsUserCantChangeLanguage',\r\n ewalletBalanceAfter: 'ewalletBalanceAfter',\r\n ewalletBalanceBefore: 'ewalletBalanceBefore',\r\n ewalletBlockedBalance: 'ewalletBlockedBalance',\r\n ewalletBlockedBalanceAfter: 'ewalletBlockedBalanceAfter',\r\n ewalletBlockedBalanceBefore: 'ewalletBlockedBalanceBefore',\r\n ewalletDescription: 'ewalletDescription',\r\n ewalletEwalletTitle: 'ewalletEwalletTitle',\r\n ewalletExecutionType: 'ewalletExecutionType',\r\n ewalletHistoryTitle: 'ewalletHistoryTitle',\r\n ewalletOpertionDetailsTitle: 'ewalletOpertionDetailsTitle',\r\n ewalletTransferType: 'ewalletTransferType',\r\n ewalletWalletAccountId: 'ewalletWalletAccountId',\r\n ewalletWalletAccountType: 'ewalletWalletAccountType',\r\n ewalletWalletNumber: 'ewalletWalletNumber',\r\n ewalletWalletOperationId: 'ewalletWalletOperationId',\r\n fileImportFieldsCreatedCount: 'fileImportFieldsCreatedCount',\r\n fileImportFieldsFailedCount: 'fileImportFieldsFailedCount',\r\n fileImportFieldsShowLogAction: 'fileImportFieldsShowLogAction',\r\n fileImportFieldsUpdatedCount: 'fileImportFieldsUpdatedCount',\r\n filterOperatorDescriptionEnumOrEnumAsStringEndWith: 'filterOperatorDescriptionEnumOrEnumAsStringEndWith',\r\n filterOperatorDescriptionEnumOrEnumAsStringEqual: 'filterOperatorDescriptionEnumOrEnumAsStringEqual',\r\n filterOperatorDescriptionEnumOrEnumAsStringIn: 'filterOperatorDescriptionEnumOrEnumAsStringIn',\r\n filterOperatorDescriptionEnumOrEnumAsStringIsNotNull: 'filterOperatorDescriptionEnumOrEnumAsStringIsNotNull',\r\n filterOperatorDescriptionEnumOrEnumAsStringIsNotNullOrEmpty:\r\n 'filterOperatorDescriptionEnumOrEnumAsStringIsNotNullOrEmpty',\r\n filterOperatorDescriptionEnumOrEnumAsStringIsNull: 'filterOperatorDescriptionEnumOrEnumAsStringIsNull',\r\n filterOperatorDescriptionEnumOrEnumAsStringIsNullOrEmpty: 'filterOperatorDescriptionEnumOrEnumAsStringIsNullOrEmpty',\r\n filterOperatorDescriptionEnumOrEnumAsStringLike: 'filterOperatorDescriptionEnumOrEnumAsStringLike',\r\n filterOperatorDescriptionEnumOrEnumAsStringNotEqual: 'filterOperatorDescriptionEnumOrEnumAsStringNotEqual',\r\n filterOperatorDescriptionEnumOrEnumAsStringNotIn: 'filterOperatorDescriptionEnumOrEnumAsStringNotIn',\r\n filterOperatorDescriptionEnumOrEnumAsStringStartWith: 'filterOperatorDescriptionEnumOrEnumAsStringStartWith',\r\n financialIdentityType: 'financialIdentityType',\r\n followUpDescriptionValidation: 'followUpDescriptionValidation',\r\n followUpErrorFailedToGetDeclineReason: 'followUpErrorFailedToGetDeclineReason',\r\n formValidationLimitValidation: 'formValidationLimitValidation',\r\n formatsFormatNumber: 'formatsFormatNumber',\r\n formsBrowse: 'formsBrowse',\r\n formsChoose: 'formsChoose',\r\n formsChooseFile: 'formsChooseFile',\r\n formsCreateNew: 'formsCreateNew',\r\n formsDataRangeAllOption: 'formsDataRangeAllOption',\r\n formsDataRangeCurrentDayOption: 'formsDataRangeCurrentDayOption',\r\n formsDataRangeCurrentMonthOption: 'formsDataRangeCurrentMonthOption',\r\n formsDataRangeCustomOption: 'formsDataRangeCustomOption',\r\n formsDataRangePastDayOption: 'formsDataRangePastDayOption',\r\n formsDataRangePastMonthOption: 'formsDataRangePastMonthOption',\r\n formsDatePlaceholdersDay: 'formsDatePlaceholdersDay',\r\n formsDatePlaceholdersMonth: 'formsDatePlaceholdersMonth',\r\n formsDatePlaceholdersYear: 'formsDatePlaceholdersYear',\r\n formsExport: 'formsExport',\r\n formsFilter: 'formsFilter',\r\n formsFrom: 'formsFrom',\r\n formsInputTooltipsIbCode: 'formsInputTooltipsIbCode',\r\n formsMax: 'formsMax',\r\n formsMin: 'formsMin',\r\n formsPasswordStrengthHasLowercase: 'formsPasswordStrengthHasLowercase',\r\n formsPasswordStrengthHasNumber: 'formsPasswordStrengthHasNumber',\r\n formsPasswordStrengthHasSpecialCharacters: 'formsPasswordStrengthHasSpecialCharacters',\r\n formsPasswordStrengthHasUppercase: 'formsPasswordStrengthHasUppercase',\r\n formsPasswordStrengthMinLength: 'formsPasswordStrengthMinLength',\r\n formsPlaceholdersNameOrEmail: 'formsPlaceholdersNameOrEmail',\r\n formsPlaceholdersTypeNumber: 'formsPlaceholdersTypeNumber',\r\n formsPlaceholdersTypeText: 'formsPlaceholdersTypeText',\r\n formsSearch: 'formsSearch',\r\n formsSegmentedSelectorOptionAll: 'formsSegmentedSelectorOptionAll',\r\n formsSelect: 'formsSelect',\r\n formsTo: 'formsTo',\r\n formsValidationBeneficiaryAccountFieldError: 'formsValidationBeneficiaryAccountFieldError',\r\n formsValidationBeneficiaryAccountFieldErrorWithLength: 'formsValidationBeneficiaryAccountFieldErrorWithLength',\r\n formsValidationConfirmError: 'formsValidationConfirmError',\r\n formsValidationDateTimeError: 'formsValidationDateTimeError',\r\n formsValidationDigitsOnlyError: 'formsValidationDigitsOnlyError',\r\n formsValidationEightCharactersLong: 'formsValidationEightCharactersLong',\r\n formsValidationEmailError: 'formsValidationEmailError',\r\n formsValidationFieldIsNotFilledIn: 'formsValidationFieldIsNotFilledIn',\r\n formsValidationFirstNameOnlyChineseCharacters: 'formsValidationFirstNameOnlyChineseCharacters',\r\n formsValidationFullNameOnlyChineseCharacters: 'formsValidationFullNameOnlyChineseCharacters',\r\n formsValidationIfscFieldError: 'formsValidationIfscFieldError',\r\n formsValidationInt32Error: 'formsValidationInt32Error',\r\n formsValidationInvalidDate: 'formsValidationInvalidDate',\r\n formsValidationInvalidNumericValue: 'formsValidationInvalidNumericValue',\r\n formsValidationLastNameOnlyChineseCharacters: 'formsValidationLastNameOnlyChineseCharacters',\r\n formsValidationMapError: 'formsValidationMapError',\r\n formsValidationNewPasswordDifferFromOldOne: 'formsValidationNewPasswordDifferFromOldOne',\r\n formsValidationNewPasswordIsDifferent: 'formsValidationNewPasswordIsDifferent',\r\n formsValidationNoWhitespaceCharsError: 'formsValidationNoWhitespaceCharsError',\r\n formsValidationOneLowercaseLetter: 'formsValidationOneLowercaseLetter',\r\n formsValidationOneNumber: 'formsValidationOneNumber',\r\n formsValidationOneSpecialSymbol: 'formsValidationOneSpecialSymbol',\r\n formsValidationOneUppercaseLetter: 'formsValidationOneUppercaseLetter',\r\n formsValidationOnlyEnglishAndDigitsAndSpecialSymbolsError:\r\n 'formsValidationOnlyEnglishAndDigitsAndSpecialSymbolsError',\r\n formsValidationOnlyEnglishAndDigitsError: 'formsValidationOnlyEnglishAndDigitsError',\r\n formsValidationOnlyEnglishError: 'formsValidationOnlyEnglishError',\r\n formsValidationOutRange: 'formsValidationOutRange',\r\n formsValidationOutTotal: 'formsValidationOutTotal',\r\n formsValidationRepeatedCharacters: 'formsValidationRepeatedCharacters',\r\n formsValidationRequiredError: 'formsValidationRequiredError',\r\n formsValidationRequiredErrorCanBe0: 'formsValidationRequiredErrorCanBe0',\r\n formsValidationStrengthError: 'formsValidationStrengthError',\r\n formsValidationValueShouldBeEmptyOrGreaterThan: 'formsValidationValueShouldBeEmptyOrGreaterThan',\r\n formsValidationValueShouldBeGreaterThan: 'formsValidationValueShouldBeGreaterThan',\r\n formsValidationValueShouldBeLowerThan: 'formsValidationValueShouldBeLowerThan',\r\n governmentPhotoCitizenship: 'governmentPhotoCitizenship',\r\n governmentPhotoDocumentNumber: 'governmentPhotoDocumentNumber',\r\n governmentPhotoDocumentType: 'governmentPhotoDocumentType',\r\n governmentPhotoNationalIDNumber: 'governmentPhotoNationalIDNumber',\r\n headerWithBalanceAccountBalance: 'headerWithBalanceAccountBalance',\r\n headerWithBalanceFailedToFetchBalance: 'headerWithBalanceFailedToFetchBalance',\r\n headerWithBalanceGrid: 'headerWithBalanceGrid',\r\n headerWithBalanceList: 'headerWithBalanceList',\r\n headerWithBalanceTABalance: 'headerWithBalanceTABalance',\r\n ibCommissionChildRebate: 'ibCommissionChildRebate',\r\n ibCommissionCloseTime: 'ibCommissionCloseTime',\r\n ibCommissionCommission: 'ibCommissionCommission',\r\n ibCommissionCommissionHistoryId: 'ibCommissionCommissionHistoryId',\r\n ibCommissionCommissionInTaCurrency: 'ibCommissionCommissionInTaCurrency',\r\n ibCommissionCommissionUnit: 'ibCommissionCommissionUnit',\r\n ibCommissionIbLevel: 'ibCommissionIbLevel',\r\n ibCommissionIsDirect: 'ibCommissionIsDirect',\r\n ibCommissionNotPaidRebate: 'ibCommissionNotPaidRebate',\r\n ibCommissionOpenTime: 'ibCommissionOpenTime',\r\n ibCommissionPaidToWallet: 'ibCommissionPaidToWallet',\r\n ibCommissionPayoutModel: 'ibCommissionPayoutModel',\r\n ibCommissionPipTaCurrency: 'ibCommissionPipTaCurrency',\r\n ibCommissionRate: 'ibCommissionRate',\r\n ibCommissionRateForConversionToAccountCurrency: 'ibCommissionRateForConversionToAccountCurrency',\r\n ibCommissionRebate: 'ibCommissionRebate',\r\n ibCommissionRebateExcluded: 'ibCommissionRebateExcluded',\r\n ibCommissionRebateInTaCurrency: 'ibCommissionRebateInTaCurrency',\r\n ibCommissionRebateUnit: 'ibCommissionRebateUnit',\r\n ibCommissionSpread: 'ibCommissionSpread',\r\n ibCommissionSpreadInTaCurrency: 'ibCommissionSpreadInTaCurrency',\r\n ibCommissionSpreadUnit: 'ibCommissionSpreadUnit',\r\n ibCommissionSymbol: 'ibCommissionSymbol',\r\n ibCommissionTicket: 'ibCommissionTicket',\r\n ibCommissionTotalInTaCurrency: 'ibCommissionTotalInTaCurrency',\r\n ibCommissionTotalInUsd: 'ibCommissionTotalInUsd',\r\n ibCommissionTotalPayoutTaCurrency: 'ibCommissionTotalPayoutTaCurrency',\r\n ibCommissionTradingAccountCurrency: 'ibCommissionTradingAccountCurrency',\r\n ibCommissionUserLevel: 'ibCommissionUserLevel',\r\n ibCommissionVolume: 'ibCommissionVolume',\r\n ibCommissionVolumeInLots: 'ibCommissionVolumeInLots',\r\n importItemImportConfirmMessage: 'importItemImportConfirmMessage',\r\n importItemValidateConfirmMessage: 'importItemValidateConfirmMessage',\r\n investorsCount: 'investorsCount',\r\n investorsFieldsAccount: 'investorsFieldsAccount',\r\n investorsFieldsCopyingMyMasterAccount: 'investorsFieldsCopyingMyMasterAccount',\r\n investorsFieldsMasterAccount: 'investorsFieldsMasterAccount',\r\n investorsFieldsPosition: 'investorsFieldsPosition',\r\n investorsFieldsSubscribedOn: 'investorsFieldsSubscribedOn',\r\n investorsFieldsTotalDeposits: 'investorsFieldsTotalDeposits',\r\n investorsFieldsTotalWithdrawals: 'investorsFieldsTotalWithdrawals',\r\n investorsHint: 'investorsHint',\r\n investorsInvestorNickname: 'investorsInvestorNickname',\r\n investorsInvestors: 'investorsInvestors',\r\n investorsInvestorsAccount: 'investorsInvestorsAccount',\r\n investorsPlaceholder: 'investorsPlaceholder',\r\n investorsTitle: 'investorsTitle',\r\n imageProcessingConfirmationText: 'imageProcessingConfirmationText',\r\n jurisdictionAdminJurisdiction: 'jurisdictionAdminJurisdiction',\r\n jurisdictionAdminStartProcessingBtn: 'jurisdictionAdminStartProcessingBtn',\r\n jurisdictionAdminStartedProcessingSuccessfully: 'jurisdictionAdminStartedProcessingSuccessfully',\r\n jurisdictionAdminToJurisdiction: 'jurisdictionAdminToJurisdiction',\r\n jurisdictionAgreementAcceptedOn: 'jurisdictionAgreementAcceptedOn',\r\n jurisdictionAgreementIsAccepted: 'jurisdictionAgreementIsAccepted',\r\n jurisdictionAgreementReadOn: 'jurisdictionAgreementReadOn',\r\n jurisdictionPopupAcceptButton: 'jurisdictionPopupAcceptButton',\r\n jurisdictionPopupChatButton: 'jurisdictionPopupChatButton',\r\n jurisdictionPopupQuestions: 'jurisdictionPopupQuestions',\r\n jurisdictionPopupReadDocuments: 'jurisdictionPopupReadDocuments',\r\n jurisdictionTitle: 'jurisdictionTitle',\r\n kycVerificationApiLog: 'kycVerificationApiLog',\r\n kycVerificationApplicantId: 'kycVerificationApplicantId',\r\n kycVerificationBatchTitle: 'kycVerificationBatchTitle',\r\n kycVerificationCallbackLog: 'kycVerificationCallbackLog',\r\n kycVerificationCompletedOn: 'kycVerificationCompletedOn',\r\n kycVerificationDelayBetweenEachUser: 'kycVerificationDelayBetweenEachUser',\r\n kycVerificationDocsUploaded: 'kycVerificationDocsUploaded',\r\n kycVerificationEnqueueBatch: 'kycVerificationEnqueueBatch',\r\n kycVerificationEnqueueBatchFromImport: 'kycVerificationEnqueueBatchFromImport',\r\n kycVerificationFollowedUpButtonToolTip: 'kycVerificationFollowedUpButtonToolTip',\r\n kycVerificationFollowedUpBy: 'kycVerificationFollowedUpBy',\r\n kycVerificationHeaders: 'kycVerificationHeaders',\r\n kycVerificationId: 'kycVerificationId',\r\n kycVerificationIsPersonalDataEntered: 'kycVerificationIsPersonalDataEntered',\r\n kycVerificationIsVerified: 'kycVerificationIsVerified',\r\n kycVerificationKycVerification: 'kycVerificationKycVerification',\r\n kycVerificationKycVerifications: 'kycVerificationKycVerifications',\r\n kycVerificationMethod: 'kycVerificationMethod',\r\n kycVerificationPayload: 'kycVerificationPayload',\r\n kycVerificationProfileStatus: 'kycVerificationProfileStatus',\r\n kycVerificationProvider: 'kycVerificationProvider',\r\n kycVerificationProviderClass: 'kycVerificationProviderClass',\r\n kycVerificationProviderName: 'kycVerificationProviderName',\r\n kycVerificationRequest: 'kycVerificationRequest',\r\n kycVerificationRequestHeaders: 'kycVerificationRequestHeaders',\r\n kycVerificationResponse: 'kycVerificationResponse',\r\n kycVerificationResponseHeaders: 'kycVerificationResponseHeaders',\r\n kycVerificationRunningBatchHint: 'kycVerificationRunningBatchHint',\r\n kycVerificationStartedOn: 'kycVerificationStartedOn',\r\n kycVerificationStatus: 'kycVerificationStatus',\r\n kycVerificationStatusCode: 'kycVerificationStatusCode',\r\n kycVerificationTotalUsersProcessed: 'kycVerificationTotalUsersProcessed',\r\n kycVerificationUnfollow: 'kycVerificationUnfollow',\r\n kycVerificationUnfollowButtonToolTip: 'kycVerificationUnfollowButtonToolTip',\r\n kycVerificationUnfollowWithOverride: 'kycVerificationUnfollowWithOverride',\r\n kycVerificationUnverifiedUserBatchEnqueued: 'kycVerificationUnverifiedUserBatchEnqueued',\r\n kycVerificationUnverifiedUsersBatch: 'kycVerificationUnverifiedUsersBatch',\r\n kycVerificationUpdateFixedInfo: 'kycVerificationUpdateFixedInfo',\r\n kycVerificationUpdateRequiredMsg: 'kycVerificationUpdateRequiredMsg',\r\n kycVerificationUpdateRequiredSecondLineMsg: 'kycVerificationUpdateRequiredSecondLineMsg',\r\n kycVerificationUpdateRequiredTitle: 'kycVerificationUpdateRequiredTitle',\r\n kycVerificationUploadedDocumentType1: 'kycVerificationUploadedDocumentType1',\r\n kycVerificationUploadedDocumentType2: 'kycVerificationUploadedDocumentType2',\r\n kycVerificationUrgentUpdateMsg: 'kycVerificationUrgentUpdateMsg',\r\n kycVerificationUrgentUpdateSecondLineMsg: 'kycVerificationUrgentUpdateSecondLineMsg',\r\n kycVerificationUrl: 'kycVerificationUrl',\r\n kycVerificationVerificationData: 'kycVerificationVerificationData',\r\n kycVerificationVerificationType: 'kycVerificationVerificationType',\r\n kytVerificationAddressFrom: 'kytVerificationAddressFrom',\r\n kytVerificationAddressTo: 'kytVerificationAddressTo',\r\n kytVerificationApiLog: 'kytVerificationApiLog',\r\n kytVerificationApiLogs: 'kytVerificationApiLogs',\r\n kytVerificationEkytVerification: 'kytVerificationEkytVerification',\r\n kytVerificationKytProvider: 'kytVerificationKytProvider',\r\n kytVerificationKytTransfer: 'kytVerificationKytTransfer',\r\n kytVerificationKytVerification: 'kytVerificationKytVerification',\r\n kytVerificationKytVerifications: 'kytVerificationKytVerifications',\r\n kytVerificationKytWithdrawalAttempt: 'kytVerificationKytWithdrawalAttempt',\r\n kytVerificationMethod: 'kytVerificationMethod',\r\n kytVerificationNetwork: 'kytVerificationNetwork',\r\n kytVerificationNotes: 'kytVerificationNotes',\r\n kytVerificationRateUSD: 'kytVerificationRateUSD',\r\n kytVerificationRequest: 'kytVerificationRequest',\r\n kytVerificationResponse: 'kytVerificationResponse',\r\n kytVerificationRiskScore: 'kytVerificationRiskScore',\r\n kytVerificationStatusCode: 'kytVerificationStatusCode',\r\n kytVerificationTransactionReference: 'kytVerificationTransactionReference',\r\n kytVerificationTransfers: 'kytVerificationTransfers',\r\n kytVerificationUrl: 'kytVerificationUrl',\r\n kytVerificationVerificationData: 'kytVerificationVerificationData',\r\n kytVerificationWithdrawalAttempts: 'kytVerificationWithdrawalAttempts',\r\n legalDownloadPdf: 'legalDownloadPdf',\r\n legalSectionType: 'legalSectionType',\r\n legalTitle: 'legalTitle',\r\n legalTradingPlatformIcon: 'legalTradingPlatformIcon',\r\n legalTradingPlatformIsQRCode: 'legalTradingPlatformIsQRCode',\r\n legalTradingPlatformSectionType: 'legalTradingPlatformSectionType',\r\n legalTradingPlatformUrlDestinationType: 'legalTradingPlatformUrlDestinationType',\r\n legalTradingPlatformUrlHint: 'legalTradingPlatformUrlHint',\r\n loginBrowser: 'loginBrowser',\r\n loginBrowserVersion: 'loginBrowserVersion',\r\n loginDevice: 'loginDevice',\r\n loginHistoryType: 'loginHistoryType',\r\n loginOperationSystem: 'loginOperationSystem',\r\n loginPlatform: 'loginPlatform',\r\n lotMultiplierAllowsYouToMultiplySizeOfYourTradeWithTradeThat:\r\n 'lotMultiplierAllowsYouToMultiplySizeOfYourTradeWithTradeThat',\r\n loyaltyProgram: 'loyaltyProgram',\r\n loyaltyProgramAccessDescription: 'loyaltyProgramAccessDescription',\r\n loyaltyProgramAccessTitle: 'loyaltyProgramAccessTitle',\r\n loyaltyProgramConsentRequired: 'loyaltyProgramConsentRequired',\r\n loyaltyProgramConversationRateTradeVolumeHint: 'loyaltyProgramConversationRateTradeVolumeHint',\r\n loyaltyProgramConversionRateDepositHint: 'loyaltyProgramConversionRateDepositHint',\r\n loyaltyProgramDocumentBulkExportFileName: 'loyaltyProgramDocumentBulkExportFileName',\r\n loyaltyProgramDocumentList: 'loyaltyProgramDocumentList',\r\n loyaltyProgramDurationDays: 'loyaltyProgramDurationDays',\r\n loyaltyProgramJoinCheckboxLabel: 'loyaltyProgramJoinCheckboxLabel',\r\n loyaltyProgramJoinSuccess: 'loyaltyProgramJoinSuccess',\r\n loyaltyProgramLoyaltyPoints: 'loyaltyProgramLoyaltyPoints',\r\n loyaltyProgramMinDuration: 'loyaltyProgramMinDuration',\r\n loyaltyProgramNoAvailableOperations: 'loyaltyProgramNoAvailableOperations',\r\n loyaltyProgramNoAvailablePrizes: 'loyaltyProgramNoAvailablePrizes',\r\n loyaltyProgramNoProgramAvailable: 'loyaltyProgramNoProgramAvailable',\r\n loyaltyProgramOperation: 'loyaltyProgramOperation',\r\n loyaltyProgramOperationList: 'loyaltyProgramOperationList',\r\n loyaltyProgramOperations: 'loyaltyProgramOperations',\r\n loyaltyProgramParticipant: 'loyaltyProgramParticipant',\r\n loyaltyProgramParticipantList: 'loyaltyProgramParticipantList',\r\n loyaltyProgramParticipantRedeem: 'loyaltyProgramParticipantRedeem',\r\n loyaltyProgramParticipantRedeemList: 'loyaltyProgramParticipantRedeemList',\r\n loyaltyProgramParticipants: 'loyaltyProgramParticipants',\r\n loyaltyProgramParticipate: 'loyaltyProgramParticipate',\r\n loyaltyProgramPoints: 'loyaltyProgramPoints',\r\n loyaltyProgramPrice: 'loyaltyProgramPrice',\r\n loyaltyProgramPrizeDetails: 'loyaltyProgramPrizeDetails',\r\n loyaltyProgramProcessor: 'loyaltyProgramProcessor',\r\n loyaltyProgramProcessorDepositParameters: 'loyaltyProgramProcessorDepositParameters',\r\n loyaltyProgramProcessorList: 'loyaltyProgramProcessorList',\r\n loyaltyProgramProcessorTradeVolumeParameters: 'loyaltyProgramProcessorTradeVolumeParameters',\r\n loyaltyProgramProcessors: 'loyaltyProgramProcessors',\r\n loyaltyProgramRedeem: 'loyaltyProgramRedeem',\r\n loyaltyProgramRedeemCancelDescription: 'loyaltyProgramRedeemCancelDescription',\r\n loyaltyProgramRedeemCancelSuccess: 'loyaltyProgramRedeemCancelSuccess',\r\n loyaltyProgramRedeemEWalletType: 'loyaltyProgramRedeemEWalletType',\r\n loyaltyProgramRedeemEWalletTypeHint: 'loyaltyProgramRedeemEWalletTypeHint',\r\n loyaltyProgramRedeemGridTitle: 'loyaltyProgramRedeemGridTitle',\r\n loyaltyProgramRedeemHintAmountHint: 'loyaltyProgramRedeemHintAmountHint',\r\n loyaltyProgramRedeemImageHint: 'loyaltyProgramRedeemImageHint',\r\n loyaltyProgramRedeemItems: 'loyaltyProgramRedeemItems',\r\n loyaltyProgramRedeemList: 'loyaltyProgramRedeemList',\r\n loyaltyProgramRedeemMaterialHint: 'loyaltyProgramRedeemMaterialHint',\r\n loyaltyProgramRedeemModalTitle: 'loyaltyProgramRedeemModalTitle',\r\n loyaltyProgramRedeemRedemptionType: 'loyaltyProgramRedeemRedemptionType',\r\n loyaltyProgramRedeemRequests: 'loyaltyProgramRedeemRequests',\r\n loyaltyProgramRedeemSelectAccount: 'loyaltyProgramRedeemSelectAccount',\r\n loyaltyProgramRedeemSelectAccountType: 'loyaltyProgramRedeemSelectAccountType',\r\n loyaltyProgramRedeemSuccess: 'loyaltyProgramRedeemSuccess',\r\n loyaltyProgramRedeemTitle: 'loyaltyProgramRedeemTitle',\r\n loyaltyProgramRedemptionEndDate: 'loyaltyProgramRedemptionEndDate',\r\n loyaltyProgramRedemptionEndOn: 'loyaltyProgramRedemptionEndOn',\r\n loyaltyProgramRequestDate: 'loyaltyProgramRequestDate',\r\n loyaltyProgramRequestId: 'loyaltyProgramRequestId',\r\n loyaltyProgramRequestOperation: 'loyaltyProgramRequestOperation',\r\n loyaltyProgramResultOperation: 'loyaltyProgramResultOperation',\r\n loyaltyProgramStopParticipatingDescription: 'loyaltyProgramStopParticipatingDescription',\r\n loyaltyProgramStopParticipatingSuccess: 'loyaltyProgramStopParticipatingSuccess',\r\n loyaltyProgramTabPointsHistory: 'loyaltyProgramTabPointsHistory',\r\n loyaltyProgramTabPrizesHistory: 'loyaltyProgramTabPrizesHistory',\r\n loyaltyProgramTakePartIn: 'loyaltyProgramTakePartIn',\r\n loyaltyProgramTradingAccountTypeIdsHint: 'loyaltyProgramTradingAccountTypeIdsHint',\r\n loyaltyProgramUserAccessSettingList: 'loyaltyProgramUserAccessSettingList',\r\n loyaltyProgramUserRulesEnd: 'loyaltyProgramUserRulesEnd',\r\n loyaltyProgramUserRulesStart: 'loyaltyProgramUserRulesStart',\r\n loyaltyPrograms: 'loyaltyPrograms',\r\n mamChooseTradingAccount: 'mamChooseTradingAccount',\r\n mamMasterAccount: 'mamMasterAccount',\r\n mamMasterAccountMonthlyManagementFee: 'mamMasterAccountMonthlyManagementFee',\r\n mamMasterAccounts: 'mamMasterAccounts',\r\n mamMasterCommissionAccount: 'mamMasterCommissionAccount',\r\n mamMasterCommissionPoints: 'mamMasterCommissionPoints',\r\n mamMasterProfitSharing: 'mamMasterProfitSharing',\r\n mamMasterTerminationTimeInHours: 'mamMasterTerminationTimeInHours',\r\n mamProceedWithLPOA: 'mamProceedWithLPOA',\r\n mamTerminateConfirmation: 'mamTerminateConfirmation',\r\n mamTerminateLPOA: 'mamTerminateLPOA',\r\n masterAccount: 'masterAccount',\r\n masterProfileAccountDescription: 'masterProfileAccountDescription',\r\n masterProfileAccountPrefixCent: 'masterProfileAccountPrefixCent',\r\n masterProfileAccountPrefixECN: 'masterProfileAccountPrefixECN',\r\n masterProfileAccountPrefixStandard: 'masterProfileAccountPrefixStandard',\r\n masterProfileInfoFieldsAverageDrawdown: 'masterProfileInfoFieldsAverageDrawdown',\r\n masterProfileInfoFieldsCopyType: 'masterProfileInfoFieldsCopyType',\r\n masterProfileInfoFieldsCountry: 'masterProfileInfoFieldsCountry',\r\n masterProfileInfoFieldsGroupMappingType: 'masterProfileInfoFieldsGroupMappingType',\r\n masterProfileInfoFieldsLanguage: 'masterProfileInfoFieldsLanguage',\r\n masterProfileInfoFieldsMaxDrawdown: 'masterProfileInfoFieldsMaxDrawdown',\r\n masterProfileInfoFieldsOpeningTime: 'masterProfileInfoFieldsOpeningTime',\r\n masterProfileInfoFieldsPosition: 'masterProfileInfoFieldsPosition',\r\n masterProfileInfoFieldsProfitSharing: 'masterProfileInfoFieldsProfitSharing',\r\n masterProfileInfoFieldsProfitability: 'masterProfileInfoFieldsProfitability',\r\n masterProfileInfoFieldsRecommendedMinDepositAmount: 'masterProfileInfoFieldsRecommendedMinDepositAmount',\r\n masterProfileInfoFieldsRegistrationDate: 'masterProfileInfoFieldsRegistrationDate',\r\n masterProfileInfoFieldsReturnOnInvestment: 'masterProfileInfoFieldsReturnOnInvestment',\r\n masterProfileInfoFieldsTotalManagedFunds: 'masterProfileInfoFieldsTotalManagedFunds',\r\n masterProfileInfoFieldsTotalOwnedFunds: 'masterProfileInfoFieldsTotalOwnedFunds',\r\n masterProfileInfoFieldsTradesCount: 'masterProfileInfoFieldsTradesCount',\r\n masterProfileInvestorProfile: 'masterProfileInvestorProfile',\r\n masterProfileMasterAccounts: 'masterProfileMasterAccounts',\r\n masterProfileMasterProfile: 'masterProfileMasterProfile',\r\n masterProfileStatistics: 'masterProfileStatistics',\r\n masterProfileTradeColumnsClosePrice: 'masterProfileTradeColumnsClosePrice',\r\n masterProfileTradeColumnsCloseTime: 'masterProfileTradeColumnsCloseTime',\r\n masterProfileTradeColumnsInstrument: 'masterProfileTradeColumnsInstrument',\r\n masterProfileTradeColumnsOpenTime: 'masterProfileTradeColumnsOpenTime',\r\n masterProfileTradeColumnsProfitUsc: 'masterProfileTradeColumnsProfitUsc',\r\n masterProfileTradeColumnsProfitUsd: 'masterProfileTradeColumnsProfitUsd',\r\n masterProfileTradeColumnsSize: 'masterProfileTradeColumnsSize',\r\n masterProfileTradeColumnsStopLoss: 'masterProfileTradeColumnsStopLoss',\r\n masterProfileTradeColumnsTakeProfit: 'masterProfileTradeColumnsTakeProfit',\r\n masterProfileTradeColumnsType: 'masterProfileTradeColumnsType',\r\n masterProfileTradeHistoryTitle: 'masterProfileTradeHistoryTitle',\r\n masterProfileTradeHistoryTooltip: 'masterProfileTradeHistoryTooltip',\r\n mastersFieldsInvestorAccount: 'mastersFieldsInvestorAccount',\r\n mastersFieldsProfitSharing: 'mastersFieldsProfitSharing',\r\n mastersFieldsProfitability: 'mastersFieldsProfitability',\r\n mastersFilterName: 'mastersFilterName',\r\n mastersHint: 'mastersHint',\r\n mastersPlaceholder: 'mastersPlaceholder',\r\n mastersSelectPlaceholder: 'mastersSelectPlaceholder',\r\n mastersTitle: 'mastersTitle',\r\n menuAccounts: 'menuAccounts',\r\n menuEducationPortal: 'menuEducationPortal',\r\n menuFaq: 'menuFaq',\r\n menuFunding: 'menuFunding',\r\n menuHelpCenter: 'menuHelpCenter',\r\n menuHistory: 'menuHistory',\r\n menuLegal: 'menuLegal',\r\n menuLoyaltyProgram: 'menuLoyaltyProgram',\r\n menuNotificationsAndMessages: 'menuNotificationsAndMessages',\r\n menuOpenInvestorsAccount: 'menuOpenInvestorsAccount',\r\n menuOpenMastersAccount: 'menuOpenMastersAccount',\r\n menuPartnership: 'menuPartnership',\r\n menuRatings: 'menuRatings',\r\n menuSales: 'menuSales',\r\n menuServerTime: 'menuServerTime',\r\n menuSettings: 'menuSettings',\r\n menuSocialTrading: 'menuSocialTrading',\r\n menuStatistics: 'menuStatistics',\r\n menuTickets: 'menuTickets',\r\n menuTradingContests: 'menuTradingContests',\r\n menuTradingPlatforms: 'menuTradingPlatforms',\r\n menuTradingTools: 'menuTradingTools',\r\n menuViewMore: 'menuViewMore',\r\n modalClose: 'modalClose',\r\n modalConfirm: 'modalConfirm',\r\n modalConfirmation: 'modalConfirmation',\r\n modalGotIt: 'modalGotIt',\r\n modalItCouldBeDelays: 'modalItCouldBeDelays',\r\n modalNo: 'modalNo',\r\n modalProcessingCompleteWithin: 'modalProcessingCompleteWithin',\r\n modalThanksForRequest: 'modalThanksForRequest',\r\n modalValidationMessage: 'modalValidationMessage',\r\n modalWelcomeCompleteProfile: 'modalWelcomeCompleteProfile',\r\n modalWelcomeDepositNow: 'modalWelcomeDepositNow',\r\n modalWelcomeGetTradingApp: 'modalWelcomeGetTradingApp',\r\n modalWelcomeGettingStarted: 'modalWelcomeGettingStarted',\r\n modalWelcomeTitle: 'modalWelcomeTitle',\r\n modalWelcomeYourTradingJourneyStartsHere: 'modalWelcomeYourTradingJourneyStartsHere',\r\n modalYes: 'modalYes',\r\n myCopyingAccounts: 'myCopyingAccounts',\r\n myStatisticsChartInvestorSubtitle: 'myStatisticsChartInvestorSubtitle',\r\n myStatisticsChartMasterSubtitle: 'myStatisticsChartMasterSubtitle',\r\n myStatisticsFilterName: 'myStatisticsFilterName',\r\n myStatisticsInvestorsHint: 'myStatisticsInvestorsHint',\r\n myStatisticsMasters: 'myStatisticsMasters',\r\n myStatisticsMastersHint: 'myStatisticsMastersHint',\r\n myStatisticsOpenDetailsList: 'myStatisticsOpenDetailsList',\r\n myStatisticsTitle: 'myStatisticsTitle',\r\n noStayOnPage: 'noStayOnPage',\r\n notesHistory: 'notesHistory',\r\n notificationGroupDistributionList: 'notificationGroupDistributionList',\r\n notificationGroupDynamicFieldsFilterBy: 'notificationGroupDynamicFieldsFilterBy',\r\n notificationGroupDynamicFieldsFilterValue: 'notificationGroupDynamicFieldsFilterValue',\r\n notificationGroupDynamicFieldsOperatorType: 'notificationGroupDynamicFieldsOperatorType',\r\n notificationGroupDynamicFilterListTitle: 'notificationGroupDynamicFilterListTitle',\r\n notificationGroupMemberAdminTitle: 'notificationGroupMemberAdminTitle',\r\n notificationGroupMemberFormImportModalExpectedColumns: 'notificationGroupMemberFormImportModalExpectedColumns',\r\n notificationGroupMemberFormImportModalExpectedExtension: 'notificationGroupMemberFormImportModalExpectedExtension',\r\n notificationGroupMemberFormImportModalPromptList1: 'notificationGroupMemberFormImportModalPromptList1',\r\n notificationGroupMemberFormImportModalPromptList2: 'notificationGroupMemberFormImportModalPromptList2',\r\n notificationGroupMemberFormImportModalPromptList3: 'notificationGroupMemberFormImportModalPromptList3',\r\n notificationGroupMemberFormImportModalPromptTitle: 'notificationGroupMemberFormImportModalPromptTitle',\r\n notificationGroupMemberFormImportModalPromptTitle2: 'notificationGroupMemberFormImportModalPromptTitle2',\r\n notificationsFieldsEventTypeTitle: 'notificationsFieldsEventTypeTitle',\r\n notificationsFieldsIsSaveNotificationTitle: 'notificationsFieldsIsSaveNotificationTitle',\r\n notificationsFieldsIsUseUserLanguageTitle: 'notificationsFieldsIsUseUserLanguageTitle',\r\n notificationsFieldsNotificationMethodHint: 'notificationsFieldsNotificationMethodHint',\r\n notificationsFieldsNotificationMethodTitle: 'notificationsFieldsNotificationMethodTitle',\r\n notificationsFieldsSubjectTitle: 'notificationsFieldsSubjectTitle',\r\n notificationsMarkNewBtn: 'notificationsMarkNewBtn',\r\n notificationsMarkReadBtn: 'notificationsMarkReadBtn',\r\n notificationsNotificationsTitle: 'notificationsNotificationsTitle',\r\n onboardingConfigurationFieldsNewDirectUsersInvited: 'onboardingConfigurationFieldsNewDirectUsersInvited',\r\n onboardingConfigurationFieldsShowBonusesTab: 'onboardingConfigurationFieldsShowBonusesTab',\r\n onboardingConfigurationFieldsShowEducationPortalTab: 'onboardingConfigurationFieldsShowEducationPortalTab',\r\n onboardingConfigurationFieldsShowFaqTab: 'onboardingConfigurationFieldsShowFaqTab',\r\n onboardingConfigurationFieldsShowLoyaltyProgramsTab: 'onboardingConfigurationFieldsShowLoyaltyProgramsTab',\r\n onboardingConfigurationFieldsShowTradingContestsTab: 'onboardingConfigurationFieldsShowTradingContestsTab',\r\n onboardingConfigurationFieldsShowTradingPushNotificationsTab:\r\n 'onboardingConfigurationFieldsShowTradingPushNotificationsTab',\r\n onboardingConfigurationFieldsShowTradingToolTab: 'onboardingConfigurationFieldsShowTradingToolTab',\r\n onboardingConfigurationFieldsShowUserPushNotificationsTab:\r\n 'onboardingConfigurationFieldsShowUserPushNotificationsTab',\r\n operationHistoryFieldsDate: 'operationHistoryFieldsDate',\r\n operationHistoryFieldsEvent: 'operationHistoryFieldsEvent',\r\n operationHistoryFieldsMyAccount: 'operationHistoryFieldsMyAccount',\r\n operationHistoryFieldsPosition: 'operationHistoryFieldsPosition',\r\n operationHistoryTitle: 'operationHistoryTitle',\r\n pageTitlesAdminBrandingBrandingMenuTitle: 'pageTitlesAdminBrandingBrandingMenuTitle',\r\n pageTitlesAdminBrandingChildrenBanners: 'pageTitlesAdminBrandingChildrenBanners',\r\n pageTitlesAdminBrandingChildrenConsents: 'pageTitlesAdminBrandingChildrenConsents',\r\n pageTitlesAdminBrandingChildrenClientSideTranslations: 'pageTitlesAdminBrandingChildrenClientSideTranslations',\r\n pageTitlesAdminBrandingChildrenFaqs: 'pageTitlesAdminBrandingChildrenFaqs',\r\n pageTitlesAdminBrandingChildrenLegalDocuments: 'pageTitlesAdminBrandingChildrenLegalDocuments',\r\n pageTitlesAdminBrandingChildrenLegalTradingPlatforms: 'pageTitlesAdminBrandingChildrenLegalTradingPlatforms',\r\n pageTitlesAdminBrandingChildrenLinks: 'pageTitlesAdminBrandingChildrenLinks',\r\n pageTitlesAdminBrandingChildrenTradingPlatformBrandingSettings:\r\n 'pageTitlesAdminBrandingChildrenTradingPlatformBrandingSettings',\r\n pageTitlesAdminBrandingChildrenUrlDomains: 'pageTitlesAdminBrandingChildrenUrlDomains',\r\n pageTitlesAdminBrandingChildrenVideos: 'pageTitlesAdminBrandingChildrenVideos',\r\n pageTitlesAdminCompaniesChildrenCompanyAccount: 'pageTitlesAdminCompaniesChildrenCompanyAccount',\r\n pageTitlesAdminCompaniesChildrenCompanyTransfer: 'pageTitlesAdminCompaniesChildrenCompanyTransfer',\r\n pageTitlesAdminCompaniesCompanyMenuTitle: 'pageTitlesAdminCompaniesCompanyMenuTitle',\r\n pageTitlesAdminContestsChildrenTradingContests: 'pageTitlesAdminContestsChildrenTradingContests',\r\n pageTitlesAdminContestsContestsMenuTitle: 'pageTitlesAdminContestsContestsMenuTitle',\r\n pageTitlesAdminCrmChildrenAssignmentRules: 'pageTitlesAdminCrmChildrenAssignmentRules',\r\n pageTitlesAdminCrmChildrenBusinessManagers: 'pageTitlesAdminCrmChildrenBusinessManagers',\r\n pageTitlesAdminCrmChildrenCrmCache: 'pageTitlesAdminCrmChildrenCrmCache',\r\n pageTitlesAdminCrmChildrenExternalJobs: 'pageTitlesAdminCrmChildrenExternalJobs',\r\n pageTitlesAdminCrmChildrenSalesLeads: 'pageTitlesAdminCrmChildrenSalesLeads',\r\n pageTitlesAdminCrmChildrenSalesUsers: 'pageTitlesAdminCrmChildrenSalesUsers',\r\n pageTitlesAdminCrmCrmMenuTitle: 'pageTitlesAdminCrmCrmMenuTitle',\r\n pageTitlesAdminDashboard: 'pageTitlesAdminDashboard',\r\n pageTitlesAdminDocumentsDocumentsMenuTitle: 'pageTitlesAdminDocumentsDocumentsMenuTitle',\r\n pageTitlesAdminFinancialIdentityChildrenBanks: 'pageTitlesAdminFinancialIdentityChildrenBanks',\r\n pageTitlesAdminFinancialIdentityChildrenCryptoWalletAccounts:\r\n 'pageTitlesAdminFinancialIdentityChildrenCryptoWalletAccounts',\r\n pageTitlesAdminFinancialIdentityChildrenDigitalWallets: 'pageTitlesAdminFinancialIdentityChildrenDigitalWallets',\r\n pageTitlesAdminFinancialIdentityChildrenUserBankAccountCreate:\r\n 'pageTitlesAdminFinancialIdentityChildrenUserBankAccountCreate',\r\n pageTitlesAdminFinancialIdentityChildrenUserBankAccounts: 'pageTitlesAdminFinancialIdentityChildrenUserBankAccounts',\r\n pageTitlesAdminFinancialIdentityChildrenUserCardAccounts: 'pageTitlesAdminFinancialIdentityChildrenUserCardAccounts',\r\n pageTitlesAdminFinancialIdentityChildrenUserDigitalWalletAccounts:\r\n 'pageTitlesAdminFinancialIdentityChildrenUserDigitalWalletAccounts',\r\n pageTitlesAdminFinancialIdentityFinancialIdentityMenuTitle:\r\n 'pageTitlesAdminFinancialIdentityFinancialIdentityMenuTitle',\r\n pageTitlesAdminFinancialIdentityUserCryptoWalletAccounts: 'pageTitlesAdminFinancialIdentityUserCryptoWalletAccounts',\r\n pageTitlesAdminImoprtChildrenImportItems: 'pageTitlesAdminImoprtChildrenImportItems',\r\n pageTitlesAdminImoprtImoprtMenuTitle: 'pageTitlesAdminImoprtImoprtMenuTitle',\r\n pageTitlesAdminImportingChildrenUsers: 'pageTitlesAdminImportingChildrenUsers',\r\n pageTitlesAdminImportingImportMenuTitle: 'pageTitlesAdminImportingImportMenuTitle',\r\n pageTitlesAdminLoyaltyProgramsChildrenLoyaltyProgramOperations:\r\n 'pageTitlesAdminLoyaltyProgramsChildrenLoyaltyProgramOperations',\r\n pageTitlesAdminLoyaltyProgramsChildrenLoyaltyProgramParticipantRedeems:\r\n 'pageTitlesAdminLoyaltyProgramsChildrenLoyaltyProgramParticipantRedeems',\r\n pageTitlesAdminLoyaltyProgramsChildrenLoyaltyProgramParticipants:\r\n 'pageTitlesAdminLoyaltyProgramsChildrenLoyaltyProgramParticipants',\r\n pageTitlesAdminLoyaltyProgramsChildrenLoyaltyProgramProcessors:\r\n 'pageTitlesAdminLoyaltyProgramsChildrenLoyaltyProgramProcessors',\r\n pageTitlesAdminLoyaltyProgramsChildrenLoyaltyProgramRedeems:\r\n 'pageTitlesAdminLoyaltyProgramsChildrenLoyaltyProgramRedeems',\r\n pageTitlesAdminLoyaltyProgramsChildrenLoyaltyPrograms: 'pageTitlesAdminLoyaltyProgramsChildrenLoyaltyPrograms',\r\n pageTitlesAdminLoyaltyProgramsLoyaltyProgramsMenuTitle: 'pageTitlesAdminLoyaltyProgramsLoyaltyProgramsMenuTitle',\r\n pageTitlesAdminNotificationsChildrenAutoNotification: 'pageTitlesAdminNotificationsChildrenAutoNotification',\r\n pageTitlesAdminNotificationsChildrenCustomNotification: 'pageTitlesAdminNotificationsChildrenCustomNotification',\r\n pageTitlesAdminNotificationsChildrenCustomPushNotification:\r\n 'pageTitlesAdminNotificationsChildrenCustomPushNotification',\r\n pageTitlesAdminNotificationsChildrenEmailTemplates: 'pageTitlesAdminNotificationsChildrenEmailTemplates',\r\n pageTitlesAdminNotificationsChildrenMail: 'pageTitlesAdminNotificationsChildrenMail',\r\n pageTitlesAdminNotificationsChildrenNotificationCategory: 'pageTitlesAdminNotificationsChildrenNotificationCategory',\r\n pageTitlesAdminNotificationsChildrenNotificationGroup: 'pageTitlesAdminNotificationsChildrenNotificationGroup',\r\n pageTitlesAdminNotificationsChildrenPush: 'pageTitlesAdminNotificationsChildrenPush',\r\n pageTitlesAdminNotificationsChildrenSms: 'pageTitlesAdminNotificationsChildrenSms',\r\n pageTitlesAdminNotificationsNotificationsMenuTitle: 'pageTitlesAdminNotificationsNotificationsMenuTitle',\r\n pageTitlesAdminOnboardingChildrenDocumentsConfiguration: 'pageTitlesAdminOnboardingChildrenDocumentsConfiguration',\r\n pageTitlesAdminOnboardingChildrenOnboardingConfiguration: 'pageTitlesAdminOnboardingChildrenOnboardingConfiguration',\r\n pageTitlesAdminOnboardingOnboardingMenuTitle: 'pageTitlesAdminOnboardingOnboardingMenuTitle',\r\n pageTitlesAdminPartnershipChildrenIbCommissionSummary: 'pageTitlesAdminPartnershipChildrenIbCommissionSummary',\r\n pageTitlesAdminPartnershipChildrenMamMasterAccounts: 'pageTitlesAdminPartnershipChildrenMamMasterAccounts',\r\n pageTitlesAdminPartnershipChildrenQuestionnaires: 'pageTitlesAdminPartnershipChildrenQuestionnaires',\r\n pageTitlesAdminPartnershipPartnershipMenuTitle: 'pageTitlesAdminPartnershipPartnershipMenuTitle',\r\n pageTitlesAdminReportsChildrenCommissionHistory: 'pageTitlesAdminReportsChildrenCommissionHistory',\r\n pageTitlesAdminReportsChildrenCommissionTicketProcessing: 'pageTitlesAdminReportsChildrenCommissionTicketProcessing',\r\n pageTitlesAdminReportsChildrenDeposits: 'pageTitlesAdminReportsChildrenDeposits',\r\n pageTitlesAdminReportsChildrenDepositsNew: 'pageTitlesAdminReportsChildrenDepositsNew',\r\n pageTitlesAdminReportsChildrenEWallets: 'pageTitlesAdminReportsChildrenEWallets',\r\n pageTitlesAdminReportsChildrenFtdUtmReport: 'pageTitlesAdminReportsChildrenFtdUtmReport',\r\n pageTitlesAdminReportsChildrenPspActivityTimeReport: 'pageTitlesAdminReportsChildrenPspActivityTimeReport',\r\n pageTitlesAdminReportsChildrenPspOperationHistoryReport: 'pageTitlesAdminReportsChildrenPspOperationHistoryReport',\r\n pageTitlesAdminReportsChildrenPspOperationPerCountryReport:\r\n 'pageTitlesAdminReportsChildrenPspOperationPerCountryReport',\r\n pageTitlesAdminReportsChildrenPspOperationReport: 'pageTitlesAdminReportsChildrenPspOperationReport',\r\n pageTitlesAdminReportsChildrenPspOperationStatisticsReport:\r\n 'pageTitlesAdminReportsChildrenPspOperationStatisticsReport',\r\n pageTitlesAdminReportsChildrenReportJobs: 'pageTitlesAdminReportsChildrenReportJobs',\r\n pageTitlesAdminReportsChildrenReportsHistory: 'pageTitlesAdminReportsChildrenReportsHistory',\r\n pageTitlesAdminReportsChildrenTradingBonusLinkReport: 'pageTitlesAdminReportsChildrenTradingBonusLinkReport',\r\n pageTitlesAdminReportsChildrenWalletOperations: 'pageTitlesAdminReportsChildrenWalletOperations',\r\n pageTitlesAdminReportsChildrenWithdrawals: 'pageTitlesAdminReportsChildrenWithdrawals',\r\n pageTitlesAdminReportsChildrenWithdrawalsNew: 'pageTitlesAdminReportsChildrenWithdrawalsNew',\r\n pageTitlesAdminReportsReportsMenuTitle: 'pageTitlesAdminReportsReportsMenuTitle',\r\n pageTitlesAdminSettingsChildrenAppVersions: 'pageTitlesAdminSettingsChildrenAppVersions',\r\n pageTitlesAdminSettingsChildrenComponents: 'pageTitlesAdminSettingsChildrenComponents',\r\n pageTitlesAdminSettingsChildrenJobs: 'pageTitlesAdminSettingsChildrenJobs',\r\n pageTitlesAdminSettingsChildrenJobsHistory: 'pageTitlesAdminSettingsChildrenJobsHistory',\r\n pageTitlesAdminSettingsChildrenJurisdictionUpdate: 'pageTitlesAdminSettingsChildrenJurisdictionUpdate',\r\n pageTitlesAdminSettingsChildrenPsp: 'pageTitlesAdminSettingsChildrenPsp',\r\n pageTitlesAdminSettingsChildrenTradingServers: 'pageTitlesAdminSettingsChildrenTradingServers',\r\n pageTitlesAdminSettingsSettingsMenuTitle: 'pageTitlesAdminSettingsSettingsMenuTitle',\r\n pageTitlesAdminSocialTradingChildrenInvestorAccount: 'pageTitlesAdminSocialTradingChildrenInvestorAccount',\r\n pageTitlesAdminSocialTradingChildrenMasterAccount: 'pageTitlesAdminSocialTradingChildrenMasterAccount',\r\n pageTitlesAdminSocialTradingSocialTradingMenuTitle: 'pageTitlesAdminSocialTradingSocialTradingMenuTitle',\r\n pageTitlesAdminTradingConfigsChildrenTradingAccountTypes: 'pageTitlesAdminTradingConfigsChildrenTradingAccountTypes',\r\n pageTitlesAdminTradingConfigsChildrenTradingAccounts: 'pageTitlesAdminTradingConfigsChildrenTradingAccounts',\r\n pageTitlesAdminTradingConfigsChildrenTradingCategories: 'pageTitlesAdminTradingConfigsChildrenTradingCategories',\r\n pageTitlesAdminTradingConfigsChildrenTradingGroups: 'pageTitlesAdminTradingConfigsChildrenTradingGroups',\r\n pageTitlesAdminTradingConfigsChildrenTradingSymbols: 'pageTitlesAdminTradingConfigsChildrenTradingSymbols',\r\n pageTitlesAdminTradingConfigsTradingConfigsMenuTitle: 'pageTitlesAdminTradingConfigsTradingConfigsMenuTitle',\r\n pageTitlesAdminUsersChildrenLoginHistory: 'pageTitlesAdminUsersChildrenLoginHistory',\r\n pageTitlesAdminUsersChildrenPermissions: 'pageTitlesAdminUsersChildrenPermissions',\r\n pageTitlesAdminUsersChildrenTradingBonusLinks: 'pageTitlesAdminUsersChildrenTradingBonusLinks',\r\n pageTitlesAdminUsersChildrenTrustedDevices: 'pageTitlesAdminUsersChildrenTrustedDevices',\r\n pageTitlesAdminUsersChildrenUserBonuses: 'pageTitlesAdminUsersChildrenUserBonuses',\r\n pageTitlesAdminUsersChildrenUserCountryAccess: 'pageTitlesAdminUsersChildrenUserCountryAccess',\r\n pageTitlesAdminUsersChildrenUserNameAliases: 'pageTitlesAdminUsersChildrenUserNameAliases',\r\n pageTitlesAdminUsersChildrenUserTickets: 'pageTitlesAdminUsersChildrenUserTickets',\r\n pageTitlesAdminUsersUsersMenuTitle: 'pageTitlesAdminUsersUsersMenuTitle',\r\n pageTitlesAdminUsersUsersMenuTitleNew: 'pageTitlesAdminUsersUsersMenuTitleNew',\r\n pageTitlesAdminVerificationChildrenEKYC: 'pageTitlesAdminVerificationChildrenEKYC',\r\n pageTitlesAdminVerificationChildrenEKYCApiLogs: 'pageTitlesAdminVerificationChildrenEKYCApiLogs',\r\n pageTitlesAdminVerificationChildrenEKYCCallbackLogs: 'pageTitlesAdminVerificationChildrenEKYCCallbackLogs',\r\n pageTitlesAdminVerificationChildrenEKYT: 'pageTitlesAdminVerificationChildrenEKYT',\r\n pageTitlesAdminVerificationChildrenEKYTApiLogs: 'pageTitlesAdminVerificationChildrenEKYTApiLogs',\r\n pageTitlesAdminVerificationChildrenEKYTTransfers: 'pageTitlesAdminVerificationChildrenEKYTTransfers',\r\n pageTitlesAdminVerificationChildrenEKYTWithdrawalAttempts:\r\n 'pageTitlesAdminVerificationChildrenEKYTWithdrawalAttempts',\r\n pageTitlesAdminVerificationChildrenUnverifiedUsers: 'pageTitlesAdminVerificationChildrenUnverifiedUsers',\r\n pageTitlesAdminVerificationChildrenUnverifiedUsersBatches:\r\n 'pageTitlesAdminVerificationChildrenUnverifiedUsersBatches',\r\n pageTitlesAdminVerificationChildrenUnverifiedUsersImport: 'pageTitlesAdminVerificationChildrenUnverifiedUsersImport',\r\n pageTitlesAdminVerificationVerificationMenuTitle: 'pageTitlesAdminVerificationVerificationMenuTitle',\r\n partnershipIbInfoBalance: 'partnershipIbInfoBalance',\r\n partnershipIbInfoIbType: 'partnershipIbInfoIbType',\r\n partnershipIbInfoInfoTitle: 'partnershipIbInfoInfoTitle',\r\n partnershipIbInfoProfitShareOnConditionLevel: 'partnershipIbInfoProfitShareOnConditionLevel',\r\n partnershipIbInfoRebateLevel: 'partnershipIbInfoRebateLevel',\r\n partnershipIbInfoStatisticsClosetTradersReportAccountNumber:\r\n 'partnershipIbInfoStatisticsClosetTradersReportAccountNumber',\r\n partnershipIbInfoStatisticsClosetTradersReportAccountType:\r\n 'partnershipIbInfoStatisticsClosetTradersReportAccountType',\r\n partnershipIbInfoStatisticsClosetTradersReportClosePrice: 'partnershipIbInfoStatisticsClosetTradersReportClosePrice',\r\n partnershipIbInfoStatisticsClosetTradersReportCloseTime: 'partnershipIbInfoStatisticsClosetTradersReportCloseTime',\r\n partnershipIbInfoStatisticsClosetTradersReportCommission: 'partnershipIbInfoStatisticsClosetTradersReportCommission',\r\n partnershipIbInfoStatisticsClosetTradersReportCommissionInTaCurrency:\r\n 'partnershipIbInfoStatisticsClosetTradersReportCommissionInTaCurrency',\r\n partnershipIbInfoStatisticsClosetTradersReportCommissionUnit:\r\n 'partnershipIbInfoStatisticsClosetTradersReportCommissionUnit',\r\n partnershipIbInfoStatisticsClosetTradersReportDifference: 'partnershipIbInfoStatisticsClosetTradersReportDifference',\r\n partnershipIbInfoStatisticsClosetTradersReportOpenTime: 'partnershipIbInfoStatisticsClosetTradersReportOpenTime',\r\n partnershipIbInfoStatisticsClosetTradersReportPeriod: 'partnershipIbInfoStatisticsClosetTradersReportPeriod',\r\n partnershipIbInfoStatisticsClosetTradersReportProfit: 'partnershipIbInfoStatisticsClosetTradersReportProfit',\r\n partnershipIbInfoStatisticsClosetTradersReportRebateInTaCurrency:\r\n 'partnershipIbInfoStatisticsClosetTradersReportRebateInTaCurrency',\r\n partnershipIbInfoStatisticsClosetTradersReportSide: 'partnershipIbInfoStatisticsClosetTradersReportSide',\r\n partnershipIbInfoStatisticsClosetTradersReportSpread: 'partnershipIbInfoStatisticsClosetTradersReportSpread',\r\n partnershipIbInfoStatisticsClosetTradersReportSpreadInTaCurrency:\r\n 'partnershipIbInfoStatisticsClosetTradersReportSpreadInTaCurrency',\r\n partnershipIbInfoStatisticsClosetTradersReportSpreadUnit: 'partnershipIbInfoStatisticsClosetTradersReportSpreadUnit',\r\n partnershipIbInfoStatisticsClosetTradersReportTicket: 'partnershipIbInfoStatisticsClosetTradersReportTicket',\r\n partnershipIbInfoStatisticsClosetTradersReportTitle: 'partnershipIbInfoStatisticsClosetTradersReportTitle',\r\n partnershipIbInfoStatisticsClosetTradersReportTotalInTaCurrency:\r\n 'partnershipIbInfoStatisticsClosetTradersReportTotalInTaCurrency',\r\n partnershipIbInfoStatisticsClosetTradersReportTotalInUsd: 'partnershipIbInfoStatisticsClosetTradersReportTotalInUsd',\r\n partnershipIbInfoStatisticsClosetTradersReportVolume: 'partnershipIbInfoStatisticsClosetTradersReportVolume',\r\n partnershipIbInfoStatisticsPreviousReportDocTitle: 'partnershipIbInfoStatisticsPreviousReportDocTitle',\r\n partnershipIbInfoStatisticsPreviousReportTitle: 'partnershipIbInfoStatisticsPreviousReportTitle',\r\n partnershipIbInfoStatisticsStatisticsTitle: 'partnershipIbInfoStatisticsStatisticsTitle',\r\n partnershipIbInfoStatisticsTradingVolReportByAccount: 'partnershipIbInfoStatisticsTradingVolReportByAccount',\r\n partnershipIbInfoStatisticsTradingVolReportBySymbol: 'partnershipIbInfoStatisticsTradingVolReportBySymbol',\r\n partnershipIbInfoStatisticsTradingVolReportCommissionUsd: 'partnershipIbInfoStatisticsTradingVolReportCommissionUsd',\r\n partnershipIbInfoStatisticsTradingVolReportLevel: 'partnershipIbInfoStatisticsTradingVolReportLevel',\r\n partnershipIbInfoStatisticsTradingVolReportMainIbCode: 'partnershipIbInfoStatisticsTradingVolReportMainIbCode',\r\n partnershipIbInfoStatisticsTradingVolReportOwnDepositUsd: 'partnershipIbInfoStatisticsTradingVolReportOwnDepositUsd',\r\n partnershipIbInfoStatisticsTradingVolReportOwnNetDepositUsd:\r\n 'partnershipIbInfoStatisticsTradingVolReportOwnNetDepositUsd',\r\n partnershipIbInfoStatisticsTradingVolReportOwnTradingVolume:\r\n 'partnershipIbInfoStatisticsTradingVolReportOwnTradingVolume',\r\n partnershipIbInfoStatisticsTradingVolReportOwnWithdrawalUsd:\r\n 'partnershipIbInfoStatisticsTradingVolReportOwnWithdrawalUsd',\r\n partnershipIbInfoStatisticsTradingVolReportPartnerAccount:\r\n 'partnershipIbInfoStatisticsTradingVolReportPartnerAccount',\r\n partnershipIbInfoStatisticsTradingVolReportPartnerDepositUsd:\r\n 'partnershipIbInfoStatisticsTradingVolReportPartnerDepositUsd',\r\n partnershipIbInfoStatisticsTradingVolReportPartnerNetDepositUsd:\r\n 'partnershipIbInfoStatisticsTradingVolReportPartnerNetDepositUsd',\r\n partnershipIbInfoStatisticsTradingVolReportPartnerTradingVolume:\r\n 'partnershipIbInfoStatisticsTradingVolReportPartnerTradingVolume',\r\n partnershipIbInfoStatisticsTradingVolReportPartnerWithdrawalUsd:\r\n 'partnershipIbInfoStatisticsTradingVolReportPartnerWithdrawalUsd',\r\n partnershipIbInfoStatisticsTradingVolReportPeriod: 'partnershipIbInfoStatisticsTradingVolReportPeriod',\r\n partnershipIbInfoStatisticsTradingVolReportTitle: 'partnershipIbInfoStatisticsTradingVolReportTitle',\r\n partnershipIbInfoStatisticsTradingVolReportTotalClientsSubIb:\r\n 'partnershipIbInfoStatisticsTradingVolReportTotalClientsSubIb',\r\n partnershipIbInfoStatisticsTradingVolReportTotalEcn: 'partnershipIbInfoStatisticsTradingVolReportTotalEcn',\r\n partnershipIbInfoStatisticsTradingVolReportTotalNonEcn: 'partnershipIbInfoStatisticsTradingVolReportTotalNonEcn',\r\n partnershipIbInfoTradersSettingsActionTitle: 'partnershipIbInfoTradersSettingsActionTitle',\r\n partnershipIbInfoTradersSettingsCategory: 'partnershipIbInfoTradersSettingsCategory',\r\n partnershipIbInfoTradersSettingsCommission: 'partnershipIbInfoTradersSettingsCommission',\r\n partnershipIbInfoTradersSettingsIsHidden: 'partnershipIbInfoTradersSettingsIsHidden',\r\n partnershipIbInfoTradersSettingsSpread: 'partnershipIbInfoTradersSettingsSpread',\r\n partnershipIbInfoTradersSettingsTitle: 'partnershipIbInfoTradersSettingsTitle',\r\n partnershipIbInfoTradersSettingsUser: 'partnershipIbInfoTradersSettingsUser',\r\n partnershipIbInfoTradersTraderAccountsTitle: 'partnershipIbInfoTradersTraderAccountsTitle',\r\n partnershipIbInfoTradersTraderClientsTitle: 'partnershipIbInfoTradersTraderClientsTitle',\r\n partnershipIbInfoTradersTradersTitle: 'partnershipIbInfoTradersTradersTitle',\r\n partnershipIbInfoTradingReportsLink: 'partnershipIbInfoTradingReportsLink',\r\n partnershipIbSettingsCanBeIb: 'partnershipIbSettingsCanBeIb',\r\n partnershipIbSettingsCanBeIbHint: 'partnershipIbSettingsCanBeIbHint',\r\n partnershipIbSettingsCopyToClipboardBtn: 'partnershipIbSettingsCopyToClipboardBtn',\r\n partnershipIbSettingsGenerateBtn: 'partnershipIbSettingsGenerateBtn',\r\n partnershipIbSettingsGenerateNote: 'partnershipIbSettingsGenerateNote',\r\n partnershipIbSettingsIbCodeTitle: 'partnershipIbSettingsIbCodeTitle',\r\n partnershipIbSettingsIbDataFetchFail: 'partnershipIbSettingsIbDataFetchFail',\r\n partnershipIbSettingsMinMaxMessage: 'partnershipIbSettingsMinMaxMessage',\r\n partnershipIbSettingsName: 'partnershipIbSettingsName',\r\n partnershipIbSettingsNameValueError: 'partnershipIbSettingsNameValueError',\r\n partnershipIbSettingsNoticeMessageTitle: 'partnershipIbSettingsNoticeMessageTitle',\r\n partnershipIbSettingsRefLinkSuccessCopy: 'partnershipIbSettingsRefLinkSuccessCopy',\r\n partnershipIbSettingsReferralLinkCopy: 'partnershipIbSettingsReferralLinkCopy',\r\n partnershipIbSettingsReferralLinkTitle: 'partnershipIbSettingsReferralLinkTitle',\r\n partnershipIbSettingsReferralLinkWasCreated: 'partnershipIbSettingsReferralLinkWasCreated',\r\n partnershipIbSettingsReferralLinkWasCreatedForShare: 'partnershipIbSettingsReferralLinkWasCreatedForShare',\r\n partnershipIbSettingsReferralLinksList: 'partnershipIbSettingsReferralLinksList',\r\n partnershipIbSettingsReferralSettingsTitle: 'partnershipIbSettingsReferralSettingsTitle',\r\n partnershipIbSettingsRegisteredUsers: 'partnershipIbSettingsRegisteredUsers',\r\n partnershipIbSettingsSaveAsDraftBtn: 'partnershipIbSettingsSaveAsDraftBtn',\r\n partnershipIbSettingsSaveAsDraftNote: 'partnershipIbSettingsSaveAsDraftNote',\r\n partnershipIbSettingsSendSubmitForApprovalSuccess: 'partnershipIbSettingsSendSubmitForApprovalSuccess',\r\n partnershipIbSettingsSettingsCommission: 'partnershipIbSettingsSettingsCommission',\r\n partnershipIbSettingsSettingsCommissionMax: 'partnershipIbSettingsSettingsCommissionMax',\r\n partnershipIbSettingsSettingsCommissionPrefix: 'partnershipIbSettingsSettingsCommissionPrefix',\r\n partnershipIbSettingsSettingsCommissionSettings: 'partnershipIbSettingsSettingsCommissionSettings',\r\n partnershipIbSettingsSettingsCommissionUnit: 'partnershipIbSettingsSettingsCommissionUnit',\r\n partnershipIbSettingsSettingsCost: 'partnershipIbSettingsSettingsCost',\r\n partnershipIbSettingsSettingsCostPrefix: 'partnershipIbSettingsSettingsCostPrefix',\r\n partnershipIbSettingsSettingsCostSettings: 'partnershipIbSettingsSettingsCostSettings',\r\n partnershipIbSettingsSettingsIsAllowCommission: 'partnershipIbSettingsSettingsIsAllowCommission',\r\n partnershipIbSettingsSettingsIsIb: 'partnershipIbSettingsSettingsIsIb',\r\n partnershipIbSettingsSettingsPayoutType: 'partnershipIbSettingsSettingsPayoutType',\r\n partnershipIbSettingsSettingsProfitShare: 'partnershipIbSettingsSettingsProfitShare',\r\n partnershipIbSettingsSettingsProfitShareSettings: 'partnershipIbSettingsSettingsProfitShareSettings',\r\n partnershipIbSettingsSettingsProfitShareUnit: 'partnershipIbSettingsSettingsProfitShareUnit',\r\n partnershipIbSettingsSettingsRebate: 'partnershipIbSettingsSettingsRebate',\r\n partnershipIbSettingsSettingsRebateSettings: 'partnershipIbSettingsSettingsRebateSettings',\r\n partnershipIbSettingsSettingsRebateUnit: 'partnershipIbSettingsSettingsRebateUnit',\r\n partnershipIbSettingsSettingsSpread: 'partnershipIbSettingsSettingsSpread',\r\n partnershipIbSettingsSettingsSpreadMax: 'partnershipIbSettingsSettingsSpreadMax',\r\n partnershipIbSettingsSettingsSpreadPrefix: 'partnershipIbSettingsSettingsSpreadPrefix',\r\n partnershipIbSettingsSettingsSpreadSettings: 'partnershipIbSettingsSettingsSpreadSettings',\r\n partnershipIbSettingsSettingsSpreadUnit: 'partnershipIbSettingsSettingsSpreadUnit',\r\n partnershipIbSettingsSettingsTotalMax: 'partnershipIbSettingsSettingsTotalMax',\r\n partnershipIbSettingsSettingsTotalSettings: 'partnershipIbSettingsSettingsTotalSettings',\r\n partnershipIbSettingsSettingsTotalUnit: 'partnershipIbSettingsSettingsTotalUnit',\r\n partnershipIbSettingsSettingsTradingGroup: 'partnershipIbSettingsSettingsTradingGroup',\r\n partnershipIbSettingsSettingsTradingSymbol: 'partnershipIbSettingsSettingsTradingSymbol',\r\n partnershipIbSettingsSubmitForApproval: 'partnershipIbSettingsSubmitForApproval',\r\n partnershipIbTreeComission: 'partnershipIbTreeComission',\r\n partnershipIbTreeDirectAccountsEmptyListTxt: 'partnershipIbTreeDirectAccountsEmptyListTxt',\r\n partnershipIbTreeDirectAccountsTitle: 'partnershipIbTreeDirectAccountsTitle',\r\n partnershipIbTreeEmail: 'partnershipIbTreeEmail',\r\n partnershipIbTreeIb: 'partnershipIbTreeIb',\r\n partnershipIbTreeIbCode: 'partnershipIbTreeIbCode',\r\n partnershipIbTreePartners: 'partnershipIbTreePartners',\r\n partnershipIbTreeSubIb: 'partnershipIbTreeSubIb',\r\n partnershipIbTreeSubIbsEmptyListTxt: 'partnershipIbTreeSubIbsEmptyListTxt',\r\n partnershipIbTreeSubIbsTitle: 'partnershipIbTreeSubIbsTitle',\r\n partnershipIbTreeTreeTitle: 'partnershipIbTreeTreeTitle',\r\n partnershipMamInfoInfoTitle: 'partnershipMamInfoInfoTitle',\r\n partnershipMamInfoInvestorAccountsTitle: 'partnershipMamInfoInvestorAccountsTitle',\r\n partnershipMamInfoInvestorUsersTitle: 'partnershipMamInfoInvestorUsersTitle',\r\n partnershipMamInfoMamCodeTitle: 'partnershipMamInfoMamCodeTitle',\r\n partnershipMamInfoMamDataFetchFail: 'partnershipMamInfoMamDataFetchFail',\r\n partnershipMamInvestorTitle: 'partnershipMamInvestorTitle',\r\n partnershipMamLinksCreateMamLink: 'partnershipMamLinksCreateMamLink',\r\n partnershipMamLinksEditMamLink: 'partnershipMamLinksEditMamLink',\r\n partnershipMamLinksMamLinkDetailsTitle: 'partnershipMamLinksMamLinkDetailsTitle',\r\n partnershipMamLinksMamLinksFormAccountCategory: 'partnershipMamLinksMamLinksFormAccountCategory',\r\n partnershipMamLinksMamLinksFormAllocationMode: 'partnershipMamLinksMamLinksFormAllocationMode',\r\n partnershipMamLinksMamLinksFormCommission: 'partnershipMamLinksMamLinksFormCommission',\r\n partnershipMamLinksMamLinksFormCommissionAccount: 'partnershipMamLinksMamLinksFormCommissionAccount',\r\n partnershipMamLinksMamLinksFormCreationAgreement: 'partnershipMamLinksMamLinksFormCreationAgreement',\r\n partnershipMamLinksMamLinksFormManagementFeesMonthly: 'partnershipMamLinksMamLinksFormManagementFeesMonthly',\r\n partnershipMamLinksMamLinksFormMinMaxMessage: 'partnershipMamLinksMamLinksFormMinMaxMessage',\r\n partnershipMamLinksMamLinksFormNoTradingAccounts: 'partnershipMamLinksMamLinksFormNoTradingAccounts',\r\n partnershipMamLinksMamLinksFormProfitSharing: 'partnershipMamLinksMamLinksFormProfitSharing',\r\n partnershipMamLinksMamLinksFormTerminationHours: 'partnershipMamLinksMamLinksFormTerminationHours',\r\n partnershipMamLinksMamLinksFormTradingAccount: 'partnershipMamLinksMamLinksFormTradingAccount',\r\n partnershipMamLinksMamLinksListTitle: 'partnershipMamLinksMamLinksListTitle',\r\n partnershipMamManagerTitle: 'partnershipMamManagerTitle',\r\n partnershipPartnershipEWallets: 'partnershipPartnershipEWallets',\r\n partnershipPartnershipSettingSetMainIbBtn: 'partnershipPartnershipSettingSetMainIbBtn',\r\n partnershipPartnershipSettingUpdateBtn: 'partnershipPartnershipSettingUpdateBtn',\r\n partnershipPartnershipSettingUpdateConfirmationTxt: 'partnershipPartnershipSettingUpdateConfirmationTxt',\r\n partnershipPartnershipTitle: 'partnershipPartnershipTitle',\r\n partnershipQuestionnaireCreateQuestionarrieTxt: 'partnershipQuestionnaireCreateQuestionarrieTxt',\r\n partnershipQuestionnaireDeleteConfirmationTxt: 'partnershipQuestionnaireDeleteConfirmationTxt',\r\n partnershipQuestionnaireProvideSignature: 'partnershipQuestionnaireProvideSignature',\r\n partnershipQuestionnaireQuestionnaireCreateFailErr: 'partnershipQuestionnaireQuestionnaireCreateFailErr',\r\n partnershipQuestionnaireQuestionnaireDeleteFailErr: 'partnershipQuestionnaireQuestionnaireDeleteFailErr',\r\n partnershipQuestionnaireQuestionnaireSendFailErr: 'partnershipQuestionnaireQuestionnaireSendFailErr',\r\n partnershipQuestionnaireQuestionnaireUpdateFailErr: 'partnershipQuestionnaireQuestionnaireUpdateFailErr',\r\n partnershipQuestionnaireSendBtn: 'partnershipQuestionnaireSendBtn',\r\n partnershipQuestionnaireStartBtn: 'partnershipQuestionnaireStartBtn',\r\n partnershipQuestionnaireValidationFailTxt: 'partnershipQuestionnaireValidationFailTxt',\r\n partnershipSalesUserInfoEmail: 'partnershipSalesUserInfoEmail',\r\n partnershipSalesUserInfoName: 'partnershipSalesUserInfoName',\r\n partnershipSalesUserInfoPhone: 'partnershipSalesUserInfoPhone',\r\n partnershipSalesUserInfoTitle: 'partnershipSalesUserInfoTitle',\r\n paymentMethod: 'paymentMethod',\r\n paymentStatus: 'paymentStatus',\r\n paymentSystemConsent: 'paymentSystemConsent',\r\n paymentSystemConsents: 'paymentSystemConsents',\r\n paymentSystemUserAccessSettingList: 'paymentSystemUserAccessSettingList',\r\n permissionGroup: 'permissionGroup',\r\n permissionGroups: 'permissionGroups',\r\n permissionsUser: 'permissionsUser',\r\n pinCodeConfirmNewPinCode: 'pinCodeConfirmNewPinCode',\r\n pinCodeConfirmNewPinCodeValidationMessage: 'pinCodeConfirmNewPinCodeValidationMessage',\r\n pinCodeMAPassword: 'pinCodeMAPassword',\r\n pinCodeNewPinCode: 'pinCodeNewPinCode',\r\n pinCodePinCodeHint: 'pinCodePinCodeHint',\r\n pinCodePinCodeValidationMessage: 'pinCodePinCodeValidationMessage',\r\n profileAboutMe: 'profileAboutMe',\r\n profileAccountIsNotValidatedToDeposit: 'profileAccountIsNotValidatedToDeposit',\r\n profileAccountIsNotValidatedToWithdraw: 'profileAccountIsNotValidatedToWithdraw',\r\n profileAddress: 'profileAddress',\r\n profileBankDetailsTitle: 'profileBankDetailsTitle',\r\n profileBeforeSubmitDocumentsHint: 'profileBeforeSubmitDocumentsHint',\r\n profileCategoryABProofOfAddress: 'profileCategoryABProofOfAddress',\r\n profileCategoryABProofOfIdentity: 'profileCategoryABProofOfIdentity',\r\n profileCategoryABTopHint: 'profileCategoryABTopHint',\r\n profileChangeAvatar: 'profileChangeAvatar',\r\n profileChinesePinyin: 'profileChinesePinyin',\r\n profileChinesePinyinHint: 'profileChinesePinyinHint',\r\n profileCity: 'profileCity',\r\n profileCompleteIdentification: 'profileCompleteIdentification',\r\n profileCompleteProfileToDeposit: 'profileCompleteProfileToDeposit',\r\n profileConfirmPassword: 'profileConfirmPassword',\r\n profileContactDetailsTitle: 'profileContactDetailsTitle',\r\n profileCountryOfResidence: 'profileCountryOfResidence',\r\n profileDateBirthHint: 'profileDateBirthHint',\r\n profileDateBirthHintWithMaxAllowedAge: 'profileDateBirthHintWithMaxAllowedAge',\r\n profileDateOfBirth: 'profileDateOfBirth',\r\n profileDepositsAndWithdrawalOnlyForVerifiedAccounts: 'profileDepositsAndWithdrawalOnlyForVerifiedAccounts',\r\n profileDepositsForUnverifiedAccounts: 'profileDepositsForUnverifiedAccounts',\r\n profileDocumentSideNationalIdBack: 'profileDocumentSideNationalIdBack',\r\n profileDocumentSideNationalIdFront: 'profileDocumentSideNationalIdFront',\r\n profileDocumentsHint: 'profileDocumentsHint',\r\n profileEmail: 'profileEmail',\r\n profileEnterYourNickname: 'profileEnterYourNickname',\r\n profileFailedToGetSignature: 'profileFailedToGetSignature',\r\n profileFailedToSendingUserProfile: 'profileFailedToSendingUserProfile',\r\n profileFirstName: 'profileFirstName',\r\n profileFirstNameIsTheSameAsInID: 'profileFirstNameIsTheSameAsInID',\r\n profileGovernmentPhotoTitle: 'profileGovernmentPhotoTitle',\r\n profileHoldOn: 'profileHoldOn',\r\n profileLastName: 'profileLastName',\r\n profileLastNameIsTheSameAsInID: 'profileLastNameIsTheSameAsInID',\r\n profileNewPassword: 'profileNewPassword',\r\n profileNickname: 'profileNickname',\r\n profileOccupation: 'profileOccupation',\r\n profileOneTimePassword: 'profileOneTimePassword',\r\n profilePassword: 'profilePassword',\r\n profilePasswordRegistrationRulesHint: 'profilePasswordRegistrationRulesHint',\r\n profilePersonalDetailsTitle: 'profilePersonalDetailsTitle',\r\n profilePhone: 'profilePhone',\r\n profilePlaceholder: 'profilePlaceholder',\r\n profilePleaseSelectOne: 'profilePleaseSelectOne',\r\n profilePleaseSelectRequiredCount: 'profilePleaseSelectRequiredCount',\r\n profilePleaseValidateAccountToWithdraw: 'profilePleaseValidateAccountToWithdraw',\r\n profileProofOfAddress: 'profileProofOfAddress',\r\n profileProofOfIdentity: 'profileProofOfIdentity',\r\n profileQformsTypeTitle: 'profileQformsTypeTitle',\r\n profileSignature: 'profileSignature',\r\n profileState: 'profileState',\r\n profileSubmitPersonalDetailsToDeposit: 'profileSubmitPersonalDetailsToDeposit',\r\n profileUploadDocumentsBankStatementBankStatementAccountHoldersName:\r\n 'profileUploadDocumentsBankStatementBankStatementAccountHoldersName',\r\n profileUploadDocumentsBankStatementBankStatementBankAccountNumber:\r\n 'profileUploadDocumentsBankStatementBankStatementBankAccountNumber',\r\n profileUploadDocumentsBankStatementBankStatementBankName: 'profileUploadDocumentsBankStatementBankStatementBankName',\r\n profileUploadDocumentsBankStatementBankStatementLessThan3MonthOld:\r\n 'profileUploadDocumentsBankStatementBankStatementLessThan3MonthOld',\r\n profileUploadDocumentsBankStatementBankStatementMustShow: 'profileUploadDocumentsBankStatementBankStatementMustShow',\r\n profileUploadDocumentsBankTransferBankTransferBankAccountNumber:\r\n 'profileUploadDocumentsBankTransferBankTransferBankAccountNumber',\r\n profileUploadDocumentsBankTransferBankTransferDateTimeOfPayment:\r\n 'profileUploadDocumentsBankTransferBankTransferDateTimeOfPayment',\r\n profileUploadDocumentsBankTransferBankTransferMustShow: 'profileUploadDocumentsBankTransferBankTransferMustShow',\r\n profileUploadDocumentsBankTransferBankTransferPaidAmount: 'profileUploadDocumentsBankTransferBankTransferPaidAmount',\r\n profileUploadDocumentsBankTransferBankTransferTransactionID:\r\n 'profileUploadDocumentsBankTransferBankTransferTransactionID',\r\n profileUploadDocumentsDigitalWalletStatementDigitalWalletStatementAccountNumber:\r\n 'profileUploadDocumentsDigitalWalletStatementDigitalWalletStatementAccountNumber',\r\n profileUploadDocumentsDigitalWalletStatementDigitalWalletStatementMustShow:\r\n 'profileUploadDocumentsDigitalWalletStatementDigitalWalletStatementMustShow',\r\n profileUploadDocumentsDigitalWalletStatementDigitalWalletStatementName:\r\n 'profileUploadDocumentsDigitalWalletStatementDigitalWalletStatementName',\r\n profileUploadDocumentsProofAccountProofAccountBankingDetails:\r\n 'profileUploadDocumentsProofAccountProofAccountBankingDetails',\r\n profileUploadDocumentsProofAccountProofAccountFullName: 'profileUploadDocumentsProofAccountProofAccountFullName',\r\n profileUploadDocumentsProofAccountProofAccountFundingHistory:\r\n 'profileUploadDocumentsProofAccountProofAccountFundingHistory',\r\n profileUploadDocumentsProofAccountProofAccountMustShow: 'profileUploadDocumentsProofAccountProofAccountMustShow',\r\n profileUploadDocumentsProofTransactionProofTransactionAddress:\r\n 'profileUploadDocumentsProofTransactionProofTransactionAddress',\r\n profileUploadDocumentsProofTransactionProofTransactionDateTimeOfPayment:\r\n 'profileUploadDocumentsProofTransactionProofTransactionDateTimeOfPayment',\r\n profileUploadDocumentsProofTransactionProofTransactionMustShow:\r\n 'profileUploadDocumentsProofTransactionProofTransactionMustShow',\r\n profileUploadDocumentsProofTransactionProofTransactionPaidAmount:\r\n 'profileUploadDocumentsProofTransactionProofTransactionPaidAmount',\r\n profileUploadDocumentsProofTransactionProofTransactionTransactionID:\r\n 'profileUploadDocumentsProofTransactionProofTransactionTransactionID',\r\n profileUploadDocumentsUserCardStatementUserCardStatementCardHolderNameSide:\r\n 'profileUploadDocumentsUserCardStatementUserCardStatementCardHolderNameSide',\r\n profileUploadDocumentsUserCardStatementUserCardStatementCardNumber:\r\n 'profileUploadDocumentsUserCardStatementUserCardStatementCardNumber',\r\n profileUploadDocumentsUserCardStatementUserCardStatementCardholderName:\r\n 'profileUploadDocumentsUserCardStatementUserCardStatementCardholderName',\r\n profileUploadDocumentsUserCardStatementUserCardStatementCode:\r\n 'profileUploadDocumentsUserCardStatementUserCardStatementCode',\r\n profileUploadDocumentsUserCardStatementUserCardStatementDropzoneTitle:\r\n 'profileUploadDocumentsUserCardStatementUserCardStatementDropzoneTitle',\r\n profileUploadDocumentsUserCardStatementUserCardStatementMustShow:\r\n 'profileUploadDocumentsUserCardStatementUserCardStatementMustShow',\r\n profileUploadDocumentsUserCardStatementUserCardStatementRequired:\r\n 'profileUploadDocumentsUserCardStatementUserCardStatementRequired',\r\n profileUploadDocumentsUserCardStatementUserCardUploadExpirationDate:\r\n 'profileUploadDocumentsUserCardStatementUserCardUploadExpirationDate',\r\n profileUserUploadsTitle: 'profileUserUploadsTitle',\r\n profileVerificationBtnTxt: 'profileVerificationBtnTxt',\r\n profileVerificationRequiredTxt: 'profileVerificationRequiredTxt',\r\n profileVerifyAndProceed: 'profileVerifyAndProceed',\r\n profileVerifyPhoneHint: 'profileVerifyPhoneHint',\r\n profileWarningMessageBankCardDropzoneHint: 'profileWarningMessageBankCardDropzoneHint',\r\n profileWarningMessageBankCardDropzoneTitle: 'profileWarningMessageBankCardDropzoneTitle',\r\n profileWarningMessageBankCardProvideInfo: 'profileWarningMessageBankCardProvideInfo',\r\n profileWarningMessageBankCardRequiresUpdates: 'profileWarningMessageBankCardRequiresUpdates',\r\n profileWarningMessageBankCardRequiresUpdatesDescription: 'profileWarningMessageBankCardRequiresUpdatesDescription',\r\n profileWarningMessageBankCardRequiresUpdatesReview: 'profileWarningMessageBankCardRequiresUpdatesReview',\r\n profileWarningMessageBankCardRequiresUpdatesTitle: 'profileWarningMessageBankCardRequiresUpdatesTitle',\r\n profileWarningMessageConfirmThatPaymentsAreMadeFromRegisteredAccount:\r\n 'profileWarningMessageConfirmThatPaymentsAreMadeFromRegisteredAccount',\r\n profileWarningMessageImportantInformation: 'profileWarningMessageImportantInformation',\r\n profileWarningMessageMakeSureDescriptionIsEmptyForUnionPayOnlyCN:\r\n 'profileWarningMessageMakeSureDescriptionIsEmptyForUnionPayOnlyCN',\r\n profileWarningMessageNameDoesNotMatch: 'profileWarningMessageNameDoesNotMatch',\r\n profileWarningMessageNicknameisAlreadyUsed: 'profileWarningMessageNicknameisAlreadyUsed',\r\n profileWarningMessageThirdPartyDeposits: 'profileWarningMessageThirdPartyDeposits',\r\n profileWarningMessageUploadBankCardDropzoneTitle: 'profileWarningMessageUploadBankCardDropzoneTitle',\r\n profileWarningMessageVerifyYourIdentity: 'profileWarningMessageVerifyYourIdentity',\r\n profileWithdrawalOnlyForVerifiedAccounts: 'profileWithdrawalOnlyForVerifiedAccounts',\r\n profileWorkingOnVerifyingData: 'profileWorkingOnVerifyingData',\r\n profileZipCode: 'profileZipCode',\r\n pspAmountLimitHint: 'pspAmountLimitHint',\r\n pspAssociatedCryptoWalletAccount: 'pspAssociatedCryptoWalletAccount',\r\n pspBackToPaymentMethods: 'pspBackToPaymentMethods',\r\n pspBankAccountDetailsBankAccountFormBankHint: 'pspBankAccountDetailsBankAccountFormBankHint',\r\n pspBankAccountDetailsBankAccountFormExpectedBank: 'pspBankAccountDetailsBankAccountFormExpectedBank',\r\n pspBankAccountDetailsBankAccountFormNoBankOption: 'pspBankAccountDetailsBankAccountFormNoBankOption',\r\n pspBankAccountDetailsBankAccountTabTitle: 'pspBankAccountDetailsBankAccountTabTitle',\r\n pspBankAccountDetailsCreateDuplicateConfirmMessage: 'pspBankAccountDetailsCreateDuplicateConfirmMessage',\r\n pspBankAccountDetailsCreateProhibitedBankConfirmMessage: 'pspBankAccountDetailsCreateProhibitedBankConfirmMessage',\r\n pspBankAccountDetailsTooltipStatusCreated: 'pspBankAccountDetailsTooltipStatusCreated',\r\n pspBankAccountDetailsWarningMessageTitle: 'pspBankAccountDetailsWarningMessageTitle',\r\n pspBankAccountDetailsWithdrawalHint: 'pspBankAccountDetailsWithdrawalHint',\r\n pspBankAccountWasSuccessfullyCreated: 'pspBankAccountWasSuccessfullyCreated',\r\n pspBankDocument: 'pspBankDocument',\r\n pspBankStatement: 'pspBankStatement',\r\n pspBankStatementTooltip: 'pspBankStatementTooltip',\r\n pspBankTransfer: 'pspBankTransfer',\r\n pspBankTransferReceipt: 'pspBankTransferReceipt',\r\n pspBankTransferReceiptTooltip: 'pspBankTransferReceiptTooltip',\r\n pspCardStatement: 'pspCardStatement',\r\n pspChoosePreferredMethod: 'pspChoosePreferredMethod',\r\n pspConfirmFormConfirmDepositStepTitle: 'pspConfirmFormConfirmDepositStepTitle',\r\n pspConfirmFormConfirmWithdrawalStepTitle: 'pspConfirmFormConfirmWithdrawalStepTitle',\r\n pspConfirmFormPinCodeTitle: 'pspConfirmFormPinCodeTitle',\r\n pspConfirmQRCode: 'pspConfirmQRCode',\r\n pspConfirmQRCodeGBPrimePay: 'pspConfirmQRCodeGBPrimePay',\r\n pspConfirmQRCodeParemit: 'pspConfirmQRCodeParemit',\r\n pspConsentList: 'pspConsentList',\r\n pspConsents: 'pspConsents',\r\n pspContactUs: 'pspContactUs',\r\n pspCryptoWalletAccountWarningMessageTitle: 'pspCryptoWalletAccountWarningMessageTitle',\r\n pspCryptoWalletCryptoAddressWasSuccessfullyCreated: 'pspCryptoWalletCryptoAddressWasSuccessfullyCreated',\r\n pspCryptoWalletDetailsCreateTitle: 'pspCryptoWalletDetailsCreateTitle',\r\n pspCryptoWalletDetailsCryptoWalletTabTitle: 'pspCryptoWalletDetailsCryptoWalletTabTitle',\r\n pspCryptoWalletDetailsDocumentStatementAddressTitle: 'pspCryptoWalletDetailsDocumentStatementAddressTitle',\r\n pspCryptoWalletDetailsDocumentStatementImageCryptoAddress:\r\n 'pspCryptoWalletDetailsDocumentStatementImageCryptoAddress',\r\n pspCryptoWalletDetailsDocumentStatementWalletEmailAddress:\r\n 'pspCryptoWalletDetailsDocumentStatementWalletEmailAddress',\r\n pspCryptoWalletDetailsDocumentStatementWalletHolderFullName:\r\n 'pspCryptoWalletDetailsDocumentStatementWalletHolderFullName',\r\n pspCryptoWalletDetailsDocumentStatementWalletLogoOfExchanger:\r\n 'pspCryptoWalletDetailsDocumentStatementWalletLogoOfExchanger',\r\n pspCryptoWalletDetailsDocumentStatementWalletTitle: 'pspCryptoWalletDetailsDocumentStatementWalletTitle',\r\n pspCryptoWalletDetailsReceivingAddressTitleWarning: 'pspCryptoWalletDetailsReceivingAddressTitleWarning',\r\n pspCryptoWalletDetailsWalletOwnershipTitleWarning: 'pspCryptoWalletDetailsWalletOwnershipTitleWarning',\r\n pspCurrencyAmountHint: 'pspCurrencyAmountHint',\r\n pspCurrencyAmountHintWithPrecision: 'pspCurrencyAmountHintWithPrecision',\r\n pspCurrentTransactionStatus: 'pspCurrentTransactionStatus',\r\n pspDepositBonusModalActiveModalNoticeListItemsItem1: 'pspDepositBonusModalActiveModalNoticeListItemsItem1',\r\n pspDepositBonusModalActiveModalNoticeMessage: 'pspDepositBonusModalActiveModalNoticeMessage',\r\n pspDepositBonusModalActiveModalTitle: 'pspDepositBonusModalActiveModalTitle',\r\n pspDepositBonusModalButtonsContact: 'pspDepositBonusModalButtonsContact',\r\n pspDepositBonusModalButtonsProceed: 'pspDepositBonusModalButtonsProceed',\r\n pspDepositBonusModalDisabledModalTitle: 'pspDepositBonusModalDisabledModalTitle',\r\n pspDepositBonusModalDisabledModalWarningListItemsItem1: 'pspDepositBonusModalDisabledModalWarningListItemsItem1',\r\n pspDepositBonusModalDisabledModalWarningListItemsItem2: 'pspDepositBonusModalDisabledModalWarningListItemsItem2',\r\n pspDepositBonusModalDisabledModalWarningMessage: 'pspDepositBonusModalDisabledModalWarningMessage',\r\n pspDepositBonusModalExpiredModalSubTitle: 'pspDepositBonusModalExpiredModalSubTitle',\r\n pspDepositBonusModalExpiredModalTitle: 'pspDepositBonusModalExpiredModalTitle',\r\n pspDepositBonusModalTimerDays: 'pspDepositBonusModalTimerDays',\r\n pspDepositBonusModalTimerHeader: 'pspDepositBonusModalTimerHeader',\r\n pspDepositBonusModalTimerHours: 'pspDepositBonusModalTimerHours',\r\n pspDepositBonusModalTimerMinutes: 'pspDepositBonusModalTimerMinutes',\r\n pspDepositBonusModalTimerSeconds: 'pspDepositBonusModalTimerSeconds',\r\n pspDepositDepositCPFNumberTitle: 'pspDepositDepositCPFNumberTitle',\r\n pspDepositDepositFormAccountBalanceHint: 'pspDepositDepositFormAccountBalanceHint',\r\n pspDepositDepositFormAccountHint: 'pspDepositDepositFormAccountHint',\r\n pspDepositDepositFormAccountHolderName: 'pspDepositDepositFormAccountHolderName',\r\n pspDepositDepositFormAccountNumberIsTheSameAsOnPhoto: 'pspDepositDepositFormAccountNumberIsTheSameAsOnPhoto',\r\n pspDepositDepositFormAccountNumberTitle: 'pspDepositDepositFormAccountNumberTitle',\r\n pspDepositDepositFormAccountOwnership: 'pspDepositDepositFormAccountOwnership',\r\n pspDepositDepositFormAccountTitle: 'pspDepositDepositFormAccountTitle',\r\n pspDepositDepositFormAccountVerificationCode: 'pspDepositDepositFormAccountVerificationCode',\r\n pspDepositDepositFormAddNewBankAccount: 'pspDepositDepositFormAddNewBankAccount',\r\n pspDepositDepositFormAddNewBankAccountHolderName: 'pspDepositDepositFormAddNewBankAccountHolderName',\r\n pspDepositDepositFormAddNewBankCardNumber: 'pspDepositDepositFormAddNewBankCardNumber',\r\n pspDepositDepositFormAddNewDigitalWalletAccount: 'pspDepositDepositFormAddNewDigitalWalletAccount',\r\n pspDepositDepositFormAddress: 'pspDepositDepositFormAddress',\r\n pspDepositDepositFormAddressLine1: 'pspDepositDepositFormAddressLine1',\r\n pspDepositDepositFormAmountTitle: 'pspDepositDepositFormAmountTitle',\r\n pspDepositDepositFormAmountUSDTitle: 'pspDepositDepositFormAmountUSDTitle',\r\n pspDepositDepositFormAssociatedBankAccount: 'pspDepositDepositFormAssociatedBankAccount',\r\n pspDepositDepositFormAssociatedDigitalWalletAccount: 'pspDepositDepositFormAssociatedDigitalWalletAccount',\r\n pspDepositDepositFormAssociatedPayerName: 'pspDepositDepositFormAssociatedPayerName',\r\n pspDepositDepositFormAssociatedUserCard: 'pspDepositDepositFormAssociatedUserCard',\r\n pspDepositDepositFormBankAccountHolderName: 'pspDepositDepositFormBankAccountHolderName',\r\n pspDepositDepositFormBankAccountHolderNameTooltip: 'pspDepositDepositFormBankAccountHolderNameTooltip',\r\n pspDepositDepositFormBankAccountNumber: 'pspDepositDepositFormBankAccountNumber',\r\n pspDepositDepositFormBankAccountTitle: 'pspDepositDepositFormBankAccountTitle',\r\n pspDepositDepositFormBankBranchNameHint: 'pspDepositDepositFormBankBranchNameHint',\r\n pspDepositDepositFormBankBranchNameTitle: 'pspDepositDepositFormBankBranchNameTitle',\r\n pspDepositDepositFormBankCardNumberTitle: 'pspDepositDepositFormBankCardNumberTitle',\r\n pspDepositDepositFormBankNameTitle: 'pspDepositDepositFormBankNameTitle',\r\n pspDepositDepositFormBankStatement: 'pspDepositDepositFormBankStatement',\r\n pspDepositDepositFormBankTitle: 'pspDepositDepositFormBankTitle',\r\n pspDepositDepositFormBeneficiaryBankNameTitle: 'pspDepositDepositFormBeneficiaryBankNameTitle',\r\n pspDepositDepositFormBeneficiaryDigitalWalletNameTitle: 'pspDepositDepositFormBeneficiaryDigitalWalletNameTitle',\r\n pspDepositDepositFormCardHint: 'pspDepositDepositFormCardHint',\r\n pspDepositDepositFormChannelNameTitle: 'pspDepositDepositFormChannelNameTitle',\r\n pspDepositDepositFormCityTitle: 'pspDepositDepositFormCityTitle',\r\n pspDepositDepositFormConvertedAmount: 'pspDepositDepositFormConvertedAmount',\r\n pspDepositDepositFormCryptoAddress: 'pspDepositDepositFormCryptoAddress',\r\n pspDepositDepositFormCryptoCyrrencyHint: 'pspDepositDepositFormCryptoCyrrencyHint',\r\n pspDepositDepositFormCryptoCyrrencyTitle: 'pspDepositDepositFormCryptoCyrrencyTitle',\r\n pspDepositDepositFormCurrencyTitle: 'pspDepositDepositFormCurrencyTitle',\r\n pspDepositDepositFormDepositVerification: 'pspDepositDepositFormDepositVerification',\r\n pspDepositDepositFormDigitalWalletAccountNumber: 'pspDepositDepositFormDigitalWalletAccountNumber',\r\n pspDepositDepositFormDigitalWalletNameTitle: 'pspDepositDepositFormDigitalWalletNameTitle',\r\n pspDepositDepositFormDigitalWalletStatement: 'pspDepositDepositFormDigitalWalletStatement',\r\n pspDepositDepositFormDigitalWalletTitle: 'pspDepositDepositFormDigitalWalletTitle',\r\n pspDepositDepositFormEmailAddress: 'pspDepositDepositFormEmailAddress',\r\n pspDepositDepositFormEmulatorIsRedirectTitle: 'pspDepositDepositFormEmulatorIsRedirectTitle',\r\n pspDepositDepositFormFileInputHint: 'pspDepositDepositFormFileInputHint',\r\n pspDepositDepositFormFileTitle: 'pspDepositDepositFormFileTitle',\r\n pspDepositDepositFormFpAccountFrom: 'pspDepositDepositFormFpAccountFrom',\r\n pspDepositDepositFormFullNameInChinese: 'pspDepositDepositFormFullNameInChinese',\r\n pspDepositDepositFormFullNameInChineseHint: 'pspDepositDepositFormFullNameInChineseHint',\r\n pspDepositDepositFormIdentityNumberTitle: 'pspDepositDepositFormIdentityNumberTitle',\r\n pspDepositDepositFormIdentityTypeTitle: 'pspDepositDepositFormIdentityTypeTitle',\r\n pspDepositDepositFormLocalAgent: 'pspDepositDepositFormLocalAgent',\r\n pspDepositDepositFormMakeSurePspDescriptionFieldIsEmpty: 'pspDepositDepositFormMakeSurePspDescriptionFieldIsEmpty',\r\n pspDepositDepositFormMinDepositError: 'pspDepositDepositFormMinDepositError',\r\n pspDepositDepositFormNetellerAccountEmailTitle: 'pspDepositDepositFormNetellerAccountEmailTitle',\r\n pspDepositDepositFormPayerBankAccountNumberTitle: 'pspDepositDepositFormPayerBankAccountNumberTitle',\r\n pspDepositDepositFormPayerCardNumberTitle: 'pspDepositDepositFormPayerCardNumberTitle',\r\n pspDepositDepositFormPayerDigitalWalletNumberTitle: 'pspDepositDepositFormPayerDigitalWalletNumberTitle',\r\n pspDepositDepositFormPayerNameTitle: 'pspDepositDepositFormPayerNameTitle',\r\n pspDepositDepositFormPersonalId: 'pspDepositDepositFormPersonalId',\r\n pspDepositDepositFormSkrillAccountEmailHint: 'pspDepositDepositFormSkrillAccountEmailHint',\r\n pspDepositDepositFormStateTitle: 'pspDepositDepositFormStateTitle',\r\n pspDepositDepositFormTotalAfterFee: 'pspDepositDepositFormTotalAfterFee',\r\n pspDepositDepositFormUpiAddress: 'pspDepositDepositFormUpiAddress',\r\n pspDepositDepositFormUpiId: 'pspDepositDepositFormUpiId',\r\n pspDepositDepositTabTitle: 'pspDepositDepositTabTitle',\r\n pspDepositFetchFailErr: 'pspDepositFetchFailErr',\r\n pspDigitalWalletStatement: 'pspDigitalWalletStatement',\r\n pspExchangeRatesTitle: 'pspExchangeRatesTitle',\r\n pspFailedToSetPreferredAccount: 'pspFailedToSetPreferredAccount',\r\n pspFastBanking: 'pspFastBanking',\r\n pspFastBankingDescription: 'pspFastBankingDescription',\r\n pspFastest: 'pspFastest',\r\n pspFileFormat: 'pspFileFormat',\r\n pspFormAddNewCryptoAddress: 'pspFormAddNewCryptoAddress',\r\n pspFromToAmountHint: 'pspFromToAmountHint',\r\n pspGetCredited: 'pspGetCredited',\r\n pspInternalTransferProcessFailErr: 'pspInternalTransferProcessFailErr',\r\n pspLocalAgentTableAccountName: 'pspLocalAgentTableAccountName',\r\n pspLocalAgentTableDescription: 'pspLocalAgentTableDescription',\r\n pspLocalAgentTableEmail: 'pspLocalAgentTableEmail',\r\n pspLocalAgentTableFullName: 'pspLocalAgentTableFullName',\r\n pspLocalAgentTablePhone: 'pspLocalAgentTablePhone',\r\n pspLocalDepositRecipientInfo: 'pspLocalDepositRecipientInfo',\r\n pspLocalDepositReject: 'pspLocalDepositReject',\r\n pspLocalDepositSubmit: 'pspLocalDepositSubmit',\r\n pspLocalDepositSuccessMessage: 'pspLocalDepositSuccessMessage',\r\n pspLocalDepositTitle: 'pspLocalDepositTitle',\r\n pspLockedPaymentMethod: 'pspLockedPaymentMethod',\r\n pspMinimalAmountHint: 'pspMinimalAmountHint',\r\n pspMinimalDepositAmountHint: 'pspMinimalDepositAmountHint',\r\n pspNationalIdentityWarning: 'pspNationalIdentityWarning',\r\n pspOnlyNumericAccepted: 'pspOnlyNumericAccepted',\r\n pspOperationTableCallbackStatusFromPsp: 'pspOperationTableCallbackStatusFromPsp',\r\n pspOperationsTableAccountTitle: 'pspOperationsTableAccountTitle',\r\n pspOperationsTableActionAllowed: 'pspOperationsTableActionAllowed',\r\n pspOperationsTableAmountUSDTitle: 'pspOperationsTableAmountUSDTitle',\r\n pspOperationsTableAttachedFiles: 'pspOperationsTableAttachedFiles',\r\n pspOperationsTableBalanceUpdatedTitle: 'pspOperationsTableBalanceUpdatedTitle',\r\n pspOperationsTableBeneficiaryAccountNumberStatus: 'pspOperationsTableBeneficiaryAccountNumberStatus',\r\n pspOperationsTableCallbackStatusTitle: 'pspOperationsTableCallbackStatusTitle',\r\n pspOperationsTableDepositHistoryTitle: 'pspOperationsTableDepositHistoryTitle',\r\n pspOperationsTableExecutionType: 'pspOperationsTableExecutionType',\r\n pspOperationsTableFeeUSDTitle: 'pspOperationsTableFeeUSDTitle',\r\n pspOperationsTableIsMoneyTransfer: 'pspOperationsTableIsMoneyTransfer',\r\n pspOperationsTableIsMoneyTransferDeposit: 'pspOperationsTableIsMoneyTransferDeposit',\r\n pspOperationsTableIsMoneyTransferDepositFalse: 'pspOperationsTableIsMoneyTransferDepositFalse',\r\n pspOperationsTableIsMoneyTransferWithdrawal: 'pspOperationsTableIsMoneyTransferWithdrawal',\r\n pspOperationsTableIsMoneyTransferWithdrawalFalse: 'pspOperationsTableIsMoneyTransferWithdrawalFalse',\r\n pspOperationsTableKytVerificationOperation: 'pspOperationsTableKytVerificationOperation',\r\n pspOperationsTableNetAmountUSDTitle: 'pspOperationsTableNetAmountUSDTitle',\r\n pspOperationsTableOperationIdTitle: 'pspOperationsTableOperationIdTitle',\r\n pspOperationsTablePaymentSystemClassTitle: 'pspOperationsTablePaymentSystemClassTitle',\r\n pspOperationsTablePaymentSystemNameTitle: 'pspOperationsTablePaymentSystemNameTitle',\r\n pspOperationsTablePspDepositAdminAction: 'pspOperationsTablePspDepositAdminAction',\r\n pspOperationsTableTransactionTypeTitle: 'pspOperationsTableTransactionTypeTitle',\r\n pspOperationsTableUserNote: 'pspOperationsTableUserNote',\r\n pspOperationsTableWalletOperationId: 'pspOperationsTableWalletOperationId',\r\n pspOperationsTableWithdrawalsHistoryTitle: 'pspOperationsTableWithdrawalsHistoryTitle',\r\n pspPayByLink: 'pspPayByLink',\r\n pspPleaseEnsureDocumentAge: 'pspPleaseEnsureDocumentAge',\r\n pspPluginsEmpty: 'pspPluginsEmpty',\r\n pspPlusTransferReceipt: 'pspPlusTransferReceipt',\r\n pspPreferred: 'pspPreferred',\r\n pspProofAccount: 'pspProofAccount',\r\n pspProofTransaction: 'pspProofTransaction',\r\n pspPspTitle: 'pspPspTitle',\r\n pspQrCodeNotice: 'pspQrCodeNotice',\r\n pspQrCodeNoticeParemit: 'pspQrCodeNoticeParemit',\r\n pspQrCodeTitle: 'pspQrCodeTitle',\r\n pspQrCodeTitleParemit: 'pspQrCodeTitleParemit',\r\n pspReprocessFailedToResubmitWithdrawal: 'pspReprocessFailedToResubmitWithdrawal',\r\n pspReprocessWithdrawalResubmitted: 'pspReprocessWithdrawalResubmitted',\r\n pspSingleTransactionBanking: 'pspSingleTransactionBanking',\r\n pspSingleTransactionBankingDescription: 'pspSingleTransactionBankingDescription',\r\n pspStatusFixActionConfirmation: 'pspStatusFixActionConfirmation',\r\n pspStatusFixActionFailed: 'pspStatusFixActionFailed',\r\n pspStatusFixActionName: 'pspStatusFixActionName',\r\n pspStatusFixObtainingAllowedStatusFixesFailed: 'pspStatusFixObtainingAllowedStatusFixesFailed',\r\n pspTransactionInfoFetchFailErr: 'pspTransactionInfoFetchFailErr',\r\n pspTransactionResultTitle: 'pspTransactionResultTitle',\r\n pspTransactionStatus: 'pspTransactionStatus',\r\n pspTransferTransferFormAccountFromTitle: 'pspTransferTransferFormAccountFromTitle',\r\n pspTransferTransferFormAccountToTitle: 'pspTransferTransferFormAccountToTitle',\r\n pspTransferTransferFormAmountErrorRange: 'pspTransferTransferFormAmountErrorRange',\r\n pspTransferTransferFormAmountTitle: 'pspTransferTransferFormAmountTitle',\r\n pspTransferTransferFormAmountToTransferTxt: 'pspTransferTransferFormAmountToTransferTxt',\r\n pspTransferTransferFormAvailableAmountTxt: 'pspTransferTransferFormAvailableAmountTxt',\r\n pspTransferTransferFormCentToCentDecimalHint: 'pspTransferTransferFormCentToCentDecimalHint',\r\n pspTransferTransferFormCentToDollarIntegerHint: 'pspTransferTransferFormCentToDollarIntegerHint',\r\n pspTransferTransferFormContinueBtn: 'pspTransferTransferFormContinueBtn',\r\n pspTransferTransferFormDollarDecimalHint: 'pspTransferTransferFormDollarDecimalHint',\r\n pspTransferTransferFormSelectAccountTxt: 'pspTransferTransferFormSelectAccountTxt',\r\n pspTransferTransferFormTransferFormTitle: 'pspTransferTransferFormTransferFormTitle',\r\n pspTransferTransferSuccessTxt: 'pspTransferTransferSuccessTxt',\r\n pspTransferTransferTabTitle: 'pspTransferTransferTabTitle',\r\n pspTransferTransferTitle: 'pspTransferTransferTitle',\r\n pspUploadBankDocumentDropzoneTitle: 'pspUploadBankDocumentDropzoneTitle',\r\n pspUploadBankStatement: 'pspUploadBankStatement',\r\n pspUploadBankStatementDropzoneTitle: 'pspUploadBankStatementDropzoneTitle',\r\n pspUploadBankStatementOnce: 'pspUploadBankStatementOnce',\r\n pspUploadDigitalWalletDropzoneTitle: 'pspUploadDigitalWalletDropzoneTitle',\r\n pspUploadPayslipDropzoneTitle: 'pspUploadPayslipDropzoneTitle',\r\n pspUploadProofAccountDropzoneTitle: 'pspUploadProofAccountDropzoneTitle',\r\n pspUploadProofTransactionDropzoneTitle: 'pspUploadProofTransactionDropzoneTitle',\r\n pspUserSettings: 'pspUserSettings',\r\n pspWaitingRedirectToPsp: 'pspWaitingRedirectToPsp',\r\n pspWithdrawalFetchFailErr: 'pspWithdrawalFetchFailErr',\r\n pspWithdrawalSendToPspConfirmationText: 'pspWithdrawalSendToPspConfirmationText',\r\n pspWithdrawalWithdrawalFormAccountReceiverTitle: 'pspWithdrawalWithdrawalFormAccountReceiverTitle',\r\n pspWithdrawalWithdrawalFormAccountTitle: 'pspWithdrawalWithdrawalFormAccountTitle',\r\n pspWithdrawalWithdrawalFormAgencyAccountNumberTitle: 'pspWithdrawalWithdrawalFormAgencyAccountNumberTitle',\r\n pspWithdrawalWithdrawalFormAmountTitle: 'pspWithdrawalWithdrawalFormAmountTitle',\r\n pspWithdrawalWithdrawalFormAmountUSDTitle: 'pspWithdrawalWithdrawalFormAmountUSDTitle',\r\n pspWithdrawalWithdrawalFormBankAccountTypeTitle: 'pspWithdrawalWithdrawalFormBankAccountTypeTitle',\r\n pspWithdrawalWithdrawalFormBankBranchAddressTitle: 'pspWithdrawalWithdrawalFormBankBranchAddressTitle',\r\n pspWithdrawalWithdrawalFormBankBranchNameHint: 'pspWithdrawalWithdrawalFormBankBranchNameHint',\r\n pspWithdrawalWithdrawalFormBankBranchNameTitle: 'pspWithdrawalWithdrawalFormBankBranchNameTitle',\r\n pspWithdrawalWithdrawalFormBankCityTitle: 'pspWithdrawalWithdrawalFormBankCityTitle',\r\n pspWithdrawalWithdrawalFormBankCityTitleHint: 'pspWithdrawalWithdrawalFormBankCityTitleHint',\r\n pspWithdrawalWithdrawalFormBankCountryHint: 'pspWithdrawalWithdrawalFormBankCountryHint',\r\n pspWithdrawalWithdrawalFormBankCountryTitle: 'pspWithdrawalWithdrawalFormBankCountryTitle',\r\n pspWithdrawalWithdrawalFormBankIFSCCodeHint: 'pspWithdrawalWithdrawalFormBankIFSCCodeHint',\r\n pspWithdrawalWithdrawalFormBankIFSCCodeTitle: 'pspWithdrawalWithdrawalFormBankIFSCCodeTitle',\r\n pspWithdrawalWithdrawalFormBankProvinceTitle: 'pspWithdrawalWithdrawalFormBankProvinceTitle',\r\n pspWithdrawalWithdrawalFormBankProvinceTitleHint: 'pspWithdrawalWithdrawalFormBankProvinceTitleHint',\r\n pspWithdrawalWithdrawalFormBeneficiaryAccountNameTitle: 'pspWithdrawalWithdrawalFormBeneficiaryAccountNameTitle',\r\n pspWithdrawalWithdrawalFormBeneficiaryAccountNumberHint: 'pspWithdrawalWithdrawalFormBeneficiaryAccountNumberHint',\r\n pspWithdrawalWithdrawalFormBeneficiaryAccountNumberPagsmilePixTitle:\r\n 'pspWithdrawalWithdrawalFormBeneficiaryAccountNumberPagsmilePixTitle',\r\n pspWithdrawalWithdrawalFormBeneficiaryAccountNumberTitle: 'pspWithdrawalWithdrawalFormBeneficiaryAccountNumberTitle',\r\n pspWithdrawalWithdrawalFormBeneficiaryBankAddressTitle: 'pspWithdrawalWithdrawalFormBeneficiaryBankAddressTitle',\r\n pspWithdrawalWithdrawalFormBeneficiaryBankNameHint: 'pspWithdrawalWithdrawalFormBeneficiaryBankNameHint',\r\n pspWithdrawalWithdrawalFormBeneficiaryBankNameTitle: 'pspWithdrawalWithdrawalFormBeneficiaryBankNameTitle',\r\n pspWithdrawalWithdrawalFormBeneficiaryFirstLastNameHint: 'pspWithdrawalWithdrawalFormBeneficiaryFirstLastNameHint',\r\n pspWithdrawalWithdrawalFormBeneficiaryFirstNameTitle: 'pspWithdrawalWithdrawalFormBeneficiaryFirstNameTitle',\r\n pspWithdrawalWithdrawalFormBeneficiaryLastNameTitle: 'pspWithdrawalWithdrawalFormBeneficiaryLastNameTitle',\r\n pspWithdrawalWithdrawalFormBeneficiaryNameHint: 'pspWithdrawalWithdrawalFormBeneficiaryNameHint',\r\n pspWithdrawalWithdrawalFormBeneficiaryNameTitle: 'pspWithdrawalWithdrawalFormBeneficiaryNameTitle',\r\n pspWithdrawalWithdrawalFormBeneficiaryVoletWalletHint: 'pspWithdrawalWithdrawalFormBeneficiaryVoletWalletHint',\r\n pspWithdrawalWithdrawalFormBranchCode: 'pspWithdrawalWithdrawalFormBranchCode',\r\n pspWithdrawalWithdrawalFormBranchCodeHint: 'pspWithdrawalWithdrawalFormBranchCodeHint',\r\n pspWithdrawalWithdrawalFormCPFNumberTitle: 'pspWithdrawalWithdrawalFormCPFNumberTitle',\r\n pspWithdrawalWithdrawalFormCardHolder: 'pspWithdrawalWithdrawalFormCardHolder',\r\n pspWithdrawalWithdrawalFormCardNumber: 'pspWithdrawalWithdrawalFormCardNumber',\r\n pspWithdrawalWithdrawalFormCardType: 'pspWithdrawalWithdrawalFormCardType',\r\n pspWithdrawalWithdrawalFormCityTitle: 'pspWithdrawalWithdrawalFormCityTitle',\r\n pspWithdrawalWithdrawalFormConvertedAmount: 'pspWithdrawalWithdrawalFormConvertedAmount',\r\n pspWithdrawalWithdrawalFormCurrencyTitle: 'pspWithdrawalWithdrawalFormCurrencyTitle',\r\n pspWithdrawalWithdrawalFormDigitalWalletAccountNumber: 'pspWithdrawalWithdrawalFormDigitalWalletAccountNumber',\r\n pspWithdrawalWithdrawalFormDocumentNumberTitle: 'pspWithdrawalWithdrawalFormDocumentNumberTitle',\r\n pspWithdrawalWithdrawalFormDocumentTypeTitle: 'pspWithdrawalWithdrawalFormDocumentTypeTitle',\r\n pspWithdrawalWithdrawalFormEmulatorIsNeedApproveTitle: 'pspWithdrawalWithdrawalFormEmulatorIsNeedApproveTitle',\r\n pspWithdrawalWithdrawalFormEmulatorIsRedirectTitle: 'pspWithdrawalWithdrawalFormEmulatorIsRedirectTitle',\r\n pspWithdrawalWithdrawalFormExchangeRateNote: 'pspWithdrawalWithdrawalFormExchangeRateNote',\r\n pspWithdrawalWithdrawalFormFundPurposeTitle: 'pspWithdrawalWithdrawalFormFundPurposeTitle',\r\n pspWithdrawalWithdrawalFormIdentityNumberTitle: 'pspWithdrawalWithdrawalFormIdentityNumberTitle',\r\n pspWithdrawalWithdrawalFormIdentityTypeTitle: 'pspWithdrawalWithdrawalFormIdentityTypeTitle',\r\n pspWithdrawalWithdrawalFormIfscCode: 'pspWithdrawalWithdrawalFormIfscCode',\r\n pspWithdrawalWithdrawalFormImpsAccountName: 'pspWithdrawalWithdrawalFormImpsAccountName',\r\n pspWithdrawalWithdrawalFormImpsAccountNumber: 'pspWithdrawalWithdrawalFormImpsAccountNumber',\r\n pspWithdrawalWithdrawalFormNetellerAccountEmailTitle: 'pspWithdrawalWithdrawalFormNetellerAccountEmailTitle',\r\n pspWithdrawalWithdrawalFormPayTmAccountNumber: 'pspWithdrawalWithdrawalFormPayTmAccountNumber',\r\n pspWithdrawalWithdrawalFormPayeeAccountTitle: 'pspWithdrawalWithdrawalFormPayeeAccountTitle',\r\n pspWithdrawalWithdrawalFormPaymePhoneNumberTitle: 'pspWithdrawalWithdrawalFormPaymePhoneNumberTitle',\r\n pspWithdrawalWithdrawalFormPaymeWalletNameTitle: 'pspWithdrawalWithdrawalFormPaymeWalletNameTitle',\r\n pspWithdrawalWithdrawalFormPayoutAccountTypeTitle: 'pspWithdrawalWithdrawalFormPayoutAccountTypeTitle',\r\n pspWithdrawalWithdrawalFormPixKeyHint: 'pspWithdrawalWithdrawalFormPixKeyHint',\r\n pspWithdrawalWithdrawalFormPixKeyTitle: 'pspWithdrawalWithdrawalFormPixKeyTitle',\r\n pspWithdrawalWithdrawalFormProvinceTitle: 'pspWithdrawalWithdrawalFormProvinceTitle',\r\n pspWithdrawalWithdrawalFormSWIFTHint: 'pspWithdrawalWithdrawalFormSWIFTHint',\r\n pspWithdrawalWithdrawalFormSWIFTTitle: 'pspWithdrawalWithdrawalFormSWIFTTitle',\r\n pspWithdrawalWithdrawalFormSortCodeHint: 'pspWithdrawalWithdrawalFormSortCodeHint',\r\n pspWithdrawalWithdrawalFormSortCodeTitle: 'pspWithdrawalWithdrawalFormSortCodeTitle',\r\n pspWithdrawalWithdrawalFormTotalAfterFee: 'pspWithdrawalWithdrawalFormTotalAfterFee',\r\n pspWithdrawalWithdrawalFormUpiAddress: 'pspWithdrawalWithdrawalFormUpiAddress',\r\n pspWithdrawalWithdrawalFormWithdrawBtn: 'pspWithdrawalWithdrawalFormWithdrawBtn',\r\n pspWithdrawalWithdrawalFormWithdrawalVerification: 'pspWithdrawalWithdrawalFormWithdrawalVerification',\r\n pspWithdrawalWithdrawalTabTitle: 'pspWithdrawalWithdrawalTabTitle',\r\n pushNotifications: 'pushNotifications',\r\n qFormAdminQuestionnaire: 'qFormAdminQuestionnaire',\r\n reAssignmentUsersToNewSalesUser: 'reAssignmentUsersToNewSalesUser',\r\n recurringJobs: 'recurringJobs',\r\n salesActivityHistoryContactMethod: 'salesActivityHistoryContactMethod',\r\n salesActivityHistoryContactOn: 'salesActivityHistoryContactOn',\r\n salesActivityHistoryTitle: 'salesActivityHistoryTitle',\r\n salesClientsDepositTitle: 'salesClientsDepositTitle',\r\n salesClientsIbSummary: 'salesClientsIbSummary',\r\n salesClientsIbTreesTradingVolume: 'salesClientsIbTreesTradingVolume',\r\n salesClientsSalesClientsInfoTitle: 'salesClientsSalesClientsInfoTitle',\r\n salesClientsTradingAccountTitle: 'salesClientsTradingAccountTitle',\r\n salesClientsUserTitle: 'salesClientsUserTitle',\r\n salesClientsWithdrawalTitle: 'salesClientsWithdrawalTitle',\r\n salesFieldsTradingAccountIsReadOnly: 'salesFieldsTradingAccountIsReadOnly',\r\n salesFieldsTradingAccountLastDeposit: 'salesFieldsTradingAccountLastDeposit',\r\n salesFieldsTradingAccountLastLogin: 'salesFieldsTradingAccountLastLogin',\r\n salesFieldsUserNetAmountUsd: 'salesFieldsUserNetAmountUsd',\r\n salesFieldsUserOwnIbRebate: 'salesFieldsUserOwnIbRebate',\r\n salesFieldsUserParentIbRebate: 'salesFieldsUserParentIbRebate',\r\n salesFieldsUserPeriodOn: 'salesFieldsUserPeriodOn',\r\n salesFieldsUserPeriodOnTooltip: 'salesFieldsUserPeriodOnTooltip',\r\n salesFieldsUserTotalDepositedUsd: 'salesFieldsUserTotalDepositedUsd',\r\n salesFieldsUserTotalVolume: 'salesFieldsUserTotalVolume',\r\n salesFieldsUserTotalWithdrawnUsd: 'salesFieldsUserTotalWithdrawnUsd',\r\n salesInfoTitle: 'salesInfoTitle',\r\n salesLeadCampaignCode: 'salesLeadCampaignCode',\r\n salesLeadDownloadCount: 'salesLeadDownloadCount',\r\n salesLeadIsNewLead: 'salesLeadIsNewLead',\r\n salesLeadIsNewLeadAndRegistered: 'salesLeadIsNewLeadAndRegistered',\r\n salesLeadLandingPageUrl: 'salesLeadLandingPageUrl',\r\n salesLeadRegisteredOn: 'salesLeadRegisteredOn',\r\n salesLeadTotalDepositUSD: 'salesLeadTotalDepositUSD',\r\n salesLeadVerified: 'salesLeadVerified',\r\n salesPartnershipDetailsTitle: 'salesPartnershipDetailsTitle',\r\n salesPartnershipErrorMessage: 'salesPartnershipErrorMessage',\r\n salesPartnershipHintMessage: 'salesPartnershipHintMessage',\r\n salesPartnershipSearchTitle: 'salesPartnershipSearchTitle',\r\n salesPartnershipTitle: 'salesPartnershipTitle',\r\n salesTitle: 'salesTitle',\r\n settingsChangeEmailFormChangeEmailStepHintsFifthStepHint: 'settingsChangeEmailFormChangeEmailStepHintsFifthStepHint',\r\n settingsChangeEmailFormChangeEmailStepHintsFirstStepHint: 'settingsChangeEmailFormChangeEmailStepHintsFirstStepHint',\r\n settingsChangeEmailFormChangeEmailStepHintsFourthStepHint:\r\n 'settingsChangeEmailFormChangeEmailStepHintsFourthStepHint',\r\n settingsChangeEmailFormChangeEmailStepHintsSecondStepHint:\r\n 'settingsChangeEmailFormChangeEmailStepHintsSecondStepHint',\r\n settingsChangeEmailFormChangeEmailStepHintsSeventhStepHint:\r\n 'settingsChangeEmailFormChangeEmailStepHintsSeventhStepHint',\r\n settingsChangeEmailFormChangeEmailStepHintsSixthStepHint: 'settingsChangeEmailFormChangeEmailStepHintsSixthStepHint',\r\n settingsChangeEmailFormChangeEmailStepHintsThirdStepHint: 'settingsChangeEmailFormChangeEmailStepHintsThirdStepHint',\r\n settingsChangeEmailFormChangeEmailStepHintsTitle: 'settingsChangeEmailFormChangeEmailStepHintsTitle',\r\n settingsChangeEmailFormErrorMessage: 'settingsChangeEmailFormErrorMessage',\r\n settingsChangeEmailFormNewEmailTitle: 'settingsChangeEmailFormNewEmailTitle',\r\n settingsChangeEmailFormNewEmailValidation: 'settingsChangeEmailFormNewEmailValidation',\r\n settingsChangeEmailFormSuccessMessage: 'settingsChangeEmailFormSuccessMessage',\r\n settingsChangeEmailFormTitle: 'settingsChangeEmailFormTitle',\r\n settingsChangeMemberAreaPasswordFormConfirmPasswordTitle: 'settingsChangeMemberAreaPasswordFormConfirmPasswordTitle',\r\n settingsChangeMemberAreaPasswordFormErrorMessage: 'settingsChangeMemberAreaPasswordFormErrorMessage',\r\n settingsChangeMemberAreaPasswordFormNewPasswordTitle: 'settingsChangeMemberAreaPasswordFormNewPasswordTitle',\r\n settingsChangeMemberAreaPasswordFormOldPasswordTitle: 'settingsChangeMemberAreaPasswordFormOldPasswordTitle',\r\n settingsChangeMemberAreaPasswordFormPinTitle: 'settingsChangeMemberAreaPasswordFormPinTitle',\r\n settingsChangeMemberAreaPasswordFormSuccessMessage: 'settingsChangeMemberAreaPasswordFormSuccessMessage',\r\n settingsChangeMemberAreaPasswordFormTitle: 'settingsChangeMemberAreaPasswordFormTitle',\r\n settingsChangePinCodeFormConfirmNewPinCodeTitle: 'settingsChangePinCodeFormConfirmNewPinCodeTitle',\r\n settingsChangePinCodeFormConfirmNewPinCodeValidation: 'settingsChangePinCodeFormConfirmNewPinCodeValidation',\r\n settingsChangePinCodeFormErrorMessage: 'settingsChangePinCodeFormErrorMessage',\r\n settingsChangePinCodeFormNewPinCodeTitle: 'settingsChangePinCodeFormNewPinCodeTitle',\r\n settingsChangePinCodeFormNewPinCodeValidation: 'settingsChangePinCodeFormNewPinCodeValidation',\r\n settingsChangePinCodeFormOldPinCodeTitle: 'settingsChangePinCodeFormOldPinCodeTitle',\r\n settingsChangePinCodeFormPasswordTitle: 'settingsChangePinCodeFormPasswordTitle',\r\n settingsChangePinCodeFormPinCodeHint: 'settingsChangePinCodeFormPinCodeHint',\r\n settingsChangePinCodeFormSuccessMessage: 'settingsChangePinCodeFormSuccessMessage',\r\n settingsChangePinCodeFormTitle: 'settingsChangePinCodeFormTitle',\r\n settingsDocsFormAnd: 'settingsDocsFormAnd',\r\n settingsDocsFormDeleteConfirmMessage: 'settingsDocsFormDeleteConfirmMessage',\r\n settingsDocsFormDocumentNameTitle: 'settingsDocsFormDocumentNameTitle',\r\n settingsDocsFormDocumentNumber: 'settingsDocsFormDocumentNumber',\r\n settingsDocsFormDocumentTypeBankCardRequiredTitle: 'settingsDocsFormDocumentTypeBankCardRequiredTitle',\r\n settingsDocsFormDocumentTypeBankCardRequiredTitleForChineseCountries:\r\n 'settingsDocsFormDocumentTypeBankCardRequiredTitleForChineseCountries',\r\n settingsDocsFormDocumentTypeTitle: 'settingsDocsFormDocumentTypeTitle',\r\n settingsDocsFormDocumentsUploadedTitle: 'settingsDocsFormDocumentsUploadedTitle',\r\n settingsDocsFormFileExtensionErrorHint: 'settingsDocsFormFileExtensionErrorHint',\r\n settingsDocsFormFileHint: 'settingsDocsFormFileHint',\r\n settingsDocsFormFileHintCustomSizeAndFormat: 'settingsDocsFormFileHintCustomSizeAndFormat',\r\n settingsDocsFormFileHintImage: 'settingsDocsFormFileHintImage',\r\n settingsDocsFormFileHintPdf: 'settingsDocsFormFileHintPdf',\r\n settingsDocsFormFileUploaded: 'settingsDocsFormFileUploaded',\r\n settingsDocsFormFrontSideTitle: 'settingsDocsFormFrontSideTitle',\r\n settingsDocsFormNoDocuments: 'settingsDocsFormNoDocuments',\r\n settingsDocsFormNoDocumentsWithDocTypes: 'settingsDocsFormNoDocumentsWithDocTypes',\r\n settingsDocsFormOneRequiredText: 'settingsDocsFormOneRequiredText',\r\n settingsDocsFormReverseSideTitle: 'settingsDocsFormReverseSideTitle',\r\n settingsDocsFormUploadAnImageTitle: 'settingsDocsFormUploadAnImageTitle',\r\n settingsDocsFormUploadBackSideTitle: 'settingsDocsFormUploadBackSideTitle',\r\n settingsDocsFormUploadDocumentsTitle: 'settingsDocsFormUploadDocumentsTitle',\r\n settingsDocsFormUploadErrorMessage: 'settingsDocsFormUploadErrorMessage',\r\n settingsDocsFormUploadFieldDescription: 'settingsDocsFormUploadFieldDescription',\r\n settingsDocsFormUploadFieldTitle: 'settingsDocsFormUploadFieldTitle',\r\n settingsDocsFormUploadFrontSideTitle: 'settingsDocsFormUploadFrontSideTitle',\r\n settingsDocsFormUploadReverseSideTitle: 'settingsDocsFormUploadReverseSideTitle',\r\n settingsDocsFormUploadSuccessMessage: 'settingsDocsFormUploadSuccessMessage',\r\n settingsDocsFormUploadedDocumentsTableTableTitle: 'settingsDocsFormUploadedDocumentsTableTableTitle',\r\n settingsEmailSubscriptionsCategoryHintsMarketing: 'settingsEmailSubscriptionsCategoryHintsMarketing',\r\n settingsEmailSubscriptionsCategoryHintsTransactional: 'settingsEmailSubscriptionsCategoryHintsTransactional',\r\n settingsEmailSubscriptionsTitle: 'settingsEmailSubscriptionsTitle',\r\n settingsMasterAccountSettingsFormMastersVisibilityHint: 'settingsMasterAccountSettingsFormMastersVisibilityHint',\r\n settingsProfileFormNotValidFormMessage: 'settingsProfileFormNotValidFormMessage',\r\n settingsProfileFormPleaseUploadBackSide: 'settingsProfileFormPleaseUploadBackSide',\r\n settingsProfileFormPleaseUploadBankCard: 'settingsProfileFormPleaseUploadBankCard',\r\n settingsProfileFormPleaseUploadFrontSide: 'settingsProfileFormPleaseUploadFrontSide',\r\n settingsProfileFormPleaseUploadProofOfIdentity: 'settingsProfileFormPleaseUploadProofOfIdentity',\r\n settingsProfileFormSaveUserErrorMessage: 'settingsProfileFormSaveUserErrorMessage',\r\n settingsProfileFormSendUserErrorMessage: 'settingsProfileFormSendUserErrorMessage',\r\n settingsProfileFormSendUserSuccessMessage: 'settingsProfileFormSendUserSuccessMessage',\r\n settingsProfileFormTitle: 'settingsProfileFormTitle',\r\n settingsProfileFormUnverifiedDocumentsModalSubtitle: 'settingsProfileFormUnverifiedDocumentsModalSubtitle',\r\n settingsProfileFormUnverifiedDocumentsModalTitle: 'settingsProfileFormUnverifiedDocumentsModalTitle',\r\n settingsProfileFormVerifyID: 'settingsProfileFormVerifyID',\r\n settingsProfileFormYourDetailsSubmittedSuccessfully: 'settingsProfileFormYourDetailsSubmittedSuccessfully',\r\n settingsPushSubscriptionsTitle: 'settingsPushSubscriptionsTitle',\r\n settingsResetPinCodeFormErrorMessage: 'settingsResetPinCodeFormErrorMessage',\r\n settingsResetPinCodeFormForgotPin: 'settingsResetPinCodeFormForgotPin',\r\n settingsResetPinCodeFormForgotPinClick: 'settingsResetPinCodeFormForgotPinClick',\r\n settingsResetPinCodeFormResetPinCodeHint: 'settingsResetPinCodeFormResetPinCodeHint',\r\n settingsResetPinCodeFormSubmitBtn: 'settingsResetPinCodeFormSubmitBtn',\r\n settingsResetPinCodeFormSuccessMessage: 'settingsResetPinCodeFormSuccessMessage',\r\n settingsResetPinCodeFormTitle: 'settingsResetPinCodeFormTitle',\r\n settingsTitle: 'settingsTitle',\r\n settingsTrustedDevicesTitle: 'settingsTrustedDevicesTitle',\r\n settingsUserFormAccountManagerTitle: 'settingsUserFormAccountManagerTitle',\r\n settingsUserFormBankCardPhoto: 'settingsUserFormBankCardPhoto',\r\n settingsUserFormBankDetailsBankAccountCurrencyTitle: 'settingsUserFormBankDetailsBankAccountCurrencyTitle',\r\n settingsUserFormBankDetailsBankBranchNameTitle: 'settingsUserFormBankDetailsBankBranchNameTitle',\r\n settingsUserFormBankDetailsBankCountryTitle: 'settingsUserFormBankDetailsBankCountryTitle',\r\n settingsUserFormBankDetailsBeneficiaryAccountNumberTitle: 'settingsUserFormBankDetailsBeneficiaryAccountNumberTitle',\r\n settingsUserFormBankDetailsBeneficiaryBankNameTitle: 'settingsUserFormBankDetailsBeneficiaryBankNameTitle',\r\n settingsUserFormBankDetailsBeneficiaryNameTitle: 'settingsUserFormBankDetailsBeneficiaryNameTitle',\r\n settingsUserFormBankDetailsSWIFTTitle: 'settingsUserFormBankDetailsSWIFTTitle',\r\n settingsUserFormBankDetailsSortCodeTitle: 'settingsUserFormBankDetailsSortCodeTitle',\r\n settingsUserFormBankDetailsTitle: 'settingsUserFormBankDetailsTitle',\r\n settingsUserFormBusinessManagerTitle: 'settingsUserFormBusinessManagerTitle',\r\n settingsUserFormGovernmentPhotoTitle: 'settingsUserFormGovernmentPhotoTitle',\r\n settingsUserFormPersonalDataTitle: 'settingsUserFormPersonalDataTitle',\r\n settingsUserFormProfileAddressTitle: 'settingsUserFormProfileAddressTitle',\r\n settingsUserFormProfileCityTitle: 'settingsUserFormProfileCityTitle',\r\n settingsUserFormProfileCountryTitle: 'settingsUserFormProfileCountryTitle',\r\n settingsUserFormProfileDateOfBirthTitle: 'settingsUserFormProfileDateOfBirthTitle',\r\n settingsUserFormProfileFirstNameTitle: 'settingsUserFormProfileFirstNameTitle',\r\n settingsUserFormProfileGenderTitle: 'settingsUserFormProfileGenderTitle',\r\n settingsUserFormProfileLanguage: 'settingsUserFormProfileLanguage',\r\n settingsUserFormProfileLastNameTitle: 'settingsUserFormProfileLastNameTitle',\r\n settingsUserFormProfileMobilePhoneTitle: 'settingsUserFormProfileMobilePhoneTitle',\r\n settingsUserFormProfileOccupation: 'settingsUserFormProfileOccupation',\r\n settingsUserFormProfileStateTitle: 'settingsUserFormProfileStateTitle',\r\n settingsUserFormProfileZipCodeTitle: 'settingsUserFormProfileZipCodeTitle',\r\n settingsUserFormUserGovernmentPhotoUserCitizenship: 'settingsUserFormUserGovernmentPhotoUserCitizenship',\r\n settingsUserFormUserGovernmentPhotoUserDocumentNumber: 'settingsUserFormUserGovernmentPhotoUserDocumentNumber',\r\n settingsUserFormUserGovernmentPhotoUserDocumentType: 'settingsUserFormUserGovernmentPhotoUserDocumentType',\r\n settingsUserFormUserGovernmentPhotoUserGovernmentId: 'settingsUserFormUserGovernmentPhotoUserGovernmentId',\r\n sharedActionsActions: 'sharedActionsActions',\r\n sharedActionsActivate: 'sharedActionsActivate',\r\n sharedActionsAdd: 'sharedActionsAdd',\r\n sharedActionsArchive: 'sharedActionsArchive',\r\n sharedActionsBack: 'sharedActionsBack',\r\n sharedActionsCancel: 'sharedActionsCancel',\r\n sharedActionsCheck: 'sharedActionsCheck',\r\n sharedActionsClaim: 'sharedActionsClaim',\r\n sharedActionsClear: 'sharedActionsClear',\r\n sharedActionsClone: 'sharedActionsClone',\r\n sharedActionsComment: 'sharedActionsComment',\r\n sharedActionsCopy: 'sharedActionsCopy',\r\n sharedActionsCreate: 'sharedActionsCreate',\r\n sharedActionsDelete: 'sharedActionsDelete',\r\n sharedActionsDeposit: 'sharedActionsDeposit',\r\n sharedActionsDetails: 'sharedActionsDetails',\r\n sharedActionsDisable: 'sharedActionsDisable',\r\n sharedActionsDownload: 'sharedActionsDownload',\r\n sharedActionsEdit: 'sharedActionsEdit',\r\n sharedActionsEnable: 'sharedActionsEnable',\r\n sharedActionsExport: 'sharedActionsExport',\r\n sharedActionsExportAs: 'sharedActionsExportAs',\r\n sharedActionsFilter: 'sharedActionsFilter',\r\n sharedActionsFollowUp: 'sharedActionsFollowUp',\r\n sharedActionsGoToProfile: 'sharedActionsGoToProfile',\r\n sharedActionsHide: 'sharedActionsHide',\r\n sharedActionsImport: 'sharedActionsImport',\r\n sharedActionsLater: 'sharedActionsLater',\r\n sharedActionsLess: 'sharedActionsLess',\r\n sharedActionsMore: 'sharedActionsMore',\r\n sharedActionsOpen: 'sharedActionsOpen',\r\n sharedActionsPromote: 'sharedActionsPromote',\r\n sharedActionsRecovery: 'sharedActionsRecovery',\r\n sharedActionsReprocess: 'sharedActionsReprocess',\r\n sharedActionsRetry: 'sharedActionsRetry',\r\n sharedActionsSave: 'sharedActionsSave',\r\n sharedActionsSend: 'sharedActionsSend',\r\n sharedActionsSendToVerification: 'sharedActionsSendToVerification',\r\n sharedActionsSettings: 'sharedActionsSettings',\r\n sharedActionsShow: 'sharedActionsShow',\r\n sharedActionsStop: 'sharedActionsStop',\r\n sharedActionsStopCopy: 'sharedActionsStopCopy',\r\n sharedActionsSubmit: 'sharedActionsSubmit',\r\n sharedActionsSync: 'sharedActionsSync',\r\n sharedActionsSyncToCRM: 'sharedActionsSyncToCRM',\r\n sharedActionsTrigger: 'sharedActionsTrigger',\r\n sharedActionsUnarchive: 'sharedActionsUnarchive',\r\n sharedActionsUpload: 'sharedActionsUpload',\r\n sharedActionsValidate: 'sharedActionsValidate',\r\n sharedAdminDashboard: 'sharedAdminDashboard',\r\n sharedConfirmMessage: 'sharedConfirmMessage',\r\n sharedConfirmMessageArchive: 'sharedConfirmMessageArchive',\r\n sharedConfirmMessageCancel: 'sharedConfirmMessageCancel',\r\n sharedConfirmMessageClone: 'sharedConfirmMessageClone',\r\n sharedConfirmMessageDelete: 'sharedConfirmMessageDelete',\r\n sharedConfirmMessageDisable: 'sharedConfirmMessageDisable',\r\n sharedConfirmMessageEnable: 'sharedConfirmMessageEnable',\r\n sharedConfirmMessageHide: 'sharedConfirmMessageHide',\r\n sharedConfirmMessageShow: 'sharedConfirmMessageShow',\r\n sharedConfirmMessageStopCopy: 'sharedConfirmMessageStopCopy',\r\n sharedConfirmMessageUnarchive: 'sharedConfirmMessageUnarchive',\r\n sharedErrorsFailedMessageForRecord: 'sharedErrorsFailedMessageForRecord',\r\n sharedErrorsFailedToCommitOperation: 'sharedErrorsFailedToCommitOperation',\r\n sharedErrorsFailedToCreateRecord: 'sharedErrorsFailedToCreateRecord',\r\n sharedErrorsFailedToDeleteRecord: 'sharedErrorsFailedToDeleteRecord',\r\n sharedErrorsFailedToGetData: 'sharedErrorsFailedToGetData',\r\n sharedErrorsFailedToGetInterfaces: 'sharedErrorsFailedToGetInterfaces',\r\n sharedErrorsFailedToGetRecord: 'sharedErrorsFailedToGetRecord',\r\n sharedErrorsFailedToGetSettings: 'sharedErrorsFailedToGetSettings',\r\n sharedErrorsFailedToLoadBanner: 'sharedErrorsFailedToLoadBanner',\r\n sharedErrorsFailedToLoadFile: 'sharedErrorsFailedToLoadFile',\r\n sharedErrorsFailedToPromoteRecord: 'sharedErrorsFailedToPromoteRecord',\r\n sharedErrorsFailedToSaveRecord: 'sharedErrorsFailedToSaveRecord',\r\n sharedErrorsFailedToSaveSettings: 'sharedErrorsFailedToSaveSettings',\r\n sharedErrorsFailedToSaveTemplate: 'sharedErrorsFailedToSaveTemplate',\r\n sharedErrorsFailedToSendProfile: 'sharedErrorsFailedToSendProfile',\r\n sharedErrorsFailedToSyncRecord: 'sharedErrorsFailedToSyncRecord',\r\n sharedErrorsFailedToSyncRecordToCRM: 'sharedErrorsFailedToSyncRecordToCRM',\r\n sharedErrorsFailedToUpdateRecord: 'sharedErrorsFailedToUpdateRecord',\r\n sharedErrorsHaveUnsavedChanges: 'sharedErrorsHaveUnsavedChanges',\r\n sharedErrorsOperationFailed: 'sharedErrorsOperationFailed',\r\n sharedFieldsAccountId: 'sharedFieldsAccountId',\r\n sharedFieldsAccountType: 'sharedFieldsAccountType',\r\n sharedFieldsAeCode: 'sharedFieldsAeCode',\r\n sharedFieldsAmount: 'sharedFieldsAmount',\r\n sharedFieldsArchivedBy: 'sharedFieldsArchivedBy',\r\n sharedFieldsArchivedOn: 'sharedFieldsArchivedOn',\r\n sharedFieldsArguments: 'sharedFieldsArguments',\r\n sharedFieldsAutoComment: 'sharedFieldsAutoComment',\r\n sharedFieldsAvailableBalanceUsd: 'sharedFieldsAvailableBalanceUsd',\r\n sharedFieldsBdmCode: 'sharedFieldsBdmCode',\r\n sharedFieldsBody: 'sharedFieldsBody',\r\n sharedFieldsCategory: 'sharedFieldsCategory',\r\n sharedFieldsClientApp: 'sharedFieldsClientApp',\r\n sharedFieldsClientSourceType: 'sharedFieldsClientSourceType',\r\n sharedFieldsComment: 'sharedFieldsComment',\r\n sharedFieldsConversionRate: 'sharedFieldsConversionRate',\r\n sharedFieldsCountry: 'sharedFieldsCountry',\r\n sharedFieldsCreatedBy: 'sharedFieldsCreatedBy',\r\n sharedFieldsCreatedOn: 'sharedFieldsCreatedOn',\r\n sharedFieldsCryptoAddress: 'sharedFieldsCryptoAddress',\r\n sharedFieldsCurrency: 'sharedFieldsCurrency',\r\n sharedFieldsDeclineReason: 'sharedFieldsDeclineReason',\r\n sharedFieldsDescription: 'sharedFieldsDescription',\r\n sharedFieldsDescriptionHtml: 'sharedFieldsDescriptionHtml',\r\n sharedFieldsDisplayName: 'sharedFieldsDisplayName',\r\n sharedFieldsEWallet: 'sharedFieldsEWallet',\r\n sharedFieldsEmail: 'sharedFieldsEmail',\r\n sharedFieldsEnabled: 'sharedFieldsEnabled',\r\n sharedFieldsEndOn: 'sharedFieldsEndOn',\r\n sharedFieldsExternalId: 'sharedFieldsExternalId',\r\n sharedFieldsFile: 'sharedFieldsFile',\r\n sharedFieldsFullName: 'sharedFieldsFullName',\r\n sharedFieldsGroup: 'sharedFieldsGroup',\r\n sharedFieldsIb: 'sharedFieldsIb',\r\n sharedFieldsIbCode: 'sharedFieldsIbCode',\r\n sharedFieldsIbId: 'sharedFieldsIbId',\r\n sharedFieldsId: 'sharedFieldsId',\r\n sharedFieldsInternalComment: 'sharedFieldsInternalComment',\r\n sharedFieldsIsArchived: 'sharedFieldsIsArchived',\r\n sharedFieldsIsConsentRequired: 'sharedFieldsIsConsentRequired',\r\n sharedFieldsIsHidden: 'sharedFieldsIsHidden',\r\n sharedFieldsLanguage: 'sharedFieldsLanguage',\r\n sharedFieldsLockedBy: 'sharedFieldsLockedBy',\r\n sharedFieldsLockedOn: 'sharedFieldsLockedOn',\r\n sharedFieldsMamCode: 'sharedFieldsMamCode',\r\n sharedFieldsMaxAmount: 'sharedFieldsMaxAmount',\r\n sharedFieldsMaxVolume: 'sharedFieldsMaxVolume',\r\n sharedFieldsMinAmount: 'sharedFieldsMinAmount',\r\n sharedFieldsMinMobileAppVersion: 'sharedFieldsMinMobileAppVersion',\r\n sharedFieldsMinVolume: 'sharedFieldsMinVolume',\r\n sharedFieldsModifiedBy: 'sharedFieldsModifiedBy',\r\n sharedFieldsModifiedOn: 'sharedFieldsModifiedOn',\r\n sharedFieldsName: 'sharedFieldsName',\r\n sharedFieldsNumber: 'sharedFieldsNumber',\r\n sharedFieldsOpenPrice: 'sharedFieldsOpenPrice',\r\n sharedFieldsOrder: 'sharedFieldsOrder',\r\n sharedFieldsParameters: 'sharedFieldsParameters',\r\n sharedFieldsParentIbCode: 'sharedFieldsParentIbCode',\r\n sharedFieldsPhone: 'sharedFieldsPhone',\r\n sharedFieldsProhibitedBank: 'sharedFieldsProhibitedBank',\r\n sharedFieldsPromotedBy: 'sharedFieldsPromotedBy',\r\n sharedFieldsPromotedOn: 'sharedFieldsPromotedOn',\r\n sharedFieldsPublicComment: 'sharedFieldsPublicComment',\r\n sharedFieldsPublishOn: 'sharedFieldsPublishOn',\r\n sharedFieldsSalesUser: 'sharedFieldsSalesUser',\r\n sharedFieldsStartOn: 'sharedFieldsStartOn',\r\n sharedFieldsStatus: 'sharedFieldsStatus',\r\n sharedFieldsSubtype: 'sharedFieldsSubtype',\r\n sharedFieldsTitle: 'sharedFieldsTitle',\r\n sharedFieldsToken: 'sharedFieldsToken',\r\n sharedFieldsTotalAvailableBalance: 'sharedFieldsTotalAvailableBalance',\r\n sharedFieldsTotalPayoutUsd: 'sharedFieldsTotalPayoutUsd',\r\n sharedFieldsTradedAccount: 'sharedFieldsTradedAccount',\r\n sharedFieldsTradingAccount: 'sharedFieldsTradingAccount',\r\n sharedFieldsTradingAccountType: 'sharedFieldsTradingAccountType',\r\n sharedFieldsTradingAccountTypes: 'sharedFieldsTradingAccountTypes',\r\n sharedFieldsTradingPlatformType: 'sharedFieldsTradingPlatformType',\r\n sharedFieldsTradingServer: 'sharedFieldsTradingServer',\r\n sharedFieldsTransactionId: 'sharedFieldsTransactionId',\r\n sharedFieldsTreeIbCode: 'sharedFieldsTreeIbCode',\r\n sharedFieldsType: 'sharedFieldsType',\r\n sharedFieldsUrl: 'sharedFieldsUrl',\r\n sharedFieldsUseBackwardCompatibleHint: 'sharedFieldsUseBackwardCompatibleHint',\r\n sharedFieldsUser: 'sharedFieldsUser',\r\n sharedFieldsVersion: 'sharedFieldsVersion',\r\n sharedImportedBy: 'sharedImportedBy',\r\n sharedImportedOn: 'sharedImportedOn',\r\n sharedMemberDashboard: 'sharedMemberDashboard',\r\n sharedMsgProfileSentSuccessfully: 'sharedMsgProfileSentSuccessfully',\r\n sharedMsgRecordSuccessDeleted: 'sharedMsgRecordSuccessDeleted',\r\n sharedMsgRecordSuccessPromote: 'sharedMsgRecordSuccessPromote',\r\n sharedMsgRecordSuccessSaved: 'sharedMsgRecordSuccessSaved',\r\n sharedMsgRecordSuccessSynced: 'sharedMsgRecordSuccessSynced',\r\n sharedMsgRecordSuccessUpdated: 'sharedMsgRecordSuccessUpdated',\r\n sharedMsgSettingsSuccessSaved: 'sharedMsgSettingsSuccessSaved',\r\n sharedSystemError401: 'sharedSystemError401',\r\n sharedSystemError403: 'sharedSystemError403',\r\n sharedSystemError503: 'sharedSystemError503',\r\n sharedSystemErrorOccurred: 'sharedSystemErrorOccurred',\r\n sharedSystemInternalServerError: 'sharedSystemInternalServerError',\r\n sharedSystemInvalidSession: 'sharedSystemInvalidSession',\r\n sharedSystemNoPermissionToAccessSection: 'sharedSystemNoPermissionToAccessSection',\r\n sharedSystemNotFoundPageButton: 'sharedSystemNotFoundPageButton',\r\n sharedSystemNotFoundPageSubtitle: 'sharedSystemNotFoundPageSubtitle',\r\n sharedSystemNotFoundPageTitle: 'sharedSystemNotFoundPageTitle',\r\n sharedSystemRefreshButton: 'sharedSystemRefreshButton',\r\n sharedSystemRefreshPage: 'sharedSystemRefreshPage',\r\n sharedSystemSomethingWentWrong: 'sharedSystemSomethingWentWrong',\r\n sharedWelcome: 'sharedWelcome',\r\n shortLinksAlternativeDomain: 'shortLinksAlternativeDomain',\r\n shortLinksShortLink: 'shortLinksShortLink',\r\n shortLinksShortLinkCreate: 'shortLinksShortLinkCreate',\r\n shortLinksShortLinks: 'shortLinksShortLinks',\r\n shortLinksUsageCount: 'shortLinksUsageCount',\r\n shortLinksUseAlternativeURL: 'shortLinksUseAlternativeURL',\r\n signatureClearBtn: 'signatureClearBtn',\r\n socialTradingModalAccountNumber: 'socialTradingModalAccountNumber',\r\n socialTradingModalAll: 'socialTradingModalAll',\r\n socialTradingModalCopyTitle: 'socialTradingModalCopyTitle',\r\n socialTradingModalMasterDescription: 'socialTradingModalMasterDescription',\r\n socialTradingModalMastersStopCopyError: 'socialTradingModalMastersStopCopyError',\r\n socialTradingModalMastersinvisibilityCopyError: 'socialTradingModalMastersinvisibilityCopyError',\r\n socialTradingModalSelectAcountDescription: 'socialTradingModalSelectAcountDescription',\r\n socialTradingModalStartCopy: 'socialTradingModalStartCopy',\r\n socialTradingModalStopByMasterDescription: 'socialTradingModalStopByMasterDescription',\r\n socialTradingModalStopCopy: 'socialTradingModalStopCopy',\r\n socialTradingModalStopDescriptionFirstLine: 'socialTradingModalStopDescriptionFirstLine',\r\n socialTradingModalStopDescriptionSecondLine: 'socialTradingModalStopDescriptionSecondLine',\r\n socialTradingModalStopTitle: 'socialTradingModalStopTitle',\r\n socialTradingModalWarning: 'socialTradingModalWarning',\r\n sticpayPspEmailHint: 'sticpayPspEmailHint',\r\n successfullyCopiedToClipboard: 'successfullyCopiedToClipboard',\r\n tableClearSection: 'tableClearSection',\r\n tableClickFilterButton: 'tableClickFilterButton',\r\n tablePosition: 'tablePosition',\r\n tableProfitability: 'tableProfitability',\r\n tableQuotesNote: 'tableQuotesNote',\r\n tableShowItems: 'tableShowItems',\r\n tableShowTotals: 'tableShowTotals',\r\n tableShowTotalsFieldsAmount: 'tableShowTotalsFieldsAmount',\r\n tableShowTotalsFieldsAmountUsd: 'tableShowTotalsFieldsAmountUsd',\r\n tableShowTotalsFieldsTotalInCurrency: 'tableShowTotalsFieldsTotalInCurrency',\r\n tableShowTotalsFieldsTradingVolumeInLots: 'tableShowTotalsFieldsTradingVolumeInLots',\r\n tableTotal: 'tableTotal',\r\n tableTotalCount: 'tableTotalCount',\r\n ticketsCreateTicketTitle: 'ticketsCreateTicketTitle',\r\n ticketsDetailsTicketTitle: 'ticketsDetailsTicketTitle',\r\n ticketsFieldsAssignedTitle: 'ticketsFieldsAssignedTitle',\r\n ticketsFieldsBodyTitle: 'ticketsFieldsBodyTitle',\r\n ticketsFieldsSubjectTitle: 'ticketsFieldsSubjectTitle',\r\n ticketsTicketsTitle: 'ticketsTicketsTitle',\r\n totalNetAmountUSD: 'totalNetAmountUSD',\r\n tradindServerAskViewPasPermissionMes: 'tradindServerAskViewPasPermissionMes',\r\n tradingAccountPushNotificationLabel: 'tradingAccountPushNotificationLabel',\r\n tradingAccountTypeMinMobileAppVersionHint: 'tradingAccountTypeMinMobileAppVersionHint',\r\n tradingAccountTypeUserAccessSettingList: 'tradingAccountTypeUserAccessSettingList',\r\n tradingAccountsAccount: 'tradingAccountsAccount',\r\n tradingAccountsAccountHistoryFormTitle: 'tradingAccountsAccountHistoryFormTitle',\r\n tradingAccountsAccountHistoryTitle: 'tradingAccountsAccountHistoryTitle',\r\n tradingAccountsAccountOrderHistory: 'tradingAccountsAccountOrderHistory',\r\n tradingAccountsAccountSuccessfullyCreated: 'tradingAccountsAccountSuccessfullyCreated',\r\n tradingAccountsAccounts: 'tradingAccountsAccounts',\r\n tradingAccountsActionsDepositTitle: 'tradingAccountsActionsDepositTitle',\r\n tradingAccountsActionsSaveTitle: 'tradingAccountsActionsSaveTitle',\r\n tradingAccountsActionsSetPasswordTitle: 'tradingAccountsActionsSetPasswordTitle',\r\n tradingAccountsActionsWithdrawTitle: 'tradingAccountsActionsWithdrawTitle',\r\n tradingAccountsArchvingFormConfirmMessage: 'tradingAccountsArchvingFormConfirmMessage',\r\n tradingAccountsArchvingFormErrorMessage: 'tradingAccountsArchvingFormErrorMessage',\r\n tradingAccountsArchvingFormSuccessMessage: 'tradingAccountsArchvingFormSuccessMessage',\r\n tradingAccountsArchvingFormTitle: 'tradingAccountsArchvingFormTitle',\r\n tradingAccountsArchvingFormWarnigingMessageRestrictInformation:\r\n 'tradingAccountsArchvingFormWarnigingMessageRestrictInformation',\r\n tradingAccountsArchvingFormWarnigingMessageTitle: 'tradingAccountsArchvingFormWarnigingMessageTitle',\r\n tradingAccountsArchvingFormWarnigingMessageUndoneAction: 'tradingAccountsArchvingFormWarnigingMessageUndoneAction',\r\n tradingAccountsChangeSettings: 'tradingAccountsChangeSettings',\r\n tradingAccountsChangeSettingsErrorMessage: 'tradingAccountsChangeSettingsErrorMessage',\r\n tradingAccountsChangeSettingsSuccessMessage: 'tradingAccountsChangeSettingsSuccessMessage',\r\n tradingAccountsChangeTradingAccountNameSubtitle: 'tradingAccountsChangeTradingAccountNameSubtitle',\r\n tradingAccountsCommissionAccount: 'tradingAccountsCommissionAccount',\r\n tradingAccountsCopyType: 'tradingAccountsCopyType',\r\n tradingAccountsCopyingNotice: 'tradingAccountsCopyingNotice',\r\n tradingAccountsDefaultActionMessage: 'tradingAccountsDefaultActionMessage',\r\n tradingAccountsDemoTitle: 'tradingAccountsDemoTitle',\r\n tradingAccountsDepositFormTitle: 'tradingAccountsDepositFormTitle',\r\n tradingAccountsFailedToChangeTradingAccountName: 'tradingAccountsFailedToChangeTradingAccountName',\r\n tradingAccountsFailedToFetchTradingAccounts: 'tradingAccountsFailedToFetchTradingAccounts',\r\n tradingAccountsGroupUpdateWarning: 'tradingAccountsGroupUpdateWarning',\r\n tradingAccountsHideActionMessagesHideActiveInvestorAccountConfirmation:\r\n 'tradingAccountsHideActionMessagesHideActiveInvestorAccountConfirmation',\r\n tradingAccountsHideActionMessagesHideActiveMamAccountConfirmation:\r\n 'tradingAccountsHideActionMessagesHideActiveMamAccountConfirmation',\r\n tradingAccountsInactiveAccount: 'tradingAccountsInactiveAccount',\r\n tradingAccountsInitialDeposit: 'tradingAccountsInitialDeposit',\r\n tradingAccountsInvestorAccount: 'tradingAccountsInvestorAccount',\r\n tradingAccountsInvestorPasswordFormConfirmPasswordTitle: 'tradingAccountsInvestorPasswordFormConfirmPasswordTitle',\r\n tradingAccountsInvestorPasswordFormErrorMessage: 'tradingAccountsInvestorPasswordFormErrorMessage',\r\n tradingAccountsInvestorPasswordFormPasswordTitle: 'tradingAccountsInvestorPasswordFormPasswordTitle',\r\n tradingAccountsInvestorPasswordFormPinCodeTitle: 'tradingAccountsInvestorPasswordFormPinCodeTitle',\r\n tradingAccountsInvestorPasswordFormSuccessMessage: 'tradingAccountsInvestorPasswordFormSuccessMessage',\r\n tradingAccountsInvestorPasswordFormTitle: 'tradingAccountsInvestorPasswordFormTitle',\r\n tradingAccountsLeverageFormErrorMessage: 'tradingAccountsLeverageFormErrorMessage',\r\n tradingAccountsLeverageFormLeverageHint: 'tradingAccountsLeverageFormLeverageHint',\r\n tradingAccountsLeverageFormSuccessMessage: 'tradingAccountsLeverageFormSuccessMessage',\r\n tradingAccountsLeverageFormTitle: 'tradingAccountsLeverageFormTitle',\r\n tradingAccountsLogin: 'tradingAccountsLogin',\r\n tradingAccountsLotMultiplier: 'tradingAccountsLotMultiplier',\r\n tradingAccountsMarginStopCopyLevel: 'tradingAccountsMarginStopCopyLevel',\r\n tradingAccountsMarginStopCopyLevelTooltip: 'tradingAccountsMarginStopCopyLevelTooltip',\r\n tradingAccountsMasterAccountLink: 'tradingAccountsMasterAccountLink',\r\n tradingAccountsMasterPasswordFormConfirmPasswordTitle: 'tradingAccountsMasterPasswordFormConfirmPasswordTitle',\r\n tradingAccountsMasterPasswordFormErrorMessage: 'tradingAccountsMasterPasswordFormErrorMessage',\r\n tradingAccountsMasterPasswordFormPasswordTitle: 'tradingAccountsMasterPasswordFormPasswordTitle',\r\n tradingAccountsMasterPasswordFormPinCodeTitle: 'tradingAccountsMasterPasswordFormPinCodeTitle',\r\n tradingAccountsMasterPasswordFormSuccessMessage: 'tradingAccountsMasterPasswordFormSuccessMessage',\r\n tradingAccountsMasterPasswordFormTitle: 'tradingAccountsMasterPasswordFormTitle',\r\n tradingAccountsMasterStatusInvisible: 'tradingAccountsMasterStatusInvisible',\r\n tradingAccountsMasterStatusVisible: 'tradingAccountsMasterStatusVisible',\r\n tradingAccountsNoAccountsHint: 'tradingAccountsNoAccountsHint',\r\n tradingAccountsNotificationsFormTitle: 'tradingAccountsNotificationsFormTitle',\r\n tradingAccountsOpenAccount: 'tradingAccountsOpenAccount',\r\n tradingAccountsOpenAccountAgree: 'tradingAccountsOpenAccountAgree',\r\n tradingAccountsOpenAccountError: 'tradingAccountsOpenAccountError',\r\n tradingAccountsOpenAccountModalTitle: 'tradingAccountsOpenAccountModalTitle',\r\n tradingAccountsOpenMasterAccountFormRecommendedDeposit: 'tradingAccountsOpenMasterAccountFormRecommendedDeposit',\r\n tradingAccountsOpenMasterAccountFormRecommendedDepositMandatoryTooltipMsg:\r\n 'tradingAccountsOpenMasterAccountFormRecommendedDepositMandatoryTooltipMsg',\r\n tradingAccountsOpenMasterAccountFormRecommendedDepositOptionalTooltipMsg:\r\n 'tradingAccountsOpenMasterAccountFormRecommendedDepositOptionalTooltipMsg',\r\n tradingAccountsPercentageLossStopCopyLevel: 'tradingAccountsPercentageLossStopCopyLevel',\r\n tradingAccountsPercentageLossStopCopyLevelTooltip: 'tradingAccountsPercentageLossStopCopyLevelTooltip',\r\n tradingAccountsPushNotificationHint: 'tradingAccountsPushNotificationHint',\r\n tradingAccountsRealTitle: 'tradingAccountsRealTitle',\r\n tradingAccountsRefillFormRefillActionTitle: 'tradingAccountsRefillFormRefillActionTitle',\r\n tradingAccountsRefillFormRefillAmountTitle: 'tradingAccountsRefillFormRefillAmountTitle',\r\n tradingAccountsRefillFormRefillErrorMessage: 'tradingAccountsRefillFormRefillErrorMessage',\r\n tradingAccountsRefillFormRefillSuccessMessage: 'tradingAccountsRefillFormRefillSuccessMessage',\r\n tradingAccountsRefillFormRefillTitle: 'tradingAccountsRefillFormRefillTitle',\r\n tradingAccountsRemapLinksExcludedUserIds: 'tradingAccountsRemapLinksExcludedUserIds',\r\n tradingAccountsRemapLinksFromTradingGroup: 'tradingAccountsRemapLinksFromTradingGroup',\r\n tradingAccountsRemapLinksIncludedUserIds: 'tradingAccountsRemapLinksIncludedUserIds',\r\n tradingAccountsRemapLinksRemapGroupLinks: 'tradingAccountsRemapLinksRemapGroupLinks',\r\n tradingAccountsRemapLinksRemapGroupUserCategories: 'tradingAccountsRemapLinksRemapGroupUserCategories',\r\n tradingAccountsRemapLinksToTradingGroup: 'tradingAccountsRemapLinksToTradingGroup',\r\n tradingAccountsRenameAccount: 'tradingAccountsRenameAccount',\r\n tradingAccountsRenameYourAccount: 'tradingAccountsRenameYourAccount',\r\n tradingAccountsSearchPlaceholder: 'tradingAccountsSearchPlaceholder',\r\n tradingAccountsServer: 'tradingAccountsServer',\r\n tradingAccountsSignLPOA: 'tradingAccountsSignLPOA',\r\n tradingAccountsSocialTradingSettings: 'tradingAccountsSocialTradingSettings',\r\n tradingAccountsStopCopyViaMarginLevel: 'tradingAccountsStopCopyViaMarginLevel',\r\n tradingAccountsStopCopyViaMarginLevelTooltip: 'tradingAccountsStopCopyViaMarginLevelTooltip',\r\n tradingAccountsTableHistoryClosePriceTitle: 'tradingAccountsTableHistoryClosePriceTitle',\r\n tradingAccountsTableHistoryCloseTimeTitle: 'tradingAccountsTableHistoryCloseTimeTitle',\r\n tradingAccountsTableHistoryCmdTitle: 'tradingAccountsTableHistoryCmdTitle',\r\n tradingAccountsTableHistoryCommentTitle: 'tradingAccountsTableHistoryCommentTitle',\r\n tradingAccountsTableHistoryCommissionTitle: 'tradingAccountsTableHistoryCommissionTitle',\r\n tradingAccountsTableHistoryOpenTimeTitle: 'tradingAccountsTableHistoryOpenTimeTitle',\r\n tradingAccountsTableHistoryProfitTitle: 'tradingAccountsTableHistoryProfitTitle',\r\n tradingAccountsTableHistorySlTitle: 'tradingAccountsTableHistorySlTitle',\r\n tradingAccountsTableHistorySwapsTitle: 'tradingAccountsTableHistorySwapsTitle',\r\n tradingAccountsTableHistorySymbolTitle: 'tradingAccountsTableHistorySymbolTitle',\r\n tradingAccountsTableHistoryTicketTitle: 'tradingAccountsTableHistoryTicketTitle',\r\n tradingAccountsTableHistoryTpTitle: 'tradingAccountsTableHistoryTpTitle',\r\n tradingAccountsTableHistoryVolumeTitle: 'tradingAccountsTableHistoryVolumeTitle',\r\n tradingAccountsTerminateLPOA: 'tradingAccountsTerminateLPOA',\r\n tradingAccountsTitle: 'tradingAccountsTitle',\r\n tradingAccountsTradingAccountName: 'tradingAccountsTradingAccountName',\r\n tradingAccountsTradingAccountNameSuccessfullyChanged: 'tradingAccountsTradingAccountNameSuccessfullyChanged',\r\n tradingAccountsTransferFormTitle: 'tradingAccountsTransferFormTitle',\r\n tradingAccountsType: 'tradingAccountsType',\r\n tradingAccountsWithdrawFormTitle: 'tradingAccountsWithdrawFormTitle',\r\n tradingActionLinkExistingAccount: 'tradingActionLinkExistingAccount',\r\n tradingContestAccountNumber: 'tradingContestAccountNumber',\r\n tradingContestAdminClientSourceTypeHint: 'tradingContestAdminClientSourceTypeHint',\r\n tradingContestAllContests: 'tradingContestAllContests',\r\n tradingContestAverageDrawdown: 'tradingContestAverageDrawdown',\r\n tradingContestAverageDrawdownCounter: 'tradingContestAverageDrawdownCounter',\r\n tradingContestBalanceOperationSum: 'tradingContestBalanceOperationSum',\r\n tradingContestCalculatedOn: 'tradingContestCalculatedOn',\r\n tradingContestContestEndsIn: 'tradingContestContestEndsIn',\r\n tradingContestContestStartsIn: 'tradingContestContestStartsIn',\r\n tradingContestCurrentKPI: 'tradingContestCurrentKPI',\r\n tradingContestDepositSum: 'tradingContestDepositSum',\r\n tradingContestDrawdown: 'tradingContestDrawdown',\r\n tradingContestEnded: 'tradingContestEnded',\r\n tradingContestEquity: 'tradingContestEquity',\r\n tradingContestInOrderToParticipateHintOne: 'tradingContestInOrderToParticipateHintOne',\r\n tradingContestInOrderToParticipateHintTwo: 'tradingContestInOrderToParticipateHintTwo',\r\n tradingContestJoined: 'tradingContestJoined',\r\n tradingContestMaxDrawdown: 'tradingContestMaxDrawdown',\r\n tradingContestName: 'tradingContestName',\r\n tradingContestNickname: 'tradingContestNickname',\r\n tradingContestNoAvailableContests: 'tradingContestNoAvailableContests',\r\n tradingContestNoParticipantsYet: 'tradingContestNoParticipantsYet',\r\n tradingContestNotJoined: 'tradingContestNotJoined',\r\n tradingContestPosition: 'tradingContestPosition',\r\n tradingContestProfitability: 'tradingContestProfitability',\r\n tradingContestProfitabilityOnStartingBalance: 'tradingContestProfitabilityOnStartingBalance',\r\n tradingContestStartBalanceOperationSum: 'tradingContestStartBalanceOperationSum',\r\n tradingContestStartWithdrawalSum: 'tradingContestStartWithdrawalSum',\r\n tradingContestState: 'tradingContestState',\r\n tradingContestTradingContest: 'tradingContestTradingContest',\r\n tradingContestWithdrawalSum: 'tradingContestWithdrawalSum',\r\n tradingFieldsAccountFrom: 'tradingFieldsAccountFrom',\r\n tradingFieldsAccountRange: 'tradingFieldsAccountRange',\r\n tradingFieldsAccountTo: 'tradingFieldsAccountTo',\r\n tradingFieldsBaseCurrency: 'tradingFieldsBaseCurrency',\r\n tradingFieldsCommissionSettingsInstruments: 'tradingFieldsCommissionSettingsInstruments',\r\n tradingFieldsCommissionSettingsIsNotManageableByIb: 'tradingFieldsCommissionSettingsIsNotManageableByIb',\r\n tradingFieldsCommissionSettingsIsUsedForCommissionSettings:\r\n 'tradingFieldsCommissionSettingsIsUsedForCommissionSettings',\r\n tradingFieldsCommonSettingsArchivingAllowed: 'tradingFieldsCommonSettingsArchivingAllowed',\r\n tradingFieldsCommonSettingsChangeInvestorPasswordAllowed: 'tradingFieldsCommonSettingsChangeInvestorPasswordAllowed',\r\n tradingFieldsCommonSettingsChangeLeverageAllowed: 'tradingFieldsCommonSettingsChangeLeverageAllowed',\r\n tradingFieldsCommonSettingsChangeMasterPasswordAllowed: 'tradingFieldsCommonSettingsChangeMasterPasswordAllowed',\r\n tradingFieldsCommonSettingsDepositAllowed: 'tradingFieldsCommonSettingsDepositAllowed',\r\n tradingFieldsCommonSettingsInvestorsAutoAttachmentAllowed:\r\n 'tradingFieldsCommonSettingsInvestorsAutoAttachmentAllowed',\r\n tradingFieldsCommonSettingsWithdrawalAllowed: 'tradingFieldsCommonSettingsWithdrawalAllowed',\r\n tradingFieldsContractSize: 'tradingFieldsContractSize',\r\n tradingFieldsDepositWithdrawalSettingsDepositSettings: 'tradingFieldsDepositWithdrawalSettingsDepositSettings',\r\n tradingFieldsDepositWithdrawalSettingsIsAllowed: 'tradingFieldsDepositWithdrawalSettingsIsAllowed',\r\n tradingFieldsDepositWithdrawalSettingsIsAllowedOnWeekend: 'tradingFieldsDepositWithdrawalSettingsIsAllowedOnWeekend',\r\n tradingFieldsDepositWithdrawalSettingsWithdrawalSettings: 'tradingFieldsDepositWithdrawalSettingsWithdrawalSettings',\r\n tradingFieldsFullPip: 'tradingFieldsFullPip',\r\n tradingFieldsGroupMapping: 'tradingFieldsGroupMapping',\r\n tradingFieldsGroupMappingType: 'tradingFieldsGroupMappingType',\r\n tradingFieldsMaxNumber: 'tradingFieldsMaxNumber',\r\n tradingFieldsMinBalanceToMakeAccount: 'tradingFieldsMinBalanceToMakeAccount',\r\n tradingFieldsMinDeposit: 'tradingFieldsMinDeposit',\r\n tradingFieldsNextLogin: 'tradingFieldsNextLogin',\r\n tradingFieldsProfitCurrency: 'tradingFieldsProfitCurrency',\r\n tradingFieldsSymbol: 'tradingFieldsSymbol',\r\n tradingFieldsTradingAccountSettingsEnabled: 'tradingFieldsTradingAccountSettingsEnabled',\r\n tradingFieldsTradingAccountSettingsIsDisplay: 'tradingFieldsTradingAccountSettingsIsDisplay',\r\n tradingFieldsTradingAccountSettingsIsReadonly: 'tradingFieldsTradingAccountSettingsIsReadonly',\r\n tradingFieldsTradingAccountSettingsLastUpdateDateFromTP: 'tradingFieldsTradingAccountSettingsLastUpdateDateFromTP',\r\n tradingFieldsTradingAccountSettingsSendReports: 'tradingFieldsTradingAccountSettingsSendReports',\r\n tradingFieldsUseForCheckPreferred: 'tradingFieldsUseForCheckPreferred',\r\n tradingPlatformsTitle: 'tradingPlatformsTitle',\r\n tradingToolsMarketBuzzMentionsSourcesDescription: 'tradingToolsMarketBuzzMentionsSourcesDescription',\r\n tradingToolsMarketBuzzNewsFeedDescription: 'tradingToolsMarketBuzzNewsFeedDescription',\r\n tradingToolsMarketBuzzOverallMentionsDescription: 'tradingToolsMarketBuzzOverallMentionsDescription',\r\n tradingToolsMarketBuzzPlaceholder: 'tradingToolsMarketBuzzPlaceholder',\r\n tradingToolsMarketBuzzTitle: 'tradingToolsMarketBuzzTitle',\r\n tradingToolsTitle: 'tradingToolsTitle',\r\n trustedDeviceDeviceId: 'trustedDeviceDeviceId',\r\n trustedDeviceDeviceInfo: 'trustedDeviceDeviceInfo',\r\n trustedDeviceIpAddress: 'trustedDeviceIpAddress',\r\n trustedDeviceLastLogin: 'trustedDeviceLastLogin',\r\n trustedDeviceLocation: 'trustedDeviceLocation',\r\n tutorialVideoSeeTutorialAction: 'tutorialVideoSeeTutorialAction',\r\n tutorialVideoSkipAction: 'tutorialVideoSkipAction',\r\n tutorialVideoUserChoice: 'tutorialVideoUserChoice',\r\n userBankAccount: 'userBankAccount',\r\n userBankAccounts: 'userBankAccounts',\r\n userCryptoWalletAccount: 'userCryptoWalletAccount',\r\n userDigitalWalletAccounts: 'userDigitalWalletAccounts',\r\n userOnlyChineseCharactersCanBeUsed: 'userOnlyChineseCharactersCanBeUsed',\r\n userPspAccessType: 'userPspAccessType',\r\n userPspUserType: 'userPspUserType',\r\n userPspUserTypeHint: 'userPspUserTypeHint',\r\n usersTickets: 'usersTickets',\r\n videoTitlesPlatformVideoTitle: 'videoTitlesPlatformVideoTitle',\r\n videoTitlesPspVideoTitle: 'videoTitlesPspVideoTitle',\r\n withdrawalFinancialIdentityType: 'withdrawalFinancialIdentityType',\r\n withdrawalWarningMessageApologize: 'withdrawalWarningMessageApologize',\r\n withdrawalWarningMessageBankDetailsProceedRequest: 'withdrawalWarningMessageBankDetailsProceedRequest',\r\n withdrawalWarningMessageBankDetailsTitle: 'withdrawalWarningMessageBankDetailsTitle',\r\n withdrawalWarningMessageBestRegards: 'withdrawalWarningMessageBestRegards',\r\n withdrawalWarningMessageEnterInformation: 'withdrawalWarningMessageEnterInformation',\r\n yesCloseWithoutSaving: 'yesCloseWithoutSaving',\r\n youHaveNoCopyingAccounts: 'youHaveNoCopyingAccounts',\r\n});\r\nexport type KeyMapKeys = keyof typeof keyMap;\r\nexport type KeyMap = typeof keyMap;\r\n","/* eslint-disable @typescript-eslint/no-inferrable-types */\r\nimport { apiUserAccountService } from '@api/services/account.apiService';\r\nimport { IApiUserIpInfo } from '@api/services/account.apiService.interface';\r\nimport { CountryInfo } from '@components-shared/countryDetection/countryDetector';\r\nimport { cookieService } from '@utils/library/cookie.service';\r\nimport {\r\n IGeneralSettings,\r\n IOnboardingConfiguration,\r\n IUser,\r\n IUserDocument,\r\n IUserIpInfo,\r\n IUserProfile,\r\n} from 'global.interfaces';\r\nimport { makeAutoObservable, runInAction } from 'mobx';\r\nimport { setUserId } from 'utils/userInfoStore';\r\nimport type { MobxRootStore } from './mobx.store';\r\n\r\nconst FOUR_HOURS_IN_SECONDS = 14400;\r\n\r\nexport class AccountStore {\r\n mobxStore: MobxRootStore;\r\n\r\n private _generalSettings: IGeneralSettings | null = null;\r\n private _generalSettingsLoading: boolean = true;\r\n private _userInfo: IUser | null | Record = null;\r\n private _userInfoLoading: boolean = false;\r\n private _onboardingConfigurationLoading: boolean = true;\r\n private _onboardingConfiguration: IOnboardingConfiguration | null = null;\r\n private _userProfile: IUserProfile | Record }> = {};\r\n private _userProfileLoading: boolean = true;\r\n private _userDocuments: IUserDocument[] = [];\r\n private _userDocumentsLoading: boolean = true;\r\n private _userDocumentsProgress: number = 0;\r\n private _userIpInfo: IUserIpInfo | null = null;\r\n\r\n constructor(mobxStore: MobxRootStore) {\r\n this.mobxStore = mobxStore;\r\n makeAutoObservable(this);\r\n }\r\n\r\n fetchGeneralSettings = () => {\r\n if (this._generalSettings) {\r\n console.error('generalSettings are loaded');\r\n }\r\n\r\n runInAction(() => {\r\n this._generalSettingsLoading = true;\r\n this._generalSettings = window.generalSettings as IGeneralSettings;\r\n this._generalSettingsLoading = false;\r\n });\r\n };\r\n\r\n fetchUserInfo = async (options: { showLoader?: boolean; isInitialRequest?: boolean } = {}) => {\r\n if (options?.showLoader) {\r\n this._userInfoLoading = true;\r\n }\r\n\r\n try {\r\n const response = await apiUserAccountService.getUserSettings({ isInitialAuth: options.isInitialRequest });\r\n\r\n runInAction(() => {\r\n this._userInfo = response.data;\r\n this._userInfoLoading = false;\r\n\r\n setUserId(response.data?.id);\r\n });\r\n } catch (error) {\r\n runInAction(() => {\r\n this._userInfoLoading = false;\r\n });\r\n }\r\n };\r\n\r\n fetchUserProfile = async () => {\r\n this._userProfileLoading = true;\r\n try {\r\n const response = await apiUserAccountService.getUserProfile();\r\n\r\n runInAction(() => {\r\n this._userProfile = response.data;\r\n this._userProfileLoading = false;\r\n });\r\n } catch (error) {\r\n runInAction(() => {\r\n this._userProfile = {};\r\n this._userProfileLoading = false;\r\n });\r\n }\r\n };\r\n\r\n fetchUserDocuments = async () => {\r\n this._userDocumentsLoading = true;\r\n try {\r\n const response = await apiUserAccountService.getUserDocuments({ skip: 0, take: 100 });\r\n\r\n runInAction(() => {\r\n this._userDocuments = response.data.records ?? [];\r\n this._userDocumentsLoading = false;\r\n });\r\n } catch (error) {\r\n this._userDocuments = [];\r\n this._userDocumentsLoading = false;\r\n }\r\n };\r\n\r\n fetchUserDocumentsSilently = async () => {\r\n try {\r\n const response = await apiUserAccountService.getUserDocuments({ skip: 0, take: 100 });\r\n\r\n this._userDocuments = response.data.records ?? [];\r\n } catch (error) {\r\n this._userDocuments = [];\r\n }\r\n };\r\n\r\n fetchUserIpInfo = async () => {\r\n try {\r\n const cookie = cookieService.getCookie('__ipInfo');\r\n let responseData: IApiUserIpInfo | null = cookie ? JSON.parse(cookie) : null;\r\n\r\n if (!responseData) {\r\n const { data } = await apiUserAccountService.getUserIpInfo();\r\n\r\n responseData = {\r\n country_code: data.country_code,\r\n country_name: data.country_name,\r\n location: { calling_code: data.location?.calling_code },\r\n };\r\n\r\n cookieService.setCookie('__ipInfo', JSON.stringify(responseData), undefined, FOUR_HOURS_IN_SECONDS);\r\n }\r\n\r\n runInAction(() => {\r\n this._userIpInfo = responseData && Object.keys(responseData).length > 0 ? responseData : null;\r\n });\r\n } catch (error) {\r\n runInAction(() => {\r\n this._userIpInfo = null;\r\n });\r\n console.error(error);\r\n }\r\n };\r\n\r\n setUserDocumentsProgress = (value: number) => {\r\n this._userDocumentsProgress = value;\r\n };\r\n\r\n fetchOnboardingConfiguration = async () => {\r\n this._onboardingConfigurationLoading = true;\r\n\r\n /** @description Legacy code. Migrated from Redux. */\r\n this._onboardingConfiguration = {} as IOnboardingConfiguration;\r\n\r\n try {\r\n const response = await apiUserAccountService.getOnboardingConfiguration();\r\n\r\n runInAction(() => {\r\n this._onboardingConfiguration = response.data;\r\n this._onboardingConfigurationLoading = false;\r\n });\r\n } catch (err) {\r\n runInAction(() => {\r\n this._onboardingConfigurationLoading = false;\r\n });\r\n }\r\n };\r\n\r\n initStoryBookGeneralSettings = () => {\r\n this._generalSettings = { utcOffsetInHours: 0 } as IGeneralSettings;\r\n };\r\n\r\n get generalSettings(): IGeneralSettings {\r\n if (!this._generalSettings) {\r\n throw new Error('generalSettings is missing');\r\n }\r\n return this._generalSettings as IGeneralSettings;\r\n }\r\n\r\n get generalSettingsLoading() {\r\n return this._generalSettingsLoading;\r\n }\r\n\r\n get initialUserInfo() {\r\n return this._userInfo;\r\n }\r\n\r\n get userInfo() {\r\n if (!this._userInfo) {\r\n throw new Error('userInfo is missing');\r\n }\r\n return this._userInfo as IUser;\r\n }\r\n\r\n get userInfoLoading() {\r\n return this._userInfoLoading;\r\n }\r\n\r\n get userProfile(): IUserProfile {\r\n const getIsUserProfile = (profile: typeof this._userProfile): profile is IUserProfile => {\r\n return !!profile?.profile;\r\n };\r\n\r\n if (getIsUserProfile(this._userProfile)) {\r\n return this._userProfile;\r\n } else {\r\n /**\r\n * @description userProfile is empty object in this case\r\n * legacy code\r\n */\r\n\r\n return this._userProfile as unknown as IUserProfile;\r\n }\r\n }\r\n\r\n get userProfileLoading() {\r\n return this._userProfileLoading;\r\n }\r\n\r\n get onboardingConfiguration() {\r\n return this._onboardingConfiguration;\r\n }\r\n\r\n get onboardingConfigurationLoading() {\r\n return this._onboardingConfigurationLoading;\r\n }\r\n\r\n get userDocuments() {\r\n return this._userDocuments;\r\n }\r\n\r\n get userDocumentsLoading() {\r\n return this._userDocumentsLoading;\r\n }\r\n\r\n get userDocumentsProgress() {\r\n return this._userDocumentsProgress;\r\n }\r\n\r\n get telemetryIKey() {\r\n return this._generalSettings?.iKey;\r\n }\r\n\r\n get utcOffsetInHoursFormattedString() {\r\n const { utcOffsetInHours } = this.generalSettings;\r\n\r\n const sign = utcOffsetInHours > 0 ? '+' : '';\r\n\r\n return `(GMT${sign}${utcOffsetInHours})`;\r\n }\r\n\r\n get utcOffsetInHours() {\r\n return this._generalSettings ? this._generalSettings.utcOffsetInHours : 0;\r\n }\r\n\r\n get brokerParams() {\r\n if (!this._generalSettings) {\r\n console.error('generalSettings is missing');\r\n return null;\r\n }\r\n\r\n return this._generalSettings.brokerParams;\r\n }\r\n\r\n get userCountryInfo(): CountryInfo | null {\r\n if (!this._userIpInfo) {\r\n return null;\r\n }\r\n return {\r\n countryCode: this._userIpInfo.country_code,\r\n countryName: this._userIpInfo.country_name,\r\n callingCode: this._userIpInfo.location?.calling_code,\r\n };\r\n }\r\n}\r\n","import i18next from 'i18next';\r\nimport { makeAutoObservable } from 'mobx';\r\nimport { MobxRootStore } from './mobx.store';\r\n\r\n/**\r\n * @deprecated\r\n * Temporary solution. Added due to typing problems in some components.\r\n */\r\n\r\nexport class AppSettingStore {\r\n mobxStore: MobxRootStore;\r\n\r\n private _i18next: typeof i18next = i18next;\r\n\r\n constructor(mobxStore: MobxRootStore) {\r\n this.mobxStore = mobxStore;\r\n makeAutoObservable(this);\r\n }\r\n\r\n setI18next = (i18n: typeof i18next) => {\r\n /* This is a shallow copy of i18next. Prototype is missing. */\r\n this._i18next = { ...i18n, t: i18n.t };\r\n };\r\n\r\n get i18next() {\r\n return this._i18next;\r\n }\r\n}\r\n","import { apiUserAccountService } from '@api/services/account.apiService';\r\nimport { homeRoutes } from '@components-register/home.routes';\r\nimport { NotificationDialog } from '@components-shared/modal';\r\nimport { keyMap } from '@locales/lokalise/keyMap';\r\nimport { handleError } from '@utils/errors';\r\nimport { navigateToURL } from '@utils/navigateToURL';\r\nimport i18next from 'i18next';\r\nimport { makeAutoObservable } from 'mobx';\r\nimport type { MobxRootStore } from './mobx.store';\r\n\r\nconst ASP_NET_COOKIE_EXP = '.AspNet.Cookies.ExpirationDate';\r\n\r\nexport class AuthStore {\r\n mobxStore: MobxRootStore;\r\n\r\n private _visibilityChangeCallback;\r\n\r\n private fetchCookieIfNotExist = async () => {\r\n const cookieExp = localStorage.getItem(ASP_NET_COOKIE_EXP);\r\n\r\n if (!cookieExp) {\r\n await this.fetchCookieExpirationDate();\r\n }\r\n };\r\n\r\n private getIsAuthRecordValidOrNotExist = () => {\r\n const cookieExp = localStorage.getItem(ASP_NET_COOKIE_EXP);\r\n\r\n if (!cookieExp || new Date(cookieExp) > new Date()) {\r\n return true;\r\n }\r\n\r\n return false;\r\n };\r\n\r\n constructor(mobxStore: MobxRootStore) {\r\n this.mobxStore = mobxStore;\r\n makeAutoObservable(this);\r\n\r\n this._visibilityChangeCallback = async () => {\r\n if (!document.hidden) {\r\n await this.fetchCookieIfNotExist();\r\n void this.validateCookieExpiration();\r\n }\r\n };\r\n }\r\n\r\n startAuthCookieExpirationDateCheckListener = () => {\r\n document.addEventListener('visibilitychange', this._visibilityChangeCallback);\r\n };\r\n\r\n stopAuthCookieExpirationDateCheckListener = () => {\r\n document.removeEventListener('visibilitychange', this._visibilityChangeCallback);\r\n };\r\n\r\n signIn = async (params: {\r\n email: string;\r\n password: string;\r\n otp?: string;\r\n captchaValue: string | null | undefined;\r\n referralToken?: string | null;\r\n }) => {\r\n const result = await apiUserAccountService.signIn(params);\r\n\r\n await this.fetchCookieExpirationDate();\r\n\r\n return result;\r\n };\r\n\r\n signOut = async ({\r\n returnUrl,\r\n navigateUrl,\r\n skipSignOutRequest,\r\n }: {\r\n returnUrl?: string;\r\n navigateUrl?: string;\r\n skipSignOutRequest?: boolean;\r\n } = {}) => {\r\n const returnUrlQuery = !returnUrl ? '' : `?returnUrl=${returnUrl}`;\r\n\r\n try {\r\n if (!skipSignOutRequest) {\r\n await apiUserAccountService.signOut();\r\n }\r\n\r\n localStorage.removeItem(ASP_NET_COOKIE_EXP);\r\n navigateToURL(navigateUrl ?? `${homeRoutes.signIn}${returnUrlQuery}`);\r\n } catch (error) {\r\n handleError(i18next.t(keyMap.accountFailedToSignOutError), error);\r\n }\r\n };\r\n\r\n fetchCookieExpirationDate = async () => {\r\n try {\r\n const authCookieExpirationDate = (await apiUserAccountService.getAuthCookieExpirationDate()).data;\r\n\r\n localStorage.setItem(ASP_NET_COOKIE_EXP, authCookieExpirationDate.expirationDateTimeUtc);\r\n\r\n return authCookieExpirationDate.expirationDateTimeUtc;\r\n } catch (error) {\r\n console.error(error);\r\n return null;\r\n }\r\n };\r\n\r\n validateCookieExpiration = () => {\r\n if (this.getIsAuthRecordValidOrNotExist()) {\r\n return true;\r\n }\r\n\r\n this.signOutAndShowSessionExpiredNotificationDialog();\r\n return false;\r\n };\r\n\r\n signOutAndShowSessionExpiredNotificationDialog = ({\r\n skipSignOutRequest,\r\n }: {\r\n skipSignOutRequest?: boolean;\r\n } = {}) => {\r\n NotificationDialog.show(keyMap.sharedSystemError401, 'error');\r\n\r\n setTimeout(() => {\r\n void this.signOut({\r\n skipSignOutRequest,\r\n returnUrl: encodeURIComponent(window.location.href),\r\n });\r\n }, 500);\r\n };\r\n}\r\n","import { IApiUserClientSideTranslationKey } from '@api/services/user/clientSideTranslations/clientSideTranslation.apiService.interfaces';\r\nimport { apiUserClientSideTranslations } from '@api/services/user/clientSideTranslations/clientSideTranslations.apiService';\r\nimport { keyMap } from '@locales/lokalise/keyMap';\r\nimport { handleError } from '@utils/errors';\r\nimport { makeAutoObservable, runInAction } from 'mobx';\r\nimport { MobxRootStore } from './mobx.store';\r\n\r\nexport class ClientSideTranslation {\r\n mobxStore: MobxRootStore;\r\n\r\n private _translations: Partial> = {};\r\n private _loading = false;\r\n\r\n constructor(mobxStore: MobxRootStore) {\r\n this.mobxStore = mobxStore;\r\n makeAutoObservable(this);\r\n }\r\n\r\n fetchTranslations = async (language?: string) => {\r\n this._loading = true;\r\n try {\r\n const { data } = await apiUserClientSideTranslations.getAll(language);\r\n\r\n const newTranslations: Record = {};\r\n\r\n data.forEach((item) => {\r\n newTranslations[item.key] = item.value;\r\n });\r\n\r\n runInAction(() => {\r\n this._translations = newTranslations;\r\n });\r\n } catch (error) {\r\n handleError(keyMap.sharedErrorsFailedToGetData);\r\n } finally {\r\n runInAction(() => {\r\n this._loading = false;\r\n });\r\n }\r\n };\r\n\r\n t = (key: IApiUserClientSideTranslationKey) => {\r\n const translationValue = this._translations[key];\r\n\r\n return translationValue || key;\r\n };\r\n\r\n get clientSideTranslationsLoading() {\r\n return this._loading;\r\n }\r\n}\r\n","import { featureService } from '@api/services/feature/feature.apiService';\r\nimport { FeatureFlags, FeatureTypes } from '@api/services/feature/feature.apiService.interfaces';\r\nimport { keyMap } from '@locales/lokalise/keyMap';\r\nimport { handleError } from '@utils/errors';\r\nimport { makeAutoObservable, runInAction } from 'mobx';\r\nimport type { MobxRootStore } from './mobx.store';\r\n\r\nexport class FeaturesStore {\r\n mobxStore: MobxRootStore;\r\n private _isFeaturesProcessing = false;\r\n private _isFeaturesLoaded = false;\r\n private _featureFlags: FeatureFlags = {\r\n TradingContests: false,\r\n SocialTrading: false,\r\n Bonuses: false,\r\n MAM: false,\r\n EducationalPortal: false,\r\n LoyaltyPrograms: false,\r\n CustomNotifications: false,\r\n EmailTemplates: false,\r\n CustomPushNotifications: false,\r\n };\r\n\r\n constructor(mobxStore: MobxRootStore) {\r\n this.mobxStore = mobxStore;\r\n makeAutoObservable(this);\r\n }\r\n\r\n fetchFeatureFlags = async () => {\r\n this._isFeaturesProcessing = true;\r\n try {\r\n const { data: features } = await featureService.getAll();\r\n\r\n if (features) {\r\n runInAction(() => {\r\n this._featureFlags = features;\r\n this._isFeaturesProcessing = false;\r\n this._isFeaturesLoaded = true;\r\n });\r\n }\r\n } catch (error) {\r\n handleError(keyMap.sharedErrorsFailedToGetSettings, error);\r\n this._isFeaturesProcessing = false;\r\n }\r\n };\r\n\r\n isFeatureEnabled = (feature?: FeatureTypes): boolean => {\r\n if (!feature) {\r\n return true;\r\n }\r\n\r\n return this._featureFlags[feature];\r\n };\r\n\r\n get featureFlags() {\r\n return this._featureFlags;\r\n }\r\n\r\n get isFeaturesProcessing() {\r\n return this._isFeaturesProcessing;\r\n }\r\n\r\n get isFeaturesLoaded() {\r\n return this._isFeaturesLoaded;\r\n }\r\n}\r\n","import { createContext, useContext } from 'react';\r\nimport { mobxStore } from './mobx.store';\r\n\r\nexport { mobxStore } from './mobx.store';\r\n\r\nexport const MobxRootStoreContext = createContext(null);\r\n\r\nexport const useMobxStore = () => {\r\n const context = useContext(MobxRootStoreContext);\r\n\r\n if (context === null) {\r\n throw new Error('You have forgotten to wrap your root component with RootStoreProvider');\r\n }\r\n\r\n return context;\r\n};\r\n","import { apiLoyaltyProgramParticipantUserService } from '@api/services/user/loyaltyProgram/loyaltyProgramParticipantUser.apiService';\r\nimport { IApiLoyaltyProgramParticipantUserInfo } from '@api/services/user/loyaltyProgram/loyaltyProgramParticipantUser.apiService.interface';\r\nimport { getUserStatusData } from '@components-member/userDataProvider';\r\nimport { NUMBER_OF_ROWS } from '@components-shared/table/constants';\r\nimport { keyMap } from '@locales/lokalise/keyMap';\r\nimport { handleError } from '@utils/errors';\r\nimport { makeAutoObservable, runInAction } from 'mobx';\r\nimport { MobxRootStore } from './mobx.store';\r\n\r\nexport class LoyaltyProgramStore {\r\n mobxStore: MobxRootStore;\r\n\r\n private _loyaltyProgramInfo: IApiLoyaltyProgramParticipantUserInfo[] = [];\r\n\r\n constructor(mobxStore: MobxRootStore) {\r\n this.mobxStore = mobxStore;\r\n makeAutoObservable(this);\r\n }\r\n\r\n fetchLoyaltyProgramInfo = async () => {\r\n const { LoyaltyPrograms } = this.mobxStore.featuresStore.featureFlags;\r\n const { onboardingConfiguration, userInfo } = this.mobxStore.accountStore;\r\n const { isUserApproved } = getUserStatusData(userInfo);\r\n\r\n if (!LoyaltyPrograms || !onboardingConfiguration?.showLoyaltyProgramsTab || !isUserApproved) {\r\n return;\r\n }\r\n\r\n try {\r\n const response = await apiLoyaltyProgramParticipantUserService.getInfo(0, NUMBER_OF_ROWS[2]);\r\n\r\n runInAction(() => {\r\n this._loyaltyProgramInfo = response.data;\r\n });\r\n } catch (error) {\r\n handleError(keyMap.sharedErrorsFailedToGetRecord, error);\r\n }\r\n };\r\n\r\n get LoyaltyProgramInfo() {\r\n return this._loyaltyProgramInfo;\r\n }\r\n}\r\n","/**\r\n * Returns same result until the first promise is resolved\r\n */\r\nexport const takeLeading = ReturnType>(cb: T) => {\r\n let currentResult: ReturnType | undefined;\r\n\r\n return (...args: Parameters) => {\r\n if (currentResult) {\r\n return currentResult;\r\n }\r\n\r\n const result = cb(...args);\r\n\r\n if (result instanceof Promise) {\r\n currentResult = result;\r\n // eslint-disable-next-line promise/prefer-await-to-then\r\n result.finally(() => (currentResult = undefined));\r\n }\r\n\r\n return result;\r\n };\r\n};\r\n","import { AccountStore } from './account.store';\r\nimport { AppSettingStore } from './appSettings.store';\r\nimport { AuthStore } from './auth.store';\r\nimport { ClientSideTranslation } from './clientSideTranslation.store';\r\nimport { FeaturesStore } from './features.store';\r\nimport { LoyaltyProgramStore } from './loyaltyProgram.store';\r\nimport { NotificationsStore } from './notifications.store';\r\nimport { PopupModalStore } from './popupModal.store';\r\nimport { PSPStore } from './psp.store';\r\nimport { TradingAccountsStore } from './tradingAccounts.store';\r\n\r\nexport class MobxRootStore {\r\n authStore: AuthStore;\r\n accountStore: AccountStore;\r\n pspStore: PSPStore;\r\n notificationStore: NotificationsStore;\r\n appSettingStore: AppSettingStore;\r\n tradingAccountsStore: TradingAccountsStore;\r\n popupModalStore: PopupModalStore;\r\n featuresStore: FeaturesStore;\r\n loyaltyProgramStore: LoyaltyProgramStore;\r\n clientSideTranslationStore: ClientSideTranslation;\r\n\r\n constructor() {\r\n this.authStore = new AuthStore(this);\r\n this.accountStore = new AccountStore(this);\r\n this.pspStore = new PSPStore(this);\r\n this.notificationStore = new NotificationsStore(this);\r\n this.appSettingStore = new AppSettingStore(this);\r\n this.tradingAccountsStore = new TradingAccountsStore(this);\r\n this.popupModalStore = new PopupModalStore(this);\r\n this.featuresStore = new FeaturesStore(this);\r\n this.loyaltyProgramStore = new LoyaltyProgramStore(this);\r\n this.clientSideTranslationStore = new ClientSideTranslation(this);\r\n }\r\n}\r\n\r\nexport const mobxStore = new MobxRootStore();\r\n","import { apiNotificationsUserService } from '@api/services/notificationsUser.apiService';\r\nimport { INotification } from '@api/services/notificationsUser.apiService.interfaces';\r\nimport { keyMap } from '@locales/lokalise/keyMap';\r\nimport { handleError } from '@utils/errors';\r\nimport { makeAutoObservable, onBecomeObserved, onBecomeUnobserved, runInAction } from 'mobx';\r\nimport { MobxRootStore } from './mobx.store';\r\n\r\nexport class NotificationsStore {\r\n mobxStore: MobxRootStore;\r\n\r\n private _notifications: INotification[] = [];\r\n private _pollingInterval: NodeJS.Timeout | undefined;\r\n private _pollingDelay = 60 * 1000 * 5;\r\n private _selectedNotificationId: number | null = null;\r\n private _areNotificationsObserved = false;\r\n\r\n constructor(mobxStore: MobxRootStore) {\r\n this.mobxStore = mobxStore;\r\n makeAutoObservable(this);\r\n\r\n document.addEventListener('visibilitychange', () => {\r\n if (!this._areNotificationsObserved) {\r\n return;\r\n }\r\n if (document.hidden) {\r\n this.suspendPolling();\r\n } else {\r\n void this.resumePolling();\r\n }\r\n });\r\n\r\n onBecomeObserved(this, 'notifications', () => {\r\n this._areNotificationsObserved = true;\r\n void this.resumePolling();\r\n });\r\n onBecomeUnobserved(this, 'notifications', () => {\r\n this._areNotificationsObserved = false;\r\n this.suspendPolling();\r\n });\r\n }\r\n\r\n resumePolling = async () => {\r\n await this.fetchNotifications();\r\n void this.runNotificationPolling();\r\n };\r\n\r\n suspendPolling = () => {\r\n clearInterval(this._pollingInterval);\r\n };\r\n\r\n setAcceptBonusProposal = async (notificationId: number) => {\r\n const currentNotification = this.notifications.find((notification) => notification.id === notificationId);\r\n\r\n if (!currentNotification || currentNotification.state === 'Accepted') {\r\n return;\r\n }\r\n\r\n const statusSnapshot = currentNotification.state;\r\n\r\n try {\r\n currentNotification.state = 'Accepted';\r\n currentNotification.isRead = true;\r\n\r\n await apiNotificationsUserService.accept(currentNotification.id);\r\n } catch (error) {\r\n currentNotification.state = statusSnapshot;\r\n handleError(keyMap.sharedErrorsFailedToCreateRecord, error);\r\n }\r\n };\r\n\r\n setRejectBonusProposal = async (notificationId: number) => {\r\n const currentNotification = this.notifications.find((notification) => notification.id === notificationId);\r\n\r\n if (!currentNotification || currentNotification.state !== 'ActionIsRequired') {\r\n return;\r\n }\r\n\r\n const statusSnapshot = currentNotification.state;\r\n\r\n try {\r\n currentNotification.state = 'Rejected';\r\n currentNotification.isRead = true;\r\n\r\n await apiNotificationsUserService.reject(currentNotification.id);\r\n } catch (error) {\r\n currentNotification.state = statusSnapshot;\r\n handleError(keyMap.sharedErrorsFailedToCreateRecord, error);\r\n }\r\n };\r\n\r\n fetchNotifications = async () => {\r\n try {\r\n const response = await apiNotificationsUserService.getGrid(\r\n { skip: 0, take: 999 },\r\n { methods: ['Popup'], notExpired: true },\r\n );\r\n\r\n this.updatePollingDelayAndReRunPolling(response.data.pollingIntervalInSeconds);\r\n\r\n runInAction(() => {\r\n this._notifications = response.data.records.sort((notificationA, notificationB) =>\r\n new Date(notificationA.expirationDate) > new Date(notificationB.expirationDate) ? 1 : -1,\r\n );\r\n });\r\n\r\n return response;\r\n } catch (error) {\r\n console.error(error);\r\n }\r\n };\r\n\r\n updatePollingDelayAndReRunPolling = (seconds: number) => {\r\n const newPollingDelay = seconds * 1000;\r\n\r\n if (this._pollingInterval && newPollingDelay !== this._pollingDelay) {\r\n this._pollingDelay = newPollingDelay;\r\n void this.runNotificationPolling();\r\n } else {\r\n this._pollingDelay = newPollingDelay;\r\n }\r\n };\r\n\r\n runNotificationPolling = () => {\r\n this.suspendPolling();\r\n\r\n this._pollingInterval = setInterval(() => {\r\n void this.fetchNotifications();\r\n }, this._pollingDelay);\r\n };\r\n\r\n setShowSelectedNotificationPopup = (notificationId: number) => {\r\n this._selectedNotificationId = notificationId;\r\n };\r\n\r\n setHideSelectedNotificationPopup = () => {\r\n this._selectedNotificationId = null;\r\n };\r\n\r\n get notifications() {\r\n return this._notifications;\r\n }\r\n\r\n get actualPopupNotifications() {\r\n return this.notifications.filter((notification) => {\r\n const isNotExpired = new Date(notification.expirationDate) > new Date();\r\n const isNotApplied =\r\n notification.state === 'Accepted' ||\r\n notification.state === 'ActionIsRequired' ||\r\n notification.state === 'Rejected';\r\n\r\n return notification.method === 'Popup' && isNotExpired && isNotApplied;\r\n });\r\n }\r\n\r\n get selectedNotificationId() {\r\n return this._selectedNotificationId;\r\n }\r\n\r\n get selectedNotification() {\r\n return this.notifications.find((notification) => notification.id === this.selectedNotificationId);\r\n }\r\n\r\n get unreadPopupNotification() {\r\n return this.actualPopupNotifications.find((notification) => notification.isRead === false);\r\n }\r\n}\r\n","import { apiDataChangeRequestUserService } from '@api/services/dataChangeRequestUser.apiService';\r\nimport { makeAutoObservable } from 'mobx';\r\nimport { MobxRootStore } from './mobx.store';\r\n\r\nexport class PopupModalStore {\r\n mobxStore: MobxRootStore;\r\n\r\n private _isBankCardUpdateRequired = false;\r\n private _isUpdateBankCardModalShown = false;\r\n\r\n constructor(mobxStore: MobxRootStore) {\r\n this.mobxStore = mobxStore;\r\n makeAutoObservable(this);\r\n }\r\n\r\n fetchUserBankCardRequiresUpdatesAndShowModal = async () => {\r\n if (this._isBankCardUpdateRequired) {\r\n this.openCloseUpdateBankCardModal(true);\r\n }\r\n\r\n try {\r\n const { data: isShowModal } = await apiDataChangeRequestUserService.showDataChangeRequestPopup();\r\n\r\n this._isBankCardUpdateRequired = isShowModal;\r\n this.openCloseUpdateBankCardModal(isShowModal);\r\n } catch (error) {\r\n console.error(error);\r\n }\r\n };\r\n\r\n openCloseUpdateBankCardModal = (value: boolean) => {\r\n this._isUpdateBankCardModalShown = value;\r\n };\r\n\r\n get isUpdateBankCardModalShown() {\r\n return this._isUpdateBankCardModalShown;\r\n }\r\n}\r\n","/* eslint-disable @typescript-eslint/no-inferrable-types */\r\nimport { apiPspService } from '@api/services/psp.apiService';\r\nimport { getEmptyPspInfo } from '@components-member/psp/getEmptyPspInfo';\r\nimport type { IPSPInfo } from '@components-member/psp/pspInfo.interface';\r\nimport type { IEnumConstant } from '@components-shared/enum.constants.interface';\r\nimport { GENERAL_CONSTANTS } from '@components-shared/general.constants';\r\nimport { IAccount, IAccountApiResponse } from '@components-shared/shared.interfaces';\r\nimport { AxiosError } from 'axios';\r\nimport { PSP_INFO_LOADING_STATUS } from 'global.enums';\r\nimport type { IAccountSettings, IPlugin, IWallet, InternalTransferInfo } from 'global.interfaces';\r\nimport { makeAutoObservable, runInAction } from 'mobx';\r\nimport type { MobxRootStore } from './mobx.store';\r\n\r\nexport class PSPStore {\r\n mobxStore: MobxRootStore;\r\n\r\n private _plugins: IPlugin[] = [];\r\n private _pluginLoading: boolean = true;\r\n private _selectedCategory: string | null = null;\r\n private _selectedPlugin: IPlugin | null = null;\r\n private _infoLoadingState: PSP_INFO_LOADING_STATUS = PSP_INFO_LOADING_STATUS.EMPTY;\r\n private _pluginInfo: IPSPInfo = getEmptyPspInfo();\r\n private _tradingAccounts: IAccountApiResponse[] = [];\r\n private _walletAccounts: IWallet[] = [];\r\n private _accountsLoading: boolean = true;\r\n private _internalTransferInfo: InternalTransferInfo | Record = {};\r\n private _internalTransferInfoLoading: boolean = true;\r\n private _wallets: IWallet[] = [];\r\n private _walletsLoading: boolean = true;\r\n\r\n constructor(mobxStore: MobxRootStore) {\r\n this.mobxStore = mobxStore;\r\n makeAutoObservable(this);\r\n }\r\n\r\n fetchPspPlugins = async (pspType: string) => {\r\n this._plugins = [];\r\n this._pluginLoading = true;\r\n this._selectedCategory = null;\r\n\r\n try {\r\n const response = await apiPspService.getPspPlugins(pspType);\r\n\r\n runInAction(() => {\r\n // @ts-ignore\r\n this._plugins = response.data?.data || response.data;\r\n this._pluginLoading = false;\r\n });\r\n\r\n const getCategories = (currentPlugins: IPlugin[] = []) => {\r\n const categories = GENERAL_CONSTANTS.WALLET_OPERATION_CATEGORY as IEnumConstant[];\r\n const pluginsCategories = currentPlugins.map((pl) => pl.category);\r\n\r\n return categories.filter((cat) => pluginsCategories.indexOf(cat.value) !== -1);\r\n };\r\n\r\n const categories = getCategories(response.data as IPlugin[]);\r\n\r\n this.setPspCategory(categories[0] ? categories[0].value || null : null);\r\n } catch (error) {\r\n runInAction(() => {\r\n this._plugins = [];\r\n this._pluginLoading = false;\r\n\r\n /**\r\n * @description Legacy code migrated from redux\r\n * @todo: Verify if we need it\r\n */\r\n const payload = (error as { data?: unknown })?.data ?? (error as AxiosError).response?.data;\r\n\r\n if (payload?.plugins) {\r\n this._plugins = payload.plugins;\r\n }\r\n });\r\n }\r\n };\r\n\r\n fetchPspPluginInfo = async (type: string, pspId: string | number) => {\r\n this._pluginInfo = getEmptyPspInfo();\r\n this._infoLoadingState = PSP_INFO_LOADING_STATUS.LOADING;\r\n try {\r\n const response = await apiPspService.getPspPluginInfo({ type, pspId });\r\n\r\n runInAction(() => {\r\n this._pluginInfo = { ...response.data };\r\n this._infoLoadingState = PSP_INFO_LOADING_STATUS.LOADED_SUCCESS;\r\n });\r\n } catch (error) {\r\n runInAction(() => {\r\n const payload = error?.data ?? (error as AxiosError).response?.data;\r\n\r\n this._pluginInfo = { ...payload };\r\n\r\n this._infoLoadingState = PSP_INFO_LOADING_STATUS.LOADED_FAIL;\r\n });\r\n }\r\n };\r\n\r\n setPspCategory = (category: string | null) => {\r\n this._selectedCategory = category;\r\n };\r\n\r\n setPspPlugin = (plugin: IPlugin | null) => {\r\n this._selectedPlugin = plugin;\r\n };\r\n\r\n setPspInfoEmpty = () => {\r\n this._pluginInfo = getEmptyPspInfo();\r\n this._infoLoadingState = PSP_INFO_LOADING_STATUS.EMPTY;\r\n };\r\n\r\n fetchAllAccounts = async (accountType: string) => {\r\n this._accountsLoading = true;\r\n\r\n try {\r\n const [accounts, walletAccounts] = await Promise.all([\r\n apiPspService.getAccounts(accountType),\r\n apiPspService.getWalletsAccount(),\r\n ]);\r\n\r\n runInAction(() => {\r\n this._accountsLoading = false;\r\n this._tradingAccounts = accounts.data;\r\n this._walletAccounts = walletAccounts.data;\r\n });\r\n } catch (error) {\r\n runInAction(() => {\r\n this._accountsLoading = false;\r\n });\r\n }\r\n };\r\n\r\n fetchInternalTransferInfo = async () => {\r\n this._internalTransferInfoLoading = true;\r\n this._internalTransferInfo = {};\r\n\r\n try {\r\n const response = await apiPspService.getInternalTransferInfo();\r\n\r\n runInAction(() => {\r\n this._internalTransferInfo = response.data;\r\n this._internalTransferInfoLoading = false;\r\n });\r\n } catch (error) {\r\n runInAction(() => {\r\n this._internalTransferInfoLoading = false;\r\n });\r\n }\r\n };\r\n\r\n fetchWalletAccounts = async () => {\r\n this._walletsLoading = true;\r\n\r\n try {\r\n const response = await apiPspService.getWalletsAccount();\r\n\r\n runInAction(() => {\r\n this._wallets = response.data;\r\n this._walletsLoading = false;\r\n });\r\n } catch (error) {\r\n runInAction(() => {\r\n this._walletsLoading = false;\r\n });\r\n }\r\n };\r\n\r\n get categories(): IEnumConstant[] {\r\n const categories = GENERAL_CONSTANTS.WALLET_OPERATION_CATEGORY as IEnumConstant[];\r\n const plugins = this._plugins ?? [];\r\n\r\n const pluginsCategories = plugins.map((pl) => pl.category);\r\n\r\n return categories.filter((cat) => pluginsCategories.indexOf(cat.value) !== -1);\r\n }\r\n\r\n get allAccountOptions(): {\r\n settings?: IAccountSettings;\r\n balance: number;\r\n walletType: string | null;\r\n accountType: string;\r\n currency: string;\r\n id: number;\r\n title?: string;\r\n value: string;\r\n idHash?: IAccount['idHash'];\r\n }[] {\r\n const accounts = this._tradingAccounts ?? [];\r\n const walletAccounts = this._walletAccounts ?? [];\r\n\r\n const options = [...walletAccounts, ...accounts.filter((acc) => !!acc.currency)];\r\n\r\n return options.map((option) => {\r\n const accountType = 'walletNumber' in option ? 'wallet' : 'account';\r\n let title;\r\n\r\n if ('walletNumber' in option) {\r\n title = option.walletNumber;\r\n } else if ('login' in option) {\r\n title = `${option.login}`;\r\n }\r\n\r\n return Object.assign(\r\n {},\r\n {\r\n ...option,\r\n title,\r\n value: `${accountType}-${option.id}`,\r\n walletType: 'type' in option ? option.type : null,\r\n accountType,\r\n },\r\n );\r\n });\r\n }\r\n\r\n get plugins() {\r\n return this._plugins;\r\n }\r\n get pluginLoading() {\r\n return this._pluginLoading;\r\n }\r\n get selectedCategory() {\r\n return this._selectedCategory;\r\n }\r\n get selectedPlugin() {\r\n return this._selectedPlugin;\r\n }\r\n get infoLoadingState() {\r\n return this._infoLoadingState;\r\n }\r\n get pluginInfo() {\r\n return this._pluginInfo;\r\n }\r\n get tradingAccounts() {\r\n return this._tradingAccounts;\r\n }\r\n get walletAccounts() {\r\n return this._walletAccounts;\r\n }\r\n get accountsLoading() {\r\n return this._accountsLoading;\r\n }\r\n get internalTransferInfo() {\r\n return this._internalTransferInfo;\r\n }\r\n get internalTransferInfoLoading() {\r\n return this._internalTransferInfoLoading;\r\n }\r\n get wallets() {\r\n return this._wallets;\r\n }\r\n get walletsLoading() {\r\n return this._walletsLoading;\r\n }\r\n}\r\n","import { IApiTradingAccountCardCategory, IApiTradingPlatformType } from '@api/interfaces/data-contracts';\r\nimport { apiCopyTradingAccountCardUser } from '@api/services/copyTradingAccountCardUser.apiService';\r\nimport { apiTradingAccountCardUser } from '@api/services/tradingAccountCardUser.apiService';\r\nimport { apiTradingAccountUser } from '@api/services/tradingAccountUser.apiService';\r\nimport { accountCreatedSuccessfullyEvent } from '@components-member/TradingAccounts/AccountCreate/requests';\r\nimport { openAccountAnalyticsService } from '@components-member/TradingAccounts/analyticsEvents/openAccount.analytics.service';\r\nimport type { IAccountCreationQueryParams } from '@components-member/TradingAccounts/hooks/useAccountCreationQueryParams';\r\nimport { IApiTradingAccountCardInfoExt } from '@components-member/TradingAccounts/interfaces';\r\nimport { pushAccountCreateErrorEvent } from '@components-shared/googleAnalyticsEvents';\r\nimport { NotificationDialog } from '@components-shared/modal';\r\nimport { keyMap } from '@locales/lokalise/keyMap';\r\nimport { handleError } from '@utils/errors';\r\nimport { getAccountCategoryType } from '@utils/getAccountCategoryType';\r\nimport { reactRouterService } from '@utils/library/reactRouter.service';\r\nimport { QUERY_PARAMS, TRADING_ACCOUNT_FORM_TYPE, TRADING_ACCOUNT_SOURCE } from 'global.enums';\r\nimport type { IUser } from 'global.interfaces';\r\nimport { i18n } from 'i18next';\r\nimport { makeAutoObservable, runInAction } from 'mobx';\r\nimport { takeLeading } from './mobx.helpers';\r\nimport type { MobxRootStore } from './mobx.store';\r\n\r\nexport class TradingAccountsStore {\r\n mobxStore: MobxRootStore;\r\n\r\n private _tradingAccountsCategories: IApiTradingAccountCardCategory[] = [];\r\n private _selfAccounts: IApiTradingAccountCardInfoExt[] = [];\r\n private _investorAccounts: IApiTradingAccountCardInfoExt[] = [];\r\n private _masterAccounts: IApiTradingAccountCardInfoExt[] = [];\r\n private _isTradingAccountBeingSynced = false;\r\n private _isFetchTradingAccountsProcessing = false;\r\n private _isCreateTradingAccountModalOpened = false;\r\n private _createSelfAccountCallbacks: Array<() => void> = [];\r\n\r\n constructor(mobxStore: MobxRootStore) {\r\n this.mobxStore = mobxStore;\r\n makeAutoObservable(this);\r\n }\r\n\r\n subscribeOnSelfAccountCreate = (callback: () => void) => {\r\n this._createSelfAccountCallbacks.push(callback);\r\n };\r\n\r\n unsubscribeOnSelfAccountCreate = (callback: () => void) => {\r\n this._createSelfAccountCallbacks = this._createSelfAccountCallbacks.filter((cb) => cb !== callback);\r\n };\r\n\r\n private _clearAllSelfAccountSubscriptions = () => {\r\n this._createSelfAccountCallbacks = [];\r\n };\r\n\r\n private _executeAllSelfAccountSubscriptions = () => {\r\n this._createSelfAccountCallbacks.forEach((callback) => callback());\r\n };\r\n\r\n fetchInitialAccountsData = async ({ isPreloaderEnable }: { isPreloaderEnable: boolean }) => {\r\n try {\r\n if (isPreloaderEnable) {\r\n runInAction(() => (this._isFetchTradingAccountsProcessing = true));\r\n }\r\n\r\n const [categoriesResponse, accountsResponse, investorAccountsResponse, masterAccountsResponse] =\r\n await Promise.all([\r\n apiTradingAccountCardUser.getCategories(),\r\n apiTradingAccountCardUser.getSelfTradingAccounts(),\r\n apiCopyTradingAccountCardUser.getInvestorAccounts(),\r\n apiCopyTradingAccountCardUser.getMasterAccounts(),\r\n ]);\r\n\r\n runInAction(() => {\r\n this._selfAccounts = accountsResponse.data;\r\n this._investorAccounts = investorAccountsResponse.data;\r\n this._masterAccounts = masterAccountsResponse.data;\r\n this._tradingAccountsCategories = categoriesResponse.data.sort((a, b) => a.priority - b.priority);\r\n });\r\n } catch (error) {\r\n handleError(keyMap.tradingAccountsFailedToFetchTradingAccounts, error);\r\n } finally {\r\n if (isPreloaderEnable) {\r\n runInAction(() => (this._isFetchTradingAccountsProcessing = false));\r\n }\r\n }\r\n };\r\n\r\n fetchSelfAccounts = takeLeading(async () => {\r\n try {\r\n const accountsResponse = await apiTradingAccountCardUser.getSelfTradingAccounts();\r\n\r\n runInAction(() => (this._selfAccounts = accountsResponse.data));\r\n } catch (error) {\r\n handleError(keyMap.tradingAccountsFailedToFetchTradingAccounts, error);\r\n }\r\n });\r\n\r\n fetchSyncTradingAccount = async (tradingAccountId: number) => {\r\n try {\r\n this._isTradingAccountBeingSynced = true;\r\n await apiTradingAccountUser.sync(tradingAccountId);\r\n await this.fetchInitialAccountsData({ isPreloaderEnable: false });\r\n } catch (error) {\r\n handleError(keyMap.tradingAccountsFailedToFetchTradingAccounts, error);\r\n } finally {\r\n this._isTradingAccountBeingSynced = false;\r\n }\r\n };\r\n\r\n /**\r\n * @deprecated\r\n * Do NOT use outside AccountCreateEntry\r\n * Please use configureCreateTradingAccountModal instead\r\n */\r\n openCreateTradingAccountModal = () => {\r\n openAccountAnalyticsService.openAccountModalShowEvent(this.mobxStore.accountStore.userInfo);\r\n this._isCreateTradingAccountModalOpened = true;\r\n };\r\n\r\n configureCreateTradingAccountModal = (options: {\r\n queryParams: {\r\n [QUERY_PARAMS.OPEN_ACCOUNT]?: TRADING_ACCOUNT_FORM_TYPE;\r\n [QUERY_PARAMS.SOURCE]?: TRADING_ACCOUNT_SOURCE;\r\n [QUERY_PARAMS.PLATFORM_TYPE]?: IAccountCreationQueryParams['platformType'];\r\n [QUERY_PARAMS.CONTEST_ID]?: string | number;\r\n };\r\n }) => {\r\n reactRouterService.addUrlQueryParams(options.queryParams);\r\n };\r\n\r\n closeCreateTradingAccountModal = () => {\r\n openAccountAnalyticsService.openAccountModalCloseEvent(this.mobxStore.accountStore.userInfo);\r\n reactRouterService.deleteUrlQueryParams();\r\n this._isCreateTradingAccountModalOpened = false;\r\n this._clearAllSelfAccountSubscriptions();\r\n };\r\n\r\n createSelfTradeAccount = async (form: Record, user: IUser) => {\r\n try {\r\n const response = await apiTradingAccountUser.createSelfTradeAccount(form);\r\n\r\n NotificationDialog.show(keyMap.tradingAccountsAccountSuccessfullyCreated);\r\n\r\n accountCreatedSuccessfullyEvent(response.data.idHash, form, user, response.data.accountType);\r\n this._executeAllSelfAccountSubscriptions();\r\n return response.data;\r\n } catch (error) {\r\n pushAccountCreateErrorEvent(error.response.data);\r\n handleError(keyMap.tradingAccountsFailedToFetchTradingAccounts, error);\r\n }\r\n };\r\n\r\n getAccountTradeLink = (options: { i18n: i18n; accountId: number }) => {\r\n const { i18n } = options;\r\n\r\n const {\r\n accountStore: { userInfo, generalSettings },\r\n tradingAccountsStore,\r\n } = this.mobxStore;\r\n const { webTraderUrl } = generalSettings;\r\n\r\n const account = tradingAccountsStore.tradingAccountsAll.find((account) => account.id === options.accountId);\r\n\r\n const isTradingPlatformType = account?.type.tradingPlatformType === IApiTradingPlatformType.Gmi;\r\n\r\n if (!account) {\r\n return null;\r\n }\r\n\r\n const { isCommissionAccount, isMamCommissionAccount } = getAccountCategoryType({\r\n groupMappingType: account?.groupMappingType,\r\n masterId: account.master?.masterId || null,\r\n investorId: account.investor?.investorId || null,\r\n });\r\n\r\n if (\r\n !webTraderUrl ||\r\n !account ||\r\n !isTradingPlatformType ||\r\n !userInfo.isEdgeTradingEnabled ||\r\n isCommissionAccount ||\r\n isMamCommissionAccount\r\n ) {\r\n return null;\r\n }\r\n\r\n const {\r\n login,\r\n metaServerAddress,\r\n type: { displayName },\r\n id,\r\n } = account;\r\n\r\n const queryParams = new URLSearchParams({\r\n metaServerAddress,\r\n accountName: displayName,\r\n login: String(login),\r\n id: String(id),\r\n userId: String(userInfo.id),\r\n language: i18n.language,\r\n });\r\n\r\n return `${webTraderUrl}?${queryParams}`;\r\n };\r\n\r\n get tradingAccountsAll() {\r\n return [...this._selfAccounts, ...this._investorAccounts, ...this._masterAccounts];\r\n }\r\n\r\n get tradingAccountsSelf() {\r\n return this._selfAccounts;\r\n }\r\n\r\n get tradingAccountsCategories() {\r\n return this._tradingAccountsCategories;\r\n }\r\n\r\n get isFetchTradingAccountsProcessing() {\r\n return this._isFetchTradingAccountsProcessing;\r\n }\r\n\r\n get isTradingAccountBeingSynced() {\r\n return this._isTradingAccountBeingSynced;\r\n }\r\n\r\n get isCreateTradingAccountModalOpened() {\r\n return this._isCreateTradingAccountModalOpened;\r\n }\r\n}\r\n","import { keyMap } from '@locales/lokalise/keyMap';\r\nimport { EmptyObject } from 'components/shared/shared.interfaces';\r\nimport { ErrorCodesInfo, ErrorCodesData } from 'global.interfaces';\r\nimport i18next from 'i18next';\r\n\r\nexport const getErrorInfoByErrorCode = (\r\n errorCode: string,\r\n errorCodesData?: ErrorCodesData | EmptyObject,\r\n messagePlaceholders?: string[],\r\n): ErrorCodesInfo | null => {\r\n const specificErrorCodesMap = getSpecificInfo(errorCode, errorCodesData);\r\n\r\n if (specificErrorCodesMap) {\r\n return specificErrorCodesMap;\r\n }\r\n\r\n const resourceName = `errors.${errorCode}`;\r\n\r\n const interpolationOptions = messagePlaceholders?.reduce((acc, value, index) => {\r\n acc[index as number] = value;\r\n return acc;\r\n }, {} as Record);\r\n\r\n if (i18next.exists(resourceName)) {\r\n return {\r\n // @ts-ignore\r\n message: i18next.t(resourceName, { replace: interpolationOptions }),\r\n resourceName,\r\n };\r\n }\r\n\r\n return null;\r\n};\r\n\r\nconst getSpecificInfo = (\r\n errorCode: string,\r\n errorCodesMapData?: ErrorCodesData | EmptyObject,\r\n): ErrorCodesInfo | null => {\r\n if (errorCode == 'captcha.wasnt-passed') {\r\n const clientSupportEmail = errorCodesMapData?.clientSupportEmail ?? '';\r\n\r\n return {\r\n // @ts-ignore\r\n message: i18next.t(keyMap.errorsCaptchaCaptchaServerIsUnavailable, { 0: clientSupportEmail }),\r\n callback: () => window.location.reload(),\r\n showTime: 7000,\r\n };\r\n }\r\n\r\n return null;\r\n};\r\n","// @ts-ignore: remove after translating into typescript\r\nimport { keyMap } from '@locales/lokalise/keyMap';\r\nimport { KeyMapKeys } from '@locales/lokalise/keyMap';\r\nimport { SeverityLevel } from '@microsoft/applicationinsights-web';\r\nimport { AIError } from 'applicationInsights/AIError';\r\n// @ts-ignore: remove after translating into typescript\r\nimport { getAppInsights } from 'applicationInsights/TelemetryService';\r\nimport { AxiosError } from 'axios';\r\nimport { NotificationDialog } from 'components/shared/modal';\r\nimport { EmptyObject } from 'components/shared/shared.interfaces';\r\nimport { ErrorCodesData, ErrorCodeServerResponse, ErrorCodesInfo } from 'global.interfaces';\r\nimport i18next from 'i18next';\r\nimport { getErrorInfoByErrorCode } from 'utils/errorCodesMap';\r\n\r\nconst DEFENDER_THROW_EXCEPTION = 'MembersArea.Common.Core.Defender.ThrowException';\r\nconst SQL_EXCEPTION = 'MySqlException';\r\nconst HTML_ELEMENT = '