@kato-lee/components 1.0.3
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/LICENSE +21 -0
- package/README.md +7 -0
- package/assets/_fade-in.scss +40 -0
- package/assets/_fields.scss +76 -0
- package/assets/_grids.scss +317 -0
- package/assets/components/_buttons.scss +3 -0
- package/assets/components/_cards.scss +26 -0
- package/assets/components/_dialogs.scss +13 -0
- package/assets/components/_fields.scss +110 -0
- package/assets/components/_material.scss +15 -0
- package/assets/components/_pretty-box.scss +41 -0
- package/assets/components/_scroll-bar.scss +23 -0
- package/assets/components/_snack-bar.scss +18 -0
- package/assets/components/_tables.scss +235 -0
- package/assets/components/_tabs.scss +7 -0
- package/assets/components/main.scss +25 -0
- package/assets/fonts/body/Transpass-Bold.ttf +0 -0
- package/assets/fonts/body/Transpass-Light.ttf +0 -0
- package/assets/fonts/body/Transpass-Medium.ttf +0 -0
- package/assets/fonts/body/Transpass-Regular.ttf +0 -0
- package/assets/fonts/body/style-font.scss +40 -0
- package/assets/fonts/main.scss +2 -0
- package/assets/fonts/title/Poppins-Bold.ttf +0 -0
- package/assets/fonts/title/Poppins-Light.ttf +0 -0
- package/assets/fonts/title/Poppins-Medium.ttf +0 -0
- package/assets/fonts/title/Poppins-Regular.ttf +0 -0
- package/assets/fonts/title/Poppins-SemiBold.ttf +0 -0
- package/assets/fonts/title/style-font.scss +39 -0
- package/assets/layouts/_loader.scss +71 -0
- package/assets/layouts/origin.scss +775 -0
- package/assets/main.scss +4 -0
- package/assets/material/icons/icons.woff2 +0 -0
- package/assets/material/icons/local.css +1 -0
- package/assets/material/icons/remote.css +1 -0
- package/assets/material/themes/dark.scss +55 -0
- package/assets/material/themes/default.scss +106 -0
- package/assets/material/themes/main.scss +2907 -0
- package/assets/themes/_dark.scss +15 -0
- package/assets/themes/_default.scss +30 -0
- package/assets/themes/main.scss +2 -0
- package/assets/variables.scss +7 -0
- package/box-form/box-form.component.d.ts +34 -0
- package/box-form/box-form.module.d.ts +13 -0
- package/box-form/common.d.ts +5 -0
- package/box-form/index.d.ts +3 -0
- package/box-form/package.json +3 -0
- package/capsule/capsule.component.d.ts +14 -0
- package/capsule/capsule.module.d.ts +7 -0
- package/capsule/index.d.ts +2 -0
- package/capsule/package.json +3 -0
- package/cards/cards.module.d.ts +7 -0
- package/cards/index.d.ts +2 -0
- package/cards/package.json +3 -0
- package/cards/simple-card.component.d.ts +8 -0
- package/dialogs/dialogs.module.d.ts +11 -0
- package/dialogs/dismiss-dialog-button.component.d.ts +8 -0
- package/dialogs/index.d.ts +2 -0
- package/dialogs/package.json +3 -0
- package/esm2022/box-form/box-form.component.mjs +99 -0
- package/esm2022/box-form/box-form.module.mjs +40 -0
- package/esm2022/box-form/common.mjs +2 -0
- package/esm2022/box-form/index.mjs +7 -0
- package/esm2022/box-form/kato-lee-components-box-form.mjs +5 -0
- package/esm2022/capsule/capsule.component.mjs +78 -0
- package/esm2022/capsule/capsule.module.mjs +16 -0
- package/esm2022/capsule/index.mjs +6 -0
- package/esm2022/capsule/kato-lee-components-capsule.mjs +5 -0
- package/esm2022/cards/cards.module.mjs +17 -0
- package/esm2022/cards/index.mjs +6 -0
- package/esm2022/cards/kato-lee-components-cards.mjs +5 -0
- package/esm2022/cards/simple-card.component.mjs +47 -0
- package/esm2022/dialogs/dialogs.module.mjs +22 -0
- package/esm2022/dialogs/dismiss-dialog-button.component.mjs +44 -0
- package/esm2022/dialogs/index.mjs +6 -0
- package/esm2022/dialogs/kato-lee-components-dialogs.mjs +5 -0
- package/esm2022/fields/autocomplete-field/autocomplete-field.component.mjs +240 -0
- package/esm2022/fields/date-field/date-field.component.mjs +148 -0
- package/esm2022/fields/date-range-field/date-range-field.component.mjs +70 -0
- package/esm2022/fields/error/error-equals.pipe.mjs +19 -0
- package/esm2022/fields/error/error.component.mjs +55 -0
- package/esm2022/fields/error/error.module.mjs +21 -0
- package/esm2022/fields/error/error.msg.pipe.mjs +19 -0
- package/esm2022/fields/error/lang/_en.mjs +12 -0
- package/esm2022/fields/error/lang/_es.mjs +12 -0
- package/esm2022/fields/error/lang/index.mjs +3 -0
- package/esm2022/fields/fields.common.mjs +8 -0
- package/esm2022/fields/fields.module.mjs +118 -0
- package/esm2022/fields/general-field/general-field.component.mjs +188 -0
- package/esm2022/fields/index.mjs +17 -0
- package/esm2022/fields/kato-lee-components-fields.mjs +5 -0
- package/esm2022/fields/money-field/money-field.component.mjs +188 -0
- package/esm2022/fields/number-field/number-field.component.mjs +165 -0
- package/esm2022/fields/select-field/select-field.component.mjs +135 -0
- package/esm2022/fields/text-area/textarea.component.mjs +171 -0
- package/esm2022/index.mjs +2 -0
- package/esm2022/kato-lee-components.mjs +5 -0
- package/esm2022/layouts/origin/breadcrumb/breadcrumb.component.mjs +65 -0
- package/esm2022/layouts/origin/footer/footer.component.mjs +11 -0
- package/esm2022/layouts/origin/header/header.component.mjs +46 -0
- package/esm2022/layouts/origin/index.mjs +12 -0
- package/esm2022/layouts/origin/kato-lee-components-layouts-origin.mjs +5 -0
- package/esm2022/layouts/origin/layout.component.mjs +210 -0
- package/esm2022/layouts/origin/layout.module.mjs +52 -0
- package/esm2022/layouts/origin/layout.navigation.mjs +19 -0
- package/esm2022/layouts/origin/navigation-interfaces.mjs +2 -0
- package/esm2022/layouts/origin/services/index.mjs +4 -0
- package/esm2022/layouts/origin/services/route-parts.service.mjs +28 -0
- package/esm2022/layouts/origin/services/toggle-sidebar.mjs +48 -0
- package/esm2022/layouts/origin/services/validate-access.pipe.mjs +53 -0
- package/esm2022/layouts/origin/sidebar/sidebar.component.mjs +69 -0
- package/esm2022/layouts/origin/sidebar/sidenav/expansion/accordion.component.mjs +74 -0
- package/esm2022/layouts/origin/sidebar/sidenav/expansion/expansion-panel-header.component.mjs +51 -0
- package/esm2022/layouts/origin/sidebar/sidenav/expansion/expansion-panel.component.mjs +63 -0
- package/esm2022/layouts/origin/sidebar/sidenav/sidenav.component.mjs +130 -0
- package/esm2022/modal/config.mjs +2 -0
- package/esm2022/modal/index.mjs +8 -0
- package/esm2022/modal/kato-lee-components-modal.mjs +5 -0
- package/esm2022/modal/modal.component.mjs +63 -0
- package/esm2022/modal/modal.module.mjs +21 -0
- package/esm2022/modal/modal.service.mjs +33 -0
- package/esm2022/pretty-box/index.mjs +5 -0
- package/esm2022/pretty-box/kato-lee-components-pretty-box.mjs +5 -0
- package/esm2022/pretty-box/pretty-box.component.mjs +94 -0
- package/esm2022/tables/index.mjs +6 -0
- package/esm2022/tables/kato-lee-components-tables.mjs +5 -0
- package/esm2022/tables/mat-paginator.translation.mjs +22 -0
- package/esm2022/tables/tables.module.mjs +19 -0
- package/esm2022/toast/index.mjs +5 -0
- package/esm2022/toast/kato-lee-components-toast.mjs +5 -0
- package/esm2022/toast/toast.service.mjs +42 -0
- package/fesm2022/kato-lee-components-box-form.mjs +146 -0
- package/fesm2022/kato-lee-components-box-form.mjs.map +1 -0
- package/fesm2022/kato-lee-components-capsule.mjs +102 -0
- package/fesm2022/kato-lee-components-capsule.mjs.map +1 -0
- package/fesm2022/kato-lee-components-cards.mjs +72 -0
- package/fesm2022/kato-lee-components-cards.mjs.map +1 -0
- package/fesm2022/kato-lee-components-dialogs.mjs +74 -0
- package/fesm2022/kato-lee-components-dialogs.mjs.map +1 -0
- package/fesm2022/kato-lee-components-fields.mjs +1486 -0
- package/fesm2022/kato-lee-components-fields.mjs.map +1 -0
- package/fesm2022/kato-lee-components-layouts-origin.mjs +872 -0
- package/fesm2022/kato-lee-components-layouts-origin.mjs.map +1 -0
- package/fesm2022/kato-lee-components-modal.mjs +121 -0
- package/fesm2022/kato-lee-components-modal.mjs.map +1 -0
- package/fesm2022/kato-lee-components-pretty-box.mjs +105 -0
- package/fesm2022/kato-lee-components-pretty-box.mjs.map +1 -0
- package/fesm2022/kato-lee-components-tables.mjs +51 -0
- package/fesm2022/kato-lee-components-tables.mjs.map +1 -0
- package/fesm2022/kato-lee-components-toast.mjs +53 -0
- package/fesm2022/kato-lee-components-toast.mjs.map +1 -0
- package/fesm2022/kato-lee-components.mjs +4 -0
- package/fesm2022/kato-lee-components.mjs.map +1 -0
- package/fields/autocomplete-field/autocomplete-field.component.d.ts +65 -0
- package/fields/date-field/date-field.component.d.ts +46 -0
- package/fields/date-range-field/date-range-field.component.d.ts +23 -0
- package/fields/error/error-equals.pipe.d.ts +7 -0
- package/fields/error/error.component.d.ts +22 -0
- package/fields/error/error.module.d.ts +11 -0
- package/fields/error/error.msg.pipe.d.ts +7 -0
- package/fields/error/lang/_en.d.ts +1 -0
- package/fields/error/lang/_es.d.ts +1 -0
- package/fields/error/lang/index.d.ts +2 -0
- package/fields/fields.common.d.ts +5 -0
- package/fields/fields.module.d.ts +28 -0
- package/fields/general-field/general-field.component.d.ts +56 -0
- package/fields/index.d.ts +13 -0
- package/fields/money-field/money-field.component.d.ts +53 -0
- package/fields/number-field/number-field.component.d.ts +52 -0
- package/fields/package.json +3 -0
- package/fields/select-field/select-field.component.d.ts +44 -0
- package/fields/text-area/textarea.component.d.ts +55 -0
- package/index.d.ts +1 -0
- package/layouts/origin/breadcrumb/breadcrumb.component.d.ts +24 -0
- package/layouts/origin/footer/footer.component.d.ts +5 -0
- package/layouts/origin/header/header.component.d.ts +15 -0
- package/layouts/origin/index.d.ts +8 -0
- package/layouts/origin/layout.component.d.ts +58 -0
- package/layouts/origin/layout.module.d.ts +18 -0
- package/layouts/origin/layout.navigation.d.ts +10 -0
- package/layouts/origin/navigation-interfaces.d.ts +24 -0
- package/layouts/origin/package.json +3 -0
- package/layouts/origin/services/index.d.ts +3 -0
- package/layouts/origin/services/route-parts.service.d.ts +15 -0
- package/layouts/origin/services/toggle-sidebar.d.ts +10 -0
- package/layouts/origin/services/validate-access.pipe.d.ts +7 -0
- package/layouts/origin/sidebar/sidebar.component.d.ts +27 -0
- package/layouts/origin/sidebar/sidenav/expansion/accordion.component.d.ts +10 -0
- package/layouts/origin/sidebar/sidenav/expansion/expansion-panel-header.component.d.ts +11 -0
- package/layouts/origin/sidebar/sidenav/expansion/expansion-panel.component.d.ts +12 -0
- package/layouts/origin/sidebar/sidenav/sidenav.component.d.ts +23 -0
- package/modal/config.d.ts +9 -0
- package/modal/index.d.ts +4 -0
- package/modal/modal.component.d.ts +35 -0
- package/modal/modal.module.d.ts +11 -0
- package/modal/modal.service.d.ts +13 -0
- package/modal/package.json +3 -0
- package/package.json +82 -0
- package/pretty-box/index.d.ts +1 -0
- package/pretty-box/package.json +3 -0
- package/pretty-box/pretty-box.component.d.ts +24 -0
- package/tables/index.d.ts +2 -0
- package/tables/mat-paginator.translation.d.ts +2 -0
- package/tables/package.json +3 -0
- package/tables/tables.module.d.ts +9 -0
- package/toast/index.d.ts +1 -0
- package/toast/package.json +3 -0
- package/toast/toast.service.d.ts +21 -0
|
@@ -0,0 +1,188 @@
|
|
|
1
|
+
import { Component, Optional, Input, Self, Output, EventEmitter, } from '@angular/core';
|
|
2
|
+
import { Validators, } from '@angular/forms';
|
|
3
|
+
import { TAK_DEFAULT_APPEARANCE_FORM } from '../fields.common';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/forms";
|
|
6
|
+
import * as i2 from "@kato-lee/material/form-field";
|
|
7
|
+
import * as i3 from "@kato-lee/material/button";
|
|
8
|
+
import * as i4 from "../error/error.component";
|
|
9
|
+
import * as i5 from "@kato-lee/material/icon";
|
|
10
|
+
import * as i6 from "@kato-lee/material/input";
|
|
11
|
+
export class TakGeneralFieldComponent {
|
|
12
|
+
constructor(_ngControl, _formGroupDirective, _cd) {
|
|
13
|
+
this._ngControl = _ngControl;
|
|
14
|
+
this._formGroupDirective = _formGroupDirective;
|
|
15
|
+
this._cd = _cd;
|
|
16
|
+
this.autocomplete = 'off';
|
|
17
|
+
this.appearance = TAK_DEFAULT_APPEARANCE_FORM;
|
|
18
|
+
this.type = 'text';
|
|
19
|
+
this.floatLabel = 'never';
|
|
20
|
+
this.color = 'primary';
|
|
21
|
+
this.actionIcon = 'search';
|
|
22
|
+
this.defaultFilterStyle = true;
|
|
23
|
+
this.hasActionButton = false;
|
|
24
|
+
this.hasClearButton = false;
|
|
25
|
+
this.countCaracters = false;
|
|
26
|
+
this.placeholder = '';
|
|
27
|
+
this.disabled = false;
|
|
28
|
+
this.onExecuteAction = new EventEmitter();
|
|
29
|
+
this.onKeyUp = new EventEmitter();
|
|
30
|
+
this.onChangeFn = (_) => { };
|
|
31
|
+
this.onTouchFn = (_) => { };
|
|
32
|
+
this._isSubmitted = false;
|
|
33
|
+
this._isInvalid = false;
|
|
34
|
+
this._required = false;
|
|
35
|
+
this._value = '';
|
|
36
|
+
this._decrypted = false;
|
|
37
|
+
if (_ngControl)
|
|
38
|
+
this._ngControl.valueAccessor = this;
|
|
39
|
+
if (_formGroupDirective) {
|
|
40
|
+
this._subscription = _formGroupDirective.ngSubmit.subscribe(() => {
|
|
41
|
+
this._isSubmitted = true;
|
|
42
|
+
_cd.markForCheck();
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
ngOnInit() {
|
|
47
|
+
const form = this.control;
|
|
48
|
+
if (this.type === 'filter' && this.defaultFilterStyle) {
|
|
49
|
+
this.control.removeValidators(Validators.required);
|
|
50
|
+
this.appearance = 'legacy';
|
|
51
|
+
this.floatLabel = 'never';
|
|
52
|
+
if (!this.placeholder)
|
|
53
|
+
this.placeholder = 'Buscar';
|
|
54
|
+
this.hasClearButton = true;
|
|
55
|
+
this._cd.markForCheck();
|
|
56
|
+
}
|
|
57
|
+
if (form?._rawValidators) {
|
|
58
|
+
form._rawValidators.forEach((r) => {
|
|
59
|
+
if (r.name.includes('required'))
|
|
60
|
+
this._required = true;
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
if (this.disabled)
|
|
64
|
+
this.control.disable();
|
|
65
|
+
}
|
|
66
|
+
writeValue(value) {
|
|
67
|
+
if (value === null)
|
|
68
|
+
this._isInvalid = false;
|
|
69
|
+
this._value = value;
|
|
70
|
+
this._isSubmitted = false;
|
|
71
|
+
this._cd.markForCheck();
|
|
72
|
+
}
|
|
73
|
+
registerOnChange(fn) {
|
|
74
|
+
this.onChangeFn = fn;
|
|
75
|
+
}
|
|
76
|
+
registerOnTouched(fn) {
|
|
77
|
+
this.onTouchFn = fn;
|
|
78
|
+
}
|
|
79
|
+
onChange(event) {
|
|
80
|
+
this._value = event.target.value;
|
|
81
|
+
this.onChangeFn(event.target.value);
|
|
82
|
+
if (!this.control.value && this.type === 'password')
|
|
83
|
+
this._decrypted = false;
|
|
84
|
+
if (this.control.touched)
|
|
85
|
+
this._onValidate();
|
|
86
|
+
if (this.type === 'filter')
|
|
87
|
+
this.onKeyUp.emit(this.control.value);
|
|
88
|
+
}
|
|
89
|
+
showPassword() {
|
|
90
|
+
if (this.type === 'password') {
|
|
91
|
+
if (this._decrypted)
|
|
92
|
+
this._decrypted = false;
|
|
93
|
+
else
|
|
94
|
+
this._decrypted = true;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
onFocusOut() {
|
|
98
|
+
this.onTouchFn(true);
|
|
99
|
+
this._onValidate();
|
|
100
|
+
}
|
|
101
|
+
_onValidate() {
|
|
102
|
+
if (this.control.invalid)
|
|
103
|
+
this._isInvalid = true;
|
|
104
|
+
else
|
|
105
|
+
this._isInvalid = false;
|
|
106
|
+
}
|
|
107
|
+
onClearControl() {
|
|
108
|
+
if (['', null, undefined].indexOf(this.control.value) >= 0) {
|
|
109
|
+
this.control.setValue('', { emitEvent: false });
|
|
110
|
+
}
|
|
111
|
+
else
|
|
112
|
+
this.control.setValue('');
|
|
113
|
+
this._value = '';
|
|
114
|
+
}
|
|
115
|
+
ngOnDestroy() {
|
|
116
|
+
if (this._subscription)
|
|
117
|
+
this._subscription.unsubscribe();
|
|
118
|
+
}
|
|
119
|
+
get control() {
|
|
120
|
+
return this._ngControl.control;
|
|
121
|
+
}
|
|
122
|
+
get directive() {
|
|
123
|
+
return this._formGroupDirective;
|
|
124
|
+
}
|
|
125
|
+
get decrypted() {
|
|
126
|
+
return this._decrypted;
|
|
127
|
+
}
|
|
128
|
+
get isDisabled() {
|
|
129
|
+
return this._ngControl.disabled;
|
|
130
|
+
}
|
|
131
|
+
get isSubmitted() {
|
|
132
|
+
return this._isSubmitted;
|
|
133
|
+
}
|
|
134
|
+
get isInvalid() {
|
|
135
|
+
return this._isInvalid;
|
|
136
|
+
}
|
|
137
|
+
get required() {
|
|
138
|
+
return this._required;
|
|
139
|
+
}
|
|
140
|
+
get value() {
|
|
141
|
+
return this._value;
|
|
142
|
+
}
|
|
143
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: TakGeneralFieldComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: i1.FormGroupDirective, optional: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
144
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.3", type: TakGeneralFieldComponent, selector: "tak-general-field", inputs: { autocomplete: "autocomplete", appearance: "appearance", type: "type", floatLabel: "floatLabel", color: "color", actionIcon: "actionIcon", defaultFilterStyle: "defaultFilterStyle", hasActionButton: "hasActionButton", hasClearButton: "hasClearButton", countCaracters: "countCaracters", placeholder: "placeholder", maxLength: "maxLength", minLength: "minLength", disabled: "disabled" }, outputs: { onExecuteAction: "onExecuteAction", onKeyUp: "onKeyUp" }, ngImport: i0, template: "<div class=\"tak-form-container\">\r\n <mat-form-field\r\n [floatLabel]=\"floatLabel\"\r\n [class.mat-form-field-invalid]=\"isInvalid || (isSubmitted && control.invalid)\"\r\n [appearance]=\"appearance\"\r\n [color]=\"color\"\r\n >\r\n <mat-label>\r\n <ng-content></ng-content>{{ ' ' }}\r\n @if (required) {\r\n <span class=\"tak-field__danger-x\">*</span>\r\n }\r\n </mat-label>\r\n <input\r\n [type]=\"type === 'password' && !decrypted ? 'password' : 'text'\"\r\n matInput\r\n [autocomplete]=\"autocomplete\"\r\n [value]=\"value\"\r\n (keyup)=\"onChange($event)\"\r\n (change)=\"onChange($event)\"\r\n [placeholder]=\"placeholder\"\r\n [disabled]=\"isDisabled\"\r\n [attr.minLength]=\"minLength\"\r\n [attr.maxLength]=\"maxLength\"\r\n (focusout)=\"onFocusOut()\"\r\n />\r\n @if (control.value && hasClearButton && !isDisabled) {\r\n <button matSuffix mat-icon-button type=\"button\" (click)=\"onClearControl()\">\r\n <mat-icon class=\"tak-suffix-icon-button\">close</mat-icon>\r\n </button>\r\n }\r\n @if (control.value && hasActionButton && !isDisabled) {\r\n <button matSuffix mat-icon-button type=\"button\" (click)=\"onExecuteAction.emit(control.value)\">\r\n <mat-icon class=\"tak-suffix-icon-button\">{{ actionIcon }}</mat-icon>\r\n </button>\r\n }\r\n @if (control.value && type === 'password' && !isDisabled) {\r\n <button matSuffix mat-icon-button type=\"button\" (click)=\"showPassword()\">\r\n <mat-icon class=\"tak-suffix-icon-button\">{{\r\n decrypted ? 'visibility_off' : 'visibility'\r\n }}</mat-icon>\r\n </button>\r\n }\r\n @if (countCaracters) {\r\n <mat-hint align=\"end\" class=\"tak-hint\">\r\n {{ control.value?.length || 0 }}/{{ maxLength }}\r\n </mat-hint>\r\n }\r\n </mat-form-field>\r\n <div [style.maxWidth]=\"countCaracters ? '80%' : '100%'\">\r\n @if (isInvalid || (isSubmitted && control.invalid)) {\r\n <tak-error [control]=\"control\"></tak-error>\r\n }\r\n </div>\r\n</div>\r\n", dependencies: [{ kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2.MatSuffix, selector: "[matSuffix]" }, { kind: "component", type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4.TakErrorComponent, selector: "tak-error", inputs: ["control", "start", "end", "isDateField", "isNumberField", "marginTop"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }] }); }
|
|
145
|
+
}
|
|
146
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: TakGeneralFieldComponent, decorators: [{
|
|
147
|
+
type: Component,
|
|
148
|
+
args: [{ selector: 'tak-general-field', template: "<div class=\"tak-form-container\">\r\n <mat-form-field\r\n [floatLabel]=\"floatLabel\"\r\n [class.mat-form-field-invalid]=\"isInvalid || (isSubmitted && control.invalid)\"\r\n [appearance]=\"appearance\"\r\n [color]=\"color\"\r\n >\r\n <mat-label>\r\n <ng-content></ng-content>{{ ' ' }}\r\n @if (required) {\r\n <span class=\"tak-field__danger-x\">*</span>\r\n }\r\n </mat-label>\r\n <input\r\n [type]=\"type === 'password' && !decrypted ? 'password' : 'text'\"\r\n matInput\r\n [autocomplete]=\"autocomplete\"\r\n [value]=\"value\"\r\n (keyup)=\"onChange($event)\"\r\n (change)=\"onChange($event)\"\r\n [placeholder]=\"placeholder\"\r\n [disabled]=\"isDisabled\"\r\n [attr.minLength]=\"minLength\"\r\n [attr.maxLength]=\"maxLength\"\r\n (focusout)=\"onFocusOut()\"\r\n />\r\n @if (control.value && hasClearButton && !isDisabled) {\r\n <button matSuffix mat-icon-button type=\"button\" (click)=\"onClearControl()\">\r\n <mat-icon class=\"tak-suffix-icon-button\">close</mat-icon>\r\n </button>\r\n }\r\n @if (control.value && hasActionButton && !isDisabled) {\r\n <button matSuffix mat-icon-button type=\"button\" (click)=\"onExecuteAction.emit(control.value)\">\r\n <mat-icon class=\"tak-suffix-icon-button\">{{ actionIcon }}</mat-icon>\r\n </button>\r\n }\r\n @if (control.value && type === 'password' && !isDisabled) {\r\n <button matSuffix mat-icon-button type=\"button\" (click)=\"showPassword()\">\r\n <mat-icon class=\"tak-suffix-icon-button\">{{\r\n decrypted ? 'visibility_off' : 'visibility'\r\n }}</mat-icon>\r\n </button>\r\n }\r\n @if (countCaracters) {\r\n <mat-hint align=\"end\" class=\"tak-hint\">\r\n {{ control.value?.length || 0 }}/{{ maxLength }}\r\n </mat-hint>\r\n }\r\n </mat-form-field>\r\n <div [style.maxWidth]=\"countCaracters ? '80%' : '100%'\">\r\n @if (isInvalid || (isSubmitted && control.invalid)) {\r\n <tak-error [control]=\"control\"></tak-error>\r\n }\r\n </div>\r\n</div>\r\n" }]
|
|
149
|
+
}], ctorParameters: () => [{ type: i1.NgControl, decorators: [{
|
|
150
|
+
type: Self
|
|
151
|
+
}, {
|
|
152
|
+
type: Optional
|
|
153
|
+
}] }, { type: i1.FormGroupDirective, decorators: [{
|
|
154
|
+
type: Optional
|
|
155
|
+
}] }, { type: i0.ChangeDetectorRef }], propDecorators: { autocomplete: [{
|
|
156
|
+
type: Input
|
|
157
|
+
}], appearance: [{
|
|
158
|
+
type: Input
|
|
159
|
+
}], type: [{
|
|
160
|
+
type: Input
|
|
161
|
+
}], floatLabel: [{
|
|
162
|
+
type: Input
|
|
163
|
+
}], color: [{
|
|
164
|
+
type: Input
|
|
165
|
+
}], actionIcon: [{
|
|
166
|
+
type: Input
|
|
167
|
+
}], defaultFilterStyle: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], hasActionButton: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], hasClearButton: [{
|
|
172
|
+
type: Input
|
|
173
|
+
}], countCaracters: [{
|
|
174
|
+
type: Input
|
|
175
|
+
}], placeholder: [{
|
|
176
|
+
type: Input
|
|
177
|
+
}], maxLength: [{
|
|
178
|
+
type: Input
|
|
179
|
+
}], minLength: [{
|
|
180
|
+
type: Input
|
|
181
|
+
}], disabled: [{
|
|
182
|
+
type: Input
|
|
183
|
+
}], onExecuteAction: [{
|
|
184
|
+
type: Output
|
|
185
|
+
}], onKeyUp: [{
|
|
186
|
+
type: Output
|
|
187
|
+
}] } });
|
|
188
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"general-field.component.js","sourceRoot":"","sources":["../../../../../libraries/components/fields/general-field/general-field.component.ts","../../../../../libraries/components/fields/general-field/general-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  OnDestroy,\r\n  Optional,\r\n  OnInit,\r\n  Input,\r\n  Self,\r\n  Output,\r\n  EventEmitter,\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  FormGroupDirective,\r\n  FormControl,\r\n  NgControl,\r\n  Validators,\r\n} from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { TAK_DEFAULT_APPEARANCE_FORM, TakGeneralFieldType } from '../fields.common';\r\nimport { FloatLabelType, MatFormFieldAppearance } from '@kato-lee/material/form-field';\r\nimport { ThemePalette } from '@kato-lee/material/core';\r\n\r\n@Component({\r\n  selector: 'tak-general-field',\r\n  templateUrl: './general-field.component.html',\r\n})\r\nexport class TakGeneralFieldComponent implements OnInit, OnDestroy, ControlValueAccessor {\r\n  @Input() autocomplete: 'off' | 'on' = 'off';\r\n\r\n  @Input() appearance: MatFormFieldAppearance = TAK_DEFAULT_APPEARANCE_FORM;\r\n  @Input() type: TakGeneralFieldType = 'text';\r\n  @Input() floatLabel: FloatLabelType = 'never';\r\n  @Input() color: ThemePalette = 'primary';\r\n  @Input() actionIcon = 'search';\r\n\r\n  @Input() defaultFilterStyle = true;\r\n  @Input() hasActionButton = false;\r\n  @Input() hasClearButton = false;\r\n  @Input() countCaracters = false;\r\n  @Input() placeholder = '';\r\n\r\n  @Input() maxLength!: number;\r\n  @Input() minLength!: number;\r\n\r\n  @Input() disabled = false;\r\n\r\n  @Output() onExecuteAction = new EventEmitter();\r\n  @Output() onKeyUp = new EventEmitter();\r\n\r\n  public onChangeFn = (_: any) => {};\r\n  public onTouchFn = (_: any) => {};\r\n\r\n  private _isSubmitted = false;\r\n  private _isInvalid = false;\r\n  private _required = false;\r\n  private _value = '';\r\n\r\n  private _subscription!: Subscription;\r\n  private _decrypted = false;\r\n\r\n  constructor(\r\n    @Self() @Optional() private _ngControl: NgControl,\r\n    @Optional() private _formGroupDirective: FormGroupDirective,\r\n    private _cd: ChangeDetectorRef\r\n  ) {\r\n    if (_ngControl) this._ngControl.valueAccessor = this;\r\n\r\n    if (_formGroupDirective) {\r\n      this._subscription = _formGroupDirective.ngSubmit.subscribe(() => {\r\n        this._isSubmitted = true;\r\n        _cd.markForCheck();\r\n      });\r\n    }\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    const form: any = this.control;\r\n\r\n    if (this.type === 'filter' && this.defaultFilterStyle) {\r\n      this.control.removeValidators(Validators.required);\r\n      this.appearance = 'legacy';\r\n      this.floatLabel = 'never';\r\n      if (!this.placeholder) this.placeholder = 'Buscar';\r\n      this.hasClearButton = true;\r\n      this._cd.markForCheck();\r\n    }\r\n\r\n    if (form?._rawValidators) {\r\n      form._rawValidators.forEach((r: any) => {\r\n        if (r.name.includes('required')) this._required = true;\r\n      });\r\n    }\r\n\r\n    if (this.disabled) this.control.disable();\r\n  }\r\n\r\n  public writeValue(value: string): void {\r\n    if (value === null) this._isInvalid = false;\r\n    this._value = value;\r\n    this._isSubmitted = false;\r\n    this._cd.markForCheck();\r\n  }\r\n\r\n  public registerOnChange(fn: any): void {\r\n    this.onChangeFn = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: any): void {\r\n    this.onTouchFn = fn;\r\n  }\r\n\r\n  public onChange(event: any): void {\r\n    this._value = event.target.value;\r\n    this.onChangeFn(event.target.value);\r\n    if (!this.control.value && this.type === 'password') this._decrypted = false;\r\n    if (this.control.touched) this._onValidate();\r\n    if (this.type === 'filter') this.onKeyUp.emit(this.control.value);\r\n  }\r\n\r\n  public showPassword(): void {\r\n    if (this.type === 'password') {\r\n      if (this._decrypted) this._decrypted = false;\r\n      else this._decrypted = true;\r\n    }\r\n  }\r\n\r\n  public onFocusOut(): void {\r\n    this.onTouchFn(true);\r\n    this._onValidate();\r\n  }\r\n\r\n  private _onValidate(): void {\r\n    if (this.control.invalid) this._isInvalid = true;\r\n    else this._isInvalid = false;\r\n  }\r\n\r\n  public onClearControl(): void {\r\n    if (['', null, undefined].indexOf(this.control.value) >= 0) {\r\n      this.control.setValue('', { emitEvent: false });\r\n    } else this.control.setValue('');\r\n    this._value = '';\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    if (this._subscription) this._subscription.unsubscribe();\r\n  }\r\n\r\n  get control(): FormControl {\r\n    return this._ngControl.control as FormControl;\r\n  }\r\n\r\n  get directive(): FormGroupDirective {\r\n    return this._formGroupDirective as FormGroupDirective;\r\n  }\r\n\r\n  get decrypted() {\r\n    return this._decrypted;\r\n  }\r\n\r\n  get isDisabled() {\r\n    return this._ngControl.disabled;\r\n  }\r\n\r\n  get isSubmitted() {\r\n    return this._isSubmitted;\r\n  }\r\n\r\n  get isInvalid() {\r\n    return this._isInvalid;\r\n  }\r\n\r\n  get required() {\r\n    return this._required;\r\n  }\r\n\r\n  get value() {\r\n    return this._value;\r\n  }\r\n}\r\n","<div class=\"tak-form-container\">\r\n  <mat-form-field\r\n    [floatLabel]=\"floatLabel\"\r\n    [class.mat-form-field-invalid]=\"isInvalid || (isSubmitted && control.invalid)\"\r\n    [appearance]=\"appearance\"\r\n    [color]=\"color\"\r\n  >\r\n    <mat-label>\r\n      <ng-content></ng-content>{{ ' ' }}\r\n      @if (required) {\r\n        <span class=\"tak-field__danger-x\">*</span>\r\n      }\r\n    </mat-label>\r\n    <input\r\n      [type]=\"type === 'password' && !decrypted ? 'password' : 'text'\"\r\n      matInput\r\n      [autocomplete]=\"autocomplete\"\r\n      [value]=\"value\"\r\n      (keyup)=\"onChange($event)\"\r\n      (change)=\"onChange($event)\"\r\n      [placeholder]=\"placeholder\"\r\n      [disabled]=\"isDisabled\"\r\n      [attr.minLength]=\"minLength\"\r\n      [attr.maxLength]=\"maxLength\"\r\n      (focusout)=\"onFocusOut()\"\r\n    />\r\n    @if (control.value && hasClearButton && !isDisabled) {\r\n      <button matSuffix mat-icon-button type=\"button\" (click)=\"onClearControl()\">\r\n        <mat-icon class=\"tak-suffix-icon-button\">close</mat-icon>\r\n      </button>\r\n    }\r\n    @if (control.value && hasActionButton && !isDisabled) {\r\n      <button matSuffix mat-icon-button type=\"button\" (click)=\"onExecuteAction.emit(control.value)\">\r\n        <mat-icon class=\"tak-suffix-icon-button\">{{ actionIcon }}</mat-icon>\r\n      </button>\r\n    }\r\n    @if (control.value && type === 'password' && !isDisabled) {\r\n      <button matSuffix mat-icon-button type=\"button\" (click)=\"showPassword()\">\r\n        <mat-icon class=\"tak-suffix-icon-button\">{{\r\n          decrypted ? 'visibility_off' : 'visibility'\r\n        }}</mat-icon>\r\n      </button>\r\n    }\r\n    @if (countCaracters) {\r\n      <mat-hint align=\"end\" class=\"tak-hint\">\r\n        {{ control.value?.length || 0 }}/{{ maxLength }}\r\n      </mat-hint>\r\n    }\r\n  </mat-form-field>\r\n  <div [style.maxWidth]=\"countCaracters ? '80%' : '100%'\">\r\n    @if (isInvalid || (isSubmitted && control.invalid)) {\r\n      <tak-error [control]=\"control\"></tak-error>\r\n    }\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Public API Surface of @kato-lee/components/fields
|
|
3
|
+
*/
|
|
4
|
+
export * from './error/error-equals.pipe';
|
|
5
|
+
export * from './error/error.component';
|
|
6
|
+
export * from './error/error.msg.pipe';
|
|
7
|
+
export * from './fields.common';
|
|
8
|
+
export * from './fields.module';
|
|
9
|
+
export * from './select-field/select-field.component';
|
|
10
|
+
export * from './date-field/date-field.component';
|
|
11
|
+
export * from './autocomplete-field/autocomplete-field.component';
|
|
12
|
+
export * from './general-field/general-field.component';
|
|
13
|
+
export * from './money-field/money-field.component';
|
|
14
|
+
export * from './text-area/textarea.component';
|
|
15
|
+
export * from './date-range-field/date-range-field.component';
|
|
16
|
+
export * from './number-field/number-field.component';
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJyYXJpZXMvY29tcG9uZW50cy9maWVsZHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLHVDQUF1QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIEBrYXRvLWxlZS9jb21wb25lbnRzL2ZpZWxkc1xyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vZXJyb3IvZXJyb3ItZXF1YWxzLnBpcGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2Vycm9yL2Vycm9yLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZXJyb3IvZXJyb3IubXNnLnBpcGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2ZpZWxkcy5jb21tb24nO1xyXG5leHBvcnQgKiBmcm9tICcuL2ZpZWxkcy5tb2R1bGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NlbGVjdC1maWVsZC9zZWxlY3QtZmllbGQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9kYXRlLWZpZWxkL2RhdGUtZmllbGQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9hdXRvY29tcGxldGUtZmllbGQvYXV0b2NvbXBsZXRlLWZpZWxkLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZ2VuZXJhbC1maWVsZC9nZW5lcmFsLWZpZWxkLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbW9uZXktZmllbGQvbW9uZXktZmllbGQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi90ZXh0LWFyZWEvdGV4dGFyZWEuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9kYXRlLXJhbmdlLWZpZWxkL2RhdGUtcmFuZ2UtZmllbGQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9udW1iZXItZmllbGQvbnVtYmVyLWZpZWxkLmNvbXBvbmVudCc7XHJcbiJdfQ==
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2F0by1sZWUtY29tcG9uZW50cy1maWVsZHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJyYXJpZXMvY29tcG9uZW50cy9maWVsZHMva2F0by1sZWUtY29tcG9uZW50cy1maWVsZHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
|
|
@@ -0,0 +1,188 @@
|
|
|
1
|
+
import { Component, Optional, Input, Self, Output, EventEmitter, } from '@angular/core';
|
|
2
|
+
import { Validators, } from '@angular/forms';
|
|
3
|
+
import { TAK_DEFAULT_APPEARANCE_FORM } from '../fields.common';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/forms";
|
|
6
|
+
import * as i2 from "@kato-lee/material/form-field";
|
|
7
|
+
import * as i3 from "@kato-lee/material/button";
|
|
8
|
+
import * as i4 from "../error/error.component";
|
|
9
|
+
import * as i5 from "@kato-lee/material/icon";
|
|
10
|
+
import * as i6 from "@kato-lee/material/input";
|
|
11
|
+
export class TakMoneyFieldComponent {
|
|
12
|
+
constructor(_ngControl, _formGroupDirective, _cd) {
|
|
13
|
+
this._ngControl = _ngControl;
|
|
14
|
+
this._formGroupDirective = _formGroupDirective;
|
|
15
|
+
this._cd = _cd;
|
|
16
|
+
this.autocomplete = 'off';
|
|
17
|
+
this.appearance = TAK_DEFAULT_APPEARANCE_FORM;
|
|
18
|
+
this.floatLabel = 'auto';
|
|
19
|
+
this.color = 'primary';
|
|
20
|
+
this.actionIcon = 'search';
|
|
21
|
+
this.defaultFilterStyle = true;
|
|
22
|
+
this.hasActionButton = false;
|
|
23
|
+
this.hasClearButton = true;
|
|
24
|
+
this.countCaracters = false;
|
|
25
|
+
this.placeholder = '';
|
|
26
|
+
this.disabled = false;
|
|
27
|
+
this.onExecuteAction = new EventEmitter();
|
|
28
|
+
this.onKeyUp = new EventEmitter();
|
|
29
|
+
this.onChangeFn = (_) => { };
|
|
30
|
+
this.onTouchFn = (_) => { };
|
|
31
|
+
this._isSubmitted = false;
|
|
32
|
+
this._isInvalid = false;
|
|
33
|
+
this._required = false;
|
|
34
|
+
this._value = '';
|
|
35
|
+
if (_ngControl)
|
|
36
|
+
this._ngControl.valueAccessor = this;
|
|
37
|
+
if (_formGroupDirective) {
|
|
38
|
+
this._subscription = _formGroupDirective.ngSubmit.subscribe(() => {
|
|
39
|
+
this._isSubmitted = true;
|
|
40
|
+
_cd.markForCheck();
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
ngOnInit() {
|
|
45
|
+
const form = this.control;
|
|
46
|
+
if (form?._rawValidators) {
|
|
47
|
+
form._rawValidators.forEach((r) => {
|
|
48
|
+
if (r.name.includes('required'))
|
|
49
|
+
this._required = true;
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
this.control.addValidators(Validators.pattern(/^[0-9.,-]+$/));
|
|
53
|
+
if (['', null, undefined, '-'].indexOf(this.control.value) < 0)
|
|
54
|
+
this._addCurrencyMask();
|
|
55
|
+
if (this.disabled)
|
|
56
|
+
this.control.disable();
|
|
57
|
+
}
|
|
58
|
+
writeValue(value) {
|
|
59
|
+
if (value === null) {
|
|
60
|
+
this._isInvalid = false;
|
|
61
|
+
}
|
|
62
|
+
this._value = value;
|
|
63
|
+
this._isSubmitted = false;
|
|
64
|
+
this._cd.markForCheck();
|
|
65
|
+
}
|
|
66
|
+
registerOnChange(fn) {
|
|
67
|
+
this.onChangeFn = fn;
|
|
68
|
+
}
|
|
69
|
+
registerOnTouched(fn) {
|
|
70
|
+
this.onTouchFn = fn;
|
|
71
|
+
}
|
|
72
|
+
onChange(event) {
|
|
73
|
+
this._value = event.target.value;
|
|
74
|
+
this.onChangeFn(event.target.value);
|
|
75
|
+
this._addCurrencyMask();
|
|
76
|
+
if (this.control.touched)
|
|
77
|
+
this._onValidate();
|
|
78
|
+
}
|
|
79
|
+
_addCurrencyMask() {
|
|
80
|
+
const valueFormatted = this.control.value
|
|
81
|
+
.toString()
|
|
82
|
+
.replace(/,/g, '')
|
|
83
|
+
.replace(/ /g, '')
|
|
84
|
+
.replace('$', '');
|
|
85
|
+
if (['', null, undefined, '-'].indexOf(valueFormatted) < 0 && !isNaN(Number(valueFormatted))) {
|
|
86
|
+
const value = '$ ' + Intl.NumberFormat('en-US').format(Number(valueFormatted));
|
|
87
|
+
this.control.setValue(+valueFormatted);
|
|
88
|
+
this._value = value;
|
|
89
|
+
}
|
|
90
|
+
else if (['-'].indexOf(valueFormatted) >= 0)
|
|
91
|
+
this.control.setValue('-');
|
|
92
|
+
else
|
|
93
|
+
this.control.setValue(null);
|
|
94
|
+
}
|
|
95
|
+
onFocusOut() {
|
|
96
|
+
this.onTouchFn(true);
|
|
97
|
+
//this._executeIfIsMoneyField();
|
|
98
|
+
this._onValidate();
|
|
99
|
+
}
|
|
100
|
+
_onValidate() {
|
|
101
|
+
if (this.control.invalid)
|
|
102
|
+
this._isInvalid = true;
|
|
103
|
+
else
|
|
104
|
+
this._isInvalid = false;
|
|
105
|
+
}
|
|
106
|
+
onKeyDown(event) {
|
|
107
|
+
const pattern = /[0-9.-]/i.test(event.key);
|
|
108
|
+
const validKeyCodes = [8, 46, 37, 39, 9, 17, 16, 67, 86, 109, 189];
|
|
109
|
+
return pattern || validKeyCodes.indexOf(event.keyCode) >= 0;
|
|
110
|
+
}
|
|
111
|
+
onClearControl() {
|
|
112
|
+
if (['', null, undefined].indexOf(this.control.value) >= 0) {
|
|
113
|
+
this.control.setValue('', { emitEvent: false });
|
|
114
|
+
}
|
|
115
|
+
else {
|
|
116
|
+
this.control.setValue('');
|
|
117
|
+
}
|
|
118
|
+
this._value = '';
|
|
119
|
+
}
|
|
120
|
+
ngOnDestroy() {
|
|
121
|
+
if (this._subscription)
|
|
122
|
+
this._subscription.unsubscribe();
|
|
123
|
+
}
|
|
124
|
+
get control() {
|
|
125
|
+
return this._ngControl.control;
|
|
126
|
+
}
|
|
127
|
+
get directive() {
|
|
128
|
+
return this._formGroupDirective;
|
|
129
|
+
}
|
|
130
|
+
get isDisabled() {
|
|
131
|
+
return this._ngControl.disabled;
|
|
132
|
+
}
|
|
133
|
+
get isSubmitted() {
|
|
134
|
+
return this._isSubmitted;
|
|
135
|
+
}
|
|
136
|
+
get isInvalid() {
|
|
137
|
+
return this._isInvalid;
|
|
138
|
+
}
|
|
139
|
+
get required() {
|
|
140
|
+
return this._required;
|
|
141
|
+
}
|
|
142
|
+
get value() {
|
|
143
|
+
return this._value;
|
|
144
|
+
}
|
|
145
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: TakMoneyFieldComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: i1.FormGroupDirective, optional: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
146
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.3", type: TakMoneyFieldComponent, selector: "tak-money-field", inputs: { autocomplete: "autocomplete", appearance: "appearance", floatLabel: "floatLabel", color: "color", actionIcon: "actionIcon", defaultFilterStyle: "defaultFilterStyle", hasActionButton: "hasActionButton", hasClearButton: "hasClearButton", countCaracters: "countCaracters", placeholder: "placeholder", maxLength: "maxLength", minLength: "minLength", disabled: "disabled" }, outputs: { onExecuteAction: "onExecuteAction", onKeyUp: "onKeyUp" }, ngImport: i0, template: "<div class=\"tak-form-container\">\r\n <mat-form-field\r\n [floatLabel]=\"floatLabel\"\r\n [class.mat-form-field-invalid]=\"isInvalid || (isSubmitted && control.invalid)\"\r\n [appearance]=\"appearance\"\r\n [color]=\"color\"\r\n >\r\n <mat-label>\r\n <ng-content></ng-content>{{ ' ' }}\r\n @if (required) {\r\n <span class=\"tak-field__danger-x\">*</span>\r\n }\r\n </mat-label>\r\n <input\r\n class=\"money-input\"\r\n matInput\r\n [autocomplete]=\"autocomplete\"\r\n [placeholder]=\"placeholder\"\r\n [value]=\"value\"\r\n (keyup)=\"onChange($event)\"\r\n (change)=\"onChange($event)\"\r\n (keydown)=\"onKeyDown($event)\"\r\n [disabled]=\"isDisabled\"\r\n [attr.minLength]=\"minLength\"\r\n [attr.maxLength]=\"maxLength\"\r\n (focusout)=\"onFocusOut()\"\r\n />\r\n @if (control.value && hasClearButton && !isDisabled) {\r\n <button matSuffix mat-icon-button type=\"button\" (click)=\"onClearControl()\">\r\n <mat-icon class=\"tak-suffix-icon-button\">close</mat-icon>\r\n </button>\r\n }\r\n @if (control.value && hasActionButton && !isDisabled) {\r\n <button matSuffix mat-icon-button type=\"button\" (click)=\"onExecuteAction.emit(control.value)\">\r\n <mat-icon class=\"tak-suffix-icon-button\">{{ actionIcon }}</mat-icon>\r\n </button>\r\n }\r\n @if (countCaracters) {\r\n <mat-hint align=\"end\" class=\"tak-hint\">\r\n {{ control.value?.length || 0 }}/{{ maxLength }}\r\n </mat-hint>\r\n }\r\n </mat-form-field>\r\n <div [style.maxWidth]=\"countCaracters ? '80%' : '100%'\">\r\n @if (isInvalid || (isSubmitted && control.invalid)) {\r\n <tak-error [control]=\"control\"></tak-error>\r\n }\r\n </div>\r\n</div>\r\n", dependencies: [{ kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2.MatSuffix, selector: "[matSuffix]" }, { kind: "component", type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4.TakErrorComponent, selector: "tak-error", inputs: ["control", "start", "end", "isDateField", "isNumberField", "marginTop"] }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }] }); }
|
|
147
|
+
}
|
|
148
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: TakMoneyFieldComponent, decorators: [{
|
|
149
|
+
type: Component,
|
|
150
|
+
args: [{ selector: 'tak-money-field', template: "<div class=\"tak-form-container\">\r\n <mat-form-field\r\n [floatLabel]=\"floatLabel\"\r\n [class.mat-form-field-invalid]=\"isInvalid || (isSubmitted && control.invalid)\"\r\n [appearance]=\"appearance\"\r\n [color]=\"color\"\r\n >\r\n <mat-label>\r\n <ng-content></ng-content>{{ ' ' }}\r\n @if (required) {\r\n <span class=\"tak-field__danger-x\">*</span>\r\n }\r\n </mat-label>\r\n <input\r\n class=\"money-input\"\r\n matInput\r\n [autocomplete]=\"autocomplete\"\r\n [placeholder]=\"placeholder\"\r\n [value]=\"value\"\r\n (keyup)=\"onChange($event)\"\r\n (change)=\"onChange($event)\"\r\n (keydown)=\"onKeyDown($event)\"\r\n [disabled]=\"isDisabled\"\r\n [attr.minLength]=\"minLength\"\r\n [attr.maxLength]=\"maxLength\"\r\n (focusout)=\"onFocusOut()\"\r\n />\r\n @if (control.value && hasClearButton && !isDisabled) {\r\n <button matSuffix mat-icon-button type=\"button\" (click)=\"onClearControl()\">\r\n <mat-icon class=\"tak-suffix-icon-button\">close</mat-icon>\r\n </button>\r\n }\r\n @if (control.value && hasActionButton && !isDisabled) {\r\n <button matSuffix mat-icon-button type=\"button\" (click)=\"onExecuteAction.emit(control.value)\">\r\n <mat-icon class=\"tak-suffix-icon-button\">{{ actionIcon }}</mat-icon>\r\n </button>\r\n }\r\n @if (countCaracters) {\r\n <mat-hint align=\"end\" class=\"tak-hint\">\r\n {{ control.value?.length || 0 }}/{{ maxLength }}\r\n </mat-hint>\r\n }\r\n </mat-form-field>\r\n <div [style.maxWidth]=\"countCaracters ? '80%' : '100%'\">\r\n @if (isInvalid || (isSubmitted && control.invalid)) {\r\n <tak-error [control]=\"control\"></tak-error>\r\n }\r\n </div>\r\n</div>\r\n" }]
|
|
151
|
+
}], ctorParameters: () => [{ type: i1.NgControl, decorators: [{
|
|
152
|
+
type: Self
|
|
153
|
+
}, {
|
|
154
|
+
type: Optional
|
|
155
|
+
}] }, { type: i1.FormGroupDirective, decorators: [{
|
|
156
|
+
type: Optional
|
|
157
|
+
}] }, { type: i0.ChangeDetectorRef }], propDecorators: { autocomplete: [{
|
|
158
|
+
type: Input
|
|
159
|
+
}], appearance: [{
|
|
160
|
+
type: Input
|
|
161
|
+
}], floatLabel: [{
|
|
162
|
+
type: Input
|
|
163
|
+
}], color: [{
|
|
164
|
+
type: Input
|
|
165
|
+
}], actionIcon: [{
|
|
166
|
+
type: Input
|
|
167
|
+
}], defaultFilterStyle: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], hasActionButton: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], hasClearButton: [{
|
|
172
|
+
type: Input
|
|
173
|
+
}], countCaracters: [{
|
|
174
|
+
type: Input
|
|
175
|
+
}], placeholder: [{
|
|
176
|
+
type: Input
|
|
177
|
+
}], maxLength: [{
|
|
178
|
+
type: Input
|
|
179
|
+
}], minLength: [{
|
|
180
|
+
type: Input
|
|
181
|
+
}], disabled: [{
|
|
182
|
+
type: Input
|
|
183
|
+
}], onExecuteAction: [{
|
|
184
|
+
type: Output
|
|
185
|
+
}], onKeyUp: [{
|
|
186
|
+
type: Output
|
|
187
|
+
}] } });
|
|
188
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"money-field.component.js","sourceRoot":"","sources":["../../../../../libraries/components/fields/money-field/money-field.component.ts","../../../../../libraries/components/fields/money-field/money-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  OnDestroy,\r\n  Optional,\r\n  OnInit,\r\n  Input,\r\n  Self,\r\n  Output,\r\n  EventEmitter,\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  FormGroupDirective,\r\n  FormControl,\r\n  NgControl,\r\n  Validators,\r\n} from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { TAK_DEFAULT_APPEARANCE_FORM } from '../fields.common';\r\nimport { FloatLabelType, MatFormFieldAppearance } from '@kato-lee/material/form-field';\r\nimport { ThemePalette } from '@kato-lee/material/core';\r\n\r\n@Component({\r\n  selector: 'tak-money-field',\r\n  templateUrl: './money-field.component.html',\r\n})\r\nexport class TakMoneyFieldComponent implements OnInit, OnDestroy, ControlValueAccessor {\r\n  @Input() autocomplete: 'off' | 'on' = 'off';\r\n\r\n  @Input() appearance: MatFormFieldAppearance = TAK_DEFAULT_APPEARANCE_FORM;\r\n  @Input() floatLabel: FloatLabelType = 'auto';\r\n  @Input() color: ThemePalette = 'primary';\r\n  @Input() actionIcon = 'search';\r\n\r\n  @Input() defaultFilterStyle = true;\r\n  @Input() hasActionButton = false;\r\n  @Input() hasClearButton = true;\r\n  @Input() countCaracters = false;\r\n  @Input() placeholder = '';\r\n\r\n  @Input() maxLength!: number;\r\n  @Input() minLength!: number;\r\n\r\n  @Input() disabled = false;\r\n\r\n  @Output() onExecuteAction = new EventEmitter();\r\n  @Output() onKeyUp = new EventEmitter();\r\n\r\n  public onChangeFn = (_: any) => {};\r\n  public onTouchFn = (_: any) => {};\r\n\r\n  private _isSubmitted = false;\r\n  private _isInvalid = false;\r\n  private _required = false;\r\n  private _value = '';\r\n\r\n  private _subscription!: Subscription;\r\n\r\n  constructor(\r\n    @Self() @Optional() private _ngControl: NgControl,\r\n    @Optional() private _formGroupDirective: FormGroupDirective,\r\n    private _cd: ChangeDetectorRef\r\n  ) {\r\n    if (_ngControl) this._ngControl.valueAccessor = this;\r\n\r\n    if (_formGroupDirective) {\r\n      this._subscription = _formGroupDirective.ngSubmit.subscribe(() => {\r\n        this._isSubmitted = true;\r\n        _cd.markForCheck();\r\n      });\r\n    }\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    const form: any = this.control;\r\n\r\n    if (form?._rawValidators) {\r\n      form._rawValidators.forEach((r: any) => {\r\n        if (r.name.includes('required')) this._required = true;\r\n      });\r\n    }\r\n\r\n    this.control.addValidators(Validators.pattern(/^[0-9.,-]+$/));\r\n\r\n    if (['', null, undefined, '-'].indexOf(this.control.value) < 0) this._addCurrencyMask();\r\n\r\n    if (this.disabled) this.control.disable();\r\n  }\r\n\r\n  public writeValue(value: string): void {\r\n    if (value === null) {\r\n      this._isInvalid = false;\r\n    }\r\n    this._value = value;\r\n    this._isSubmitted = false;\r\n    this._cd.markForCheck();\r\n  }\r\n\r\n  public registerOnChange(fn: any): void {\r\n    this.onChangeFn = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: any): void {\r\n    this.onTouchFn = fn;\r\n  }\r\n\r\n  public onChange(event: any): void {\r\n    this._value = event.target.value;\r\n    this.onChangeFn(event.target.value);\r\n    this._addCurrencyMask();\r\n    if (this.control.touched) this._onValidate();\r\n  }\r\n\r\n  private _addCurrencyMask() {\r\n    const valueFormatted = this.control.value\r\n      .toString()\r\n      .replace(/,/g, '')\r\n      .replace(/ /g, '')\r\n      .replace('$', '');\r\n\r\n    if (['', null, undefined, '-'].indexOf(valueFormatted) < 0 && !isNaN(Number(valueFormatted))) {\r\n      const value = '$ ' + Intl.NumberFormat('en-US').format(Number(valueFormatted));\r\n      this.control.setValue(+valueFormatted);\r\n      this._value = value;\r\n    } else if (['-'].indexOf(valueFormatted) >= 0) this.control.setValue('-');\r\n    else this.control.setValue(null);\r\n  }\r\n\r\n  public onFocusOut(): void {\r\n    this.onTouchFn(true);\r\n    //this._executeIfIsMoneyField();\r\n    this._onValidate();\r\n  }\r\n\r\n  private _onValidate(): void {\r\n    if (this.control.invalid) this._isInvalid = true;\r\n    else this._isInvalid = false;\r\n  }\r\n\r\n  public onKeyDown(event: any) {\r\n    const pattern = /[0-9.-]/i.test(event.key);\r\n    const validKeyCodes = [8, 46, 37, 39, 9, 17, 16, 67, 86, 109, 189];\r\n    return pattern || validKeyCodes.indexOf(event.keyCode) >= 0;\r\n  }\r\n\r\n  public onClearControl(): void {\r\n    if (['', null, undefined].indexOf(this.control.value) >= 0) {\r\n      this.control.setValue('', { emitEvent: false });\r\n    } else {\r\n      this.control.setValue('');\r\n    }\r\n\r\n    this._value = '';\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    if (this._subscription) this._subscription.unsubscribe();\r\n  }\r\n\r\n  get control(): FormControl {\r\n    return this._ngControl.control as FormControl;\r\n  }\r\n\r\n  get directive(): FormGroupDirective {\r\n    return this._formGroupDirective as FormGroupDirective;\r\n  }\r\n\r\n  get isDisabled() {\r\n    return this._ngControl.disabled;\r\n  }\r\n\r\n  get isSubmitted() {\r\n    return this._isSubmitted;\r\n  }\r\n\r\n  get isInvalid() {\r\n    return this._isInvalid;\r\n  }\r\n\r\n  get required() {\r\n    return this._required;\r\n  }\r\n\r\n  get value() {\r\n    return this._value;\r\n  }\r\n}\r\n","<div class=\"tak-form-container\">\r\n  <mat-form-field\r\n    [floatLabel]=\"floatLabel\"\r\n    [class.mat-form-field-invalid]=\"isInvalid || (isSubmitted && control.invalid)\"\r\n    [appearance]=\"appearance\"\r\n    [color]=\"color\"\r\n  >\r\n    <mat-label>\r\n      <ng-content></ng-content>{{ ' ' }}\r\n      @if (required) {\r\n        <span class=\"tak-field__danger-x\">*</span>\r\n      }\r\n    </mat-label>\r\n    <input\r\n      class=\"money-input\"\r\n      matInput\r\n      [autocomplete]=\"autocomplete\"\r\n      [placeholder]=\"placeholder\"\r\n      [value]=\"value\"\r\n      (keyup)=\"onChange($event)\"\r\n      (change)=\"onChange($event)\"\r\n      (keydown)=\"onKeyDown($event)\"\r\n      [disabled]=\"isDisabled\"\r\n      [attr.minLength]=\"minLength\"\r\n      [attr.maxLength]=\"maxLength\"\r\n      (focusout)=\"onFocusOut()\"\r\n    />\r\n    @if (control.value && hasClearButton && !isDisabled) {\r\n      <button matSuffix mat-icon-button type=\"button\" (click)=\"onClearControl()\">\r\n        <mat-icon class=\"tak-suffix-icon-button\">close</mat-icon>\r\n      </button>\r\n    }\r\n    @if (control.value && hasActionButton && !isDisabled) {\r\n      <button matSuffix mat-icon-button type=\"button\" (click)=\"onExecuteAction.emit(control.value)\">\r\n        <mat-icon class=\"tak-suffix-icon-button\">{{ actionIcon }}</mat-icon>\r\n      </button>\r\n    }\r\n    @if (countCaracters) {\r\n      <mat-hint align=\"end\" class=\"tak-hint\">\r\n        {{ control.value?.length || 0 }}/{{ maxLength }}\r\n      </mat-hint>\r\n    }\r\n  </mat-form-field>\r\n  <div [style.maxWidth]=\"countCaracters ? '80%' : '100%'\">\r\n    @if (isInvalid || (isSubmitted && control.invalid)) {\r\n      <tak-error [control]=\"control\"></tak-error>\r\n    }\r\n  </div>\r\n</div>\r\n"]}
|