master-control 0.3.86 → 0.3.88
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/esm2022/lib/annuity-premium-calculator/annuity-premium-calculator.component.mjs +5 -5
- package/esm2022/lib/dob/dob.component.mjs +76 -99
- package/esm2022/lib/toggle/toggle.component.mjs +3 -3
- package/fesm2022/master-control.mjs +97 -119
- package/fesm2022/master-control.mjs.map +1 -1
- package/lib/dob/dob.component.d.ts +8 -13
- package/master-control-0.3.88.tgz +0 -0
- package/package.json +1 -1
- package/master-control-0.3.86.tgz +0 -0
|
@@ -1,161 +1,141 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
|
-
import { Component, EventEmitter, input, Output
|
|
3
|
-
import { NG_VALUE_ACCESSOR, ReactiveFormsModule
|
|
4
|
-
import { MomentDateAdapter, MomentDateModule
|
|
5
|
-
import { DateAdapter, MAT_DATE_FORMATS
|
|
2
|
+
import { Component, EventEmitter, input, Output } from '@angular/core';
|
|
3
|
+
import { NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
|
|
4
|
+
import { MomentDateAdapter, MomentDateModule } from '@angular/material-moment-adapter';
|
|
5
|
+
import { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';
|
|
6
6
|
import { MatDatepickerModule } from '@angular/material/datepicker';
|
|
7
7
|
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
8
8
|
import { MatInputModule } from '@angular/material/input';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
import * as i1 from "../master-control.service";
|
|
11
|
-
import * as i2 from "@angular/material/
|
|
12
|
-
import * as i3 from "@angular/
|
|
13
|
-
import * as i4 from "@angular/
|
|
14
|
-
import * as i5 from "@angular/material/
|
|
15
|
-
import * as i6 from "@angular/
|
|
16
|
-
import * as i7 from "@angular/forms";
|
|
11
|
+
import * as i2 from "@angular/material/input";
|
|
12
|
+
import * as i3 from "@angular/material/form-field";
|
|
13
|
+
import * as i4 from "@angular/common";
|
|
14
|
+
import * as i5 from "@angular/material/datepicker";
|
|
15
|
+
import * as i6 from "@angular/forms";
|
|
17
16
|
export const MY_DATE_FORMAT = {
|
|
18
17
|
parse: {
|
|
19
|
-
dateInput: [
|
|
18
|
+
dateInput: [
|
|
19
|
+
'DD-MM-YYYY',
|
|
20
|
+
'MM/DD/YYYY',
|
|
21
|
+
'YYYY/MM/DD',
|
|
22
|
+
'DD/MM/YYYY',
|
|
23
|
+
'DD MMM YYYY',
|
|
24
|
+
'DD MMMM YYYY',
|
|
25
|
+
'DD-MMM-YYYY'
|
|
26
|
+
]
|
|
20
27
|
},
|
|
21
28
|
display: {
|
|
22
29
|
dateInput: 'DD-MMM-YYYY',
|
|
23
30
|
monthYearLabel: 'MMM YYYY',
|
|
24
31
|
dateA11yLabel: 'DD-MMM-YYYY',
|
|
25
|
-
monthYearA11yLabel: 'MMMM YYYY'
|
|
26
|
-
}
|
|
32
|
+
monthYearA11yLabel: 'MMMM YYYY'
|
|
33
|
+
}
|
|
27
34
|
};
|
|
28
35
|
export class DobComponent {
|
|
29
36
|
service;
|
|
30
|
-
adapter;
|
|
31
37
|
field = input.required();
|
|
38
|
+
inputValue = null;
|
|
32
39
|
reactiveFormControlobject = input();
|
|
33
40
|
blur = new EventEmitter();
|
|
34
41
|
valueChange = new EventEmitter();
|
|
35
42
|
dateSelected = new EventEmitter();
|
|
36
43
|
invalidDate = new EventEmitter();
|
|
37
|
-
|
|
38
|
-
_control = new FormControl(null);
|
|
39
|
-
_onChange = () => { };
|
|
40
|
-
_onTouched = () => { };
|
|
41
|
-
constructor(service, adapter) {
|
|
44
|
+
constructor(service) {
|
|
42
45
|
this.service = service;
|
|
43
|
-
this.adapter = adapter;
|
|
44
46
|
}
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
if (!
|
|
48
|
-
|
|
49
|
-
return;
|
|
47
|
+
dateDivisionFormat(event) {
|
|
48
|
+
let evt = event.target;
|
|
49
|
+
if (evt.value.length > 2 && !evt.value.substr(2, 1).includes('-')) {
|
|
50
|
+
evt.value = [evt.value.slice(0, 2), '-', evt.value.slice(2)].join('');
|
|
50
51
|
}
|
|
51
|
-
if (
|
|
52
|
-
|
|
53
|
-
|
|
52
|
+
else if (evt.value.length > 5 &&
|
|
53
|
+
Number(evt.value.substr(3, 2)) &&
|
|
54
|
+
!evt.value.substr(5, 1).includes('-')) {
|
|
55
|
+
evt.value = [evt.value.slice(0, 5), '-', evt.value.slice(5)].join('');
|
|
54
56
|
}
|
|
55
|
-
else
|
|
56
|
-
|
|
57
|
+
else if (evt.value.length > 6 &&
|
|
58
|
+
!Number(evt.value.substr(3, 2)) &&
|
|
59
|
+
!evt.value.substr(6, 1).includes('-')) {
|
|
60
|
+
evt.value = [evt.value.slice(0, 6), '-', evt.value.slice(6)].join('');
|
|
57
61
|
}
|
|
58
62
|
}
|
|
63
|
+
_onChange = (inputValue) => { };
|
|
64
|
+
_unTouched = () => { };
|
|
65
|
+
writeValue(obj) {
|
|
66
|
+
this.inputValue = obj;
|
|
67
|
+
}
|
|
68
|
+
;
|
|
59
69
|
registerOnChange(fn) {
|
|
60
70
|
this._onChange = fn;
|
|
61
|
-
this.ctrl.valueChanges.subscribe((m) => {
|
|
62
|
-
if (m && m.isValid && m.isValid()) {
|
|
63
|
-
const s = this.adapter.format(m, MY_DATE_FORMAT.display.dateInput);
|
|
64
|
-
fn(s);
|
|
65
|
-
this.valueChange.emit(s);
|
|
66
|
-
}
|
|
67
|
-
else {
|
|
68
|
-
fn('');
|
|
69
|
-
this.valueChange.emit('');
|
|
70
|
-
}
|
|
71
|
-
});
|
|
72
71
|
}
|
|
72
|
+
;
|
|
73
73
|
registerOnTouched(fn) {
|
|
74
|
-
this.
|
|
75
|
-
}
|
|
76
|
-
setDisabledState(isDisabled) {
|
|
77
|
-
if (isDisabled)
|
|
78
|
-
this.ctrl.disable({ emitEvent: false });
|
|
79
|
-
else
|
|
80
|
-
this.ctrl.enable({ emitEvent: false });
|
|
74
|
+
this._unTouched = fn;
|
|
81
75
|
}
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
v = `${v.slice(0, 5)}-${v.slice(5)}`;
|
|
89
|
-
el.value = v;
|
|
76
|
+
;
|
|
77
|
+
setDisabledState(isDisabled) { }
|
|
78
|
+
;
|
|
79
|
+
onInputChange(event) {
|
|
80
|
+
this.inputValue = event.target.value;
|
|
81
|
+
this._onChange(this.inputValue);
|
|
90
82
|
}
|
|
91
83
|
onInputBlur(event) {
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
if (!this.service.checkIfValueIsEmpty(raw) && !isValid) {
|
|
97
|
-
this.invalidDate.emit({ value: raw, isValid: false, source: 'blur' });
|
|
84
|
+
if (!this.service.checkIfValueIsEmpty(event.target.value)) {
|
|
85
|
+
if (isNaN(Date.parse(event.target.value))) {
|
|
86
|
+
event.target.value = '';
|
|
87
|
+
}
|
|
98
88
|
}
|
|
99
|
-
this.
|
|
89
|
+
this._unTouched();
|
|
100
90
|
this.blur.emit(event);
|
|
101
91
|
}
|
|
92
|
+
// Handle datepicker selection
|
|
102
93
|
onDateChange(event) {
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
94
|
+
if (event.value) {
|
|
95
|
+
const selectedDate = event.value;
|
|
96
|
+
this.inputValue = selectedDate;
|
|
97
|
+
this._onChange(this.inputValue);
|
|
98
|
+
// Emit date selection event
|
|
107
99
|
this.dateSelected.emit({
|
|
108
|
-
formattedValue:
|
|
109
|
-
dateObject:
|
|
100
|
+
formattedValue: this.inputValue,
|
|
101
|
+
dateObject: selectedDate,
|
|
110
102
|
isValid: true,
|
|
111
|
-
source: 'datepicker'
|
|
103
|
+
source: 'datepicker'
|
|
112
104
|
});
|
|
113
|
-
this.valueChange.emit(
|
|
105
|
+
this.valueChange.emit(this.inputValue);
|
|
114
106
|
}
|
|
115
107
|
}
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
}
|
|
119
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DobComponent, deps: [{ token: i1.MasterControlService }, { token: i2.DateAdapter }], target: i0.ɵɵFactoryTarget.Component });
|
|
120
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: DobComponent, isStandalone: true, selector: "lib-dob", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null }, reactiveFormControlobject: { classPropertyName: "reactiveFormControlobject", publicName: "reactiveFormControlobject", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { blur: "blur", valueChange: "valueChange", dateSelected: "dateSelected", invalidDate: "invalidDate" }, providers: [
|
|
108
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DobComponent, deps: [{ token: i1.MasterControlService }], target: i0.ɵɵFactoryTarget.Component });
|
|
109
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DobComponent, isStandalone: true, selector: "lib-dob", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: true, transformFunction: null }, reactiveFormControlobject: { classPropertyName: "reactiveFormControlobject", publicName: "reactiveFormControlobject", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { blur: "blur", valueChange: "valueChange", dateSelected: "dateSelected", invalidDate: "invalidDate" }, providers: [
|
|
121
110
|
{
|
|
122
111
|
provide: NG_VALUE_ACCESSOR,
|
|
123
112
|
useExisting: DobComponent,
|
|
124
|
-
multi: true
|
|
113
|
+
multi: true
|
|
125
114
|
},
|
|
126
115
|
{
|
|
127
116
|
provide: DateAdapter,
|
|
128
117
|
useClass: MomentDateAdapter,
|
|
129
|
-
deps: [
|
|
118
|
+
deps: []
|
|
130
119
|
},
|
|
131
|
-
{ provide: MAT_DATE_FORMATS, useValue: MY_DATE_FORMAT }
|
|
132
|
-
{ provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS, useValue: { useUtc: false, strict: true } },
|
|
133
|
-
], viewQueries: [{ propertyName: "picker", first: true, predicate: ["picker"], descendants: true }], ngImport: i0, template: "<label\r\n *ngIf=\"field() && field()?.isVisible && field().isShowLabel\"\r\n class=\"field-lable\"\r\n>\r\n {{ field()?.label }}\r\n <span style=\"color:red\" *ngIf=\"field()?.validators?.isRequired\">*</span>\r\n</label>\r\n\r\n<mat-form-field\r\n class=\"w-100\"\r\n appearance=\"outline\"\r\n *ngIf=\"field() && field()?.isVisible\"\r\n [ngStyle]=\"{\r\n '--custom-border-color': field()?.controlStyle?.borderColor,\r\n '--custom-border-width': field()?.controlStyle?.borderWidth,\r\n '--custom-border-radius': field()?.controlStyle?.borderRadius,\r\n '--custom-border-color-focus': field()?.controlStyle?.focusBorderColor,\r\n '--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth,\r\n '--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor,\r\n '--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth,\r\n '--custom-border-color-error': field()?.controlStyle?.errorBorderColor,\r\n '--custom-border-width-error': field()?.controlStyle?.errorBorderWidth,\r\n '--custom-font-size': field()?.controlStyle?.fontSize,\r\n '--custom-font-weight': field()?.controlStyle?.fontWeight,\r\n '--custom-font-family': field()?.controlStyle?.fontFamily,\r\n '--custom-font-color': field()?.controlStyle?.color,\r\n '--custom-caret-color': field()?.controlStyle?.caretColor,\r\n '--custom-font-color-disabled': field()?.controlStyle?.disableColor,\r\n '--custom-bg-color-disabled': field()?.controlStyle?.disableBackground,\r\n '--custom-bg-color': field()?.controlStyle?.background,\r\n '--custom-bg-color-focus': field()?.controlStyle?.focusBackground\r\n }\"\r\n>\r\n <input\r\n #txt\r\n matInput\r\n autocomplete=\"off\"\r\n type=\"text\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n [placeholder]=\"field()?.placeHolder\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n [pattern]=\"field()?.validators?.pattern\"\r\n [matDatepicker]=\"picker\"\r\n [formControl]=\"reactiveFormControlobject() || _control\"\r\n (keyup)=\"dateDivisionFormat($event)\"\r\n (dateChange)=\"onDateChange($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n [disabled]=\"field()?.isDisable\"\r\n [min]=\"field()?.configData?.min\"\r\n [max]=\"field()?.configData?.max\"\r\n />\r\n\r\n <mat-datepicker-toggle matSuffix [for]=\"picker\">\r\n <img\r\n src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\"\r\n style=\"width:atepicker\">\r\n </mat-datepicker-toggle>\r\n <mat-datepicker #picker></mat-datepicker>\r\n <mat-error *ngIf=\"(reactiveFormControlobject() || _control).hasError('matDatepickerParse')\">\r\n {{ field()?.validators?.patternMessage || 'Please enter date as DD-MM-YYYY.' }}\r\n </mat-error>\r\n\r\n <mat-error *ngIf=\"field()?.validators?.isRequired && (reactiveFormControlobject() || _control).hasError('required')\">\r\n {{ field()?.validators?.requiredMessage || 'Date is required.' }}\r\n </mat-error>\r\n\r\n</mat-form-field>", styles: [".field-lable{font-size:12px!important;font-weight:700!important;color:#444!important;margin-bottom:0!important}.error-message{color:red}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mat-mdc-notch-piece{border-color:var(--custom-border-color-focus, #ffbb00)!important;border-width:var(--custom-border-width-focus, 1.5px)!important}::ng-deep .mat-mdc-form-field{background-color:var(--custom-bg-color, #ffffff)!important;border-radius:var(--custom-border-radius , 4px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__leading{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__notch{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__trailing{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined .mat-mdc-notch-piece{border-color:var(--custom-border-color, #dddddd)!important;border-width:var(--custom-border-width, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled) .mdc-text-field__input{caret-color:var(--custom-caret-color, #ffbb00)!important;font-size:12px!important;font-weight:var(--custom-font-weight, 400)!important;font-family:var(--custom-font-family, \"Mulish\")!important;color:var(--custom-font-color, #444444)!important}::ng-deep .mat-form-field-invalid .mdc-text-field--outlined .mat-mdc-notch-piece{border-color:var(--custom-border-color-error, red)!important;border-width:var(--custom-border-width-error, 1.5px)!important}::ng-deep .mat-mdc-form-field.mat-form-field-disabled{background:var(--custom-bg-color-disabled, #ECECEC)!important}::ng-deep .mdc-text-field--outlined.mdc-text-field--disabled .mdc-text-field__input{color:var(--custom-font-color-disabled, #999999)!important}::ng-deep .mdc-label{color:var(--custom-font-color, #444)!important;font-size:var(--custom-font-size, 16px)!important;font-weight:var(--custom-font-weight, 400)!important;font-family:var(--custom-font-family, \"Mulish\")!important}::placeholder{color:#8f8f8f!important;font-size:12px!important}::ng-deep .mat-mdc-form-field-hint-wrapper{padding:0!important}::ng-deep .mat-mdc-form-field-error-wrapper{padding:0!important}::ng-deep .mat-mdc-form-field-error{color:#e00!important;font-size:12px;font-weight:500;font-family:Mulish!important;letter-spacing:0}::ng-deep .mdc-text-field--outlined{--mdc-outlined-text-field-container-shape: var(--custom-border-radius , 4px) !important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--invalid .mat-mdc-notch-piece{border-color:var(--custom-border-color-error, red)!important;border-width:var(--custom-border-width-error, 1.5px)!important}::ng-deep .mat-mdc-form-field-subscript-wrapper{display:none!important}*{font-family:mulish!important}::ng-deep .mat-calendar-period-button .mdc-button__label{display:flex;flex-direction:row-reverse;align-items:center;gap:10px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i4.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"] }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i5.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i6.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i6.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i6.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "ngmodule", type: MomentDateModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i7.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i7.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i7.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i7.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }] });
|
|
120
|
+
{ provide: MAT_DATE_FORMATS, useValue: MY_DATE_FORMAT }
|
|
121
|
+
], ngImport: i0, template: "<label\r\n *ngIf=\"field() && field()?.isVisible && field().isShowLabel\"\r\n class=\"field-lable\"\r\n >{{ field()?.label\r\n }}<span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\"\r\n >*</span\r\n ></label\r\n>\r\n<mat-form-field\r\n class=\"w-100\"\r\n appearance=\"outline\"\r\n *ngIf=\"field() && field()?.isVisible\"\r\n [ngStyle]=\"{\r\n '--custom-border-color': field()?.controlStyle?.borderColor ,\r\n '--custom-border-width': field()?.controlStyle?.borderWidth ,\r\n '--custom-border-radius': field()?.controlStyle?.borderRadius ,\r\n '--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\r\n '--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\r\n '--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\r\n '--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\r\n '--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\r\n '--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\r\n '--custom-font-size': field()?.controlStyle?.fontSize ,\r\n '--custom-font-weight': field()?.controlStyle?.fontWeight ,\r\n '--custom-font-family': field()?.controlStyle?.fontFamily ,\r\n '--custom-font-color': field()?.controlStyle?.color ,\r\n '--custom-caret-color': field()?.controlStyle?.caretColor ,\r\n '--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\r\n '--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\r\n '--custom-bg-color': field()?.controlStyle?.background ,\r\n '--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\r\n }\"\r\n>\r\n @if(reactiveFormControlobject()) {\r\n <input\r\n matInput\r\n autocomplete=\"none\"\r\n type=\"text\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n [placeholder]=\"field()?.placeHolder || 'DD-MM-YYYY'\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n [pattern]=\"field()?.validators?.pattern\"\r\n [matDatepicker]=\"picker\"\r\n (keyup)=\"dateDivisionFormat($event)\"\r\n [min]=\"field()?.configData?.min\"\r\n [max]=\"field()?.configData?.max\"\r\n [disabled]=\"field()?.isDisable\"\r\n (dateChange)=\"onDateChange($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n [value]=\"inputValue\"\r\n [formControl]=\"reactiveFormControlobject()\"\r\n />\r\n }@else {\r\n <input\r\n matInput\r\n autocomplete=\"none\"\r\n type=\"text\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n [placeholder]=\"field()?.placeHolder\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n [pattern]=\"field()?.validators?.pattern\"\r\n [matDatepicker]=\"picker\"\r\n (keyup)=\"dateDivisionFormat($event)\"\r\n [min]=\"field()?.configData?.min\"\r\n [max]=\"field()?.configData?.max\"\r\n [disabled]=\"field()?.isDisable\"\r\n (dateChange)=\"onDateChange($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n [value]=\"inputValue\"\r\n />\r\n }\r\n\r\n <mat-datepicker-toggle matSuffix [for]=\"picker\">\r\n <img\r\n src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\"\r\n style=\"width: 16px\"\r\n matDatepickerToggleIcon\r\n />\r\n </mat-datepicker-toggle>\r\n <mat-datepicker #picker></mat-datepicker>\r\n <mat-error *ngIf=\"false\">\r\n {{ field()?.validators?.isRequiredMessage }}\r\n </mat-error>\r\n</mat-form-field>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field()?.validators?.isRequiredMessage }}.\r\n</div>\r\n<div class=\"error-message\" *ngIf=\"field()?.configData?.isInvalid\">\r\n {{ field()?.validators?.patternMessage }}.\r\n</div>\r\n", styles: [".field-lable{font-size:12px!important;font-weight:700!important;color:#444!important;margin-bottom:0!important}.error-message{color:red}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mat-mdc-notch-piece{border-color:var(--custom-border-color-focus, #ffbb00)!important;border-width:var(--custom-border-width-focus, 1.5px)!important}::ng-deep .mat-mdc-form-field{background-color:var(--custom-bg-color, #ffffff)!important;border-radius:var(--custom-border-radius , 4px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__leading{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__notch{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__trailing{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined .mat-mdc-notch-piece{border-color:var(--custom-border-color, #dddddd)!important;border-width:var(--custom-border-width, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled) .mdc-text-field__input{caret-color:var(--custom-caret-color, #ffbb00)!important;font-size:12px!important;font-weight:var(--custom-font-weight, 400)!important;font-family:var(--custom-font-family, \"Mulish\")!important;color:var(--custom-font-color, #444444)!important}::ng-deep .mat-form-field-invalid .mdc-text-field--outlined .mat-mdc-notch-piece{border-color:var(--custom-border-color-error, red)!important;border-width:var(--custom-border-width-error, 1.5px)!important}::ng-deep .mat-mdc-form-field.mat-form-field-disabled{background:var(--custom-bg-color-disabled, #ECECEC)!important}::ng-deep .mdc-text-field--outlined.mdc-text-field--disabled .mdc-text-field__input{color:var(--custom-font-color-disabled, #999999)!important}::ng-deep .mdc-label{color:var(--custom-font-color, #444)!important;font-size:var(--custom-font-size, 16px)!important;font-weight:var(--custom-font-weight, 400)!important;font-family:var(--custom-font-family, \"Mulish\")!important}::placeholder{color:#8f8f8f!important;font-size:12px!important}::ng-deep .mat-mdc-form-field-hint-wrapper{padding:0!important}::ng-deep .mat-mdc-form-field-error-wrapper{padding:0!important}::ng-deep .mat-mdc-form-field-error{color:#e00!important;font-size:12px;font-weight:500;font-family:Mulish!important;letter-spacing:0}::ng-deep .mdc-text-field--outlined{--mdc-outlined-text-field-container-shape: var(--custom-border-radius , 4px) !important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--invalid .mat-mdc-notch-piece{border-color:var(--custom-border-color-error, red)!important;border-width:var(--custom-border-width-error, 1.5px)!important}::ng-deep .mat-mdc-form-field-subscript-wrapper{display:none!important}*{font-family:mulish!important}::ng-deep .mat-calendar-period-button .mdc-button__label{display:flex;flex-direction:row-reverse;align-items:center;gap:10px}\n"], dependencies: [{ kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i2.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"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i5.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i5.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i5.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "directive", type: i5.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { kind: "ngmodule", type: MomentDateModule }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i6.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i6.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }] });
|
|
134
122
|
}
|
|
135
123
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DobComponent, decorators: [{
|
|
136
124
|
type: Component,
|
|
137
|
-
args: [{ selector: 'lib-dob', standalone: true, imports: [
|
|
138
|
-
CommonModule,
|
|
139
|
-
MatInputModule,
|
|
140
|
-
MatFormFieldModule,
|
|
141
|
-
MatDatepickerModule,
|
|
142
|
-
MomentDateModule,
|
|
143
|
-
ReactiveFormsModule,
|
|
144
|
-
], providers: [
|
|
125
|
+
args: [{ selector: 'lib-dob', standalone: true, imports: [MatInputModule, MatFormFieldModule, CommonModule, MatDatepickerModule, MomentDateModule, ReactiveFormsModule], providers: [
|
|
145
126
|
{
|
|
146
127
|
provide: NG_VALUE_ACCESSOR,
|
|
147
128
|
useExisting: DobComponent,
|
|
148
|
-
multi: true
|
|
129
|
+
multi: true
|
|
149
130
|
},
|
|
150
131
|
{
|
|
151
132
|
provide: DateAdapter,
|
|
152
133
|
useClass: MomentDateAdapter,
|
|
153
|
-
deps: [
|
|
134
|
+
deps: []
|
|
154
135
|
},
|
|
155
|
-
{ provide: MAT_DATE_FORMATS, useValue: MY_DATE_FORMAT }
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
}], ctorParameters: () => [{ type: i1.MasterControlService }, { type: i2.DateAdapter }], propDecorators: { blur: [{
|
|
136
|
+
{ provide: MAT_DATE_FORMATS, useValue: MY_DATE_FORMAT }
|
|
137
|
+
], template: "<label\r\n *ngIf=\"field() && field()?.isVisible && field().isShowLabel\"\r\n class=\"field-lable\"\r\n >{{ field()?.label\r\n }}<span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\"\r\n >*</span\r\n ></label\r\n>\r\n<mat-form-field\r\n class=\"w-100\"\r\n appearance=\"outline\"\r\n *ngIf=\"field() && field()?.isVisible\"\r\n [ngStyle]=\"{\r\n '--custom-border-color': field()?.controlStyle?.borderColor ,\r\n '--custom-border-width': field()?.controlStyle?.borderWidth ,\r\n '--custom-border-radius': field()?.controlStyle?.borderRadius ,\r\n '--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\r\n '--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\r\n '--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\r\n '--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\r\n '--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\r\n '--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\r\n '--custom-font-size': field()?.controlStyle?.fontSize ,\r\n '--custom-font-weight': field()?.controlStyle?.fontWeight ,\r\n '--custom-font-family': field()?.controlStyle?.fontFamily ,\r\n '--custom-font-color': field()?.controlStyle?.color ,\r\n '--custom-caret-color': field()?.controlStyle?.caretColor ,\r\n '--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\r\n '--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\r\n '--custom-bg-color': field()?.controlStyle?.background ,\r\n '--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\r\n }\"\r\n>\r\n @if(reactiveFormControlobject()) {\r\n <input\r\n matInput\r\n autocomplete=\"none\"\r\n type=\"text\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n [placeholder]=\"field()?.placeHolder || 'DD-MM-YYYY'\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n [pattern]=\"field()?.validators?.pattern\"\r\n [matDatepicker]=\"picker\"\r\n (keyup)=\"dateDivisionFormat($event)\"\r\n [min]=\"field()?.configData?.min\"\r\n [max]=\"field()?.configData?.max\"\r\n [disabled]=\"field()?.isDisable\"\r\n (dateChange)=\"onDateChange($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n [value]=\"inputValue\"\r\n [formControl]=\"reactiveFormControlobject()\"\r\n />\r\n }@else {\r\n <input\r\n matInput\r\n autocomplete=\"none\"\r\n type=\"text\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n [placeholder]=\"field()?.placeHolder\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n [pattern]=\"field()?.validators?.pattern\"\r\n [matDatepicker]=\"picker\"\r\n (keyup)=\"dateDivisionFormat($event)\"\r\n [min]=\"field()?.configData?.min\"\r\n [max]=\"field()?.configData?.max\"\r\n [disabled]=\"field()?.isDisable\"\r\n (dateChange)=\"onDateChange($event)\"\r\n (blur)=\"onInputBlur($event)\"\r\n [value]=\"inputValue\"\r\n />\r\n }\r\n\r\n <mat-datepicker-toggle matSuffix [for]=\"picker\">\r\n <img\r\n src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\"\r\n style=\"width: 16px\"\r\n matDatepickerToggleIcon\r\n />\r\n </mat-datepicker-toggle>\r\n <mat-datepicker #picker></mat-datepicker>\r\n <mat-error *ngIf=\"false\">\r\n {{ field()?.validators?.isRequiredMessage }}\r\n </mat-error>\r\n</mat-form-field>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n {{ field()?.validators?.isRequiredMessage }}.\r\n</div>\r\n<div class=\"error-message\" *ngIf=\"field()?.configData?.isInvalid\">\r\n {{ field()?.validators?.patternMessage }}.\r\n</div>\r\n", styles: [".field-lable{font-size:12px!important;font-weight:700!important;color:#444!important;margin-bottom:0!important}.error-message{color:red}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mat-mdc-notch-piece{border-color:var(--custom-border-color-focus, #ffbb00)!important;border-width:var(--custom-border-width-focus, 1.5px)!important}::ng-deep .mat-mdc-form-field{background-color:var(--custom-bg-color, #ffffff)!important;border-radius:var(--custom-border-radius , 4px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__leading{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__notch{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused):hover .mdc-notched-outline .mdc-notched-outline__trailing{border-color:var(--custom-border-color-hover, #ffbb00)!important;border-width:var(--custom-border-width-hover, 1.5px)!important}::ng-deep .mdc-text-field--outlined .mat-mdc-notch-piece{border-color:var(--custom-border-color, #dddddd)!important;border-width:var(--custom-border-width, 1.5px)!important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled) .mdc-text-field__input{caret-color:var(--custom-caret-color, #ffbb00)!important;font-size:12px!important;font-weight:var(--custom-font-weight, 400)!important;font-family:var(--custom-font-family, \"Mulish\")!important;color:var(--custom-font-color, #444444)!important}::ng-deep .mat-form-field-invalid .mdc-text-field--outlined .mat-mdc-notch-piece{border-color:var(--custom-border-color-error, red)!important;border-width:var(--custom-border-width-error, 1.5px)!important}::ng-deep .mat-mdc-form-field.mat-form-field-disabled{background:var(--custom-bg-color-disabled, #ECECEC)!important}::ng-deep .mdc-text-field--outlined.mdc-text-field--disabled .mdc-text-field__input{color:var(--custom-font-color-disabled, #999999)!important}::ng-deep .mdc-label{color:var(--custom-font-color, #444)!important;font-size:var(--custom-font-size, 16px)!important;font-weight:var(--custom-font-weight, 400)!important;font-family:var(--custom-font-family, \"Mulish\")!important}::placeholder{color:#8f8f8f!important;font-size:12px!important}::ng-deep .mat-mdc-form-field-hint-wrapper{padding:0!important}::ng-deep .mat-mdc-form-field-error-wrapper{padding:0!important}::ng-deep .mat-mdc-form-field-error{color:#e00!important;font-size:12px;font-weight:500;font-family:Mulish!important;letter-spacing:0}::ng-deep .mdc-text-field--outlined{--mdc-outlined-text-field-container-shape: var(--custom-border-radius , 4px) !important}::ng-deep .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--invalid .mat-mdc-notch-piece{border-color:var(--custom-border-color-error, red)!important;border-width:var(--custom-border-width-error, 1.5px)!important}::ng-deep .mat-mdc-form-field-subscript-wrapper{display:none!important}*{font-family:mulish!important}::ng-deep .mat-calendar-period-button .mdc-button__label{display:flex;flex-direction:row-reverse;align-items:center;gap:10px}\n"] }]
|
|
138
|
+
}], ctorParameters: () => [{ type: i1.MasterControlService }], propDecorators: { blur: [{
|
|
159
139
|
type: Output
|
|
160
140
|
}], valueChange: [{
|
|
161
141
|
type: Output
|
|
@@ -163,8 +143,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
163
143
|
type: Output
|
|
164
144
|
}], invalidDate: [{
|
|
165
145
|
type: Output
|
|
166
|
-
}], picker: [{
|
|
167
|
-
type: ViewChild,
|
|
168
|
-
args: ['picker', { static: false }]
|
|
169
146
|
}] } });
|
|
170
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dob.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/dob/dob.component.ts","../../../../../projects/master-control/src/lib/dob/dob.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, EventEmitter, input, Output, ViewChild } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule, FormControl } from '@angular/forms';\r\nimport {\r\n  MomentDateAdapter,\r\n  MomentDateModule,\r\n  MAT_MOMENT_DATE_ADAPTER_OPTIONS,\r\n} from '@angular/material-moment-adapter';\r\nimport {\r\n  DateAdapter,\r\n  MAT_DATE_FORMATS,\r\n  MAT_DATE_LOCALE,\r\n} from '@angular/material/core';\r\nimport { MatDatepicker, MatDatepickerModule } from '@angular/material/datepicker';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport type { Moment } from 'moment';\r\nimport { MasterControlService } from '../master-control.service';\r\n\r\nexport const MY_DATE_FORMAT = {\r\n  parse: {\r\n    dateInput: ['DD-MM-YYYY'],\r\n  },\r\n  display: {\r\n    dateInput: 'DD-MMM-YYYY',\r\n    monthYearLabel: 'MMM YYYY',\r\n    dateA11yLabel: 'DD-MMM-YYYY',\r\n    monthYearA11yLabel: 'MMMM YYYY',\r\n  },\r\n};\r\n\r\n@Component({\r\n  selector: 'lib-dob',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    MatInputModule,\r\n    MatFormFieldModule,\r\n    MatDatepickerModule,\r\n    MomentDateModule,\r\n    ReactiveFormsModule,\r\n  ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: DobComponent,\r\n      multi: true,\r\n    },\r\n    {\r\n      provide: DateAdapter,\r\n      useClass: MomentDateAdapter,\r\n      deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],\r\n    },\r\n    { provide: MAT_DATE_FORMATS, useValue: MY_DATE_FORMAT },\r\n    { provide: MAT_MOMENT_DATE_ADAPTER_OPTIONS, useValue: { useUtc: false, strict: true } },\r\n  ],\r\n  templateUrl: './dob.component.html',\r\n  styleUrl: './dob.component.css',\r\n})\r\nexport class DobComponent implements ControlValueAccessor {\r\n  field: any = input.required<any>();\r\n  reactiveFormControlobject: any = input<any>();\r\n\r\n  @Output() blur = new EventEmitter<any>();\r\n  @Output() valueChange = new EventEmitter<any>();\r\n  @Output() dateSelected = new EventEmitter<any>();\r\n  @Output() invalidDate = new EventEmitter<any>();\r\n\r\n  @ViewChild('picker', { static: false }) picker!: MatDatepicker<Moment>;\r\n\r\n  public _control = new FormControl<Moment | null>(null);\r\n\r\n  private _onChange: (v: any) => void = () => {};\r\n  private _onTouched: () => void = () => {};\r\n\r\n  constructor(public service: MasterControlService, private adapter: DateAdapter<Moment>) {}\r\n\r\n  writeValue(obj: any): void {\r\n    const c = this.ctrl;\r\n    if (!obj) {\r\n      c.setValue(null, { emitEvent: false });\r\n      return;\r\n    }\r\n    if (typeof obj === 'string') {\r\n      const m = (this.adapter as any).parse(obj, MY_DATE_FORMAT.parse.dateInput);\r\n      c.setValue(m && m.isValid && m.isValid() ? m : null, { emitEvent: false });\r\n    } else {\r\n      c.setValue(obj, { emitEvent: false });\r\n    }\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this._onChange = fn;\r\n    this.ctrl.valueChanges.subscribe((m: Moment | null) => {\r\n      if (m && (m as any).isValid && m.isValid()) {\r\n        const s = (this.adapter as any).format(m, MY_DATE_FORMAT.display.dateInput);\r\n        fn(s);\r\n        this.valueChange.emit(s);\r\n      } else {\r\n        fn('');\r\n        this.valueChange.emit('');\r\n      }\r\n    });\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this._onTouched = fn;\r\n  }\r\n\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    if (isDisabled) this.ctrl.disable({ emitEvent: false });\r\n    else this.ctrl.enable({ emitEvent: false });\r\n  }\r\n\r\n  dateDivisionFormat(event: KeyboardEvent): void {\r\n    const el = event.target as HTMLInputElement;\r\n    let v = el.value.replace(/[^\\d-]/g, '');\r\n    if (v.length > 2 && v[2] !== '-') v = `${v.slice(0, 2)}-${v.slice(2)}`;\r\n    if (v.length > 5 && v[5] !== '-') v = `${v.slice(0, 5)}-${v.slice(5)}`;\r\n    el.value = v; \r\n  }\r\n\r\n  onInputBlur(event: FocusEvent): void {\r\n    const el = event.target as HTMLInputElement;\r\n    const raw = el.value?.trim();\r\n    const m = (this.adapter as any).parse(raw, MY_DATE_FORMAT.parse.dateInput);\r\n    const isValid = m && m.isValid && m.isValid();\r\n\r\n    if (!this.service.checkIfValueIsEmpty(raw) && !isValid) {\r\n      this.invalidDate.emit({ value: raw, isValid: false, source: 'blur' });\r\n    }\r\n    this._onTouched();\r\n    this.blur.emit(event);\r\n  }\r\n\r\n  onDateChange(event: any): void {\r\n    const m: Moment | null = event?.value ?? null;\r\n    this.ctrl.setValue(m);\r\n    if (m) {\r\n      const formatted = (this.adapter as any).format(m, MY_DATE_FORMAT.display.dateInput);\r\n      this.dateSelected.emit({\r\n        formattedValue: formatted,\r\n        dateObject: m,\r\n        isValid: true,\r\n        source: 'datepicker',\r\n      });\r\n      this.valueChange.emit(formatted);\r\n    }\r\n  }\r\n\r\n  private get ctrl(): FormControl<Moment | null> {\r\n    return this.reactiveFormControlobject() || this._control;\r\n  }\r\n}\r\n","<label\r\n  *ngIf=\"field() && field()?.isVisible && field().isShowLabel\"\r\n  class=\"field-lable\"\r\n>\r\n  {{ field()?.label }}\r\n  <span style=\"color:red\" *ngIf=\"field()?.validators?.isRequired\">*</span>\r\n</label>\r\n\r\n<mat-form-field\r\n  class=\"w-100\"\r\n  appearance=\"outline\"\r\n  *ngIf=\"field() && field()?.isVisible\"\r\n  [ngStyle]=\"{\r\n    '--custom-border-color': field()?.controlStyle?.borderColor,\r\n    '--custom-border-width': field()?.controlStyle?.borderWidth,\r\n    '--custom-border-radius': field()?.controlStyle?.borderRadius,\r\n    '--custom-border-color-focus': field()?.controlStyle?.focusBorderColor,\r\n    '--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth,\r\n    '--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor,\r\n    '--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth,\r\n    '--custom-border-color-error': field()?.controlStyle?.errorBorderColor,\r\n    '--custom-border-width-error': field()?.controlStyle?.errorBorderWidth,\r\n    '--custom-font-size': field()?.controlStyle?.fontSize,\r\n    '--custom-font-weight': field()?.controlStyle?.fontWeight,\r\n    '--custom-font-family': field()?.controlStyle?.fontFamily,\r\n    '--custom-font-color': field()?.controlStyle?.color,\r\n    '--custom-caret-color': field()?.controlStyle?.caretColor,\r\n    '--custom-font-color-disabled': field()?.controlStyle?.disableColor,\r\n    '--custom-bg-color-disabled': field()?.controlStyle?.disableBackground,\r\n    '--custom-bg-color': field()?.controlStyle?.background,\r\n    '--custom-bg-color-focus': field()?.controlStyle?.focusBackground\r\n  }\"\r\n>\r\n  <input\r\n    #txt\r\n    matInput\r\n    autocomplete=\"off\"\r\n    type=\"text\"\r\n    [name]=\"field()?.fieldName\"\r\n    [id]=\"field()?.fieldName\"\r\n    [placeholder]=\"field()?.placeHolder\"\r\n    [required]=\"field()?.validators?.isRequired\"\r\n    [pattern]=\"field()?.validators?.pattern\"\r\n    [matDatepicker]=\"picker\"\r\n    [formControl]=\"reactiveFormControlobject() || _control\"\r\n    (keyup)=\"dateDivisionFormat($event)\"\r\n    (dateChange)=\"onDateChange($event)\"\r\n    (blur)=\"onInputBlur($event)\"\r\n    [disabled]=\"field()?.isDisable\"\r\n    [min]=\"field()?.configData?.min\"\r\n    [max]=\"field()?.configData?.max\"\r\n  />\r\n\r\n  <mat-datepicker-toggle matSuffix [for]=\"picker\">\r\n    <img\r\n      src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\"\r\n      style=\"width:atepicker\">\r\n      </mat-datepicker-toggle>\r\n  <mat-datepicker #picker></mat-datepicker>\r\n  <mat-error *ngIf=\"(reactiveFormControlobject() || _control).hasError('matDatepickerParse')\">\r\n    {{ field()?.validators?.patternMessage || 'Please enter date as DD-MM-YYYY.' }}\r\n  </mat-error>\r\n\r\n  <mat-error *ngIf=\"field()?.validators?.isRequired && (reactiveFormControlobject() || _control).hasError('required')\">\r\n    {{ field()?.validators?.requiredMessage || 'Date is required.' }}\r\n  </mat-error>\r\n\r\n</mat-form-field>"]}
|
|
147
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dob.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/dob/dob.component.ts","../../../../../projects/master-control/src/lib/dob/dob.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvE,OAAO,EAAwB,iBAAiB,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAC9F,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AACvF,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AACvE,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;;;;;;;;AAIzD,MAAM,CAAC,MAAM,cAAc,GAAG;IAC5B,KAAK,EAAE;QACL,SAAS,EAAE;YACT,YAAY;YACZ,YAAY;YACZ,YAAY;YACZ,YAAY;YACZ,aAAa;YACb,cAAc;YACd,aAAa;SACd;KACF;IACD,OAAO,EAAE;QACP,SAAS,EAAE,aAAa;QACxB,cAAc,EAAE,UAAU;QAC1B,aAAa,EAAE,aAAa;QAC5B,kBAAkB,EAAE,WAAW;KAChC;CACF,CAAC;AAsBF,MAAM,OAAO,YAAY;IASJ;IARnB,KAAK,GAAQ,KAAK,CAAC,QAAQ,EAAO,CAAC;IACnC,UAAU,GAAQ,IAAI,CAAC;IACvB,yBAAyB,GAAS,KAAK,EAAO,CAAC;IACrC,IAAI,GAAG,IAAI,YAAY,EAAO,CAAC;IAC/B,WAAW,GAAG,IAAI,YAAY,EAAO,CAAC;IACtC,YAAY,GAAG,IAAI,YAAY,EAAO,CAAC;IACvC,WAAW,GAAG,IAAI,YAAY,EAAO,CAAC;IAEhD,YAAmB,OAA8B;QAA9B,YAAO,GAAP,OAAO,CAAuB;IAAG,CAAC;IAErD,kBAAkB,CAAC,KAAU;QAC7B,IAAI,GAAG,GAAG,KAAK,CAAC,MAAM,CAAC;QACvB,IAAI,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,CAAC;YACpE,GAAG,CAAC,KAAK,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACpE,CAAC;aAAM,IACL,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC;YACpB,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YAC9B,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,EACrC,CAAC;YACD,GAAG,CAAC,KAAK,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACxE,CAAC;aAAM,IACL,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC;YACpB,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YAC/B,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,EACrC,CAAC;YACD,GAAG,CAAC,KAAK,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACxE,CAAC;IACH,CAAC;IAMD,SAAS,GAAQ,CAAC,UAAc,EAAE,EAAE,GAAE,CAAC,CAAC;IACxC,UAAU,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;IAE3B,UAAU,CAAC,GAAQ;QACjB,IAAI,CAAC,UAAU,GAAC,GAAG,CAAC;IACtB,CAAC;IAAA,CAAC;IACF,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAAA,CAAC;IACF,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACvB,CAAC;IAAA,CAAC;IACF,gBAAgB,CAAE,UAAmB,IAAQ,CAAC;IAAA,CAAC;IAE/C,aAAa,CAAC,KAAU;QACtB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QACrC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAClC,CAAC;IAED,WAAW,CAAC,KAAY;QACtB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;YAC1D,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC;gBAC1C,KAAK,CAAC,MAAM,CAAC,KAAK,GAAG,EAAE,CAAC;YAC1B,CAAC;QACH,CAAC;QACD,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACxB,CAAC;IAGD,8BAA8B;IAC9B,YAAY,CAAC,KAAU;QACrB,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;YAChB,MAAM,YAAY,GAAG,KAAK,CAAC,KAAK,CAAC;YACjC,IAAI,CAAC,UAAU,GAAG,YAAY,CAAC;YAC/B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAEhC,4BAA4B;YAC5B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;gBACrB,cAAc,EAAE,IAAI,CAAC,UAAU;gBAC/B,UAAU,EAAE,YAAY;gBACxB,OAAO,EAAE,IAAI;gBACb,MAAM,EAAE,YAAY;aACrB,CAAC,CAAC;YAEH,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACzC,CAAC;IACH,CAAC;wGAjFU,YAAY;4FAAZ,YAAY,8dAhBV;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,YAAY;gBACzB,KAAK,EAAE,IAAI;aACZ;YACH;gBACE,OAAO,EAAE,WAAW;gBACpB,QAAQ,EAAE,iBAAiB;gBAC3B,IAAI,EAAE,EAAE;aACT;YACD,EAAE,OAAO,EAAE,gBAAgB,EAAE,QAAQ,EAAE,cAAc,EAAE;SACxD,0BC/CH,4sHA4FA,q9GD1DY,cAAc,mxBAAE,kBAAkB,8BAAE,YAAY,uNAAE,mBAAmB,imBAAE,gBAAgB,8BAAE,mBAAmB;;4FAiB3G,YAAY;kBApBxB,SAAS;+BACE,SAAS,cACP,IAAI,WACP,CAAC,cAAc,EAAE,kBAAkB,EAAE,YAAY,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,mBAAmB,CAAC,aAC1G;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,cAAc;4BACzB,KAAK,EAAE,IAAI;yBACZ;wBACH;4BACE,OAAO,EAAE,WAAW;4BACpB,QAAQ,EAAE,iBAAiB;4BAC3B,IAAI,EAAE,EAAE;yBACT;wBACD,EAAE,OAAO,EAAE,gBAAgB,EAAE,QAAQ,EAAE,cAAc,EAAE;qBACxD;yFAQS,IAAI;sBAAb,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,YAAY;sBAArB,MAAM;gBACG,WAAW;sBAApB,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, EventEmitter, input, Output } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\r\nimport { MomentDateAdapter, MomentDateModule } from '@angular/material-moment-adapter';\r\nimport { DateAdapter, MAT_DATE_FORMATS } from '@angular/material/core';\r\nimport { MatDatepickerModule } from '@angular/material/datepicker';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatInputModule } from '@angular/material/input';\r\nimport { MasterControlService } from '../master-control.service';\r\n\r\n\r\nexport const MY_DATE_FORMAT = {\r\n  parse: {\r\n    dateInput: [\r\n      'DD-MM-YYYY',\r\n      'MM/DD/YYYY',\r\n      'YYYY/MM/DD',\r\n      'DD/MM/YYYY',\r\n      'DD MMM YYYY',\r\n      'DD MMMM YYYY',\r\n      'DD-MMM-YYYY'\r\n    ]\r\n  },\r\n  display: {\r\n    dateInput: 'DD-MMM-YYYY',\r\n    monthYearLabel: 'MMM YYYY',\r\n    dateA11yLabel: 'DD-MMM-YYYY',\r\n    monthYearA11yLabel: 'MMMM YYYY'\r\n  }\r\n};\r\n\r\n@Component({\r\n  selector: 'lib-dob',\r\n  standalone: true,\r\n  imports: [MatInputModule, MatFormFieldModule, CommonModule, MatDatepickerModule, MomentDateModule, ReactiveFormsModule],\r\n    providers: [\r\n      {\r\n        provide: NG_VALUE_ACCESSOR,\r\n        useExisting: DobComponent,\r\n        multi: true\r\n      },\r\n    {\r\n      provide: DateAdapter,\r\n      useClass: MomentDateAdapter,\r\n      deps: []\r\n    },\r\n    { provide: MAT_DATE_FORMATS, useValue: MY_DATE_FORMAT }\r\n  ],\r\n  templateUrl: './dob.component.html',\r\n  styleUrl: './dob.component.css',\r\n})\r\nexport class DobComponent implements ControlValueAccessor {\r\n  field: any = input.required<any>();\r\n  inputValue: any = null;\r\n  reactiveFormControlobject : any = input<any>();\r\n  @Output() blur = new EventEmitter<any>();\r\n  @Output() valueChange = new EventEmitter<any>();\r\n  @Output() dateSelected = new EventEmitter<any>();\r\n  @Output() invalidDate = new EventEmitter<any>();\r\n\r\n  constructor(public service : MasterControlService) {}\r\n\r\n  dateDivisionFormat(event: any) {\r\n  let evt = event.target;\r\n  if (evt.value.length > 2 && !evt.value.substr(2, 1).includes('-')) {\r\n  evt.value = [evt.value.slice(0, 2), '-', evt.value.slice(2)].join('');\r\n    } else if (\r\n      evt.value.length > 5 &&\r\n      Number(evt.value.substr(3, 2)) &&\r\n      !evt.value.substr(5, 1).includes('-')\r\n    ) {\r\n      evt.value = [evt.value.slice(0, 5), '-', evt.value.slice(5)].join('');\r\n    } else if (\r\n      evt.value.length > 6 &&\r\n      !Number(evt.value.substr(3, 2)) &&\r\n      !evt.value.substr(6, 1).includes('-')\r\n    ) {\r\n      evt.value = [evt.value.slice(0, 6), '-', evt.value.slice(6)].join('');\r\n    }\r\n  }\r\n\r\n\r\n\r\n\r\n\r\n  _onChange: any = (inputValue:any) => {};\r\n  _unTouched: any = () => {};\r\n\r\n  writeValue(obj: any): void{\r\n    this.inputValue=obj;\r\n  };\r\n  registerOnChange(fn: any): void{\r\n    this._onChange = fn;\r\n  };\r\n  registerOnTouched(fn: any): void{\r\n    this._unTouched = fn;\r\n  };\r\n  setDisabledState?(isDisabled: boolean): void{};\r\n\r\n  onInputChange(event: any): void {\r\n    this.inputValue = event.target.value;\r\n    this._onChange(this.inputValue);\r\n  }\r\n\r\n  onInputBlur(event? : any): void {\r\n    if (!this.service.checkIfValueIsEmpty(event.target.value)) {\r\n      if (isNaN(Date.parse(event.target.value))) {\r\n        event.target.value = '';\r\n      }\r\n    }\r\n    this._unTouched();\r\n    this.blur.emit(event);\r\n  }\r\n\r\n\r\n  // Handle datepicker selection\r\n  onDateChange(event: any): void {\r\n    if (event.value) {\r\n      const selectedDate = event.value;\r\n      this.inputValue = selectedDate;\r\n      this._onChange(this.inputValue);\r\n      \r\n      // Emit date selection event\r\n      this.dateSelected.emit({\r\n        formattedValue: this.inputValue,\r\n        dateObject: selectedDate,\r\n        isValid: true,\r\n        source: 'datepicker'\r\n      });\r\n      \r\n      this.valueChange.emit(this.inputValue);\r\n    }\r\n  }\r\n\r\n}\r\n","<label\r\n  *ngIf=\"field() && field()?.isVisible && field().isShowLabel\"\r\n  class=\"field-lable\"\r\n  >{{ field()?.label\r\n  }}<span style=\"color: red\" *ngIf=\"field() && field()?.validators?.isRequired\"\r\n    >*</span\r\n  ></label\r\n>\r\n<mat-form-field\r\n  class=\"w-100\"\r\n  appearance=\"outline\"\r\n  *ngIf=\"field() && field()?.isVisible\"\r\n  [ngStyle]=\"{\r\n    '--custom-border-color': field()?.controlStyle?.borderColor ,\r\n    '--custom-border-width': field()?.controlStyle?.borderWidth ,\r\n    '--custom-border-radius': field()?.controlStyle?.borderRadius ,\r\n    '--custom-border-color-focus': field()?.controlStyle?.focusBorderColor ,\r\n    '--custom-border-width-focus': field()?.controlStyle?.focusBorderWidth ,\r\n    '--custom-border-color-hover': field()?.controlStyle?.hoverBorderColor ,\r\n    '--custom-border-width-hover': field()?.controlStyle?.hoverBorderWidth ,\r\n    '--custom-border-color-error': field()?.controlStyle?.errorBorderColor ,\r\n    '--custom-border-width-error': field()?.controlStyle?.errorBorderWidth ,\r\n    '--custom-font-size': field()?.controlStyle?.fontSize ,\r\n    '--custom-font-weight': field()?.controlStyle?.fontWeight ,\r\n    '--custom-font-family': field()?.controlStyle?.fontFamily ,\r\n    '--custom-font-color': field()?.controlStyle?.color ,\r\n    '--custom-caret-color': field()?.controlStyle?.caretColor ,\r\n    '--custom-font-color-disabled' : field()?.controlStyle?.disableColor ,\r\n    '--custom-bg-color-disabled' : field()?.controlStyle?.disableBackground ,\r\n    '--custom-bg-color': field()?.controlStyle?.background ,\r\n     '--custom-bg-color-focus': field()?.controlStyle?.focusBackground ,\r\n    }\"\r\n>\r\n  @if(reactiveFormControlobject()) {\r\n  <input\r\n    matInput\r\n    autocomplete=\"none\"\r\n    type=\"text\"\r\n    [name]=\"field()?.fieldName\"\r\n    [id]=\"field()?.fieldName\"\r\n    [placeholder]=\"field()?.placeHolder || 'DD-MM-YYYY'\"\r\n    [required]=\"field()?.validators?.isRequired\"\r\n    [pattern]=\"field()?.validators?.pattern\"\r\n    [matDatepicker]=\"picker\"\r\n    (keyup)=\"dateDivisionFormat($event)\"\r\n    [min]=\"field()?.configData?.min\"\r\n    [max]=\"field()?.configData?.max\"\r\n    [disabled]=\"field()?.isDisable\"\r\n    (dateChange)=\"onDateChange($event)\"\r\n    (blur)=\"onInputBlur($event)\"\r\n    [value]=\"inputValue\"\r\n    [formControl]=\"reactiveFormControlobject()\"\r\n  />\r\n  }@else {\r\n  <input\r\n    matInput\r\n    autocomplete=\"none\"\r\n    type=\"text\"\r\n    [name]=\"field()?.fieldName\"\r\n    [id]=\"field()?.fieldName\"\r\n    [placeholder]=\"field()?.placeHolder\"\r\n    [required]=\"field()?.validators?.isRequired\"\r\n    [pattern]=\"field()?.validators?.pattern\"\r\n    [matDatepicker]=\"picker\"\r\n    (keyup)=\"dateDivisionFormat($event)\"\r\n    [min]=\"field()?.configData?.min\"\r\n    [max]=\"field()?.configData?.max\"\r\n    [disabled]=\"field()?.isDisable\"\r\n    (dateChange)=\"onDateChange($event)\"\r\n    (blur)=\"onInputBlur($event)\"\r\n    [value]=\"inputValue\"\r\n  />\r\n  }\r\n\r\n  <mat-datepicker-toggle matSuffix [for]=\"picker\">\r\n    <img\r\n      src=\"https://cdn.godigit.com/digitPlusAssets/retail-life-icon/svgicon/date_picker_icon.svg\"\r\n      style=\"width: 16px\"\r\n      matDatepickerToggleIcon\r\n    />\r\n  </mat-datepicker-toggle>\r\n  <mat-datepicker #picker></mat-datepicker>\r\n  <mat-error *ngIf=\"false\">\r\n    {{ field()?.validators?.isRequiredMessage }}\r\n  </mat-error>\r\n</mat-form-field>\r\n<div class=\"error-message\" *ngIf=\"false\">\r\n  {{ field()?.validators?.isRequiredMessage }}.\r\n</div>\r\n<div class=\"error-message\" *ngIf=\"field()?.configData?.isInvalid\">\r\n  {{ field()?.validators?.patternMessage }}.\r\n</div>\r\n"]}
|
|
@@ -43,7 +43,7 @@ export class ToggleComponent {
|
|
|
43
43
|
useExisting: forwardRef(() => ToggleComponent),
|
|
44
44
|
multi: true,
|
|
45
45
|
},
|
|
46
|
-
], ngImport: i0, template: "<div class=\"\" *ngIf=\"field() && field()?.isVisible && field().isShowLabel\" [ngStyle]=\"{\r\n '--custom-toggle-bg-color': field()?.controlStyle?.background,\r\n '--custom-toggle-border-color': field()?.controlStyle?.borderColor ,\r\n '--custom-toggle-border-width': field()?.controlStyle?.borderWidth ,\r\n '--custom-toggle-border-radius': field()?.controlStyle?.borderRadius,\r\n '--custom-toggle-width': field()?.controlStyle?.width,\r\n }\"\r\n class=\"card toggle-background mt-2\"\r\n >\r\n <div class=\"toggle_switch mt-2\">\r\n <div *ngIf=\"field().configData?.leftLabel\" [ngStyle]=\"{\r\n '--custom-toggle-font-size': field()?.controlStyle?.fontSize ,\r\n '--custom-toggle-font-weight': field()?.controlStyle?.fontWeight ,\r\n '--custom-toggle-font-family': field()?.controlStyle?.fontFamily ,\r\n '--custom-toggle-font-color': field()?.controlStyle?.color ,\r\n }\" class=\"toggle-text\">\r\n <div>{{field().configData?.leftLabel}}</div>\r\n </div>\r\n <div class=\"mt-1\">\r\n <label class=\"switch\">\r\n @if(reactiveFormControlobject()) {\r\n <input\r\n type=\"checkbox\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n [checked]=\"inputValue\"\r\n [disabled]=\"field()?.isDisable\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n [formControl]=\"reactiveFormControlobject()\"\r\n (change)=\"onToggleChange($event)\"\r\n />\r\n }@else {\r\n <input\r\n type=\"checkbox\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n [checked]=\"inputValue\"\r\n [disabled]=\"field()?.isDisable\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n (change)=\"onToggleChange($event)\"\r\n />\r\n }\r\n <span class=\"slider round\"></span>\r\n </label>\r\n </div>\r\n <div [ngStyle]=\"{\r\n '--custom-toggle-font-size': field()?.controlStyle?.fontSize ,\r\n '--custom-toggle-font-weight': field()?.controlStyle?.fontWeight ,\r\n '--custom-toggle-font-family': field()?.controlStyle?.fontFamily ,\r\n '--custom-toggle-font-color': field()?.controlStyle?.color ,\r\n }\" class=\"toggle-text mb-2\">\r\n <div>{{field()?.label}}</div>\r\n <div style=\"font-size: 10px; font-weight: 400;\" *ngIf=\"field().configData?.subLabel\">{{field()?.configData?.subLabel}} <img alt=\"\" [src]=\"field()?.imageUrl\" *ngIf=\"field()?.imageUrl\" /> </div>\r\n </div>\r\n </div>\r\n </div>\r\n", styles: ["*{font-family:mulish!important}::ng-deep .toggle-background{background-color:var(--custom-toggle-bg-color , #f5f5f5)!important;padding:2px 8px;width:var(--custom-toggle-width , 100%)!important;box-shadow:none}::ng-deep .toggle-background{border-color:var(--custom-toggle-border-color , transparent)!important;border-radius:var(--custom-toggle-border-radius , 4px)!important;border-width:var(--custom-toggle-border-width , 1px)!important}::ng-deep .toggle_switch{display:flex;align-items:
|
|
46
|
+
], ngImport: i0, template: "<div class=\"\" *ngIf=\"field() && field()?.isVisible && field().isShowLabel\" [ngStyle]=\"{\r\n '--custom-toggle-bg-color': field()?.controlStyle?.background,\r\n '--custom-toggle-border-color': field()?.controlStyle?.borderColor ,\r\n '--custom-toggle-border-width': field()?.controlStyle?.borderWidth ,\r\n '--custom-toggle-border-radius': field()?.controlStyle?.borderRadius,\r\n '--custom-toggle-width': field()?.controlStyle?.width,\r\n }\"\r\n class=\"card toggle-background mt-2\"\r\n >\r\n <div class=\"toggle_switch mt-2\">\r\n <div *ngIf=\"field().configData?.leftLabel\" [ngStyle]=\"{\r\n '--custom-toggle-font-size': field()?.controlStyle?.fontSize ,\r\n '--custom-toggle-font-weight': field()?.controlStyle?.fontWeight ,\r\n '--custom-toggle-font-family': field()?.controlStyle?.fontFamily ,\r\n '--custom-toggle-font-color': field()?.controlStyle?.color ,\r\n }\" class=\"toggle-text\">\r\n <div>{{field().configData?.leftLabel}}</div>\r\n </div>\r\n <div class=\"mt-1\">\r\n <label class=\"switch\">\r\n @if(reactiveFormControlobject()) {\r\n <input\r\n type=\"checkbox\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n [checked]=\"inputValue\"\r\n [disabled]=\"field()?.isDisable\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n [formControl]=\"reactiveFormControlobject()\"\r\n (change)=\"onToggleChange($event)\"\r\n />\r\n }@else {\r\n <input\r\n type=\"checkbox\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n [checked]=\"inputValue\"\r\n [disabled]=\"field()?.isDisable\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n (change)=\"onToggleChange($event)\"\r\n />\r\n }\r\n <span class=\"slider round\"></span>\r\n </label>\r\n </div>\r\n <div [ngStyle]=\"{\r\n '--custom-toggle-font-size': field()?.controlStyle?.fontSize ,\r\n '--custom-toggle-font-weight': field()?.controlStyle?.fontWeight ,\r\n '--custom-toggle-font-family': field()?.controlStyle?.fontFamily ,\r\n '--custom-toggle-font-color': field()?.controlStyle?.color ,\r\n }\" class=\"toggle-text mb-2\">\r\n <div>{{field()?.label}}</div>\r\n <div style=\"font-size: 10px; font-weight: 400;\" *ngIf=\"field().configData?.subLabel\">{{field()?.configData?.subLabel}} <img alt=\"\" [src]=\"field()?.imageUrl\" *ngIf=\"field()?.imageUrl\" /> </div>\r\n </div>\r\n </div>\r\n </div>\r\n", styles: ["*{font-family:mulish!important}::ng-deep .toggle-background{background-color:var(--custom-toggle-bg-color , #f5f5f5)!important;padding:2px 8px;width:var(--custom-toggle-width , 100%)!important;box-shadow:none}::ng-deep .toggle-background{border-color:var(--custom-toggle-border-color , transparent)!important;border-radius:var(--custom-toggle-border-radius , 4px)!important;border-width:var(--custom-toggle-border-width , 1px)!important}::ng-deep .toggle_switch{display:flex;align-items:stretch;gap:10px;font-size:17px;font-weight:400;font-family:Mulish;color:#444}::ng-deep .switch{position:relative;display:inline-block;width:34px;height:18px}::ng-deep .switch input{opacity:0;width:0;height:0}::ng-deep .slider{position:absolute;cursor:pointer;inset:0;background-color:#ddd;-webkit-transition:.4s;transition:.4s}::ng-deep .slider:before{position:absolute;content:\"\";height:11px;width:11px;left:4px;bottom:4px;background-color:#fff;-webkit-transition:.4s;transition:.4s}::ng-deep .slider.round{border-radius:34px}::ng-deep input:checked+.slider{background-color:#fb0}::ng-deep input:checked+.slider:before{-webkit-transform:translateX(16px);-ms-transform:translateX(16px);transform:translate(16px)}::ng-deep .slider.round:before{border-radius:50%}::ng-deep .remove-border{border:none!important;outline:none!important;box-shadow:none!important}::ng-deep .remove-border:focus-visible{border:none!important;outline:none!important;box-shadow:none!important}::ng-deep .mdc-checkbox__native-control:enabled:checked~.mdc-checkbox__background,.mdc-checkbox__native-control:enabled:indeterminate~.mdc-checkbox__background{border-color:#fb0!important;background-color:#fb0!important;border-radius:4px!important}::ng-deep .mdc-checkbox__checkmark{color:#fff!important}::ng-deep .mdc-checkbox__background{border:1px solid #dadada!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.CheckboxRequiredValidator, selector: "input[type=checkbox][required][formControlName],input[type=checkbox][required][formControl],input[type=checkbox][required][ngModel]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }] });
|
|
47
47
|
}
|
|
48
48
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ToggleComponent, decorators: [{
|
|
49
49
|
type: Component,
|
|
@@ -53,8 +53,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
53
53
|
useExisting: forwardRef(() => ToggleComponent),
|
|
54
54
|
multi: true,
|
|
55
55
|
},
|
|
56
|
-
], template: "<div class=\"\" *ngIf=\"field() && field()?.isVisible && field().isShowLabel\" [ngStyle]=\"{\r\n '--custom-toggle-bg-color': field()?.controlStyle?.background,\r\n '--custom-toggle-border-color': field()?.controlStyle?.borderColor ,\r\n '--custom-toggle-border-width': field()?.controlStyle?.borderWidth ,\r\n '--custom-toggle-border-radius': field()?.controlStyle?.borderRadius,\r\n '--custom-toggle-width': field()?.controlStyle?.width,\r\n }\"\r\n class=\"card toggle-background mt-2\"\r\n >\r\n <div class=\"toggle_switch mt-2\">\r\n <div *ngIf=\"field().configData?.leftLabel\" [ngStyle]=\"{\r\n '--custom-toggle-font-size': field()?.controlStyle?.fontSize ,\r\n '--custom-toggle-font-weight': field()?.controlStyle?.fontWeight ,\r\n '--custom-toggle-font-family': field()?.controlStyle?.fontFamily ,\r\n '--custom-toggle-font-color': field()?.controlStyle?.color ,\r\n }\" class=\"toggle-text\">\r\n <div>{{field().configData?.leftLabel}}</div>\r\n </div>\r\n <div class=\"mt-1\">\r\n <label class=\"switch\">\r\n @if(reactiveFormControlobject()) {\r\n <input\r\n type=\"checkbox\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n [checked]=\"inputValue\"\r\n [disabled]=\"field()?.isDisable\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n [formControl]=\"reactiveFormControlobject()\"\r\n (change)=\"onToggleChange($event)\"\r\n />\r\n }@else {\r\n <input\r\n type=\"checkbox\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n [checked]=\"inputValue\"\r\n [disabled]=\"field()?.isDisable\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n (change)=\"onToggleChange($event)\"\r\n />\r\n }\r\n <span class=\"slider round\"></span>\r\n </label>\r\n </div>\r\n <div [ngStyle]=\"{\r\n '--custom-toggle-font-size': field()?.controlStyle?.fontSize ,\r\n '--custom-toggle-font-weight': field()?.controlStyle?.fontWeight ,\r\n '--custom-toggle-font-family': field()?.controlStyle?.fontFamily ,\r\n '--custom-toggle-font-color': field()?.controlStyle?.color ,\r\n }\" class=\"toggle-text mb-2\">\r\n <div>{{field()?.label}}</div>\r\n <div style=\"font-size: 10px; font-weight: 400;\" *ngIf=\"field().configData?.subLabel\">{{field()?.configData?.subLabel}} <img alt=\"\" [src]=\"field()?.imageUrl\" *ngIf=\"field()?.imageUrl\" /> </div>\r\n </div>\r\n </div>\r\n </div>\r\n", styles: ["*{font-family:mulish!important}::ng-deep .toggle-background{background-color:var(--custom-toggle-bg-color , #f5f5f5)!important;padding:2px 8px;width:var(--custom-toggle-width , 100%)!important;box-shadow:none}::ng-deep .toggle-background{border-color:var(--custom-toggle-border-color , transparent)!important;border-radius:var(--custom-toggle-border-radius , 4px)!important;border-width:var(--custom-toggle-border-width , 1px)!important}::ng-deep .toggle_switch{display:flex;align-items:
|
|
56
|
+
], template: "<div class=\"\" *ngIf=\"field() && field()?.isVisible && field().isShowLabel\" [ngStyle]=\"{\r\n '--custom-toggle-bg-color': field()?.controlStyle?.background,\r\n '--custom-toggle-border-color': field()?.controlStyle?.borderColor ,\r\n '--custom-toggle-border-width': field()?.controlStyle?.borderWidth ,\r\n '--custom-toggle-border-radius': field()?.controlStyle?.borderRadius,\r\n '--custom-toggle-width': field()?.controlStyle?.width,\r\n }\"\r\n class=\"card toggle-background mt-2\"\r\n >\r\n <div class=\"toggle_switch mt-2\">\r\n <div *ngIf=\"field().configData?.leftLabel\" [ngStyle]=\"{\r\n '--custom-toggle-font-size': field()?.controlStyle?.fontSize ,\r\n '--custom-toggle-font-weight': field()?.controlStyle?.fontWeight ,\r\n '--custom-toggle-font-family': field()?.controlStyle?.fontFamily ,\r\n '--custom-toggle-font-color': field()?.controlStyle?.color ,\r\n }\" class=\"toggle-text\">\r\n <div>{{field().configData?.leftLabel}}</div>\r\n </div>\r\n <div class=\"mt-1\">\r\n <label class=\"switch\">\r\n @if(reactiveFormControlobject()) {\r\n <input\r\n type=\"checkbox\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n [checked]=\"inputValue\"\r\n [disabled]=\"field()?.isDisable\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n [formControl]=\"reactiveFormControlobject()\"\r\n (change)=\"onToggleChange($event)\"\r\n />\r\n }@else {\r\n <input\r\n type=\"checkbox\"\r\n [name]=\"field()?.fieldName\"\r\n [id]=\"field()?.fieldName\"\r\n [checked]=\"inputValue\"\r\n [disabled]=\"field()?.isDisable\"\r\n [required]=\"field()?.validators?.isRequired\"\r\n (change)=\"onToggleChange($event)\"\r\n />\r\n }\r\n <span class=\"slider round\"></span>\r\n </label>\r\n </div>\r\n <div [ngStyle]=\"{\r\n '--custom-toggle-font-size': field()?.controlStyle?.fontSize ,\r\n '--custom-toggle-font-weight': field()?.controlStyle?.fontWeight ,\r\n '--custom-toggle-font-family': field()?.controlStyle?.fontFamily ,\r\n '--custom-toggle-font-color': field()?.controlStyle?.color ,\r\n }\" class=\"toggle-text mb-2\">\r\n <div>{{field()?.label}}</div>\r\n <div style=\"font-size: 10px; font-weight: 400;\" *ngIf=\"field().configData?.subLabel\">{{field()?.configData?.subLabel}} <img alt=\"\" [src]=\"field()?.imageUrl\" *ngIf=\"field()?.imageUrl\" /> </div>\r\n </div>\r\n </div>\r\n </div>\r\n", styles: ["*{font-family:mulish!important}::ng-deep .toggle-background{background-color:var(--custom-toggle-bg-color , #f5f5f5)!important;padding:2px 8px;width:var(--custom-toggle-width , 100%)!important;box-shadow:none}::ng-deep .toggle-background{border-color:var(--custom-toggle-border-color , transparent)!important;border-radius:var(--custom-toggle-border-radius , 4px)!important;border-width:var(--custom-toggle-border-width , 1px)!important}::ng-deep .toggle_switch{display:flex;align-items:stretch;gap:10px;font-size:17px;font-weight:400;font-family:Mulish;color:#444}::ng-deep .switch{position:relative;display:inline-block;width:34px;height:18px}::ng-deep .switch input{opacity:0;width:0;height:0}::ng-deep .slider{position:absolute;cursor:pointer;inset:0;background-color:#ddd;-webkit-transition:.4s;transition:.4s}::ng-deep .slider:before{position:absolute;content:\"\";height:11px;width:11px;left:4px;bottom:4px;background-color:#fff;-webkit-transition:.4s;transition:.4s}::ng-deep .slider.round{border-radius:34px}::ng-deep input:checked+.slider{background-color:#fb0}::ng-deep input:checked+.slider:before{-webkit-transform:translateX(16px);-ms-transform:translateX(16px);transform:translate(16px)}::ng-deep .slider.round:before{border-radius:50%}::ng-deep .remove-border{border:none!important;outline:none!important;box-shadow:none!important}::ng-deep .remove-border:focus-visible{border:none!important;outline:none!important;box-shadow:none!important}::ng-deep .mdc-checkbox__native-control:enabled:checked~.mdc-checkbox__background,.mdc-checkbox__native-control:enabled:indeterminate~.mdc-checkbox__background{border-color:#fb0!important;background-color:#fb0!important;border-radius:4px!important}::ng-deep .mdc-checkbox__checkmark{color:#fff!important}::ng-deep .mdc-checkbox__background{border:1px solid #dadada!important}\n"] }]
|
|
57
57
|
}], ctorParameters: () => [{ type: i1.MasterControlService }], propDecorators: { change: [{
|
|
58
58
|
type: Output
|
|
59
59
|
}] } });
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toggle.component.js","sourceRoot":"","sources":["../../../../../projects/master-control/src/lib/toggle/toggle.component.ts","../../../../../projects/master-control/src/lib/toggle/toggle.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAC,YAAY,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAElF,OAAO,EAAwB,iBAAiB,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;;;;;AAgB9F,MAAM,OAAO,eAAe;IACP;IAAnB,YAAmB,aAAoC;QAApC,kBAAa,GAAb,aAAa,CAAuB;IAAE,CAAC;IAC1D,KAAK,GAAS,KAAK,CAAC,QAAQ,EAAO,CAAC;IACnC,UAAU,GAAQ,KAAK,CAAC;IACxB,yBAAyB,GAAS,KAAK,EAAO,CAAC;IAChD,SAAS,GAAQ,CAAC,UAAe,EAAE,EAAE,GAAE,CAAC,CAAC;IACzC,UAAU,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;IAE3B,mDAAmD;IACzC,MAAM,GAAG,IAAI,YAAY,EAAO,CAAC;IAE3C,UAAU,CAAC,GAAQ;QACjB,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC;IACxB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACvB,CAAC;IAED,gBAAgB,CAAE,UAAmB;QACnC,kCAAkC;IACpC,CAAC;IAED,cAAc,CAAC,KAAU;QACvB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC;QACvC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAChC,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,4CAA4C;QAC5C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACpC,CAAC;wGAjCU,eAAe;4FAAf,eAAe,+YARf;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,eAAe,CAAC;gBAC9C,KAAK,EAAE,IAAI;aACZ;SACF,0BCjBH,ksFAwDA,m2DDhDY,YAAY,uNAAE,mBAAmB;;4FAWhC,eAAe;kBAd3B,SAAS;+BACE,YAAY,cACV,IAAI,WACP,CAAC,YAAY,EAAE,mBAAmB,CAAC,aAGjC;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,gBAAgB,CAAC;4BAC9C,KAAK,EAAE,IAAI;yBACZ;qBACF;yFAWS,MAAM;sBAAf,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, input, Output,EventEmitter, forwardRef } from '@angular/core';\r\nimport { MasterControlService } from '../master-control.service';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'lib-toggle',\r\n  standalone: true,\r\n  imports: [CommonModule, ReactiveFormsModule],\r\n  templateUrl: './toggle.component.html',\r\n  styleUrl: './toggle.component.css',\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => ToggleComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class ToggleComponent implements ControlValueAccessor {\r\n  constructor(public masterService : MasterControlService){}\r\n  field : any = input.required<any>();\r\n   inputValue: any = false;\r\n   reactiveFormControlobject : any = input<any>();\r\n  _onChange: any = (inputValue: any) => {};\r\n  _onTouched: any = () => {};\r\n\r\n  // Declare Output event emitters here (class level)\r\n  @Output() change = new EventEmitter<any>();\r\n\r\n  writeValue(obj: any): void {\r\n    this.inputValue = obj;\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this._onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this._onTouched = fn;\r\n  }\r\n\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    // Handle disabled state if needed\r\n  }\r\n\r\n  onToggleChange(event: any): void {\r\n    this.inputValue = event.target.checked;\r\n    this._onChange(this.inputValue);\r\n    this._onTouched();\r\n    // Emit the change event to parent component\r\n    this.change.emit(this.inputValue);\r\n  }\r\n}\r\n","<div class=\"\" *ngIf=\"field() && field()?.isVisible && field().isShowLabel\" [ngStyle]=\"{\r\n  '--custom-toggle-bg-color': field()?.controlStyle?.background,\r\n  '--custom-toggle-border-color': field()?.controlStyle?.borderColor ,\r\n  '--custom-toggle-border-width': field()?.controlStyle?.borderWidth ,\r\n  '--custom-toggle-border-radius': field()?.controlStyle?.borderRadius,\r\n  '--custom-toggle-width': field()?.controlStyle?.width,\r\n  }\"\r\n  class=\"card toggle-background mt-2\"\r\n  >\r\n    <div class=\"toggle_switch mt-2\">\r\n      <div *ngIf=\"field().configData?.leftLabel\" [ngStyle]=\"{\r\n        '--custom-toggle-font-size': field()?.controlStyle?.fontSize ,\r\n        '--custom-toggle-font-weight': field()?.controlStyle?.fontWeight ,\r\n        '--custom-toggle-font-family': field()?.controlStyle?.fontFamily ,\r\n        '--custom-toggle-font-color': field()?.controlStyle?.color ,\r\n        }\" class=\"toggle-text\">\r\n        <div>{{field().configData?.leftLabel}}</div>\r\n      </div>\r\n      <div class=\"mt-1\">\r\n        <label class=\"switch\">\r\n          @if(reactiveFormControlobject()) {\r\n            <input\r\n              type=\"checkbox\"\r\n              [name]=\"field()?.fieldName\"\r\n              [id]=\"field()?.fieldName\"\r\n              [checked]=\"inputValue\"\r\n              [disabled]=\"field()?.isDisable\"\r\n              [required]=\"field()?.validators?.isRequired\"\r\n              [formControl]=\"reactiveFormControlobject()\"\r\n              (change)=\"onToggleChange($event)\"\r\n            />\r\n          }@else {\r\n            <input\r\n              type=\"checkbox\"\r\n              [name]=\"field()?.fieldName\"\r\n              [id]=\"field()?.fieldName\"\r\n              [checked]=\"inputValue\"\r\n              [disabled]=\"field()?.isDisable\"\r\n              [required]=\"field()?.validators?.isRequired\"\r\n              (change)=\"onToggleChange($event)\"\r\n            />\r\n          }\r\n          <span class=\"slider round\"></span>\r\n        </label>\r\n      </div>\r\n      <div [ngStyle]=\"{\r\n        '--custom-toggle-font-size': field()?.controlStyle?.fontSize ,\r\n        '--custom-toggle-font-weight': field()?.controlStyle?.fontWeight ,\r\n        '--custom-toggle-font-family': field()?.controlStyle?.fontFamily ,\r\n        '--custom-toggle-font-color': field()?.controlStyle?.color ,\r\n        }\" class=\"toggle-text mb-2\">\r\n        <div>{{field()?.label}}</div>\r\n        <div style=\"font-size: 10px; font-weight: 400;\" *ngIf=\"field().configData?.subLabel\">{{field()?.configData?.subLabel}} <img alt=\"\" [src]=\"field()?.imageUrl\" *ngIf=\"field()?.imageUrl\" /> </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n"]}
|