@seniorsistemas/angular-components 17.5.1 → 17.5.2
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 +710 -554
- package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js +2 -2
- package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
- package/components/bignumber-input/number-input.directive.d.ts +5 -1
- package/components/dynamic-form/components/fields/bignumber/number-field.component.d.ts +4 -0
- package/components/dynamic-form/components/fields/currency/currency-field.component.d.ts +7 -1
- package/components/dynamic-form/components/fields/number/number-field.component.d.ts +4 -0
- package/components/dynamic-form/dynamic-form.d.ts +0 -1
- package/components/locale/locale.service.d.ts +3 -1
- package/components/localized-number-input/localized-number-input.directive.d.ts +3 -1
- package/components/number-input/number-input.directive.d.ts +5 -1
- package/esm2015/components/bignumber-input/number-input.directive.js +24 -6
- package/esm2015/components/dynamic-form/components/fields/bignumber/number-field.component.js +40 -13
- package/esm2015/components/dynamic-form/components/fields/currency/currency-field.component.js +40 -1
- package/esm2015/components/dynamic-form/components/fields/number/number-field.component.js +37 -4
- package/esm2015/components/dynamic-form/configurations/fields/bignumber-field.js +2 -3
- package/esm2015/components/dynamic-form/configurations/fields/currency-field.js +2 -3
- package/esm2015/components/dynamic-form/configurations/fields/decimal-field.js +2 -3
- package/esm2015/components/dynamic-form/configurations/fields/number-field.js +2 -3
- package/esm2015/components/dynamic-form/dynamic-form.js +1 -7
- package/esm2015/components/locale/locale.service.js +26 -5
- package/esm2015/components/localized-number-input/localized-number-input.directive.js +17 -4
- package/esm2015/components/number-input/number-input.directive.js +24 -7
- package/esm5/components/bignumber-input/number-input.directive.js +25 -6
- package/esm5/components/dynamic-form/components/fields/bignumber/number-field.component.js +42 -14
- package/esm5/components/dynamic-form/components/fields/currency/currency-field.component.js +42 -4
- package/esm5/components/dynamic-form/components/fields/number/number-field.component.js +39 -5
- package/esm5/components/dynamic-form/configurations/fields/bignumber-field.js +2 -3
- package/esm5/components/dynamic-form/configurations/fields/currency-field.js +2 -3
- package/esm5/components/dynamic-form/configurations/fields/decimal-field.js +2 -3
- package/esm5/components/dynamic-form/configurations/fields/number-field.js +2 -3
- package/esm5/components/dynamic-form/dynamic-form.js +1 -7
- package/esm5/components/locale/locale.service.js +25 -4
- package/esm5/components/localized-number-input/localized-number-input.directive.js +18 -4
- package/esm5/components/number-input/number-input.directive.js +25 -7
- package/fesm2015/seniorsistemas-angular-components.js +653 -501
- package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
- package/fesm5/seniorsistemas-angular-components.js +707 -551
- package/fesm5/seniorsistemas-angular-components.js.map +1 -1
- package/package.json +1 -1
- package/seniorsistemas-angular-components.metadata.json +1 -1
|
@@ -6,7 +6,7 @@ import * as moment_ from "moment";
|
|
|
6
6
|
import { from, of } from "rxjs";
|
|
7
7
|
import { catchError, map, switchMap, tap } from "rxjs/operators";
|
|
8
8
|
import { LocaleOptions } from "./options/index";
|
|
9
|
-
import { CookieService } from
|
|
9
|
+
import { CookieService } from "ngx-cookie-service";
|
|
10
10
|
var moment = moment_; // @HACK Necessary because of https://github.com/rollup/rollup/issues/670
|
|
11
11
|
var LocaleService = /** @class */ (function () {
|
|
12
12
|
function LocaleService(http, cookieService) {
|
|
@@ -32,10 +32,10 @@ var LocaleService = /** @class */ (function () {
|
|
|
32
32
|
};
|
|
33
33
|
LocaleService.prototype.getUserData = function () {
|
|
34
34
|
try {
|
|
35
|
-
return of(JSON.parse(this.cookieService.get(
|
|
35
|
+
return of(JSON.parse(this.cookieService.get("com.senior.token")));
|
|
36
36
|
}
|
|
37
37
|
catch (ex) {
|
|
38
|
-
console.warn(
|
|
38
|
+
console.warn("Unable to obtain user locale from cookie, calling getUser");
|
|
39
39
|
return user.getUserData();
|
|
40
40
|
}
|
|
41
41
|
};
|
|
@@ -51,6 +51,27 @@ var LocaleService = /** @class */ (function () {
|
|
|
51
51
|
return of(new LocaleOptions());
|
|
52
52
|
}));
|
|
53
53
|
};
|
|
54
|
+
LocaleService.prototype.getGroupingSeparator = function () {
|
|
55
|
+
var _a;
|
|
56
|
+
var numberFormat = new Intl.NumberFormat(this.locale, {
|
|
57
|
+
style: "decimal",
|
|
58
|
+
minimumFractionDigits: 5,
|
|
59
|
+
maximumFractionDigits: 5,
|
|
60
|
+
});
|
|
61
|
+
// The default groupingSeparator for 'fr' is the character code 8239. We need it to be the regular space.
|
|
62
|
+
if (this.locale.includes("fr"))
|
|
63
|
+
return " ";
|
|
64
|
+
return (_a = numberFormat.formatToParts(1000).find(function (part) { return part.type === "group"; })) === null || _a === void 0 ? void 0 : _a.value;
|
|
65
|
+
};
|
|
66
|
+
LocaleService.prototype.getDecimalSeparator = function () {
|
|
67
|
+
var _a;
|
|
68
|
+
var numberFormat = new Intl.NumberFormat(this.locale, {
|
|
69
|
+
style: "decimal",
|
|
70
|
+
minimumFractionDigits: 5,
|
|
71
|
+
maximumFractionDigits: 5,
|
|
72
|
+
});
|
|
73
|
+
return (_a = numberFormat.formatToParts(1.2).find(function (part) { return part.type === "decimal"; })) === null || _a === void 0 ? void 0 : _a.value;
|
|
74
|
+
};
|
|
54
75
|
LocaleService.ctorParameters = function () { return [
|
|
55
76
|
{ type: HttpClient },
|
|
56
77
|
{ type: CookieService }
|
|
@@ -61,4 +82,4 @@ var LocaleService = /** @class */ (function () {
|
|
|
61
82
|
return LocaleService;
|
|
62
83
|
}());
|
|
63
84
|
export { LocaleService };
|
|
64
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"locale.service.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/locale/locale.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from \"@angular/common/http\";\nimport { Injectable } from \"@angular/core\";\nimport { user } from \"@seniorsistemas/senior-platform-data\";\nimport * as moment_ from \"moment\";\nimport { from, Observable, of } from \"rxjs\";\nimport { catchError, map, switchMap, tap } from \"rxjs/operators\";\nimport { ILocaleOptions, LocaleOptions } from \"./options/index\";\nimport { CookieService } from \"ngx-cookie-service\";\n\nconst moment = moment_; // @HACK Necessary because of https://github.com/rollup/rollup/issues/670\n\n@Injectable()\nexport class LocaleService {\n    private locale: string;\n    private localeOptions: LocaleOptions;\n    private localeOptionsAddress = \"https://cdn.senior.com.br/primeng/locales\";\n    private localeOptionsVersion = \"3.0.0\";\n\n    constructor(\n        private http: HttpClient,\n        private cookieService: CookieService\n    ) {}\n\n    get(): Observable<LocaleOptions> {\n        return this.localeOptions\n            ? of(this.localeOptions)\n            : this.getLocaleConfig().pipe(tap((localeOptions: LocaleOptions) => (this.localeOptions = localeOptions)));\n    }\n\n    getLocale(): Observable<string> {\n        return this.locale\n            ? of(this.locale)\n            : from(this.getUserData()).pipe(\n                  map((userData: any) => {\n                      this.locale = <string>userData.locale || <string>userData.tenantLocale || \"pt-BR\";\n                      return this.locale;\n                  })\n              );\n    }\n\n    private getUserData() {\n        try {\n            return of(JSON.parse(this.cookieService.get(\"com.senior.token\")));\n        } catch (ex) {\n            console.warn(\"Unable to obtain user locale from cookie, calling getUser\");\n            return user.getUserData();\n        }\n    }\n\n    private getLocaleConfig(): Observable<LocaleOptions> {\n        return this.getLocale().pipe(\n            switchMap((locale: string) => {\n                moment.locale(locale);\n\n                return this.http\n                    .get<ILocaleOptions>(`${this.localeOptionsAddress}/${this.localeOptionsVersion}/${locale}.json`)\n                    .pipe(map((response) => new LocaleOptions(response)));\n            }),\n            catchError((err: any) => {\n                console.warn(`Error getting locale configuration. Using fallback.`, err);\n                return of(new LocaleOptions());\n            })\n        );\n    }\n\n    getGroupingSeparator(): string {\n        const numberFormat = new Intl.NumberFormat(this.locale, {\n            style: \"decimal\",\n            minimumFractionDigits: 5,\n            maximumFractionDigits: 5,\n        });\n\n        // The default groupingSeparator for 'fr' is the character code 8239. We need it to be the regular space.\n        if (this.locale.includes(\"fr\")) return \" \";\n\n        return numberFormat.formatToParts(1000).find((part) => part.type === \"group\")?.value;\n    }\n\n    getDecimalSeparator(): string {\n        const numberFormat = new Intl.NumberFormat(this.locale, {\n            style: \"decimal\",\n            minimumFractionDigits: 5,\n            maximumFractionDigits: 5,\n        });\n\n        return numberFormat.formatToParts(1.2).find((part) => part.type === \"decimal\")?.value;\n    }\n}\n"]}
|
|
@@ -1,18 +1,29 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
2
|
import { Directive, forwardRef, Input } from "@angular/core";
|
|
3
3
|
import { NG_VALIDATORS } from "@angular/forms";
|
|
4
|
+
import { LocaleService } from "../locale/locale.service";
|
|
5
|
+
import { first } from "rxjs/operators";
|
|
4
6
|
var LocalizedNumberInputDirective = /** @class */ (function () {
|
|
5
|
-
function LocalizedNumberInputDirective() {
|
|
6
|
-
this.
|
|
7
|
-
this.thousandsSeparator = ".";
|
|
7
|
+
function LocalizedNumberInputDirective(localeService) {
|
|
8
|
+
this.localeService = localeService;
|
|
8
9
|
this.precision = 2;
|
|
9
10
|
}
|
|
10
11
|
LocalizedNumberInputDirective_1 = LocalizedNumberInputDirective;
|
|
11
12
|
LocalizedNumberInputDirective.prototype.ngOnInit = function () {
|
|
13
|
+
var _this = this;
|
|
12
14
|
// Gera a expressão regular para validar números de acordo com os separadores decimais e de milhares.
|
|
13
15
|
// Exemplo: /^(\+?)(\-?)([0-9]{0,3})*((\,[0-9]{3,3})|((\,[0-9]{3,3})+(\,[0-9]{3,3}))|((\,[0-9]{3,3})+(\.[0-9]{1,10})))?$/g
|
|
14
16
|
// tslint:disable-next-line: max-line-length
|
|
15
17
|
this.numberRegex = "^((\\+?)|(-?))([0-9]{1,3})+((\\" + this.thousandsSeparator + "[0-9]{3,3})|((\\" + this.thousandsSeparator + "[0-9]{3,3})+(\\" + this.thousandsSeparator + "[0-9]{3,3}))|((\\" + this.thousandsSeparator + "[0-9]{3,3})+(\\" + this.decimalSeparator + "[0-9]{1,2}))|(\\" + this.decimalSeparator + "[0-9]{1," + this.precision + "}))?$";
|
|
18
|
+
this.localeService
|
|
19
|
+
.getLocale()
|
|
20
|
+
.pipe(first())
|
|
21
|
+
.subscribe(function () {
|
|
22
|
+
var _a, _b;
|
|
23
|
+
_this.decimalSeparator = (_a = _this.decimalSeparator) !== null && _a !== void 0 ? _a : _this.localeService.getDecimalSeparator();
|
|
24
|
+
_this.thousandsSeparator = (_b = _this.thousandsSeparator) !== null && _b !== void 0 ? _b : _this.localeService.getGroupingSeparator();
|
|
25
|
+
_this.numberRegex = "^((\\+?)|(-?))([0-9]{1,3})+((\\" + _this.thousandsSeparator + "[0-9]{3,3})|((\\" + _this.thousandsSeparator + "[0-9]{3,3})+(\\" + _this.thousandsSeparator + "[0-9]{3,3}))|((\\" + _this.thousandsSeparator + "[0-9]{3,3})+(\\" + _this.decimalSeparator + "[0-9]{1,2}))|(\\" + _this.decimalSeparator + "[0-9]{1," + _this.precision + "}))?$";
|
|
26
|
+
});
|
|
16
27
|
};
|
|
17
28
|
LocalizedNumberInputDirective.prototype.validate = function (control) {
|
|
18
29
|
if (control.value && !String(control.value).match(new RegExp(this.numberRegex, "g")))
|
|
@@ -20,6 +31,9 @@ var LocalizedNumberInputDirective = /** @class */ (function () {
|
|
|
20
31
|
return null;
|
|
21
32
|
};
|
|
22
33
|
var LocalizedNumberInputDirective_1;
|
|
34
|
+
LocalizedNumberInputDirective.ctorParameters = function () { return [
|
|
35
|
+
{ type: LocaleService }
|
|
36
|
+
]; };
|
|
23
37
|
__decorate([
|
|
24
38
|
Input()
|
|
25
39
|
], LocalizedNumberInputDirective.prototype, "decimalSeparator", void 0);
|
|
@@ -44,4 +58,4 @@ var LocalizedNumberInputDirective = /** @class */ (function () {
|
|
|
44
58
|
return LocalizedNumberInputDirective;
|
|
45
59
|
}());
|
|
46
60
|
export { LocalizedNumberInputDirective };
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9jYWxpemVkLW51bWJlci1pbnB1dC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9sb2NhbGl6ZWQtbnVtYmVyLWlucHV0L2xvY2FsaXplZC1udW1iZXItaW5wdXQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDckUsT0FBTyxFQUFtQixhQUFhLEVBQStCLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0YsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQVl2QztJQVVJLHVDQUE2QixhQUE0QjtRQUE1QixrQkFBYSxHQUFiLGFBQWEsQ0FBZTtRQUpsRCxjQUFTLEdBQUcsQ0FBQyxDQUFDO0lBSXVDLENBQUM7c0NBVnBELDZCQUE2QjtJQVl0QyxnREFBUSxHQUFSO1FBQUEsaUJBZUM7UUFkRyxxR0FBcUc7UUFDckcsMEhBQTBIO1FBQzFILDRDQUE0QztRQUM1QyxJQUFJLENBQUMsV0FBVyxHQUFHLG9DQUFrQyxJQUFJLENBQUMsa0JBQWtCLHdCQUFtQixJQUFJLENBQUMsa0JBQWtCLHVCQUFrQixJQUFJLENBQUMsa0JBQWtCLHlCQUFvQixJQUFJLENBQUMsa0JBQWtCLHVCQUFrQixJQUFJLENBQUMsZ0JBQWdCLHdCQUFtQixJQUFJLENBQUMsZ0JBQWdCLGdCQUFXLElBQUksQ0FBQyxTQUFTLFVBQU8sQ0FBQztRQUUxVCxJQUFJLENBQUMsYUFBYTthQUNiLFNBQVMsRUFBRTthQUNYLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQzthQUNiLFNBQVMsQ0FBQzs7WUFDUCxLQUFJLENBQUMsZ0JBQWdCLFNBQUcsS0FBSSxDQUFDLGdCQUFnQixtQ0FBSSxLQUFJLENBQUMsYUFBYSxDQUFDLG1CQUFtQixFQUFFLENBQUM7WUFDMUYsS0FBSSxDQUFDLGtCQUFrQixTQUFHLEtBQUksQ0FBQyxrQkFBa0IsbUNBQUksS0FBSSxDQUFDLGFBQWEsQ0FBQyxvQkFBb0IsRUFBRSxDQUFDO1lBRS9GLEtBQUksQ0FBQyxXQUFXLEdBQUcsb0NBQWtDLEtBQUksQ0FBQyxrQkFBa0Isd0JBQW1CLEtBQUksQ0FBQyxrQkFBa0IsdUJBQWtCLEtBQUksQ0FBQyxrQkFBa0IseUJBQW9CLEtBQUksQ0FBQyxrQkFBa0IsdUJBQWtCLEtBQUksQ0FBQyxnQkFBZ0Isd0JBQW1CLEtBQUksQ0FBQyxnQkFBZ0IsZ0JBQVcsS0FBSSxDQUFDLFNBQVMsVUFBTyxDQUFDO1FBQzlULENBQUMsQ0FBQyxDQUFDO0lBQ1gsQ0FBQztJQUVELGdEQUFRLEdBQVIsVUFBUyxPQUF3QjtRQUM3QixJQUFJLE9BQU8sQ0FBQyxLQUFLLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLEtBQUssQ0FBQyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLEdBQUcsQ0FBQyxDQUFDO1lBQUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxJQUFJLEVBQUUsQ0FBQztRQUNySCxPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDOzs7Z0JBdEIyQyxhQUFhOztJQVJ6RDtRQURDLEtBQUssRUFBRTsyRUFDd0I7SUFFaEM7UUFEQyxLQUFLLEVBQUU7NkVBQzBCO0lBRWxDO1FBREMsS0FBSyxFQUFFO29FQUNhO0lBTlosNkJBQTZCO1FBVnpDLFNBQVMsQ0FBQztZQUNQLFFBQVEsRUFBRSw4QkFBOEI7WUFDeEMsU0FBUyxFQUFFO2dCQUNQO29CQUNJLE9BQU8sRUFBRSxhQUFhO29CQUN0QixXQUFXLEVBQUUsVUFBVSxDQUFDLGNBQU0sT0FBQSwrQkFBNkIsRUFBN0IsQ0FBNkIsQ0FBQztvQkFDNUQsS0FBSyxFQUFFLElBQUk7aUJBQ2Q7YUFDSjtTQUNKLENBQUM7T0FDVyw2QkFBNkIsQ0FpQ3pDO0lBQUQsb0NBQUM7Q0FBQSxBQWpDRCxJQWlDQztTQWpDWSw2QkFBNkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGZvcndhcmRSZWYsIElucHV0LCBPbkluaXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgQWJzdHJhY3RDb250cm9sLCBOR19WQUxJREFUT1JTLCBWYWxpZGF0aW9uRXJyb3JzLCBWYWxpZGF0b3IgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcbmltcG9ydCB7IExvY2FsZVNlcnZpY2UgfSBmcm9tIFwiLi4vbG9jYWxlL2xvY2FsZS5zZXJ2aWNlXCI7XG5pbXBvcnQgeyBmaXJzdCB9IGZyb20gXCJyeGpzL29wZXJhdG9yc1wiO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogXCJpbnB1dFtzTG9jYWxpemVkTnVtYmVySW5wdXRdXCIsXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IE5HX1ZBTElEQVRPUlMsXG4gICAgICAgICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBMb2NhbGl6ZWROdW1iZXJJbnB1dERpcmVjdGl2ZSksXG4gICAgICAgICAgICBtdWx0aTogdHJ1ZSxcbiAgICAgICAgfSxcbiAgICBdLFxufSlcbmV4cG9ydCBjbGFzcyBMb2NhbGl6ZWROdW1iZXJJbnB1dERpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCwgVmFsaWRhdG9yIHtcbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBkZWNpbWFsU2VwYXJhdG9yOiBzdHJpbmc7XG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgdGhvdXNhbmRzU2VwYXJhdG9yOiBzdHJpbmc7XG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgcHJlY2lzaW9uID0gMjtcblxuICAgIHByaXZhdGUgbnVtYmVyUmVnZXg6IHN0cmluZztcblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgbG9jYWxlU2VydmljZTogTG9jYWxlU2VydmljZSkge31cblxuICAgIG5nT25Jbml0KCkge1xuICAgICAgICAvLyBHZXJhIGEgZXhwcmVzc8OjbyByZWd1bGFyIHBhcmEgdmFsaWRhciBuw7ptZXJvcyBkZSBhY29yZG8gY29tIG9zIHNlcGFyYWRvcmVzIGRlY2ltYWlzIGUgZGUgbWlsaGFyZXMuXG4gICAgICAgIC8vIEV4ZW1wbG86IC9eKFxcKz8pKFxcLT8pKFswLTldezAsM30pKigoXFwsWzAtOV17MywzfSl8KChcXCxbMC05XXszLDN9KSsoXFwsWzAtOV17MywzfSkpfCgoXFwsWzAtOV17MywzfSkrKFxcLlswLTldezEsMTB9KSkpPyQvZ1xuICAgICAgICAvLyB0c2xpbnQ6ZGlzYWJsZS1uZXh0LWxpbmU6IG1heC1saW5lLWxlbmd0aFxuICAgICAgICB0aGlzLm51bWJlclJlZ2V4ID0gYF4oKFxcXFwrPyl8KC0/KSkoWzAtOV17MSwzfSkrKChcXFxcJHt0aGlzLnRob3VzYW5kc1NlcGFyYXRvcn1bMC05XXszLDN9KXwoKFxcXFwke3RoaXMudGhvdXNhbmRzU2VwYXJhdG9yfVswLTldezMsM30pKyhcXFxcJHt0aGlzLnRob3VzYW5kc1NlcGFyYXRvcn1bMC05XXszLDN9KSl8KChcXFxcJHt0aGlzLnRob3VzYW5kc1NlcGFyYXRvcn1bMC05XXszLDN9KSsoXFxcXCR7dGhpcy5kZWNpbWFsU2VwYXJhdG9yfVswLTldezEsMn0pKXwoXFxcXCR7dGhpcy5kZWNpbWFsU2VwYXJhdG9yfVswLTldezEsJHt0aGlzLnByZWNpc2lvbn19KSk/JGA7XG5cbiAgICAgICAgdGhpcy5sb2NhbGVTZXJ2aWNlXG4gICAgICAgICAgICAuZ2V0TG9jYWxlKClcbiAgICAgICAgICAgIC5waXBlKGZpcnN0KCkpXG4gICAgICAgICAgICAuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgICAgICB0aGlzLmRlY2ltYWxTZXBhcmF0b3IgPSB0aGlzLmRlY2ltYWxTZXBhcmF0b3IgPz8gdGhpcy5sb2NhbGVTZXJ2aWNlLmdldERlY2ltYWxTZXBhcmF0b3IoKTtcbiAgICAgICAgICAgICAgICB0aGlzLnRob3VzYW5kc1NlcGFyYXRvciA9IHRoaXMudGhvdXNhbmRzU2VwYXJhdG9yID8/IHRoaXMubG9jYWxlU2VydmljZS5nZXRHcm91cGluZ1NlcGFyYXRvcigpO1xuXG4gICAgICAgICAgICAgICAgdGhpcy5udW1iZXJSZWdleCA9IGBeKChcXFxcKz8pfCgtPykpKFswLTldezEsM30pKygoXFxcXCR7dGhpcy50aG91c2FuZHNTZXBhcmF0b3J9WzAtOV17MywzfSl8KChcXFxcJHt0aGlzLnRob3VzYW5kc1NlcGFyYXRvcn1bMC05XXszLDN9KSsoXFxcXCR7dGhpcy50aG91c2FuZHNTZXBhcmF0b3J9WzAtOV17MywzfSkpfCgoXFxcXCR7dGhpcy50aG91c2FuZHNTZXBhcmF0b3J9WzAtOV17MywzfSkrKFxcXFwke3RoaXMuZGVjaW1hbFNlcGFyYXRvcn1bMC05XXsxLDJ9KSl8KFxcXFwke3RoaXMuZGVjaW1hbFNlcGFyYXRvcn1bMC05XXsxLCR7dGhpcy5wcmVjaXNpb259fSkpPyRgO1xuICAgICAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgdmFsaWRhdGUoY29udHJvbDogQWJzdHJhY3RDb250cm9sKTogVmFsaWRhdGlvbkVycm9ycyB7XG4gICAgICAgIGlmIChjb250cm9sLnZhbHVlICYmICFTdHJpbmcoY29udHJvbC52YWx1ZSkubWF0Y2gobmV3IFJlZ0V4cCh0aGlzLm51bWJlclJlZ2V4LCBcImdcIikpKSByZXR1cm4geyBpbnZhbGlkTnVtYmVyOiB0cnVlIH07XG4gICAgICAgIHJldHVybiBudWxsO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { __decorate, __extends } from "tslib";
|
|
2
|
-
import { Directive, forwardRef, HostBinding, Input } from "@angular/core";
|
|
2
|
+
import { Directive, ElementRef, forwardRef, HostBinding, Injectable, Input, KeyValueDiffers, OnChanges, OnInit, SimpleChanges, } from "@angular/core";
|
|
3
3
|
import { NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
4
|
+
import { LocaleService } from "../locale/locale.service";
|
|
4
5
|
import { CurrencyMaskDirective } from "ng2-currency-mask";
|
|
6
|
+
import { first } from "rxjs/operators";
|
|
5
7
|
/**
|
|
6
8
|
* @deprecated Should use 'AlignmentOptions' from @seniorsistemas/ng2-currency-mask instead
|
|
7
9
|
*/
|
|
@@ -15,15 +17,15 @@ export var NumberAlignmentOption;
|
|
|
15
17
|
*/
|
|
16
18
|
var NumberInputDirective = /** @class */ (function (_super) {
|
|
17
19
|
__extends(NumberInputDirective, _super);
|
|
18
|
-
function NumberInputDirective() {
|
|
19
|
-
var _this = _super
|
|
20
|
+
function NumberInputDirective(_elementRef, _keyValueDiffers, localeService) {
|
|
21
|
+
var _this = _super.call(this, null, _elementRef, _keyValueDiffers) || this;
|
|
22
|
+
_this.localeService = localeService;
|
|
20
23
|
_this.precision = 15;
|
|
21
24
|
_this.scale = 0;
|
|
22
|
-
_this.decimalSeparator = ",";
|
|
23
|
-
_this.thousandsSeparator = ".";
|
|
24
25
|
_this.alignTo = NumberAlignmentOption.LEFT;
|
|
25
26
|
_this.allowNegative = true;
|
|
26
27
|
_this.regex = /\d/;
|
|
28
|
+
_this.onLocaleService();
|
|
27
29
|
return _this;
|
|
28
30
|
}
|
|
29
31
|
NumberInputDirective_1 = NumberInputDirective;
|
|
@@ -55,7 +57,7 @@ var NumberInputDirective = /** @class */ (function (_super) {
|
|
|
55
57
|
precision: this.scale || 0,
|
|
56
58
|
prefix: "",
|
|
57
59
|
suffix: "",
|
|
58
|
-
allowNegative: this.allowNegative
|
|
60
|
+
allowNegative: this.allowNegative,
|
|
59
61
|
};
|
|
60
62
|
this.calculateMaxLength();
|
|
61
63
|
};
|
|
@@ -85,7 +87,23 @@ var NumberInputDirective = /** @class */ (function (_super) {
|
|
|
85
87
|
else
|
|
86
88
|
event.preventDefault();
|
|
87
89
|
};
|
|
90
|
+
NumberInputDirective.prototype.onLocaleService = function () {
|
|
91
|
+
var _this = this;
|
|
92
|
+
this.localeService
|
|
93
|
+
.getLocale()
|
|
94
|
+
.pipe(first())
|
|
95
|
+
.subscribe(function () {
|
|
96
|
+
var _a, _b;
|
|
97
|
+
_this.decimalSeparator = (_a = _this.decimalSeparator) !== null && _a !== void 0 ? _a : _this.localeService.getDecimalSeparator();
|
|
98
|
+
_this.thousandsSeparator = (_b = _this.thousandsSeparator) !== null && _b !== void 0 ? _b : _this.localeService.getGroupingSeparator();
|
|
99
|
+
});
|
|
100
|
+
};
|
|
88
101
|
var NumberInputDirective_1;
|
|
102
|
+
NumberInputDirective.ctorParameters = function () { return [
|
|
103
|
+
{ type: ElementRef },
|
|
104
|
+
{ type: KeyValueDiffers },
|
|
105
|
+
{ type: LocaleService }
|
|
106
|
+
]; };
|
|
89
107
|
__decorate([
|
|
90
108
|
Input()
|
|
91
109
|
], NumberInputDirective.prototype, "precision", void 0);
|
|
@@ -126,4 +144,4 @@ var NumberInputDirective = /** @class */ (function (_super) {
|
|
|
126
144
|
return NumberInputDirective;
|
|
127
145
|
}(CurrencyMaskDirective));
|
|
128
146
|
export { NumberInputDirective };
|
|
129
|
-
//# 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 { Directive, forwardRef, HostBinding, Input, OnChanges, OnInit, SimpleChanges } from \"@angular/core\";\nimport { NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { CurrencyMaskDirective } from \"ng2-currency-mask\";\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 = \",\";\n\n    @Input()\n    public thousandsSeparator = \".\";\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    public ngOnInit() {\n        this.updateVariables();\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"]}
|
|
147
|
+
//# 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    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"]}
|