@seniorsistemas/angular-components 17.26.5-bugfix-sds-299-7054ebd8 → 17.26.6
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/bundles/seniorsistemas-angular-components.umd.js +92 -30
- package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
- package/components/bignumber-input/{number-input.directive.d.ts → bignumber-input.directive.d.ts} +3 -1
- package/components/bignumber-input/index.d.ts +2 -2
- package/components/card/card.component.d.ts +5 -2
- package/components/number-input/number-input.directive.d.ts +11 -9
- package/components/text-area-ia/text-area-ia.component.d.ts +1 -0
- package/esm2015/components/bignumber-input/bignumber-input.directive.js +150 -0
- package/esm2015/components/bignumber-input/bignumber-input.module.js +15 -0
- package/esm2015/components/bignumber-input/index.js +3 -3
- package/esm2015/components/card/card.component.js +22 -7
- package/esm2015/components/dynamic-form/components/fields/bignumber/bignumber-field.module.js +2 -2
- package/esm2015/components/dynamic-form/configurations/fields/text-area-ia-field.js +2 -2
- package/esm2015/components/dynamic-form/dynamic-form.module.js +2 -2
- package/esm2015/components/inline-edit/inline-edit.module.js +2 -2
- package/esm2015/components/number-input/number-input.directive.js +41 -21
- package/esm2015/components/text-area/text-area/text-area.component.js +2 -2
- package/esm2015/components/text-area-ia/text-area-ia.component.js +8 -3
- package/esm2015/components/text-area-ia/text-area-ia.module.js +3 -3
- package/esm5/components/bignumber-input/bignumber-input.directive.js +155 -0
- package/esm5/components/bignumber-input/bignumber-input.module.js +18 -0
- package/esm5/components/bignumber-input/index.js +3 -3
- package/esm5/components/card/card.component.js +26 -7
- package/esm5/components/dynamic-form/components/fields/bignumber/bignumber-field.module.js +2 -2
- package/esm5/components/dynamic-form/configurations/fields/text-area-ia-field.js +2 -2
- package/esm5/components/dynamic-form/dynamic-form.module.js +2 -2
- package/esm5/components/inline-edit/inline-edit.module.js +2 -2
- package/esm5/components/number-input/number-input.directive.js +42 -22
- package/esm5/components/text-area/text-area/text-area.component.js +2 -2
- package/esm5/components/text-area-ia/text-area-ia.component.js +8 -3
- package/esm5/components/text-area-ia/text-area-ia.module.js +3 -3
- package/fesm2015/seniorsistemas-angular-components.js +88 -30
- package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
- package/fesm5/seniorsistemas-angular-components.js +93 -31
- package/fesm5/seniorsistemas-angular-components.js.map +1 -1
- package/package.json +1 -1
- package/seniorsistemas-angular-components.metadata.json +1 -1
- package/esm2015/components/bignumber-input/number-input.directive.js +0 -132
- package/esm2015/components/bignumber-input/number-input.module.js +0 -15
- package/esm5/components/bignumber-input/number-input.directive.js +0 -137
- package/esm5/components/bignumber-input/number-input.module.js +0 -18
- /package/components/bignumber-input/{number-input.module.d.ts → bignumber-input.module.d.ts} +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
var NumberInputDirective_1;
|
|
2
2
|
import { __decorate } from "tslib";
|
|
3
|
-
import { Directive, ElementRef, forwardRef, HostBinding,
|
|
3
|
+
import { Directive, ElementRef, EventEmitter, forwardRef, HostBinding, Input, KeyValueDiffers, OnChanges, OnDestroy, OnInit, Output, SimpleChanges, } from "@angular/core";
|
|
4
4
|
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
5
5
|
import { LocaleService } from "../locale/locale.service";
|
|
6
6
|
import { CurrencyMaskDirective } from "ng2-currency-mask";
|
|
@@ -17,19 +17,24 @@ export var NumberAlignmentOption;
|
|
|
17
17
|
* @deprecated Should use BigNumberInput directive instead
|
|
18
18
|
*/
|
|
19
19
|
let NumberInputDirective = NumberInputDirective_1 = class NumberInputDirective extends CurrencyMaskDirective {
|
|
20
|
-
constructor(
|
|
20
|
+
constructor(_keyValueDiffers, _elementRef, localeService) {
|
|
21
21
|
super(null, _elementRef, _keyValueDiffers);
|
|
22
|
+
this._elementRef = _elementRef;
|
|
22
23
|
this.localeService = localeService;
|
|
23
24
|
this.precision = 15;
|
|
24
25
|
this.scale = 0;
|
|
25
26
|
this.alignTo = NumberAlignmentOption.LEFT;
|
|
26
27
|
this.allowNegative = true;
|
|
27
|
-
this.
|
|
28
|
+
this.pasteRejected = new EventEmitter();
|
|
28
29
|
this.onLocaleService();
|
|
29
30
|
}
|
|
30
31
|
ngOnInit() {
|
|
31
32
|
this.updateVariables();
|
|
32
33
|
super.ngOnInit();
|
|
34
|
+
this.pasteListener = this._onPaste.bind(this);
|
|
35
|
+
this._elementRef.nativeElement.addEventListener("paste", this.pasteListener);
|
|
36
|
+
this.keypressListener = this._onKeypress.bind(this);
|
|
37
|
+
this._elementRef.nativeElement.addEventListener("keypress", this.keypressListener);
|
|
33
38
|
}
|
|
34
39
|
ngOnChanges(changes) {
|
|
35
40
|
const placeholderChange = changes.placeholder && changes.placeholder.currentValue;
|
|
@@ -44,6 +49,33 @@ let NumberInputDirective = NumberInputDirective_1 = class NumberInputDirective e
|
|
|
44
49
|
this.updateVariables();
|
|
45
50
|
}
|
|
46
51
|
}
|
|
52
|
+
ngOnDestroy() {
|
|
53
|
+
this._elementRef.nativeElement.removeEventListener("paste", this.pasteListener);
|
|
54
|
+
this._elementRef.nativeElement.removeEventListener("keypress", this.keypressListener);
|
|
55
|
+
}
|
|
56
|
+
_onPaste(event) {
|
|
57
|
+
var _a, _b;
|
|
58
|
+
const pastedText = (_b = (_a = event.clipboardData) === null || _a === void 0 ? void 0 : _a.getData("text")) !== null && _b !== void 0 ? _b : "";
|
|
59
|
+
const numericText = pastedText.replace(new RegExp(`\\${this.thousandsSeparator}`, "g"), "").replace(this.decimalSeparator, ".");
|
|
60
|
+
const [intPart, decimalPart = ""] = numericText.split(".");
|
|
61
|
+
const totalDigits = intPart.replace(/\D/g, "").length + decimalPart.slice(0, this.scale).length;
|
|
62
|
+
if (totalDigits > this.precision) {
|
|
63
|
+
event.preventDefault();
|
|
64
|
+
event.stopPropagation();
|
|
65
|
+
this.pasteRejected.emit(pastedText);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
_onKeypress(event) {
|
|
69
|
+
const code = event.code;
|
|
70
|
+
if (code === "Minus" || code === "NumpadSubtract") {
|
|
71
|
+
if (this.allowNegative) {
|
|
72
|
+
this.maxLength = this._maxLength + 1;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
else if (code === "Equal" || code === "NumpadAdd") {
|
|
76
|
+
this.maxLength = this._maxLength;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
47
79
|
/**
|
|
48
80
|
* Update the options values according to the directive input values.
|
|
49
81
|
*/
|
|
@@ -67,24 +99,9 @@ let NumberInputDirective = NumberInputDirective_1 = class NumberInputDirective e
|
|
|
67
99
|
const thoSepLength = this.thousandsSeparator.length;
|
|
68
100
|
let maxLength = this.precision + (this.scale ? decSepLength : 0);
|
|
69
101
|
maxLength += Math.ceil((this.precision - (this.scale ? this.scale : 0)) / 3 - 1) * thoSepLength;
|
|
102
|
+
this._maxLength = maxLength;
|
|
70
103
|
this.maxLength = maxLength;
|
|
71
104
|
}
|
|
72
|
-
/**
|
|
73
|
-
* Prevents the default CurrencyMask behavior when typed a incorrect value.
|
|
74
|
-
* By default the CurrencyMask inputs the mask value to the component value when typed a incorrect value.
|
|
75
|
-
*/
|
|
76
|
-
handleKeypress(event) {
|
|
77
|
-
const negativeOperator = "-";
|
|
78
|
-
const { key } = event;
|
|
79
|
-
if (this.thousandsSeparator.includes(key) ||
|
|
80
|
-
this.decimalSeparator.includes(key) ||
|
|
81
|
-
negativeOperator.includes(key) ||
|
|
82
|
-
this.regex.test(key) ||
|
|
83
|
-
"Enter".toUpperCase() === key.toUpperCase())
|
|
84
|
-
super.handleKeypress(event);
|
|
85
|
-
else
|
|
86
|
-
event.preventDefault();
|
|
87
|
-
}
|
|
88
105
|
onLocaleService() {
|
|
89
106
|
this.localeService
|
|
90
107
|
.getLocale()
|
|
@@ -97,8 +114,8 @@ let NumberInputDirective = NumberInputDirective_1 = class NumberInputDirective e
|
|
|
97
114
|
}
|
|
98
115
|
};
|
|
99
116
|
NumberInputDirective.ctorParameters = () => [
|
|
100
|
-
{ type: ElementRef },
|
|
101
117
|
{ type: KeyValueDiffers },
|
|
118
|
+
{ type: ElementRef },
|
|
102
119
|
{ type: LocaleService }
|
|
103
120
|
];
|
|
104
121
|
__decorate([
|
|
@@ -126,6 +143,9 @@ __decorate([
|
|
|
126
143
|
__decorate([
|
|
127
144
|
HostBinding("attr.maxLength")
|
|
128
145
|
], NumberInputDirective.prototype, "maxLength", void 0);
|
|
146
|
+
__decorate([
|
|
147
|
+
Output()
|
|
148
|
+
], NumberInputDirective.prototype, "pasteRejected", void 0);
|
|
129
149
|
NumberInputDirective = NumberInputDirective_1 = __decorate([
|
|
130
150
|
Directive({
|
|
131
151
|
selector: "input[sNumberInput]",
|
|
@@ -139,4 +159,4 @@ NumberInputDirective = NumberInputDirective_1 = __decorate([
|
|
|
139
159
|
})
|
|
140
160
|
], NumberInputDirective);
|
|
141
161
|
export { NumberInputDirective };
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-input.directive.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/number-input/number-input.directive.ts"],"names":[],"mappings":";;AAAA,OAAO,EACH,SAAS,EACT,UAAU,EACV,UAAU,EACV,WAAW,EACX,UAAU,EACV,KAAK,EACL,eAAe,EACf,SAAS,EACT,MAAM,EACN,aAAa,GAChB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAEvC;;GAEG;AACH,MAAM,CAAN,IAAY,qBAGX;AAHD,WAAY,qBAAqB;IAC7B,wCAAe,CAAA;IACf,sCAAa,CAAA;AACjB,CAAC,EAHW,qBAAqB,KAArB,qBAAqB,QAGhC;AAED;;GAEG;AAWH,IAAa,oBAAoB,4BAAjC,MAAa,oBAAqB,SAAQ,qBAAqB;IA4B3D,YACI,WAAuB,EACvB,gBAAiC,EAChB,aAA4B;QAE7C,KAAK,CAAC,IAAI,EAAE,WAAW,EAAE,gBAAgB,CAAC,CAAC;QAF1B,kBAAa,GAAb,aAAa,CAAe;QA7B1C,cAAS,GAAG,EAAE,CAAC;QAGf,UAAK,GAAG,CAAC,CAAC;QASV,YAAO,GAAG,qBAAqB,CAAC,IAAI,CAAC;QAGrC,kBAAa,GAAG,IAAI,CAAC;QASpB,UAAK,GAAW,IAAI,CAAC;QASzB,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,eAAe,EAAE,CAAC;QAEvB,KAAK,CAAC,QAAQ,EAAE,CAAC;IACrB,CAAC;IAEM,WAAW,CAAC,OAAsB;QACrC,MAAM,iBAAiB,GAAG,OAAO,CAAC,WAAW,IAAI,OAAO,CAAC,WAAW,CAAC,YAAY,CAAC;QAClF,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,KAAK;YAAE,IAAI,CAAC,WAAW,GAAG,IAAI,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,EAAE,CAAC;QAElH,IACI,OAAO,CAAC,KAAK;YACb,OAAO,CAAC,gBAAgB;YACxB,OAAO,CAAC,kBAAkB;YAC1B,OAAO,CAAC,OAAO;YACf,OAAO,CAAC,SAAS;YACjB,OAAO,CAAC,aAAa,EACvB;YACE,IAAI,CAAC,eAAe,EAAE,CAAC;SAC1B;IACL,CAAC;IAED;;OAEG;IACK,eAAe;QACnB,IAAI,CAAC,OAAO,GAAG;YACX,KAAK,EAAE,IAAI,CAAC,OAAO;YACnB,OAAO,EAAE,IAAI,CAAC,gBAAgB;YAC9B,SAAS,EAAE,IAAI,CAAC,kBAAkB;YAClC,SAAS,EAAE,IAAI,CAAC,KAAK,IAAI,CAAC;YAC1B,MAAM,EAAE,EAAE;YACV,MAAM,EAAE,EAAE;YACV,aAAa,EAAE,IAAI,CAAC,aAAa;SACpC,CAAC;QACF,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC9B,CAAC;IAED;;OAEG;IACK,kBAAkB;QACtB,MAAM,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC;QAClD,MAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC;QAEpD,IAAI,SAAS,GAAG,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACjE,SAAS,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,YAAY,CAAC;QAEhG,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;IAC/B,CAAC;IAED;;;OAGG;IACI,cAAc,CAAC,KAAoB;QACtC,MAAM,gBAAgB,GAAG,GAAG,CAAC;QAC7B,MAAM,EAAE,GAAG,EAAE,GAAG,KAAK,CAAC;QAEtB,IACI,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,GAAG,CAAC;YACrC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,GAAG,CAAC;YACnC,gBAAgB,CAAC,QAAQ,CAAC,GAAG,CAAC;YAC9B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC;YACpB,OAAO,CAAC,WAAW,EAAE,KAAK,GAAG,CAAC,WAAW,EAAE;YAE3C,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;;YAC3B,KAAK,CAAC,cAAc,EAAE,CAAC;IAChC,CAAC;IAEO,eAAe;QACnB,IAAI,CAAC,aAAa;aACb,SAAS,EAAE;aACX,IAAI,CAAC,KAAK,EAAE,CAAC;aACb,SAAS,CAAC,GAAG,EAAE;;YACZ,IAAI,CAAC,gBAAgB,SAAG,IAAI,CAAC,gBAAgB,mCAAI,IAAI,CAAC,aAAa,CAAC,mBAAmB,EAAE,CAAC;YAC1F,IAAI,CAAC,kBAAkB,SAAG,IAAI,CAAC,kBAAkB,mCAAI,IAAI,CAAC,aAAa,CAAC,oBAAoB,EAAE,CAAC;QACnG,CAAC,CAAC,CAAC;IACX,CAAC;CACJ,CAAA;;YAxFoB,UAAU;YACL,eAAe;YACD,aAAa;;AA7BjD;IADC,KAAK,EAAE;uDACc;AAGtB;IADC,KAAK,EAAE;mDACS;AAGjB;IADC,KAAK,EAAE;8DACwB;AAGhC;IADC,KAAK,EAAE;gEAC0B;AAGlC;IADC,KAAK,EAAE;qDACoC;AAG5C;IADC,KAAK,EAAE;2DACoB;AAI5B;IAFC,KAAK,EAAE;IACP,WAAW,CAAC,kBAAkB,CAAC;yDACL;AAG3B;IADC,WAAW,CAAC,gBAAgB,CAAC;uDACL;AAxBhB,oBAAoB;IAVhC,SAAS,CAAC;QACP,QAAQ,EAAE,qBAAqB;QAC/B,SAAS,EAAE;YACP;gBACI,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,sBAAoB,CAAC;gBACnD,KAAK,EAAE,IAAI;aACd;SACJ;KACJ,CAAC;GACW,oBAAoB,CAqHhC;SArHY,oBAAoB","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    forwardRef,\n    HostBinding,\n    Injectable,\n    Input,\n    KeyValueDiffers,\n    OnChanges,\n    OnInit,\n    SimpleChanges,\n} from \"@angular/core\";\nimport { NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { LocaleService } from \"../locale/locale.service\";\nimport { CurrencyMaskDirective } from \"ng2-currency-mask\";\nimport { first } from \"rxjs/operators\";\n\n/**\n * @deprecated Should use 'AlignmentOptions' from @seniorsistemas/ng2-currency-mask instead\n */\nexport enum NumberAlignmentOption {\n    RIGHT = \"right\",\n    LEFT = \"left\",\n}\n\n/**\n * @deprecated Should use BigNumberInput directive instead\n */\n@Directive({\n    selector: \"input[sNumberInput]\",\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => NumberInputDirective),\n            multi: true,\n        },\n    ],\n})\nexport class NumberInputDirective extends CurrencyMaskDirective implements OnInit, OnChanges {\n    @Input()\n    public precision = 15;\n\n    @Input()\n    public scale = 0;\n\n    @Input()\n    public decimalSeparator: string;\n\n    @Input()\n    public thousandsSeparator: string;\n\n    @Input()\n    public alignTo = NumberAlignmentOption.LEFT;\n\n    @Input()\n    public allowNegative = true;\n\n    @Input()\n    @HostBinding(\"attr.placeholder\")\n    public placeholder: string;\n\n    @HostBinding(\"attr.maxLength\")\n    public maxLength: number;\n\n    private regex: RegExp = /\\d/;\n\n    constructor(\n        _elementRef: ElementRef,\n        _keyValueDiffers: KeyValueDiffers,\n        private readonly localeService: LocaleService\n    ) {\n        super(null, _elementRef, _keyValueDiffers);\n\n        this.onLocaleService();\n    }\n\n    ngOnInit(): void {\n        this.updateVariables();\n\n        super.ngOnInit();\n    }\n\n    public ngOnChanges(changes: SimpleChanges) {\n        const placeholderChange = changes.placeholder && changes.placeholder.currentValue;\n        if (!placeholderChange && this.scale) this.placeholder = `0${this.decimalSeparator}${\"\".padEnd(this.scale, \"0\")}`;\n\n        if (\n            changes.scale ||\n            changes.decimalSeparator ||\n            changes.thousandsSeparator ||\n            changes.alignTo ||\n            changes.precision ||\n            changes.allowNegative\n        ) {\n            this.updateVariables();\n        }\n    }\n\n    /**\n     * Update the options values according to the directive input values.\n     */\n    private updateVariables(): void {\n        this.options = {\n            align: this.alignTo,\n            decimal: this.decimalSeparator,\n            thousands: this.thousandsSeparator,\n            precision: this.scale || 0,\n            prefix: \"\",\n            suffix: \"\",\n            allowNegative: this.allowNegative,\n        };\n        this.calculateMaxLength();\n    }\n\n    /**\n     * Responsible to calculate the field maximum length considering the separators.\n     */\n    private calculateMaxLength(): void {\n        const decSepLength = this.decimalSeparator.length;\n        const thoSepLength = this.thousandsSeparator.length;\n\n        let maxLength = this.precision + (this.scale ? decSepLength : 0);\n        maxLength += Math.ceil((this.precision - (this.scale ? this.scale : 0)) / 3 - 1) * thoSepLength;\n\n        this.maxLength = maxLength;\n    }\n\n    /**\n     * Prevents the default CurrencyMask behavior when typed a incorrect value.\n     * By default the CurrencyMask inputs the mask value to the component value when typed a incorrect value.\n     */\n    public handleKeypress(event: KeyboardEvent): void {\n        const negativeOperator = \"-\";\n        const { key } = event;\n\n        if (\n            this.thousandsSeparator.includes(key) ||\n            this.decimalSeparator.includes(key) ||\n            negativeOperator.includes(key) ||\n            this.regex.test(key) ||\n            \"Enter\".toUpperCase() === key.toUpperCase()\n        )\n            super.handleKeypress(event);\n        else event.preventDefault();\n    }\n\n    private onLocaleService(): void {\n        this.localeService\n            .getLocale()\n            .pipe(first())\n            .subscribe(() => {\n                this.decimalSeparator = this.decimalSeparator ?? this.localeService.getDecimalSeparator();\n                this.thousandsSeparator = this.thousandsSeparator ?? this.localeService.getGroupingSeparator();\n            });\n    }\n}\n"]}
|
|
162
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-input.directive.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/number-input/number-input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Input,\n    KeyValueDiffers,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Output,\n    SimpleChanges,\n} from \"@angular/core\";\nimport { NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { LocaleService } from \"../locale/locale.service\";\nimport { CurrencyMaskDirective } from \"ng2-currency-mask\";\nimport { first } from \"rxjs/operators\";\n\n/**\n * @deprecated Should use 'AlignmentOptions' from @seniorsistemas/ng2-currency-mask instead\n */\nexport enum NumberAlignmentOption {\n    RIGHT = \"right\",\n    LEFT = \"left\",\n}\n\n/**\n * @deprecated Should use BigNumberInput directive instead\n */\n@Directive({\n    selector: \"input[sNumberInput]\",\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => NumberInputDirective),\n            multi: true,\n        },\n    ],\n})\nexport class NumberInputDirective extends CurrencyMaskDirective implements OnInit, OnChanges, OnDestroy {\n    @Input()\n    public precision = 15;\n\n    @Input()\n    public scale = 0;\n\n    @Input()\n    public decimalSeparator: string;\n\n    @Input()\n    public thousandsSeparator: string;\n\n    @Input()\n    public alignTo = NumberAlignmentOption.LEFT;\n\n    @Input()\n    public allowNegative = true;\n\n    @Input()\n    @HostBinding(\"attr.placeholder\")\n    public placeholder: string;\n\n    @HostBinding(\"attr.maxLength\")\n    public maxLength: number;\n\n    @Output()\n    public pasteRejected = new EventEmitter<string>();\n\n    private _maxLength: number;\n\n    private pasteListener: any;\n    private keypressListener: any;\n\n    constructor(\n        _keyValueDiffers: KeyValueDiffers,\n        private readonly _elementRef: ElementRef,\n        private readonly localeService: LocaleService\n    ) {\n        super(null, _elementRef, _keyValueDiffers);\n\n        this.onLocaleService();\n    }\n\n    public ngOnInit(): void {\n        this.updateVariables();\n\n        super.ngOnInit();\n\n        this.pasteListener = this._onPaste.bind(this);\n        this._elementRef.nativeElement.addEventListener(\"paste\", this.pasteListener);\n\n        this.keypressListener = this._onKeypress.bind(this);\n        this._elementRef.nativeElement.addEventListener(\"keypress\", this.keypressListener);\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        const placeholderChange = changes.placeholder && changes.placeholder.currentValue;\n        if (!placeholderChange && this.scale) this.placeholder = `0${this.decimalSeparator}${\"\".padEnd(this.scale, \"0\")}`;\n\n        if (\n            changes.scale ||\n            changes.decimalSeparator ||\n            changes.thousandsSeparator ||\n            changes.alignTo ||\n            changes.precision ||\n            changes.allowNegative\n        ) {\n            this.updateVariables();\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this._elementRef.nativeElement.removeEventListener(\"paste\", this.pasteListener);\n        this._elementRef.nativeElement.removeEventListener(\"keypress\", this.keypressListener);\n    }\n\n    private _onPaste(event: ClipboardEvent): void {\n        const pastedText = event.clipboardData?.getData(\"text\") ?? \"\";\n        const numericText = pastedText.replace(new RegExp(`\\\\${this.thousandsSeparator}`, \"g\"), \"\").replace(this.decimalSeparator, \".\");\n        const [intPart, decimalPart = \"\"] = numericText.split(\".\");\n        const totalDigits = intPart.replace(/\\D/g, \"\").length + decimalPart.slice(0, this.scale).length;\n\n        if (totalDigits > this.precision) {\n            event.preventDefault();\n            event.stopPropagation();\n            this.pasteRejected.emit(pastedText);\n        }\n    }\n\n    private _onKeypress(event: KeyboardEvent): void {\n        const code = event.code;\n\n        if (code === \"Minus\" || code === \"NumpadSubtract\") {\n            if (this.allowNegative) {\n                this.maxLength = this._maxLength + 1;\n            }\n        } else if (code === \"Equal\" || code === \"NumpadAdd\") {\n            this.maxLength = this._maxLength;\n        }\n    }\n\n    /**\n     * Update the options values according to the directive input values.\n     */\n    private updateVariables(): void {\n        this.options = {\n            align: this.alignTo,\n            decimal: this.decimalSeparator,\n            thousands: this.thousandsSeparator,\n            precision: this.scale || 0,\n            prefix: \"\",\n            suffix: \"\",\n            allowNegative: this.allowNegative,\n        };\n        this.calculateMaxLength();\n    }\n\n    /**\n     * Responsible to calculate the field maximum length considering the separators.\n     */\n    private calculateMaxLength(): void {\n        const decSepLength = this.decimalSeparator.length;\n        const thoSepLength = this.thousandsSeparator.length;\n\n        let maxLength = this.precision + (this.scale ? decSepLength : 0);\n        maxLength += Math.ceil((this.precision - (this.scale ? this.scale : 0)) / 3 - 1) * thoSepLength;\n\n        this._maxLength = maxLength;\n        this.maxLength = maxLength;\n    }\n\n    private onLocaleService(): void {\n        this.localeService\n            .getLocale()\n            .pipe(first())\n            .subscribe(() => {\n                this.decimalSeparator = this.decimalSeparator ?? this.localeService.getDecimalSeparator();\n                this.thousandsSeparator = this.thousandsSeparator ?? this.localeService.getGroupingSeparator();\n            });\n    }\n}\n"]}
|
|
@@ -32,7 +32,7 @@ let TextAreaComponent = TextAreaComponent_1 = class TextAreaComponent {
|
|
|
32
32
|
return this._inputStyle;
|
|
33
33
|
}
|
|
34
34
|
set inputStyle(value) {
|
|
35
|
-
this._inputStyle = Object.assign(Object.assign({}, this._inputStyle)
|
|
35
|
+
this._inputStyle = Object.assign(Object.assign({}, value), this._inputStyle);
|
|
36
36
|
}
|
|
37
37
|
writeValue(obj) {
|
|
38
38
|
this.value = obj;
|
|
@@ -98,4 +98,4 @@ TextAreaComponent = TextAreaComponent_1 = __decorate([
|
|
|
98
98
|
})
|
|
99
99
|
], TextAreaComponent);
|
|
100
100
|
export { TextAreaComponent };
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1hcmVhLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3JzaXN0ZW1hcy9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL3RleHQtYXJlYS90ZXh0LWFyZWEvdGV4dC1hcmVhLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLFVBQVUsRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZHLE9BQU8sRUFBd0IsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQWN6RSxJQUFhLGlCQUFpQix5QkFBOUIsTUFBYSxpQkFBaUI7SUF3QzVCLFlBQTZCLEdBQXNCO1FBQXRCLFFBQUcsR0FBSCxHQUFHLENBQW1CO1FBdkNuRCxhQUFRLEdBQTRCLEdBQUcsRUFBRSxHQUFHLENBQUMsQ0FBQztRQUM5QyxjQUFTLEdBQTRCLEdBQUcsRUFBRSxHQUFHLENBQUMsQ0FBQztRQUMvQyxhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLFVBQUssR0FBRyxFQUFFLENBQUM7UUFnQkYsWUFBTyxHQUFHLFlBQVksSUFBSSxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUM7UUFDdEMsU0FBSSxHQUFHLENBQUMsQ0FBQztRQUNULHNCQUFpQixHQUFHLEtBQUssQ0FBQztRQUUzQixnQkFBVyxHQUFpQztZQUNsRCxNQUFNLEVBQUUsVUFBVTtTQUNuQixDQUFBO1FBVVEsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUUxQixtQkFBYyxHQUFHLEtBQUssQ0FBQztJQUVnQyxDQUFDO0lBaEN4RCxJQUFXLGVBQWU7UUFDeEIsT0FBTyxJQUFJLENBQUMsZ0JBQWdCLENBQUM7SUFDL0IsQ0FBQztJQUVELElBQVcsZUFBZSxDQUFDLEtBQXNDO1FBQy9ELElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxLQUFLLENBQUM7UUFDOUIsVUFBVSxDQUFDLEdBQUcsRUFBRTtZQUNkLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDO1lBQzNCLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7UUFDM0IsQ0FBQyxDQUFDLENBQUE7SUFDSixDQUFDO0lBU1EsSUFBSSxVQUFVO1FBQ3JCLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUMxQixDQUFDO0lBQ0QsSUFBSSxVQUFVLENBQUMsS0FBbUM7UUFDaEQsSUFBSSxDQUFDLFdBQVcsbUNBQ1gsS0FBSyxHQUNMLElBQUksQ0FBQyxXQUFXLENBQ3BCLENBQUM7SUFDSixDQUFDO0lBT0QsVUFBVSxDQUFDLEdBQVc7UUFDcEIsSUFBSSxDQUFDLEtBQUssR0FBRyxHQUFHLENBQUM7SUFDbkIsQ0FBQztJQUVELGdCQUFnQixDQUFDLEVBQTJCO1FBQzFDLElBQUksQ0FBQyxRQUFRLEdBQUcsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxFQUFjO1FBQzlCLElBQUksQ0FBQyxTQUFTLEdBQUcsRUFBRSxDQUFDO0lBQ3RCLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxVQUFtQjtRQUNsQyxJQUFJLENBQUMsUUFBUSxHQUFHLFVBQVUsQ0FBQztJQUM3QixDQUFDO0lBRUQsUUFBUSxDQUFDLEtBQWE7UUFDcEIsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2pCLE9BQU87U0FDUjtRQUNELElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzVCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzFCLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzdCLENBQUM7SUFFRCxvQkFBb0IsQ0FBQyxjQUFzQjtRQUN6QyxJQUFJLENBQUMsUUFBUSxDQUFDLGNBQWMsQ0FBQyxDQUFDO0lBQ2hDLENBQUM7Q0FDRixDQUFBOztZQS9CbUMsaUJBQWlCOztBQWhDbkQ7SUFEQyxTQUFTLENBQUMsVUFBVSxFQUFFLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxDQUFDO3dEQUczQztBQVVRO0lBQVIsS0FBSyxFQUFFO2tEQUF1QztBQUN0QztJQUFSLEtBQUssRUFBRTsrQ0FBVTtBQUNUO0lBQVIsS0FBSyxFQUFFOzREQUEyQjtBQUMxQjtJQUFSLEtBQUssRUFBRTtvREFBNEI7QUFJM0I7SUFBUixLQUFLLEVBQUU7bURBRVA7QUFPUTtJQUFSLEtBQUssRUFBRTttREFBa0I7QUFwQ2YsaUJBQWlCO0lBWjdCLFNBQVMsQ0FBQztRQUNULFFBQVEsRUFBRSxZQUFZO1FBQ3RCLG0xQkFBeUM7UUFFekMsU0FBUyxFQUFFO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxtQkFBaUIsQ0FBQztnQkFDaEQsS0FBSyxFQUFFLElBQUk7YUFDWjtTQUNGOztLQUNGLENBQUM7R0FDVyxpQkFBaUIsQ0F1RTdCO1NBdkVZLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIEVsZW1lbnRSZWYsIGZvcndhcmRSZWYsIElucHV0LCBWaWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncy10ZXh0YXJlYScsXG4gIHRlbXBsYXRlVXJsOiAnLi90ZXh0LWFyZWEuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi90ZXh0LWFyZWEuY29tcG9uZW50LnNjc3MnXSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBUZXh0QXJlYUNvbXBvbmVudCksXG4gICAgICBtdWx0aTogdHJ1ZSxcbiAgICB9LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBUZXh0QXJlYUNvbXBvbmVudCBpbXBsZW1lbnRzIENvbnRyb2xWYWx1ZUFjY2Vzc29yIHtcbiAgb25DaGFuZ2U6ICh2YWx1ZTogc3RyaW5nKSA9PiB2b2lkID0gKCkgPT4geyB9O1xuICBvblRvdWNoZWQ6ICh2YWx1ZTogc3RyaW5nKSA9PiB2b2lkID0gKCkgPT4geyB9O1xuICBkaXNhYmxlZCA9IGZhbHNlO1xuICB2YWx1ZSA9ICcnO1xuICBwcml2YXRlIF90ZXh0QXJlYUVsZW1lbnQ6IEVsZW1lbnRSZWY8SFRNTFRleHRBcmVhRWxlbWVudD47XG5cbiAgQFZpZXdDaGlsZCgndGV4dEFyZWEnLCB7IHJlYWQ6IEVsZW1lbnRSZWYgfSlcbiAgcHVibGljIGdldCB0ZXh0QXJlYUVsZW1lbnQoKTogRWxlbWVudFJlZjxIVE1MVGV4dEFyZWFFbGVtZW50PiB7XG4gICAgcmV0dXJuIHRoaXMuX3RleHRBcmVhRWxlbWVudDtcbiAgfVxuXG4gIHB1YmxpYyBzZXQgdGV4dEFyZWFFbGVtZW50KHZhbHVlOiBFbGVtZW50UmVmPEhUTUxUZXh0QXJlYUVsZW1lbnQ+KSB7XG4gICAgdGhpcy5fdGV4dEFyZWFFbGVtZW50ID0gdmFsdWU7XG4gICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICB0aGlzLnJlbmRlclRleHRBcmVhID0gdHJ1ZTtcbiAgICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcbiAgICB9KVxuICB9XG5cbiAgQElucHV0KCkgaW5wdXRJZCA9IGB0ZXh0YXJlYS0ke01hdGgucmFuZG9tKCl9YDtcbiAgQElucHV0KCkgcm93cyA9IDU7XG4gIEBJbnB1dCgpIHNwZWVjaFJlY29nbml0aW9uID0gZmFsc2U7XG4gIEBJbnB1dCgpIGtleUZpbHRlcjogc3RyaW5nIHwgUmVnRXhwO1xuICBwcml2YXRlIF9pbnB1dFN0eWxlOiBQYXJ0aWFsPENTU1N0eWxlRGVjbGFyYXRpb24+ID0ge1xuICAgIHJlc2l6ZTogJ3ZlcnRpY2FsJ1xuICB9XG4gIEBJbnB1dCgpIGdldCBpbnB1dFN0eWxlKCk6IFBhcnRpYWw8Q1NTU3R5bGVEZWNsYXJhdGlvbj4ge1xuICAgIHJldHVybiB0aGlzLl9pbnB1dFN0eWxlO1xuICB9XG4gIHNldCBpbnB1dFN0eWxlKHZhbHVlOiBQYXJ0aWFsPENTU1N0eWxlRGVjbGFyYXRpb24+KSB7XG4gICAgdGhpcy5faW5wdXRTdHlsZSA9IHtcbiAgICAgIC4uLnZhbHVlLFxuICAgICAgLi4udGhpcy5faW5wdXRTdHlsZSxcbiAgICB9O1xuICB9XG4gIEBJbnB1dCgpIHJlYWRPbmx5ID0gZmFsc2U7XG5cbiAgcmVuZGVyVGV4dEFyZWEgPSBmYWxzZTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHsgfVxuXG4gIHdyaXRlVmFsdWUob2JqOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLnZhbHVlID0gb2JqO1xuICB9XG5cbiAgcmVnaXN0ZXJPbkNoYW5nZShmbjogKHZhbHVlOiBzdHJpbmcpID0+IHZvaWQpOiB2b2lkIHtcbiAgICB0aGlzLm9uQ2hhbmdlID0gZm47XG4gIH1cblxuICByZWdpc3Rlck9uVG91Y2hlZChmbjogKCkgPT4gdm9pZCk6IHZvaWQge1xuICAgIHRoaXMub25Ub3VjaGVkID0gZm47XG4gIH1cblxuICBzZXREaXNhYmxlZFN0YXRlKGlzRGlzYWJsZWQ6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICB0aGlzLmRpc2FibGVkID0gaXNEaXNhYmxlZDtcbiAgfVxuXG4gIHNldFZhbHVlKHZhbHVlOiBzdHJpbmcpIHtcbiAgICBpZiAodGhpcy5kaXNhYmxlZCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICB0aGlzLnZhbHVlID0gdmFsdWU7XG4gICAgdGhpcy53cml0ZVZhbHVlKHRoaXMudmFsdWUpO1xuICAgIHRoaXMub25DaGFuZ2UodGhpcy52YWx1ZSk7XG4gICAgdGhpcy5vblRvdWNoZWQodGhpcy52YWx1ZSk7XG4gIH1cblxuICBoYW5kbGVSZWNvZ25pemVkVGV4dChyZWNvZ25pemVkVGV4dDogc3RyaW5nKSB7XG4gICAgdGhpcy5zZXRWYWx1ZShyZWNvZ25pemVkVGV4dCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -13,6 +13,7 @@ let TextAreaIAComponent = TextAreaIAComponent_1 = class TextAreaIAComponent {
|
|
|
13
13
|
this._iassistService = _iassistService;
|
|
14
14
|
this._formBuilder = _formBuilder;
|
|
15
15
|
this._translateService = _translateService;
|
|
16
|
+
this.speechRecognition = false;
|
|
16
17
|
this.isVisible = false;
|
|
17
18
|
this.isLoading = false;
|
|
18
19
|
}
|
|
@@ -75,6 +76,7 @@ let TextAreaIAComponent = TextAreaIAComponent_1 = class TextAreaIAComponent {
|
|
|
75
76
|
type: FieldType.Text,
|
|
76
77
|
label: this._translateService.instant("platform.angular_components.context"),
|
|
77
78
|
size: { sm: 12, md: 12, lg: 12, xl: 12 },
|
|
79
|
+
speechRecognition: this.speechRecognition
|
|
78
80
|
}),
|
|
79
81
|
];
|
|
80
82
|
}
|
|
@@ -110,10 +112,13 @@ __decorate([
|
|
|
110
112
|
__decorate([
|
|
111
113
|
Input()
|
|
112
114
|
], TextAreaIAComponent.prototype, "cols", void 0);
|
|
115
|
+
__decorate([
|
|
116
|
+
Input()
|
|
117
|
+
], TextAreaIAComponent.prototype, "speechRecognition", void 0);
|
|
113
118
|
TextAreaIAComponent = TextAreaIAComponent_1 = __decorate([
|
|
114
119
|
Component({
|
|
115
120
|
selector: "s-text-area-ia",
|
|
116
|
-
template: "<s-loading-state\n [loading]=\"isLoading\"\n [blockWindow]=\"true\">\n</s-loading-state>\n\n<p-dialog\n [(visible)]=\"isVisible\"\n [modal]=\"true\"\n [style]=\"{ width: '50vw' }\"\n [draggable]=\"false\"\n [resizable]=\"false\"\n (onHide)=\"onHideDialog()\">\n <p-header>\n <div class=\"dialog-header\">\n <span class=\"iassist-icon\">\n <ng-container [ngTemplateOutlet]=\"iassistIcon\"></ng-container>\n </span>\n IAssist - Content Generator\n </div>\n </p-header>\n <s-dynamic-form\n [fields]=\"fields\"\n [form]=\"formGroup\">\n </s-dynamic-form>\n <p-footer>\n <div class=\"footer-content\">\n <s-button\n id=\"-submit-button\"\n type=\"button\"\n [label]=\"'platform.angular_components.generate_text' | translate\"\n (onClick)=\"submitContext()\"\n sTooltip=\"(ALT + SHIFT + S)\"\n showDelay=\"500\">\n </s-button>\n <s-button\n id=\"-cancel-button\"\n type=\"button\"\n priority=\"link\"\n [label]=\"'platform.angular_components.cancel' | translate\"\n (onClick)=\"hideDialog()\"\n sTooltip=\"(ALT + SHIFT + C)\"\n showDelay=\"500\">\n </s-button>\n </div>\n </p-footer>\n</p-dialog>\n\n<div class=\"textarea-ia\">\n <textarea\n [
|
|
121
|
+
template: "<s-loading-state\n [loading]=\"isLoading\"\n [blockWindow]=\"true\">\n</s-loading-state>\n\n<p-dialog\n [(visible)]=\"isVisible\"\n [modal]=\"true\"\n [style]=\"{ width: '50vw' }\"\n [draggable]=\"false\"\n [resizable]=\"false\"\n (onHide)=\"onHideDialog()\">\n <p-header>\n <div class=\"dialog-header\">\n <span class=\"iassist-icon\">\n <ng-container [ngTemplateOutlet]=\"iassistIcon\"></ng-container>\n </span>\n IAssist - Content Generator\n </div>\n </p-header>\n <s-dynamic-form\n [fields]=\"fields\"\n [form]=\"formGroup\">\n </s-dynamic-form>\n <p-footer>\n <div class=\"footer-content\">\n <s-button\n id=\"-submit-button\"\n type=\"button\"\n [label]=\"'platform.angular_components.generate_text' | translate\"\n (onClick)=\"submitContext()\"\n sTooltip=\"(ALT + SHIFT + S)\"\n showDelay=\"500\">\n </s-button>\n <s-button\n id=\"-cancel-button\"\n type=\"button\"\n priority=\"link\"\n [label]=\"'platform.angular_components.cancel' | translate\"\n (onClick)=\"hideDialog()\"\n sTooltip=\"(ALT + SHIFT + C)\"\n showDelay=\"500\">\n </s-button>\n </div>\n </p-footer>\n</p-dialog>\n\n<div class=\"textarea-ia\">\n <s-textarea\n [inputId]=\"id\"\n [rows]=\"rows\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"onValueChange($event)\"\n [readOnly]=\"readonly\"\n [speechRecognition]=\"speechRecognition\"\n ></s-textarea>\n <button\n class=\"iassist-button\"\n [class.speech-recognition]=\"speechRecognition\"\n (click)=\"showDialog()\"\n sTooltip=\"IAssist - Content Generator\">\n <ng-container [ngTemplateOutlet]=\"iassistIcon\"></ng-container>\n </button>\n</div>\n\n<ng-template #iassistIcon>\n <svg style=\"width: 100%; height: 100%;\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M5.81451 18.1054L5.99593 17.6059L7.52166 13.4099L7.60877 13.1726L7.61277 13.1614L7.94285 12.2543L8.01159 12.0648L8.05394 11.949L5.2998 8.52426L5.02726 8.18379C5.00569 8.15821 4.9881 8.13104 4.97292 8.10226C4.90099 7.9632 4.85063 7.81294 4.82186 7.6531C4.73075 7.1344 4.90418 6.60771 5.28382 6.24326C5.29421 6.23447 5.3038 6.22567 5.31419 6.21688L5.47164 6.0914L9.3439 3.00238L9.5469 2.84094L9.57088 2.82096L10.4101 2.15041L11.8007 1.04188C11.2181 0.925188 10.6163 0.863647 10.0001 0.863647C4.95374 0.863647 0.863281 4.9541 0.863281 9.99963C0.863281 13.5346 2.87254 16.5989 5.80971 18.1182\" fill=\"#0FA389\"/>\n <path d=\"M14.099 1.83472L13.9495 2.24632L11.997 7.61074L11.9427 7.7594L11.9003 7.87369L14.7448 11.4103C14.7463 11.4127 14.7479 11.4143 14.7495 11.4167L14.9414 11.654C14.9541 11.67 14.9661 11.6868 14.9765 11.7044C15.0764 11.8698 15.1444 12.0505 15.1779 12.2431C15.273 12.7826 15.0812 13.3284 14.676 13.6897C14.656 13.7129 14.6345 13.7344 14.6105 13.7536L11.8563 15.9507L11.6789 16.0922L11.6022 16.1537L10.7406 16.8402V16.841L10.3937 17.1176L9.85747 17.5452L9.39951 17.9112L8.11035 18.9398C8.72016 19.0677 9.35155 19.1364 9.99973 19.1364C15.0461 19.1364 19.1365 15.046 19.1365 9.99964C19.1365 6.42789 17.0857 3.33727 14.099 1.83472Z\" fill=\"#0FA389\"/>\n <path d=\"M14.7287 12.3222C14.7047 12.1832 14.6551 12.0545 14.5864 11.941L14.3954 11.7036C14.3954 11.7036 14.3946 11.7028 14.3938 11.7028L11.3839 7.96005L10.5031 6.86511L10.4256 6.7676L9.03255 5.03487L8.83674 4.79191C8.79278 4.71678 8.75681 4.63446 8.73204 4.54814C8.72085 4.51058 8.71286 4.47222 8.70566 4.43465C8.68568 4.32196 8.68408 4.21007 8.69847 4.10217L8.62334 4.16291L8.44511 4.30438L5.75731 6.44871L5.60066 6.57339C5.34011 6.82275 5.20584 7.19279 5.27218 7.57482C5.29296 7.68751 5.32892 7.79541 5.37927 7.89292C5.37927 7.89292 5.37927 7.89292 5.38007 7.89371L5.6566 8.23818L8.57139 11.8627L8.63293 11.9394L9.53047 13.0559L9.59041 13.1303L9.98363 13.6186L11.0178 14.9046C11.0186 14.9054 11.0194 14.9069 11.0202 14.9077L11.1361 15.0516V15.0524C11.2184 15.1755 11.2768 15.317 11.3048 15.4728C11.3239 15.5807 11.3263 15.6878 11.3143 15.7925L11.3175 15.7965L11.3943 15.735L11.5717 15.5935L14.3266 13.3964L14.3218 13.3908C14.6335 13.1438 14.8022 12.7394 14.7287 12.3222Z\" fill=\"#F3F3F5\"/>\n <path d=\"M10.6822 15.0082C10.6814 15.0074 10.6806 15.0058 10.6806 15.005L10.5672 14.8643L10.3809 14.6325L10.3282 14.567L10.2211 14.4335L9.40028 13.4129L9.32835 13.3242L8.77289 12.6345L8.68098 12.5194L8.44121 12.2205L8.37168 12.4099L8.04159 13.317L8.0376 13.329L7.95128 13.5664L6.42475 17.7623L6.24333 18.2618L5.90605 19.1881L5.73262 19.6645C5.73182 19.6661 5.73102 19.6677 5.73102 19.6685C5.72863 19.6749 5.72703 19.6821 5.72543 19.6885C5.71584 19.7228 5.71424 19.758 5.72063 19.7948C5.74461 19.929 5.87329 20.0193 6.00836 19.9962C6.04112 19.9898 6.07229 19.9778 6.09867 19.9602C6.09867 19.9602 6.09947 19.9602 6.10027 19.9594L6.14103 19.9266L7.39422 18.9268L9.11496 17.5537L9.57292 17.1877L10.1092 16.7601L10.4561 16.4827L10.4537 16.4811C10.7582 16.2382 10.9236 15.8402 10.8509 15.4294C10.8237 15.2735 10.7654 15.1313 10.6822 15.0082Z\" fill=\"#0C847B\"/>\n <path d=\"M9.17644 4.56325C9.2124 4.68713 9.26915 4.80062 9.34268 4.90053C9.34348 4.90053 9.34428 4.90213 9.34428 4.90213L9.40342 4.97645C9.40502 4.97805 9.40582 4.97885 9.40662 4.98045L9.56806 5.17946L9.64878 5.28096L9.67915 5.31932L9.8414 5.51993L10.5559 6.40947L10.7054 6.59569L11.2169 7.23188L11.5142 7.60192L11.5693 7.45247L13.5202 2.08964L14.1596 0.332135C14.1596 0.330536 14.1604 0.328139 14.1612 0.32654C14.174 0.288177 14.1772 0.246617 14.17 0.205058C14.1468 0.0699879 14.0182 -0.0195258 13.8823 0.00365186C13.8407 0.0116442 13.8024 0.028428 13.7712 0.0540033L12.578 1.00589L12.498 1.06982L10.6958 2.50844L9.85658 3.17819L9.8326 3.19737L9.6296 3.35961L9.45297 3.50028C9.2116 3.73925 9.08692 4.08931 9.15006 4.44976C9.15726 4.48813 9.16525 4.52649 9.17644 4.56325Z\" fill=\"#0C847B\"/>\n </svg>\n</ng-template>\n",
|
|
117
122
|
providers: [
|
|
118
123
|
{
|
|
119
124
|
provide: NG_VALUE_ACCESSOR,
|
|
@@ -121,8 +126,8 @@ TextAreaIAComponent = TextAreaIAComponent_1 = __decorate([
|
|
|
121
126
|
multi: true,
|
|
122
127
|
},
|
|
123
128
|
],
|
|
124
|
-
styles: [".footer-content{display:-ms-flexbox;display:flex;-ms-flex-positive:0;flex-grow:0}.textarea-ia{display:-ms-flexbox;display:flex;-ms-flex-align:end;align-items:flex-end;gap:8px}.textarea-ia
|
|
129
|
+
styles: [".footer-content{display:-ms-flexbox;display:flex;-ms-flex-positive:0;flex-grow:0}.textarea-ia{display:-ms-flexbox;display:flex;-ms-flex-align:end;align-items:flex-end;gap:8px}.textarea-ia s-textarea{width:100%}.iassist-button{display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center;-ms-flex-align:center;align-items:center;border:none;border-radius:50%;box-shadow:none;cursor:pointer;height:32px;width:32px}.dialog-header{display:-ms-flexbox;display:flex;gap:12px}.dialog-header .iassist-icon{display:block;height:24px;width:24px}.speech-recognition{margin-bottom:12.5px}"]
|
|
125
130
|
})
|
|
126
131
|
], TextAreaIAComponent);
|
|
127
132
|
export { TextAreaIAComponent };
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
133
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-area-ia.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/text-area-ia/text-area-ia.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpErrorResponse } from \"@angular/common/http\";\nimport { Component, forwardRef, Input, OnInit } from \"@angular/core\";\nimport { ControlValueAccessor, FormBuilder, FormGroup, NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\nimport { TranslateService } from \"@ngx-translate/core\";\nimport { throwError } from \"rxjs\";\nimport { catchError } from \"rxjs/operators\";\n\nimport { FieldType, FormField } from \"../dynamic-form\";\nimport { IAssistService } from \"../dynamic-form/services/IAssist/iassist.service\";\nimport { IAssistResponse } from \"../dynamic-form/services/IAssist/models\";\n\n@Component({\n    selector: \"s-text-area-ia\",\n    templateUrl: \"./text-area-ia.component.html\",\n    styleUrls: [\"./text-area-ia.component.scss\"],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => TextAreaIAComponent),\n            multi: true,\n        },\n    ],\n})\nexport class TextAreaIAComponent implements OnInit, ControlValueAccessor {\n    @Input()\n    public id: string;\n\n    @Input()\n    public label: string;\n\n    @Input()\n    public placeholder: string;\n\n    @Input()\n    public prompt: string;\n\n    @Input()\n    public readonly: boolean;\n\n    @Input()\n    public rows: number;\n\n    @Input()\n    public cols: number;\n\n    @Input()\n    speechRecognition = false\n\n    public fields: FormField[];\n    public formGroup: FormGroup;\n    public isVisible = false;\n    public isLoading = false;\n    public value: string;\n\n    private _isDisabled: boolean;\n    private _onChange: (value: string) => void;\n    private _onTouched: () => void;\n\n    constructor(\n        private readonly _iassistService: IAssistService, // Mover pra uma pasta global\n        private readonly _formBuilder: FormBuilder,\n        private readonly _translateService: TranslateService,\n    ) { }\n\n    public ngOnInit(): void {\n        this._createDialogFields();\n        this._createDialogFormGroup();\n    }\n\n    public writeValue(value: string): void {\n        this.value = value;\n    }\n\n    public registerOnChange(onChange: (value: string) => void): void {\n        this._onChange = onChange;\n    }\n\n    public registerOnTouched(onTouched: () => void): void {\n        this._onTouched = onTouched;\n    }\n\n    public setDisabledState?(isDisabled: boolean): void {\n        this._isDisabled = isDisabled;\n    }\n\n    public onValueChange(value: string): void {\n        this.value = value;\n        this._onChange?.(value);\n    }\n\n    public showDialog(): void {\n        this.isVisible = true;\n        this._onTouched();\n    }\n\n    public hideDialog(): void {\n        this.isVisible = false;\n    }\n\n    public onHideDialog(): void {\n        this.formGroup.get(\"context\").setValue(\"\");\n    }\n\n    public submitContext(): void {\n        const context = this.formGroup.get(\"context\");\n        this.isLoading = true;\n\n        this._iassistService\n            .askIA(context.value, {\n                id: this.id,\n                label: this.label,\n                placeholder: this.placeholder,\n                prompt: this.prompt,\n            })\n            .pipe(\n                catchError((err: HttpErrorResponse) => {\n                    this.isLoading = false;\n                    return throwError(err);\n                })\n            )\n            .subscribe((res: IAssistResponse) => {\n                this.value = res.text;\n                this._onChange(this.value);\n                this.isLoading = false;\n            });\n\n        this.hideDialog();\n    }\n\n    private _createDialogFields(): void {\n        this.fields = [\n            new FormField({\n                name: \"context\",\n                type: FieldType.Text,\n                label: this._translateService.instant(\"platform.angular_components.context\"),\n                size: { sm: 12, md: 12, lg: 12, xl: 12 },\n                speechRecognition: this.speechRecognition\n            }),\n        ];\n    }\n\n    private _createDialogFormGroup(): void {\n        this.formGroup = this._formBuilder.group({\n            context: [\"\"],\n        });\n    }\n}\n"]}
|
|
@@ -4,11 +4,11 @@ import { NgModule } from "@angular/core";
|
|
|
4
4
|
import { FormsModule, ReactiveFormsModule } from "@angular/forms";
|
|
5
5
|
import { TranslateModule } from "@ngx-translate/core";
|
|
6
6
|
import { DialogModule } from "primeng/dialog";
|
|
7
|
-
import { InputTextareaModule } from "primeng/inputtextarea";
|
|
8
7
|
import { ButtonModule } from "../button/button.module";
|
|
9
8
|
import { DynamicFormModule } from "../dynamic-form/dynamic-form.module";
|
|
10
9
|
import { LoadingStateModule } from "../loading-state/loading-state.module";
|
|
11
10
|
import { TextAreaIAComponent } from "./text-area-ia.component";
|
|
11
|
+
import { TextAreaModule } from "../text-area/text-area.module";
|
|
12
12
|
let TextAreaIAModule = class TextAreaIAModule {
|
|
13
13
|
};
|
|
14
14
|
TextAreaIAModule = __decorate([
|
|
@@ -19,14 +19,14 @@ TextAreaIAModule = __decorate([
|
|
|
19
19
|
ReactiveFormsModule,
|
|
20
20
|
TranslateModule,
|
|
21
21
|
DialogModule,
|
|
22
|
-
InputTextareaModule,
|
|
23
22
|
ButtonModule,
|
|
24
23
|
DynamicFormModule,
|
|
25
24
|
LoadingStateModule,
|
|
25
|
+
TextAreaModule
|
|
26
26
|
],
|
|
27
27
|
declarations: [TextAreaIAComponent],
|
|
28
28
|
exports: [TextAreaIAComponent],
|
|
29
29
|
})
|
|
30
30
|
], TextAreaIAModule);
|
|
31
31
|
export { TextAreaIAModule };
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1hcmVhLWlhLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3JzaXN0ZW1hcy9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL3RleHQtYXJlYS1pYS90ZXh0LWFyZWEtaWEubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFbEUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUU5QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDeEUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDM0UsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDL0QsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBaUIvRCxJQUFhLGdCQUFnQixHQUE3QixNQUFhLGdCQUFnQjtDQUFJLENBQUE7QUFBcEIsZ0JBQWdCO0lBZjVCLFFBQVEsQ0FBQztRQUNOLE9BQU8sRUFBRTtZQUNMLFlBQVk7WUFDWixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLGVBQWU7WUFDZixZQUFZO1lBQ1osWUFBWTtZQUNaLGlCQUFpQjtZQUNqQixrQkFBa0I7WUFDbEIsY0FBYztTQUNqQjtRQUNELFlBQVksRUFBRSxDQUFDLG1CQUFtQixDQUFDO1FBQ25DLE9BQU8sRUFBRSxDQUFDLG1CQUFtQixDQUFDO0tBQ2pDLENBQUM7R0FDVyxnQkFBZ0IsQ0FBSTtTQUFwQixnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xuXG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tIFwiQG5neC10cmFuc2xhdGUvY29yZVwiO1xuaW1wb3J0IHsgRGlhbG9nTW9kdWxlIH0gZnJvbSBcInByaW1lbmcvZGlhbG9nXCI7XG5cbmltcG9ydCB7IEJ1dHRvbk1vZHVsZSB9IGZyb20gXCIuLi9idXR0b24vYnV0dG9uLm1vZHVsZVwiO1xuaW1wb3J0IHsgRHluYW1pY0Zvcm1Nb2R1bGUgfSBmcm9tIFwiLi4vZHluYW1pYy1mb3JtL2R5bmFtaWMtZm9ybS5tb2R1bGVcIjtcbmltcG9ydCB7IExvYWRpbmdTdGF0ZU1vZHVsZSB9IGZyb20gXCIuLi9sb2FkaW5nLXN0YXRlL2xvYWRpbmctc3RhdGUubW9kdWxlXCI7XG5pbXBvcnQgeyBUZXh0QXJlYUlBQ29tcG9uZW50IH0gZnJvbSBcIi4vdGV4dC1hcmVhLWlhLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgVGV4dEFyZWFNb2R1bGUgfSBmcm9tIFwiLi4vdGV4dC1hcmVhL3RleHQtYXJlYS5tb2R1bGVcIjtcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgRm9ybXNNb2R1bGUsXG4gICAgICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgICAgIFRyYW5zbGF0ZU1vZHVsZSxcbiAgICAgICAgRGlhbG9nTW9kdWxlLFxuICAgICAgICBCdXR0b25Nb2R1bGUsXG4gICAgICAgIER5bmFtaWNGb3JtTW9kdWxlLFxuICAgICAgICBMb2FkaW5nU3RhdGVNb2R1bGUsXG4gICAgICAgIFRleHRBcmVhTW9kdWxlXG4gICAgXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtUZXh0QXJlYUlBQ29tcG9uZW50XSxcbiAgICBleHBvcnRzOiBbVGV4dEFyZWFJQUNvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIFRleHRBcmVhSUFNb2R1bGUgeyB9XG4iXX0=
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
import { __decorate, __extends, __read } from "tslib";
|
|
2
|
+
import { Directive, ElementRef, EventEmitter, forwardRef, HostBinding, HostListener, Input, KeyValueDiffers, OnChanges, OnInit, Output, SimpleChanges, } from "@angular/core";
|
|
3
|
+
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
4
|
+
import { LocaleService } from "../locale/locale.service";
|
|
5
|
+
import { AlignmentOptions, CurrencyMaskDirective } from "@seniorsistemas/ng2-currency-mask";
|
|
6
|
+
import { first } from "rxjs/operators";
|
|
7
|
+
var BignumberInputDirective = /** @class */ (function (_super) {
|
|
8
|
+
__extends(BignumberInputDirective, _super);
|
|
9
|
+
function BignumberInputDirective(_elementRef, _keyValueDiffers, localeService) {
|
|
10
|
+
var _this = _super.call(this, null, _elementRef, _keyValueDiffers) || this;
|
|
11
|
+
_this.localeService = localeService;
|
|
12
|
+
_this.precision = 15;
|
|
13
|
+
_this.scale = 0;
|
|
14
|
+
_this.alignTo = AlignmentOptions.LEFT;
|
|
15
|
+
_this.allowNegative = true;
|
|
16
|
+
_this.pasteRejected = new EventEmitter();
|
|
17
|
+
_this.onLocaleService();
|
|
18
|
+
return _this;
|
|
19
|
+
}
|
|
20
|
+
BignumberInputDirective_1 = BignumberInputDirective;
|
|
21
|
+
BignumberInputDirective.prototype.ngOnInit = function () {
|
|
22
|
+
this.updateVariables();
|
|
23
|
+
_super.prototype.ngOnInit.call(this);
|
|
24
|
+
};
|
|
25
|
+
BignumberInputDirective.prototype.ngOnChanges = function (changes) {
|
|
26
|
+
var placeholderChange = changes.placeholder && changes.placeholder.currentValue;
|
|
27
|
+
if (!placeholderChange && this.scale) {
|
|
28
|
+
this.placeholder = "0" + this.decimalSeparator + "".padEnd(this.scale, "0");
|
|
29
|
+
}
|
|
30
|
+
if (changes.scale ||
|
|
31
|
+
changes.decimalSeparator ||
|
|
32
|
+
changes.thousandsSeparator ||
|
|
33
|
+
changes.alignTo ||
|
|
34
|
+
changes.precision ||
|
|
35
|
+
changes.allowNegative) {
|
|
36
|
+
this.updateVariables();
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
BignumberInputDirective.prototype.onPaste = function (event) {
|
|
40
|
+
var _a, _b;
|
|
41
|
+
var pastedText = (_b = (_a = event.clipboardData) === null || _a === void 0 ? void 0 : _a.getData("text")) !== null && _b !== void 0 ? _b : "";
|
|
42
|
+
var numericText = pastedText.replace(new RegExp("\\" + this.thousandsSeparator, "g"), "").replace(this.decimalSeparator, ".");
|
|
43
|
+
var _c = __read(numericText.split("."), 2), intPart = _c[0], _d = _c[1], decimalPart = _d === void 0 ? "" : _d;
|
|
44
|
+
var totalDigits = intPart.replace(/\D/g, "").length + decimalPart.slice(0, this.scale).length;
|
|
45
|
+
if (totalDigits > this.precision) {
|
|
46
|
+
event.preventDefault();
|
|
47
|
+
this.pasteRejected.emit(pastedText);
|
|
48
|
+
}
|
|
49
|
+
};
|
|
50
|
+
BignumberInputDirective.prototype.onKeypress = function (event) {
|
|
51
|
+
var code = event.code;
|
|
52
|
+
if (code === "Minus" || code === "NumpadSubtract") {
|
|
53
|
+
if (this.allowNegative) {
|
|
54
|
+
this.maxLength = this._maxLength + 1;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
else if (code === "Equal" || code === "NumpadAdd") {
|
|
58
|
+
this.maxLength = this._maxLength;
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
/**
|
|
62
|
+
* Update the options values according to the directive input values.
|
|
63
|
+
*/
|
|
64
|
+
BignumberInputDirective.prototype.updateVariables = function () {
|
|
65
|
+
var _a;
|
|
66
|
+
this.options = {
|
|
67
|
+
align: this.alignTo,
|
|
68
|
+
decimalSeparator: this.decimalSeparator,
|
|
69
|
+
thousandsSeparator: (_a = this.thousandsSeparator) !== null && _a !== void 0 ? _a : ".",
|
|
70
|
+
scale: this.scale || 0,
|
|
71
|
+
prefix: "",
|
|
72
|
+
suffix: "",
|
|
73
|
+
allowNegative: this.allowNegative,
|
|
74
|
+
};
|
|
75
|
+
this.calculateMaxLength();
|
|
76
|
+
};
|
|
77
|
+
/**
|
|
78
|
+
* Responsible to calculate the field maximum length considering the separators.
|
|
79
|
+
*/
|
|
80
|
+
BignumberInputDirective.prototype.calculateMaxLength = function () {
|
|
81
|
+
var _a, _b;
|
|
82
|
+
var decSepLength = this.decimalSeparator.length;
|
|
83
|
+
var thoSepLength = (_b = (_a = this.thousandsSeparator) === null || _a === void 0 ? void 0 : _a.length) !== null && _b !== void 0 ? _b : 1;
|
|
84
|
+
var maxLength = this.precision + (this.scale ? decSepLength : 0);
|
|
85
|
+
maxLength += Math.ceil((this.precision - (this.scale ? this.scale : 0)) / 3 - 1) * thoSepLength;
|
|
86
|
+
this._maxLength = maxLength;
|
|
87
|
+
this.maxLength = maxLength;
|
|
88
|
+
};
|
|
89
|
+
BignumberInputDirective.prototype.onLocaleService = function () {
|
|
90
|
+
var _this = this;
|
|
91
|
+
this.localeService
|
|
92
|
+
.getLocale()
|
|
93
|
+
.pipe(first())
|
|
94
|
+
.subscribe(function () {
|
|
95
|
+
var _a, _b;
|
|
96
|
+
_this.decimalSeparator = (_a = _this.decimalSeparator) !== null && _a !== void 0 ? _a : _this.localeService.getDecimalSeparator();
|
|
97
|
+
_this.thousandsSeparator = (_b = _this.thousandsSeparator) !== null && _b !== void 0 ? _b : _this.localeService.getGroupingSeparator();
|
|
98
|
+
});
|
|
99
|
+
};
|
|
100
|
+
var BignumberInputDirective_1;
|
|
101
|
+
BignumberInputDirective.ctorParameters = function () { return [
|
|
102
|
+
{ type: ElementRef },
|
|
103
|
+
{ type: KeyValueDiffers },
|
|
104
|
+
{ type: LocaleService }
|
|
105
|
+
]; };
|
|
106
|
+
__decorate([
|
|
107
|
+
Input()
|
|
108
|
+
], BignumberInputDirective.prototype, "precision", void 0);
|
|
109
|
+
__decorate([
|
|
110
|
+
Input()
|
|
111
|
+
], BignumberInputDirective.prototype, "scale", void 0);
|
|
112
|
+
__decorate([
|
|
113
|
+
Input()
|
|
114
|
+
], BignumberInputDirective.prototype, "decimalSeparator", void 0);
|
|
115
|
+
__decorate([
|
|
116
|
+
Input()
|
|
117
|
+
], BignumberInputDirective.prototype, "thousandsSeparator", void 0);
|
|
118
|
+
__decorate([
|
|
119
|
+
Input()
|
|
120
|
+
], BignumberInputDirective.prototype, "alignTo", void 0);
|
|
121
|
+
__decorate([
|
|
122
|
+
Input()
|
|
123
|
+
], BignumberInputDirective.prototype, "allowNegative", void 0);
|
|
124
|
+
__decorate([
|
|
125
|
+
Input(),
|
|
126
|
+
HostBinding("attr.placeholder")
|
|
127
|
+
], BignumberInputDirective.prototype, "placeholder", void 0);
|
|
128
|
+
__decorate([
|
|
129
|
+
HostBinding("attr.maxLength")
|
|
130
|
+
], BignumberInputDirective.prototype, "maxLength", void 0);
|
|
131
|
+
__decorate([
|
|
132
|
+
Output()
|
|
133
|
+
], BignumberInputDirective.prototype, "pasteRejected", void 0);
|
|
134
|
+
__decorate([
|
|
135
|
+
HostListener("paste", ["$event"])
|
|
136
|
+
], BignumberInputDirective.prototype, "onPaste", null);
|
|
137
|
+
__decorate([
|
|
138
|
+
HostListener("keypress", ["$event"])
|
|
139
|
+
], BignumberInputDirective.prototype, "onKeypress", null);
|
|
140
|
+
BignumberInputDirective = BignumberInputDirective_1 = __decorate([
|
|
141
|
+
Directive({
|
|
142
|
+
selector: "input[sBignumberInput]",
|
|
143
|
+
providers: [
|
|
144
|
+
{
|
|
145
|
+
provide: NG_VALUE_ACCESSOR,
|
|
146
|
+
useExisting: forwardRef(function () { return BignumberInputDirective_1; }),
|
|
147
|
+
multi: true,
|
|
148
|
+
},
|
|
149
|
+
],
|
|
150
|
+
})
|
|
151
|
+
], BignumberInputDirective);
|
|
152
|
+
return BignumberInputDirective;
|
|
153
|
+
}(CurrencyMaskDirective));
|
|
154
|
+
export { BignumberInputDirective };
|
|
155
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bignumber-input.directive.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/bignumber-input/bignumber-input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    HostListener,\n    Input,\n    KeyValueDiffers,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n} from \"@angular/core\";\nimport { NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { LocaleService } from \"../locale/locale.service\";\n\nimport { AlignmentOptions, CurrencyMaskDirective } from \"@seniorsistemas/ng2-currency-mask\";\nimport { first } from \"rxjs/operators\";\n\n@Directive({\n    selector: \"input[sBignumberInput]\",\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => BignumberInputDirective),\n            multi: true,\n        },\n    ],\n})\nexport class BignumberInputDirective extends CurrencyMaskDirective implements OnInit, OnChanges {\n    @Input()\n    public precision = 15;\n\n    @Input()\n    public scale = 0;\n\n    @Input()\n    public decimalSeparator: string;\n\n    @Input()\n    public thousandsSeparator: string;\n\n    @Input()\n    public alignTo = AlignmentOptions.LEFT;\n\n    @Input()\n    public allowNegative = true;\n\n    @Input()\n    @HostBinding(\"attr.placeholder\")\n    public placeholder: string;\n\n    @HostBinding(\"attr.maxLength\")\n    public maxLength: number;\n\n    @Output()\n    public pasteRejected = new EventEmitter<string>();\n\n    private _maxLength: number;\n\n    constructor(\n        _elementRef: ElementRef,\n        _keyValueDiffers: KeyValueDiffers,\n        private readonly localeService: LocaleService\n    ) {\n        super(null, _elementRef, _keyValueDiffers);\n\n        this.onLocaleService();\n    }\n\n    public ngOnInit(): void {\n        this.updateVariables();\n\n        super.ngOnInit();\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        const placeholderChange = changes.placeholder && changes.placeholder.currentValue;\n        if (!placeholderChange && this.scale) {\n            this.placeholder = `0${this.decimalSeparator}${\"\".padEnd(this.scale, \"0\")}`;\n        }\n\n        if (\n            changes.scale ||\n            changes.decimalSeparator ||\n            changes.thousandsSeparator ||\n            changes.alignTo ||\n            changes.precision ||\n            changes.allowNegative\n        ) {\n            this.updateVariables();\n        }\n    }\n\n    @HostListener(\"paste\", [\"$event\"])\n    public onPaste(event: ClipboardEvent): void {\n        const pastedText = event.clipboardData?.getData(\"text\") ?? \"\";\n        const numericText = pastedText.replace(new RegExp(`\\\\${this.thousandsSeparator}`, \"g\"), \"\").replace(this.decimalSeparator, \".\");\n        const [intPart, decimalPart = \"\"] = numericText.split(\".\");\n        const totalDigits = intPart.replace(/\\D/g, \"\").length + decimalPart.slice(0, this.scale).length;\n\n        if (totalDigits > this.precision) {\n            event.preventDefault();\n            this.pasteRejected.emit(pastedText);\n        }\n    }\n\n    @HostListener(\"keypress\", [\"$event\"])\n    public onKeypress(event: KeyboardEvent) {\n        const code = event.code;\n\n        if (code === \"Minus\" || code === \"NumpadSubtract\") {\n            if (this.allowNegative) {\n                this.maxLength = this._maxLength + 1;\n            }\n        } else if (code === \"Equal\" || code === \"NumpadAdd\") {\n            this.maxLength = this._maxLength;\n        }\n    }\n\n    /**\n     * Update the options values according to the directive input values.\n     */\n    private updateVariables(): void {\n        this.options = {\n            align: this.alignTo,\n            decimalSeparator: this.decimalSeparator,\n            thousandsSeparator: this.thousandsSeparator ?? \".\",\n            scale: this.scale || 0,\n            prefix: \"\",\n            suffix: \"\",\n            allowNegative: this.allowNegative,\n        };\n        this.calculateMaxLength();\n    }\n\n    /**\n     * Responsible to calculate the field maximum length considering the separators.\n     */\n    private calculateMaxLength(): void {\n        const decSepLength = this.decimalSeparator.length;\n        const thoSepLength = this.thousandsSeparator?.length ?? 1;\n\n        let maxLength = this.precision + (this.scale ? decSepLength : 0);\n        maxLength += Math.ceil((this.precision - (this.scale ? this.scale : 0)) / 3 - 1) * thoSepLength;\n\n        this._maxLength = maxLength;\n        this.maxLength = maxLength;\n    }\n\n    private onLocaleService(): void {\n        this.localeService\n            .getLocale()\n            .pipe(first())\n            .subscribe(() => {\n                this.decimalSeparator = this.decimalSeparator ?? this.localeService.getDecimalSeparator();\n                this.thousandsSeparator = this.thousandsSeparator ?? this.localeService.getGroupingSeparator();\n            });\n    }\n}\n"]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { CommonModule } from "@angular/common";
|
|
3
|
+
import { NgModule } from "@angular/core";
|
|
4
|
+
import { BignumberInputDirective } from "./bignumber-input.directive";
|
|
5
|
+
var BignumberInputModule = /** @class */ (function () {
|
|
6
|
+
function BignumberInputModule() {
|
|
7
|
+
}
|
|
8
|
+
BignumberInputModule = __decorate([
|
|
9
|
+
NgModule({
|
|
10
|
+
imports: [CommonModule],
|
|
11
|
+
declarations: [BignumberInputDirective],
|
|
12
|
+
exports: [BignumberInputDirective],
|
|
13
|
+
})
|
|
14
|
+
], BignumberInputModule);
|
|
15
|
+
return BignumberInputModule;
|
|
16
|
+
}());
|
|
17
|
+
export { BignumberInputModule };
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmlnbnVtYmVyLWlucHV0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BzZW5pb3JzaXN0ZW1hcy9hbmd1bGFyLWNvbXBvbmVudHMvIiwic291cmNlcyI6WyJjb21wb25lbnRzL2JpZ251bWJlci1pbnB1dC9iaWdudW1iZXItaW5wdXQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQU90RTtJQUFBO0lBQW1DLENBQUM7SUFBdkIsb0JBQW9CO1FBTGhDLFFBQVEsQ0FBQztZQUNOLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztZQUN2QixZQUFZLEVBQUUsQ0FBQyx1QkFBdUIsQ0FBQztZQUN2QyxPQUFPLEVBQUUsQ0FBQyx1QkFBdUIsQ0FBQztTQUNyQyxDQUFDO09BQ1csb0JBQW9CLENBQUc7SUFBRCwyQkFBQztDQUFBLEFBQXBDLElBQW9DO1NBQXZCLG9CQUFvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuaW1wb3J0IHsgQmlnbnVtYmVySW5wdXREaXJlY3RpdmUgfSBmcm9tIFwiLi9iaWdudW1iZXItaW5wdXQuZGlyZWN0aXZlXCI7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gICAgZGVjbGFyYXRpb25zOiBbQmlnbnVtYmVySW5wdXREaXJlY3RpdmVdLFxuICAgIGV4cG9ydHM6IFtCaWdudW1iZXJJbnB1dERpcmVjdGl2ZV0sXG59KVxuZXhwb3J0IGNsYXNzIEJpZ251bWJlcklucHV0TW9kdWxlIHt9XG4iXX0=
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export * from "./
|
|
2
|
-
export * from "./
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
export * from "./bignumber-input.directive";
|
|
2
|
+
export * from "./bignumber-input.module";
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9iaWdudW1iZXItaW5wdXQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vYmlnbnVtYmVyLWlucHV0LmRpcmVjdGl2ZVwiO1xuZXhwb3J0ICogZnJvbSBcIi4vYmlnbnVtYmVyLWlucHV0Lm1vZHVsZVwiO1xuIl19
|