Fix: allow 0 in monetary field (#6658)

This commit is contained in:
shamoon 2024-05-09 10:43:27 -07:00 committed by GitHub
parent 9b3a29cddd
commit 22c8d8ef2a
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 15 additions and 2 deletions

View File

@ -74,4 +74,13 @@ describe('MonetaryComponent', () => {
expect(component.currency).toEqual('USD')
expect(component.monetaryValue).toEqual('')
})
it('should handle zero values', () => {
component.writeValue('USD0.00')
expect(component.currency).toEqual('USD')
expect(component.monetaryValue).toEqual('0.00')
component.monetaryValue = '0'
component.monetaryValueChange()
expect(component.value).toEqual('USD0.00')
})
})

View File

@ -22,8 +22,9 @@ export class MonetaryComponent extends AbstractInputComponent<string> {
public get monetaryValue(): string {
return this._monetaryValue
}
public set monetaryValue(value: string) {
if (value) this._monetaryValue = value
public set monetaryValue(value: any) {
if (value || value?.toString() === '0')
this._monetaryValue = value.toString()
}
defaultCurrencyCode: string
@ -44,6 +45,9 @@ export class MonetaryComponent extends AbstractInputComponent<string> {
public monetaryValueChange(fixed: boolean = false): void {
this.monetaryValue = this.parseMonetaryValue(this.monetaryValue, fixed)
if (this.monetaryValue === '0') {
this.monetaryValue = '0.00'
}
this.onChange(this.currency + this.monetaryValue)
}