bpm-core 0.0.32 → 0.0.34
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/app/app.component.mjs +2 -2
- package/esm2022/lib/components/app-component-sections/faq-sidenav/faq-sidenav.component.mjs +1 -5
- package/esm2022/lib/components/app-component-sections/faqs/faqs.component.mjs +4 -9
- package/esm2022/lib/components/app-component-sections/form-section/form-section.component.mjs +140 -72
- package/esm2022/lib/components/app-component-sections/index.mjs +1 -2
- package/esm2022/lib/components/app-component-sections/main-request-details/main-request-details.component.mjs +5 -7
- package/esm2022/lib/components/app-component-sections/previous-requests/previous-requests.component.mjs +67 -0
- package/esm2022/lib/components/app-component-sections/service-header/service-header.component.mjs +158 -68
- package/esm2022/lib/components/shared-components/form-field/control-value-accessor.directive.mjs +5 -6
- package/esm2022/lib/components/shared-components/form-field/custom-searchable-autocomplete/custom-searchable.component.mjs +3 -3
- package/esm2022/lib/components/shared-components/form-field/date-picker/date-picker.component.mjs +8 -46
- package/esm2022/lib/components/shared-components/form-field/date-range-picker/date-range-picker.component.mjs +161 -14
- package/esm2022/lib/components/shared-components/form-field/input/input.component.mjs +10 -12
- package/esm2022/lib/components/shared-components/form-field/input-currency/input-currency.component.mjs +11 -4
- package/esm2022/lib/components/shared-components/form-field/input-email/input-email.component.mjs +12 -4
- package/esm2022/lib/components/shared-components/form-field/input-mask/input-mask.component.mjs +3 -3
- package/esm2022/lib/components/shared-components/form-field/input-number/input-number.component.mjs +9 -5
- package/esm2022/lib/components/shared-components/form-field/validation-errors/validation-errors.component.mjs +5 -1
- package/esm2022/lib/{validators → directives}/ar.directive.mjs +4 -3
- package/esm2022/lib/{validators → directives}/currency.directive.mjs +4 -3
- package/esm2022/lib/{validators → directives}/en.directive.mjs +4 -3
- package/esm2022/lib/directives/number.directive.mjs +68 -0
- package/esm2022/lib/i18n/ar.mjs +4 -2
- package/esm2022/lib/i18n/en.mjs +3 -1
- package/esm2022/lib/pipes/status-style.pipe.mjs +57 -0
- package/esm2022/lib/regex/regex-patterns.mjs +4 -0
- package/esm2022/lib/services/core.service.ts.mjs +37 -9
- package/esm2022/lib/testComponent/general-approver-section/general-approver-section.component.mjs +2 -2
- package/esm2022/lib/testComponent/request-details-section/request-details-section.component.mjs +13 -6
- package/esm2022/lib/validators/index.mjs +4 -4
- package/fesm2022/bpm-core.mjs +1007 -592
- package/fesm2022/bpm-core.mjs.map +1 -1
- package/lib/components/app-component-sections/faq-sidenav/faq-sidenav.component.d.ts +2 -4
- package/lib/components/app-component-sections/faqs/faqs.component.d.ts +1 -3
- package/lib/components/app-component-sections/form-section/form-section.component.d.ts +92 -7
- package/lib/components/app-component-sections/index.d.ts +0 -1
- package/lib/components/app-component-sections/previous-requests/previous-requests.component.d.ts +22 -0
- package/lib/components/app-component-sections/service-header/service-header.component.d.ts +98 -7
- package/lib/components/shared-components/form-field/control-value-accessor.directive.d.ts +2 -1
- package/lib/components/shared-components/form-field/date-picker/date-picker.component.d.ts +0 -4
- package/lib/components/shared-components/form-field/date-range-picker/date-range-picker.component.d.ts +22 -6
- package/lib/components/shared-components/form-field/input/input.component.d.ts +1 -3
- package/lib/components/shared-components/form-field/input-email/input-email.component.d.ts +1 -0
- package/lib/{validators → directives}/ar.directive.d.ts +1 -1
- package/lib/{validators → directives}/currency.directive.d.ts +1 -1
- package/lib/{validators → directives}/en.directive.d.ts +1 -1
- package/lib/directives/number.directive.d.ts +14 -0
- package/lib/i18n/ar.d.ts +2 -0
- package/lib/i18n/en.d.ts +2 -0
- package/lib/pipes/status-style.pipe.d.ts +7 -0
- package/lib/regex/regex-patterns.d.ts +3 -0
- package/lib/services/core.service.ts.d.ts +2 -0
- package/lib/validators/index.d.ts +0 -3
- package/package.json +1 -1
- package/src/lib/assets/scss/_custom-popover.scss +3 -0
- package/src/lib/assets/scss/_settings.scss +5 -2
- package/esm2022/lib/components/app-component-sections/comment-section/comment-section.component.mjs +0 -66
- package/lib/components/app-component-sections/comment-section/comment-section.component.d.ts +0 -19
|
@@ -1,26 +1,173 @@
|
|
|
1
1
|
/* eslint-disable @angular-eslint/component-selector */
|
|
2
2
|
/* eslint-disable @typescript-eslint/no-empty-function */
|
|
3
|
-
import { Component, CUSTOM_ELEMENTS_SCHEMA, Input } from '@angular/core';
|
|
3
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA, forwardRef, Inject, Input, ViewChild } from '@angular/core';
|
|
4
|
+
import { ControlValueAccessorDirective } from '../control-value-accessor.directive';
|
|
5
|
+
import { FormControl, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
|
|
6
|
+
import { MatFormField, MatFormFieldModule } from '@angular/material/form-field';
|
|
7
|
+
import { MatDatepicker, MatDatepickerInput, MatDatepickerModule, MatDatepickerToggle } from '@angular/material/datepicker';
|
|
8
|
+
import { MatInput } from '@angular/material/input';
|
|
9
|
+
import { MatIcon } from '@angular/material/icon';
|
|
10
|
+
import { NgClass, NgIf } from '@angular/common';
|
|
11
|
+
import { InfoItemComponent } from '../info-item/info-item.component';
|
|
12
|
+
import { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';
|
|
13
|
+
import { MAT_MOMENT_DATE_ADAPTER_OPTIONS, MomentDateAdapter } from '@angular/material-moment-adapter';
|
|
14
|
+
import { CustomDateFormat } from '../date-picker/date-format';
|
|
15
|
+
import * as moment from 'moment';
|
|
16
|
+
import { ValidationErrorsComponent } from '../validation-errors/validation-errors.component';
|
|
4
17
|
import * as i0 from "@angular/core";
|
|
5
|
-
|
|
6
|
-
|
|
18
|
+
import * as i1 from "@angular/material/form-field";
|
|
19
|
+
import * as i2 from "@angular/material/datepicker";
|
|
20
|
+
import * as i3 from "@angular/forms";
|
|
21
|
+
const YEAR_ONLY_FORMAT = {
|
|
22
|
+
parse: {
|
|
23
|
+
dateInput: 'YYYY',
|
|
24
|
+
},
|
|
25
|
+
display: {
|
|
26
|
+
dateInput: 'YYYY',
|
|
27
|
+
monthYearLabel: 'YYYY',
|
|
28
|
+
dateA11yLabel: 'LL',
|
|
29
|
+
monthYearA11yLabel: 'YYYY',
|
|
30
|
+
},
|
|
31
|
+
};
|
|
32
|
+
export class DateRangePickerComponent extends ControlValueAccessorDirective {
|
|
7
33
|
tooltip;
|
|
8
|
-
className = '
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
34
|
+
className = 'white-input';
|
|
35
|
+
yearOnly;
|
|
36
|
+
dateFormat;
|
|
37
|
+
datepicker;
|
|
38
|
+
startControl = new FormControl();
|
|
39
|
+
endControl = new FormControl();
|
|
40
|
+
startInputValue;
|
|
41
|
+
endInputValue;
|
|
42
|
+
dateRange;
|
|
43
|
+
ngAfterViewInit() {
|
|
44
|
+
if (!this.isReadOnly && this.yearOnly)
|
|
45
|
+
this.activateYearOnlyMode();
|
|
46
|
+
}
|
|
47
|
+
ngOnChanges(changes) {
|
|
48
|
+
if (changes) {
|
|
49
|
+
if (this.customMaxDate) {
|
|
50
|
+
const date = new Date(this.customMaxDate);
|
|
51
|
+
this.maxDateValue = new Date(date.getFullYear(), date.getMonth(), date.getDate());
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
if (changes && !this.isReadOnly) { // add min date value for 2 dates validations
|
|
55
|
+
if (this.customMinDate) {
|
|
56
|
+
const date = new Date(this.customMinDate);
|
|
57
|
+
this.minDateValue = new Date(date.getFullYear(), date.getMonth(), date.getDate() + 1);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
focusPicker(picker) {
|
|
62
|
+
picker.open();
|
|
63
|
+
}
|
|
64
|
+
dateChange(event) {
|
|
65
|
+
if (event?.value && !this.isDisabled) {
|
|
66
|
+
let inputValue;
|
|
67
|
+
if (this.startControl.value && !this.endControl.value) {
|
|
68
|
+
this.startInputValue = moment(event.value).locale('en-US').format("YYYY-MM-DDTHH:mm:ss.SSSZ");
|
|
69
|
+
}
|
|
70
|
+
if (this.startControl.value && this.endControl.value) {
|
|
71
|
+
this.endInputValue = moment(event.value).locale('en-US').format("YYYY-MM-DDTHH:mm:ss.SSSZ");
|
|
72
|
+
}
|
|
73
|
+
if (this.endInputValue && this.startInputValue) {
|
|
74
|
+
this.dateRange = {
|
|
75
|
+
startDate: this.startInputValue,
|
|
76
|
+
endDate: this.endInputValue
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
inputValue = moment(event.value).locale('en-US').format("YYYY-MM-DDTHH:mm:ss.SSSZ");
|
|
80
|
+
if (this.dateRange?.startDate && this.dateRange?.endDate) {
|
|
81
|
+
this.control.setValue(this.dateRange);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
clearDateValue(event) {
|
|
86
|
+
this.dateRange = null;
|
|
87
|
+
this.startInputValue = null;
|
|
88
|
+
this.endInputValue = null;
|
|
89
|
+
this.control.setValue(null);
|
|
90
|
+
this.endControl.setValue(null);
|
|
91
|
+
this.startControl.setValue(null);
|
|
92
|
+
}
|
|
93
|
+
activateYearOnlyMode() {
|
|
94
|
+
this.dateFormat.updateDateFormat(YEAR_ONLY_FORMAT.parse, YEAR_ONLY_FORMAT.display);
|
|
95
|
+
if (this.control) {
|
|
96
|
+
this.control.setValue(moment(this.control.value).format('yyyy'));
|
|
97
|
+
}
|
|
98
|
+
this.datepicker.startView = 'multi-year';
|
|
99
|
+
this.datepicker.yearSelected.subscribe(e => {
|
|
100
|
+
this.control.setValue(moment(e).format('yyyy'));
|
|
101
|
+
this.datepicker.close();
|
|
102
|
+
});
|
|
103
|
+
this.datepicker.openedStream.subscribe(() => {
|
|
104
|
+
document.body.classList.add('year-only');
|
|
105
|
+
});
|
|
106
|
+
this.datepicker.closedStream.subscribe(() => {
|
|
107
|
+
document.body.classList.remove('year-only');
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: DateRangePickerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
111
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: DateRangePickerComponent, isStandalone: true, selector: "app-date-range-picker", inputs: { tooltip: "tooltip", className: "className", yearOnly: "yearOnly" }, providers: [
|
|
112
|
+
{
|
|
113
|
+
provide: NG_VALUE_ACCESSOR,
|
|
114
|
+
useExisting: forwardRef(() => DateRangePickerComponent),
|
|
115
|
+
multi: true,
|
|
116
|
+
},
|
|
117
|
+
{
|
|
118
|
+
provide: DateAdapter,
|
|
119
|
+
useClass: MomentDateAdapter,
|
|
120
|
+
deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],
|
|
121
|
+
},
|
|
122
|
+
{
|
|
123
|
+
provide: MAT_DATE_FORMATS,
|
|
124
|
+
useClass: CustomDateFormat
|
|
125
|
+
},
|
|
126
|
+
], viewQueries: [{ propertyName: "datepicker", first: true, predicate: MatDatepicker, descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "@if(label){\r\n <div class=\"d-flex justify-content-between mb-1\">\r\n <span class=\"form-label mb-0\">{{label}}</span>\r\n @if(!required){\r\n <span class=\"fs-11 fc-dark-gray\"> {{i18n.translate('optional')}} </span>\r\n }\r\n </div>\r\n}\r\n<mat-form-field class=\"date-range primary-form {{className}}\">\r\n <label class=\"mat-form-content\">\r\n <mat-date-range-input [rangePicker]=\"picker\">\r\n <input matStartDate placeholder=\"Start date\" [formControl]=\"startControl\" [value]=\"value?.startDate ? value?.startDate : null\" (dateInput)=\"dateChange($event)\" (focus)=\"focusPicker(picker)\" [min]=\"minDateValue\"\r\n [max]=\"maxDateValue\">\r\n <input matEndDate placeholder=\"End date\" [formControl]=\"endControl\" [value]=\"value?.endDate ? value?.endDate : null\" (dateInput)=\"dateChange($event)\" (focus)=\"focusPicker(picker)\" [min]=\"minDateValue\"\r\n [max]=\"maxDateValue\">\r\n </mat-date-range-input>\r\n </label>\r\n @if(control?.value){\r\n <ds-icon matSuffix icon=\"close\" class=\"fc-onyx fs-10 mx-2 cursor-pointer\" (click)=\"clearDateValue($event)\"></ds-icon>\r\n }\r\n <mat-datepicker-toggle matSuffix [for]=\"picker\" [disableRipple]=\"true\">\r\n <i class=\"sfi sfi-calendar-o fc-onyx font-18\" matDatepickerToggleIcon></i>\r\n </mat-datepicker-toggle>\r\n <mat-date-range-picker #picker></mat-date-range-picker>\r\n</mat-form-field>\r\n<app-validation-errors [errors]=\"control.errors\"></app-validation-errors>\r\n", styles: [":host{flex-grow:1}\n"], dependencies: [{ kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i1.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i1.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i2.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "directive", type: i2.MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { kind: "component", type: i2.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i2.MatStartDate, selector: "input[matStartDate]", outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i2.MatEndDate, selector: "input[matEndDate]", outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i2.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: ValidationErrorsComponent, selector: "app-validation-errors", inputs: ["errors", "customErrorMessages"] }] });
|
|
13
127
|
}
|
|
14
128
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: DateRangePickerComponent, decorators: [{
|
|
15
129
|
type: Component,
|
|
16
|
-
args: [{ selector: 'app-date-range-picker', schemas: [CUSTOM_ELEMENTS_SCHEMA], standalone: true,
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
130
|
+
args: [{ selector: 'app-date-range-picker', schemas: [CUSTOM_ELEMENTS_SCHEMA], standalone: true, providers: [
|
|
131
|
+
{
|
|
132
|
+
provide: NG_VALUE_ACCESSOR,
|
|
133
|
+
useExisting: forwardRef(() => DateRangePickerComponent),
|
|
134
|
+
multi: true,
|
|
135
|
+
},
|
|
136
|
+
{
|
|
137
|
+
provide: DateAdapter,
|
|
138
|
+
useClass: MomentDateAdapter,
|
|
139
|
+
deps: [MAT_DATE_LOCALE, MAT_MOMENT_DATE_ADAPTER_OPTIONS],
|
|
140
|
+
},
|
|
141
|
+
{
|
|
142
|
+
provide: MAT_DATE_FORMATS,
|
|
143
|
+
useClass: CustomDateFormat
|
|
144
|
+
},
|
|
145
|
+
], imports: [
|
|
146
|
+
MatFormFieldModule,
|
|
147
|
+
MatDatepickerModule,
|
|
148
|
+
MatFormField,
|
|
149
|
+
MatInput,
|
|
150
|
+
MatIcon,
|
|
151
|
+
MatDatepickerToggle,
|
|
152
|
+
MatDatepicker,
|
|
153
|
+
MatDatepickerInput,
|
|
154
|
+
NgClass,
|
|
155
|
+
NgIf,
|
|
156
|
+
InfoItemComponent,
|
|
157
|
+
ReactiveFormsModule,
|
|
158
|
+
ValidationErrorsComponent
|
|
159
|
+
], template: "@if(label){\r\n <div class=\"d-flex justify-content-between mb-1\">\r\n <span class=\"form-label mb-0\">{{label}}</span>\r\n @if(!required){\r\n <span class=\"fs-11 fc-dark-gray\"> {{i18n.translate('optional')}} </span>\r\n }\r\n </div>\r\n}\r\n<mat-form-field class=\"date-range primary-form {{className}}\">\r\n <label class=\"mat-form-content\">\r\n <mat-date-range-input [rangePicker]=\"picker\">\r\n <input matStartDate placeholder=\"Start date\" [formControl]=\"startControl\" [value]=\"value?.startDate ? value?.startDate : null\" (dateInput)=\"dateChange($event)\" (focus)=\"focusPicker(picker)\" [min]=\"minDateValue\"\r\n [max]=\"maxDateValue\">\r\n <input matEndDate placeholder=\"End date\" [formControl]=\"endControl\" [value]=\"value?.endDate ? value?.endDate : null\" (dateInput)=\"dateChange($event)\" (focus)=\"focusPicker(picker)\" [min]=\"minDateValue\"\r\n [max]=\"maxDateValue\">\r\n </mat-date-range-input>\r\n </label>\r\n @if(control?.value){\r\n <ds-icon matSuffix icon=\"close\" class=\"fc-onyx fs-10 mx-2 cursor-pointer\" (click)=\"clearDateValue($event)\"></ds-icon>\r\n }\r\n <mat-datepicker-toggle matSuffix [for]=\"picker\" [disableRipple]=\"true\">\r\n <i class=\"sfi sfi-calendar-o fc-onyx font-18\" matDatepickerToggleIcon></i>\r\n </mat-datepicker-toggle>\r\n <mat-date-range-picker #picker></mat-date-range-picker>\r\n</mat-form-field>\r\n<app-validation-errors [errors]=\"control.errors\"></app-validation-errors>\r\n", styles: [":host{flex-grow:1}\n"] }]
|
|
160
|
+
}], propDecorators: { tooltip: [{
|
|
20
161
|
type: Input
|
|
21
162
|
}], className: [{
|
|
22
163
|
type: Input
|
|
23
|
-
}],
|
|
164
|
+
}], yearOnly: [{
|
|
24
165
|
type: Input
|
|
166
|
+
}], dateFormat: [{
|
|
167
|
+
type: Inject,
|
|
168
|
+
args: [MAT_DATE_FORMATS]
|
|
169
|
+
}], datepicker: [{
|
|
170
|
+
type: ViewChild,
|
|
171
|
+
args: [MatDatepicker]
|
|
25
172
|
}] } });
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1yYW5nZS1waWNrZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL3NoYXJlZC1jb21wb25lbnRzL2Zvcm0tZmllbGQvZGF0ZS1yYW5nZS1waWNrZXIvZGF0ZS1yYW5nZS1waWNrZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYnBtLWNvcmUvc3JjL2xpYi9jb21wb25lbnRzL3NoYXJlZC1jb21wb25lbnRzL2Zvcm0tZmllbGQvZGF0ZS1yYW5nZS1waWNrZXIvZGF0ZS1yYW5nZS1waWNrZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsdURBQXVEO0FBQ3ZELHlEQUF5RDtBQUN6RCxPQUFPLEVBQUMsU0FBUyxFQUFFLHNCQUFzQixFQUFFLEtBQUssRUFBQyxNQUFNLGVBQWUsQ0FBQzs7QUFVdkUsTUFBTSxPQUFPLHdCQUF3QjtJQUMxQixLQUFLLENBQVc7SUFDaEIsT0FBTyxDQUFXO0lBQ2xCLFNBQVMsR0FBRyxZQUFZLENBQUM7SUFDekIsV0FBVyxDQUFXO0lBQy9CLGdCQUFnQixDQUFDO3VHQUxOLHdCQUF3QjsyRkFBeEIsd0JBQXdCLHFMQ1pyQyxxbEJBWUE7OzJGREFhLHdCQUF3QjtrQkFScEMsU0FBUzsrQkFDRSx1QkFBdUIsV0FHeEIsQ0FBQyxzQkFBc0IsQ0FBQyxjQUNyQixJQUFJO3dEQUlQLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgQGFuZ3VsYXItZXNsaW50L2NvbXBvbmVudC1zZWxlY3RvciAqL1xyXG4vKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktZnVuY3Rpb24gKi9cclxuaW1wb3J0IHtDb21wb25lbnQsIENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIElucHV0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXBwLWRhdGUtcmFuZ2UtcGlja2VyJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZGF0ZS1yYW5nZS1waWNrZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2RhdGUtcmFuZ2UtcGlja2VyLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgc2NoZW1hczogW0NVU1RPTV9FTEVNRU5UU19TQ0hFTUFdLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcblxyXG59KVxyXG5leHBvcnQgY2xhc3MgRGF0ZVJhbmdlUGlja2VyQ29tcG9uZW50ICB7XHJcbiAgQElucHV0KCkgbGFiZWwhIDogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIHRvb2x0aXAhIDogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIGNsYXNzTmFtZSA9ICdncmF5LWlucHV0JztcclxuICBASW5wdXQoKSBwbGFjZWhvbGRlciEgOiBzdHJpbmc7XHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgXHJcblxyXG59XHJcbiIsIjxtYXQtZm9ybS1maWVsZCBjbGFzcz1cImRhdGUtcmFuZ2UgcHJpbWFyeS1mb3JtIHt7Y2xhc3NOYW1lfX1cIj5cclxuICA8bGFiZWwgY2xhc3M9XCJtYXQtZm9ybS1jb250ZW50XCI+XHJcbiAgICA8bWF0LWRhdGUtcmFuZ2UtaW5wdXQgW3JhbmdlUGlja2VyXT1cInBpY2tlclwiPlxyXG4gICAgICA8aW5wdXQgbWF0U3RhcnREYXRlIHBsYWNlaG9sZGVyPVwiU3RhcnQgZGF0ZVwiPlxyXG4gICAgICA8aW5wdXQgbWF0RW5kRGF0ZSBwbGFjZWhvbGRlcj1cIkVuZCBkYXRlXCI+XHJcbiAgICA8L21hdC1kYXRlLXJhbmdlLWlucHV0PlxyXG4gIDwvbGFiZWw+XHJcbiAgPG1hdC1kYXRlcGlja2VyLXRvZ2dsZSBtYXRTdWZmaXggW2Zvcl09XCJwaWNrZXJcIiBbZGlzYWJsZVJpcHBsZV09XCJ0cnVlXCI+XHJcbiAgICA8aSBjbGFzcz1cInNmaSBzZmktY2FsZW5kYXItbyBmYy1vbnl4IGZvbnQtMThcIiBtYXREYXRlcGlja2VyVG9nZ2xlSWNvbj48L2k+XHJcbiAgPC9tYXQtZGF0ZXBpY2tlci10b2dnbGU+XHJcbiAgPG1hdC1kYXRlLXJhbmdlLXBpY2tlciAjcGlja2VyPjwvbWF0LWRhdGUtcmFuZ2UtcGlja2VyPlxyXG48L21hdC1mb3JtLWZpZWxkPlxyXG4iXX0=
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-picker.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/date-range-picker/date-range-picker.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/date-range-picker/date-range-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/component-selector */\r\n/* eslint-disable @typescript-eslint/no-empty-function */\r\nimport {Component, CUSTOM_ELEMENTS_SCHEMA, forwardRef, Inject, Input, ViewChild, SimpleChanges} from '@angular/core';\r\nimport { ControlValueAccessorDirective } from '../control-value-accessor.directive';\r\nimport { FormControl, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\r\nimport { MatFormField, MatFormFieldModule } from '@angular/material/form-field';\r\nimport { MatDatepicker, MatDatepickerInput, MatDatepickerModule, MatDatepickerToggle } from '@angular/material/datepicker';\r\nimport { MatInput } from '@angular/material/input';\r\nimport { MatIcon } from '@angular/material/icon';\r\nimport { NgClass, NgIf } from '@angular/common';\r\nimport { InfoItemComponent } from '../info-item/info-item.component';\r\nimport { DateAdapter, MAT_DATE_FORMATS, MAT_DATE_LOCALE } from '@angular/material/core';\r\nimport { MAT_MOMENT_DATE_ADAPTER_OPTIONS, MomentDateAdapter } from '@angular/material-moment-adapter';\r\nimport { CustomDateFormat } from '../date-picker/date-format';\r\nimport * as moment from 'moment';\r\nimport { ValidationErrorsComponent } from '../validation-errors/validation-errors.component';\r\nconst YEAR_ONLY_FORMAT = {\r\n  parse: {\r\n    dateInput: 'YYYY',\r\n  },\r\n  display: {\r\n    dateInput: 'YYYY',\r\n    monthYearLabel: 'YYYY',\r\n    dateA11yLabel: 'LL',\r\n    monthYearA11yLabel: 'YYYY',\r\n  },\r\n};\r\n\r\n\r\n@Component({\r\n  selector: 'app-date-range-picker',\r\n  templateUrl: './date-range-picker.component.html',\r\n  styleUrls: ['./date-range-picker.component.scss'],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  standalone: true,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => DateRangePickerComponent),\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    {\r\n      provide: MAT_DATE_FORMATS,\r\n      useClass: CustomDateFormat\r\n    },\r\n  ],\r\n  imports: [\r\n    MatFormFieldModule,\r\n    MatDatepickerModule,\r\n    MatFormField,\r\n    MatInput,\r\n    MatIcon,\r\n    MatDatepickerToggle,\r\n    MatDatepicker,\r\n    MatDatepickerInput,\r\n    NgClass,\r\n    NgIf,\r\n    InfoItemComponent,\r\n    ReactiveFormsModule,\r\n    ValidationErrorsComponent\r\n  ]\r\n\r\n})\r\nexport class DateRangePickerComponent<Type> extends ControlValueAccessorDirective<Type>  {\r\n  @Input() tooltip! : string;\r\n  @Input() className = 'white-input';\r\n  @Input() yearOnly: boolean;\r\n  @Inject(MAT_DATE_FORMATS) public dateFormat: CustomDateFormat;\r\n  @ViewChild(MatDatepicker) datepicker: MatDatepicker<any>;\r\n  startControl = new FormControl()\r\n  endControl = new FormControl();\r\n  startInputValue:string\r\n  endInputValue:string\r\n  dateRange:any\r\n\r\n\r\n\r\n  ngAfterViewInit(): void {\r\n    if (!this.isReadOnly && this.yearOnly) this.activateYearOnlyMode();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes) {\r\n      if (this.customMaxDate) {\r\n        const date = new Date(this.customMaxDate);\r\n        this.maxDateValue = new Date(date.getFullYear(), date.getMonth(), date.getDate());\r\n      }\r\n    }\r\n    if (changes && !this.isReadOnly) { // add min date value for 2 dates validations\r\n      if (this.customMinDate) {\r\n        const date = new Date(this.customMinDate);\r\n        this.minDateValue = new Date(date.getFullYear(), date.getMonth(), date.getDate() + 1);\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n  focusPicker(picker) {\r\n    picker.open();\r\n  }\r\n\r\n  dateChange(event: any) {\r\n      if (event?.value && !this.isDisabled) {\r\n          let inputValue\r\n          if (this.startControl.value && !this.endControl.value){\r\n            this.startInputValue = moment(event.value).locale('en-US').format(\"YYYY-MM-DDTHH:mm:ss.SSSZ\")\r\n          }\r\n          if(this.startControl.value && this.endControl.value){\r\n            this.endInputValue = moment(event.value).locale('en-US').format(\"YYYY-MM-DDTHH:mm:ss.SSSZ\")\r\n          }\r\n\r\n          if(this.endInputValue && this.startInputValue){\r\n            this.dateRange = {\r\n              startDate: this.startInputValue,\r\n              endDate: this.endInputValue\r\n            }\r\n          }\r\n\r\n          inputValue = moment(event.value).locale('en-US').format(\"YYYY-MM-DDTHH:mm:ss.SSSZ\");\r\n          if (this.dateRange?.startDate && this.dateRange?.endDate){\r\n            this.control.setValue(this.dateRange)\r\n          }\r\n      }\r\n  }\r\n\r\n  clearDateValue(event): void {\r\n    this.dateRange = null;\r\n    this.startInputValue = null;\r\n    this.endInputValue = null;\r\n    this.control.setValue(null);\r\n    this.endControl.setValue(null);\r\n    this.startControl.setValue(null);\r\n  }\r\n\r\n  private activateYearOnlyMode(): void {\r\n    this.dateFormat.updateDateFormat(YEAR_ONLY_FORMAT.parse, YEAR_ONLY_FORMAT.display);\r\n    if (this.control) {\r\n      this.control.setValue(moment(this.control.value).format('yyyy'));\r\n    }\r\n    this.datepicker.startView = 'multi-year';\r\n    this.datepicker.yearSelected.subscribe(e => {\r\n      this.control.setValue(moment(e).format('yyyy'));\r\n      this.datepicker.close();\r\n    })\r\n    this.datepicker.openedStream.subscribe(() => {\r\n      document.body.classList.add('year-only');\r\n    })\r\n    this.datepicker.closedStream.subscribe(() => {\r\n      document.body.classList.remove('year-only');\r\n    })\r\n  }\r\n}\r\n","@if(label){\r\n  <div class=\"d-flex justify-content-between mb-1\">\r\n    <span class=\"form-label mb-0\">{{label}}</span>\r\n    @if(!required){\r\n    <span class=\"fs-11 fc-dark-gray\"> {{i18n.translate('optional')}} </span>\r\n    }\r\n  </div>\r\n}\r\n<mat-form-field class=\"date-range primary-form {{className}}\">\r\n  <label class=\"mat-form-content\">\r\n    <mat-date-range-input [rangePicker]=\"picker\">\r\n      <input matStartDate placeholder=\"Start date\" [formControl]=\"startControl\" [value]=\"value?.startDate ? value?.startDate : null\" (dateInput)=\"dateChange($event)\" (focus)=\"focusPicker(picker)\" [min]=\"minDateValue\"\r\n      [max]=\"maxDateValue\">\r\n      <input matEndDate placeholder=\"End date\" [formControl]=\"endControl\" [value]=\"value?.endDate ? value?.endDate : null\" (dateInput)=\"dateChange($event)\" (focus)=\"focusPicker(picker)\" [min]=\"minDateValue\"\r\n      [max]=\"maxDateValue\">\r\n    </mat-date-range-input>\r\n  </label>\r\n  @if(control?.value){\r\n    <ds-icon matSuffix icon=\"close\" class=\"fc-onyx fs-10 mx-2 cursor-pointer\" (click)=\"clearDateValue($event)\"></ds-icon>\r\n    }\r\n  <mat-datepicker-toggle matSuffix [for]=\"picker\" [disableRipple]=\"true\">\r\n    <i class=\"sfi sfi-calendar-o fc-onyx font-18\" matDatepickerToggleIcon></i>\r\n  </mat-datepicker-toggle>\r\n  <mat-date-range-picker #picker></mat-date-range-picker>\r\n</mat-form-field>\r\n<app-validation-errors [errors]=\"control.errors\"></app-validation-errors>\r\n"]}
|
|
@@ -10,26 +10,26 @@ import { InfoItemComponent } from "../info-item/info-item.component";
|
|
|
10
10
|
import { MatInput } from "@angular/material/input";
|
|
11
11
|
import { ControlValueAccessorDirective } from '../control-value-accessor.directive';
|
|
12
12
|
import { ValidationErrorsComponent } from '../validation-errors/validation-errors.component';
|
|
13
|
+
import { EnOnlyDirective } from "../../../../directives/en.directive";
|
|
14
|
+
import { ArOnlyDirective } from "../../../../directives/ar.directive";
|
|
13
15
|
import * as i0 from "@angular/core";
|
|
14
16
|
import * as i1 from "@ncstate/sat-popover";
|
|
15
17
|
import * as i2 from "@angular/forms";
|
|
16
18
|
export class InputComponent extends ControlValueAccessorDirective {
|
|
17
|
-
hasTooltip = false;
|
|
18
19
|
tooltip;
|
|
19
20
|
floatLabel = 'auto';
|
|
20
21
|
className = 'bordered-input';
|
|
21
|
-
showLabel = true;
|
|
22
22
|
iconPrefixName;
|
|
23
23
|
iconSuffixName;
|
|
24
24
|
emitedChangedValue1 = new EventEmitter();
|
|
25
25
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: InputComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
26
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: InputComponent, isStandalone: true, selector: "app-input", inputs: {
|
|
26
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: InputComponent, isStandalone: true, selector: "app-input", inputs: { tooltip: "tooltip", floatLabel: "floatLabel", className: "className", iconPrefixName: "iconPrefixName", iconSuffixName: "iconSuffixName", emitedChangedValue1: "emitedChangedValue1" }, providers: [
|
|
27
27
|
{
|
|
28
28
|
provide: NG_VALUE_ACCESSOR,
|
|
29
29
|
useExisting: forwardRef(() => InputComponent),
|
|
30
30
|
multi: true,
|
|
31
31
|
},
|
|
32
|
-
], usesInheritance: true, ngImport: i0, template: "@if(!isReadOnly){\r\n
|
|
32
|
+
], usesInheritance: true, ngImport: i0, template: "@if(!isReadOnly){\r\n@if(label){\r\n<div class=\"d-flex justify-content-between mb-1\">\r\n <span class=\"form-label mb-0\">{{ label }}</span\r\n > @if(!required){<span class=\"fs-11 fc-dark-gray\">{{\r\n i18n.translate(\"Optional\")\r\n }}</span\r\n >} @if(hasTooltip){\r\n <span class=\"form-label mb-0\">\r\n {{ tooltip }}\r\n <ds-icon\r\n icon=\"info fs-22\"\r\n class=\"cursor-pointer\"\r\n [satPopoverAnchor]=\"popover\"\r\n (click)=\"popover.toggle(); $event.stopImmediatePropagation()\"\r\n ></ds-icon>\r\n </span>\r\n }\r\n</div>\r\n}\r\n<mat-form-field\r\n class=\"primary-form {{ className }}\"\r\n [ngClass]=\"{ 'input-disabled': control.disabled }\"\r\n [floatLabel]=\"floatLabel\"\r\n>\r\n @if(iconPrefixName){<span class=\"sfi {{ iconPrefixName }}\"></span>}\r\n <label class=\"mat-form-content\">\r\n <!-- add input for ar && en custom directive with add type = arOnly || type = enOnly-->\r\n @if(type === 'arOnly'){\r\n <input\r\n arOnly\r\n matInput\r\n [value]=\"value\"\r\n oninput=\"validity.valid || (value='');\"\r\n [formControl]=\"control\"\r\n [required]=\"required\"\r\n [placeholder]=\"placeholder\"\r\n />\r\n } @else if(type === 'enOnly'){\r\n <input\r\n enOnly\r\n matInput\r\n [value]=\"value\"\r\n oninput=\"validity.valid || (value='');\"\r\n [formControl]=\"control\"\r\n [required]=\"required\"\r\n [placeholder]=\"placeholder\"\r\n />\r\n }\r\n @else{\r\n <input\r\n matInput\r\n [value]=\"value\"\r\n oninput=\"validity.valid || (value='');\"\r\n [formControl]=\"control\"\r\n [type]=\"type\"\r\n [placeholder]=\"placeholder\"\r\n />\r\n }\r\n </label>\r\n \r\n @if(iconSuffixName){<span matSuffix class=\"sfi {{ iconSuffixName }}\"></span>}\r\n @if(hint){\r\n <mat-hint class=\"d-flex align-items-center gap-1 mt-1\">\r\n <span\r\n class=\"sfi sfi-info fs-17 fc-dark-gray\"\r\n [ngClass]=\"{ 'fc-oasis-light-imp': value }\"\r\n ></span>\r\n <span class=\"fs-12 fc-black line-height-1\">{{ hint }}</span>\r\n </mat-hint>\r\n }\r\n</mat-form-field>\r\n<app-validation-errors [errors]=\"control.errors\"></app-validation-errors>\r\n\r\n} @if(isReadOnly && (showIfEmpty || control)){\r\n<ng-container class=\"info-section\">\r\n <app-info-item\r\n class=\"info-item w-100\"\r\n [label]=\"label\"\r\n [insideTable]=\"insideTable\"\r\n [hasLabel]=\"!!label\"\r\n [type]=\"type\"\r\n [value]=\"control.value\"\r\n ></app-info-item>\r\n</ng-container>\r\n}\r\n\r\n<sat-popover #popover [hasBackdrop]=\"true\" verticalAlign=\"below\">\r\n <div class=\"default-popover p-3 fs-14\">\r\n <span class=\"fs-14 fw-bold signature-notes\" [innerHTML]=\"tooltip\"></span>\r\n </div>\r\n</sat-popover>\r\n", styles: [":host{flex-grow:1}.input-disabled{pointer-events:none;opacity:1.5}\n"], dependencies: [{ kind: "ngmodule", type: SatPopoverModule }, { kind: "component", type: i1.SatPopoverComponent, selector: "sat-popover", inputs: ["anchor", "horizontalAlign", "xAlign", "verticalAlign", "yAlign", "forceAlignment", "lockAlignment", "autoFocus", "restoreFocus", "scrollStrategy", "hasBackdrop", "interactiveClose", "openTransition", "closeTransition", "openAnimationStartAtScale", "closeAnimationEndAtScale", "backdropClass", "panelClass"], outputs: ["opened", "closed", "afterOpen", "afterClose", "backdropClicked", "overlayKeydown"] }, { kind: "directive", type: i1.SatPopoverAnchorDirective, selector: "[satPopoverAnchor]", inputs: ["satPopoverAnchor"], exportAs: ["satPopoverAnchor"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: InfoItemComponent, selector: "app-info-item", inputs: ["label", "value", "name", "type", "dateType", "multiple", "insideTable", "hasLabel", "arrayList", "actionType", "download"] }, { kind: "component", type: MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: 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: ValidationErrorsComponent, selector: "app-validation-errors", inputs: ["errors", "customErrorMessages"] }, { kind: "directive", type: EnOnlyDirective, selector: "[enOnly]" }, { kind: "directive", type: ArOnlyDirective, selector: "[arOnly]" }] });
|
|
33
33
|
}
|
|
34
34
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: InputComponent, decorators: [{
|
|
35
35
|
type: Component,
|
|
@@ -43,24 +43,22 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
43
43
|
InfoItemComponent,
|
|
44
44
|
MatFormField,
|
|
45
45
|
MatInput,
|
|
46
|
-
ValidationErrorsComponent
|
|
46
|
+
ValidationErrorsComponent,
|
|
47
|
+
EnOnlyDirective,
|
|
48
|
+
ArOnlyDirective
|
|
47
49
|
], standalone: true, providers: [
|
|
48
50
|
{
|
|
49
51
|
provide: NG_VALUE_ACCESSOR,
|
|
50
52
|
useExisting: forwardRef(() => InputComponent),
|
|
51
53
|
multi: true,
|
|
52
54
|
},
|
|
53
|
-
], template: "@if(!isReadOnly){\r\n
|
|
54
|
-
}], propDecorators: {
|
|
55
|
-
type: Input
|
|
56
|
-
}], tooltip: [{
|
|
55
|
+
], template: "@if(!isReadOnly){\r\n@if(label){\r\n<div class=\"d-flex justify-content-between mb-1\">\r\n <span class=\"form-label mb-0\">{{ label }}</span\r\n > @if(!required){<span class=\"fs-11 fc-dark-gray\">{{\r\n i18n.translate(\"Optional\")\r\n }}</span\r\n >} @if(hasTooltip){\r\n <span class=\"form-label mb-0\">\r\n {{ tooltip }}\r\n <ds-icon\r\n icon=\"info fs-22\"\r\n class=\"cursor-pointer\"\r\n [satPopoverAnchor]=\"popover\"\r\n (click)=\"popover.toggle(); $event.stopImmediatePropagation()\"\r\n ></ds-icon>\r\n </span>\r\n }\r\n</div>\r\n}\r\n<mat-form-field\r\n class=\"primary-form {{ className }}\"\r\n [ngClass]=\"{ 'input-disabled': control.disabled }\"\r\n [floatLabel]=\"floatLabel\"\r\n>\r\n @if(iconPrefixName){<span class=\"sfi {{ iconPrefixName }}\"></span>}\r\n <label class=\"mat-form-content\">\r\n <!-- add input for ar && en custom directive with add type = arOnly || type = enOnly-->\r\n @if(type === 'arOnly'){\r\n <input\r\n arOnly\r\n matInput\r\n [value]=\"value\"\r\n oninput=\"validity.valid || (value='');\"\r\n [formControl]=\"control\"\r\n [required]=\"required\"\r\n [placeholder]=\"placeholder\"\r\n />\r\n } @else if(type === 'enOnly'){\r\n <input\r\n enOnly\r\n matInput\r\n [value]=\"value\"\r\n oninput=\"validity.valid || (value='');\"\r\n [formControl]=\"control\"\r\n [required]=\"required\"\r\n [placeholder]=\"placeholder\"\r\n />\r\n }\r\n @else{\r\n <input\r\n matInput\r\n [value]=\"value\"\r\n oninput=\"validity.valid || (value='');\"\r\n [formControl]=\"control\"\r\n [type]=\"type\"\r\n [placeholder]=\"placeholder\"\r\n />\r\n }\r\n </label>\r\n \r\n @if(iconSuffixName){<span matSuffix class=\"sfi {{ iconSuffixName }}\"></span>}\r\n @if(hint){\r\n <mat-hint class=\"d-flex align-items-center gap-1 mt-1\">\r\n <span\r\n class=\"sfi sfi-info fs-17 fc-dark-gray\"\r\n [ngClass]=\"{ 'fc-oasis-light-imp': value }\"\r\n ></span>\r\n <span class=\"fs-12 fc-black line-height-1\">{{ hint }}</span>\r\n </mat-hint>\r\n }\r\n</mat-form-field>\r\n<app-validation-errors [errors]=\"control.errors\"></app-validation-errors>\r\n\r\n} @if(isReadOnly && (showIfEmpty || control)){\r\n<ng-container class=\"info-section\">\r\n <app-info-item\r\n class=\"info-item w-100\"\r\n [label]=\"label\"\r\n [insideTable]=\"insideTable\"\r\n [hasLabel]=\"!!label\"\r\n [type]=\"type\"\r\n [value]=\"control.value\"\r\n ></app-info-item>\r\n</ng-container>\r\n}\r\n\r\n<sat-popover #popover [hasBackdrop]=\"true\" verticalAlign=\"below\">\r\n <div class=\"default-popover p-3 fs-14\">\r\n <span class=\"fs-14 fw-bold signature-notes\" [innerHTML]=\"tooltip\"></span>\r\n </div>\r\n</sat-popover>\r\n", styles: [":host{flex-grow:1}.input-disabled{pointer-events:none;opacity:1.5}\n"] }]
|
|
56
|
+
}], propDecorators: { tooltip: [{
|
|
57
57
|
type: Input
|
|
58
58
|
}], floatLabel: [{
|
|
59
59
|
type: Input
|
|
60
60
|
}], className: [{
|
|
61
61
|
type: Input
|
|
62
|
-
}], showLabel: [{
|
|
63
|
-
type: Input
|
|
64
62
|
}], iconPrefixName: [{
|
|
65
63
|
type: Input
|
|
66
64
|
}], iconSuffixName: [{
|
|
@@ -68,4 +66,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
68
66
|
}], emitedChangedValue1: [{
|
|
69
67
|
type: Input
|
|
70
68
|
}] } });
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/input/input.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/input/input.component.html"],"names":[],"mappings":"AAAA,4DAA4D;AAC5D,uDAAuD;AACvD,uDAAuD;AACvD,OAAO,EAAC,iBAAiB,EAAE,mBAAmB,EAAC,MAAM,gBAAgB,CAAC;AACtE,OAAO,EAAE,SAAS,EAAE,sBAAsB,EAAE,KAAK,EAAiB,YAAY,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAClH,OAAO,EAAC,QAAQ,EAAE,YAAY,EAAE,OAAO,EAAC,MAAM,8BAA8B,CAAC;AAC7E,OAAO,EAAC,gBAAgB,EAAC,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAC,OAAO,EAAE,IAAI,EAAC,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAC,iBAAiB,EAAC,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAC,QAAQ,EAAC,MAAM,yBAAyB,CAAC;AACjD,OAAO,EAAE,6BAA6B,EAAE,MAAM,qCAAqC,CAAC;AACpF,OAAO,EAAE,yBAAyB,EAAE,MAAM,kDAAkD,CAAC;;;;AA6B7F,MAAM,OAAO,cAAqB,SAAQ,6BAAmC;IAClE,UAAU,GAAG,KAAK,CAAC;IACnB,OAAO,CAAU;IACjB,UAAU,GAAQ,MAAM,CAAC;IACzB,SAAS,GAAG,gBAAgB,CAAC;IAC7B,SAAS,GAAG,IAAI,CAAC;IACjB,cAAc,CAAU;IACxB,cAAc,CAAU;IACxB,mBAAmB,GAAG,IAAI,YAAY,EAAE,CAAC;uGARvC,cAAc;2FAAd,cAAc,4SATd;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC;gBAC7C,KAAK,EAAE,IAAI;aACZ;SACF,iDCrCH,+4HAqIA,6HDlHI,gBAAgB,kqBAChB,mBAAmB,uyBAGnB,OAAO,8EACP,OAAO,oFACP,iBAAiB,gMACjB,YAAY,4LACZ,QAAQ,iUACR,yBAAyB;;2FAYhB,cAAc;kBA3B1B,SAAS;+BACE,WAAW,WAGZ,CAAC,sBAAsB,CAAC,WACxB;wBACP,gBAAgB;wBAChB,mBAAmB;wBACnB,IAAI;wBACJ,QAAQ;wBACR,OAAO;wBACP,OAAO;wBACP,iBAAiB;wBACjB,YAAY;wBACZ,QAAQ;wBACR,yBAAyB;qBAC1B,cACW,IAAI,aACL;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,eAAe,CAAC;4BAC7C,KAAK,EAAE,IAAI;yBACZ;qBACF;8BAIQ,UAAU;sBAAlB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK","sourcesContent":["/* eslint-disable @angular-eslint/use-lifecycle-interface */\r\n/* eslint-disable @typescript-eslint/no-explicit-any */\r\n/* eslint-disable @angular-eslint/component-selector */\r\nimport {NG_VALUE_ACCESSOR, ReactiveFormsModule} from '@angular/forms';\r\nimport { Component, CUSTOM_ELEMENTS_SCHEMA, Input, SimpleChanges, EventEmitter, forwardRef } from '@angular/core';\r\nimport {MatError, MatFormField, MatHint} from '@angular/material/form-field';\r\nimport {SatPopoverModule} from \"@ncstate/sat-popover\";\r\nimport {NgClass, NgIf} from \"@angular/common\";\r\nimport {InfoItemComponent} from \"../info-item/info-item.component\";\r\nimport {MatInput} from \"@angular/material/input\";\r\nimport { ControlValueAccessorDirective } from '../control-value-accessor.directive';\r\nimport { ValidationErrorsComponent } from '../validation-errors/validation-errors.component';\r\n\r\n@Component({\r\n  selector: 'app-input',\r\n  templateUrl: './input.component.html',\r\n  styleUrls: ['./input.component.scss'],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  imports: [\r\n    SatPopoverModule,\r\n    ReactiveFormsModule,\r\n    NgIf,\r\n    MatError,\r\n    MatHint,\r\n    NgClass,\r\n    InfoItemComponent,\r\n    MatFormField,\r\n    MatInput,\r\n    ValidationErrorsComponent\r\n  ],\r\n  standalone: true,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InputComponent),\r\n      multi: true,\r\n    },\r\n  ]\r\n\r\n})\r\nexport class InputComponent<Type> extends ControlValueAccessorDirective<Type>  {\r\n  @Input() hasTooltip = false;\r\n  @Input() tooltip!: string;\r\n  @Input() floatLabel: any = 'auto';\r\n  @Input() className = 'bordered-input';\r\n  @Input() showLabel = true;\r\n  @Input() iconPrefixName!: string;\r\n  @Input() iconSuffixName!: string;\r\n  @Input() emitedChangedValue1 = new EventEmitter();\r\n\r\n}\r\n","@if(!isReadOnly){\r\n<app-form-label\r\n  [label]=\"label\"\r\n  [optional]=\"!required\"\r\n  [hideOption]=\"required\"\r\n  [showLabel]=\"showLabel\"\r\n></app-form-label>\r\n@if(label){\r\n<div class=\"d-flex justify-content-between mb-1\">\r\n  @if(!hasTooltip){<span class=\"form-label mb-0\">{{ label }}</span\r\n  >} @if(!required){<span class=\"fs-11 fc-dark-gray\">{{\r\n    i18n.translate(\"Optional\")\r\n  }}</span\r\n  >} @if(hasTooltip){\r\n  <span class=\"form-label mb-0\">\r\n    {{ labelTextWriteMode }}\r\n    <ds-icon\r\n      icon=\"info fs-22\"\r\n      class=\"cursor-pointer\"\r\n      [satPopoverAnchor]=\"popover\"\r\n      (click)=\"popover.toggle(); $event.stopImmediatePropagation()\"\r\n    ></ds-icon>\r\n  </span>\r\n  }\r\n</div>\r\n}\r\n<mat-form-field\r\n  class=\"primary-form {{ className }}\"\r\n  [ngClass]=\"{ 'input-disabled': control.disabled }\"\r\n  [floatLabel]=\"floatLabel\"\r\n>\r\n  @if(iconPrefixName){<span class=\"sfi {{ iconPrefixName }}\"></span>}\r\n  @if(loading){<span\r\n    class=\"sfi sfi-spinner d-inline-block spin fc-coral\"\r\n    matSuffix\r\n  ></span\r\n  >}\r\n\r\n  <label class=\"mat-form-content\">\r\n    <!-- add input for ar && en custom directive with add type = arOnly ||  type = enOnly-->\r\n    @if(type === 'arOnly'){\r\n    <input\r\n      arOnly\r\n      matInput\r\n      [value]=\"value\"\r\n      oninput=\"validity.valid || (value='');\"\r\n      [formControl]=\"control\"\r\n      [required]=\"required\"\r\n      [placeholder]=\"placeholder\"\r\n    />\r\n    } @else if(type === 'enOnly'){\r\n    <input\r\n      enOnly\r\n      matInput\r\n      [value]=\"value\"\r\n      oninput=\"validity.valid || (value='');\"\r\n      [formControl]=\"control\"\r\n      [required]=\"required\"\r\n      [placeholder]=\"placeholder\"\r\n    />\r\n    }\r\n    <!--  -->\r\n    @else{\r\n    <input\r\n      matInput\r\n      [value]=\"value\"\r\n      oninput=\"validity.valid || (value='');\"\r\n      [formControl]=\"control\"\r\n      [type]=\"type\"\r\n      [placeholder]=\"placeholder\"\r\n    />\r\n    }\r\n  </label>\r\n  \r\n  @if(matSuffix){<span matSuffix class=\"sfi {{ iconSuffixName }}\"></span>}\r\n  @if(!control?.valid){\r\n  <!-- <mat-error class=\"mb-2\">\r\n    {{ i18n.translate(\"validFieldError\") }}{{ label }}\r\n  </mat-error> -->\r\n  \r\n  } @if(showHint){\r\n  <mat-hint class=\"d-flex align-items-center gap-1 mt-1\">\r\n    <span\r\n      class=\"sfi sfi-info fs-17 fc-dark-gray\"\r\n      [ngClass]=\"{ 'fc-oasis-light-imp': value }\"\r\n    ></span>\r\n    <span class=\"fs-12 fc-black line-height-1\">{{ hint }}</span>\r\n  </mat-hint>\r\n  }\r\n</mat-form-field>\r\n<app-validation-errors [errors]=\"control.errors\"></app-validation-errors>\r\n\r\n\r\n\r\n\r\n<!-- <span class=\"fc-coral\" style=\"color: #f44336\">\r\n  {{ control.errors }}\r\n</span> -->\r\n\r\n} @if(isReadOnly && (showIfEmpty || control)){\r\n<ng-container class=\"info-section\">\r\n  <app-info-item\r\n    class=\"info-item w-100\"\r\n    [label]=\"label\"\r\n    [insideTable]=\"insideTable\"\r\n    [hasLabel]=\"label ? true : false\"\r\n    [type]=\"type\"\r\n    [value]=\"control.value\"\r\n  ></app-info-item>\r\n  @if(showHint){\r\n  <mat-hint class=\"d-flex align-items-center gap-1 mt-1\">\r\n    <span\r\n      class=\"sfi sfi-info fs-17 fc-dark-gray\"\r\n      [ngClass]=\"{ 'fc-oasis-light-imp': value }\"\r\n    ></span>\r\n    <span class=\"fs-12 fc-black line-height-1\">{{ hint }}</span>\r\n  </mat-hint>\r\n  }\r\n</ng-container>\r\n}\r\n\r\n<!-- section tooltip -->\r\n<!-- <sat-popover #popover [hasBackdrop]=\"true\" verticalAlign=\"below\">\r\n  <div class=\"deafult-tooltip\">\r\n    {{tooltip}}\r\n  </div>\r\n</sat-popover> -->\r\n\r\n<sat-popover #popover [hasBackdrop]=\"true\" verticalAlign=\"below\">\r\n  <div class=\"default-popover p-3 fs-14\">\r\n    <span class=\"fs-14 fw-bold signature-notes\" [innerHTML]=\"tooltip\"></span>\r\n  </div>\r\n</sat-popover>\r\n"]}
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/input/input.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/input/input.component.html"],"names":[],"mappings":"AAAA,4DAA4D;AAC5D,uDAAuD;AACvD,uDAAuD;AACvD,OAAO,EAAC,iBAAiB,EAAE,mBAAmB,EAAC,MAAM,gBAAgB,CAAC;AACtE,OAAO,EAAE,SAAS,EAAE,sBAAsB,EAAE,KAAK,EAAiB,YAAY,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAClH,OAAO,EAAC,QAAQ,EAAE,YAAY,EAAE,OAAO,EAAC,MAAM,8BAA8B,CAAC;AAC7E,OAAO,EAAC,gBAAgB,EAAC,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAC,OAAO,EAAE,IAAI,EAAC,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAC,iBAAiB,EAAC,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAC,QAAQ,EAAC,MAAM,yBAAyB,CAAC;AACjD,OAAO,EAAE,6BAA6B,EAAE,MAAM,qCAAqC,CAAC;AACpF,OAAO,EAAE,yBAAyB,EAAE,MAAM,kDAAkD,CAAC;AAC7F,OAAO,EAAC,eAAe,EAAC,MAAM,qCAAqC,CAAC;AACpE,OAAO,EAAC,eAAe,EAAC,MAAM,qCAAqC,CAAC;;;;AA+BpE,MAAM,OAAO,cAAqB,SAAQ,6BAAmC;IAClE,OAAO,CAAU;IACjB,UAAU,GAAQ,MAAM,CAAC;IACzB,SAAS,GAAG,gBAAgB,CAAC;IAC7B,cAAc,CAAU;IACxB,cAAc,CAAU;IACxB,mBAAmB,GAAG,IAAI,YAAY,EAAE,CAAC;uGANvC,cAAc;2FAAd,cAAc,0PATd;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC;gBAC7C,KAAK,EAAE,IAAI;aACZ;SACF,iDCzCH,2yFA4FA,6HDvEI,gBAAgB,kqBAChB,mBAAmB,uyBAGnB,OAAO,8EACP,OAAO,oFACP,iBAAiB,gMACjB,YAAY,4LACZ,QAAQ,iUACR,yBAAyB,6GACzB,eAAe,qDACf,eAAe;;2FAYN,cAAc;kBA7B1B,SAAS;+BACE,WAAW,WAGZ,CAAC,sBAAsB,CAAC,WACxB;wBACP,gBAAgB;wBAChB,mBAAmB;wBACnB,IAAI;wBACJ,QAAQ;wBACR,OAAO;wBACP,OAAO;wBACP,iBAAiB;wBACjB,YAAY;wBACZ,QAAQ;wBACR,yBAAyB;wBACzB,eAAe;wBACf,eAAe;qBAChB,cACW,IAAI,aACL;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,eAAe,CAAC;4BAC7C,KAAK,EAAE,IAAI;yBACZ;qBACF;8BAIQ,OAAO;sBAAf,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK","sourcesContent":["/* eslint-disable @angular-eslint/use-lifecycle-interface */\r\n/* eslint-disable @typescript-eslint/no-explicit-any */\r\n/* eslint-disable @angular-eslint/component-selector */\r\nimport {NG_VALUE_ACCESSOR, ReactiveFormsModule} from '@angular/forms';\r\nimport { Component, CUSTOM_ELEMENTS_SCHEMA, Input, SimpleChanges, EventEmitter, forwardRef } from '@angular/core';\r\nimport {MatError, MatFormField, MatHint} from '@angular/material/form-field';\r\nimport {SatPopoverModule} from \"@ncstate/sat-popover\";\r\nimport {NgClass, NgIf} from \"@angular/common\";\r\nimport {InfoItemComponent} from \"../info-item/info-item.component\";\r\nimport {MatInput} from \"@angular/material/input\";\r\nimport { ControlValueAccessorDirective } from '../control-value-accessor.directive';\r\nimport { ValidationErrorsComponent } from '../validation-errors/validation-errors.component';\r\nimport {EnOnlyDirective} from \"../../../../directives/en.directive\";\r\nimport {ArOnlyDirective} from \"../../../../directives/ar.directive\";\r\n\r\n@Component({\r\n  selector: 'app-input',\r\n  templateUrl: './input.component.html',\r\n  styleUrls: ['./input.component.scss'],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  imports: [\r\n    SatPopoverModule,\r\n    ReactiveFormsModule,\r\n    NgIf,\r\n    MatError,\r\n    MatHint,\r\n    NgClass,\r\n    InfoItemComponent,\r\n    MatFormField,\r\n    MatInput,\r\n    ValidationErrorsComponent,\r\n    EnOnlyDirective,\r\n    ArOnlyDirective\r\n  ],\r\n  standalone: true,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InputComponent),\r\n      multi: true,\r\n    },\r\n  ]\r\n\r\n})\r\nexport class InputComponent<Type> extends ControlValueAccessorDirective<Type>  {\r\n  @Input() tooltip!: string;\r\n  @Input() floatLabel: any = 'auto';\r\n  @Input() className = 'bordered-input';\r\n  @Input() iconPrefixName!: string;\r\n  @Input() iconSuffixName!: string;\r\n  @Input() emitedChangedValue1 = new EventEmitter();\r\n\r\n}\r\n","@if(!isReadOnly){\r\n@if(label){\r\n<div class=\"d-flex justify-content-between mb-1\">\r\n  <span class=\"form-label mb-0\">{{ label }}</span\r\n  > @if(!required){<span class=\"fs-11 fc-dark-gray\">{{\r\n    i18n.translate(\"Optional\")\r\n  }}</span\r\n  >} @if(hasTooltip){\r\n  <span class=\"form-label mb-0\">\r\n    {{ tooltip }}\r\n    <ds-icon\r\n      icon=\"info fs-22\"\r\n      class=\"cursor-pointer\"\r\n      [satPopoverAnchor]=\"popover\"\r\n      (click)=\"popover.toggle(); $event.stopImmediatePropagation()\"\r\n    ></ds-icon>\r\n  </span>\r\n  }\r\n</div>\r\n}\r\n<mat-form-field\r\n  class=\"primary-form {{ className }}\"\r\n  [ngClass]=\"{ 'input-disabled': control.disabled }\"\r\n  [floatLabel]=\"floatLabel\"\r\n>\r\n  @if(iconPrefixName){<span class=\"sfi {{ iconPrefixName }}\"></span>}\r\n  <label class=\"mat-form-content\">\r\n    <!-- add input for ar && en custom directive with add type = arOnly ||  type = enOnly-->\r\n    @if(type === 'arOnly'){\r\n    <input\r\n      arOnly\r\n      matInput\r\n      [value]=\"value\"\r\n      oninput=\"validity.valid || (value='');\"\r\n      [formControl]=\"control\"\r\n      [required]=\"required\"\r\n      [placeholder]=\"placeholder\"\r\n    />\r\n    } @else if(type === 'enOnly'){\r\n    <input\r\n      enOnly\r\n      matInput\r\n      [value]=\"value\"\r\n      oninput=\"validity.valid || (value='');\"\r\n      [formControl]=\"control\"\r\n      [required]=\"required\"\r\n      [placeholder]=\"placeholder\"\r\n    />\r\n    }\r\n    @else{\r\n    <input\r\n      matInput\r\n      [value]=\"value\"\r\n      oninput=\"validity.valid || (value='');\"\r\n      [formControl]=\"control\"\r\n      [type]=\"type\"\r\n      [placeholder]=\"placeholder\"\r\n    />\r\n    }\r\n  </label>\r\n  \r\n  @if(iconSuffixName){<span matSuffix class=\"sfi {{ iconSuffixName }}\"></span>}\r\n  @if(hint){\r\n  <mat-hint class=\"d-flex align-items-center gap-1 mt-1\">\r\n    <span\r\n      class=\"sfi sfi-info fs-17 fc-dark-gray\"\r\n      [ngClass]=\"{ 'fc-oasis-light-imp': value }\"\r\n    ></span>\r\n    <span class=\"fs-12 fc-black line-height-1\">{{ hint }}</span>\r\n  </mat-hint>\r\n  }\r\n</mat-form-field>\r\n<app-validation-errors [errors]=\"control.errors\"></app-validation-errors>\r\n\r\n} @if(isReadOnly && (showIfEmpty || control)){\r\n<ng-container class=\"info-section\">\r\n  <app-info-item\r\n    class=\"info-item w-100\"\r\n    [label]=\"label\"\r\n    [insideTable]=\"insideTable\"\r\n    [hasLabel]=\"!!label\"\r\n    [type]=\"type\"\r\n    [value]=\"control.value\"\r\n  ></app-info-item>\r\n</ng-container>\r\n}\r\n\r\n<sat-popover #popover [hasBackdrop]=\"true\" verticalAlign=\"below\">\r\n  <div class=\"default-popover p-3 fs-14\">\r\n    <span class=\"fs-14 fw-bold signature-notes\" [innerHTML]=\"tooltip\"></span>\r\n  </div>\r\n</sat-popover>\r\n"]}
|
|
@@ -10,6 +10,9 @@ import { InfoItemComponent } from "../info-item/info-item.component";
|
|
|
10
10
|
import { SatPopoverModule } from "@ncstate/sat-popover";
|
|
11
11
|
import { ControlValueAccessorDirective } from '../control-value-accessor.directive';
|
|
12
12
|
import { MatInput } from '@angular/material/input';
|
|
13
|
+
import { MycurrencyPipe } from "../../../../pipes";
|
|
14
|
+
import { ValidationErrorsComponent } from '../validation-errors/validation-errors.component';
|
|
15
|
+
import { MycurrencyDirective } from "../../../../directives/currency.directive";
|
|
13
16
|
import * as i0 from "@angular/core";
|
|
14
17
|
import * as i1 from "@angular/forms";
|
|
15
18
|
import * as i2 from "@ncstate/sat-popover";
|
|
@@ -28,7 +31,8 @@ export class InputCurrencyComponent extends ControlValueAccessorDirective {
|
|
|
28
31
|
useExisting: forwardRef(() => InputCurrencyComponent),
|
|
29
32
|
multi: true,
|
|
30
33
|
},
|
|
31
|
-
|
|
34
|
+
MycurrencyPipe
|
|
35
|
+
], usesInheritance: true, ngImport: i0, template: "@if(!isReadOnly){\r\n @if(label){\r\n <div class=\"d-flex justify-content-between mb-1\">\r\n <span class=\"form-label mb-0\">{{ label }}</span\r\n > @if(!required){<span class=\"fs-11 fc-dark-gray\">{{\r\n i18n.translate(\"Optional\")\r\n }}</span\r\n >} @if(hasTooltip){\r\n <span class=\"form-label mb-0\">\r\n {{ tooltip }}\r\n <ds-icon\r\n icon=\"info fs-22\"\r\n class=\"cursor-pointer\"\r\n [satPopoverAnchor]=\"popover\"\r\n (click)=\"popover.toggle(); $event.stopImmediatePropagation()\"\r\n ></ds-icon>\r\n </span>\r\n }\r\n </div>\r\n }\r\n <mat-form-field\r\n class=\"primary-form {{ className }}\"\r\n [ngClass]=\"{ 'input-disabled': control.disabled }\"\r\n [floatLabel]=\"floatLabel\"\r\n >\r\n @if(iconPrefixName){<span class=\"sfi {{ iconPrefixName }}\"></span>}\r\n @if(loading){<span\r\n class=\"sfi sfi-spinner d-inline-block spin fc-coral\"\r\n matSuffix\r\n ></span\r\n >}\r\n <label class=\"mat-form-content\">\r\n <!-- add input for ar && en custom directive with add type = arOnly || type = enOnly-->\r\n <input\r\n matInput\r\n [value]=\"value\"\r\n oninput=\"validity.valid || (value='');\"\r\n [formControl]=\"control\"\r\n [type]=\"type\"\r\n [placeholder]=\"placeholder\"\r\n appMycurrency\r\n />\r\n </label>\r\n @if(iconSuffixName){<span matSuffix class=\"sfi {{ iconSuffixName }}\"></span>}\r\n @if(hint){\r\n <mat-hint class=\"d-flex align-items-center gap-1 mt-1\">\r\n <span\r\n class=\"sfi sfi-info fs-17 fc-dark-gray\"\r\n [ngClass]=\"{ 'fc-oasis-light-imp': value }\"\r\n ></span>\r\n <span class=\"fs-12 fc-black line-height-1\">{{ hint }}</span>\r\n </mat-hint>\r\n }\r\n </mat-form-field>\r\n <app-validation-errors [errors]=\"control.errors\"></app-validation-errors>\r\n } @if(isReadOnly && (showIfEmpty || control)){\r\n <ng-container class=\"info-section\">\r\n <app-info-item\r\n class=\"info-item w-100\"\r\n [label]=\"label\"\r\n [insideTable]=\"insideTable\"\r\n [hasLabel]=\"!!label\"\r\n [type]=\"type\"\r\n [value]=\"control.value\"\r\n ></app-info-item>\r\n </ng-container>\r\n }\r\n <sat-popover #popover [hasBackdrop]=\"true\" verticalAlign=\"below\">\r\n <div class=\"default-popover p-3 fs-14\">\r\n <span class=\"fs-14 fw-bold signature-notes\" [innerHTML]=\"tooltip\"></span>\r\n </div>\r\n </sat-popover>\r\n ", styles: [":host{flex-grow:1}.input-disabled{pointer-events:none!important;opacity:1.5}\n"], dependencies: [{ kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.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: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "component", type: InfoItemComponent, selector: "app-info-item", inputs: ["label", "value", "name", "type", "dateType", "multiple", "insideTable", "hasLabel", "arrayList", "actionType", "download"] }, { kind: "ngmodule", type: SatPopoverModule }, { kind: "component", type: i2.SatPopoverComponent, selector: "sat-popover", inputs: ["anchor", "horizontalAlign", "xAlign", "verticalAlign", "yAlign", "forceAlignment", "lockAlignment", "autoFocus", "restoreFocus", "scrollStrategy", "hasBackdrop", "interactiveClose", "openTransition", "closeTransition", "openAnimationStartAtScale", "closeAnimationEndAtScale", "backdropClass", "panelClass"], outputs: ["opened", "closed", "afterOpen", "afterClose", "backdropClicked", "overlayKeydown"] }, { kind: "directive", type: i2.SatPopoverAnchorDirective, selector: "[satPopoverAnchor]", inputs: ["satPopoverAnchor"], exportAs: ["satPopoverAnchor"] }, { kind: "component", type: MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: 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: "directive", type: MycurrencyDirective, selector: "[appMycurrency]", inputs: ["decimals"] }, { kind: "component", type: ValidationErrorsComponent, selector: "app-validation-errors", inputs: ["errors", "customErrorMessages"] }] });
|
|
32
36
|
}
|
|
33
37
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: InputCurrencyComponent, decorators: [{
|
|
34
38
|
type: Component,
|
|
@@ -41,14 +45,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
41
45
|
SatPopoverModule,
|
|
42
46
|
MatFormField,
|
|
43
47
|
MatInput,
|
|
44
|
-
NgIf
|
|
48
|
+
NgIf,
|
|
49
|
+
MycurrencyDirective,
|
|
50
|
+
ValidationErrorsComponent
|
|
45
51
|
], providers: [
|
|
46
52
|
{
|
|
47
53
|
provide: NG_VALUE_ACCESSOR,
|
|
48
54
|
useExisting: forwardRef(() => InputCurrencyComponent),
|
|
49
55
|
multi: true,
|
|
50
56
|
},
|
|
51
|
-
|
|
57
|
+
MycurrencyPipe
|
|
58
|
+
], template: "@if(!isReadOnly){\r\n @if(label){\r\n <div class=\"d-flex justify-content-between mb-1\">\r\n <span class=\"form-label mb-0\">{{ label }}</span\r\n > @if(!required){<span class=\"fs-11 fc-dark-gray\">{{\r\n i18n.translate(\"Optional\")\r\n }}</span\r\n >} @if(hasTooltip){\r\n <span class=\"form-label mb-0\">\r\n {{ tooltip }}\r\n <ds-icon\r\n icon=\"info fs-22\"\r\n class=\"cursor-pointer\"\r\n [satPopoverAnchor]=\"popover\"\r\n (click)=\"popover.toggle(); $event.stopImmediatePropagation()\"\r\n ></ds-icon>\r\n </span>\r\n }\r\n </div>\r\n }\r\n <mat-form-field\r\n class=\"primary-form {{ className }}\"\r\n [ngClass]=\"{ 'input-disabled': control.disabled }\"\r\n [floatLabel]=\"floatLabel\"\r\n >\r\n @if(iconPrefixName){<span class=\"sfi {{ iconPrefixName }}\"></span>}\r\n @if(loading){<span\r\n class=\"sfi sfi-spinner d-inline-block spin fc-coral\"\r\n matSuffix\r\n ></span\r\n >}\r\n <label class=\"mat-form-content\">\r\n <!-- add input for ar && en custom directive with add type = arOnly || type = enOnly-->\r\n <input\r\n matInput\r\n [value]=\"value\"\r\n oninput=\"validity.valid || (value='');\"\r\n [formControl]=\"control\"\r\n [type]=\"type\"\r\n [placeholder]=\"placeholder\"\r\n appMycurrency\r\n />\r\n </label>\r\n @if(iconSuffixName){<span matSuffix class=\"sfi {{ iconSuffixName }}\"></span>}\r\n @if(hint){\r\n <mat-hint class=\"d-flex align-items-center gap-1 mt-1\">\r\n <span\r\n class=\"sfi sfi-info fs-17 fc-dark-gray\"\r\n [ngClass]=\"{ 'fc-oasis-light-imp': value }\"\r\n ></span>\r\n <span class=\"fs-12 fc-black line-height-1\">{{ hint }}</span>\r\n </mat-hint>\r\n }\r\n </mat-form-field>\r\n <app-validation-errors [errors]=\"control.errors\"></app-validation-errors>\r\n } @if(isReadOnly && (showIfEmpty || control)){\r\n <ng-container class=\"info-section\">\r\n <app-info-item\r\n class=\"info-item w-100\"\r\n [label]=\"label\"\r\n [insideTable]=\"insideTable\"\r\n [hasLabel]=\"!!label\"\r\n [type]=\"type\"\r\n [value]=\"control.value\"\r\n ></app-info-item>\r\n </ng-container>\r\n }\r\n <sat-popover #popover [hasBackdrop]=\"true\" verticalAlign=\"below\">\r\n <div class=\"default-popover p-3 fs-14\">\r\n <span class=\"fs-14 fw-bold signature-notes\" [innerHTML]=\"tooltip\"></span>\r\n </div>\r\n </sat-popover>\r\n ", styles: [":host{flex-grow:1}.input-disabled{pointer-events:none!important;opacity:1.5}\n"] }]
|
|
52
59
|
}], propDecorators: { tooltip: [{
|
|
53
60
|
type: Input
|
|
54
61
|
}], floatLabel: [{
|
|
@@ -62,4 +69,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
62
69
|
}], numberSuffixName: [{
|
|
63
70
|
type: Input
|
|
64
71
|
}] } });
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-currency.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/input-currency/input-currency.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/shared-components/form-field/input-currency/input-currency.component.html"],"names":[],"mappings":"AAAA,sDAAsD;AACtD,4DAA4D;AAC5D,uDAAuD;AACvD,uDAAuD;AACvD,OAAO,EAAC,iBAAiB,EAAE,mBAAmB,EAAC,MAAM,gBAAgB,CAAC;AACtE,OAAO,EAAE,SAAS,EAAE,sBAAsB,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACrF,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,OAAO,EAAC,MAAM,8BAA8B,CAAC;AAC9E,OAAO,EAAC,OAAO,EAAE,IAAI,EAAC,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAC,iBAAiB,EAAC,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAC,gBAAgB,EAAC,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,6BAA6B,EAAE,MAAM,qCAAqC,CAAC;AACpF,OAAO,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAC;AACnD,OAAO,EAAC,cAAc,EAAC,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,yBAAyB,EAAE,MAAM,kDAAkD,CAAC;AAC7F,OAAO,EAAC,mBAAmB,EAAC,MAAM,2CAA2C,CAAC;;;;AA+B9E,MAAM,OAAO,sBAA6B,SAAQ,6BAAmC;IAC1E,OAAO,CAAU;IACjB,UAAU,GAAQ,MAAM,CAAC;IACzB,SAAS,GAAG,gBAAgB,CAAC;IAC7B,cAAc,CAAU;IACxB,cAAc,CAAU;IACxB,gBAAgB,CAAU;IAC5B,cAAc,CAAgB;uGAP1B,sBAAsB;2FAAtB,sBAAsB,6PAVtB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC;gBACrD,KAAK,EAAE,IAAI;aAEZ;YACD,cAAc;SACf,iDC3CH,q/EAwEE,uIDjDE,mBAAmB,0kBACnB,OAAO,oFAEP,OAAO,8EACP,iBAAiB,+LACjB,gBAAgB,mqBAChB,YAAY,4LACZ,QAAQ,iUAER,mBAAmB,kFACnB,yBAAyB;;2FAYhB,sBAAsB;kBA7BlC,SAAS;+BACE,oBAAoB,WAGrB,CAAC,sBAAsB,CAAC,cACrB,IAAI,WACP;wBACP,mBAAmB;wBACnB,OAAO;wBACP,QAAQ;wBACR,OAAO;wBACP,iBAAiB;wBACjB,gBAAgB;wBAChB,YAAY;wBACZ,QAAQ;wBACR,IAAI;wBACJ,mBAAmB;wBACnB,yBAAyB;qBAC1B,aACU;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,uBAAuB,CAAC;4BACrD,KAAK,EAAE,IAAI;yBAEZ;wBACD,cAAc;qBACf;8BAGQ,OAAO;sBAAf,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK","sourcesContent":["/* eslint-disable @typescript-eslint/no-unused-vars */\r\n/* eslint-disable @angular-eslint/use-lifecycle-interface */\r\n/* eslint-disable @typescript-eslint/no-explicit-any */\r\n/* eslint-disable @angular-eslint/component-selector */\r\nimport {NG_VALUE_ACCESSOR, ReactiveFormsModule} from '@angular/forms';\r\nimport { Component, CUSTOM_ELEMENTS_SCHEMA, forwardRef, Input } from '@angular/core';\r\nimport { MatError, MatFormField, MatHint} from '@angular/material/form-field';\r\nimport {NgClass, NgIf} from \"@angular/common\";\r\nimport {InfoItemComponent} from \"../info-item/info-item.component\";\r\nimport {SatPopoverModule} from \"@ncstate/sat-popover\";\r\nimport { ControlValueAccessorDirective } from '../control-value-accessor.directive';\r\nimport { MatInput } from '@angular/material/input';\r\nimport {MycurrencyPipe} from \"../../../../pipes\";\r\nimport { ValidationErrorsComponent } from '../validation-errors/validation-errors.component';\r\nimport {MycurrencyDirective} from \"../../../../directives/currency.directive\";\r\n\r\n@Component({\r\n  selector: 'app-input-currency',\r\n  templateUrl: './input-currency.component.html',\r\n  styleUrls: ['./input-currency.component.scss'],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\r\n  standalone: true,\r\n  imports: [\r\n    ReactiveFormsModule,\r\n    NgClass,\r\n    MatError,\r\n    MatHint,\r\n    InfoItemComponent,\r\n    SatPopoverModule,\r\n    MatFormField,\r\n    MatInput,\r\n    NgIf,\r\n    MycurrencyDirective,\r\n    ValidationErrorsComponent\r\n  ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InputCurrencyComponent),\r\n      multi: true,\r\n\r\n    },\r\n    MycurrencyPipe\r\n  ]\r\n})\r\nexport class InputCurrencyComponent<Type> extends ControlValueAccessorDirective<Type>  {\r\n  @Input() tooltip!: string;\r\n  @Input() floatLabel: any = 'auto';\r\n  @Input() className = 'bordered-input';\r\n  @Input() iconPrefixName!: string;\r\n  @Input() iconSuffixName!: string;\r\n  @Input() numberSuffixName!: string;\r\n  public mycurrencyPipe: MycurrencyPipe\r\n\r\n}\r\n","@if(!isReadOnly){\r\n  @if(label){\r\n  <div class=\"d-flex justify-content-between mb-1\">\r\n    <span class=\"form-label mb-0\">{{ label }}</span\r\n    > @if(!required){<span class=\"fs-11 fc-dark-gray\">{{\r\n      i18n.translate(\"Optional\")\r\n    }}</span\r\n    >} @if(hasTooltip){\r\n    <span class=\"form-label mb-0\">\r\n      {{ tooltip }}\r\n      <ds-icon\r\n        icon=\"info fs-22\"\r\n        class=\"cursor-pointer\"\r\n        [satPopoverAnchor]=\"popover\"\r\n        (click)=\"popover.toggle(); $event.stopImmediatePropagation()\"\r\n      ></ds-icon>\r\n    </span>\r\n    }\r\n  </div>\r\n  }\r\n  <mat-form-field\r\n    class=\"primary-form {{ className }}\"\r\n    [ngClass]=\"{ 'input-disabled': control.disabled }\"\r\n    [floatLabel]=\"floatLabel\"\r\n  >\r\n    @if(iconPrefixName){<span class=\"sfi {{ iconPrefixName }}\"></span>}\r\n    @if(loading){<span\r\n      class=\"sfi sfi-spinner d-inline-block spin fc-coral\"\r\n      matSuffix\r\n    ></span\r\n    >}\r\n    <label class=\"mat-form-content\">\r\n      <!-- add input for ar && en custom directive with add type = arOnly ||  type = enOnly-->\r\n      <input\r\n        matInput\r\n        [value]=\"value\"\r\n        oninput=\"validity.valid || (value='');\"\r\n        [formControl]=\"control\"\r\n        [type]=\"type\"\r\n        [placeholder]=\"placeholder\"\r\n        appMycurrency\r\n      />\r\n    </label>\r\n    @if(iconSuffixName){<span matSuffix class=\"sfi {{ iconSuffixName }}\"></span>}\r\n    @if(hint){\r\n    <mat-hint class=\"d-flex align-items-center gap-1 mt-1\">\r\n      <span\r\n        class=\"sfi sfi-info fs-17 fc-dark-gray\"\r\n        [ngClass]=\"{ 'fc-oasis-light-imp': value }\"\r\n      ></span>\r\n      <span class=\"fs-12 fc-black line-height-1\">{{ hint }}</span>\r\n    </mat-hint>\r\n    }\r\n  </mat-form-field>\r\n  <app-validation-errors [errors]=\"control.errors\"></app-validation-errors>\r\n  } @if(isReadOnly && (showIfEmpty || control)){\r\n  <ng-container class=\"info-section\">\r\n    <app-info-item\r\n      class=\"info-item w-100\"\r\n      [label]=\"label\"\r\n      [insideTable]=\"insideTable\"\r\n      [hasLabel]=\"!!label\"\r\n      [type]=\"type\"\r\n      [value]=\"control.value\"\r\n    ></app-info-item>\r\n  </ng-container>\r\n  }\r\n  <sat-popover #popover [hasBackdrop]=\"true\" verticalAlign=\"below\">\r\n    <div class=\"default-popover p-3 fs-14\">\r\n      <span class=\"fs-14 fw-bold signature-notes\" [innerHTML]=\"tooltip\"></span>\r\n    </div>\r\n  </sat-popover>\r\n  "]}
|