@morozeckiy/dd-lib 0.6.4 → 0.7.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/lib-date-input/lib-date-input.component.mjs +115 -0
- package/esm2022/lib/lib-date-range/lib-date-range.component.mjs +1 -1
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/morozeckiy-dd-lib.mjs +121 -18
- package/fesm2022/morozeckiy-dd-lib.mjs.map +1 -1
- package/lib/lib-date-input/lib-date-input.component.d.ts +27 -0
- package/morozeckiy-dd-lib-0.7.0.tgz +0 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/morozeckiy-dd-lib-0.6.4.tgz +0 -0
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, forwardRef, Input } from '@angular/core';
|
|
2
|
+
import { ClickOutsideDirective, DateService, FilterByKeyPipe, HighlightPipe, SafePipe } from "../core";
|
|
3
|
+
import { FormsModule, NG_VALUE_ACCESSOR } from "@angular/forms";
|
|
4
|
+
import { LibLoaderComponent } from "../lib-loader/lib-loader.component";
|
|
5
|
+
import { LibSvgIconComponent } from "../lib-svg-icon/lib-svg-icon.component";
|
|
6
|
+
import { LibPeriodComponent } from "../lib-period/lib-period.component";
|
|
7
|
+
import { LibCalendarComponent } from "../lib-calendar/lib-calendar.component";
|
|
8
|
+
import { format } from "date-fns";
|
|
9
|
+
import { NgxMaskDirective, provideNgxMask } from "ngx-mask";
|
|
10
|
+
import { JsonPipe, NgClass } from "@angular/common";
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
import * as i1 from "@angular/forms";
|
|
13
|
+
export class LibDateInputComponent {
|
|
14
|
+
constructor() {
|
|
15
|
+
this.isShownCalendar = false;
|
|
16
|
+
this.disabled = false;
|
|
17
|
+
this.selectedDate = new Date();
|
|
18
|
+
}
|
|
19
|
+
static { this.idCounter = 1; }
|
|
20
|
+
ngOnInit() {
|
|
21
|
+
if (!this.dateId) {
|
|
22
|
+
this.dateId = 'dd-date-' + LibDateInputComponent.idCounter++;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
openCalendar() {
|
|
26
|
+
if (!this.disabled) {
|
|
27
|
+
this.isShownCalendar = true;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
closeCalendar() {
|
|
31
|
+
if (!this.selectedDate) {
|
|
32
|
+
this.selectedDateStr = undefined;
|
|
33
|
+
}
|
|
34
|
+
this.isShownCalendar = false;
|
|
35
|
+
}
|
|
36
|
+
setPeriod($event) {
|
|
37
|
+
this.isShownCalendar = false;
|
|
38
|
+
if ($event) {
|
|
39
|
+
this.selectedDateStr = `${format($event, 'dd.MM.yyyy')}`;
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
this.selectedDate = undefined;
|
|
43
|
+
this.selectedDateStr = undefined;
|
|
44
|
+
}
|
|
45
|
+
this.propagateChange(this.selectedDate);
|
|
46
|
+
}
|
|
47
|
+
changeStrDate($event) {
|
|
48
|
+
const date = DateService.getDateFromString($event.substring(0, 8));
|
|
49
|
+
if (date) {
|
|
50
|
+
this.selectedDate = date;
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
this.selectedDate = undefined;
|
|
54
|
+
}
|
|
55
|
+
this.propagateChange(this.selectedDate);
|
|
56
|
+
}
|
|
57
|
+
propagateChange(_value) {
|
|
58
|
+
}
|
|
59
|
+
registerOnChange(fn) {
|
|
60
|
+
this.propagateChange = fn;
|
|
61
|
+
}
|
|
62
|
+
registerOnTouched(fn) {
|
|
63
|
+
this.onTouchedCallback = fn;
|
|
64
|
+
}
|
|
65
|
+
writeValue($event) {
|
|
66
|
+
this.selectedDate = $event;
|
|
67
|
+
if ($event) {
|
|
68
|
+
this.selectedDateStr = `${format($event, 'dd.MM.yyyy')}`;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: LibDateInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
72
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.2", type: LibDateInputComponent, isStandalone: true, selector: "dd-lib-date-input", inputs: { topSide: "topSide", dateId: "dateId", placeholder: "placeholder", label: "label", required: "required" }, providers: [
|
|
73
|
+
provideNgxMask(),
|
|
74
|
+
{
|
|
75
|
+
provide: NG_VALUE_ACCESSOR,
|
|
76
|
+
useExisting: forwardRef(() => LibDateInputComponent),
|
|
77
|
+
multi: true,
|
|
78
|
+
},
|
|
79
|
+
], ngImport: i0, template: "<div class=\"lib-date\" id=\"lib-date-{{ dateId }}\">\r\n @if (label) {\r\n <label [for]=\"dateId\" class=\"lib-date__title\">\r\n {{ label }}\r\n @if (required) {\r\n <dd-lib-svg-icon icon=\"error_hint\"></dd-lib-svg-icon>\r\n }\r\n </label>\r\n }\r\n <div class=\"pos-relative\">\r\n <input\r\n [attr.id]=\"dateId\"\r\n [attr.placeholder]=\"placeholder\"\r\n (click)=\"openCalendar()\"\r\n [(ngModel)]=\"selectedDateStr\"\r\n [mask]=\"'d0.M0.0000'\"\r\n (ngModelChange)=\"changeStrDate($event)\"\r\n [leadZeroDateTime]=\"true\"\r\n class=\"text-select\"/>\r\n @if (!selectedDateStr) {\r\n <dd-lib-svg-icon [class.gray-svg]=\"!isShownCalendar\"\r\n (click)=\"openCalendar()\"\r\n id=\"calendar-{{ dateId }}\"\r\n class=\"calendar\" icon=\"calendar\"></dd-lib-svg-icon>\r\n\r\n\r\n } @else {\r\n <dd-lib-svg-icon\r\n (click)=\"setPeriod(undefined)\"\r\n class=\"clear\"\r\n icon=\"clear\"></dd-lib-svg-icon>\r\n\r\n }\r\n </div>\r\n @if (isShownCalendar) {\r\n <div\r\n (ddClickOutside)=\"closeCalendar()\"\r\n [elements]=\"['lib-date-' + dateId, 'calendar' + dateId]\"\r\n class=\"calendar-wrapper\" [ngClass]=\"{top: topSide}\">\r\n <dd-lib-calendar [(ngModel)]=\"selectedDate\" (emitDate)=\"setPeriod($event)\"></dd-lib-calendar>\r\n </div>\r\n }\r\n</div>\r\n", styles: [".lib-date{min-width:340px;position:relative}.lib-date input{width:100%;height:48px;padding:15px 28px 15px 16px;overflow:hidden;text-overflow:ellipsis;border-radius:8px;border:1px solid var(--input-border-color);background-color:transparent;position:relative}.lib-date input:hover{border-color:var(--input-active-border-colort)}.lib-date input:focus{border-color:var(--input-active-border-colort);box-shadow:var(--input-active-border-shadow)}.lib-date input:disabled{border:none;background-color:var(--input-disable-input);color:var(--input-disable-text);pointer-events:none}.lib-date input:disabled::placeholder{color:var(--input-placeholder)}.lib-date input.invalid,.lib-date input.invalid:hover{border-color:var(--input-error-border-color)}.lib-date input.invalid:focus{border-color:var(--input-error-border-color);box-shadow:var(--input-error-border-shadow)}.lib-date .clear{cursor:pointer;position:absolute;right:8px;top:12px}.lib-date .calendar{cursor:pointer;position:absolute;right:16px;top:10px}.lib-date .calendar.up{transform:rotate(180deg)}.lib-date__title{margin-bottom:4px;font-size:14px;line-height:24px;display:flex;align-items:flex-start}.lib-date__error{color:var(--primary-red-color);font-size:12px;font-weight:400;line-height:10px;margin-top:2px;position:absolute}.lib-date .calendar-wrapper{max-width:350px;position:absolute;display:block;z-index:100;width:100%;overflow:auto;border-radius:8px;box-shadow:var(--main-card-shadow);background-color:var(--main-card-color)}.lib-date .calendar-wrapper.top{bottom:48px}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { 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.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: LibSvgIconComponent, selector: "dd-lib-svg-icon", inputs: ["width", "height", "color", "icon"] }, { kind: "directive", type: ClickOutsideDirective, selector: "[ddClickOutside]", inputs: ["elements"], outputs: ["ddClickOutside"] }, { kind: "component", type: LibCalendarComponent, selector: "dd-lib-calendar", inputs: ["type", "formatDate", "formatTime", "rangeMode", "maxHours", "maxMinutes", "needTime", "mode", "maxDate", "minDate"], outputs: ["emitDate", "emitPeriod"] }, { kind: "directive", type: NgxMaskDirective, selector: "input[mask], textarea[mask]", inputs: ["mask", "specialCharacters", "patterns", "prefix", "suffix", "thousandSeparator", "decimalMarker", "dropSpecialCharacters", "hiddenInput", "showMaskTyped", "placeHolderCharacter", "shownMaskExpression", "showTemplate", "clearIfNotMatch", "validation", "separatorLimit", "allowNegativeNumbers", "leadZeroDateTime", "leadZero", "triggerOnMaskChange", "apm", "inputTransformFn", "outputTransformFn", "keepCharacterPositions"], outputs: ["maskFilled"], exportAs: ["mask", "ngxMask"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
80
|
+
}
|
|
81
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: LibDateInputComponent, decorators: [{
|
|
82
|
+
type: Component,
|
|
83
|
+
args: [{ selector: 'dd-lib-date-input', standalone: true, imports: [
|
|
84
|
+
FilterByKeyPipe,
|
|
85
|
+
FormsModule,
|
|
86
|
+
HighlightPipe,
|
|
87
|
+
LibLoaderComponent,
|
|
88
|
+
LibSvgIconComponent,
|
|
89
|
+
SafePipe,
|
|
90
|
+
ClickOutsideDirective,
|
|
91
|
+
LibPeriodComponent,
|
|
92
|
+
LibCalendarComponent,
|
|
93
|
+
NgxMaskDirective,
|
|
94
|
+
JsonPipe,
|
|
95
|
+
NgClass
|
|
96
|
+
], providers: [
|
|
97
|
+
provideNgxMask(),
|
|
98
|
+
{
|
|
99
|
+
provide: NG_VALUE_ACCESSOR,
|
|
100
|
+
useExisting: forwardRef(() => LibDateInputComponent),
|
|
101
|
+
multi: true,
|
|
102
|
+
},
|
|
103
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"lib-date\" id=\"lib-date-{{ dateId }}\">\r\n @if (label) {\r\n <label [for]=\"dateId\" class=\"lib-date__title\">\r\n {{ label }}\r\n @if (required) {\r\n <dd-lib-svg-icon icon=\"error_hint\"></dd-lib-svg-icon>\r\n }\r\n </label>\r\n }\r\n <div class=\"pos-relative\">\r\n <input\r\n [attr.id]=\"dateId\"\r\n [attr.placeholder]=\"placeholder\"\r\n (click)=\"openCalendar()\"\r\n [(ngModel)]=\"selectedDateStr\"\r\n [mask]=\"'d0.M0.0000'\"\r\n (ngModelChange)=\"changeStrDate($event)\"\r\n [leadZeroDateTime]=\"true\"\r\n class=\"text-select\"/>\r\n @if (!selectedDateStr) {\r\n <dd-lib-svg-icon [class.gray-svg]=\"!isShownCalendar\"\r\n (click)=\"openCalendar()\"\r\n id=\"calendar-{{ dateId }}\"\r\n class=\"calendar\" icon=\"calendar\"></dd-lib-svg-icon>\r\n\r\n\r\n } @else {\r\n <dd-lib-svg-icon\r\n (click)=\"setPeriod(undefined)\"\r\n class=\"clear\"\r\n icon=\"clear\"></dd-lib-svg-icon>\r\n\r\n }\r\n </div>\r\n @if (isShownCalendar) {\r\n <div\r\n (ddClickOutside)=\"closeCalendar()\"\r\n [elements]=\"['lib-date-' + dateId, 'calendar' + dateId]\"\r\n class=\"calendar-wrapper\" [ngClass]=\"{top: topSide}\">\r\n <dd-lib-calendar [(ngModel)]=\"selectedDate\" (emitDate)=\"setPeriod($event)\"></dd-lib-calendar>\r\n </div>\r\n }\r\n</div>\r\n", styles: [".lib-date{min-width:340px;position:relative}.lib-date input{width:100%;height:48px;padding:15px 28px 15px 16px;overflow:hidden;text-overflow:ellipsis;border-radius:8px;border:1px solid var(--input-border-color);background-color:transparent;position:relative}.lib-date input:hover{border-color:var(--input-active-border-colort)}.lib-date input:focus{border-color:var(--input-active-border-colort);box-shadow:var(--input-active-border-shadow)}.lib-date input:disabled{border:none;background-color:var(--input-disable-input);color:var(--input-disable-text);pointer-events:none}.lib-date input:disabled::placeholder{color:var(--input-placeholder)}.lib-date input.invalid,.lib-date input.invalid:hover{border-color:var(--input-error-border-color)}.lib-date input.invalid:focus{border-color:var(--input-error-border-color);box-shadow:var(--input-error-border-shadow)}.lib-date .clear{cursor:pointer;position:absolute;right:8px;top:12px}.lib-date .calendar{cursor:pointer;position:absolute;right:16px;top:10px}.lib-date .calendar.up{transform:rotate(180deg)}.lib-date__title{margin-bottom:4px;font-size:14px;line-height:24px;display:flex;align-items:flex-start}.lib-date__error{color:var(--primary-red-color);font-size:12px;font-weight:400;line-height:10px;margin-top:2px;position:absolute}.lib-date .calendar-wrapper{max-width:350px;position:absolute;display:block;z-index:100;width:100%;overflow:auto;border-radius:8px;box-shadow:var(--main-card-shadow);background-color:var(--main-card-color)}.lib-date .calendar-wrapper.top{bottom:48px}\n"] }]
|
|
104
|
+
}], propDecorators: { topSide: [{
|
|
105
|
+
type: Input
|
|
106
|
+
}], dateId: [{
|
|
107
|
+
type: Input
|
|
108
|
+
}], placeholder: [{
|
|
109
|
+
type: Input
|
|
110
|
+
}], label: [{
|
|
111
|
+
type: Input
|
|
112
|
+
}], required: [{
|
|
113
|
+
type: Input
|
|
114
|
+
}] } });
|
|
115
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib-date-input.component.js","sourceRoot":"","sources":["../../../../../projects/dd-lib/src/lib/lib-date-input/lib-date-input.component.ts","../../../../../projects/dd-lib/src/lib/lib-date-input/lib-date-input.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAS,MAAM,eAAe,CAAC;AAC5F,OAAO,EAAC,qBAAqB,EAAE,WAAW,EAAE,eAAe,EAAE,aAAa,EAAE,QAAQ,EAAC,MAAM,SAAS,CAAC;AACrG,OAAO,EAAuB,WAAW,EAAE,iBAAiB,EAAC,MAAM,gBAAgB,CAAC;AACpF,OAAO,EAAC,kBAAkB,EAAC,MAAM,oCAAoC,CAAC;AACtE,OAAO,EAAC,mBAAmB,EAAC,MAAM,wCAAwC,CAAC;AAC3E,OAAO,EAAC,kBAAkB,EAAC,MAAM,oCAAoC,CAAC;AACtE,OAAO,EAAc,oBAAoB,EAAC,MAAM,wCAAwC,CAAC;AACzF,OAAO,EAAC,MAAM,EAAC,MAAM,UAAU,CAAC;AAChC,OAAO,EAAC,gBAAgB,EAAE,cAAc,EAAC,MAAM,UAAU,CAAC;AAC1D,OAAO,EAAC,QAAQ,EAAE,OAAO,EAAC,MAAM,iBAAiB,CAAC;;;AA+BlD,MAAM,OAAO,qBAAqB;IA7BlC;QAoCS,oBAAe,GAAG,KAAK,CAAA;QACvB,aAAQ,GAAG,KAAK,CAAA;QAEhB,iBAAY,GAAU,IAAI,IAAI,EAAE,CAAC;KAiEzC;aA1Ee,cAAS,GAAG,CAAC,AAAJ,CAAK;IAarB,QAAQ;QACb,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACjB,IAAI,CAAC,MAAM,GAAG,UAAU,GAAG,qBAAqB,CAAC,SAAS,EAAE,CAAC;QAC/D,CAAC;IACH,CAAC;IAGM,YAAY;QACjB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC9B,CAAC;IACH,CAAC;IAGM,aAAa;QAClB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;YACvB,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;QACnC,CAAC;QACD,IAAI,CAAC,eAAe,GAAG,KAAK,CAAA;IAE9B,CAAC;IAEM,SAAS,CAAC,MAAwB;QACvC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;QAC7B,IAAI,MAAM,EAAE,CAAC;YACX,IAAI,CAAC,eAAe,GAAG,GAAG,MAAM,CAAC,MAAM,EAAE,YAAY,CAAC,EAAE,CAAC;QAE3D,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;YAC9B,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;QACnC,CAAC;QACD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,CAAA;IACzC,CAAC;IAED,aAAa,CAAC,MAAc;QAC1B,MAAM,IAAI,GAAG,WAAW,CAAC,iBAAiB,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACnE,IAAI,IAAI,EAAE,CAAC;YACT,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QAC3B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;QAChC,CAAC;QACD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC1C,CAAC;IAEM,eAAe,CAAC,MAAwB;IAC/C,CAAC;IAEM,gBAAgB,CAAC,EAAO;QAC7B,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC5B,CAAC;IAEM,iBAAiB,CAAC,EAAO;QAC9B,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;IAC9B,CAAC;IAEM,UAAU,CAAC,MAAY;QAC5B,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC;QAC3B,IAAI,MAAM,EAAE,CAAC;YACX,IAAI,CAAC,eAAe,GAAG,GAAG,MAAM,CAAC,MAAM,EAAE,YAAY,CAAC,EAAE,CAAC;QAC3D,CAAC;IACH,CAAC;8GA1EU,qBAAqB;kGAArB,qBAAqB,oLAZrB;YACT,cAAc,EAAE;YAChB;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC;gBACpD,KAAK,EAAE,IAAI;aACZ;SACF,0BCnCH,k8CA2CA,wjDD3BI,WAAW,+mBAGX,mBAAmB,0GAEnB,qBAAqB,gHAErB,oBAAoB,gOACpB,gBAAgB,ijBAEhB,OAAO;;2FAcE,qBAAqB;kBA7BjC,SAAS;+BACE,mBAAmB,cACjB,IAAI,WACP;wBACP,eAAe;wBACf,WAAW;wBACX,aAAa;wBACb,kBAAkB;wBAClB,mBAAmB;wBACnB,QAAQ;wBACR,qBAAqB;wBACrB,kBAAkB;wBAClB,oBAAoB;wBACpB,gBAAgB;wBAChB,QAAQ;wBACR,OAAO;qBACR,aACU;wBACT,cAAc,EAAE;wBAChB;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,sBAAsB,CAAC;4BACpD,KAAK,EAAE,IAAI;yBACZ;qBACF,mBAGgB,uBAAuB,CAAC,MAAM;8BAI/B,OAAO;sBAAtB,KAAK;gBACU,MAAM;sBAArB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBACU,KAAK;sBAApB,KAAK;gBACU,QAAQ;sBAAvB,KAAK","sourcesContent":["import {ChangeDetectionStrategy, Component, forwardRef, Input, OnInit} from '@angular/core';\r\nimport {ClickOutsideDirective, DateService, FilterByKeyPipe, HighlightPipe, SafePipe} from \"../core\";\r\nimport {ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR} from \"@angular/forms\";\r\nimport {LibLoaderComponent} from \"../lib-loader/lib-loader.component\";\r\nimport {LibSvgIconComponent} from \"../lib-svg-icon/lib-svg-icon.component\";\r\nimport {LibPeriodComponent} from \"../lib-period/lib-period.component\";\r\nimport {IDatePeriod, LibCalendarComponent} from \"../lib-calendar/lib-calendar.component\";\r\nimport {format} from \"date-fns\";\r\nimport {NgxMaskDirective, provideNgxMask} from \"ngx-mask\";\r\nimport {JsonPipe, NgClass} from \"@angular/common\";\r\n\r\n@Component({\r\n  selector: 'dd-lib-date-input',\r\n  standalone: true,\r\n  imports: [\r\n    FilterByKeyPipe,\r\n    FormsModule,\r\n    HighlightPipe,\r\n    LibLoaderComponent,\r\n    LibSvgIconComponent,\r\n    SafePipe,\r\n    ClickOutsideDirective,\r\n    LibPeriodComponent,\r\n    LibCalendarComponent,\r\n    NgxMaskDirective,\r\n    JsonPipe,\r\n    NgClass\r\n  ],\r\n  providers: [\r\n    provideNgxMask(),\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => LibDateInputComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n  templateUrl: './lib-date-input.component.html',\r\n  styleUrl: './lib-date-input.component.scss',\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class LibDateInputComponent implements ControlValueAccessor, OnInit {\r\n  public static idCounter = 1;\r\n  @Input() public topSide?: boolean;\r\n  @Input() public dateId?: string;\r\n  @Input() public placeholder?: string;\r\n  @Input() public label?: string;\r\n  @Input() public required?: boolean;\r\n  public isShownCalendar = false\r\n  public disabled = false\r\n  public selectedDateStr?: string;\r\n  public selectedDate?: Date = new Date();\r\n  public onTouchedCallback?: (() => void);\r\n\r\n\r\n  public ngOnInit() {\r\n    if (!this.dateId) {\r\n      this.dateId = 'dd-date-' + LibDateInputComponent.idCounter++;\r\n    }\r\n  }\r\n\r\n\r\n  public openCalendar(): void {\r\n    if (!this.disabled) {\r\n      this.isShownCalendar = true;\r\n    }\r\n  }\r\n\r\n\r\n  public closeCalendar(): void {\r\n    if (!this.selectedDate) {\r\n      this.selectedDateStr = undefined;\r\n    }\r\n    this.isShownCalendar = false\r\n\r\n  }\r\n\r\n  public setPeriod($event: Date | undefined): void {\r\n    this.isShownCalendar = false;\r\n    if ($event) {\r\n      this.selectedDateStr = `${format($event, 'dd.MM.yyyy')}`;\r\n\r\n    } else {\r\n      this.selectedDate = undefined;\r\n      this.selectedDateStr = undefined;\r\n    }\r\n    this.propagateChange(this.selectedDate)\r\n  }\r\n\r\n  changeStrDate($event: string) {\r\n    const date = DateService.getDateFromString($event.substring(0, 8));\r\n    if (date) {\r\n      this.selectedDate = date;\r\n    } else {\r\n      this.selectedDate = undefined;\r\n    }\r\n    this.propagateChange(this.selectedDate);\r\n  }\r\n\r\n  public propagateChange(_value: Date | undefined): void {\r\n  }\r\n\r\n  public registerOnChange(fn: any): void {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: any): void {\r\n    this.onTouchedCallback = fn;\r\n  }\r\n\r\n  public writeValue($event: Date): void {\r\n    this.selectedDate = $event;\r\n    if ($event) {\r\n      this.selectedDateStr = `${format($event, 'dd.MM.yyyy')}`;\r\n    }\r\n  }\r\n}\r\n","<div class=\"lib-date\" id=\"lib-date-{{ dateId }}\">\r\n  @if (label) {\r\n    <label [for]=\"dateId\" class=\"lib-date__title\">\r\n      {{ label }}\r\n      @if (required) {\r\n        <dd-lib-svg-icon icon=\"error_hint\"></dd-lib-svg-icon>\r\n      }\r\n    </label>\r\n  }\r\n  <div class=\"pos-relative\">\r\n    <input\r\n      [attr.id]=\"dateId\"\r\n      [attr.placeholder]=\"placeholder\"\r\n      (click)=\"openCalendar()\"\r\n      [(ngModel)]=\"selectedDateStr\"\r\n      [mask]=\"'d0.M0.0000'\"\r\n      (ngModelChange)=\"changeStrDate($event)\"\r\n      [leadZeroDateTime]=\"true\"\r\n      class=\"text-select\"/>\r\n    @if (!selectedDateStr) {\r\n      <dd-lib-svg-icon [class.gray-svg]=\"!isShownCalendar\"\r\n                       (click)=\"openCalendar()\"\r\n                       id=\"calendar-{{ dateId }}\"\r\n                       class=\"calendar\" icon=\"calendar\"></dd-lib-svg-icon>\r\n\r\n\r\n    } @else {\r\n      <dd-lib-svg-icon\r\n        (click)=\"setPeriod(undefined)\"\r\n        class=\"clear\"\r\n        icon=\"clear\"></dd-lib-svg-icon>\r\n\r\n    }\r\n  </div>\r\n  @if (isShownCalendar) {\r\n    <div\r\n      (ddClickOutside)=\"closeCalendar()\"\r\n      [elements]=\"['lib-date-' + dateId, 'calendar' + dateId]\"\r\n      class=\"calendar-wrapper\" [ngClass]=\"{top: topSide}\">\r\n      <dd-lib-calendar [(ngModel)]=\"selectedDate\" (emitDate)=\"setPeriod($event)\"></dd-lib-calendar>\r\n    </div>\r\n  }\r\n</div>\r\n"]}
|
|
@@ -110,4 +110,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImpor
|
|
|
110
110
|
}], required: [{
|
|
111
111
|
type: Input
|
|
112
112
|
}] } });
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib-date-range.component.js","sourceRoot":"","sources":["../../../../../projects/dd-lib/src/lib/lib-date-range/lib-date-range.component.ts","../../../../../projects/dd-lib/src/lib/lib-date-range/lib-date-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, forwardRef, Input, OnInit} from '@angular/core';\r\nimport {ClickOutsideDirective, DateService, FilterByKeyPipe, HighlightPipe, SafePipe} from \"../core\";\r\nimport {ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR} from \"@angular/forms\";\r\nimport {LibLoaderComponent} from \"../lib-loader/lib-loader.component\";\r\nimport {LibSvgIconComponent} from \"../lib-svg-icon/lib-svg-icon.component\";\r\nimport {LibPeriodComponent} from \"../lib-period/lib-period.component\";\r\nimport {IDatePeriod, LibCalendarComponent} from \"../lib-calendar/lib-calendar.component\";\r\nimport {format} from \"date-fns\";\r\nimport {NgxMaskDirective, provideNgxMask} from \"ngx-mask\";\r\nimport {JsonPipe} from \"@angular/common\";\r\n\r\n@Component({\r\n  selector: 'dd-lib-date-range',\r\n  standalone: true,\r\n  imports: [\r\n    FilterByKeyPipe,\r\n    FormsModule,\r\n    HighlightPipe,\r\n    LibLoaderComponent,\r\n    LibSvgIconComponent,\r\n    SafePipe,\r\n    ClickOutsideDirective,\r\n    LibPeriodComponent,\r\n    LibCalendarComponent,\r\n    NgxMaskDirective,\r\n    JsonPipe\r\n  ],\r\n  providers: [\r\n    provideNgxMask(),\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => LibDateRangeComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n  templateUrl: './lib-date-range.component.html',\r\n  styleUrl: './lib-date-range.component.scss',\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class LibDateRangeComponent implements ControlValueAccessor, OnInit {\r\n  public static idCounter = 1;\r\n  @Input() public rangeId: string | undefined;\r\n  @Input() public placeholder: string | undefined;\r\n  @Input() public label: string  | undefined;\r\n  @Input() public required: boolean  | undefined;\r\n  public isShownPeriod = false\r\n  public disabled = false\r\n  public selectedPeriodStr: string | undefined;\r\n  public selectedPeriod: IDatePeriod | undefined = {start: new Date(), end: new Date()};\r\n  public onTouchedCallback: (() => void) | undefined;\r\n\r\n\r\n  public ngOnInit() {\r\n    if (!this.rangeId) {\r\n      this.rangeId = 'dd-range-' + LibDateRangeComponent.idCounter++;\r\n    }\r\n  }\r\n\r\n\r\n  public openCalendar(): void {\r\n    if (!this.disabled) {\r\n      this.isShownPeriod = true;\r\n    }\r\n  }\r\n\r\n\r\n  public closeCalendar(): void {\r\n    if (!this.selectedPeriod) {\r\n      this.selectedPeriodStr = undefined;\r\n    }\r\n    this.isShownPeriod = false\r\n\r\n  }\r\n\r\n  setPeriod($event: IDatePeriod | undefined) {\r\n    this.isShownPeriod = false;\r\n    if ($event) {\r\n      this.selectedPeriodStr = `${format($event?.start!, 'dd.MM.yyyy')} - ${format($event?.end!, 'dd.MM.yyyy')}`;\r\n\r\n    } else {\r\n      this.selectedPeriod = undefined;\r\n      this.selectedPeriodStr = undefined;\r\n    }\r\n    this.propagateChange(this.selectedPeriod)\r\n  }\r\n\r\n  changeStrDate($event: string) {\r\n    const start = DateService.getDateFromString($event.substring(0, 8));\r\n    const end = DateService.getDateFromString($event.substring(8, 16));\r\n    if (start && end) {\r\n      this.selectedPeriod = {start, end};\r\n    } else {\r\n      this.selectedPeriod = undefined;\r\n    }\r\n    this.propagateChange(this.selectedPeriod);\r\n  }\r\n\r\n  public propagateChange(_value: IDatePeriod | undefined): void {\r\n  }\r\n\r\n  public registerOnChange(fn: any): void {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: any): void {\r\n    this.onTouchedCallback = fn;\r\n  }\r\n\r\n  public writeValue($event: IDatePeriod): void {\r\n    this.selectedPeriod = $event;\r\n    if ($event?.start && $event?.end) {\r\n      this.selectedPeriodStr = `${format($event?.start!, 'dd.MM.yyyy')} - ${format($event?.end!, 'dd.MM.yyyy')}`;\r\n    }\r\n  }\r\n}\r\n","<div class=\"lib-range\" id=\"lib-range-{{ rangeId }}\">\r\n  @if (label) {\r\n    <label [for]=\"rangeId\" class=\"lib-range__title\">\r\n      {{ label }}\r\n      @if (required) {\r\n        <dd-lib-svg-icon icon=\"error_hint\"></dd-lib-svg-icon>\r\n      }\r\n    </label>\r\n  }\r\n  <div class=\"pos-relative\">\r\n    <input\r\n      [attr.id]=\"rangeId\"\r\n      [attr.placeholder]=\"placeholder\"\r\n      (click)=\"openCalendar()\"\r\n      [(ngModel)]=\"selectedPeriodStr\"\r\n      [mask]=\"'d0.M0.0000 - d0.M0.0000'\"\r\n      (ngModelChange)=\"changeStrDate($event)\"\r\n      [leadZeroDateTime]=\"true\"\r\n      class=\"text-select\"/>\r\n    @if (!selectedPeriodStr) {\r\n      <dd-lib-svg-icon [class.gray-svg]=\"!isShownPeriod\"\r\n                       (click)=\"openCalendar()\"\r\n                       id=\"calendar-{{ rangeId }}\"\r\n                       class=\"calendar\" icon=\"calendar\"></dd-lib-svg-icon>\r\n\r\n\r\n    } @else {\r\n      <dd-lib-svg-icon\r\n        (click)=\"setPeriod(undefined)\"\r\n        class=\"clear\"\r\n        icon=\"clear\"></dd-lib-svg-icon>\r\n\r\n    }\r\n  </div>\r\n  @if (isShownPeriod) {\r\n    <div\r\n      (ddClickOutside)=\"closeCalendar()\"\r\n      [elements]=\"['lib-range-' + rangeId, 'calendar' + rangeId]\"\r\n      class=\"calendar-wrapper\">\r\n      <dd-lib-calendar [(ngModel)]=\"selectedPeriod\" [rangeMode]=\"true\" (emitPeriod)=\"setPeriod($event)\"></dd-lib-calendar>\r\n    </div>\r\n  }\r\n</div>\r\n"]}
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib-date-range.component.js","sourceRoot":"","sources":["../../../../../projects/dd-lib/src/lib/lib-date-range/lib-date-range.component.ts","../../../../../projects/dd-lib/src/lib/lib-date-range/lib-date-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, forwardRef, Input, OnInit} from '@angular/core';\r\nimport {ClickOutsideDirective, DateService, FilterByKeyPipe, HighlightPipe, SafePipe} from \"../core\";\r\nimport {ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR} from \"@angular/forms\";\r\nimport {LibLoaderComponent} from \"../lib-loader/lib-loader.component\";\r\nimport {LibSvgIconComponent} from \"../lib-svg-icon/lib-svg-icon.component\";\r\nimport {LibPeriodComponent} from \"../lib-period/lib-period.component\";\r\nimport {IDatePeriod, LibCalendarComponent} from \"../lib-calendar/lib-calendar.component\";\r\nimport {format} from \"date-fns\";\r\nimport {NgxMaskDirective, provideNgxMask} from \"ngx-mask\";\r\nimport {JsonPipe} from \"@angular/common\";\r\n\r\n@Component({\r\n  selector: 'dd-lib-date-range',\r\n  standalone: true,\r\n  imports: [\r\n    FilterByKeyPipe,\r\n    FormsModule,\r\n    HighlightPipe,\r\n    LibLoaderComponent,\r\n    LibSvgIconComponent,\r\n    SafePipe,\r\n    ClickOutsideDirective,\r\n    LibPeriodComponent,\r\n    LibCalendarComponent,\r\n    NgxMaskDirective,\r\n    JsonPipe\r\n  ],\r\n  providers: [\r\n    provideNgxMask(),\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => LibDateRangeComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n  templateUrl: './lib-date-range.component.html',\r\n  styleUrl: './lib-date-range.component.scss',\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class LibDateRangeComponent implements ControlValueAccessor, OnInit {\r\n  public static idCounter = 1;\r\n  @Input() public rangeId: string | undefined;\r\n  @Input() public placeholder: string | undefined;\r\n  @Input() public label: string  | undefined;\r\n  @Input() public required: boolean  | undefined;\r\n  public isShownPeriod = false\r\n  public disabled = false\r\n  public selectedPeriodStr: string | undefined;\r\n  public selectedPeriod: IDatePeriod | undefined = {start: new Date(), end: new Date()};\r\n  public onTouchedCallback: (() => void) | undefined;\r\n\r\n\r\n  public ngOnInit() {\r\n    if (!this.rangeId) {\r\n      this.rangeId = 'dd-range-' + LibDateRangeComponent.idCounter++;\r\n    }\r\n  }\r\n\r\n\r\n  public openCalendar(): void {\r\n    if (!this.disabled) {\r\n      this.isShownPeriod = true;\r\n    }\r\n  }\r\n\r\n\r\n  public closeCalendar(): void {\r\n    if (!this.selectedPeriod) {\r\n      this.selectedPeriodStr = undefined;\r\n    }\r\n    this.isShownPeriod = false\r\n\r\n  }\r\n\r\n  public setPeriod($event: IDatePeriod | undefined): void {\r\n    this.isShownPeriod = false;\r\n    if ($event) {\r\n      this.selectedPeriodStr = `${format($event?.start!, 'dd.MM.yyyy')} - ${format($event?.end!, 'dd.MM.yyyy')}`;\r\n\r\n    } else {\r\n      this.selectedPeriod = undefined;\r\n      this.selectedPeriodStr = undefined;\r\n    }\r\n    this.propagateChange(this.selectedPeriod)\r\n  }\r\n\r\n public changeStrDate($event: string): void {\r\n    const start = DateService.getDateFromString($event.substring(0, 8));\r\n    const end = DateService.getDateFromString($event.substring(8, 16));\r\n    if (start && end) {\r\n      this.selectedPeriod = {start, end};\r\n    } else {\r\n      this.selectedPeriod = undefined;\r\n    }\r\n    this.propagateChange(this.selectedPeriod);\r\n  }\r\n\r\n  public propagateChange(_value: IDatePeriod | undefined): void {\r\n  }\r\n\r\n  public registerOnChange(fn: any): void {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: any): void {\r\n    this.onTouchedCallback = fn;\r\n  }\r\n\r\n  public writeValue($event: IDatePeriod): void {\r\n    this.selectedPeriod = $event;\r\n    if ($event?.start && $event?.end) {\r\n      this.selectedPeriodStr = `${format($event?.start!, 'dd.MM.yyyy')} - ${format($event?.end!, 'dd.MM.yyyy')}`;\r\n    }\r\n  }\r\n}\r\n","<div class=\"lib-range\" id=\"lib-range-{{ rangeId }}\">\r\n  @if (label) {\r\n    <label [for]=\"rangeId\" class=\"lib-range__title\">\r\n      {{ label }}\r\n      @if (required) {\r\n        <dd-lib-svg-icon icon=\"error_hint\"></dd-lib-svg-icon>\r\n      }\r\n    </label>\r\n  }\r\n  <div class=\"pos-relative\">\r\n    <input\r\n      [attr.id]=\"rangeId\"\r\n      [attr.placeholder]=\"placeholder\"\r\n      (click)=\"openCalendar()\"\r\n      [(ngModel)]=\"selectedPeriodStr\"\r\n      [mask]=\"'d0.M0.0000 - d0.M0.0000'\"\r\n      (ngModelChange)=\"changeStrDate($event)\"\r\n      [leadZeroDateTime]=\"true\"\r\n      class=\"text-select\"/>\r\n    @if (!selectedPeriodStr) {\r\n      <dd-lib-svg-icon [class.gray-svg]=\"!isShownPeriod\"\r\n                       (click)=\"openCalendar()\"\r\n                       id=\"calendar-{{ rangeId }}\"\r\n                       class=\"calendar\" icon=\"calendar\"></dd-lib-svg-icon>\r\n\r\n\r\n    } @else {\r\n      <dd-lib-svg-icon\r\n        (click)=\"setPeriod(undefined)\"\r\n        class=\"clear\"\r\n        icon=\"clear\"></dd-lib-svg-icon>\r\n\r\n    }\r\n  </div>\r\n  @if (isShownPeriod) {\r\n    <div\r\n      (ddClickOutside)=\"closeCalendar()\"\r\n      [elements]=\"['lib-range-' + rangeId, 'calendar' + rangeId]\"\r\n      class=\"calendar-wrapper\">\r\n      <dd-lib-calendar [(ngModel)]=\"selectedPeriod\" [rangeMode]=\"true\" (emitPeriod)=\"setPeriod($event)\"></dd-lib-calendar>\r\n    </div>\r\n  }\r\n</div>\r\n"]}
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -30,10 +30,11 @@ export * from './lib/lib-tabs-fragment/lib-tabs-fragment.component';
|
|
|
30
30
|
export * from './lib/lib-textarea/lib-textarea.component';
|
|
31
31
|
export * from './lib/lib-file-loader/lib-file-loader.component';
|
|
32
32
|
export * from './lib/lib-date-range/lib-date-range.component';
|
|
33
|
+
export * from './lib/lib-date-input/lib-date-input.component';
|
|
33
34
|
export * from './lib/lib-filter/lib-filter.component';
|
|
34
35
|
export * from './lib/lib-info-card/lib-info-card.component';
|
|
35
36
|
export * from './lib/utils/decorators';
|
|
36
37
|
export * from './lib/core/index';
|
|
37
38
|
export * from './lib/components/index';
|
|
38
39
|
export * from './lib/svg-icons/svg-icon.model';
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2RkLWxpYi9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLENBQUMsR0FBRyxJQUFJLENBQUE7QUFDckIsYUFBYTtBQUNiLGNBQWMsZ0NBQWdDLENBQUE7QUFDOUMsY0FBYyxvQ0FBb0MsQ0FBQTtBQUNsRCxjQUFjLHVDQUF1QyxDQUFBO0FBQ3JELGNBQWMsdUNBQXVDLENBQUE7QUFDckQsY0FBYyw2Q0FBNkMsQ0FBQTtBQUMzRCxjQUFjLGlEQUFpRCxDQUFBO0FBQy9ELGNBQWMsMkNBQTJDLENBQUE7QUFDekQsY0FBYyxtQ0FBbUMsQ0FBQTtBQUNqRCxjQUFjLDJDQUEyQyxDQUFBO0FBQ3pELGNBQWMscURBQXFELENBQUE7QUFDbkUsY0FBYyxpREFBaUQsQ0FBQTtBQUMvRCxjQUFjLHFEQUFxRCxDQUFBO0FBQ25FLGNBQWMsbURBQW1ELENBQUE7QUFDakUsY0FBYyxxQ0FBcUMsQ0FBQTtBQUNuRCxjQUFjLHVDQUF1QyxDQUFBO0FBQ3JELGNBQWMscUNBQXFDLENBQUE7QUFDbkQsY0FBYyxtREFBbUQsQ0FBQTtBQUNqRSxjQUFjLHVDQUF1QyxDQUFBO0FBQ3JELGNBQWMsMkNBQTJDLENBQUE7QUFDekQsY0FBYyxtQ0FBbUMsQ0FBQTtBQUNqRCxjQUFjLG1DQUFtQyxDQUFBO0FBQ2pELGNBQWMsaUNBQWlDLENBQUE7QUFDL0MsY0FBYywyQ0FBMkMsQ0FBQTtBQUN6RCxjQUFjLHFEQUFxRCxDQUFBO0FBQ25FLGNBQWMsMkNBQTJDLENBQUE7QUFDekQsY0FBYyxpREFBaUQsQ0FBQTtBQUMvRCxjQUFjLCtDQUErQyxDQUFBO0FBQzdELGNBQWMsK0NBQStDLENBQUE7QUFDN0QsY0FBYyx1Q0FBdUMsQ0FBQTtBQUNyRCxjQUFjLDZDQUE2QyxDQUFBO0FBRTNELGNBQWMsd0JBQXdCLENBQUE7QUFHdEMsY0FBYyxrQkFBa0IsQ0FBQTtBQUNoQyxjQUFjLHdCQUF3QixDQUFBO0FBQ3RDLGNBQWMsZ0NBQWdDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgZGQtbGliXHJcbiAqL1xyXG5leHBvcnQgY29uc3QgdCA9IHRydWVcclxuLy8gY29tcG9uZW50c1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21tb24vbGliLWNvbW1vbi1idXR0b24nXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbW1vbi9saWItY29tbW9uLWlucHV0LXRleHQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1sb2FkZXIvbGliLWxvYWRlci5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1idXR0b24vbGliLWJ1dHRvbi5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1hY2NvcmRpb24vbGliLWFjY29yZGlvbi5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1iYWNrLWJ1dHRvbi9saWItYmFjay1idXR0b24uY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItY2FsZW5kYXIvbGliLWNhbGVuZGFyLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLWNhcmQvbGliLWNhcmQuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItY2hlY2tib3gvbGliLWNoZWNrYm94LmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLWNvbW1lbnQtaW5wdXQvbGliLWNvbW1lbnQtaW5wdXQuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItZmlsZS11cGxvYWQvbGliLWZpbGUtdXBsb2FkLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLWZpbHRlci1idXR0b24vbGliLWZpbHRlci1idXR0b24uY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItaW1hZ2UtbG9hZGVyL2xpYi1pbWFnZS1sb2FkZXIuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItaW5wdXQvbGliLWlucHV0LmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLXBlcmlvZC9saWItcGVyaW9kLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLXJhZGlvL2xpYi1yYWRpby5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1zZWFyY2gtaW5wdXQvbGliLXNlYXJjaC1pbnB1dC5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1zZWxlY3QvbGliLXNlbGVjdC5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1za2VsZXRvbi9saWItc2tlbGV0b24uY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItc29ydC9saWItc29ydC5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1zdGVwL2xpYi1zdGVwLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLXN2Zy9saWItc3ZnLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLXN2Zy1pY29uL2xpYi1zdmctaWNvbi5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi10YWJzLWZyYWdtZW50L2xpYi10YWJzLWZyYWdtZW50LmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLXRleHRhcmVhL2xpYi10ZXh0YXJlYS5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1maWxlLWxvYWRlci9saWItZmlsZS1sb2FkZXIuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItZGF0ZS1yYW5nZS9saWItZGF0ZS1yYW5nZS5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1kYXRlLWlucHV0L2xpYi1kYXRlLWlucHV0LmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLWZpbHRlci9saWItZmlsdGVyLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLWluZm8tY2FyZC9saWItaW5mby1jYXJkLmNvbXBvbmVudCdcclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL2RlY29yYXRvcnMnXHJcblxyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29yZS9pbmRleCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9pbmRleCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc3ZnLWljb25zL3N2Zy1pY29uLm1vZGVsJ1xyXG5cclxuIl19
|