@seniorsistemas/angular-components 19.1.0 → 19.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bignumber-input/lib/bignumber-input/bignumber-input.directive.d.ts +58 -25
- package/dynamic-form/dynamic-form/components/lookup/lookup.component.d.ts +8 -8
- package/esm2022/bignumber-input/lib/bignumber-input/bignumber-input.directive.mjs +140 -99
- package/esm2022/dynamic-form/dynamic-form/components/lookup/lookup.component.mjs +12 -12
- package/esm2022/dynamic-form/dynamic-form/form-field/fields/bignumber/bignumber-field.component.mjs +3 -3
- package/esm2022/dynamic-form/dynamic-form/form-field/fields/currency/currency-field.component.mjs +3 -3
- package/esm2022/dynamic-form/dynamic-form/form-field/fields/number/number-field.component.mjs +3 -3
- package/esm2022/inline-edit/lib/inline-edit/components/fields/inline-edit-number/inline-edit-number.component.mjs +1 -1
- package/esm2022/inline-edit/lib/inline-edit/fields/inline-edit-number-field.mjs +2 -3
- package/esm2022/locale/lib/locale/apply-localized-mask.mjs +19 -0
- package/esm2022/locale/lib/locale/pipes/localized-bignumber-impure.pipe.mjs +1 -1
- package/esm2022/locale/lib/locale/pipes/localized-bignumber.pipe.mjs +5 -4
- package/esm2022/locale/public-api.mjs +2 -1
- package/esm2022/number-input/lib/number-input/number-input.directive.mjs +12 -148
- package/esm2022/number-input/lib/number-input/number-input.module.mjs +5 -5
- package/esm2022/numeric-mask/lib/numeric-mask/numeric-mask.directive.mjs +32 -35
- package/esm2022/table/lib/table/table-column/table-columns.component.mjs +20 -4
- package/esm2022/table/public-api.mjs +2 -1
- package/fesm2022/seniorsistemas-angular-components-bignumber-input.mjs +139 -98
- package/fesm2022/seniorsistemas-angular-components-bignumber-input.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-dynamic-form.mjs +19 -19
- package/fesm2022/seniorsistemas-angular-components-dynamic-form.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-inline-edit.mjs +2 -3
- package/fesm2022/seniorsistemas-angular-components-inline-edit.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-locale.mjs +22 -4
- package/fesm2022/seniorsistemas-angular-components-locale.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-number-input.mjs +14 -151
- package/fesm2022/seniorsistemas-angular-components-number-input.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-numeric-mask.mjs +31 -34
- package/fesm2022/seniorsistemas-angular-components-numeric-mask.mjs.map +1 -1
- package/fesm2022/seniorsistemas-angular-components-table.mjs +21 -6
- package/fesm2022/seniorsistemas-angular-components-table.mjs.map +1 -1
- package/inline-edit/lib/inline-edit/fields/inline-edit-number-field.d.ts +2 -3
- package/locale/lib/locale/apply-localized-mask.d.ts +9 -0
- package/locale/lib/locale/pipes/localized-bignumber-impure.pipe.d.ts +2 -3
- package/locale/lib/locale/pipes/localized-bignumber.pipe.d.ts +3 -2
- package/locale/public-api.d.ts +1 -0
- package/number-input/lib/number-input/number-input.directive.d.ts +7 -47
- package/number-input/lib/number-input/number-input.module.d.ts +2 -2
- package/numeric-mask/lib/numeric-mask/numeric-mask.directive.d.ts +8 -9
- package/package.json +1 -1
- package/table/public-api.d.ts +1 -0
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Component, Inject, Input, ViewChild, } from '@angular/core';
|
|
2
2
|
import { HostProjectConfigsInjectionToken } from '@seniorsistemas/angular-components/common';
|
|
3
|
+
import { applyLocalizedMask, } from '@seniorsistemas/angular-components/locale';
|
|
3
4
|
import { deepClone, isNullOrUndefined } from '@seniorsistemas/angular-components/utils';
|
|
4
|
-
import { applyMask } from '@seniorsistemas/ng2-currency-mask';
|
|
5
5
|
import BigNumber from 'bignumber.js';
|
|
6
6
|
import moment from 'moment';
|
|
7
7
|
import { convertToMomentDateFormat } from '../../locale-utils';
|
|
@@ -187,7 +187,15 @@ export class TableColumnsComponent {
|
|
|
187
187
|
? this.numericService.instant(attributeValue, {
|
|
188
188
|
numberFormatOptions,
|
|
189
189
|
})
|
|
190
|
-
:
|
|
190
|
+
: applyLocalizedMask(attributeValue, {
|
|
191
|
+
decimalSeparator: '.',
|
|
192
|
+
thousandsSeparator: ',',
|
|
193
|
+
scale: 2,
|
|
194
|
+
prefix: '',
|
|
195
|
+
suffix: '',
|
|
196
|
+
allowNegative: true,
|
|
197
|
+
...numberConfigs,
|
|
198
|
+
}, this.isNumber(attributeValue));
|
|
191
199
|
}
|
|
192
200
|
case EnumColumnFieldType.DATE:
|
|
193
201
|
const dateFormat = this.getDateFormat(column, locale);
|
|
@@ -208,7 +216,15 @@ export class TableColumnsComponent {
|
|
|
208
216
|
? this.numericService.instant(attributeValue, {
|
|
209
217
|
numberFormatOptions,
|
|
210
218
|
})
|
|
211
|
-
:
|
|
219
|
+
: applyLocalizedMask(attributeValue, {
|
|
220
|
+
decimalSeparator: '.',
|
|
221
|
+
thousandsSeparator: ',',
|
|
222
|
+
scale: 2,
|
|
223
|
+
prefix: '',
|
|
224
|
+
suffix: '',
|
|
225
|
+
allowNegative: true,
|
|
226
|
+
...numberConfigs,
|
|
227
|
+
}, this.isNumber(attributeValue));
|
|
212
228
|
}
|
|
213
229
|
case EnumColumnFieldType.TOKENS:
|
|
214
230
|
return this.getTokens(attributeValue);
|
|
@@ -311,4 +327,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
311
327
|
}], locale: [{
|
|
312
328
|
type: Input
|
|
313
329
|
}] } });
|
|
314
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-columns.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-components/table/src/lib/table/table-column/table-columns.component.ts","../../../../../../projects/angular-components/table/src/lib/table/table-column/table-columns.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EACT,MAAM,EACN,KAAK,EAIL,SAAS,GAEZ,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAsB,gCAAgC,EAAE,MAAM,2CAA2C,CAAC;AAIjH,OAAO,EAAE,SAAS,EAAE,iBAAiB,EAAE,MAAM,0CAA0C,CAAC;AACxF,OAAO,EAAc,SAAS,EAAE,MAAM,mCAAmC,CAAC;AAC1E,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,yBAAyB,EAAE,MAAM,oBAAoB,CAAC;AAC/D,OAAO,EAAwB,mBAAmB,EAA4B,MAAM,UAAU,CAAC;;;;;;;;;;AAE/F;;;;;;;;;;;GAWG;AAMH,MAAM,OAAO,qBAAqB;IAqBT;IACA;IACA;IACA;IAC0C;IAvBxD,eAAe,GAA4B,IAAI,CAAC;IAEvD,wFAAwF;IAEjF,OAAO,GAAa,EAAE,CAAC;IAE9B,mGAAmG;IAE5F,QAAQ,CAAO;IAEtB,qGAAqG;IAE9F,MAAM,GAAoC,IAAI,CAAC;IAEtD,SAAS,GAAwB,EAAE,CAAC;IAEpC,gBAAgB,GAAmB,EAAE,CAAC;IAEtC,YACqB,aAA4B,EAC5B,gBAAkC,EAClC,SAA2B,EAC3B,cAA8B,EACY,kBAAsC;QAJhF,kBAAa,GAAb,aAAa,CAAe;QAC5B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,cAAS,GAAT,SAAS,CAAkB;QAC3B,mBAAc,GAAd,cAAc,CAAgB;QACY,uBAAkB,GAAlB,kBAAkB,CAAoB;QAEjG,IAAI,CAAC,MAAM,GAAG;YACV,QAAQ,EAAE;gBACN,GAAG,IAAI,CAAC,aAAa,CAAC,gBAAgB,EAAE,EAAE,QAAQ;gBAClD,UAAU,EAAE,yBAAyB,CAAC,IAAI,CAAC,aAAa,CAAC,gBAAgB,EAAE,EAAE,QAAQ,CAAC,UAAU,IAAI,EAAE,CAAC;aAC1G;YACD,MAAM,EAAE;gBACJ,GAAG,IAAI,CAAC,aAAa,CAAC,gBAAgB,EAAE,EAAE,MAAM;gBAChD,KAAK,EAAE,CAAC;aACX;SACJ,CAAC;IACN,CAAC;IAED,WAAW,CAAC,OAAsB;QAC9B,IAAI,CAAC,2BAA2B,CAAC,OAAO,CAAC,CAAC;QAE1C,IAAI,OAAO,CAAC,SAAS,CAAC,IAAI,OAAO,CAAC,SAAS,CAAC,CAAC,YAAY,KAAK,OAAO,CAAC,SAAS,CAAC,CAAC,aAAa,EAAE,CAAC;YAC7F,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,YAAY,CAAC,CAAC;QAC/E,CAAC;QACD,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;IAEM,OAAO,CAAC,KAAU;QACrB,OAAO,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAEM,iBAAiB,CAAC,MAAoB;QACzC,OAAO,MAAM,CAAC,WAAuB,CAAC;IAC1C,CAAC;IAEO,WAAW,CAAC,MAAoB;QACpC,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,GAAG,MAAM,CAAC;QAEtD,IAAI,OAAO,WAAW,KAAK,QAAQ,EAAE,CAAC;YAClC,MAAM,cAAc,GAAG,WAAW,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YAEpD,OAAO,cAAc,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;gBACxC,MAAM,WAAW,GAAG,cAAc,CAAC,MAAM,GAAG,CAAC,KAAK,KAAK,CAAC;gBAExD,OAAO;oBACH,KAAK,EAAE,MAAM;oBACb,YAAY,EAAE,MAAM,KAAK,UAAU;oBACnC,SAAS,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI;iBAC7C,CAAC;YACN,CAAC,CAAC,CAAC;QACP,CAAC;QAED,OAAO,IAAI,CAAC;IAChB,CAAC;IAEO,2BAA2B,CAAC,OAAsB;QACtD,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,YAAY,EAAE,CAAC;YACrD,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;QACjE,CAAC;QACD,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,YAAY,EAAE,CAAC;YACvD,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC,CAAC;QAClE,CAAC;IACL,CAAC;IAEO,qBAAqB,CAAC,OAAsB;QAChD,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;QAE9B,MAAM,OAAO,GAAa,OAAO,CAAC,SAAS,CAAC,EAAE,YAAY,IAAI,IAAI,CAAC,OAAO,CAAC;QAE3E,MAAM,QAAQ,GAAW,SAAS,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,YAAY,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC;QAEvF,MAAM,MAAM,GAA6B,OAAO,CAAC,QAAQ,CAAC,EAAE,YAAY,IAAI,IAAI,CAAC,MAAM,CAAC;QAExF,IAAI,CAAC,gBAAgB,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC,CAAC;QAE/F,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC;QAEjF,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE,CAAC;YAC3C,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QACnE,CAAC;IACL,CAAC;IAEO,kBAAkB,CAAC,MAAc;QACrC,OAAO,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC;IACvD,CAAC;IAEO,oBAAoB,CAAC,MAAc;QACvC,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,kBAAkB,CAAC,MAAM,IAAI,IAAI,CAAC,kBAAkB,CAAC,OAAO,GAAG,CAAC;IACnH,CAAC;IAEO,uBAAuB,CAAC,cAAmB;QAC/C,OAAO,CACH,cAAc,KAAK,IAAI;YACvB,cAAc,KAAK,SAAS;YAC5B,CAAC,cAAc,EAAE,OAAO,EAAE,mBAAmB,IAAI,iBAAiB,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;YAC1F,CAAC,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC;YACxD,CAAC,OAAO,cAAc,KAAK,QAAQ,IAAI,cAAc,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CACvE,CAAC;IACN,CAAC;IAEO,uBAAuB,CAC3B,MAAc,EACd,WAAkB,EAClB,mBAA2B,EAC3B,cAAsB,EACtB,gBAAwB;QAExB,IAAI,gBAAgB,KAAK,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,CAAC;YAChD,OAAO,cAAc,CAAC;QAC1B,CAAC;QAED,IAAI,MAAM,CAAC,IAAI,KAAK,mBAAmB,CAAC,MAAM,EAAE,CAAC;YAC7C,OAAO,EAAE,CAAC,MAAM,CAAC,KAAK,CAClB,EAAE,EACF,WAAW,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,KAAK,cAAc,CAAC,CAC5D,CAAC;QACN,CAAC;QAED,OAAO,mBAAmB,CAAC;IAC/B,CAAC;IAEO,iBAAiB,CAAC,SAAiB,EAAE,QAAa;QACtD,IAAI,cAAoB,CAAC;QAEzB,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,KAAa,EAAE,EAAE;YAC3C,IAAI,CAAC,cAAc,EAAE,CAAC;gBAClB,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,GAAW,EAAE,CAAC,EAAE,EAAE;oBACxC,IAAI,CAAC,QAAQ,EAAE,CAAC;wBACZ,OAAO;oBACX,CAAC;oBAED,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;wBACV,cAAc,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC;oBACnC,CAAC;yBAAM,CAAC;wBACJ,IAAI,cAAc,EAAE,CAAC;4BACjB,cAAc,GAAG,cAAc,CAAC,GAAG,CAAC,CAAC;wBACzC,CAAC;oBACL,CAAC;gBACL,CAAC,CAAC,CAAC;YACP,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,OAAO,cAAc,CAAC;IAC1B,CAAC;IAEO,gBAAgB,CAAC,MAAc;QACnC,OAAO;YACH,GAAG,IAAI,CAAC,MAAM,EAAE,MAAM;YACtB,KAAK,EACD,MAAM,CAAC,KAAK,KAAK,IAAI,IAAI,MAAM,CAAC,KAAK,KAAK,SAAS;gBAC/C,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,CAAC;gBACnC,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,KAAK;YACnC,MAAM,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,cAAc,GAAG;SACnD,CAAC;IACN,CAAC;IAEO,aAAa,CAAC,MAAc,EAAE,MAAgC;QAClE,OAAO,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC;IAC9E,CAAC;IAEO,cAAc,CAAC,MAAc,EAAE,QAAa,EAAE,MAAgC;QAClF,MAAM,MAAM,GAAG,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;QACjD,MAAM,SAAS,GAAG,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;QAClD,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,GAAG,aAAa,CAAC,CAAC;QAClE,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;QAE3B,MAAM,WAAW,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,SAAmC,EAAE,EAAE;YAC9E,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAAC,SAAmB,EAAE,QAAQ,CAAC,CAAC;YAE7E,IAAI,IAAI,CAAC,uBAAuB,CAAC,cAAc,CAAC,EAAE,CAAC;gBAC/C,OAAO,UAAU,CAAC;YACtB,CAAC;YAED,MAAM,aAAa,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;YAEpD,QAAQ,MAAM,CAAC,IAAI,EAAE,CAAC;gBAClB,KAAK,mBAAmB,CAAC,IAAI;oBACzB,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,UAAU,GAAG,cAAc,CAAC,QAAQ,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;gBAE/F,KAAK,mBAAmB,CAAC,QAAQ,CAAC,CAAC,CAAC;oBAChC,MAAM,mBAAmB,GAAG,cAAc,EAAE,OAAO,EAAE,mBAAmB;wBACpE,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,mBAAmB;wBAC5C,CAAC,CAAC,OAAO,MAAM,CAAC,mBAAmB,KAAK,UAAU;4BAChD,CAAC,CAAC,MAAM,CAAC,mBAAmB,CAAC;gCACvB,OAAO,EAAE,QAAQ;6BACpB,CAAC;4BACJ,CAAC,CAAC,MAAM,CAAC,mBAAmB,CAAC;oBAEnC,OAAO,mBAAmB;wBACtB,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,cAAc,EAAE;4BACxC,mBAAmB;yBACtB,CAAC;wBACJ,CAAC,CAAC,SAAS,CAAC,cAAc,EAAE,aAAa,EAAE,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC,CAAC;gBAClF,CAAC;gBAED,KAAK,mBAAmB,CAAC,IAAI;oBACzB,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;oBACtD,OAAO,MAAM,CAAC,cAAc,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;gBAErD,KAAK,mBAAmB,CAAC,OAAO;oBAC5B,MAAM,KAAK,GAAG,cAAc,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;oBAC5C,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC;gBAElD,KAAK,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC;oBAC9B,aAAa,CAAC,MAAM,GAAG,EAAE,CAAC;oBAE1B,MAAM,mBAAmB,GAAG,cAAc,EAAE,OAAO,EAAE,mBAAmB;wBACpE,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,mBAAmB;wBAC5C,CAAC,CAAC,OAAO,MAAM,CAAC,mBAAmB,KAAK,UAAU;4BAChD,CAAC,CAAC,MAAM,CAAC,mBAAmB,CAAC;gCACvB,OAAO,EAAE,QAAQ;6BACpB,CAAC;4BACJ,CAAC,CAAC,MAAM,CAAC,mBAAmB,CAAC;oBAEnC,OAAO,mBAAmB;wBACtB,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,cAAc,EAAE;4BACxC,mBAAmB;yBACtB,CAAC;wBACJ,CAAC,CAAC,SAAS,CAAC,cAAc,EAAE,aAAa,EAAE,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC,CAAC;gBAClF,CAAC;gBACD,KAAK,mBAAmB,CAAC,MAAM;oBAC3B,OAAO,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;gBAE1C;oBACI,OAAO,cAAc,CAAC;YAC9B,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,MAAM,mBAAmB,GAAG,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACxD,MAAM,gBAAgB,GAAG,mBAAmB,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,KAAK,UAAU,CAAC,CAAC,MAAM,CAAC;QAC7G,MAAM,oBAAoB,GAAG,IAAI,CAAC,uBAAuB,CACrD,MAAM,EACN,WAAW,EACX,mBAAmB,EACnB,UAAU,EACV,gBAAgB,CACnB,CAAC;QAEF,OAAO;YACH,KAAK;YACL,WAAW,EAAE,oBAAoB;YACjC,SAAS;YACT,UAAU;YACV,YAAY,EAAE,MAAM,EAAE,YAAY,EAAE,IAAI,CACpC,CAAC,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,SAAS,KAAK,QAAQ,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,KAAK,CAAC,CAC5F;YACD,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC;YAC/B,IAAI,EAAE,MAAM,CAAC,IAAI;YACjB,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,OAAO,CAAC;YAC9C,QAAQ,EAAE,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,QAAQ,CAAC;YACjD,WAAW,EAAE,MAAM,CAAC,WAAW;YAC/B,aAAa,EAAE,MAAM,CAAC,aAAa;YACnC,OAAO,EAAE,MAAM,CAAC,OAAO;SAC1B,CAAC;IACN,CAAC;IAEO,cAAc,CAAC,KAA2C;QAC9D,IAAI,OAAO,KAAK,KAAK,UAAU,EAAE,CAAC;YAC9B,OAAO,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;QAC3C,CAAC;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;IAEO,iBAAiB,CAAC,QAAsD;QAC5E,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC/B,IAAI,OAAO,QAAQ,KAAK,UAAU,EAAE,CAAC;gBACjC,OAAO,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;YAC9C,CAAC;YACD,OAAO,QAAQ,CAAC;QACpB,CAAC;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAEO,gBAAgB,CAAC,OAA8C;QACnE,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,EAAE,CAAC;YAC9B,IAAI,OAAO,OAAO,KAAK,UAAU,EAAE,CAAC;gBAChC,OAAO,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;YAC7C,CAAC;YACD,OAAO,OAAO,CAAC;QACnB,CAAC;QACD,OAAO,EAAE,CAAC;IACd,CAAC;IAEO,QAAQ,CAAC,KAAU;QACvB,OAAO,CAAC,IAAI,SAAS,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,CAAC;IACzC,CAAC;IAEO,SAAS,CAAC,MAAW;QACzB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YACxB,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;QAC/D,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAE,CAAC;YAClC,MAAM,IAAI,KAAK,CACX,oGAAoG,CACvG,CAAC;QACN,CAAC;QAED,IAAI,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,EAAE,CAAC;YAClC,OAAO,MAAM,CAAC;QAClB,CAAC;QAED,OAAO,MAAM;aACR,MAAM,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,CAAC;aAC7D,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE;YAChB,MAAM,KAAK,GAAG,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,GAAG,KAAK,EAAE,CAAC;YACxE,OAAO;gBACH,KAAK;aACR,CAAC;QACN,CAAC,CAAC,CAAC;IACX,CAAC;IAEO,iBAAiB,CAAC,MAAa;QACnC,OAAO,IAAI,CAAC,sBAAsB,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;IAClF,CAAC;IAEO,sBAAsB,CAAC,MAAa;QACxC,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,KAAK,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,CAAC;IACtF,CAAC;IAEO,kBAAkB,CAAC,MAAa;QACpC,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,IAAI,KAAK,EAAE,KAAK,KAAK,SAAS,CAAC,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,CAAC;IAClH,CAAC;IAEO,qBAAqB,CAAC,OAAiB;QAC3C,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,CAAC,CAAC;IACzE,CAAC;wGA3VQ,qBAAqB,6IAyBlB,gCAAgC;4FAzBnC,qBAAqB,sRCxClC,6uHA+EA;;4FDvCa,qBAAqB;kBALjC,SAAS;+BAGI,iBAAiB;;0BA2BtB,MAAM;2BAAC,gCAAgC;yCAvBrC,eAAe;sBADrB,SAAS;uBAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAKvC,OAAO;sBADb,KAAK;gBAKC,QAAQ;sBADd,KAAK;gBAKC,MAAM;sBADZ,KAAK","sourcesContent":["import {\n    Component,\n    Inject,\n    Input,\n    OnChanges,\n    SimpleChanges,\n    TemplateRef,\n    ViewChild,\n    ViewContainerRef,\n} from '@angular/core';\n\nimport { TranslateService } from '@ngx-translate/core';\nimport { HostProjectConfigs, HostProjectConfigsInjectionToken } from '@seniorsistemas/angular-components/common';\nimport { LocaleService } from '@seniorsistemas/angular-components/locale';\nimport { NumericService } from '@seniorsistemas/angular-components/numeric';\nimport { IToken } from '@seniorsistemas/angular-components/token-list';\nimport { deepClone, isNullOrUndefined } from '@seniorsistemas/angular-components/utils';\nimport { MaskConfig, applyMask } from '@seniorsistemas/ng2-currency-mask';\nimport BigNumber from 'bignumber.js';\nimport moment from 'moment';\nimport { convertToMomentDateFormat } from '../../locale-utils';\nimport { Column, ColumnValues, EnumColumnFieldType, TableColumnLocaleOptions } from './models';\n\n/**\n * @description Componente interno que renderiza uma linha de colunas da tabela,\n * aplicando formatação localizada (data, número, moeda, token, etc.) para cada coluna.\n * Normalmente usado dentro do contexto de uma tabela PrimeNG.\n *\n * @example\n * ```html\n * <s-table-columns [columns]=\"colunas\" [rowValue]=\"linha\" />\n * ```\n *\n * @category Data\n */\n@Component({\n    templateUrl: './table-columns.component.html',\n    styleUrls: ['./table-columns.component.scss'],\n    selector: 's-table-columns',\n})\nexport class TableColumnsComponent implements OnChanges {\n    @ViewChild('columnsTemplate', { static: true })\n    public columnsTemplate: TemplateRef<any> | null = null;\n\n    /** @description Lista de configurações das colunas a serem renderizadas. @default [] */\n    @Input()\n    public columns: Column[] = [];\n\n    /** @description Objeto da linha com os valores a serem exibidos nas colunas. Campo obrigatório. */\n    @Input()\n    public rowValue!: any;\n\n    /** @description Opções de localização (calendário e número) usadas para formatação. @default null */\n    @Input()\n    public locale: TableColumnLocaleOptions | null = null;\n\n    cellsData: (CellData | null)[] = [];\n\n    formattedColumns: ColumnValues[] = [];\n\n    constructor(\n        private readonly localeService: LocaleService,\n        private readonly viewContainerRef: ViewContainerRef,\n        private readonly translate: TranslateService,\n        private readonly numericService: NumericService,\n        @Inject(HostProjectConfigsInjectionToken) private readonly hostProjectConfigs: HostProjectConfigs,\n    ) {\n        this.locale = {\n            calendar: {\n                ...this.localeService.getLocaleOptions()?.calendar,\n                dateFormat: convertToMomentDateFormat(this.localeService.getLocaleOptions()?.calendar.dateFormat ?? ''),\n            },\n            number: {\n                ...this.localeService.getLocaleOptions()?.number,\n                scale: 0,\n            },\n        };\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        this.validateComponentAttributes(changes);\n\n        if (changes['columns'] && changes['columns'].currentValue !== changes['columns'].previousValue) {\n            this.columns = this.sortColumnsBySequence(changes['columns'].currentValue);\n        }\n        this.createColumnsTemplate(changes);\n    }\n\n    public isArray(value: any): boolean {\n        return Array.isArray(value);\n    }\n\n    public getTokensByColumn(column: ColumnValues) {\n        return column.columnValue as IToken[];\n    }\n\n    private getCellData(column: ColumnValues): CellData | null {\n        const { columnValue, separator, uninformed } = column;\n\n        if (typeof columnValue === 'string') {\n            const splittedString = columnValue.split(separator);\n\n            return splittedString.map((string, index) => {\n                const isLastIndex = splittedString.length - 1 === index;\n\n                return {\n                    value: string,\n                    isUninformed: string === uninformed,\n                    separator: !isLastIndex ? separator : null,\n                };\n            });\n        }\n\n        return null;\n    }\n\n    private validateComponentAttributes(changes: SimpleChanges): void {\n        if (!this.columns && !changes['columns']?.currentValue) {\n            throw new Error(\"The 'columns' attribute must be informed!\");\n        }\n        if (!this.rowValue && !changes['rowValue']?.currentValue) {\n            throw new Error(\"The 'rowValue' attribute must be informed!\");\n        }\n    }\n\n    private createColumnsTemplate(changes: SimpleChanges): void {\n        this.viewContainerRef.clear();\n\n        const columns: Column[] = changes['columns']?.currentValue || this.columns;\n\n        const rowValue: object = deepClone(changes['rowValue']?.currentValue ?? this.rowValue);\n\n        const locale: TableColumnLocaleOptions = changes['locale']?.currentValue || this.locale;\n\n        this.formattedColumns = columns.map((column) => this.getColumnValue(column, rowValue, locale));\n\n        this.cellsData = this.formattedColumns.map((column) => this.getCellData(column));\n\n        if (!isNullOrUndefined(this.columnsTemplate)) {\n            this.viewContainerRef.createEmbeddedView(this.columnsTemplate);\n        }\n    }\n\n    private getColumnSeparator(column: Column) {\n        return column.separator ? column.separator : ' - ';\n    }\n\n    private getTranslationPrefix(column: Column) {\n        return column.prefix ? column.prefix : `${this.hostProjectConfigs.domain}.${this.hostProjectConfigs.service}.`;\n    }\n\n    private isAttributeValueInvalid(attributeValue: any) {\n        return (\n            attributeValue === null ||\n            attributeValue === undefined ||\n            (attributeValue?.options?.numberFormatOptions && isNullOrUndefined(attributeValue?.value)) ||\n            (this.isArray(attributeValue) && !attributeValue.length) ||\n            (typeof attributeValue === 'string' && attributeValue.trim() === '')\n        );\n    }\n\n    private getFormattedColumnValue(\n        column: Column,\n        columnValue: any[],\n        unifiedColumnValues: string,\n        uninformedText: string,\n        uninformedNumber: number,\n    ) {\n        if (uninformedNumber === column.attributes.length) {\n            return uninformedText;\n        }\n\n        if (column.type === EnumColumnFieldType.TOKENS) {\n            return [].concat.apply(\n                [],\n                columnValue.filter((values) => values !== uninformedText),\n            );\n        }\n\n        return unifiedColumnValues;\n    }\n\n    private getAttributeValue(attribute: string, rowValue: any) {\n        let attributeValue!: any;\n\n        attribute.split('/').forEach((value: string) => {\n            if (!attributeValue) {\n                value.split('.').forEach((val: string, i) => {\n                    if (!rowValue) {\n                        return;\n                    }\n\n                    if (i === 0) {\n                        attributeValue = rowValue[val];\n                    } else {\n                        if (attributeValue) {\n                            attributeValue = attributeValue[val];\n                        }\n                    }\n                });\n            }\n        });\n\n        return attributeValue;\n    }\n\n    private getNumberConfigs(column: Column): MaskConfig {\n        return {\n            ...this.locale?.number,\n            scale:\n                column.scale !== null && column.scale !== undefined\n                    ? this.getColumnScale(column.scale)\n                    : this.locale?.number.scale,\n            prefix: `${this.locale?.number.currencySymbol} `,\n        };\n    }\n\n    private getDateFormat(column: Column, locale: TableColumnLocaleOptions) {\n        return column.dateFormat ? column.dateFormat : locale.calendar.dateFormat;\n    }\n\n    private getColumnValue(column: Column, rowValue: any, locale: TableColumnLocaleOptions): ColumnValues {\n        const prefix = this.getTranslationPrefix(column);\n        const separator = this.getColumnSeparator(column);\n        const uninformed = this.translate.instant(prefix + 'empty_label');\n        const style = column.style;\n\n        const columnValue = column.attributes.map((attribute: string | number | symbol) => {\n            const attributeValue = this.getAttributeValue(attribute as string, rowValue);\n\n            if (this.isAttributeValueInvalid(attributeValue)) {\n                return uninformed;\n            }\n\n            const numberConfigs = this.getNumberConfigs(column);\n\n            switch (column.type) {\n                case EnumColumnFieldType.ENUM:\n                    return this.translate.instant(column.enumPrefix + attributeValue.toString().toLowerCase());\n\n                case EnumColumnFieldType.CURRENCY: {\n                    const numberFormatOptions = attributeValue?.options?.numberFormatOptions\n                        ? attributeValue.options.numberFormatOptions\n                        : typeof column.numberFormatOptions === 'function'\n                          ? column.numberFormatOptions({\n                                rowData: rowValue,\n                            })\n                          : column.numberFormatOptions;\n\n                    return numberFormatOptions\n                        ? this.numericService.instant(attributeValue, {\n                              numberFormatOptions,\n                          })\n                        : applyMask(attributeValue, numberConfigs, this.isNumber(attributeValue));\n                }\n\n                case EnumColumnFieldType.DATE:\n                    const dateFormat = this.getDateFormat(column, locale);\n                    return moment(attributeValue).format(dateFormat);\n\n                case EnumColumnFieldType.BOOLEAN:\n                    const value = attributeValue ? 'yes' : 'no';\n                    return this.translate.instant(prefix + value);\n\n                case EnumColumnFieldType.NUMBER: {\n                    numberConfigs.prefix = '';\n\n                    const numberFormatOptions = attributeValue?.options?.numberFormatOptions\n                        ? attributeValue.options.numberFormatOptions\n                        : typeof column.numberFormatOptions === 'function'\n                          ? column.numberFormatOptions({\n                                rowData: rowValue,\n                            })\n                          : column.numberFormatOptions;\n\n                    return numberFormatOptions\n                        ? this.numericService.instant(attributeValue, {\n                              numberFormatOptions,\n                          })\n                        : applyMask(attributeValue, numberConfigs, this.isNumber(attributeValue));\n                }\n                case EnumColumnFieldType.TOKENS:\n                    return this.getTokens(attributeValue);\n\n                default:\n                    return attributeValue;\n            }\n        });\n\n        const unifiedColumnValues = columnValue.join(separator);\n        const uninformedNumber = unifiedColumnValues.split(separator).filter((value) => value === uninformed).length;\n        const formattedColumnValue = this.getFormattedColumnValue(\n            column,\n            columnValue,\n            unifiedColumnValues,\n            uninformed,\n            uninformedNumber,\n        );\n\n        return {\n            style,\n            columnValue: formattedColumnValue,\n            separator,\n            uninformed,\n            badgeConfigs: column?.badgeConfigs?.find(\n                (badgeConfig) => badgeConfig.enumValue === rowValue[column.attributes[0] ?? column.field],\n            ),\n            color: column.color?.(rowValue),\n            type: column.type,\n            tooltip: this.getColumnTooltip(column.tooltip),\n            infoSign: this.getColumnInfoSign(column.infoSign),\n            onLinkClick: column.onLinkClick,\n            onColumnClick: column.onColumnClick,\n            compact: column.compact,\n        };\n    }\n\n    private getColumnScale(scale: number | ((rowValue: any) => number)): number {\n        if (typeof scale === 'function') {\n            return scale(deepClone(this.rowValue));\n        }\n        return scale;\n    }\n\n    private getColumnInfoSign(infoSign?: string | ((rowValue: any) => string | null)): string | null {\n        if (!isNullOrUndefined(infoSign)) {\n            if (typeof infoSign === 'function') {\n                return infoSign(deepClone(this.rowValue));\n            }\n            return infoSign;\n        }\n        return null;\n    }\n\n    private getColumnTooltip(tooltip?: string | ((rowValue: any) => string)): string {\n        if (!isNullOrUndefined(tooltip)) {\n            if (typeof tooltip === 'function') {\n                return tooltip(deepClone(this.rowValue));\n            }\n            return tooltip;\n        }\n        return '';\n    }\n\n    private isNumber(value: any): boolean {\n        return !new BigNumber(value).isNaN();\n    }\n\n    private getTokens(values: any): IToken[] {\n        if (!this.isArray(values)) {\n            throw new Error('To use tokens an array must be informed');\n        }\n\n        if (!this.isValidTokenArray(values)) {\n            throw new Error(\n                'Not a valid token array. Must be a primitive values array or an objects with label attribute array',\n            );\n        }\n\n        if (this.isLabelObjectArray(values)) {\n            return values;\n        }\n\n        return values\n            .filter((value: any) => value !== undefined && value !== null)\n            .map((value: any) => {\n                const label = typeof value === 'symbol' ? value.toString() : `${value}`;\n                return {\n                    label,\n                };\n            });\n    }\n\n    private isValidTokenArray(values: any[]): boolean {\n        return this.isPrimitiveValuesArray(values) || this.isLabelObjectArray(values);\n    }\n\n    private isPrimitiveValuesArray(values: any[]): boolean {\n        return values.filter((value) => value !== Object(value)).length === values.length;\n    }\n\n    private isLabelObjectArray(values: any[]): boolean {\n        return values.filter((value) => value?.label !== null && value?.label !== undefined).length === values.length;\n    }\n\n    private sortColumnsBySequence(columns: Column[]): Column[] {\n        return columns.sort((a, b) => (a.sequence ?? 0) - (b.sequence ?? 0));\n    }\n}\n\ntype CellData = { value: string; isUninformed: boolean; separator: string | null }[];\n\n","<ng-template #columnsTemplate>\n    @for (column of formattedColumns; track $index; let i = $index) {\n        <td\n            [ngStyle]=\"column.style\"\n            (click)=\"column.onColumnClick ? column.onColumnClick(rowValue) : null\"\n        >\n            @if (column.type !== 'TOKENS' || !isArray(column.columnValue)) {\n                <div [ngClass]=\"{ 'compact-column': column.compact }\">\n                    @if (column.type !== 'LINK') {\n                        <span\n                            [sTooltip]=\"column.tooltip\"\n                            [escape]=\"false\"\n                        >\n                            <ng-container *ngTemplateOutlet=\"columnValueTemplate\"></ng-container>\n                        </span>\n                    }\n\n                    @if (column.type === 'LINK') {\n                        @if (cellsData[i]?.[0]?.isUninformed) {\n                            <span class=\"sds-empty-value\">{{ cellsData[i]?.[0]?.value }}</span>\n                        } @else {\n                            <ng-template #anchorTemplate>\n                                <a\n                                    [sTooltip]=\"column.tooltip\"\n                                    [escape]=\"false\"\n                                    (click)=\"column.onLinkClick ? column.onLinkClick(rowValue) : null\"\n                                >\n                                    <ng-container *ngTemplateOutlet=\"columnValueTemplate\"></ng-container>\n                                </a>\n                            </ng-template>\n                        }\n                    }\n\n                    <ng-template #columnValueTemplate>\n                        @for (cellData of cellsData[i]; track $index) {\n                            @if (cellData.isUninformed) {\n                                <span class=\"sds-empty-value\">{{ cellData.value }}</span>\n                            } @else {\n                                @if (column.badgeConfigs) {\n                                    <s-badge\n                                        [sTooltip]=\"column.tooltip\"\n                                        [color]=\"column.badgeConfigs.color\"\n                                        [text]=\"cellData.value\"\n                                    ></s-badge>\n                                } @else {\n                                    <span [ngClass]=\"{\n                                        'column-cell-red': column.color === 'Red',\n                                        'column-cell-orange': column.color === 'Orange',\n                                        'column-cell-yellow': column.color === 'Yellow',\n                                        'column-cell-green': column.color === 'Green',\n                                        'column-cell-blue': column.color === 'Blue'\n                                    }\"\n                                    >{{ cellData.value }}</span>\n                                }\n                            }\n\n                            @if (cellData.separator) {\n                                <span>{{ cellData.separator }}</span>\n                            }\n                        }\n\n                        @if (!!column.infoSign) {\n                            <span *sInfoSign=\"column.infoSign\"></span>\n                        }\n                    </ng-template>\n                </div>\n            } @else {\n                <s-token-list\n                    [tokens]=\"getTokensByColumn(column)\"\n                    [hidePointerEvents]=\"true\"\n                ></s-token-list>\n\n                @if (!!column.infoSign) {\n                    <span *sInfoSign=\"column.infoSign\"></span>\n                }\n            }\n        </td>\n    }\n</ng-template>\n"]}
|
|
330
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-columns.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-components/table/src/lib/table/table-column/table-columns.component.ts","../../../../../../projects/angular-components/table/src/lib/table/table-column/table-columns.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Inject,\n    Input,\n    OnChanges,\n    SimpleChanges,\n    TemplateRef,\n    ViewChild,\n    ViewContainerRef,\n} from '@angular/core';\n\nimport { TranslateService } from '@ngx-translate/core';\nimport { HostProjectConfigs, HostProjectConfigsInjectionToken } from '@seniorsistemas/angular-components/common';\nimport {\n    applyLocalizedMask,\n    LocaleService,\n    LocalizedBignumberOptions,\n} from '@seniorsistemas/angular-components/locale';\nimport { NumericService } from '@seniorsistemas/angular-components/numeric';\nimport { IToken } from '@seniorsistemas/angular-components/token-list';\nimport { deepClone, isNullOrUndefined } from '@seniorsistemas/angular-components/utils';\nimport BigNumber from 'bignumber.js';\nimport moment from 'moment';\n\nimport { convertToMomentDateFormat } from '../../locale-utils';\nimport { Column, ColumnValues, EnumColumnFieldType, TableColumnLocaleOptions } from './models';\n\n/**\n * @description Componente interno que renderiza uma linha de colunas da tabela,\n * aplicando formatação localizada (data, número, moeda, token, etc.) para cada coluna.\n * Normalmente usado dentro do contexto de uma tabela PrimeNG.\n *\n * @example\n * ```html\n * <s-table-columns [columns]=\"colunas\" [rowValue]=\"linha\" />\n * ```\n *\n * @category Data\n */\n@Component({\n    templateUrl: './table-columns.component.html',\n    styleUrls: ['./table-columns.component.scss'],\n    selector: 's-table-columns',\n})\nexport class TableColumnsComponent implements OnChanges {\n    @ViewChild('columnsTemplate', { static: true })\n    public columnsTemplate: TemplateRef<any> | null = null;\n\n    /** @description Lista de configurações das colunas a serem renderizadas. @default [] */\n    @Input()\n    public columns: Column[] = [];\n\n    /** @description Objeto da linha com os valores a serem exibidos nas colunas. Campo obrigatório. */\n    @Input()\n    public rowValue!: any;\n\n    /** @description Opções de localização (calendário e número) usadas para formatação. @default null */\n    @Input()\n    public locale: TableColumnLocaleOptions | null = null;\n\n    cellsData: (CellData | null)[] = [];\n\n    formattedColumns: ColumnValues[] = [];\n\n    constructor(\n        private readonly localeService: LocaleService,\n        private readonly viewContainerRef: ViewContainerRef,\n        private readonly translate: TranslateService,\n        private readonly numericService: NumericService,\n        @Inject(HostProjectConfigsInjectionToken) private readonly hostProjectConfigs: HostProjectConfigs,\n    ) {\n        this.locale = {\n            calendar: {\n                ...this.localeService.getLocaleOptions()?.calendar,\n                dateFormat: convertToMomentDateFormat(this.localeService.getLocaleOptions()?.calendar.dateFormat ?? ''),\n            },\n            number: {\n                ...this.localeService.getLocaleOptions()?.number,\n                scale: 0,\n            },\n        };\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        this.validateComponentAttributes(changes);\n\n        if (changes['columns'] && changes['columns'].currentValue !== changes['columns'].previousValue) {\n            this.columns = this.sortColumnsBySequence(changes['columns'].currentValue);\n        }\n        this.createColumnsTemplate(changes);\n    }\n\n    public isArray(value: any): boolean {\n        return Array.isArray(value);\n    }\n\n    public getTokensByColumn(column: ColumnValues) {\n        return column.columnValue as IToken[];\n    }\n\n    private getCellData(column: ColumnValues): CellData | null {\n        const { columnValue, separator, uninformed } = column;\n\n        if (typeof columnValue === 'string') {\n            const splittedString = columnValue.split(separator);\n\n            return splittedString.map((string, index) => {\n                const isLastIndex = splittedString.length - 1 === index;\n\n                return {\n                    value: string,\n                    isUninformed: string === uninformed,\n                    separator: !isLastIndex ? separator : null,\n                };\n            });\n        }\n\n        return null;\n    }\n\n    private validateComponentAttributes(changes: SimpleChanges): void {\n        if (!this.columns && !changes['columns']?.currentValue) {\n            throw new Error(\"The 'columns' attribute must be informed!\");\n        }\n        if (!this.rowValue && !changes['rowValue']?.currentValue) {\n            throw new Error(\"The 'rowValue' attribute must be informed!\");\n        }\n    }\n\n    private createColumnsTemplate(changes: SimpleChanges): void {\n        this.viewContainerRef.clear();\n\n        const columns: Column[] = changes['columns']?.currentValue || this.columns;\n\n        const rowValue: object = deepClone(changes['rowValue']?.currentValue ?? this.rowValue);\n\n        const locale: TableColumnLocaleOptions = changes['locale']?.currentValue || this.locale;\n\n        this.formattedColumns = columns.map((column) => this.getColumnValue(column, rowValue, locale));\n\n        this.cellsData = this.formattedColumns.map((column) => this.getCellData(column));\n\n        if (!isNullOrUndefined(this.columnsTemplate)) {\n            this.viewContainerRef.createEmbeddedView(this.columnsTemplate);\n        }\n    }\n\n    private getColumnSeparator(column: Column) {\n        return column.separator ? column.separator : ' - ';\n    }\n\n    private getTranslationPrefix(column: Column) {\n        return column.prefix ? column.prefix : `${this.hostProjectConfigs.domain}.${this.hostProjectConfigs.service}.`;\n    }\n\n    private isAttributeValueInvalid(attributeValue: any) {\n        return (\n            attributeValue === null ||\n            attributeValue === undefined ||\n            (attributeValue?.options?.numberFormatOptions && isNullOrUndefined(attributeValue?.value)) ||\n            (this.isArray(attributeValue) && !attributeValue.length) ||\n            (typeof attributeValue === 'string' && attributeValue.trim() === '')\n        );\n    }\n\n    private getFormattedColumnValue(\n        column: Column,\n        columnValue: any[],\n        unifiedColumnValues: string,\n        uninformedText: string,\n        uninformedNumber: number,\n    ) {\n        if (uninformedNumber === column.attributes.length) {\n            return uninformedText;\n        }\n\n        if (column.type === EnumColumnFieldType.TOKENS) {\n            return [].concat.apply(\n                [],\n                columnValue.filter((values) => values !== uninformedText),\n            );\n        }\n\n        return unifiedColumnValues;\n    }\n\n    private getAttributeValue(attribute: string, rowValue: any) {\n        let attributeValue!: any;\n\n        attribute.split('/').forEach((value: string) => {\n            if (!attributeValue) {\n                value.split('.').forEach((val: string, i) => {\n                    if (!rowValue) {\n                        return;\n                    }\n\n                    if (i === 0) {\n                        attributeValue = rowValue[val];\n                    } else {\n                        if (attributeValue) {\n                            attributeValue = attributeValue[val];\n                        }\n                    }\n                });\n            }\n        });\n\n        return attributeValue;\n    }\n\n    private getNumberConfigs(column: Column): LocalizedBignumberOptions {\n        return {\n            ...this.locale?.number,\n            scale:\n                column.scale !== null && column.scale !== undefined\n                    ? this.getColumnScale(column.scale)\n                    : this.locale?.number.scale,\n            prefix: `${this.locale?.number.currencySymbol} `,\n        };\n    }\n\n    private getDateFormat(column: Column, locale: TableColumnLocaleOptions) {\n        return column.dateFormat ? column.dateFormat : locale.calendar.dateFormat;\n    }\n\n    private getColumnValue(column: Column, rowValue: any, locale: TableColumnLocaleOptions): ColumnValues {\n        const prefix = this.getTranslationPrefix(column);\n        const separator = this.getColumnSeparator(column);\n        const uninformed = this.translate.instant(prefix + 'empty_label');\n        const style = column.style;\n\n        const columnValue = column.attributes.map((attribute: string | number | symbol) => {\n            const attributeValue = this.getAttributeValue(attribute as string, rowValue);\n\n            if (this.isAttributeValueInvalid(attributeValue)) {\n                return uninformed;\n            }\n\n            const numberConfigs = this.getNumberConfigs(column);\n\n            switch (column.type) {\n                case EnumColumnFieldType.ENUM:\n                    return this.translate.instant(column.enumPrefix + attributeValue.toString().toLowerCase());\n\n                case EnumColumnFieldType.CURRENCY: {\n                    const numberFormatOptions = attributeValue?.options?.numberFormatOptions\n                        ? attributeValue.options.numberFormatOptions\n                        : typeof column.numberFormatOptions === 'function'\n                          ? column.numberFormatOptions({\n                                rowData: rowValue,\n                            })\n                          : column.numberFormatOptions;\n\n                    return numberFormatOptions\n                        ? this.numericService.instant(attributeValue, {\n                              numberFormatOptions,\n                          })\n                        : applyLocalizedMask(\n                              attributeValue,\n                              {\n                                  decimalSeparator: '.',\n                                  thousandsSeparator: ',',\n                                  scale: 2,\n                                  prefix: '',\n                                  suffix: '',\n                                  allowNegative: true,\n                                  ...numberConfigs,\n                              },\n                              this.isNumber(attributeValue),\n                          );\n                }\n\n                case EnumColumnFieldType.DATE:\n                    const dateFormat = this.getDateFormat(column, locale);\n                    return moment(attributeValue).format(dateFormat);\n\n                case EnumColumnFieldType.BOOLEAN:\n                    const value = attributeValue ? 'yes' : 'no';\n                    return this.translate.instant(prefix + value);\n\n                case EnumColumnFieldType.NUMBER: {\n                    numberConfigs.prefix = '';\n\n                    const numberFormatOptions = attributeValue?.options?.numberFormatOptions\n                        ? attributeValue.options.numberFormatOptions\n                        : typeof column.numberFormatOptions === 'function'\n                          ? column.numberFormatOptions({\n                                rowData: rowValue,\n                            })\n                          : column.numberFormatOptions;\n\n                    return numberFormatOptions\n                        ? this.numericService.instant(attributeValue, {\n                              numberFormatOptions,\n                          })\n                        : applyLocalizedMask(\n                              attributeValue,\n                              {\n                                  decimalSeparator: '.',\n                                  thousandsSeparator: ',',\n                                  scale: 2,\n                                  prefix: '',\n                                  suffix: '',\n                                  allowNegative: true,\n                                  ...numberConfigs,\n                              },\n                              this.isNumber(attributeValue),\n                          );\n                }\n                case EnumColumnFieldType.TOKENS:\n                    return this.getTokens(attributeValue);\n\n                default:\n                    return attributeValue;\n            }\n        });\n\n        const unifiedColumnValues = columnValue.join(separator);\n        const uninformedNumber = unifiedColumnValues.split(separator).filter((value) => value === uninformed).length;\n        const formattedColumnValue = this.getFormattedColumnValue(\n            column,\n            columnValue,\n            unifiedColumnValues,\n            uninformed,\n            uninformedNumber,\n        );\n\n        return {\n            style,\n            columnValue: formattedColumnValue,\n            separator,\n            uninformed,\n            badgeConfigs: column?.badgeConfigs?.find(\n                (badgeConfig) => badgeConfig.enumValue === rowValue[column.attributes[0] ?? column.field],\n            ),\n            color: column.color?.(rowValue),\n            type: column.type,\n            tooltip: this.getColumnTooltip(column.tooltip),\n            infoSign: this.getColumnInfoSign(column.infoSign),\n            onLinkClick: column.onLinkClick,\n            onColumnClick: column.onColumnClick,\n            compact: column.compact,\n        };\n    }\n\n    private getColumnScale(scale: number | ((rowValue: any) => number)): number {\n        if (typeof scale === 'function') {\n            return scale(deepClone(this.rowValue));\n        }\n        return scale;\n    }\n\n    private getColumnInfoSign(infoSign?: string | ((rowValue: any) => string | null)): string | null {\n        if (!isNullOrUndefined(infoSign)) {\n            if (typeof infoSign === 'function') {\n                return infoSign(deepClone(this.rowValue));\n            }\n            return infoSign;\n        }\n        return null;\n    }\n\n    private getColumnTooltip(tooltip?: string | ((rowValue: any) => string)): string {\n        if (!isNullOrUndefined(tooltip)) {\n            if (typeof tooltip === 'function') {\n                return tooltip(deepClone(this.rowValue));\n            }\n            return tooltip;\n        }\n        return '';\n    }\n\n    private isNumber(value: any): boolean {\n        return !new BigNumber(value).isNaN();\n    }\n\n    private getTokens(values: any): IToken[] {\n        if (!this.isArray(values)) {\n            throw new Error('To use tokens an array must be informed');\n        }\n\n        if (!this.isValidTokenArray(values)) {\n            throw new Error(\n                'Not a valid token array. Must be a primitive values array or an objects with label attribute array',\n            );\n        }\n\n        if (this.isLabelObjectArray(values)) {\n            return values;\n        }\n\n        return values\n            .filter((value: any) => value !== undefined && value !== null)\n            .map((value: any) => {\n                const label = typeof value === 'symbol' ? value.toString() : `${value}`;\n                return {\n                    label,\n                };\n            });\n    }\n\n    private isValidTokenArray(values: any[]): boolean {\n        return this.isPrimitiveValuesArray(values) || this.isLabelObjectArray(values);\n    }\n\n    private isPrimitiveValuesArray(values: any[]): boolean {\n        return values.filter((value) => value !== Object(value)).length === values.length;\n    }\n\n    private isLabelObjectArray(values: any[]): boolean {\n        return values.filter((value) => value?.label !== null && value?.label !== undefined).length === values.length;\n    }\n\n    private sortColumnsBySequence(columns: Column[]): Column[] {\n        return columns.sort((a, b) => (a.sequence ?? 0) - (b.sequence ?? 0));\n    }\n}\n\ntype CellData = { value: string; isUninformed: boolean; separator: string | null }[];\n\n","<ng-template #columnsTemplate>\n    @for (column of formattedColumns; track $index; let i = $index) {\n        <td\n            [ngStyle]=\"column.style\"\n            (click)=\"column.onColumnClick ? column.onColumnClick(rowValue) : null\"\n        >\n            @if (column.type !== 'TOKENS' || !isArray(column.columnValue)) {\n                <div [ngClass]=\"{ 'compact-column': column.compact }\">\n                    @if (column.type !== 'LINK') {\n                        <span\n                            [sTooltip]=\"column.tooltip\"\n                            [escape]=\"false\"\n                        >\n                            <ng-container *ngTemplateOutlet=\"columnValueTemplate\"></ng-container>\n                        </span>\n                    }\n\n                    @if (column.type === 'LINK') {\n                        @if (cellsData[i]?.[0]?.isUninformed) {\n                            <span class=\"sds-empty-value\">{{ cellsData[i]?.[0]?.value }}</span>\n                        } @else {\n                            <ng-template #anchorTemplate>\n                                <a\n                                    [sTooltip]=\"column.tooltip\"\n                                    [escape]=\"false\"\n                                    (click)=\"column.onLinkClick ? column.onLinkClick(rowValue) : null\"\n                                >\n                                    <ng-container *ngTemplateOutlet=\"columnValueTemplate\"></ng-container>\n                                </a>\n                            </ng-template>\n                        }\n                    }\n\n                    <ng-template #columnValueTemplate>\n                        @for (cellData of cellsData[i]; track $index) {\n                            @if (cellData.isUninformed) {\n                                <span class=\"sds-empty-value\">{{ cellData.value }}</span>\n                            } @else {\n                                @if (column.badgeConfigs) {\n                                    <s-badge\n                                        [sTooltip]=\"column.tooltip\"\n                                        [color]=\"column.badgeConfigs.color\"\n                                        [text]=\"cellData.value\"\n                                    ></s-badge>\n                                } @else {\n                                    <span [ngClass]=\"{\n                                        'column-cell-red': column.color === 'Red',\n                                        'column-cell-orange': column.color === 'Orange',\n                                        'column-cell-yellow': column.color === 'Yellow',\n                                        'column-cell-green': column.color === 'Green',\n                                        'column-cell-blue': column.color === 'Blue'\n                                    }\"\n                                    >{{ cellData.value }}</span>\n                                }\n                            }\n\n                            @if (cellData.separator) {\n                                <span>{{ cellData.separator }}</span>\n                            }\n                        }\n\n                        @if (!!column.infoSign) {\n                            <span *sInfoSign=\"column.infoSign\"></span>\n                        }\n                    </ng-template>\n                </div>\n            } @else {\n                <s-token-list\n                    [tokens]=\"getTokensByColumn(column)\"\n                    [hidePointerEvents]=\"true\"\n                ></s-token-list>\n\n                @if (!!column.infoSign) {\n                    <span *sInfoSign=\"column.infoSign\"></span>\n                }\n            }\n        </td>\n    }\n</ng-template>\n"]}
|
|
@@ -3,4 +3,5 @@ export * from './lib/table/row-toggler/row-toggler.directive';
|
|
|
3
3
|
export * from './lib/table/table-column/index';
|
|
4
4
|
export * from './lib/table/table-paging/index';
|
|
5
5
|
export * from './lib/table/table.module';
|
|
6
|
-
|
|
6
|
+
export { ExportUtils } from './lib/table/export-utils';
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItY29tcG9uZW50cy90YWJsZS9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDZDQUE2QyxDQUFDO0FBQzVELGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvdGFibGUvbmF2aWdhdGlvbi9uYXZpZ2F0aW9uLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWJsZS9yb3ctdG9nZ2xlci9yb3ctdG9nZ2xlci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdGFibGUvdGFibGUtY29sdW1uL2luZGV4JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3RhYmxlL3RhYmxlLXBhZ2luZy9pbmRleCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWJsZS90YWJsZS5tb2R1bGUnO1xuZXhwb3J0IHsgRXhwb3J0VXRpbHMgfSBmcm9tICcuL2xpYi90YWJsZS9leHBvcnQtdXRpbHMnO1xuIl19
|
|
@@ -1,13 +1,11 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { input, model, output, forwardRef, Directive, NgModule } from '@angular/core';
|
|
3
3
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
4
|
-
import {
|
|
5
|
-
import { first } from 'rxjs/operators';
|
|
6
|
-
import * as i1 from '@seniorsistemas/angular-components/locale';
|
|
4
|
+
import { NumericMaskDirective } from '@seniorsistemas/angular-components/numeric-mask';
|
|
7
5
|
import { CommonModule } from '@angular/common';
|
|
8
6
|
|
|
9
7
|
/**
|
|
10
|
-
* @deprecated
|
|
8
|
+
* @deprecated Este enum não tem mais efeito. O alinhamento do campo é sempre `'right'`.
|
|
11
9
|
*/
|
|
12
10
|
var BignumberAlignmentOption;
|
|
13
11
|
(function (BignumberAlignmentOption) {
|
|
@@ -27,134 +25,198 @@ var BignumberAlignmentOption;
|
|
|
27
25
|
*
|
|
28
26
|
* @category Inputs
|
|
29
27
|
*/
|
|
30
|
-
class BignumberInputDirective extends
|
|
31
|
-
localeService;
|
|
28
|
+
class BignumberInputDirective extends NumericMaskDirective {
|
|
32
29
|
/**
|
|
33
|
-
* @description Número total de dígitos significativos aceitos pelo campo.
|
|
30
|
+
* @description Número total de dígitos significativos aceitos pelo campo (parte inteira + parte decimal).
|
|
31
|
+
*
|
|
32
|
+
* Durante a digitação, o campo limita fisicamente o número de caracteres via `maxLength`.
|
|
33
|
+
* Ao colar um valor que ultrapasse o limite, o evento `pasteRejected` é emitido e a colagem é cancelada.
|
|
34
|
+
* Após sair do campo (blur) ou ao submeter o formulário, se o valor ultrapassar `precision`,
|
|
35
|
+
* o campo ficará inválido com o erro `exceedsPrecision: { precision, actual }`.
|
|
34
36
|
*
|
|
35
37
|
* @default 15
|
|
36
38
|
*/
|
|
37
|
-
precision = 15;
|
|
39
|
+
precision = input(15);
|
|
38
40
|
/**
|
|
41
|
+
* @deprecated Use `minDecimalPlaces` e `maxDecimalPlaces` ao invés deste.
|
|
39
42
|
* @description Número de casas decimais exibidas e aceitas pelo campo.
|
|
43
|
+
* Quando informado, repassa o valor para `minDecimalPlaces` e `maxDecimalPlaces`.
|
|
40
44
|
*
|
|
41
45
|
* @default 0
|
|
42
46
|
*/
|
|
43
|
-
scale = 0;
|
|
47
|
+
scale = input(0);
|
|
48
|
+
/**
|
|
49
|
+
* @description Número mínimo de casas decimais exibidas.
|
|
50
|
+
*
|
|
51
|
+
* @default 0
|
|
52
|
+
*/
|
|
53
|
+
minDecimalPlaces = model(0);
|
|
54
|
+
/**
|
|
55
|
+
* @description Número máximo de casas decimais aceitas.
|
|
56
|
+
*
|
|
57
|
+
* @default 0
|
|
58
|
+
*/
|
|
59
|
+
maxDecimalPlaces = model(0);
|
|
44
60
|
/**
|
|
45
61
|
* @description Separador decimal personalizado. Quando não informado,
|
|
46
62
|
* utiliza o separador definido pelo locale ativo da aplicação.
|
|
47
63
|
*/
|
|
48
|
-
decimalSeparator;
|
|
64
|
+
decimalSeparator = model(',');
|
|
65
|
+
/**
|
|
66
|
+
* @deprecated Use `thousandSeparator` ao invés deste.
|
|
67
|
+
* @description Separador de milhar personalizado. Recomenda-se migrar para `thousandSeparator`.
|
|
68
|
+
*/
|
|
69
|
+
thousandsSeparator = input(undefined);
|
|
49
70
|
/**
|
|
50
71
|
* @description Separador de milhar personalizado. Quando não informado,
|
|
51
72
|
* utiliza o separador definido pelo locale ativo da aplicação.
|
|
52
73
|
*/
|
|
53
|
-
|
|
74
|
+
thousandSeparator = model('.');
|
|
54
75
|
/**
|
|
55
|
-
* @
|
|
56
|
-
*
|
|
57
|
-
* @default 'left'
|
|
76
|
+
* @deprecated Este input não tem mais efeito e pode ser removido.
|
|
77
|
+
* O alinhamento do campo é sempre `'right'`, conforme o comportamento padrão da máscara numérica.
|
|
58
78
|
*/
|
|
59
|
-
alignTo = '
|
|
79
|
+
alignTo = input('right');
|
|
60
80
|
/**
|
|
61
81
|
* @description Permite a entrada de valores negativos.
|
|
62
82
|
*
|
|
63
83
|
* @default true
|
|
64
84
|
*/
|
|
65
|
-
allowNegative = true;
|
|
85
|
+
allowNegative = input(true);
|
|
66
86
|
/**
|
|
67
87
|
* @description Texto de placeholder exibido quando o campo está vazio.
|
|
68
88
|
*/
|
|
69
|
-
placeholder;
|
|
89
|
+
placeholder = model(undefined);
|
|
70
90
|
maxLength;
|
|
71
91
|
/**
|
|
72
|
-
* @description Emitido quando uma
|
|
92
|
+
* @description Emitido quando uma colagem (paste) é rejeitada pela validação do campo.
|
|
73
93
|
* Emite a string colada que foi recusada.
|
|
74
94
|
*/
|
|
75
|
-
pasteRejected =
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
// super(injector);
|
|
81
|
-
// this._angularComponentsLocaleService = injector.get(LocaleService);
|
|
82
|
-
// this.onLocaleService();
|
|
83
|
-
// }
|
|
84
|
-
//TODO: Remover esse constructor
|
|
85
|
-
constructor(_elementRef, _keyValueDiffers, localeService) {
|
|
86
|
-
super({ align: '', allowNegative: true, decimal: '', precision: 0, prefix: '', suffix: '', thousands: '' }, _elementRef, _keyValueDiffers);
|
|
87
|
-
this.localeService = localeService;
|
|
88
|
-
this.onLocaleService();
|
|
95
|
+
pasteRejected = output();
|
|
96
|
+
_decimalSeparatorExplicit = false;
|
|
97
|
+
_thousandSeparatorExplicit = false;
|
|
98
|
+
constructor() {
|
|
99
|
+
super();
|
|
89
100
|
}
|
|
90
101
|
ngOnInit() {
|
|
91
|
-
this.updateVariables();
|
|
92
102
|
super.ngOnInit();
|
|
103
|
+
this.updatePlaceholder();
|
|
93
104
|
}
|
|
105
|
+
// ngOnChanges handles all signal writes reactively, avoiding the need for
|
|
106
|
+
// effect() with allowSignalWrites. The decimalSeparator/thousandSeparator inputs
|
|
107
|
+
// have truthy defaults, so ngOnChanges is necessary to distinguish "parent bound this"
|
|
108
|
+
// from "it's just the default value".
|
|
94
109
|
ngOnChanges(changes) {
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
110
|
+
if (changes['decimalSeparator'] && this.decimalSeparator()) {
|
|
111
|
+
this._decimalSeparatorExplicit = true;
|
|
112
|
+
}
|
|
113
|
+
if (changes['thousandSeparator'] && this.thousandSeparator()) {
|
|
114
|
+
this._thousandSeparatorExplicit = true;
|
|
98
115
|
}
|
|
99
|
-
|
|
116
|
+
if (changes['thousandsSeparator']) {
|
|
117
|
+
const val = this.thousandsSeparator();
|
|
118
|
+
if (val !== undefined) {
|
|
119
|
+
this._thousandSeparatorExplicit = true;
|
|
120
|
+
this.thousandSeparator.set(val);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
if (changes['scale']) {
|
|
124
|
+
this.minDecimalPlaces.set(this.scale());
|
|
125
|
+
this.maxDecimalPlaces.set(this.scale());
|
|
126
|
+
}
|
|
127
|
+
if (changes['scale'] ||
|
|
100
128
|
changes['decimalSeparator'] ||
|
|
129
|
+
changes['thousandSeparator'] ||
|
|
101
130
|
changes['thousandsSeparator'] ||
|
|
102
|
-
changes['
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
if (
|
|
106
|
-
this.
|
|
131
|
+
changes['precision']) {
|
|
132
|
+
this.calculateMaxLength();
|
|
133
|
+
}
|
|
134
|
+
if (changes['scale'] || changes['decimalSeparator']) {
|
|
135
|
+
this.updatePlaceholder();
|
|
107
136
|
}
|
|
108
137
|
}
|
|
138
|
+
/**
|
|
139
|
+
* Overrides base paste handler to add precision validation.
|
|
140
|
+
* If the pasted value exceeds `precision` digits, the paste is rejected.
|
|
141
|
+
*/
|
|
109
142
|
onPaste(event) {
|
|
110
143
|
const pastedText = event.clipboardData?.getData('text') ?? '';
|
|
144
|
+
const effectiveThousandSep = this.thousandsSeparator() ?? this.thousandSeparator();
|
|
111
145
|
const numericText = pastedText
|
|
112
|
-
.replace(new RegExp(`\\${
|
|
113
|
-
.replace(this.decimalSeparator, '.');
|
|
146
|
+
.replace(new RegExp(`\\${effectiveThousandSep}`, 'g'), '')
|
|
147
|
+
.replace(this.decimalSeparator(), '.');
|
|
114
148
|
const [intPart, decimalPart = ''] = numericText.split('.');
|
|
115
|
-
const totalDigits = intPart.replace(/\D/g, '').length + decimalPart.slice(0, this.scale).length;
|
|
116
|
-
if (totalDigits > this.precision) {
|
|
149
|
+
const totalDigits = intPart.replace(/\D/g, '').length + decimalPart.slice(0, this.scale()).length;
|
|
150
|
+
if (totalDigits > this.precision()) {
|
|
117
151
|
event.preventDefault();
|
|
118
152
|
this.pasteRejected.emit(pastedText);
|
|
153
|
+
return;
|
|
119
154
|
}
|
|
155
|
+
super.onPaste(event);
|
|
120
156
|
}
|
|
121
157
|
/**
|
|
122
|
-
*
|
|
158
|
+
* Overrides locale-derived separators with explicitly set inputs, if provided.
|
|
159
|
+
* If no explicit separator is set, the locale-derived value is used.
|
|
123
160
|
*/
|
|
124
|
-
|
|
125
|
-
this.
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
161
|
+
updateSeparators() {
|
|
162
|
+
const explicitDecimal = this._decimalSeparatorExplicit ? this.decimalSeparator() : undefined;
|
|
163
|
+
const explicitThousand = this._thousandSeparatorExplicit
|
|
164
|
+
? (this.thousandsSeparator() ?? this.thousandSeparator())
|
|
165
|
+
: undefined;
|
|
166
|
+
super.updateSeparators();
|
|
167
|
+
if (explicitDecimal !== undefined) {
|
|
168
|
+
this.decimalSeparator.set(explicitDecimal);
|
|
169
|
+
}
|
|
170
|
+
if (explicitThousand !== undefined) {
|
|
171
|
+
this.thousandSeparator.set(explicitThousand);
|
|
172
|
+
}
|
|
134
173
|
this.calculateMaxLength();
|
|
174
|
+
this.updatePlaceholder();
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* Overrides base validator to add precision validation.
|
|
178
|
+
* If the total number of significant digits exceeds `precision`, returns an `exceedsPrecision` error.
|
|
179
|
+
*/
|
|
180
|
+
validate(control) {
|
|
181
|
+
const baseErrors = super.validate(control);
|
|
182
|
+
if (!control.value || !this.precision()) {
|
|
183
|
+
return baseErrors ?? null;
|
|
184
|
+
}
|
|
185
|
+
const numericStr = String(control.value).replace('-', '');
|
|
186
|
+
const [intPart, decimalPart = ''] = numericStr.split('.');
|
|
187
|
+
const totalDigits = intPart.length + decimalPart.length;
|
|
188
|
+
if (totalDigits > this.precision()) {
|
|
189
|
+
return {
|
|
190
|
+
...baseErrors,
|
|
191
|
+
exceedsPrecision: {
|
|
192
|
+
precision: this.precision(),
|
|
193
|
+
actual: totalDigits,
|
|
194
|
+
},
|
|
195
|
+
};
|
|
196
|
+
}
|
|
197
|
+
return baseErrors ?? null;
|
|
135
198
|
}
|
|
136
199
|
/**
|
|
137
200
|
* Responsible to calculate the field maximum length considering the separators.
|
|
138
201
|
*/
|
|
139
202
|
calculateMaxLength() {
|
|
140
|
-
const decSepLength = this.decimalSeparator?.length ?? 0;
|
|
141
|
-
const
|
|
203
|
+
const decSepLength = this.decimalSeparator()?.length ?? 0;
|
|
204
|
+
const effectiveThousandSep = this.thousandsSeparator() ?? this.thousandSeparator();
|
|
205
|
+
const thoSepLength = effectiveThousandSep?.length ?? 0;
|
|
142
206
|
const DIGITS_GROUP_SIZE = 3;
|
|
143
|
-
let maxLength = this.precision + (this.scale ? decSepLength : 0);
|
|
144
|
-
maxLength +=
|
|
207
|
+
let maxLength = this.precision() + (this.scale() ? decSepLength : 0);
|
|
208
|
+
maxLength +=
|
|
209
|
+
Math.ceil((this.precision() - (this.scale() ? this.scale() : 0)) / DIGITS_GROUP_SIZE - 1) * thoSepLength;
|
|
145
210
|
this.maxLength = maxLength;
|
|
146
211
|
}
|
|
147
|
-
|
|
148
|
-
this.
|
|
149
|
-
|
|
150
|
-
.
|
|
151
|
-
|
|
152
|
-
this.decimalSeparator = this.decimalSeparator ?? this.localeService.getDecimalSeparator();
|
|
153
|
-
this.thousandsSeparator = this.thousandsSeparator ?? this.localeService.getGroupingSeparator();
|
|
154
|
-
});
|
|
212
|
+
updatePlaceholder() {
|
|
213
|
+
const scale = this.scale();
|
|
214
|
+
if (!this.placeholder() && scale) {
|
|
215
|
+
this.placeholder.set(`0${this.decimalSeparator()}${''.padEnd(scale, '0')}`);
|
|
216
|
+
}
|
|
155
217
|
}
|
|
156
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: BignumberInputDirective, deps: [
|
|
157
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "
|
|
218
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: BignumberInputDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
219
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.14", type: BignumberInputDirective, selector: "input[sBignumberInput]", inputs: { precision: { classPropertyName: "precision", publicName: "precision", isSignal: true, isRequired: false, transformFunction: null }, scale: { classPropertyName: "scale", publicName: "scale", isSignal: true, isRequired: false, transformFunction: null }, minDecimalPlaces: { classPropertyName: "minDecimalPlaces", publicName: "minDecimalPlaces", isSignal: true, isRequired: false, transformFunction: null }, maxDecimalPlaces: { classPropertyName: "maxDecimalPlaces", publicName: "maxDecimalPlaces", isSignal: true, isRequired: false, transformFunction: null }, decimalSeparator: { classPropertyName: "decimalSeparator", publicName: "decimalSeparator", isSignal: true, isRequired: false, transformFunction: null }, thousandsSeparator: { classPropertyName: "thousandsSeparator", publicName: "thousandsSeparator", isSignal: true, isRequired: false, transformFunction: null }, thousandSeparator: { classPropertyName: "thousandSeparator", publicName: "thousandSeparator", isSignal: true, isRequired: false, transformFunction: null }, alignTo: { classPropertyName: "alignTo", publicName: "alignTo", isSignal: true, isRequired: false, transformFunction: null }, allowNegative: { classPropertyName: "allowNegative", publicName: "allowNegative", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { minDecimalPlaces: "minDecimalPlacesChange", maxDecimalPlaces: "maxDecimalPlacesChange", decimalSeparator: "decimalSeparatorChange", thousandSeparator: "thousandSeparatorChange", placeholder: "placeholderChange", pasteRejected: "pasteRejected" }, host: { properties: { "attr.placeholder": "placeholder()", "attr.maxLength": "maxLength" } }, providers: [
|
|
158
220
|
{
|
|
159
221
|
provide: NG_VALUE_ACCESSOR,
|
|
160
222
|
// NOSONAR - 'BignumberInputDirective' is deprecated.
|
|
@@ -167,6 +229,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
167
229
|
type: Directive,
|
|
168
230
|
args: [{
|
|
169
231
|
selector: 'input[sBignumberInput]',
|
|
232
|
+
host: {
|
|
233
|
+
'[attr.placeholder]': 'placeholder()',
|
|
234
|
+
'[attr.maxLength]': 'maxLength',
|
|
235
|
+
},
|
|
170
236
|
providers: [
|
|
171
237
|
{
|
|
172
238
|
provide: NG_VALUE_ACCESSOR,
|
|
@@ -176,32 +242,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
176
242
|
},
|
|
177
243
|
],
|
|
178
244
|
}]
|
|
179
|
-
}], ctorParameters: () => [
|
|
180
|
-
type: Input
|
|
181
|
-
}], scale: [{
|
|
182
|
-
type: Input
|
|
183
|
-
}], decimalSeparator: [{
|
|
184
|
-
type: Input
|
|
185
|
-
}], thousandsSeparator: [{
|
|
186
|
-
type: Input
|
|
187
|
-
}], alignTo: [{
|
|
188
|
-
type: Input
|
|
189
|
-
}], allowNegative: [{
|
|
190
|
-
type: Input
|
|
191
|
-
}], placeholder: [{
|
|
192
|
-
type: Input
|
|
193
|
-
}, {
|
|
194
|
-
type: HostBinding,
|
|
195
|
-
args: ['attr.placeholder']
|
|
196
|
-
}], maxLength: [{
|
|
197
|
-
type: HostBinding,
|
|
198
|
-
args: ['attr.maxLength']
|
|
199
|
-
}], pasteRejected: [{
|
|
200
|
-
type: Output
|
|
201
|
-
}], onPaste: [{
|
|
202
|
-
type: HostListener,
|
|
203
|
-
args: ['paste', ['$event']]
|
|
204
|
-
}] } });
|
|
245
|
+
}], ctorParameters: () => [] });
|
|
205
246
|
|
|
206
247
|
class BignumberInputModule {
|
|
207
248
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: BignumberInputModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|