mirror of
https://github.com/docusealco/docuseal.git
synced 2026-06-23 04:10:11 +00:00
add percent format
This commit is contained in:
@@ -643,6 +643,10 @@ export default {
|
||||
return new Intl.NumberFormat('de-DE').format(number)
|
||||
} else if (format === 'space') {
|
||||
return new Intl.NumberFormat('fr-FR').format(number)
|
||||
} else if (format === 'percent') {
|
||||
return `${number}%`
|
||||
} else if (format === 'percent_space') {
|
||||
return `${String(number).replace('.', ',')} %`
|
||||
} else {
|
||||
return number
|
||||
}
|
||||
|
||||
@@ -620,6 +620,10 @@ export default {
|
||||
return new Intl.NumberFormat('de-DE').format(number)
|
||||
} else if (format === 'space') {
|
||||
return new Intl.NumberFormat('fr-FR').format(number)
|
||||
} else if (format === 'percent') {
|
||||
return `${number}%`
|
||||
} else if (format === 'percent_space') {
|
||||
return `${String(number).replace('.', ',')} %`
|
||||
} else {
|
||||
return number
|
||||
}
|
||||
|
||||
@@ -248,7 +248,7 @@ export default {
|
||||
FieldType,
|
||||
IconSettings
|
||||
},
|
||||
inject: ['t', 'save', 'backgroundColor', 'dateFormats'],
|
||||
inject: ['t', 'save', 'backgroundColor', 'dateFormats', 'locale'],
|
||||
provide () {
|
||||
return {
|
||||
fieldTypes: ['text', 'number', 'date', 'checkbox', 'radio', 'select']
|
||||
@@ -308,15 +308,18 @@ export default {
|
||||
return { text: 'string', number: 'number', date: 'date', checkbox: 'boolean', radio: 'string', select: 'string' }
|
||||
},
|
||||
numberFormats () {
|
||||
return [
|
||||
'none',
|
||||
'usd',
|
||||
'eur',
|
||||
'gbp',
|
||||
'comma',
|
||||
'dot',
|
||||
'space'
|
||||
]
|
||||
const formats = ['none', 'usd', 'eur', 'gbp', 'comma', 'dot', 'space']
|
||||
const spaceLocales = ['fr-FR', 'es-ES', 'pt-PT', 'de-DE', 'it-IT', 'nl-NL']
|
||||
|
||||
formats.push(spaceLocales.includes(this.locale) ? 'percent_space' : 'percent')
|
||||
|
||||
const selectedFormat = this.schema.format
|
||||
|
||||
if (selectedFormat && !formats.includes(selectedFormat)) {
|
||||
formats.push(selectedFormat)
|
||||
}
|
||||
|
||||
return formats
|
||||
},
|
||||
availableDateFormats () {
|
||||
const formats = this.dateFormats.length
|
||||
@@ -397,6 +400,10 @@ export default {
|
||||
return new Intl.NumberFormat('de-DE').format(number)
|
||||
} else if (format === 'space') {
|
||||
return new Intl.NumberFormat('fr-FR').format(number)
|
||||
} else if (format === 'percent') {
|
||||
return `${number}%`
|
||||
} else if (format === 'percent_space') {
|
||||
return `${String(number).replace('.', ',')} %`
|
||||
} else {
|
||||
return number
|
||||
}
|
||||
|
||||
@@ -514,7 +514,7 @@ export default {
|
||||
ContextSubmenu,
|
||||
ContextModal
|
||||
},
|
||||
inject: ['t', 'getFieldTypeIndex', 'template', 'withCustomFields', 'currencies', 'dateFormats'],
|
||||
inject: ['t', 'getFieldTypeIndex', 'template', 'withCustomFields', 'currencies', 'dateFormats', 'locale'],
|
||||
props: {
|
||||
contextMenu: {
|
||||
type: Object,
|
||||
|
||||
@@ -610,7 +610,7 @@ export default {
|
||||
IconTypography,
|
||||
IconX
|
||||
},
|
||||
inject: ['template', 't', 'dateFormats'],
|
||||
inject: ['template', 't', 'dateFormats', 'locale'],
|
||||
props: {
|
||||
field: {
|
||||
type: Object,
|
||||
@@ -691,15 +691,18 @@ export default {
|
||||
}
|
||||
},
|
||||
numberFormats () {
|
||||
return [
|
||||
'none',
|
||||
'usd',
|
||||
'eur',
|
||||
'gbp',
|
||||
'comma',
|
||||
'dot',
|
||||
'space'
|
||||
]
|
||||
const formats = ['none', 'usd', 'eur', 'gbp', 'comma', 'dot', 'space']
|
||||
const spaceLocales = ['fr-FR', 'es-ES', 'pt-PT', 'de-DE', 'it-IT', 'nl-NL']
|
||||
|
||||
formats.push(spaceLocales.includes(this.locale) ? 'percent_space' : 'percent')
|
||||
|
||||
const selectedFormat = this.field.preferences?.format
|
||||
|
||||
if (selectedFormat && !formats.includes(selectedFormat)) {
|
||||
formats.push(selectedFormat)
|
||||
}
|
||||
|
||||
return formats
|
||||
},
|
||||
availableDateFormats () {
|
||||
const formats = this.dateFormats.length
|
||||
@@ -824,6 +827,10 @@ export default {
|
||||
return new Intl.NumberFormat('de-DE').format(number)
|
||||
} else if (format === 'space') {
|
||||
return new Intl.NumberFormat('fr-FR').format(number)
|
||||
} else if (format === 'percent') {
|
||||
return `${number}%`
|
||||
} else if (format === 'percent_space') {
|
||||
return `${String(number).replace('.', ',')} %`
|
||||
} else {
|
||||
return number
|
||||
}
|
||||
|
||||
@@ -25,6 +25,10 @@ module NumberUtils
|
||||
ApplicationController.helpers.number_to_currency(number, locale:, precision: 2, unit: CURRENCY_SYMBOLS[format])
|
||||
elsif locale
|
||||
ApplicationController.helpers.number_with_delimiter(number, locale:)
|
||||
elsif format == 'percent'
|
||||
"#{number}%"
|
||||
elsif format == 'percent_space'
|
||||
"#{number.to_s.tr('.', ',')} %"
|
||||
else
|
||||
number
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user