@kato-lee/components 1.0.7 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/_grids.scss +5 -5
- package/assets/fonts/fonts.scss +11 -0
- package/assets/material/themes/dark.scss +2 -1
- package/assets/themes/_dark.scss +2 -1
- package/assets/themes/_default.scss +0 -1
- package/box-form/{box-form.component.d.ts → component.d.ts} +2 -2
- package/box-form/index.d.ts +2 -2
- package/box-form/module.d.ts +8 -0
- package/capsule/{capsule.component.d.ts → component.d.ts} +1 -1
- package/capsule/index.d.ts +2 -2
- package/capsule/{capsule.module.d.ts → module.d.ts} +3 -2
- package/cards/{simple-card.component.d.ts → component.d.ts} +1 -1
- package/cards/index.d.ts +2 -2
- package/cards/{cards.module.d.ts → module.d.ts} +3 -2
- package/dialogs/dismiss-dialog-button.component.d.ts +1 -1
- package/dialogs/index.d.ts +1 -1
- package/dialogs/module.d.ts +9 -0
- package/esm2022/box-form/component.mjs +112 -0
- package/esm2022/box-form/index.mjs +3 -3
- package/esm2022/box-form/module.mjs +17 -0
- package/esm2022/capsule/component.mjs +78 -0
- package/esm2022/capsule/index.mjs +3 -3
- package/esm2022/capsule/module.mjs +17 -0
- package/esm2022/cards/component.mjs +48 -0
- package/esm2022/cards/index.mjs +3 -3
- package/esm2022/cards/module.mjs +18 -0
- package/esm2022/dialogs/dismiss-dialog-button.component.mjs +14 -12
- package/esm2022/dialogs/index.mjs +2 -2
- package/esm2022/dialogs/module.mjs +19 -0
- package/esm2022/fields/autocomplete/component.mjs +259 -0
- package/esm2022/fields/autocomplete/index.mjs +2 -0
- package/esm2022/fields/common.mjs +11 -0
- package/esm2022/fields/date/component.mjs +163 -0
- package/esm2022/fields/date/index.mjs +2 -0
- package/esm2022/fields/date-range/component.mjs +85 -0
- package/esm2022/fields/date-range/index.mjs +2 -0
- package/esm2022/fields/error/component.mjs +57 -0
- package/esm2022/fields/error/error-equals.pipe.mjs +3 -3
- package/esm2022/fields/error/error.msg.pipe.mjs +3 -3
- package/esm2022/fields/general/component.mjs +202 -0
- package/esm2022/fields/general/index.mjs +2 -0
- package/esm2022/fields/index.mjs +14 -14
- package/esm2022/fields/module.mjs +82 -0
- package/esm2022/fields/money/component.mjs +202 -0
- package/esm2022/fields/money/index.mjs +2 -0
- package/esm2022/fields/number/component.mjs +179 -0
- package/esm2022/fields/number/index.mjs +2 -0
- package/esm2022/fields/remote-autocomplete/component.mjs +188 -0
- package/esm2022/fields/remote-autocomplete/index.mjs +2 -0
- package/esm2022/fields/select/component.mjs +158 -0
- package/esm2022/fields/select/index.mjs +2 -0
- package/esm2022/fields/text-area/component.mjs +186 -0
- package/esm2022/fields/validators.mjs +11 -0
- package/esm2022/modal/component.mjs +66 -0
- package/esm2022/modal/index.mjs +4 -4
- package/esm2022/modal/module.mjs +17 -0
- package/esm2022/modal/service.mjs +33 -0
- package/esm2022/pretty-box/component.mjs +94 -0
- package/esm2022/pretty-box/index.mjs +2 -2
- package/esm2022/tables/index.mjs +2 -2
- package/esm2022/tables/module.mjs +23 -0
- package/esm2022/toast/index.mjs +2 -2
- package/esm2022/toast/service.mjs +42 -0
- package/fesm2022/kato-lee-components-box-form.mjs +19 -29
- package/fesm2022/kato-lee-components-box-form.mjs.map +1 -1
- package/fesm2022/kato-lee-components-capsule.mjs +5 -4
- package/fesm2022/kato-lee-components-capsule.mjs.map +1 -1
- package/fesm2022/kato-lee-components-cards.mjs +7 -5
- package/fesm2022/kato-lee-components-cards.mjs.map +1 -1
- package/fesm2022/kato-lee-components-dialogs.mjs +16 -18
- package/fesm2022/kato-lee-components-dialogs.mjs.map +1 -1
- package/fesm2022/kato-lee-components-fields.mjs +135 -106
- package/fesm2022/kato-lee-components-fields.mjs.map +1 -1
- package/fesm2022/kato-lee-components-modal.mjs +9 -10
- package/fesm2022/kato-lee-components-modal.mjs.map +1 -1
- package/fesm2022/kato-lee-components-pretty-box.mjs +6 -6
- package/fesm2022/kato-lee-components-pretty-box.mjs.map +1 -1
- package/fesm2022/kato-lee-components-tables.mjs +1 -0
- package/fesm2022/kato-lee-components-tables.mjs.map +1 -1
- package/fesm2022/kato-lee-components-toast.mjs.map +1 -1
- package/fields/{autocomplete-field/autocomplete-field.component.d.ts → autocomplete/component.d.ts} +2 -2
- package/fields/autocomplete/index.d.ts +1 -0
- package/fields/{date-field/date-field.component.d.ts → date/component.d.ts} +2 -2
- package/fields/date/index.d.ts +1 -0
- package/fields/{date-range-field/date-range-field.component.d.ts → date-range/component.d.ts} +2 -2
- package/fields/date-range/index.d.ts +1 -0
- package/fields/error/{error.component.d.ts → component.d.ts} +1 -1
- package/fields/error/error-equals.pipe.d.ts +1 -1
- package/fields/error/error.msg.pipe.d.ts +1 -1
- package/fields/{general-field/general-field.component.d.ts → general/component.d.ts} +2 -2
- package/fields/general/index.d.ts +1 -0
- package/fields/index.d.ts +13 -13
- package/fields/module.d.ts +19 -0
- package/fields/{money-field/money-field.component.d.ts → money/component.d.ts} +1 -1
- package/fields/money/index.d.ts +1 -0
- package/fields/{number-field/number-field.component.d.ts → number/component.d.ts} +1 -1
- package/fields/number/index.d.ts +1 -0
- package/fields/remote-autocomplete/index.d.ts +1 -0
- package/fields/{select-field/select-field.component.d.ts → select/component.d.ts} +2 -2
- package/fields/select/index.d.ts +1 -0
- package/fields/text-area/{textarea.component.d.ts → component.d.ts} +1 -1
- package/modal/{modal.component.d.ts → component.d.ts} +1 -1
- package/modal/index.d.ts +3 -3
- package/modal/module.d.ts +8 -0
- package/package.json +1 -7
- package/pretty-box/component.d.ts +24 -0
- package/pretty-box/index.d.ts +1 -1
- package/tables/index.d.ts +1 -1
- package/tables/{tables.module.d.ts → module.d.ts} +1 -0
- package/toast/index.d.ts +1 -1
- 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 +0 -40
- package/assets/fonts/main.scss +0 -18
- 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 +0 -39
- package/assets/layouts/_loader.scss +0 -71
- package/assets/layouts/origin.scss +0 -775
- package/box-form/box-form.module.d.ts +0 -13
- package/dialogs/dialogs.module.d.ts +0 -11
- package/esm2022/box-form/box-form.component.mjs +0 -99
- package/esm2022/box-form/box-form.module.mjs +0 -40
- package/esm2022/capsule/capsule.component.mjs +0 -78
- package/esm2022/capsule/capsule.module.mjs +0 -16
- package/esm2022/cards/cards.module.mjs +0 -17
- package/esm2022/cards/simple-card.component.mjs +0 -47
- package/esm2022/dialogs/dialogs.module.mjs +0 -22
- package/esm2022/fields/autocomplete-field/autocomplete-field.component.mjs +0 -240
- package/esm2022/fields/date-field/date-field.component.mjs +0 -148
- package/esm2022/fields/date-range-field/date-range-field.component.mjs +0 -70
- package/esm2022/fields/error/error.component.mjs +0 -55
- package/esm2022/fields/error/error.module.mjs +0 -21
- package/esm2022/fields/fields.common.mjs +0 -11
- package/esm2022/fields/fields.module.mjs +0 -128
- package/esm2022/fields/fields.validators.mjs +0 -11
- package/esm2022/fields/general-field/general-field.component.mjs +0 -188
- package/esm2022/fields/money-field/money-field.component.mjs +0 -188
- package/esm2022/fields/number-field/number-field.component.mjs +0 -165
- package/esm2022/fields/remote-autocomplete-field/remote-autocomplete-field.component.mjs +0 -188
- package/esm2022/fields/select-field/select-field.component.mjs +0 -135
- package/esm2022/fields/text-area/textarea.component.mjs +0 -171
- package/esm2022/layouts/origin/breadcrumb/breadcrumb.component.mjs +0 -65
- package/esm2022/layouts/origin/footer/footer.component.mjs +0 -11
- package/esm2022/layouts/origin/header/header.component.mjs +0 -46
- package/esm2022/layouts/origin/index.mjs +0 -12
- package/esm2022/layouts/origin/kato-lee-components-layouts-origin.mjs +0 -5
- package/esm2022/layouts/origin/layout.component.mjs +0 -210
- package/esm2022/layouts/origin/layout.module.mjs +0 -52
- package/esm2022/layouts/origin/layout.navigation.mjs +0 -19
- package/esm2022/layouts/origin/navigation-interfaces.mjs +0 -2
- package/esm2022/layouts/origin/services/index.mjs +0 -4
- package/esm2022/layouts/origin/services/route-parts.service.mjs +0 -28
- package/esm2022/layouts/origin/services/toggle-sidebar.mjs +0 -48
- package/esm2022/layouts/origin/services/validate-access.pipe.mjs +0 -53
- package/esm2022/layouts/origin/sidebar/sidebar.component.mjs +0 -69
- package/esm2022/layouts/origin/sidebar/sidenav/expansion/accordion.component.mjs +0 -74
- package/esm2022/layouts/origin/sidebar/sidenav/expansion/expansion-panel-header.component.mjs +0 -51
- package/esm2022/layouts/origin/sidebar/sidenav/expansion/expansion-panel.component.mjs +0 -63
- package/esm2022/layouts/origin/sidebar/sidenav/sidenav.component.mjs +0 -130
- package/esm2022/modal/modal.component.mjs +0 -63
- package/esm2022/modal/modal.module.mjs +0 -21
- package/esm2022/modal/modal.service.mjs +0 -33
- package/esm2022/pretty-box/pretty-box.component.mjs +0 -94
- package/esm2022/tables/tables.module.mjs +0 -22
- package/esm2022/toast/toast.service.mjs +0 -42
- package/fesm2022/kato-lee-components-layouts-origin.mjs +0 -872
- package/fesm2022/kato-lee-components-layouts-origin.mjs.map +0 -1
- package/fields/error/error.module.d.ts +0 -11
- package/fields/fields.module.d.ts +0 -29
- package/layouts/origin/breadcrumb/breadcrumb.component.d.ts +0 -24
- package/layouts/origin/footer/footer.component.d.ts +0 -5
- package/layouts/origin/header/header.component.d.ts +0 -15
- package/layouts/origin/index.d.ts +0 -8
- package/layouts/origin/layout.component.d.ts +0 -58
- package/layouts/origin/layout.module.d.ts +0 -18
- package/layouts/origin/layout.navigation.d.ts +0 -10
- package/layouts/origin/navigation-interfaces.d.ts +0 -24
- package/layouts/origin/services/index.d.ts +0 -3
- package/layouts/origin/services/route-parts.service.d.ts +0 -15
- package/layouts/origin/services/toggle-sidebar.d.ts +0 -10
- package/layouts/origin/services/validate-access.pipe.d.ts +0 -7
- package/layouts/origin/sidebar/sidebar.component.d.ts +0 -27
- package/layouts/origin/sidebar/sidenav/expansion/accordion.component.d.ts +0 -10
- package/layouts/origin/sidebar/sidenav/expansion/expansion-panel-header.component.d.ts +0 -11
- package/layouts/origin/sidebar/sidenav/expansion/expansion-panel.component.d.ts +0 -12
- package/layouts/origin/sidebar/sidenav/sidenav.component.d.ts +0 -23
- package/modal/modal.module.d.ts +0 -11
- package/pretty-box/pretty-box.component.d.ts +0 -24
- /package/fields/{fields.common.d.ts → common.d.ts} +0 -0
- /package/fields/{remote-autocomplete-field/remote-autocomplete-field.component.d.ts → remote-autocomplete/component.d.ts} +0 -0
- /package/fields/{fields.validators.d.ts → validators.d.ts} +0 -0
- /package/modal/{modal.service.d.ts → service.d.ts} +0 -0
- /package/toast/{toast.service.d.ts → service.d.ts} +0 -0
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
import { Component, Optional, Input, Self, EventEmitter, Output, } from '@angular/core';
|
|
2
|
+
import { FormsModule, ReactiveFormsModule, } from '@angular/forms';
|
|
3
|
+
import { takeUntil } from 'rxjs/operators';
|
|
4
|
+
import { Subject } from 'rxjs';
|
|
5
|
+
import { TAK_DEFAULT_APPEARANCE_FORM } from '../common';
|
|
6
|
+
import { CommonModule } from '@angular/common';
|
|
7
|
+
import { MatFormFieldModule } from '@kato-lee/material/form-field';
|
|
8
|
+
import { MatTooltipModule } from '@kato-lee/material/tooltip';
|
|
9
|
+
import { TakErrorComponent } from '../error/component';
|
|
10
|
+
import { MatSelectModule } from '@kato-lee/material/select';
|
|
11
|
+
import { MatButtonModule } from '@kato-lee/material/button';
|
|
12
|
+
import { MatOptionModule } from '@kato-lee/material/core';
|
|
13
|
+
import { MatInputModule } from '@kato-lee/material/input';
|
|
14
|
+
import { MatIconModule } from '@kato-lee/material/icon';
|
|
15
|
+
import { MatMenuModule } from '@kato-lee/material/menu';
|
|
16
|
+
import * as i0 from "@angular/core";
|
|
17
|
+
import * as i1 from "@angular/forms";
|
|
18
|
+
import * as i2 from "@kato-lee/material/tooltip";
|
|
19
|
+
import * as i3 from "@kato-lee/material/menu";
|
|
20
|
+
import * as i4 from "@kato-lee/material/form-field";
|
|
21
|
+
import * as i5 from "@kato-lee/material/select";
|
|
22
|
+
import * as i6 from "@kato-lee/material/core";
|
|
23
|
+
import * as i7 from "@kato-lee/material/button";
|
|
24
|
+
import * as i8 from "@kato-lee/material/icon";
|
|
25
|
+
export class TakSelectFieldComponent {
|
|
26
|
+
constructor(_ngControl, _formGroupDirective, _cd) {
|
|
27
|
+
this._ngControl = _ngControl;
|
|
28
|
+
this._formGroupDirective = _formGroupDirective;
|
|
29
|
+
this._cd = _cd;
|
|
30
|
+
this.autocomplete = 'off';
|
|
31
|
+
this.appearance = TAK_DEFAULT_APPEARANCE_FORM;
|
|
32
|
+
this.color = 'primary';
|
|
33
|
+
this.suggestions = [];
|
|
34
|
+
this.disabled = false;
|
|
35
|
+
this.type = 'select';
|
|
36
|
+
this.tooltip = '';
|
|
37
|
+
this.icon = 'filter_list';
|
|
38
|
+
this.option = 'option';
|
|
39
|
+
this.extraInfo = '';
|
|
40
|
+
this.hasDefaultValue = false;
|
|
41
|
+
this.onSelect = new EventEmitter();
|
|
42
|
+
this.onChangeFn = (_) => { };
|
|
43
|
+
this.onTouchFn = (_) => { };
|
|
44
|
+
this.isInvalid = false;
|
|
45
|
+
this.isSubmitted = false;
|
|
46
|
+
this._unsubscribe$ = new Subject();
|
|
47
|
+
if (_ngControl)
|
|
48
|
+
this._ngControl.valueAccessor = this;
|
|
49
|
+
if (_formGroupDirective) {
|
|
50
|
+
_formGroupDirective.ngSubmit.pipe(takeUntil(this._unsubscribe$)).subscribe(() => {
|
|
51
|
+
this.isSubmitted = true;
|
|
52
|
+
_cd.markForCheck();
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
ngOnInit() {
|
|
57
|
+
if (this.suggestions.length && this.hasDefaultValue) {
|
|
58
|
+
this._ngControl.control?.setValue(this.suggestions[0]);
|
|
59
|
+
}
|
|
60
|
+
if (this.disabled)
|
|
61
|
+
this.control.disable();
|
|
62
|
+
}
|
|
63
|
+
writeValue(value) { }
|
|
64
|
+
registerOnChange(fn) {
|
|
65
|
+
this.onChangeFn = fn;
|
|
66
|
+
}
|
|
67
|
+
registerOnTouched(fn) {
|
|
68
|
+
this.onTouchFn = fn;
|
|
69
|
+
}
|
|
70
|
+
onChange(event) {
|
|
71
|
+
this.onChangeFn(event.target.value);
|
|
72
|
+
if (this.control.touched)
|
|
73
|
+
this._onValidate();
|
|
74
|
+
}
|
|
75
|
+
emit(el) {
|
|
76
|
+
if (el.isUserInput) {
|
|
77
|
+
this.onSelect.emit(el.source.value);
|
|
78
|
+
this.isInvalid = false;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
justEmit(el) {
|
|
82
|
+
this.control.setValue(el);
|
|
83
|
+
this.onSelect.emit(el);
|
|
84
|
+
this.isInvalid = false;
|
|
85
|
+
}
|
|
86
|
+
onFocusOut() {
|
|
87
|
+
this._onValidate();
|
|
88
|
+
}
|
|
89
|
+
_onValidate() {
|
|
90
|
+
if (this.control.invalid)
|
|
91
|
+
this.isInvalid = true;
|
|
92
|
+
else
|
|
93
|
+
this.isInvalid = false;
|
|
94
|
+
}
|
|
95
|
+
ngOnDestroy() {
|
|
96
|
+
this._unsubscribe$.next();
|
|
97
|
+
this._unsubscribe$.complete();
|
|
98
|
+
}
|
|
99
|
+
get control() {
|
|
100
|
+
return this._ngControl?.control;
|
|
101
|
+
}
|
|
102
|
+
get directive() {
|
|
103
|
+
return this._formGroupDirective;
|
|
104
|
+
}
|
|
105
|
+
get isDisabled() {
|
|
106
|
+
return this._ngControl.disabled;
|
|
107
|
+
}
|
|
108
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: TakSelectFieldComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: i1.FormGroupDirective, optional: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
109
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.3", type: TakSelectFieldComponent, isStandalone: true, selector: "tak-select-field", inputs: { autocomplete: "autocomplete", appearance: "appearance", color: "color", suggestions: "suggestions", disabled: "disabled", type: "type", tooltip: "tooltip", icon: "icon", option: "option", extraInfo: "extraInfo", hasDefaultValue: "hasDefaultValue" }, outputs: { onSelect: "onSelect" }, ngImport: i0, template: "@if (type === 'select') {\r\n <div class=\"tak-form-container\">\r\n <mat-form-field [appearance]=\"appearance\" [color]=\"color\">\r\n <mat-label><ng-content /></mat-label>\r\n <mat-select [formControl]=\"control\" (focusout)=\"onFocusOut()\">\r\n @for (suggestion of suggestions; track suggestion) {\r\n <mat-option\r\n [value]=\"suggestion\"\r\n (onSelectionChange)=\"emit($event)\"\r\n title=\"{{ suggestion[option] }} {{\r\n extraInfo ? '(' + suggestion[extraInfo] + ')' : ''\r\n }}\"\r\n >\r\n {{ suggestion[option] }}\r\n @if (extraInfo) {\r\n <span class=\"tak-option-span-extra\">{{ suggestion[extraInfo] }}</span>\r\n }\r\n </mat-option>\r\n }\r\n </mat-select>\r\n </mat-form-field>\r\n @if (isInvalid || (isSubmitted && control.invalid)) {\r\n <tak-error [control]=\"control\"></tak-error>\r\n }\r\n </div>\r\n} @else {\r\n <div [matTooltip]=\"tooltip\">\r\n @if (type === 'menu') {\r\n <span>\r\n <button mat-icon-button type=\"button\" [matMenuTriggerFor]=\"menu\" [disabled]=\"isDisabled\">\r\n <mat-icon>{{ icon }}</mat-icon>\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n @for (item of suggestions; track item) {\r\n <a tak-menu-item (click)=\"justEmit(item)\">\r\n {{ item[option] }}\r\n </a>\r\n }\r\n </mat-menu>\r\n </span>\r\n }\r\n </div>\r\n}\r\n", dependencies: [{ kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i3.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "directive", type: i3.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "component", type: i5.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i6.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "ngmodule", type: MatOptionModule }, { kind: "component", type: TakErrorComponent, selector: "tak-error", inputs: ["control", "start", "end", "isDateField", "isNumberField", "marginTop"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i7.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: "ngmodule", type: MatIconModule }, { kind: "component", type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatInputModule }] }); }
|
|
110
|
+
}
|
|
111
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: TakSelectFieldComponent, decorators: [{
|
|
112
|
+
type: Component,
|
|
113
|
+
args: [{ standalone: true, imports: [
|
|
114
|
+
MatTooltipModule,
|
|
115
|
+
MatMenuModule,
|
|
116
|
+
MatSelectModule,
|
|
117
|
+
MatOptionModule,
|
|
118
|
+
TakErrorComponent,
|
|
119
|
+
FormsModule,
|
|
120
|
+
CommonModule,
|
|
121
|
+
ReactiveFormsModule,
|
|
122
|
+
MatFormFieldModule,
|
|
123
|
+
MatButtonModule,
|
|
124
|
+
MatIconModule,
|
|
125
|
+
MatInputModule,
|
|
126
|
+
], selector: 'tak-select-field', template: "@if (type === 'select') {\r\n <div class=\"tak-form-container\">\r\n <mat-form-field [appearance]=\"appearance\" [color]=\"color\">\r\n <mat-label><ng-content /></mat-label>\r\n <mat-select [formControl]=\"control\" (focusout)=\"onFocusOut()\">\r\n @for (suggestion of suggestions; track suggestion) {\r\n <mat-option\r\n [value]=\"suggestion\"\r\n (onSelectionChange)=\"emit($event)\"\r\n title=\"{{ suggestion[option] }} {{\r\n extraInfo ? '(' + suggestion[extraInfo] + ')' : ''\r\n }}\"\r\n >\r\n {{ suggestion[option] }}\r\n @if (extraInfo) {\r\n <span class=\"tak-option-span-extra\">{{ suggestion[extraInfo] }}</span>\r\n }\r\n </mat-option>\r\n }\r\n </mat-select>\r\n </mat-form-field>\r\n @if (isInvalid || (isSubmitted && control.invalid)) {\r\n <tak-error [control]=\"control\"></tak-error>\r\n }\r\n </div>\r\n} @else {\r\n <div [matTooltip]=\"tooltip\">\r\n @if (type === 'menu') {\r\n <span>\r\n <button mat-icon-button type=\"button\" [matMenuTriggerFor]=\"menu\" [disabled]=\"isDisabled\">\r\n <mat-icon>{{ icon }}</mat-icon>\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n @for (item of suggestions; track item) {\r\n <a tak-menu-item (click)=\"justEmit(item)\">\r\n {{ item[option] }}\r\n </a>\r\n }\r\n </mat-menu>\r\n </span>\r\n }\r\n </div>\r\n}\r\n" }]
|
|
127
|
+
}], ctorParameters: () => [{ type: i1.NgControl, decorators: [{
|
|
128
|
+
type: Self
|
|
129
|
+
}, {
|
|
130
|
+
type: Optional
|
|
131
|
+
}] }, { type: i1.FormGroupDirective, decorators: [{
|
|
132
|
+
type: Optional
|
|
133
|
+
}] }, { type: i0.ChangeDetectorRef }], propDecorators: { autocomplete: [{
|
|
134
|
+
type: Input
|
|
135
|
+
}], appearance: [{
|
|
136
|
+
type: Input
|
|
137
|
+
}], color: [{
|
|
138
|
+
type: Input
|
|
139
|
+
}], suggestions: [{
|
|
140
|
+
type: Input
|
|
141
|
+
}], disabled: [{
|
|
142
|
+
type: Input
|
|
143
|
+
}], type: [{
|
|
144
|
+
type: Input
|
|
145
|
+
}], tooltip: [{
|
|
146
|
+
type: Input
|
|
147
|
+
}], icon: [{
|
|
148
|
+
type: Input
|
|
149
|
+
}], option: [{
|
|
150
|
+
type: Input
|
|
151
|
+
}], extraInfo: [{
|
|
152
|
+
type: Input
|
|
153
|
+
}], hasDefaultValue: [{
|
|
154
|
+
type: Input
|
|
155
|
+
}], onSelect: [{
|
|
156
|
+
type: Output
|
|
157
|
+
}] } });
|
|
158
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../libraries/components/fields/select/component.ts","../../../../../libraries/components/fields/select/component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  OnDestroy,\r\n  Component,\r\n  Optional,\r\n  Input,\r\n  Self,\r\n  OnInit,\r\n  EventEmitter,\r\n  Output,\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  FormControl,\r\n  FormGroupDirective,\r\n  FormsModule,\r\n  NgControl,\r\n  ReactiveFormsModule,\r\n} from '@angular/forms';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { Subject } from 'rxjs';\r\nimport { MatFormFieldAppearance } from '@kato-lee/material/form-field';\r\nimport { MatOptionSelectionChange, ThemePalette } from '@kato-lee/material/core';\r\nimport { TakAutocompleteFieldType, TAK_DEFAULT_APPEARANCE_FORM } from '../common';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MatFormFieldModule } from '@kato-lee/material/form-field';\r\nimport { MatTooltipModule } from '@kato-lee/material/tooltip';\r\nimport { TakErrorComponent } from '../error/component';\r\nimport { MatSelectModule } from '@kato-lee/material/select';\r\nimport { MatButtonModule } from '@kato-lee/material/button';\r\nimport { MatOptionModule } from '@kato-lee/material/core';\r\nimport { MatInputModule } from '@kato-lee/material/input';\r\nimport { MatIconModule } from '@kato-lee/material/icon';\r\nimport { MatMenuModule } from '@kato-lee/material/menu';\r\n\r\n@Component({\r\n  standalone: true,\r\n  imports: [\r\n    MatTooltipModule,\r\n    MatMenuModule,\r\n    MatSelectModule,\r\n    MatOptionModule,\r\n    TakErrorComponent,\r\n    FormsModule,\r\n    CommonModule,\r\n    ReactiveFormsModule,\r\n    MatFormFieldModule,\r\n    MatButtonModule,\r\n    MatIconModule,\r\n    MatInputModule,\r\n  ],\r\n  selector: 'tak-select-field',\r\n  templateUrl: './component.html',\r\n})\r\nexport class TakSelectFieldComponent implements OnInit, OnDestroy, ControlValueAccessor {\r\n  @Input() autocomplete: TakAutocompleteFieldType = 'off';\r\n  @Input() appearance: MatFormFieldAppearance = TAK_DEFAULT_APPEARANCE_FORM;\r\n  @Input() color: ThemePalette = 'primary';\r\n  @Input() suggestions: any[] = [];\r\n  @Input() disabled = false;\r\n\r\n  @Input() type: 'menu' | 'select' = 'select';\r\n  @Input() tooltip = '';\r\n  @Input() icon = 'filter_list';\r\n\r\n  @Input() option = 'option';\r\n  @Input() extraInfo = '';\r\n\r\n  @Input() hasDefaultValue = false;\r\n\r\n  @Output() onSelect = new EventEmitter<any>();\r\n\r\n  public onChangeFn = (_: any) => {};\r\n  public onTouchFn = (_: any) => {};\r\n\r\n  public isInvalid = false;\r\n  public isSubmitted = false;\r\n  private _unsubscribe$ = new Subject<void>();\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    if (_formGroupDirective) {\r\n      _formGroupDirective.ngSubmit.pipe(takeUntil(this._unsubscribe$)).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    if (this.suggestions.length && this.hasDefaultValue) {\r\n      this._ngControl.control?.setValue(this.suggestions[0]);\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\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.onChangeFn(event.target.value);\r\n    if (this.control.touched) this._onValidate();\r\n  }\r\n\r\n  public emit(el: MatOptionSelectionChange) {\r\n    if (el.isUserInput) {\r\n      this.onSelect.emit(el.source.value);\r\n      this.isInvalid = false;\r\n    }\r\n  }\r\n\r\n  public justEmit(el: any) {\r\n    this.control.setValue(el);\r\n    this.onSelect.emit(el);\r\n    this.isInvalid = false;\r\n  }\r\n\r\n  public onFocusOut() {\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 ngOnDestroy(): void {\r\n    this._unsubscribe$.next();\r\n    this._unsubscribe$.complete();\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","@if (type === 'select') {\r\n  <div class=\"tak-form-container\">\r\n    <mat-form-field [appearance]=\"appearance\" [color]=\"color\">\r\n      <mat-label><ng-content /></mat-label>\r\n      <mat-select [formControl]=\"control\" (focusout)=\"onFocusOut()\">\r\n        @for (suggestion of suggestions; track suggestion) {\r\n          <mat-option\r\n            [value]=\"suggestion\"\r\n            (onSelectionChange)=\"emit($event)\"\r\n            title=\"{{ suggestion[option] }} {{\r\n              extraInfo ? '(' + suggestion[extraInfo] + ')' : ''\r\n            }}\"\r\n          >\r\n            {{ suggestion[option] }}\r\n            @if (extraInfo) {\r\n              <span class=\"tak-option-span-extra\">{{ suggestion[extraInfo] }}</span>\r\n            }\r\n          </mat-option>\r\n        }\r\n      </mat-select>\r\n    </mat-form-field>\r\n    @if (isInvalid || (isSubmitted && control.invalid)) {\r\n      <tak-error [control]=\"control\"></tak-error>\r\n    }\r\n  </div>\r\n} @else {\r\n  <div [matTooltip]=\"tooltip\">\r\n    @if (type === 'menu') {\r\n      <span>\r\n        <button mat-icon-button type=\"button\" [matMenuTriggerFor]=\"menu\" [disabled]=\"isDisabled\">\r\n          <mat-icon>{{ icon }}</mat-icon>\r\n        </button>\r\n        <mat-menu #menu=\"matMenu\">\r\n          @for (item of suggestions; track item) {\r\n            <a tak-menu-item (click)=\"justEmit(item)\">\r\n              {{ item[option] }}\r\n            </a>\r\n          }\r\n        </mat-menu>\r\n      </span>\r\n    }\r\n  </div>\r\n}\r\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './component';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJyYXJpZXMvY29tcG9uZW50cy9maWVsZHMvc2VsZWN0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnQnO1xyXG4iXX0=
|
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
import { Component, Optional, Input, Self, Output, EventEmitter, } from '@angular/core';
|
|
2
|
+
import { FormsModule, ReactiveFormsModule, } from '@angular/forms';
|
|
3
|
+
import { TAK_DEFAULT_APPEARANCE_FORM } from '../common';
|
|
4
|
+
import { CommonModule } from '@angular/common';
|
|
5
|
+
import { MatFormFieldModule } from '@kato-lee/material/form-field';
|
|
6
|
+
import { TakErrorComponent } from '../error/component';
|
|
7
|
+
import { MatButtonModule } from '@kato-lee/material/button';
|
|
8
|
+
import { MatInputModule } from '@kato-lee/material/input';
|
|
9
|
+
import { MatIconModule } from '@kato-lee/material/icon';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@angular/forms";
|
|
12
|
+
import * as i2 from "@kato-lee/material/form-field";
|
|
13
|
+
import * as i3 from "@kato-lee/material/button";
|
|
14
|
+
import * as i4 from "@kato-lee/material/icon";
|
|
15
|
+
import * as i5 from "@kato-lee/material/input";
|
|
16
|
+
export class TakTextareaComponent {
|
|
17
|
+
constructor(_ngControl, _formGroupDirective, _cd) {
|
|
18
|
+
this._ngControl = _ngControl;
|
|
19
|
+
this._formGroupDirective = _formGroupDirective;
|
|
20
|
+
this._cd = _cd;
|
|
21
|
+
this.autocomplete = 'off';
|
|
22
|
+
this.appearance = TAK_DEFAULT_APPEARANCE_FORM;
|
|
23
|
+
this.floatLabel = 'auto';
|
|
24
|
+
this.color = 'primary';
|
|
25
|
+
this.actionIcon = 'search';
|
|
26
|
+
this.defaultFilterStyle = true;
|
|
27
|
+
this.hasActionButton = false;
|
|
28
|
+
this.hasClearButton = false;
|
|
29
|
+
this.countCaracters = false;
|
|
30
|
+
this.isTextArea = false;
|
|
31
|
+
this.placeholder = '';
|
|
32
|
+
this.heightInPx = 60;
|
|
33
|
+
this.disabled = false;
|
|
34
|
+
this.onExecuteAction = new EventEmitter();
|
|
35
|
+
this.onKeyUp = new EventEmitter();
|
|
36
|
+
this.onChangeFn = (_) => { };
|
|
37
|
+
this.onTouchFn = (_) => { };
|
|
38
|
+
this._isSubmitted = false;
|
|
39
|
+
this._isInvalid = false;
|
|
40
|
+
this._required = false;
|
|
41
|
+
this._value = '';
|
|
42
|
+
this._decrypted = false;
|
|
43
|
+
if (_ngControl)
|
|
44
|
+
this._ngControl.valueAccessor = this;
|
|
45
|
+
if (_formGroupDirective) {
|
|
46
|
+
this._subscription = _formGroupDirective.ngSubmit.subscribe(() => {
|
|
47
|
+
this._isSubmitted = true;
|
|
48
|
+
_cd.markForCheck();
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
ngOnInit() {
|
|
53
|
+
const form = this.control;
|
|
54
|
+
if (form?._rawValidators) {
|
|
55
|
+
form._rawValidators.forEach((r) => {
|
|
56
|
+
if (r.name.includes('required'))
|
|
57
|
+
this._required = true;
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
if (this.disabled)
|
|
61
|
+
this.control.disable();
|
|
62
|
+
}
|
|
63
|
+
writeValue(value) {
|
|
64
|
+
if (value === null) {
|
|
65
|
+
this._isInvalid = false;
|
|
66
|
+
}
|
|
67
|
+
this._value = value;
|
|
68
|
+
this._isSubmitted = false;
|
|
69
|
+
this._cd.markForCheck();
|
|
70
|
+
}
|
|
71
|
+
registerOnChange(fn) {
|
|
72
|
+
this.onChangeFn = fn;
|
|
73
|
+
}
|
|
74
|
+
registerOnTouched(fn) {
|
|
75
|
+
this.onTouchFn = fn;
|
|
76
|
+
}
|
|
77
|
+
onChange(event) {
|
|
78
|
+
this._value = event.target.value;
|
|
79
|
+
this.onChangeFn(event.target.value);
|
|
80
|
+
if (this.control.touched)
|
|
81
|
+
this._onValidate();
|
|
82
|
+
}
|
|
83
|
+
onFocusOut() {
|
|
84
|
+
this.onTouchFn(true);
|
|
85
|
+
this._onValidate();
|
|
86
|
+
}
|
|
87
|
+
_onValidate() {
|
|
88
|
+
if (this.control.invalid)
|
|
89
|
+
this._isInvalid = true;
|
|
90
|
+
else
|
|
91
|
+
this._isInvalid = false;
|
|
92
|
+
}
|
|
93
|
+
onClearControl() {
|
|
94
|
+
if (['', null, undefined].indexOf(this.control.value) >= 0) {
|
|
95
|
+
this.control.setValue('', { emitEvent: false });
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
this.control.setValue('');
|
|
99
|
+
}
|
|
100
|
+
this._value = '';
|
|
101
|
+
}
|
|
102
|
+
ngOnDestroy() {
|
|
103
|
+
if (this._subscription)
|
|
104
|
+
this._subscription.unsubscribe();
|
|
105
|
+
}
|
|
106
|
+
get control() {
|
|
107
|
+
return this._ngControl.control;
|
|
108
|
+
}
|
|
109
|
+
get directive() {
|
|
110
|
+
return this._formGroupDirective;
|
|
111
|
+
}
|
|
112
|
+
get decrypted() {
|
|
113
|
+
return this._decrypted;
|
|
114
|
+
}
|
|
115
|
+
get isDisabled() {
|
|
116
|
+
return this._ngControl.disabled;
|
|
117
|
+
}
|
|
118
|
+
get isSubmitted() {
|
|
119
|
+
return this._isSubmitted;
|
|
120
|
+
}
|
|
121
|
+
get isInvalid() {
|
|
122
|
+
return this._isInvalid;
|
|
123
|
+
}
|
|
124
|
+
get required() {
|
|
125
|
+
return this._required;
|
|
126
|
+
}
|
|
127
|
+
get value() {
|
|
128
|
+
return this._value;
|
|
129
|
+
}
|
|
130
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: TakTextareaComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: i1.FormGroupDirective, optional: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
131
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.3", type: TakTextareaComponent, isStandalone: true, selector: "tak-textarea", inputs: { autocomplete: "autocomplete", appearance: "appearance", floatLabel: "floatLabel", color: "color", actionIcon: "actionIcon", defaultFilterStyle: "defaultFilterStyle", hasActionButton: "hasActionButton", hasClearButton: "hasClearButton", countCaracters: "countCaracters", isTextArea: "isTextArea", placeholder: "placeholder", heightInPx: "heightInPx", minLength: "minLength", maxLength: "maxLength", 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 />{{ ' ' }}\r\n @if (required) {\r\n <span class=\"tak-field__danger-x\">*</span>\r\n }\r\n </mat-label>\r\n <textarea\r\n matInput\r\n [autocomplete]=\"autocomplete\"\r\n [value]=\"value\"\r\n [style.height.px]=\"heightInPx\"\r\n [placeholder]=\"placeholder\"\r\n (keyup)=\"onChange($event)\"\r\n (change)=\"onChange($event)\"\r\n [disabled]=\"isDisabled\"\r\n [attr.minLength]=\"minLength\"\r\n [attr.maxLength]=\"maxLength\"\r\n (focusout)=\"onFocusOut()\"\r\n ></textarea>\r\n @if (control.value && hasClearButton && !isDisabled) {\r\n <button mat-icon-button type=\"button\" matSuffix (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) {\r\n <button mat-icon-button type=\"button\" matSuffix (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: TakErrorComponent, selector: "tak-error", inputs: ["control", "start", "end", "isDateField", "isNumberField", "marginTop"] }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: MatFormFieldModule }, { 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: "ngmodule", type: MatButtonModule }, { 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: "ngmodule", type: MatIconModule }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i5.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"] }] }); }
|
|
132
|
+
}
|
|
133
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: TakTextareaComponent, decorators: [{
|
|
134
|
+
type: Component,
|
|
135
|
+
args: [{ standalone: true, imports: [
|
|
136
|
+
TakErrorComponent,
|
|
137
|
+
FormsModule,
|
|
138
|
+
CommonModule,
|
|
139
|
+
ReactiveFormsModule,
|
|
140
|
+
MatFormFieldModule,
|
|
141
|
+
MatButtonModule,
|
|
142
|
+
MatIconModule,
|
|
143
|
+
MatInputModule,
|
|
144
|
+
], selector: 'tak-textarea', 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 />{{ ' ' }}\r\n @if (required) {\r\n <span class=\"tak-field__danger-x\">*</span>\r\n }\r\n </mat-label>\r\n <textarea\r\n matInput\r\n [autocomplete]=\"autocomplete\"\r\n [value]=\"value\"\r\n [style.height.px]=\"heightInPx\"\r\n [placeholder]=\"placeholder\"\r\n (keyup)=\"onChange($event)\"\r\n (change)=\"onChange($event)\"\r\n [disabled]=\"isDisabled\"\r\n [attr.minLength]=\"minLength\"\r\n [attr.maxLength]=\"maxLength\"\r\n (focusout)=\"onFocusOut()\"\r\n ></textarea>\r\n @if (control.value && hasClearButton && !isDisabled) {\r\n <button mat-icon-button type=\"button\" matSuffix (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) {\r\n <button mat-icon-button type=\"button\" matSuffix (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" }]
|
|
145
|
+
}], ctorParameters: () => [{ type: i1.NgControl, decorators: [{
|
|
146
|
+
type: Self
|
|
147
|
+
}, {
|
|
148
|
+
type: Optional
|
|
149
|
+
}] }, { type: i1.FormGroupDirective, decorators: [{
|
|
150
|
+
type: Optional
|
|
151
|
+
}] }, { type: i0.ChangeDetectorRef }], propDecorators: { autocomplete: [{
|
|
152
|
+
type: Input
|
|
153
|
+
}], appearance: [{
|
|
154
|
+
type: Input
|
|
155
|
+
}], floatLabel: [{
|
|
156
|
+
type: Input
|
|
157
|
+
}], color: [{
|
|
158
|
+
type: Input
|
|
159
|
+
}], actionIcon: [{
|
|
160
|
+
type: Input
|
|
161
|
+
}], defaultFilterStyle: [{
|
|
162
|
+
type: Input
|
|
163
|
+
}], hasActionButton: [{
|
|
164
|
+
type: Input
|
|
165
|
+
}], hasClearButton: [{
|
|
166
|
+
type: Input
|
|
167
|
+
}], countCaracters: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], isTextArea: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], placeholder: [{
|
|
172
|
+
type: Input
|
|
173
|
+
}], heightInPx: [{
|
|
174
|
+
type: Input
|
|
175
|
+
}], minLength: [{
|
|
176
|
+
type: Input
|
|
177
|
+
}], maxLength: [{
|
|
178
|
+
type: Input
|
|
179
|
+
}], disabled: [{
|
|
180
|
+
type: Input
|
|
181
|
+
}], onExecuteAction: [{
|
|
182
|
+
type: Output
|
|
183
|
+
}], onKeyUp: [{
|
|
184
|
+
type: Output
|
|
185
|
+
}] } });
|
|
186
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../libraries/components/fields/text-area/component.ts","../../../../../libraries/components/fields/text-area/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  FormsModule,\r\n  ReactiveFormsModule,\r\n} from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { TAK_DEFAULT_APPEARANCE_FORM } from '../common';\r\nimport { FloatLabelType, MatFormFieldAppearance } from '@kato-lee/material/form-field';\r\nimport { ThemePalette } from '@kato-lee/material/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MatFormFieldModule } from '@kato-lee/material/form-field';\r\nimport { TakErrorComponent } from '../error/component';\r\nimport { MatButtonModule } from '@kato-lee/material/button';\r\nimport { MatInputModule } from '@kato-lee/material/input';\r\nimport { MatIconModule } from '@kato-lee/material/icon';\r\n\r\n@Component({\r\n  standalone: true,\r\n  imports: [\r\n    TakErrorComponent,\r\n    FormsModule,\r\n    CommonModule,\r\n    ReactiveFormsModule,\r\n    MatFormFieldModule,\r\n    MatButtonModule,\r\n    MatIconModule,\r\n    MatInputModule,\r\n  ],\r\n  selector: 'tak-textarea',\r\n  templateUrl: './component.html',\r\n})\r\nexport class TakTextareaComponent 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 = false;\r\n  @Input() countCaracters = false;\r\n  @Input() isTextArea = false;\r\n  @Input() placeholder = '';\r\n  @Input() heightInPx = 60;\r\n\r\n  @Input() minLength!: number;\r\n  @Input() maxLength!: 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  public _isSubmitted = false;\r\n  public _isInvalid = false;\r\n  public _required = false;\r\n  public _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 (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) {\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    if (this.control.touched) this._onValidate();\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 {\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 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 />{{ ' ' }}\r\n      @if (required) {\r\n        <span class=\"tak-field__danger-x\">*</span>\r\n      }\r\n    </mat-label>\r\n    <textarea\r\n      matInput\r\n      [autocomplete]=\"autocomplete\"\r\n      [value]=\"value\"\r\n      [style.height.px]=\"heightInPx\"\r\n      [placeholder]=\"placeholder\"\r\n      (keyup)=\"onChange($event)\"\r\n      (change)=\"onChange($event)\"\r\n      [disabled]=\"isDisabled\"\r\n      [attr.minLength]=\"minLength\"\r\n      [attr.maxLength]=\"maxLength\"\r\n      (focusout)=\"onFocusOut()\"\r\n    ></textarea>\r\n    @if (control.value && hasClearButton && !isDisabled) {\r\n      <button mat-icon-button type=\"button\" matSuffix (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) {\r\n      <button mat-icon-button type=\"button\" matSuffix (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"]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Validators } from '@angular/forms';
|
|
2
|
+
import { TAK_PTRN_EMAIL, TAK_PTRN_NONSP, TAK_PTRN_NUMRC } from './common';
|
|
3
|
+
export const required = Validators.required;
|
|
4
|
+
export const max = (max) => Validators.max(max);
|
|
5
|
+
export const min = (min) => Validators.min(min);
|
|
6
|
+
export const maxLength = (maxLength) => Validators.maxLength(maxLength);
|
|
7
|
+
export const minLength = (minLength) => Validators.minLength(minLength);
|
|
8
|
+
export const withOutSpaces = Validators.pattern(TAK_PTRN_NONSP);
|
|
9
|
+
export const onlyNumber = Validators.pattern(TAK_PTRN_NUMRC);
|
|
10
|
+
export const email = Validators.pattern(TAK_PTRN_EMAIL);
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdG9ycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnJhcmllcy9jb21wb25lbnRzL2ZpZWxkcy92YWxpZGF0b3JzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM1QyxPQUFPLEVBQUUsY0FBYyxFQUFFLGNBQWMsRUFBRSxjQUFjLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFFMUUsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFHLFVBQVUsQ0FBQyxRQUFRLENBQUM7QUFFNUMsTUFBTSxDQUFDLE1BQU0sR0FBRyxHQUFHLENBQUMsR0FBVyxFQUFFLEVBQUUsQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0FBQ3hELE1BQU0sQ0FBQyxNQUFNLEdBQUcsR0FBRyxDQUFDLEdBQVcsRUFBRSxFQUFFLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztBQUV4RCxNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsQ0FBQyxTQUFpQixFQUFFLEVBQUUsQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQyxDQUFDO0FBQ2hGLE1BQU0sQ0FBQyxNQUFNLFNBQVMsR0FBRyxDQUFDLFNBQWlCLEVBQUUsRUFBRSxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDLENBQUM7QUFFaEYsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLFVBQVUsQ0FBQyxPQUFPLENBQUMsY0FBYyxDQUFDLENBQUM7QUFDaEUsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHLFVBQVUsQ0FBQyxPQUFPLENBQUMsY0FBYyxDQUFDLENBQUM7QUFDN0QsTUFBTSxDQUFDLE1BQU0sS0FBSyxHQUFHLFVBQVUsQ0FBQyxPQUFPLENBQUMsY0FBYyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBWYWxpZGF0b3JzIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBUQUtfUFRSTl9FTUFJTCwgVEFLX1BUUk5fTk9OU1AsIFRBS19QVFJOX05VTVJDIH0gZnJvbSAnLi9jb21tb24nO1xyXG5cclxuZXhwb3J0IGNvbnN0IHJlcXVpcmVkID0gVmFsaWRhdG9ycy5yZXF1aXJlZDtcclxuXHJcbmV4cG9ydCBjb25zdCBtYXggPSAobWF4OiBudW1iZXIpID0+IFZhbGlkYXRvcnMubWF4KG1heCk7XHJcbmV4cG9ydCBjb25zdCBtaW4gPSAobWluOiBudW1iZXIpID0+IFZhbGlkYXRvcnMubWluKG1pbik7XHJcblxyXG5leHBvcnQgY29uc3QgbWF4TGVuZ3RoID0gKG1heExlbmd0aDogbnVtYmVyKSA9PiBWYWxpZGF0b3JzLm1heExlbmd0aChtYXhMZW5ndGgpO1xyXG5leHBvcnQgY29uc3QgbWluTGVuZ3RoID0gKG1pbkxlbmd0aDogbnVtYmVyKSA9PiBWYWxpZGF0b3JzLm1pbkxlbmd0aChtaW5MZW5ndGgpO1xyXG5cclxuZXhwb3J0IGNvbnN0IHdpdGhPdXRTcGFjZXMgPSBWYWxpZGF0b3JzLnBhdHRlcm4oVEFLX1BUUk5fTk9OU1ApO1xyXG5leHBvcnQgY29uc3Qgb25seU51bWJlciA9IFZhbGlkYXRvcnMucGF0dGVybihUQUtfUFRSTl9OVU1SQyk7XHJcbmV4cG9ydCBjb25zdCBlbWFpbCA9IFZhbGlkYXRvcnMucGF0dGVybihUQUtfUFRSTl9FTUFJTCk7XHJcbiJdfQ==
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { Component, Inject, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { MAT_DIALOG_DATA, MatDialogModule } from '@kato-lee/material/dialog';
|
|
3
|
+
import { MatButtonModule } from '@kato-lee/material/button';
|
|
4
|
+
import { MatIconModule } from '@kato-lee/material/icon';
|
|
5
|
+
import { MatDividerModule } from '@kato-lee/material/divider';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@kato-lee/material/dialog";
|
|
8
|
+
import * as i2 from "@kato-lee/material/button";
|
|
9
|
+
import * as i3 from "@kato-lee/material/divider";
|
|
10
|
+
import * as i4 from "@kato-lee/material/icon";
|
|
11
|
+
export class TakModalComponent {
|
|
12
|
+
constructor(href, _dialogRef, data) {
|
|
13
|
+
this._dialogRef = _dialogRef;
|
|
14
|
+
this.data = data;
|
|
15
|
+
this._isAlert = false;
|
|
16
|
+
this._confirmButton = '';
|
|
17
|
+
this._deniedButton = '';
|
|
18
|
+
this._okButton = '';
|
|
19
|
+
this._hasTopCloseButton = true;
|
|
20
|
+
href.nativeElement.classList.add('tak-modal');
|
|
21
|
+
}
|
|
22
|
+
ngOnInit() {
|
|
23
|
+
if (this.data.type === 'alert')
|
|
24
|
+
this._isAlert = true;
|
|
25
|
+
else
|
|
26
|
+
this._isAlert = false;
|
|
27
|
+
this._confirmButton = this.data.options?.confirmButton || 'SI';
|
|
28
|
+
this._deniedButton = this.data.options?.deniedButton || 'NO';
|
|
29
|
+
this._okButton = this.data.options?.okButton || 'OK';
|
|
30
|
+
this._hasTopCloseButton = this.data.options?.hasTopCloseButton || true;
|
|
31
|
+
}
|
|
32
|
+
onConfirm() {
|
|
33
|
+
this._dialogRef.close(true);
|
|
34
|
+
}
|
|
35
|
+
onClose() {
|
|
36
|
+
this._dialogRef.close(false);
|
|
37
|
+
}
|
|
38
|
+
onCloseFromButton() {
|
|
39
|
+
this._dialogRef.close(undefined);
|
|
40
|
+
}
|
|
41
|
+
get isAlert() {
|
|
42
|
+
return this._isAlert;
|
|
43
|
+
}
|
|
44
|
+
get confirmButton() {
|
|
45
|
+
return this._confirmButton;
|
|
46
|
+
}
|
|
47
|
+
get deniedButton() {
|
|
48
|
+
return this._deniedButton;
|
|
49
|
+
}
|
|
50
|
+
get okButton() {
|
|
51
|
+
return this._okButton;
|
|
52
|
+
}
|
|
53
|
+
get hasTopCloseButton() {
|
|
54
|
+
return this._hasTopCloseButton;
|
|
55
|
+
}
|
|
56
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: TakModalComponent, deps: [{ token: i0.ElementRef }, { token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
57
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.3", type: TakModalComponent, isStandalone: true, selector: "tak-modal", ngImport: i0, template: "@if (hasTopCloseButton) {\r\n <div mat-dialog-title>\r\n @if (data.title !== '') {\r\n <span class=\"tak-modal__title\">{{ data.title }}</span>\r\n }\r\n <div>\r\n <button mat-icon-button (click)=\"onCloseFromButton()\"><mat-icon>close</mat-icon></button>\r\n </div>\r\n </div>\r\n}\r\n@if (hasTopCloseButton) {\r\n <mat-divider />\r\n}\r\n<div mat-dialog-content>\r\n <div class=\"tak-modal__content\">\r\n <p>{{ data.content }}</p>\r\n </div>\r\n</div>\r\n<mat-divider />\r\n<mat-dialog-actions align=\"end\">\r\n @if (!isAlert) {\r\n <button mat-button color=\"accent\" (click)=\"onConfirm()\">\r\n {{ confirmButton }}\r\n </button>\r\n }\r\n @if (!isAlert) {\r\n <button mat-button color=\"warn\" (click)=\"onClose()\" cdkFocusInitial>\r\n {{ deniedButton }}\r\n </button>\r\n }\r\n @if (isAlert) {\r\n <button mat-button color=\"accent\" (click)=\"onClose()\" style=\"float: right\" cdkFocusInitial>\r\n {{ okButton }}\r\n </button>\r\n }\r\n</mat-dialog-actions>\r\n", styles: [".tak-modal .mat-dialog-title,.tak-modal .mat-dialog__content{padding:0}.tak-modal [mat-button]{font-weight:bolder}.tak-modal [mat-dialog-title]{display:flex;align-items:center;justify-content:space-between}.tak-modal__title{padding:10px;font-size:20px;font-weight:bolder}.tak-modal__content{padding:0 24px;font-size:14px;color:var(--mdc-dialog-subhead-color)}.tak-modal__buttons{display:flex}.tak-modal__buttons button{font-weight:bolder;text-transform:uppercase}.tak-modal__buttons.tak-modal-one{justify-content:end}.tak-modal__buttons.tak-modal-two{justify-content:space-between}.tak-modal .tak-dialog-content{padding:0}\n"], dependencies: [{ kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i2.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: "ngmodule", type: MatDialogModule }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "ngmodule", type: MatDividerModule }, { kind: "component", type: i3.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
58
|
+
}
|
|
59
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: TakModalComponent, decorators: [{
|
|
60
|
+
type: Component,
|
|
61
|
+
args: [{ standalone: true, imports: [MatButtonModule, MatDialogModule, MatDividerModule, MatIconModule], selector: 'tak-modal', encapsulation: ViewEncapsulation.None, template: "@if (hasTopCloseButton) {\r\n <div mat-dialog-title>\r\n @if (data.title !== '') {\r\n <span class=\"tak-modal__title\">{{ data.title }}</span>\r\n }\r\n <div>\r\n <button mat-icon-button (click)=\"onCloseFromButton()\"><mat-icon>close</mat-icon></button>\r\n </div>\r\n </div>\r\n}\r\n@if (hasTopCloseButton) {\r\n <mat-divider />\r\n}\r\n<div mat-dialog-content>\r\n <div class=\"tak-modal__content\">\r\n <p>{{ data.content }}</p>\r\n </div>\r\n</div>\r\n<mat-divider />\r\n<mat-dialog-actions align=\"end\">\r\n @if (!isAlert) {\r\n <button mat-button color=\"accent\" (click)=\"onConfirm()\">\r\n {{ confirmButton }}\r\n </button>\r\n }\r\n @if (!isAlert) {\r\n <button mat-button color=\"warn\" (click)=\"onClose()\" cdkFocusInitial>\r\n {{ deniedButton }}\r\n </button>\r\n }\r\n @if (isAlert) {\r\n <button mat-button color=\"accent\" (click)=\"onClose()\" style=\"float: right\" cdkFocusInitial>\r\n {{ okButton }}\r\n </button>\r\n }\r\n</mat-dialog-actions>\r\n", styles: [".tak-modal .mat-dialog-title,.tak-modal .mat-dialog__content{padding:0}.tak-modal [mat-button]{font-weight:bolder}.tak-modal [mat-dialog-title]{display:flex;align-items:center;justify-content:space-between}.tak-modal__title{padding:10px;font-size:20px;font-weight:bolder}.tak-modal__content{padding:0 24px;font-size:14px;color:var(--mdc-dialog-subhead-color)}.tak-modal__buttons{display:flex}.tak-modal__buttons button{font-weight:bolder;text-transform:uppercase}.tak-modal__buttons.tak-modal-one{justify-content:end}.tak-modal__buttons.tak-modal-two{justify-content:space-between}.tak-modal .tak-dialog-content{padding:0}\n"] }]
|
|
62
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.MatDialogRef }, { type: undefined, decorators: [{
|
|
63
|
+
type: Inject,
|
|
64
|
+
args: [MAT_DIALOG_DATA]
|
|
65
|
+
}] }] });
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbGlicmFyaWVzL2NvbXBvbmVudHMvbW9kYWwvY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vbGlicmFyaWVzL2NvbXBvbmVudHMvbW9kYWwvY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxNQUFNLEVBQVUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekYsT0FBTyxFQUFnQixlQUFlLEVBQUUsZUFBZSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFFM0YsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzVELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN4RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7Ozs7O0FBVTlELE1BQU0sT0FBTyxpQkFBaUI7SUFRNUIsWUFDRSxJQUE2QixFQUNyQixVQUEyQyxFQUU1QyxJQUFzRjtRQUZyRixlQUFVLEdBQVYsVUFBVSxDQUFpQztRQUU1QyxTQUFJLEdBQUosSUFBSSxDQUFrRjtRQVh2RixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBRWpCLG1CQUFjLEdBQUcsRUFBRSxDQUFDO1FBQ3BCLGtCQUFhLEdBQUcsRUFBRSxDQUFDO1FBQ25CLGNBQVMsR0FBRyxFQUFFLENBQUM7UUFDZix1QkFBa0IsR0FBRyxJQUFJLENBQUM7UUFRaEMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ2hELENBQUM7SUFFTSxRQUFRO1FBQ2IsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksS0FBSyxPQUFPO1lBQUUsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUM7O1lBQ2hELElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO1FBRTNCLElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsYUFBYSxJQUFJLElBQUksQ0FBQztRQUMvRCxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLFlBQVksSUFBSSxJQUFJLENBQUM7UUFDN0QsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxRQUFRLElBQUksSUFBSSxDQUFDO1FBQ3JELElBQUksQ0FBQyxrQkFBa0IsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxpQkFBaUIsSUFBSSxJQUFJLENBQUM7SUFDekUsQ0FBQztJQUVNLFNBQVM7UUFDZCxJQUFJLENBQUMsVUFBVSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUM5QixDQUFDO0lBRU0sT0FBTztRQUNaLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFTSxpQkFBaUI7UUFDdEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDbkMsQ0FBQztJQUVELElBQUksT0FBTztRQUNULE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN2QixDQUFDO0lBRUQsSUFBSSxhQUFhO1FBQ2YsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDO0lBQzdCLENBQUM7SUFFRCxJQUFJLFlBQVk7UUFDZCxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUM7SUFDNUIsQ0FBQztJQUVELElBQUksUUFBUTtRQUNWLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN4QixDQUFDO0lBRUQsSUFBSSxpQkFBaUI7UUFDbkIsT0FBTyxJQUFJLENBQUMsa0JBQWtCLENBQUM7SUFDakMsQ0FBQzs4R0F6RFUsaUJBQWlCLHdFQVdsQixlQUFlO2tHQVhkLGlCQUFpQixxRUNmOUIsbWhDQW9DQSx5cUJEM0JZLGVBQWUsMFZBQUUsZUFBZSx5YkFBRSxnQkFBZ0Isa0lBQUUsYUFBYTs7MkZBTWhFLGlCQUFpQjtrQkFSN0IsU0FBUztpQ0FDSSxJQUFJLFdBQ1AsQ0FBQyxlQUFlLEVBQUUsZUFBZSxFQUFFLGdCQUFnQixFQUFFLGFBQWEsQ0FBQyxZQUNsRSxXQUFXLGlCQUdOLGlCQUFpQixDQUFDLElBQUk7OzBCQWFsQyxNQUFNOzJCQUFDLGVBQWUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEVsZW1lbnRSZWYsIEluamVjdCwgT25Jbml0LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBNYXREaWFsb2dSZWYsIE1BVF9ESUFMT0dfREFUQSwgTWF0RGlhbG9nTW9kdWxlIH0gZnJvbSAnQGthdG8tbGVlL21hdGVyaWFsL2RpYWxvZyc7XHJcbmltcG9ydCB7IFRha01vZGFsQ29uZmlnLCBUYWtNb2RhbFR5cGUgfSBmcm9tICcuL2NvbmZpZyc7XHJcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0BrYXRvLWxlZS9tYXRlcmlhbC9idXR0b24nO1xyXG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGthdG8tbGVlL21hdGVyaWFsL2ljb24nO1xyXG5pbXBvcnQgeyBNYXREaXZpZGVyTW9kdWxlIH0gZnJvbSAnQGthdG8tbGVlL21hdGVyaWFsL2RpdmlkZXInO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBpbXBvcnRzOiBbTWF0QnV0dG9uTW9kdWxlLCBNYXREaWFsb2dNb2R1bGUsIE1hdERpdmlkZXJNb2R1bGUsIE1hdEljb25Nb2R1bGVdLFxyXG4gIHNlbGVjdG9yOiAndGFrLW1vZGFsJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2NvbXBvbmVudC5zY3NzJ10sXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcclxufSlcclxuZXhwb3J0IGNsYXNzIFRha01vZGFsQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuICBwcml2YXRlIF9pc0FsZXJ0ID0gZmFsc2U7XHJcblxyXG4gIHByaXZhdGUgX2NvbmZpcm1CdXR0b24gPSAnJztcclxuICBwcml2YXRlIF9kZW5pZWRCdXR0b24gPSAnJztcclxuICBwcml2YXRlIF9va0J1dHRvbiA9ICcnO1xyXG4gIHByaXZhdGUgX2hhc1RvcENsb3NlQnV0dG9uID0gdHJ1ZTtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBocmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PixcclxuICAgIHByaXZhdGUgX2RpYWxvZ1JlZjogTWF0RGlhbG9nUmVmPFRha01vZGFsQ29tcG9uZW50PixcclxuICAgIEBJbmplY3QoTUFUX0RJQUxPR19EQVRBKVxyXG4gICAgcHVibGljIGRhdGE6IHsgY29udGVudDogc3RyaW5nOyB0aXRsZTogc3RyaW5nOyBvcHRpb25zPzogVGFrTW9kYWxDb25maWc7IHR5cGU6IFRha01vZGFsVHlwZSB9XHJcbiAgKSB7XHJcbiAgICBocmVmLm5hdGl2ZUVsZW1lbnQuY2xhc3NMaXN0LmFkZCgndGFrLW1vZGFsJyk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICBpZiAodGhpcy5kYXRhLnR5cGUgPT09ICdhbGVydCcpIHRoaXMuX2lzQWxlcnQgPSB0cnVlO1xyXG4gICAgZWxzZSB0aGlzLl9pc0FsZXJ0ID0gZmFsc2U7XHJcblxyXG4gICAgdGhpcy5fY29uZmlybUJ1dHRvbiA9IHRoaXMuZGF0YS5vcHRpb25zPy5jb25maXJtQnV0dG9uIHx8ICdTSSc7XHJcbiAgICB0aGlzLl9kZW5pZWRCdXR0b24gPSB0aGlzLmRhdGEub3B0aW9ucz8uZGVuaWVkQnV0dG9uIHx8ICdOTyc7XHJcbiAgICB0aGlzLl9va0J1dHRvbiA9IHRoaXMuZGF0YS5vcHRpb25zPy5va0J1dHRvbiB8fCAnT0snO1xyXG4gICAgdGhpcy5faGFzVG9wQ2xvc2VCdXR0b24gPSB0aGlzLmRhdGEub3B0aW9ucz8uaGFzVG9wQ2xvc2VCdXR0b24gfHwgdHJ1ZTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBvbkNvbmZpcm0oKTogdm9pZCB7XHJcbiAgICB0aGlzLl9kaWFsb2dSZWYuY2xvc2UodHJ1ZSk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25DbG9zZSgpOiB2b2lkIHtcclxuICAgIHRoaXMuX2RpYWxvZ1JlZi5jbG9zZShmYWxzZSk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25DbG9zZUZyb21CdXR0b24oKTogdm9pZCB7XHJcbiAgICB0aGlzLl9kaWFsb2dSZWYuY2xvc2UodW5kZWZpbmVkKTtcclxuICB9XHJcblxyXG4gIGdldCBpc0FsZXJ0KCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHRoaXMuX2lzQWxlcnQ7XHJcbiAgfVxyXG5cclxuICBnZXQgY29uZmlybUJ1dHRvbigpOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIHRoaXMuX2NvbmZpcm1CdXR0b247XHJcbiAgfVxyXG5cclxuICBnZXQgZGVuaWVkQnV0dG9uKCk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gdGhpcy5fZGVuaWVkQnV0dG9uO1xyXG4gIH1cclxuXHJcbiAgZ2V0IG9rQnV0dG9uKCk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gdGhpcy5fb2tCdXR0b247XHJcbiAgfVxyXG5cclxuICBnZXQgaGFzVG9wQ2xvc2VCdXR0b24oKTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gdGhpcy5faGFzVG9wQ2xvc2VCdXR0b247XHJcbiAgfVxyXG59XHJcbiIsIkBpZiAoaGFzVG9wQ2xvc2VCdXR0b24pIHtcclxuICA8ZGl2IG1hdC1kaWFsb2ctdGl0bGU+XHJcbiAgICBAaWYgKGRhdGEudGl0bGUgIT09ICcnKSB7XHJcbiAgICAgIDxzcGFuIGNsYXNzPVwidGFrLW1vZGFsX190aXRsZVwiPnt7IGRhdGEudGl0bGUgfX08L3NwYW4+XHJcbiAgICB9XHJcbiAgICA8ZGl2PlxyXG4gICAgICA8YnV0dG9uIG1hdC1pY29uLWJ1dHRvbiAoY2xpY2spPVwib25DbG9zZUZyb21CdXR0b24oKVwiPjxtYXQtaWNvbj5jbG9zZTwvbWF0LWljb24+PC9idXR0b24+XHJcbiAgICA8L2Rpdj5cclxuICA8L2Rpdj5cclxufVxyXG5AaWYgKGhhc1RvcENsb3NlQnV0dG9uKSB7XHJcbiAgPG1hdC1kaXZpZGVyIC8+XHJcbn1cclxuPGRpdiBtYXQtZGlhbG9nLWNvbnRlbnQ+XHJcbiAgPGRpdiBjbGFzcz1cInRhay1tb2RhbF9fY29udGVudFwiPlxyXG4gICAgPHA+e3sgZGF0YS5jb250ZW50IH19PC9wPlxyXG4gIDwvZGl2PlxyXG48L2Rpdj5cclxuPG1hdC1kaXZpZGVyIC8+XHJcbjxtYXQtZGlhbG9nLWFjdGlvbnMgYWxpZ249XCJlbmRcIj5cclxuICBAaWYgKCFpc0FsZXJ0KSB7XHJcbiAgICA8YnV0dG9uIG1hdC1idXR0b24gY29sb3I9XCJhY2NlbnRcIiAoY2xpY2spPVwib25Db25maXJtKClcIj5cclxuICAgICAge3sgY29uZmlybUJ1dHRvbiB9fVxyXG4gICAgPC9idXR0b24+XHJcbiAgfVxyXG4gIEBpZiAoIWlzQWxlcnQpIHtcclxuICAgIDxidXR0b24gbWF0LWJ1dHRvbiBjb2xvcj1cIndhcm5cIiAoY2xpY2spPVwib25DbG9zZSgpXCIgY2RrRm9jdXNJbml0aWFsPlxyXG4gICAgICB7eyBkZW5pZWRCdXR0b24gfX1cclxuICAgIDwvYnV0dG9uPlxyXG4gIH1cclxuICBAaWYgKGlzQWxlcnQpIHtcclxuICAgIDxidXR0b24gbWF0LWJ1dHRvbiBjb2xvcj1cImFjY2VudFwiIChjbGljayk9XCJvbkNsb3NlKClcIiBzdHlsZT1cImZsb2F0OiByaWdodFwiIGNka0ZvY3VzSW5pdGlhbD5cclxuICAgICAge3sgb2tCdXR0b24gfX1cclxuICAgIDwvYnV0dG9uPlxyXG4gIH1cclxuPC9tYXQtZGlhbG9nLWFjdGlvbnM+XHJcbiJdfQ==
|
package/esm2022/modal/index.mjs
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
* Public API Surface of @kato-lee/components/modal
|
|
3
3
|
*/
|
|
4
4
|
export * from './config';
|
|
5
|
-
export * from './
|
|
6
|
-
export * from './
|
|
7
|
-
export * from './
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
export * from './component';
|
|
6
|
+
export * from './module';
|
|
7
|
+
export * from './service';
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJyYXJpZXMvY29tcG9uZW50cy9tb2RhbC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsV0FBVyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIEBrYXRvLWxlZS9jb21wb25lbnRzL21vZGFsXHJcbiAqL1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9jb25maWcnO1xyXG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9zZXJ2aWNlJztcclxuIl19
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { TakModalComponent } from './component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
/** @deprecated Use standalone */
|
|
5
|
+
export class TakModalModule {
|
|
6
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: TakModalModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
7
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.3", ngImport: i0, type: TakModalModule, imports: [TakModalComponent], exports: [TakModalComponent] }); }
|
|
8
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: TakModalModule, imports: [TakModalComponent] }); }
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: TakModalModule, decorators: [{
|
|
11
|
+
type: NgModule,
|
|
12
|
+
args: [{
|
|
13
|
+
imports: [TakModalComponent],
|
|
14
|
+
exports: [TakModalComponent],
|
|
15
|
+
}]
|
|
16
|
+
}] });
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vbGlicmFyaWVzL2NvbXBvbmVudHMvbW9kYWwvbW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sYUFBYSxDQUFDOztBQUVoRCxpQ0FBaUM7QUFLakMsTUFBTSxPQUFPLGNBQWM7OEdBQWQsY0FBYzsrR0FBZCxjQUFjLFlBSGYsaUJBQWlCLGFBQ2pCLGlCQUFpQjsrR0FFaEIsY0FBYyxZQUhmLGlCQUFpQjs7MkZBR2hCLGNBQWM7a0JBSjFCLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsaUJBQWlCLENBQUM7b0JBQzVCLE9BQU8sRUFBRSxDQUFDLGlCQUFpQixDQUFDO2lCQUM3QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFRha01vZGFsQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnQnO1xyXG5cclxuLyoqIEBkZXByZWNhdGVkIFVzZSBzdGFuZGFsb25lICovXHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1Rha01vZGFsQ29tcG9uZW50XSxcclxuICBleHBvcnRzOiBbVGFrTW9kYWxDb21wb25lbnRdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgVGFrTW9kYWxNb2R1bGUge31cclxuIl19
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { TakModalComponent } from './component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@kato-lee/material/dialog";
|
|
5
|
+
export class TakModal {
|
|
6
|
+
constructor(dialog) {
|
|
7
|
+
this.dialog = dialog;
|
|
8
|
+
}
|
|
9
|
+
alert(content, title = '', options) {
|
|
10
|
+
return this._generateDialog(content, title, 'alert', options);
|
|
11
|
+
}
|
|
12
|
+
confirm(content, title = '', options) {
|
|
13
|
+
return this._generateDialog(content, title, 'confirm', options);
|
|
14
|
+
}
|
|
15
|
+
_generateDialog(content, title, type, options) {
|
|
16
|
+
const dialog = this.dialog.open(TakModalComponent, {
|
|
17
|
+
data: {
|
|
18
|
+
content,
|
|
19
|
+
title,
|
|
20
|
+
options,
|
|
21
|
+
type,
|
|
22
|
+
},
|
|
23
|
+
});
|
|
24
|
+
return dialog.afterClosed();
|
|
25
|
+
}
|
|
26
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: TakModal, deps: [{ token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
27
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: TakModal, providedIn: 'root' }); }
|
|
28
|
+
}
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.3", ngImport: i0, type: TakModal, decorators: [{
|
|
30
|
+
type: Injectable,
|
|
31
|
+
args: [{ providedIn: 'root' }]
|
|
32
|
+
}], ctorParameters: () => [{ type: i1.MatDialog }] });
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnJhcmllcy9jb21wb25lbnRzL21vZGFsL3NlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxhQUFhLENBQUM7OztBQUtoRCxNQUFNLE9BQU8sUUFBUTtJQUNuQixZQUFvQixNQUFpQjtRQUFqQixXQUFNLEdBQU4sTUFBTSxDQUFXO0lBQUcsQ0FBQztJQUVsQyxLQUFLLENBQUMsT0FBZSxFQUFFLFFBQWdCLEVBQUUsRUFBRSxPQUF3QjtRQUN4RSxPQUFPLElBQUksQ0FBQyxlQUFlLENBQUMsT0FBTyxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDaEUsQ0FBQztJQUVNLE9BQU8sQ0FDWixPQUFlLEVBQ2YsUUFBZ0IsRUFBRSxFQUNsQixPQUF3QjtRQUV4QixPQUFPLElBQUksQ0FBQyxlQUFlLENBQUMsT0FBTyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDbEUsQ0FBQztJQUVPLGVBQWUsQ0FDckIsT0FBZSxFQUNmLEtBQWEsRUFDYixJQUFrQixFQUNsQixPQUF3QjtRQUV4QixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsRUFBRTtZQUNqRCxJQUFJLEVBQUU7Z0JBQ0osT0FBTztnQkFDUCxLQUFLO2dCQUNMLE9BQU87Z0JBQ1AsSUFBSTthQUNMO1NBQ0YsQ0FBQyxDQUFDO1FBQ0gsT0FBTyxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDOUIsQ0FBQzs4R0E5QlUsUUFBUTtrSEFBUixRQUFRLGNBREssTUFBTTs7MkZBQ25CLFFBQVE7a0JBRHBCLFVBQVU7bUJBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBNYXREaWFsb2cgfSBmcm9tICdAa2F0by1sZWUvbWF0ZXJpYWwvZGlhbG9nJztcclxuaW1wb3J0IHsgVGFrTW9kYWxDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudCc7XHJcbmltcG9ydCB7IFRha01vZGFsQ29uZmlnLCBUYWtNb2RhbFR5cGUgfSBmcm9tICcuL2NvbmZpZyc7XHJcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuXHJcbkBJbmplY3RhYmxlKHsgcHJvdmlkZWRJbjogJ3Jvb3QnIH0pXHJcbmV4cG9ydCBjbGFzcyBUYWtNb2RhbCB7XHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBkaWFsb2c6IE1hdERpYWxvZykge31cclxuXHJcbiAgcHVibGljIGFsZXJ0KGNvbnRlbnQ6IHN0cmluZywgdGl0bGU6IHN0cmluZyA9ICcnLCBvcHRpb25zPzogVGFrTW9kYWxDb25maWcpOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcclxuICAgIHJldHVybiB0aGlzLl9nZW5lcmF0ZURpYWxvZyhjb250ZW50LCB0aXRsZSwgJ2FsZXJ0Jywgb3B0aW9ucyk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgY29uZmlybShcclxuICAgIGNvbnRlbnQ6IHN0cmluZyxcclxuICAgIHRpdGxlOiBzdHJpbmcgPSAnJyxcclxuICAgIG9wdGlvbnM/OiBUYWtNb2RhbENvbmZpZ1xyXG4gICk6IE9ic2VydmFibGU8Ym9vbGVhbj4ge1xyXG4gICAgcmV0dXJuIHRoaXMuX2dlbmVyYXRlRGlhbG9nKGNvbnRlbnQsIHRpdGxlLCAnY29uZmlybScsIG9wdGlvbnMpO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBfZ2VuZXJhdGVEaWFsb2coXHJcbiAgICBjb250ZW50OiBzdHJpbmcsXHJcbiAgICB0aXRsZTogc3RyaW5nLFxyXG4gICAgdHlwZTogVGFrTW9kYWxUeXBlLFxyXG4gICAgb3B0aW9ucz86IFRha01vZGFsQ29uZmlnXHJcbiAgKSB7XHJcbiAgICBjb25zdCBkaWFsb2cgPSB0aGlzLmRpYWxvZy5vcGVuKFRha01vZGFsQ29tcG9uZW50LCB7XHJcbiAgICAgIGRhdGE6IHtcclxuICAgICAgICBjb250ZW50LFxyXG4gICAgICAgIHRpdGxlLFxyXG4gICAgICAgIG9wdGlvbnMsXHJcbiAgICAgICAgdHlwZSxcclxuICAgICAgfSxcclxuICAgIH0pO1xyXG4gICAgcmV0dXJuIGRpYWxvZy5hZnRlckNsb3NlZCgpO1xyXG4gIH1cclxufVxyXG4iXX0=
|