UNPKG

15.3 kBJavaScriptView Raw
1import { inject, Pipe } from '@angular/core';
2import { NGX_MASK_CONFIG } from './ngx-mask.config';
3import { NgxMaskService } from './ngx-mask.service';
4import * as i0 from "@angular/core";
5export class NgxMaskPipe {
6 constructor() {
7 this.defaultOptions = inject(NGX_MASK_CONFIG);
8 this._maskService = inject(NgxMaskService);
9 this._maskExpressionArray = [];
10 this.mask = '';
11 }
12 transform(value, mask, { patterns, ...config } = {}) {
13 const currentConfig = {
14 maskExpression: mask,
15 ...this.defaultOptions,
16 ...config,
17 patterns: {
18 ...this._maskService.patterns,
19 ...patterns,
20 },
21 };
22 Object.entries(currentConfig).forEach(([key, value]) => {
23 //eslint-disable-next-line @typescript-eslint/no-explicit-any
24 this._maskService[key] = value;
25 });
26 if (mask.includes('||')) {
27 if (mask.split('||').length > 1) {
28 this._maskExpressionArray = mask.split('||').sort((a, b) => {
29 return a.length - b.length;
30 });
31 this._setMask(value);
32 return this._maskService.applyMask(`${value}`, this.mask);
33 }
34 else {
35 this._maskExpressionArray = [];
36 return this._maskService.applyMask(`${value}`, this.mask);
37 }
38 }
39 if (mask.includes("{" /* MaskExpression.CURLY_BRACKETS_LEFT */)) {
40 return this._maskService.applyMask(`${value}`, this._maskService._repeatPatternSymbols(mask));
41 }
42 if (mask.startsWith("separator" /* MaskExpression.SEPARATOR */)) {
43 if (config.decimalMarker) {
44 this._maskService.decimalMarker = config.decimalMarker;
45 }
46 if (config.thousandSeparator) {
47 this._maskService.thousandSeparator = config.thousandSeparator;
48 }
49 if (config.leadZero) {
50 this._maskService.leadZero = config.leadZero;
51 }
52 value = String(value);
53 const localeDecimalMarker = this._maskService.currentLocaleDecimalMarker();
54 if (!Array.isArray(this._maskService.decimalMarker)) {
55 value =
56 this._maskService.decimalMarker !== localeDecimalMarker
57 ? value.replace(localeDecimalMarker, this._maskService.decimalMarker)
58 : value;
59 }
60 if (this._maskService.leadZero &&
61 value &&
62 this._maskService.dropSpecialCharacters !== false) {
63 value = this._maskService._checkPrecision(mask, value);
64 }
65 if (this._maskService.decimalMarker === "," /* MaskExpression.COMMA */) {
66 value = value.toString().replace("." /* MaskExpression.DOT */, "," /* MaskExpression.COMMA */);
67 }
68 this._maskService.isNumberValue = true;
69 }
70 if (value === null || value === undefined) {
71 return this._maskService.applyMask('', mask);
72 }
73 return this._maskService.applyMask(`${value}`, mask);
74 }
75 _setMask(value) {
76 if (this._maskExpressionArray.length > 0) {
77 this._maskExpressionArray.some((mask) => {
78 const test = this._maskService.removeMask(value)?.length <=
79 this._maskService.removeMask(mask)?.length;
80 if (value && test) {
81 this.mask = mask;
82 return test;
83 }
84 else {
85 const expression = this._maskExpressionArray[this._maskExpressionArray.length - 1] ??
86 "" /* MaskExpression.EMPTY_STRING */;
87 this.mask = expression;
88 }
89 });
90 }
91 }
92 static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgxMaskPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
93 static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.1.1", ngImport: i0, type: NgxMaskPipe, isStandalone: true, name: "mask" }); }
94}
95i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: NgxMaskPipe, decorators: [{
96 type: Pipe,
97 args: [{
98 name: 'mask',
99 pure: true,
100 standalone: true,
101 }]
102 }] });
103//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-mask.pipe.js","sourceRoot":"","sources":["../../../../projects/ngx-mask-lib/src/lib/ngx-mask.pipe.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,IAAI,EAAiB,MAAM,eAAe,CAAC;AAE5D,OAAO,EAAW,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAC7D,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;;AAQpD,MAAM,OAAO,WAAW;IALxB;QAMqB,mBAAc,GAAG,MAAM,CAAU,eAAe,CAAC,CAAC;QAElD,iBAAY,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;QAE/C,yBAAoB,GAAa,EAAE,CAAC;QAEpC,SAAI,GAAG,EAAE,CAAC;KA6FrB;IA3FU,SAAS,CACZ,KAAsB,EACtB,IAAY,EACZ,EAAE,QAAQ,EAAE,GAAG,MAAM,KAAuB,EAAsB;QAElE,MAAM,aAAa,GAAG;YAClB,cAAc,EAAE,IAAI;YACpB,GAAG,IAAI,CAAC,cAAc;YACtB,GAAG,MAAM;YACT,QAAQ,EAAE;gBACN,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ;gBAC7B,GAAG,QAAQ;aACd;SACJ,CAAC;QACF,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;YACnD,8DAA8D;YAC7D,IAAI,CAAC,YAAoB,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;QAC5C,CAAC,CAAC,CAAC;QACH,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;YACtB,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC9B,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,CAAS,EAAE,CAAS,EAAE,EAAE;oBACvE,OAAO,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,MAAM,CAAC;gBAC/B,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,QAAQ,CAAC,KAAe,CAAC,CAAC;gBAC/B,OAAO,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,KAAK,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YAC9D,CAAC;iBAAM,CAAC;gBACJ,IAAI,CAAC,oBAAoB,GAAG,EAAE,CAAC;gBAC/B,OAAO,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,KAAK,EAAE,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;YAC9D,CAAC;QACL,CAAC;QACD,IAAI,IAAI,CAAC,QAAQ,8CAAoC,EAAE,CAAC;YACpD,OAAO,IAAI,CAAC,YAAY,CAAC,SAAS,CAC9B,GAAG,KAAK,EAAE,EACV,IAAI,CAAC,YAAY,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAChD,CAAC;QACN,CAAC;QACD,IAAI,IAAI,CAAC,UAAU,4CAA0B,EAAE,CAAC;YAC5C,IAAI,MAAM,CAAC,aAAa,EAAE,CAAC;gBACvB,IAAI,CAAC,YAAY,CAAC,aAAa,GAAG,MAAM,CAAC,aAAa,CAAC;YAC3D,CAAC;YACD,IAAI,MAAM,CAAC,iBAAiB,EAAE,CAAC;gBAC3B,IAAI,CAAC,YAAY,CAAC,iBAAiB,GAAG,MAAM,CAAC,iBAAiB,CAAC;YACnE,CAAC;YACD,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;gBAClB,IAAI,CAAC,YAAY,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;YACjD,CAAC;YAED,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;YACtB,MAAM,mBAAmB,GAAG,IAAI,CAAC,YAAY,CAAC,0BAA0B,EAAE,CAAC;YAC3E,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,EAAE,CAAC;gBAClD,KAAK;oBACD,IAAI,CAAC,YAAY,CAAC,aAAa,KAAK,mBAAmB;wBACnD,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,mBAAmB,EAAE,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC;wBACrE,CAAC,CAAC,KAAK,CAAC;YACpB,CAAC;YACD,IACI,IAAI,CAAC,YAAY,CAAC,QAAQ;gBAC1B,KAAK;gBACL,IAAI,CAAC,YAAY,CAAC,qBAAqB,KAAK,KAAK,EACnD,CAAC;gBACC,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,IAAI,EAAE,KAAe,CAAC,CAAC;YACrE,CAAC;YACD,IAAI,IAAI,CAAC,YAAY,CAAC,aAAa,mCAAyB,EAAE,CAAC;gBAC3D,KAAK,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC,OAAO,8DAA0C,CAAC;YAC/E,CAAC;YACD,IAAI,CAAC,YAAY,CAAC,aAAa,GAAG,IAAI,CAAC;QAC3C,CAAC;QACD,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YACxC,OAAO,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;QACjD,CAAC;QACD,OAAO,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,KAAK,EAAE,EAAE,IAAI,CAAC,CAAC;IACzD,CAAC;IAEO,QAAQ,CAAC,KAAa;QAC1B,IAAI,IAAI,CAAC,oBAAoB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACvC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC,IAAI,EAAkB,EAAE;gBACpD,MAAM,IAAI,GACN,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,MAAM;oBAC3C,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC;gBAC/C,IAAI,KAAK,IAAI,IAAI,EAAE,CAAC;oBAChB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;oBACjB,OAAO,IAAI,CAAC;gBAChB,CAAC;qBAAM,CAAC;oBACJ,MAAM,UAAU,GACZ,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,oBAAoB,CAAC,MAAM,GAAG,CAAC,CAAC;4DACpC,CAAC;oBAChC,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC;gBAC3B,CAAC;YACL,CAAC,CAAC,CAAC;QACP,CAAC;IACL,CAAC;8GAnGQ,WAAW;4GAAX,WAAW;;2FAAX,WAAW;kBALvB,IAAI;mBAAC;oBACF,IAAI,EAAE,MAAM;oBACZ,IAAI,EAAE,IAAI;oBACV,UAAU,EAAE,IAAI;iBACnB","sourcesContent":["import { inject, Pipe, PipeTransform } from '@angular/core';\n\nimport { IConfig, NGX_MASK_CONFIG } from './ngx-mask.config';\nimport { NgxMaskService } from './ngx-mask.service';\nimport { MaskExpression } from './ngx-mask-expression.enum';\n\n@Pipe({\n    name: 'mask',\n    pure: true,\n    standalone: true,\n})\nexport class NgxMaskPipe implements PipeTransform {\n    private readonly defaultOptions = inject<IConfig>(NGX_MASK_CONFIG);\n\n    private readonly _maskService = inject(NgxMaskService);\n\n    private _maskExpressionArray: string[] = [];\n\n    private mask = '';\n\n    public transform(\n        value: string | number,\n        mask: string,\n        { patterns, ...config }: Partial<IConfig> = {} as Partial<IConfig>\n    ): string {\n        const currentConfig = {\n            maskExpression: mask,\n            ...this.defaultOptions,\n            ...config,\n            patterns: {\n                ...this._maskService.patterns,\n                ...patterns,\n            },\n        };\n        Object.entries(currentConfig).forEach(([key, value]) => {\n            //eslint-disable-next-line  @typescript-eslint/no-explicit-any\n            (this._maskService as any)[key] = value;\n        });\n        if (mask.includes('||')) {\n            if (mask.split('||').length > 1) {\n                this._maskExpressionArray = mask.split('||').sort((a: string, b: string) => {\n                    return a.length - b.length;\n                });\n                this._setMask(value as string);\n                return this._maskService.applyMask(`${value}`, this.mask);\n            } else {\n                this._maskExpressionArray = [];\n                return this._maskService.applyMask(`${value}`, this.mask);\n            }\n        }\n        if (mask.includes(MaskExpression.CURLY_BRACKETS_LEFT)) {\n            return this._maskService.applyMask(\n                `${value}`,\n                this._maskService._repeatPatternSymbols(mask)\n            );\n        }\n        if (mask.startsWith(MaskExpression.SEPARATOR)) {\n            if (config.decimalMarker) {\n                this._maskService.decimalMarker = config.decimalMarker;\n            }\n            if (config.thousandSeparator) {\n                this._maskService.thousandSeparator = config.thousandSeparator;\n            }\n            if (config.leadZero) {\n                this._maskService.leadZero = config.leadZero;\n            }\n\n            value = String(value);\n            const localeDecimalMarker = this._maskService.currentLocaleDecimalMarker();\n            if (!Array.isArray(this._maskService.decimalMarker)) {\n                value =\n                    this._maskService.decimalMarker !== localeDecimalMarker\n                        ? value.replace(localeDecimalMarker, this._maskService.decimalMarker)\n                        : value;\n            }\n            if (\n                this._maskService.leadZero &&\n                value &&\n                this._maskService.dropSpecialCharacters !== false\n            ) {\n                value = this._maskService._checkPrecision(mask, value as string);\n            }\n            if (this._maskService.decimalMarker === MaskExpression.COMMA) {\n                value = value.toString().replace(MaskExpression.DOT, MaskExpression.COMMA);\n            }\n            this._maskService.isNumberValue = true;\n        }\n        if (value === null || value === undefined) {\n            return this._maskService.applyMask('', mask);\n        }\n        return this._maskService.applyMask(`${value}`, mask);\n    }\n\n    private _setMask(value: string) {\n        if (this._maskExpressionArray.length > 0) {\n            this._maskExpressionArray.some((mask): boolean | void => {\n                const test =\n                    this._maskService.removeMask(value)?.length <=\n                    this._maskService.removeMask(mask)?.length;\n                if (value && test) {\n                    this.mask = mask;\n                    return test;\n                } else {\n                    const expression =\n                        this._maskExpressionArray[this._maskExpressionArray.length - 1] ??\n                        MaskExpression.EMPTY_STRING;\n                    this.mask = expression;\n                }\n            });\n        }\n    }\n}\n"]}
\No newline at end of file