mirror of https://github.com/nocodb/nocodb
աɨռɢӄաօռɢ
2 years ago
committed by
GitHub
7 changed files with 384 additions and 3 deletions
@ -0,0 +1,100 @@
|
||||
<script setup lang="ts"> |
||||
import { useColumnCreateStoreOrThrow, useProject } from '#imports' |
||||
import { currencyCodes, currencyLocales, validateCurrencyCode, validateCurrencyLocale } from '@/utils' |
||||
|
||||
interface Option { |
||||
label: string |
||||
value: string |
||||
} |
||||
|
||||
const { formState, validateInfos, setAdditionalValidations, sqlUi, onDataTypeChange, onAlter } = useColumnCreateStoreOrThrow() |
||||
|
||||
const validators = { |
||||
'meta.currency_locale': [ |
||||
{ |
||||
validator: (_: any, locale: any) => { |
||||
return new Promise<void>((resolve, reject) => { |
||||
if (!validateCurrencyLocale(locale)) { |
||||
return reject(new Error('Invalid locale')) |
||||
} |
||||
resolve() |
||||
}) |
||||
}, |
||||
}, |
||||
], |
||||
'meta.currency_code': [ |
||||
{ |
||||
validator: (_: any, currencyCode: any) => { |
||||
return new Promise<void>((resolve, reject) => { |
||||
if (!validateCurrencyCode(currencyCode)) { |
||||
return reject(new Error('Invalid Currency Code')) |
||||
} |
||||
resolve() |
||||
}) |
||||
}, |
||||
}, |
||||
], |
||||
} |
||||
|
||||
// set additional validations |
||||
setAdditionalValidations({ |
||||
...validators, |
||||
}) |
||||
|
||||
const { isPg } = useProject() |
||||
|
||||
const currencyList = currencyCodes || [] |
||||
|
||||
const currencyLocaleList = currencyLocales() || [] |
||||
|
||||
const isMoney = computed(() => formState.value.dt === 'money') |
||||
|
||||
const message = computed(() => { |
||||
if (isMoney.value && isPg) return "PostgreSQL 'money' type has own currency settings" |
||||
return '' |
||||
}) |
||||
|
||||
function filterOption(input: string, option: Option) { |
||||
return option.value.toUpperCase().includes(input.toUpperCase()) |
||||
} |
||||
</script> |
||||
|
||||
<template> |
||||
<a-row> |
||||
<a-col :span="12"> |
||||
<a-form-item v-bind="validateInfos['meta.currency_locale']" label="Currency Locale"> |
||||
<a-select |
||||
v-model:value="formState.meta.currency_locale" |
||||
size="small" |
||||
class="w-52" |
||||
show-search |
||||
:filter-option="filterOption" |
||||
:disabled="isMoney && isPg" |
||||
> |
||||
<a-select-option v-for="(currencyLocale, i) of currencyLocaleList" :key="i" :value="currencyLocale.value"> |
||||
{{ currencyLocale.text }} |
||||
</a-select-option> |
||||
</a-select> |
||||
</a-form-item> |
||||
</a-col> |
||||
<a-col :span="12"> |
||||
<a-form-item v-bind="validateInfos['meta.currency_code']" label="Currency Code"> |
||||
<a-select |
||||
v-model:value="formState.meta.currency_code" |
||||
class="w-52" |
||||
show-search |
||||
:filter-option="filterOption" |
||||
size="small" |
||||
:disabled="isMoney && isPg" |
||||
> |
||||
<a-select-option v-for="(currencyCode, i) of currencyList" :key="i" :value="currencyCode"> |
||||
{{ currencyCode }} |
||||
</a-select-option> |
||||
</a-select> |
||||
</a-form-item> |
||||
</a-col> |
||||
<a-col v-if="isMoney && isPg"> |
||||
<span class="text-[#FB8C00]">{{ message }}</span> |
||||
</a-col> |
||||
</a-row> |
||||
</template> |
@ -0,0 +1,220 @@
|
||||
import locale from 'locale-codes' |
||||
|
||||
export const currencyCodes = [ |
||||
'AED', |
||||
'AFN', |
||||
'ALL', |
||||
'AMD', |
||||
'ANG', |
||||
'AOA', |
||||
'ARS', |
||||
'AUD', |
||||
'AWG', |
||||
'AZN', |
||||
'BAM', |
||||
'BBD', |
||||
'BDT', |
||||
'BGN', |
||||
'BHD', |
||||
'BIF', |
||||
'BMD', |
||||
'BND', |
||||
'BOB', |
||||
'BOV', |
||||
'BRL', |
||||
'BSD', |
||||
'BTN', |
||||
'BWP', |
||||
'BYR', |
||||
'BZD', |
||||
'CAD', |
||||
'CDF', |
||||
'CHE', |
||||
'CHF', |
||||
'CHW', |
||||
'CLF', |
||||
'CLP', |
||||
'CNY', |
||||
'COP', |
||||
'COU', |
||||
'CRC', |
||||
'CUP', |
||||
'CVE', |
||||
'CYP', |
||||
'CZK', |
||||
'DJF', |
||||
'DKK', |
||||
'DOP', |
||||
'DZD', |
||||
'EEK', |
||||
'EGP', |
||||
'ERN', |
||||
'ETB', |
||||
'EUR', |
||||
'FJD', |
||||
'FKP', |
||||
'GBP', |
||||
'GEL', |
||||
'GHC', |
||||
'GIP', |
||||
'GMD', |
||||
'GNF', |
||||
'GTQ', |
||||
'GYD', |
||||
'HKD', |
||||
'HNL', |
||||
'HRK', |
||||
'HTG', |
||||
'HUF', |
||||
'IDR', |
||||
'ILS', |
||||
'INR', |
||||
'IQD', |
||||
'IRR', |
||||
'ISK', |
||||
'JMD', |
||||
'JOD', |
||||
'JPY', |
||||
'KES', |
||||
'KGS', |
||||
'KHR', |
||||
'KMF', |
||||
'KPW', |
||||
'KRW', |
||||
'KWD', |
||||
'KYD', |
||||
'KZT', |
||||
'LAK', |
||||
'LBP', |
||||
'LKR', |
||||
'LRD', |
||||
'LSL', |
||||
'LTL', |
||||
'LVL', |
||||
'LYD', |
||||
'MAD', |
||||
'MDL', |
||||
'MGA', |
||||
'MKD', |
||||
'MMK', |
||||
'MNT', |
||||
'MOP', |
||||
'MRO', |
||||
'MTL', |
||||
'MUR', |
||||
'MVR', |
||||
'MWK', |
||||
'MXN', |
||||
'MXV', |
||||
'MYR', |
||||
'MZN', |
||||
'NAD', |
||||
'NGN', |
||||
'NIO', |
||||
'NOK', |
||||
'NPR', |
||||
'NZD', |
||||
'OMR', |
||||
'PAB', |
||||
'PEN', |
||||
'PGK', |
||||
'PHP', |
||||
'PKR', |
||||
'PLN', |
||||
'PYG', |
||||
'QAR', |
||||
'ROL', |
||||
'RON', |
||||
'RSD', |
||||
'RUB', |
||||
'RWF', |
||||
'SAR', |
||||
'SBD', |
||||
'SCR', |
||||
'SDD', |
||||
'SEK', |
||||
'SGD', |
||||
'SHP', |
||||
'SIT', |
||||
'SKK', |
||||
'SLL', |
||||
'SOS', |
||||
'SRD', |
||||
'STD', |
||||
'SYP', |
||||
'SZL', |
||||
'THB', |
||||
'TJS', |
||||
'TMM', |
||||
'TND', |
||||
'TOP', |
||||
'TRY', |
||||
'TTD', |
||||
'TWD', |
||||
'TZS', |
||||
'UAH', |
||||
'UGX', |
||||
'USD', |
||||
'USN', |
||||
'USS', |
||||
'UYU', |
||||
'UZS', |
||||
'VEB', |
||||
'VND', |
||||
'VUV', |
||||
'WST', |
||||
'XAF', |
||||
'XAG', |
||||
'XAU', |
||||
'XBA', |
||||
'XBB', |
||||
'XBC', |
||||
'XBD', |
||||
'XCD', |
||||
'XDR', |
||||
'XFO', |
||||
'XFU', |
||||
'XOF', |
||||
'XPD', |
||||
'XPF', |
||||
'XPT', |
||||
'XTS', |
||||
'XXX', |
||||
'YER', |
||||
'ZAR', |
||||
'ZMK', |
||||
'ZWD', |
||||
] |
||||
|
||||
export function validateCurrencyCode(v: string) { |
||||
return currencyCodes.includes(v) |
||||
} |
||||
|
||||
export function currencyLocales() { |
||||
const localeList = locale.all |
||||
.filter((l: Record<string, any>) => { |
||||
try { |
||||
if (Intl.NumberFormat.supportedLocalesOf(l.tag).length > 0) { |
||||
return true |
||||
} |
||||
return false |
||||
} catch (e) { |
||||
return false |
||||
} |
||||
}) |
||||
.map((l: Record<string, any>) => { |
||||
return { |
||||
text: `${l.name} (${l.tag})`, |
||||
value: l.tag, |
||||
} |
||||
}) |
||||
return localeList |
||||
} |
||||
|
||||
export function validateCurrencyLocale(v: string) { |
||||
try { |
||||
return Intl.NumberFormat.supportedLocalesOf(v).length > 0 |
||||
} catch (e) { |
||||
return false |
||||
} |
||||
} |
Loading…
Reference in new issue