@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.
@@ -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":"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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, 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"]}
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2RkLWxpYi9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLENBQUMsR0FBRyxJQUFJLENBQUE7QUFDckIsYUFBYTtBQUNiLGNBQWMsZ0NBQWdDLENBQUE7QUFDOUMsY0FBYyxvQ0FBb0MsQ0FBQTtBQUNsRCxjQUFjLHVDQUF1QyxDQUFBO0FBQ3JELGNBQWMsdUNBQXVDLENBQUE7QUFDckQsY0FBYyw2Q0FBNkMsQ0FBQTtBQUMzRCxjQUFjLGlEQUFpRCxDQUFBO0FBQy9ELGNBQWMsMkNBQTJDLENBQUE7QUFDekQsY0FBYyxtQ0FBbUMsQ0FBQTtBQUNqRCxjQUFjLDJDQUEyQyxDQUFBO0FBQ3pELGNBQWMscURBQXFELENBQUE7QUFDbkUsY0FBYyxpREFBaUQsQ0FBQTtBQUMvRCxjQUFjLHFEQUFxRCxDQUFBO0FBQ25FLGNBQWMsbURBQW1ELENBQUE7QUFDakUsY0FBYyxxQ0FBcUMsQ0FBQTtBQUNuRCxjQUFjLHVDQUF1QyxDQUFBO0FBQ3JELGNBQWMscUNBQXFDLENBQUE7QUFDbkQsY0FBYyxtREFBbUQsQ0FBQTtBQUNqRSxjQUFjLHVDQUF1QyxDQUFBO0FBQ3JELGNBQWMsMkNBQTJDLENBQUE7QUFDekQsY0FBYyxtQ0FBbUMsQ0FBQTtBQUNqRCxjQUFjLG1DQUFtQyxDQUFBO0FBQ2pELGNBQWMsaUNBQWlDLENBQUE7QUFDL0MsY0FBYywyQ0FBMkMsQ0FBQTtBQUN6RCxjQUFjLHFEQUFxRCxDQUFBO0FBQ25FLGNBQWMsMkNBQTJDLENBQUE7QUFDekQsY0FBYyxpREFBaUQsQ0FBQTtBQUMvRCxjQUFjLCtDQUErQyxDQUFBO0FBQzdELGNBQWMsdUNBQXVDLENBQUE7QUFDckQsY0FBYyw2Q0FBNkMsQ0FBQTtBQUUzRCxjQUFjLHdCQUF3QixDQUFBO0FBR3RDLGNBQWMsa0JBQWtCLENBQUE7QUFDaEMsY0FBYyx3QkFBd0IsQ0FBQTtBQUN0QyxjQUFjLGdDQUFnQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGRkLWxpYlxyXG4gKi9cclxuZXhwb3J0IGNvbnN0IHQgPSB0cnVlXHJcbi8vIGNvbXBvbmVudHNcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tbW9uL2xpYi1jb21tb24tYnV0dG9uJ1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21tb24vbGliLWNvbW1vbi1pbnB1dC10ZXh0J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItbG9hZGVyL2xpYi1sb2FkZXIuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItYnV0dG9uL2xpYi1idXR0b24uY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItYWNjb3JkaW9uL2xpYi1hY2NvcmRpb24uY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItYmFjay1idXR0b24vbGliLWJhY2stYnV0dG9uLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLWNhbGVuZGFyL2xpYi1jYWxlbmRhci5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1jYXJkL2xpYi1jYXJkLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLWNoZWNrYm94L2xpYi1jaGVja2JveC5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1jb21tZW50LWlucHV0L2xpYi1jb21tZW50LWlucHV0LmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLWZpbGUtdXBsb2FkL2xpYi1maWxlLXVwbG9hZC5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1maWx0ZXItYnV0dG9uL2xpYi1maWx0ZXItYnV0dG9uLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLWltYWdlLWxvYWRlci9saWItaW1hZ2UtbG9hZGVyLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLWlucHV0L2xpYi1pbnB1dC5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1wZXJpb2QvbGliLXBlcmlvZC5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1yYWRpby9saWItcmFkaW8uY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItc2VhcmNoLWlucHV0L2xpYi1zZWFyY2gtaW5wdXQuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItc2VsZWN0L2xpYi1zZWxlY3QuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItc2tlbGV0b24vbGliLXNrZWxldG9uLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLXNvcnQvbGliLXNvcnQuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItc3RlcC9saWItc3RlcC5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1zdmcvbGliLXN2Zy5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1zdmctaWNvbi9saWItc3ZnLWljb24uY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItdGFicy1mcmFnbWVudC9saWItdGFicy1mcmFnbWVudC5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi10ZXh0YXJlYS9saWItdGV4dGFyZWEuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItZmlsZS1sb2FkZXIvbGliLWZpbGUtbG9hZGVyLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLWRhdGUtcmFuZ2UvbGliLWRhdGUtcmFuZ2UuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItZmlsdGVyL2xpYi1maWx0ZXIuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItaW5mby1jYXJkL2xpYi1pbmZvLWNhcmQuY29tcG9uZW50J1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdXRpbHMvZGVjb3JhdG9ycydcclxuXHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb3JlL2luZGV4J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2luZGV4J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zdmctaWNvbnMvc3ZnLWljb24ubW9kZWwnXHJcblxyXG4iXX0=
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2RkLWxpYi9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLENBQUMsR0FBRyxJQUFJLENBQUE7QUFDckIsYUFBYTtBQUNiLGNBQWMsZ0NBQWdDLENBQUE7QUFDOUMsY0FBYyxvQ0FBb0MsQ0FBQTtBQUNsRCxjQUFjLHVDQUF1QyxDQUFBO0FBQ3JELGNBQWMsdUNBQXVDLENBQUE7QUFDckQsY0FBYyw2Q0FBNkMsQ0FBQTtBQUMzRCxjQUFjLGlEQUFpRCxDQUFBO0FBQy9ELGNBQWMsMkNBQTJDLENBQUE7QUFDekQsY0FBYyxtQ0FBbUMsQ0FBQTtBQUNqRCxjQUFjLDJDQUEyQyxDQUFBO0FBQ3pELGNBQWMscURBQXFELENBQUE7QUFDbkUsY0FBYyxpREFBaUQsQ0FBQTtBQUMvRCxjQUFjLHFEQUFxRCxDQUFBO0FBQ25FLGNBQWMsbURBQW1ELENBQUE7QUFDakUsY0FBYyxxQ0FBcUMsQ0FBQTtBQUNuRCxjQUFjLHVDQUF1QyxDQUFBO0FBQ3JELGNBQWMscUNBQXFDLENBQUE7QUFDbkQsY0FBYyxtREFBbUQsQ0FBQTtBQUNqRSxjQUFjLHVDQUF1QyxDQUFBO0FBQ3JELGNBQWMsMkNBQTJDLENBQUE7QUFDekQsY0FBYyxtQ0FBbUMsQ0FBQTtBQUNqRCxjQUFjLG1DQUFtQyxDQUFBO0FBQ2pELGNBQWMsaUNBQWlDLENBQUE7QUFDL0MsY0FBYywyQ0FBMkMsQ0FBQTtBQUN6RCxjQUFjLHFEQUFxRCxDQUFBO0FBQ25FLGNBQWMsMkNBQTJDLENBQUE7QUFDekQsY0FBYyxpREFBaUQsQ0FBQTtBQUMvRCxjQUFjLCtDQUErQyxDQUFBO0FBQzdELGNBQWMsK0NBQStDLENBQUE7QUFDN0QsY0FBYyx1Q0FBdUMsQ0FBQTtBQUNyRCxjQUFjLDZDQUE2QyxDQUFBO0FBRTNELGNBQWMsd0JBQXdCLENBQUE7QUFHdEMsY0FBYyxrQkFBa0IsQ0FBQTtBQUNoQyxjQUFjLHdCQUF3QixDQUFBO0FBQ3RDLGNBQWMsZ0NBQWdDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgZGQtbGliXHJcbiAqL1xyXG5leHBvcnQgY29uc3QgdCA9IHRydWVcclxuLy8gY29tcG9uZW50c1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21tb24vbGliLWNvbW1vbi1idXR0b24nXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbW1vbi9saWItY29tbW9uLWlucHV0LXRleHQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1sb2FkZXIvbGliLWxvYWRlci5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1idXR0b24vbGliLWJ1dHRvbi5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1hY2NvcmRpb24vbGliLWFjY29yZGlvbi5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1iYWNrLWJ1dHRvbi9saWItYmFjay1idXR0b24uY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItY2FsZW5kYXIvbGliLWNhbGVuZGFyLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLWNhcmQvbGliLWNhcmQuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItY2hlY2tib3gvbGliLWNoZWNrYm94LmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLWNvbW1lbnQtaW5wdXQvbGliLWNvbW1lbnQtaW5wdXQuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItZmlsZS11cGxvYWQvbGliLWZpbGUtdXBsb2FkLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLWZpbHRlci1idXR0b24vbGliLWZpbHRlci1idXR0b24uY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItaW1hZ2UtbG9hZGVyL2xpYi1pbWFnZS1sb2FkZXIuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItaW5wdXQvbGliLWlucHV0LmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLXBlcmlvZC9saWItcGVyaW9kLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLXJhZGlvL2xpYi1yYWRpby5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1zZWFyY2gtaW5wdXQvbGliLXNlYXJjaC1pbnB1dC5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1zZWxlY3QvbGliLXNlbGVjdC5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1za2VsZXRvbi9saWItc2tlbGV0b24uY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItc29ydC9saWItc29ydC5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1zdGVwL2xpYi1zdGVwLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLXN2Zy9saWItc3ZnLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLXN2Zy1pY29uL2xpYi1zdmctaWNvbi5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi10YWJzLWZyYWdtZW50L2xpYi10YWJzLWZyYWdtZW50LmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLXRleHRhcmVhL2xpYi10ZXh0YXJlYS5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1maWxlLWxvYWRlci9saWItZmlsZS1sb2FkZXIuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9saWItZGF0ZS1yYW5nZS9saWItZGF0ZS1yYW5nZS5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xpYi1kYXRlLWlucHV0L2xpYi1kYXRlLWlucHV0LmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLWZpbHRlci9saWItZmlsdGVyLmNvbXBvbmVudCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvbGliLWluZm8tY2FyZC9saWItaW5mby1jYXJkLmNvbXBvbmVudCdcclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL2RlY29yYXRvcnMnXHJcblxyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29yZS9pbmRleCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9pbmRleCdcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvc3ZnLWljb25zL3N2Zy1pY29uLm1vZGVsJ1xyXG5cclxuIl19