Feature/improve currency code validation (#4598)

* Improve currency code validation

* Update changelog
This commit is contained in:
Thomas Kaul
2025-04-25 08:24:16 +02:00
committed by GitHub
parent 447fe1806f
commit 3b59d7989a
2 changed files with 18 additions and 8 deletions

View File

@ -7,6 +7,11 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
## Unreleased ## Unreleased
### Changed
- Improved the error message of the currency code validation
- Tightened the currency code validation by requiring uppercase letters
### Fixed ### Fixed
- Improved the file selector of the activities import functionality to accept case-insensitive file extensions (`.CSV` and `.JSON`) - Improved the file selector of the activities import functionality to accept case-insensitive file extensions (`.CSV` and `.JSON`)

View File

@ -25,19 +25,24 @@ export class IsExtendedCurrencyConstraint
implements ValidatorConstraintInterface implements ValidatorConstraintInterface
{ {
public defaultMessage() { public defaultMessage() {
return '$value must be a valid ISO4217 currency code'; return '$property must be a valid ISO4217 currency code';
} }
public validate(currency: any) { public validate(currency: any) {
// Return true if currency is a standard ISO 4217 code or a derived currency // Return true if currency is a standard ISO 4217 code or a derived currency
return ( return (
isISO4217CurrencyCode(currency) || this.isUpperCase(currency) &&
[ (isISO4217CurrencyCode(currency) ||
...DERIVED_CURRENCIES.map((derivedCurrency) => { [
return derivedCurrency.currency; ...DERIVED_CURRENCIES.map((derivedCurrency) => {
}), return derivedCurrency.currency;
'USX' }),
].includes(currency) 'USX'
].includes(currency))
); );
} }
private isUpperCase(aString: string) {
return aString === aString?.toUpperCase();
}
} }