@recursyve/nice-ui-kit.v2 13.2.0-beta.110 → 13.2.0-beta.112

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.
Files changed (36) hide show
  1. package/esm2020/lib/components/date-range-picker/components/header/header.component.mjs +57 -0
  2. package/esm2020/lib/components/date-range-picker/components/range-preset/range-preset.component.mjs +107 -0
  3. package/esm2020/lib/components/date-range-picker/date-range-picker.component.mjs +74 -0
  4. package/esm2020/lib/components/date-range-picker/date-range-picker.module.mjs +58 -0
  5. package/esm2020/lib/components/date-range-picker/index.mjs +2 -0
  6. package/esm2020/lib/components/date-range-picker/providers/date-range-picker.service.mjs +17 -0
  7. package/esm2020/lib/components/date-range-picker/public-api.mjs +3 -0
  8. package/esm2020/lib/components/navigation/directives/show-hint.directive.mjs +164 -0
  9. package/esm2020/lib/components/navigation/navigation.module.mjs +9 -3
  10. package/esm2020/lib/components/navigation/navigation.types.mjs +1 -1
  11. package/esm2020/lib/components/navigation/pipes/should-show-hint.pipe.mjs +32 -0
  12. package/esm2020/lib/components/navigation/providers/hint.resolver.mjs +3 -0
  13. package/esm2020/lib/components/navigation/vertical/components/basic/basic.component.mjs +6 -4
  14. package/esm2020/lib/components/navigation/vertical/components/collapsable/collapsable.component.mjs +5 -4
  15. package/esm2020/lib/components/public-api.mjs +2 -1
  16. package/fesm2015/recursyve-nice-ui-kit.v2.mjs +4203 -3748
  17. package/fesm2015/recursyve-nice-ui-kit.v2.mjs.map +1 -1
  18. package/fesm2020/recursyve-nice-ui-kit.v2.mjs +4292 -3841
  19. package/fesm2020/recursyve-nice-ui-kit.v2.mjs.map +1 -1
  20. package/lib/components/date-range-picker/components/header/header.component.d.ts +20 -0
  21. package/lib/components/date-range-picker/components/range-preset/range-preset.component.d.ts +23 -0
  22. package/lib/components/date-range-picker/date-range-picker.component.d.ts +26 -0
  23. package/lib/components/date-range-picker/date-range-picker.module.d.ts +18 -0
  24. package/lib/components/date-range-picker/index.d.ts +1 -0
  25. package/lib/components/date-range-picker/providers/date-range-picker.service.d.ts +8 -0
  26. package/lib/components/date-range-picker/public-api.d.ts +2 -0
  27. package/lib/components/navigation/directives/show-hint.directive.d.ts +34 -0
  28. package/lib/components/navigation/navigation.module.d.ts +12 -10
  29. package/lib/components/navigation/navigation.types.d.ts +6 -0
  30. package/lib/components/navigation/pipes/should-show-hint.pipe.d.ts +12 -0
  31. package/lib/components/navigation/providers/hint.resolver.d.ts +4 -0
  32. package/lib/components/public-api.d.ts +1 -0
  33. package/package.json +1 -1
  34. package/src/lib/components/date-range-picker/date-range-picker.theme.scss +47 -0
  35. package/src/lib/components/navigation/vertical/styles/appearances/default.theme.scss +38 -0
  36. package/src/lib/nice.theme.scss +2 -0
@@ -0,0 +1,57 @@
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Inject } from "@angular/core";
2
+ import { DateAdapter, MAT_DATE_FORMATS } from "@angular/material/core";
3
+ import { MatCalendar } from "@angular/material/datepicker";
4
+ import { Subject } from "rxjs";
5
+ import { takeUntil } from "rxjs/operators";
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/material/datepicker";
8
+ import * as i2 from "@angular/material/core";
9
+ import * as i3 from "../range-preset/range-preset.component";
10
+ import * as i4 from "@angular/material/button";
11
+ import * as i5 from "@angular/material/icon";
12
+ import * as i6 from "@angular/common";
13
+ export class HeaderComponent {
14
+ constructor(calendar, dateAdapter, dateFormats, cdr) {
15
+ this.calendar = calendar;
16
+ this.dateAdapter = dateAdapter;
17
+ this.dateFormats = dateFormats;
18
+ this.destroy$ = new Subject();
19
+ this.toggled = false;
20
+ calendar.stateChanges
21
+ .pipe(takeUntil(this.destroy$))
22
+ .subscribe(() => cdr.markForCheck());
23
+ }
24
+ get periodLabel() {
25
+ return this.dateAdapter
26
+ .format(this.calendar.activeDate, this.dateFormats.display.monthYearLabel)
27
+ .toLocaleUpperCase();
28
+ }
29
+ previousClicked(mode) {
30
+ this.changeDate(mode, -1);
31
+ }
32
+ nextClicked(mode) {
33
+ this.changeDate(mode, 1);
34
+ }
35
+ changeDate(mode, amount) {
36
+ this.calendar.activeDate =
37
+ mode === "month"
38
+ ? this.dateAdapter.addCalendarMonths(this.calendar.activeDate, amount)
39
+ : this.dateAdapter.addCalendarYears(this.calendar.activeDate, amount);
40
+ }
41
+ clickOptions() {
42
+ this.toggled = !this.toggled;
43
+ }
44
+ ngOnDestroy() {
45
+ this.destroy$.next();
46
+ }
47
+ }
48
+ HeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: HeaderComponent, deps: [{ token: i1.MatCalendar }, { token: i2.DateAdapter }, { token: MAT_DATE_FORMATS }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
49
+ HeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.3", type: HeaderComponent, selector: "ng-component", ngImport: i0, template: "<div class=\"hidden md:block\" fxHide.lt-md>\n <nice-range-preset></nice-range-preset>\n</div>\n<div class=\"block md:hidden\">\n <ng-container *ngIf=\"toggled\">\n <nice-range-preset></nice-range-preset>\n </ng-container>\n</div>\n\n<div class=\"header\">\n <button\n fxHide.gt-md\n mat-icon-button\n (click)=\"clickOptions()\"\n >\n <mat-icon>sort</mat-icon>\n </button>\n <button\n mat-icon-button\n class=\"double-arrow\"\n (click)=\"previousClicked('year')\"\n >\n <mat-icon>keyboard_arrow_left</mat-icon>\n <mat-icon>keyboard_arrow_left</mat-icon>\n </button>\n <button mat-icon-button (click)=\"previousClicked('month')\">\n <mat-icon>keyboard_arrow_left</mat-icon>\n </button>\n\n <span class=\"header-label\">{{ periodLabel }}</span>\n\n <button mat-icon-button (click)=\"nextClicked('month')\">\n <mat-icon>keyboard_arrow_right</mat-icon>\n </button>\n <button\n mat-icon-button\n class=\"double-arrow\"\n (click)=\"nextClicked('year')\"\n >\n <mat-icon>keyboard_arrow_right</mat-icon>\n <mat-icon>keyboard_arrow_right</mat-icon>\n </button>\n</div>\n", styles: [".header{display:flex;align-items:center;padding:.5em}.header-label{flex:1;height:1em;font-weight:500;text-align:center}.double-arrow .mat-icon{margin:-22%}\n"], components: [{ type: i3.RangePresetComponent, selector: "nice-range-preset" }, { type: i4.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
50
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: HeaderComponent, decorators: [{
51
+ type: Component,
52
+ args: [{ changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"hidden md:block\" fxHide.lt-md>\n <nice-range-preset></nice-range-preset>\n</div>\n<div class=\"block md:hidden\">\n <ng-container *ngIf=\"toggled\">\n <nice-range-preset></nice-range-preset>\n </ng-container>\n</div>\n\n<div class=\"header\">\n <button\n fxHide.gt-md\n mat-icon-button\n (click)=\"clickOptions()\"\n >\n <mat-icon>sort</mat-icon>\n </button>\n <button\n mat-icon-button\n class=\"double-arrow\"\n (click)=\"previousClicked('year')\"\n >\n <mat-icon>keyboard_arrow_left</mat-icon>\n <mat-icon>keyboard_arrow_left</mat-icon>\n </button>\n <button mat-icon-button (click)=\"previousClicked('month')\">\n <mat-icon>keyboard_arrow_left</mat-icon>\n </button>\n\n <span class=\"header-label\">{{ periodLabel }}</span>\n\n <button mat-icon-button (click)=\"nextClicked('month')\">\n <mat-icon>keyboard_arrow_right</mat-icon>\n </button>\n <button\n mat-icon-button\n class=\"double-arrow\"\n (click)=\"nextClicked('year')\"\n >\n <mat-icon>keyboard_arrow_right</mat-icon>\n <mat-icon>keyboard_arrow_right</mat-icon>\n </button>\n</div>\n", styles: [".header{display:flex;align-items:center;padding:.5em}.header-label{flex:1;height:1em;font-weight:500;text-align:center}.double-arrow .mat-icon{margin:-22%}\n"] }]
53
+ }], ctorParameters: function () { return [{ type: i1.MatCalendar }, { type: i2.DateAdapter }, { type: undefined, decorators: [{
54
+ type: Inject,
55
+ args: [MAT_DATE_FORMATS]
56
+ }] }, { type: i0.ChangeDetectorRef }]; } });
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvY29tcG9uZW50cy9kYXRlLXJhbmdlLXBpY2tlci9jb21wb25lbnRzL2hlYWRlci9oZWFkZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmljZS11aS1raXQtdjIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGUtcmFuZ2UtcGlja2VyL2NvbXBvbmVudHMvaGVhZGVyL2hlYWRlci50ZW1wbGF0ZS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxpQkFBaUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFhLE1BQU0sZUFBZSxDQUFDO0FBQ3pHLE9BQU8sRUFBRSxXQUFXLEVBQUUsZ0JBQWdCLEVBQWtCLE1BQU0sd0JBQXdCLENBQUM7QUFDdkYsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQzNELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDL0IsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7Ozs7OztBQU8zQyxNQUFNLE9BQU8sZUFBZTtJQUt4QixZQUNZLFFBQXdCLEVBQ3hCLFdBQTJCLEVBQ0QsV0FBMkIsRUFDN0QsR0FBc0I7UUFIZCxhQUFRLEdBQVIsUUFBUSxDQUFnQjtRQUN4QixnQkFBVyxHQUFYLFdBQVcsQ0FBZ0I7UUFDRCxnQkFBVyxHQUFYLFdBQVcsQ0FBZ0I7UUFQaEQsYUFBUSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFFekMsWUFBTyxHQUFHLEtBQUssQ0FBQztRQVFuQixRQUFRLENBQUMsWUFBWTthQUNoQixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQzthQUM5QixTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUVELElBQVcsV0FBVztRQUNsQixPQUFPLElBQUksQ0FBQyxXQUFXO2FBQ2xCLE1BQU0sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLFVBQVUsRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxjQUFjLENBQUM7YUFDekUsaUJBQWlCLEVBQUUsQ0FBQztJQUM3QixDQUFDO0lBRU0sZUFBZSxDQUFDLElBQXNCO1FBQ3pDLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDOUIsQ0FBQztJQUVNLFdBQVcsQ0FBQyxJQUFzQjtRQUNyQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztJQUM3QixDQUFDO0lBRU8sVUFBVSxDQUFDLElBQXNCLEVBQUUsTUFBYztRQUNyRCxJQUFJLENBQUMsUUFBUSxDQUFDLFVBQVU7WUFDcEIsSUFBSSxLQUFLLE9BQU87Z0JBQ1osQ0FBQyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxVQUFVLEVBQUUsTUFBTSxDQUFDO2dCQUN0RSxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLFVBQVUsRUFBRSxNQUFNLENBQUMsQ0FBQztJQUNsRixDQUFDO0lBRU0sWUFBWTtRQUNmLElBQUksQ0FBQyxPQUFPLEdBQUcsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ2pDLENBQUM7SUFFTSxXQUFXO1FBQ2QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN6QixDQUFDOzs0R0EzQ1EsZUFBZSx3RUFRWixnQkFBZ0I7Z0dBUm5CLGVBQWUsb0RDWDVCLGl0Q0EyQ0E7MkZEaENhLGVBQWU7a0JBTDNCLFNBQVM7c0NBR1csdUJBQXVCLENBQUMsTUFBTTs7MEJBVTFDLE1BQU07MkJBQUMsZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIEluamVjdCwgT25EZXN0cm95IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IERhdGVBZGFwdGVyLCBNQVRfREFURV9GT1JNQVRTLCBNYXREYXRlRm9ybWF0cyB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9jb3JlXCI7XG5pbXBvcnQgeyBNYXRDYWxlbmRhciB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9kYXRlcGlja2VyXCI7XG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSBcInJ4anNcIjtcbmltcG9ydCB7IHRha2VVbnRpbCB9IGZyb20gXCJyeGpzL29wZXJhdG9yc1wiO1xuXG5AQ29tcG9uZW50KHtcbiAgICB0ZW1wbGF0ZVVybDogXCJoZWFkZXIudGVtcGxhdGUuaHRtbFwiLFxuICAgIHN0eWxlVXJsczogW1wiaGVhZGVyLnN0eWxlLnNjc3NcIl0sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgSGVhZGVyQ29tcG9uZW50PEQ+IGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGRlc3Ryb3kkID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcblxuICAgIHB1YmxpYyB0b2dnbGVkID0gZmFsc2U7XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgcHJpdmF0ZSBjYWxlbmRhcjogTWF0Q2FsZW5kYXI8RD4sXG4gICAgICAgIHByaXZhdGUgZGF0ZUFkYXB0ZXI6IERhdGVBZGFwdGVyPEQ+LFxuICAgICAgICBASW5qZWN0KE1BVF9EQVRFX0ZPUk1BVFMpIHByaXZhdGUgZGF0ZUZvcm1hdHM6IE1hdERhdGVGb3JtYXRzLFxuICAgICAgICBjZHI6IENoYW5nZURldGVjdG9yUmVmXG4gICAgKSB7XG4gICAgICAgIGNhbGVuZGFyLnN0YXRlQ2hhbmdlc1xuICAgICAgICAgICAgLnBpcGUodGFrZVVudGlsKHRoaXMuZGVzdHJveSQpKVxuICAgICAgICAgICAgLnN1YnNjcmliZSgoKSA9PiBjZHIubWFya0ZvckNoZWNrKCkpO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgcGVyaW9kTGFiZWwoKTogc3RyaW5nIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZGF0ZUFkYXB0ZXJcbiAgICAgICAgICAgIC5mb3JtYXQodGhpcy5jYWxlbmRhci5hY3RpdmVEYXRlLCB0aGlzLmRhdGVGb3JtYXRzLmRpc3BsYXkubW9udGhZZWFyTGFiZWwpXG4gICAgICAgICAgICAudG9Mb2NhbGVVcHBlckNhc2UoKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgcHJldmlvdXNDbGlja2VkKG1vZGU6IFwibW9udGhcIiB8IFwieWVhclwiKTogdm9pZCB7XG4gICAgICAgIHRoaXMuY2hhbmdlRGF0ZShtb2RlLCAtMSk7XG4gICAgfVxuXG4gICAgcHVibGljIG5leHRDbGlja2VkKG1vZGU6IFwibW9udGhcIiB8IFwieWVhclwiKTogdm9pZCB7XG4gICAgICAgIHRoaXMuY2hhbmdlRGF0ZShtb2RlLCAxKTtcbiAgICB9XG5cbiAgICBwcml2YXRlIGNoYW5nZURhdGUobW9kZTogXCJtb250aFwiIHwgXCJ5ZWFyXCIsIGFtb3VudDogLTEgfCAxKTogdm9pZCB7XG4gICAgICAgIHRoaXMuY2FsZW5kYXIuYWN0aXZlRGF0ZSA9XG4gICAgICAgICAgICBtb2RlID09PSBcIm1vbnRoXCJcbiAgICAgICAgICAgICAgICA/IHRoaXMuZGF0ZUFkYXB0ZXIuYWRkQ2FsZW5kYXJNb250aHModGhpcy5jYWxlbmRhci5hY3RpdmVEYXRlLCBhbW91bnQpXG4gICAgICAgICAgICAgICAgOiB0aGlzLmRhdGVBZGFwdGVyLmFkZENhbGVuZGFyWWVhcnModGhpcy5jYWxlbmRhci5hY3RpdmVEYXRlLCBhbW91bnQpO1xuICAgIH1cblxuICAgIHB1YmxpYyBjbGlja09wdGlvbnMoKSB7XG4gICAgICAgIHRoaXMudG9nZ2xlZCA9ICF0aGlzLnRvZ2dsZWQ7XG4gICAgfVxuXG4gICAgcHVibGljIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmRlc3Ryb3kkLm5leHQoKTtcbiAgICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiaGlkZGVuIG1kOmJsb2NrXCIgZnhIaWRlLmx0LW1kPlxuICAgIDxuaWNlLXJhbmdlLXByZXNldD48L25pY2UtcmFuZ2UtcHJlc2V0PlxuPC9kaXY+XG48ZGl2IGNsYXNzPVwiYmxvY2sgbWQ6aGlkZGVuXCI+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cInRvZ2dsZWRcIj5cbiAgICAgICAgPG5pY2UtcmFuZ2UtcHJlc2V0PjwvbmljZS1yYW5nZS1wcmVzZXQ+XG4gICAgPC9uZy1jb250YWluZXI+XG48L2Rpdj5cblxuPGRpdiBjbGFzcz1cImhlYWRlclwiPlxuICAgIDxidXR0b25cbiAgICAgICAgZnhIaWRlLmd0LW1kXG4gICAgICAgIG1hdC1pY29uLWJ1dHRvblxuICAgICAgICAoY2xpY2spPVwiY2xpY2tPcHRpb25zKClcIlxuICAgID5cbiAgICAgICAgPG1hdC1pY29uPnNvcnQ8L21hdC1pY29uPlxuICAgIDwvYnV0dG9uPlxuICAgIDxidXR0b25cbiAgICAgICAgbWF0LWljb24tYnV0dG9uXG4gICAgICAgIGNsYXNzPVwiZG91YmxlLWFycm93XCJcbiAgICAgICAgKGNsaWNrKT1cInByZXZpb3VzQ2xpY2tlZCgneWVhcicpXCJcbiAgICA+XG4gICAgICAgIDxtYXQtaWNvbj5rZXlib2FyZF9hcnJvd19sZWZ0PC9tYXQtaWNvbj5cbiAgICAgICAgPG1hdC1pY29uPmtleWJvYXJkX2Fycm93X2xlZnQ8L21hdC1pY29uPlxuICAgIDwvYnV0dG9uPlxuICAgIDxidXR0b24gbWF0LWljb24tYnV0dG9uIChjbGljayk9XCJwcmV2aW91c0NsaWNrZWQoJ21vbnRoJylcIj5cbiAgICAgICAgPG1hdC1pY29uPmtleWJvYXJkX2Fycm93X2xlZnQ8L21hdC1pY29uPlxuICAgIDwvYnV0dG9uPlxuXG4gICAgPHNwYW4gY2xhc3M9XCJoZWFkZXItbGFiZWxcIj57eyBwZXJpb2RMYWJlbCB9fTwvc3Bhbj5cblxuICAgIDxidXR0b24gbWF0LWljb24tYnV0dG9uIChjbGljayk9XCJuZXh0Q2xpY2tlZCgnbW9udGgnKVwiPlxuICAgICAgICA8bWF0LWljb24+a2V5Ym9hcmRfYXJyb3dfcmlnaHQ8L21hdC1pY29uPlxuICAgIDwvYnV0dG9uPlxuICAgIDxidXR0b25cbiAgICAgICAgbWF0LWljb24tYnV0dG9uXG4gICAgICAgIGNsYXNzPVwiZG91YmxlLWFycm93XCJcbiAgICAgICAgKGNsaWNrKT1cIm5leHRDbGlja2VkKCd5ZWFyJylcIlxuICAgID5cbiAgICAgICAgPG1hdC1pY29uPmtleWJvYXJkX2Fycm93X3JpZ2h0PC9tYXQtaWNvbj5cbiAgICAgICAgPG1hdC1pY29uPmtleWJvYXJkX2Fycm93X3JpZ2h0PC9tYXQtaWNvbj5cbiAgICA8L2J1dHRvbj5cbjwvZGl2PlxuIl19
@@ -0,0 +1,107 @@
1
+ import { ChangeDetectionStrategy, Component } from "@angular/core";
2
+ import { DateAdapter } from "@angular/material/core";
3
+ import { MatDateRangePicker } from "@angular/material/datepicker";
4
+ import { NiceDateRangePickerServiceService } from "../../providers/date-range-picker.service";
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/material/core";
7
+ import * as i2 from "@angular/material/datepicker";
8
+ import * as i3 from "../../providers/date-range-picker.service";
9
+ import * as i4 from "@angular/material/card";
10
+ import * as i5 from "@angular/material/button";
11
+ import * as i6 from "@angular/common";
12
+ import * as i7 from "@ngx-translate/core";
13
+ const customPresets = [
14
+ "today",
15
+ "last_7_days",
16
+ "this_week",
17
+ "this_month",
18
+ "this_year",
19
+ "last_week",
20
+ "last_month",
21
+ "last_year",
22
+ ];
23
+ export class RangePresetComponent {
24
+ constructor(dateAdapter, picker, service) {
25
+ this.dateAdapter = dateAdapter;
26
+ this.picker = picker;
27
+ this.service = service;
28
+ this.customPresets = customPresets;
29
+ this.allowClear$ = this.service.allowClear$;
30
+ }
31
+ clearRange() {
32
+ this.picker.select(null);
33
+ this.picker.select(null);
34
+ this.picker.close();
35
+ }
36
+ selectRange(rangeName) {
37
+ const [start, end] = this.calculateDateRange(rangeName);
38
+ this.picker.select(start);
39
+ this.picker.select(end);
40
+ this.picker.close();
41
+ }
42
+ calculateDateRange(rangeName) {
43
+ const today = this.today;
44
+ const year = this.dateAdapter.getYear(today);
45
+ switch (rangeName) {
46
+ case "today":
47
+ return [today, today];
48
+ case "last_7_days": {
49
+ const start = this.dateAdapter.addCalendarDays(today, -6);
50
+ return [start, today];
51
+ }
52
+ case "this_week": {
53
+ return this.calculateWeek(today);
54
+ }
55
+ case "this_month": {
56
+ return this.calculateMonth(today);
57
+ }
58
+ case "this_year": {
59
+ const start = this.dateAdapter.createDate(year, 0, 1);
60
+ const end = this.dateAdapter.createDate(year, 11, 31);
61
+ return [start, end];
62
+ }
63
+ case "last_week": {
64
+ const thisDayLastWeek = this.dateAdapter.addCalendarDays(today, -7);
65
+ return this.calculateWeek(thisDayLastWeek);
66
+ }
67
+ case "last_month": {
68
+ const thisDayLastMonth = this.dateAdapter.addCalendarMonths(today, -1);
69
+ return this.calculateMonth(thisDayLastMonth);
70
+ }
71
+ case "last_year": {
72
+ const start = this.dateAdapter.createDate(year - 1, 0, 1);
73
+ const end = this.dateAdapter.createDate(year - 1, 11, 31);
74
+ return [start, end];
75
+ }
76
+ default:
77
+ return null;
78
+ }
79
+ }
80
+ calculateMonth(forDay) {
81
+ const year = this.dateAdapter.getYear(forDay);
82
+ const month = this.dateAdapter.getMonth(forDay);
83
+ const start = this.dateAdapter.createDate(year, month, 1);
84
+ const end = this.dateAdapter.addCalendarDays(start, this.dateAdapter.getNumDaysInMonth(forDay) - 1);
85
+ return [start, end];
86
+ }
87
+ calculateWeek(forDay) {
88
+ const deltaStart = this.dateAdapter.getFirstDayOfWeek() - this.dateAdapter.getDayOfWeek(forDay);
89
+ const start = this.dateAdapter.addCalendarDays(forDay, deltaStart);
90
+ const end = this.dateAdapter.addCalendarDays(start, 6);
91
+ return [start, end];
92
+ }
93
+ get today() {
94
+ const today = this.dateAdapter.getValidDateOrNull(new Date());
95
+ if (today === null) {
96
+ throw new Error("date creation failed");
97
+ }
98
+ return today;
99
+ }
100
+ }
101
+ RangePresetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: RangePresetComponent, deps: [{ token: i1.DateAdapter }, { token: i2.MatDateRangePicker }, { token: i3.NiceDateRangePickerServiceService }], target: i0.ɵɵFactoryTarget.Component });
102
+ RangePresetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.3", type: RangePresetComponent, selector: "nice-range-preset", ngImport: i0, template: "<mat-card class=\"mat-elevation-z3\">\n <button\n *ngIf=\"allowClear$ | async\"\n mat-button\n (click)=\"clearRange()\"\n >\n {{ \"nice_ui_kit.date_range_picker.clear\" | translate }}\n </button>\n\n <button\n *ngFor=\"let item of customPresets\"\n mat-button\n (click)=\"selectRange(item)\"\n >\n {{ \"nice_ui_kit.date_range_picker.presets.\" + item | translate }}\n </button>\n</mat-card>\n", styles: [":host{position:absolute;width:200px;left:-200px}@media screen and (max-width: 959px){:host{z-index:1000;left:50px!important}}button{width:100%;text-align:left;text-transform:unset!important}\n"], components: [{ type: i4.MatCard, selector: "mat-card", exportAs: ["matCard"] }, { type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i6.AsyncPipe, "translate": i7.TranslatePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
103
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: RangePresetComponent, decorators: [{
104
+ type: Component,
105
+ args: [{ selector: "nice-range-preset", changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-card class=\"mat-elevation-z3\">\n <button\n *ngIf=\"allowClear$ | async\"\n mat-button\n (click)=\"clearRange()\"\n >\n {{ \"nice_ui_kit.date_range_picker.clear\" | translate }}\n </button>\n\n <button\n *ngFor=\"let item of customPresets\"\n mat-button\n (click)=\"selectRange(item)\"\n >\n {{ \"nice_ui_kit.date_range_picker.presets.\" + item | translate }}\n </button>\n</mat-card>\n", styles: [":host{position:absolute;width:200px;left:-200px}@media screen and (max-width: 959px){:host{z-index:1000;left:50px!important}}button{width:100%;text-align:left;text-transform:unset!important}\n"] }]
106
+ }], ctorParameters: function () { return [{ type: i1.DateAdapter }, { type: i2.MatDateRangePicker }, { type: i3.NiceDateRangePickerServiceService }]; } });
107
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range-preset.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nice-ui-kit-v2/src/lib/components/date-range-picker/components/range-preset/range-preset.component.ts","../../../../../../../../projects/nice-ui-kit-v2/src/lib/components/date-range-picker/components/range-preset/range-preset.template.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component } from \"@angular/core\";\nimport { DateAdapter } from \"@angular/material/core\";\nimport { MatDateRangePicker } from \"@angular/material/datepicker\";\nimport { NiceDateRangePickerServiceService } from \"../../providers/date-range-picker.service\";\n\nconst customPresets = [\n    \"today\",\n    \"last_7_days\",\n    \"this_week\",\n    \"this_month\",\n    \"this_year\",\n    \"last_week\",\n    \"last_month\",\n    \"last_year\",\n];\n\ntype CustomPreset = typeof customPresets[number];\n\n@Component({\n    selector: \"nice-range-preset\",\n    templateUrl: \"range-preset.template.html\",\n    styleUrls: [\"range-preset.style.scss\"],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class RangePresetComponent<D> {\n    public readonly customPresets = customPresets;\n    public readonly allowClear$ = this.service.allowClear$;\n\n    constructor(\n        private dateAdapter: DateAdapter<D>,\n        private picker: MatDateRangePicker<D>,\n        private service: NiceDateRangePickerServiceService\n    ) {}\n\n    public clearRange(): void {\n        this.picker.select(null);\n        this.picker.select(null);\n        this.picker.close();\n    }\n\n    public selectRange(rangeName: CustomPreset): void {\n        const [start, end] = this.calculateDateRange(rangeName);\n        this.picker.select(start);\n        this.picker.select(end);\n        this.picker.close();\n    }\n\n    private calculateDateRange(rangeName: CustomPreset): [start: D, end: D] {\n        const today = this.today;\n        const year = this.dateAdapter.getYear(today);\n\n        switch (rangeName) {\n            case \"today\":\n                return [today, today];\n            case \"last_7_days\": {\n                const start = this.dateAdapter.addCalendarDays(today, -6);\n                return [start, today];\n            }\n            case \"this_week\": {\n                return this.calculateWeek(today);\n            }\n            case \"this_month\": {\n                return this.calculateMonth(today);\n            }\n            case \"this_year\": {\n                const start = this.dateAdapter.createDate(year, 0, 1);\n                const end = this.dateAdapter.createDate(year, 11, 31);\n                return [start, end];\n            }\n            case \"last_week\": {\n                const thisDayLastWeek = this.dateAdapter.addCalendarDays(today, -7);\n                return this.calculateWeek(thisDayLastWeek);\n            }\n            case \"last_month\": {\n                const thisDayLastMonth = this.dateAdapter.addCalendarMonths(today, -1);\n                return this.calculateMonth(thisDayLastMonth);\n            }\n            case \"last_year\": {\n                const start = this.dateAdapter.createDate(year - 1, 0, 1);\n                const end = this.dateAdapter.createDate(year - 1, 11, 31);\n                return [start, end];\n            }\n            default:\n                return null;\n        }\n    }\n\n    private calculateMonth(forDay: D): [start: D, end: D] {\n        const year = this.dateAdapter.getYear(forDay);\n        const month = this.dateAdapter.getMonth(forDay);\n        const start = this.dateAdapter.createDate(year, month, 1);\n        const end = this.dateAdapter.addCalendarDays(\n            start,\n            this.dateAdapter.getNumDaysInMonth(forDay) - 1\n        );\n        return [start, end];\n    }\n\n    private calculateWeek(forDay: D): [start: D, end: D] {\n        const deltaStart = this.dateAdapter.getFirstDayOfWeek() - this.dateAdapter.getDayOfWeek(forDay);\n        const start = this.dateAdapter.addCalendarDays(forDay, deltaStart);\n        const end = this.dateAdapter.addCalendarDays(start, 6);\n        return [start, end];\n    }\n\n    private get today(): D {\n        const today = this.dateAdapter.getValidDateOrNull(new Date());\n        if (today === null) {\n            throw new Error(\"date creation failed\");\n        }\n        return today;\n    }\n}\n","<mat-card class=\"mat-elevation-z3\">\n    <button\n            *ngIf=\"allowClear$ | async\"\n            mat-button\n            (click)=\"clearRange()\"\n    >\n        {{ \"nice_ui_kit.date_range_picker.clear\" | translate }}\n    </button>\n\n    <button\n        *ngFor=\"let item of customPresets\"\n        mat-button\n        (click)=\"selectRange(item)\"\n    >\n        {{ \"nice_ui_kit.date_range_picker.presets.\" + item | translate }}\n    </button>\n</mat-card>\n"]}
@@ -0,0 +1,74 @@
1
+ import { Component, forwardRef, Input, ViewChild, ViewEncapsulation } from "@angular/core";
2
+ import { FormControl, FormGroup, NG_VALUE_ACCESSOR } from "@angular/forms";
3
+ import { MatDateRangePicker } from "@angular/material/datepicker";
4
+ import subDays from "date-fns/subDays";
5
+ import { HeaderComponent } from "./components/header/header.component";
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/material/datepicker";
8
+ import * as i2 from "@angular/common";
9
+ import * as i3 from "@angular/forms";
10
+ import * as i4 from "@angular/material/form-field";
11
+ import * as i5 from "../../pipes/localized-date.pipe";
12
+ export class NiceDateRangePickerComponent {
13
+ constructor() {
14
+ this.HeaderComponent = HeaderComponent;
15
+ this.min = subDays(new Date(), 3);
16
+ this.max = new Date();
17
+ this.nowIsMax = true;
18
+ this.allowClear = true;
19
+ this.formGroup = new FormGroup({
20
+ from: new FormControl(),
21
+ to: new FormControl()
22
+ });
23
+ this.now = new Date();
24
+ }
25
+ ngOnInit() {
26
+ this.value = {
27
+ from: this.min,
28
+ to: this.max
29
+ };
30
+ this.formGroup.patchValue(this.value);
31
+ this.formGroup.valueChanges.subscribe((_) => {
32
+ this.value = this.formGroup.getRawValue();
33
+ this.propage?.(this.value);
34
+ });
35
+ }
36
+ writeValue(value) {
37
+ this.value = value;
38
+ this.formGroup.patchValue(this.value);
39
+ }
40
+ registerOnChange(fn) {
41
+ this.propage = fn;
42
+ }
43
+ registerOnTouched(fn) { }
44
+ }
45
+ NiceDateRangePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceDateRangePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
46
+ NiceDateRangePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.3", type: NiceDateRangePickerComponent, selector: "nice-date-range-picker", inputs: { min: "min", max: "max", nowIsMax: "nowIsMax", allowClear: "allowClear" }, providers: [
47
+ {
48
+ provide: NG_VALUE_ACCESSOR,
49
+ useExisting: forwardRef(() => NiceDateRangePickerComponent),
50
+ multi: true
51
+ }
52
+ ], viewQueries: [{ propertyName: "picker", first: true, predicate: MatDateRangePicker, descendants: true }], ngImport: i0, template: "<div class=\"nice-date-picker-container\">\n <div class=\"nice-date-picker-header\">\n <div class=\"from-to\">\n <ng-container *ngIf=\"value.from\">\n {{ value.from | localizedDate: \"longDate\" }}\n </ng-container>\n <ng-container *ngIf=\"value.to\">\n <div class=\"separator\">-</div>\n {{ value.to | localizedDate: \"longDate\" }}\n </ng-container>\n </div>\n </div>\n\n <mat-date-range-input [formGroup]=\"formGroup\" [max]=\"nowIsMax ? now : null\" [rangePicker]=\"picker\">\n <input formControlName=\"from\" class=\"hidden-input\" matStartDate placeholder=\"Start date\">\n <input formControlName=\"to\" class=\"hidden-input\" matEndDate placeholder=\"End date\">\n </mat-date-range-input>\n\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n\n <mat-date-range-picker\n [calendarHeaderComponent]=\"HeaderComponent\"\n #picker\n ></mat-date-range-picker>\n</div>\n", styles: ["nice-date-range-picker .mat-date-range-input{width:0;height:0;padding:0;margin:0;border:none;visibility:hidden}\n"], components: [{ type: i1.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { type: i1.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i1.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { 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]" }, { type: i1.MatStartDate, selector: "input[matStartDate]", inputs: ["errorStateMatcher"], outputs: ["dateChange", "dateInput"] }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i1.MatEndDate, selector: "input[matEndDate]", inputs: ["errorStateMatcher"], outputs: ["dateChange", "dateInput"] }, { type: i4.MatSuffix, selector: "[matSuffix]" }], pipes: { "localizedDate": i5.LocalizedDatePipe }, encapsulation: i0.ViewEncapsulation.None });
53
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceDateRangePickerComponent, decorators: [{
54
+ type: Component,
55
+ args: [{ selector: "nice-date-range-picker", encapsulation: ViewEncapsulation.None, providers: [
56
+ {
57
+ provide: NG_VALUE_ACCESSOR,
58
+ useExisting: forwardRef(() => NiceDateRangePickerComponent),
59
+ multi: true
60
+ }
61
+ ], template: "<div class=\"nice-date-picker-container\">\n <div class=\"nice-date-picker-header\">\n <div class=\"from-to\">\n <ng-container *ngIf=\"value.from\">\n {{ value.from | localizedDate: \"longDate\" }}\n </ng-container>\n <ng-container *ngIf=\"value.to\">\n <div class=\"separator\">-</div>\n {{ value.to | localizedDate: \"longDate\" }}\n </ng-container>\n </div>\n </div>\n\n <mat-date-range-input [formGroup]=\"formGroup\" [max]=\"nowIsMax ? now : null\" [rangePicker]=\"picker\">\n <input formControlName=\"from\" class=\"hidden-input\" matStartDate placeholder=\"Start date\">\n <input formControlName=\"to\" class=\"hidden-input\" matEndDate placeholder=\"End date\">\n </mat-date-range-input>\n\n <mat-datepicker-toggle matSuffix [for]=\"picker\"></mat-datepicker-toggle>\n\n <mat-date-range-picker\n [calendarHeaderComponent]=\"HeaderComponent\"\n #picker\n ></mat-date-range-picker>\n</div>\n", styles: ["nice-date-range-picker .mat-date-range-input{width:0;height:0;padding:0;margin:0;border:none;visibility:hidden}\n"] }]
62
+ }], propDecorators: { picker: [{
63
+ type: ViewChild,
64
+ args: [MatDateRangePicker]
65
+ }], min: [{
66
+ type: Input
67
+ }], max: [{
68
+ type: Input
69
+ }], nowIsMax: [{
70
+ type: Input
71
+ }], allowClear: [{
72
+ type: Input
73
+ }] } });
74
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1yYW5nZS1waWNrZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmljZS11aS1raXQtdjIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGUtcmFuZ2UtcGlja2VyL2RhdGUtcmFuZ2UtcGlja2VyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvY29tcG9uZW50cy9kYXRlLXJhbmdlLXBpY2tlci9kYXRlLXJhbmdlLXBpY2tlci50ZW1wbGF0ZS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLEtBQUssRUFBVSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkcsT0FBTyxFQUF3QixXQUFXLEVBQUUsU0FBUyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDakcsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDbEUsT0FBTyxPQUFPLE1BQU0sa0JBQWtCLENBQUM7QUFDdkMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHNDQUFzQyxDQUFDOzs7Ozs7O0FBb0J2RSxNQUFNLE9BQU8sNEJBQTRCO0lBYnpDO1FBY29CLG9CQUFlLEdBQUcsZUFBZSxDQUFDO1FBTTNDLFFBQUcsR0FBRyxPQUFPLENBQUMsSUFBSSxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUc3QixRQUFHLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQztRQUdqQixhQUFRLEdBQUcsSUFBSSxDQUFDO1FBR2hCLGVBQVUsR0FBRyxJQUFJLENBQUM7UUFFbEIsY0FBUyxHQUFHLElBQUksU0FBUyxDQUFDO1lBQzdCLElBQUksRUFBRSxJQUFJLFdBQVcsRUFBRTtZQUN2QixFQUFFLEVBQUUsSUFBSSxXQUFXLEVBQUU7U0FDeEIsQ0FBQyxDQUFDO1FBQ0ksUUFBRyxHQUFHLElBQUksSUFBSSxFQUFFLENBQUM7S0E0QjNCO0lBdkJVLFFBQVE7UUFDWCxJQUFJLENBQUMsS0FBSyxHQUFHO1lBQ1QsSUFBSSxFQUFFLElBQUksQ0FBQyxHQUFHO1lBQ2QsRUFBRSxFQUFFLElBQUksQ0FBQyxHQUFHO1NBQ2YsQ0FBQztRQUNGLElBQUksQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUV0QyxJQUFJLENBQUMsU0FBUyxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRTtZQUN4QyxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDMUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMvQixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFTSxVQUFVLENBQUMsS0FBK0I7UUFDN0MsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7UUFDbkIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzFDLENBQUM7SUFFTSxnQkFBZ0IsQ0FBQyxFQUE2QztRQUNqRSxJQUFJLENBQUMsT0FBTyxHQUFHLEVBQUUsQ0FBQztJQUN0QixDQUFDO0lBRU0saUJBQWlCLENBQUMsRUFBTyxJQUFTLENBQUM7O3lIQWpEakMsNEJBQTRCOzZHQUE1Qiw0QkFBNEIscUlBUjFCO1FBQ1A7WUFDSSxPQUFPLEVBQUUsaUJBQWlCO1lBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsNEJBQTRCLENBQUM7WUFDM0QsS0FBSyxFQUFFLElBQUk7U0FDZDtLQUNKLGtFQUtVLGtCQUFrQixnREMzQmpDLG1pQ0F5QkE7MkZERGEsNEJBQTRCO2tCQWJ4QyxTQUFTOytCQUNJLHdCQUF3QixpQkFHbkIsaUJBQWlCLENBQUMsSUFBSSxhQUMxQjt3QkFDUDs0QkFDSSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSw2QkFBNkIsQ0FBQzs0QkFDM0QsS0FBSyxFQUFFLElBQUk7eUJBQ2Q7cUJBQ0o7OEJBTU8sTUFBTTtzQkFEYixTQUFTO3VCQUFDLGtCQUFrQjtnQkFJdEIsR0FBRztzQkFEVCxLQUFLO2dCQUlDLEdBQUc7c0JBRFQsS0FBSztnQkFJQyxRQUFRO3NCQURkLEtBQUs7Z0JBSUMsVUFBVTtzQkFEaEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgZm9yd2FyZFJlZiwgSW5wdXQsIE9uSW5pdCwgVmlld0NoaWxkLCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBDb250cm9sVmFsdWVBY2Nlc3NvciwgRm9ybUNvbnRyb2wsIEZvcm1Hcm91cCwgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcbmltcG9ydCB7IE1hdERhdGVSYW5nZVBpY2tlciB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9kYXRlcGlja2VyXCI7XG5pbXBvcnQgc3ViRGF5cyBmcm9tIFwiZGF0ZS1mbnMvc3ViRGF5c1wiO1xuaW1wb3J0IHsgSGVhZGVyQ29tcG9uZW50IH0gZnJvbSBcIi4vY29tcG9uZW50cy9oZWFkZXIvaGVhZGVyLmNvbXBvbmVudFwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIE5pY2VEYXRlUmFuZ2VQaWNrZXJWYWx1ZSB7XG4gICAgZnJvbTogRGF0ZTtcbiAgICB0bzogRGF0ZTtcbn1cblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6IFwibmljZS1kYXRlLXJhbmdlLXBpY2tlclwiLFxuICAgIHRlbXBsYXRlVXJsOiBcImRhdGUtcmFuZ2UtcGlja2VyLnRlbXBsYXRlLmh0bWxcIixcbiAgICBzdHlsZVVybHM6IFtcImRhdGUtcmFuZ2UtcGlja2VyLnN0eWxlLnNjc3NcIl0sXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgICAgICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBOaWNlRGF0ZVJhbmdlUGlja2VyQ29tcG9uZW50KSxcbiAgICAgICAgICAgIG11bHRpOiB0cnVlXG4gICAgICAgIH1cbiAgICBdXG59KVxuZXhwb3J0IGNsYXNzIE5pY2VEYXRlUmFuZ2VQaWNrZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIENvbnRyb2xWYWx1ZUFjY2Vzc29yIHtcbiAgICBwdWJsaWMgcmVhZG9ubHkgSGVhZGVyQ29tcG9uZW50ID0gSGVhZGVyQ29tcG9uZW50O1xuXG4gICAgQFZpZXdDaGlsZChNYXREYXRlUmFuZ2VQaWNrZXIpXG4gICAgcHJpdmF0ZSBwaWNrZXI6IE1hdERhdGVSYW5nZVBpY2tlcjxhbnk+O1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgbWluID0gc3ViRGF5cyhuZXcgRGF0ZSgpLCAzKTtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIG1heCA9IG5ldyBEYXRlKCk7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBub3dJc01heCA9IHRydWU7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBhbGxvd0NsZWFyID0gdHJ1ZTtcblxuICAgIHB1YmxpYyBmb3JtR3JvdXAgPSBuZXcgRm9ybUdyb3VwKHtcbiAgICAgICAgZnJvbTogbmV3IEZvcm1Db250cm9sKCksXG4gICAgICAgIHRvOiBuZXcgRm9ybUNvbnRyb2woKVxuICAgIH0pO1xuICAgIHB1YmxpYyBub3cgPSBuZXcgRGF0ZSgpO1xuICAgIHB1YmxpYyB2YWx1ZTogTmljZURhdGVSYW5nZVBpY2tlclZhbHVlO1xuXG4gICAgcHJpdmF0ZSBwcm9wYWdlOiAodmFsdWU6IE5pY2VEYXRlUmFuZ2VQaWNrZXJWYWx1ZSkgPT4gdm9pZDtcblxuICAgIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy52YWx1ZSA9IHtcbiAgICAgICAgICAgIGZyb206IHRoaXMubWluLFxuICAgICAgICAgICAgdG86IHRoaXMubWF4XG4gICAgICAgIH07XG4gICAgICAgIHRoaXMuZm9ybUdyb3VwLnBhdGNoVmFsdWUodGhpcy52YWx1ZSk7XG5cbiAgICAgICAgdGhpcy5mb3JtR3JvdXAudmFsdWVDaGFuZ2VzLnN1YnNjcmliZSgoXykgPT4ge1xuICAgICAgICAgICAgdGhpcy52YWx1ZSA9IHRoaXMuZm9ybUdyb3VwLmdldFJhd1ZhbHVlKCk7XG4gICAgICAgICAgICB0aGlzLnByb3BhZ2U/Lih0aGlzLnZhbHVlKTtcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgcHVibGljIHdyaXRlVmFsdWUodmFsdWU6IE5pY2VEYXRlUmFuZ2VQaWNrZXJWYWx1ZSk6IHZvaWQge1xuICAgICAgICB0aGlzLnZhbHVlID0gdmFsdWU7XG4gICAgICAgIHRoaXMuZm9ybUdyb3VwLnBhdGNoVmFsdWUodGhpcy52YWx1ZSk7XG4gICAgfVxuXG4gICAgcHVibGljIHJlZ2lzdGVyT25DaGFuZ2UoZm46ICh2YWx1ZTogTmljZURhdGVSYW5nZVBpY2tlclZhbHVlKSA9PiB2b2lkKTogdm9pZCB7XG4gICAgICAgIHRoaXMucHJvcGFnZSA9IGZuO1xuICAgIH1cblxuICAgIHB1YmxpYyByZWdpc3Rlck9uVG91Y2hlZChmbjogYW55KTogdm9pZCB7fVxufVxuIiwiPGRpdiBjbGFzcz1cIm5pY2UtZGF0ZS1waWNrZXItY29udGFpbmVyXCI+XG4gICAgPGRpdiBjbGFzcz1cIm5pY2UtZGF0ZS1waWNrZXItaGVhZGVyXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJmcm9tLXRvXCI+XG4gICAgICAgICAgICA8bmctY29udGFpbmVyICpuZ0lmPVwidmFsdWUuZnJvbVwiPlxuICAgICAgICAgICAgICAgIHt7IHZhbHVlLmZyb20gfCBsb2NhbGl6ZWREYXRlOiBcImxvbmdEYXRlXCIgfX1cbiAgICAgICAgICAgIDwvbmctY29udGFpbmVyPlxuICAgICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cInZhbHVlLnRvXCI+XG4gICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cInNlcGFyYXRvclwiPi08L2Rpdj5cbiAgICAgICAgICAgICAgICB7eyB2YWx1ZS50byB8IGxvY2FsaXplZERhdGU6IFwibG9uZ0RhdGVcIiB9fVxuICAgICAgICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuXG4gICAgPG1hdC1kYXRlLXJhbmdlLWlucHV0IFtmb3JtR3JvdXBdPVwiZm9ybUdyb3VwXCIgW21heF09XCJub3dJc01heCA/IG5vdyA6IG51bGxcIiBbcmFuZ2VQaWNrZXJdPVwicGlja2VyXCI+XG4gICAgICAgIDxpbnB1dCBmb3JtQ29udHJvbE5hbWU9XCJmcm9tXCIgY2xhc3M9XCJoaWRkZW4taW5wdXRcIiBtYXRTdGFydERhdGUgcGxhY2Vob2xkZXI9XCJTdGFydCBkYXRlXCI+XG4gICAgICAgIDxpbnB1dCBmb3JtQ29udHJvbE5hbWU9XCJ0b1wiIGNsYXNzPVwiaGlkZGVuLWlucHV0XCIgbWF0RW5kRGF0ZSBwbGFjZWhvbGRlcj1cIkVuZCBkYXRlXCI+XG4gICAgPC9tYXQtZGF0ZS1yYW5nZS1pbnB1dD5cblxuICAgIDxtYXQtZGF0ZXBpY2tlci10b2dnbGUgbWF0U3VmZml4IFtmb3JdPVwicGlja2VyXCI+PC9tYXQtZGF0ZXBpY2tlci10b2dnbGU+XG5cbiAgICA8bWF0LWRhdGUtcmFuZ2UtcGlja2VyXG4gICAgICAgICAgICBbY2FsZW5kYXJIZWFkZXJDb21wb25lbnRdPVwiSGVhZGVyQ29tcG9uZW50XCJcbiAgICAgICAgICAgICNwaWNrZXJcbiAgICA+PC9tYXQtZGF0ZS1yYW5nZS1waWNrZXI+XG48L2Rpdj5cbiJdfQ==
@@ -0,0 +1,58 @@
1
+ import { CommonModule } from "@angular/common";
2
+ import { NgModule } from "@angular/core";
3
+ import { ReactiveFormsModule } from "@angular/forms";
4
+ import { MatButtonModule } from "@angular/material/button";
5
+ import { MatCardModule } from "@angular/material/card";
6
+ import { MatDatepickerModule } from "@angular/material/datepicker";
7
+ import { MatFormFieldModule } from "@angular/material/form-field";
8
+ import { MatIconModule } from "@angular/material/icon";
9
+ import { TranslateModule } from "@ngx-translate/core";
10
+ import { NicePipesModule } from "../../pipes";
11
+ import { HeaderComponent } from "./components/header/header.component";
12
+ import { RangePresetComponent } from "./components/range-preset/range-preset.component";
13
+ import { NiceDateRangePickerComponent } from "./date-range-picker.component";
14
+ import { NiceDateRangePickerServiceService } from "./providers/date-range-picker.service";
15
+ import * as i0 from "@angular/core";
16
+ export class NiceDateRangePickerModule {
17
+ }
18
+ NiceDateRangePickerModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceDateRangePickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
19
+ NiceDateRangePickerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceDateRangePickerModule, declarations: [NiceDateRangePickerComponent, RangePresetComponent, HeaderComponent], imports: [CommonModule,
20
+ MatDatepickerModule,
21
+ MatFormFieldModule,
22
+ MatCardModule,
23
+ MatButtonModule,
24
+ MatIconModule,
25
+ TranslateModule,
26
+ ReactiveFormsModule,
27
+ NicePipesModule], exports: [NiceDateRangePickerComponent] });
28
+ NiceDateRangePickerModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceDateRangePickerModule, providers: [NiceDateRangePickerServiceService], imports: [[
29
+ CommonModule,
30
+ MatDatepickerModule,
31
+ MatFormFieldModule,
32
+ MatCardModule,
33
+ MatButtonModule,
34
+ MatIconModule,
35
+ TranslateModule,
36
+ ReactiveFormsModule,
37
+ NicePipesModule
38
+ ]] });
39
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceDateRangePickerModule, decorators: [{
40
+ type: NgModule,
41
+ args: [{
42
+ imports: [
43
+ CommonModule,
44
+ MatDatepickerModule,
45
+ MatFormFieldModule,
46
+ MatCardModule,
47
+ MatButtonModule,
48
+ MatIconModule,
49
+ TranslateModule,
50
+ ReactiveFormsModule,
51
+ NicePipesModule
52
+ ],
53
+ declarations: [NiceDateRangePickerComponent, RangePresetComponent, HeaderComponent],
54
+ providers: [NiceDateRangePickerServiceService],
55
+ exports: [NiceDateRangePickerComponent]
56
+ }]
57
+ }] });
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1yYW5nZS1waWNrZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmljZS11aS1raXQtdjIvc3JjL2xpYi9jb21wb25lbnRzL2RhdGUtcmFuZ2UtcGlja2VyL2RhdGUtcmFuZ2UtcGlja2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ25FLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUM5QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sc0NBQXNDLENBQUM7QUFDdkUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFDeEYsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDN0UsT0FBTyxFQUFFLGlDQUFpQyxFQUFFLE1BQU0sdUNBQXVDLENBQUM7O0FBa0IxRixNQUFNLE9BQU8seUJBQXlCOztzSEFBekIseUJBQXlCO3VIQUF6Qix5QkFBeUIsaUJBSm5CLDRCQUE0QixFQUFFLG9CQUFvQixFQUFFLGVBQWUsYUFWOUUsWUFBWTtRQUNaLG1CQUFtQjtRQUNuQixrQkFBa0I7UUFDbEIsYUFBYTtRQUNiLGVBQWU7UUFDZixhQUFhO1FBQ2IsZUFBZTtRQUNmLG1CQUFtQjtRQUNuQixlQUFlLGFBSVQsNEJBQTRCO3VIQUU3Qix5QkFBeUIsYUFIdkIsQ0FBQyxpQ0FBaUMsQ0FBQyxZQVpyQztZQUNMLFlBQVk7WUFDWixtQkFBbUI7WUFDbkIsa0JBQWtCO1lBQ2xCLGFBQWE7WUFDYixlQUFlO1lBQ2YsYUFBYTtZQUNiLGVBQWU7WUFDZixtQkFBbUI7WUFDbkIsZUFBZTtTQUNsQjsyRkFLUSx5QkFBeUI7a0JBaEJyQyxRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRTt3QkFDTCxZQUFZO3dCQUNaLG1CQUFtQjt3QkFDbkIsa0JBQWtCO3dCQUNsQixhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsYUFBYTt3QkFDYixlQUFlO3dCQUNmLG1CQUFtQjt3QkFDbkIsZUFBZTtxQkFDbEI7b0JBQ0QsWUFBWSxFQUFFLENBQUMsNEJBQTRCLEVBQUUsb0JBQW9CLEVBQUUsZUFBZSxDQUFDO29CQUNuRixTQUFTLEVBQUUsQ0FBQyxpQ0FBaUMsQ0FBQztvQkFDOUMsT0FBTyxFQUFFLENBQUMsNEJBQTRCLENBQUM7aUJBQzFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgUmVhY3RpdmVGb3Jtc01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xuaW1wb3J0IHsgTWF0QnV0dG9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2J1dHRvblwiO1xuaW1wb3J0IHsgTWF0Q2FyZE1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9jYXJkXCI7XG5pbXBvcnQgeyBNYXREYXRlcGlja2VyTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2RhdGVwaWNrZXJcIjtcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkXCI7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL2ljb25cIjtcbmltcG9ydCB7IFRyYW5zbGF0ZU1vZHVsZSB9IGZyb20gXCJAbmd4LXRyYW5zbGF0ZS9jb3JlXCI7XG5pbXBvcnQgeyBOaWNlUGlwZXNNb2R1bGUgfSBmcm9tIFwiLi4vLi4vcGlwZXNcIjtcbmltcG9ydCB7IEhlYWRlckNvbXBvbmVudCB9IGZyb20gXCIuL2NvbXBvbmVudHMvaGVhZGVyL2hlYWRlci5jb21wb25lbnRcIjtcbmltcG9ydCB7IFJhbmdlUHJlc2V0Q29tcG9uZW50IH0gZnJvbSBcIi4vY29tcG9uZW50cy9yYW5nZS1wcmVzZXQvcmFuZ2UtcHJlc2V0LmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgTmljZURhdGVSYW5nZVBpY2tlckNvbXBvbmVudCB9IGZyb20gXCIuL2RhdGUtcmFuZ2UtcGlja2VyLmNvbXBvbmVudFwiO1xuaW1wb3J0IHsgTmljZURhdGVSYW5nZVBpY2tlclNlcnZpY2VTZXJ2aWNlIH0gZnJvbSBcIi4vcHJvdmlkZXJzL2RhdGUtcmFuZ2UtcGlja2VyLnNlcnZpY2VcIjtcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgTWF0RGF0ZXBpY2tlck1vZHVsZSxcbiAgICAgICAgTWF0Rm9ybUZpZWxkTW9kdWxlLFxuICAgICAgICBNYXRDYXJkTW9kdWxlLFxuICAgICAgICBNYXRCdXR0b25Nb2R1bGUsXG4gICAgICAgIE1hdEljb25Nb2R1bGUsXG4gICAgICAgIFRyYW5zbGF0ZU1vZHVsZSxcbiAgICAgICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgICAgICAgTmljZVBpcGVzTW9kdWxlXG4gICAgXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtOaWNlRGF0ZVJhbmdlUGlja2VyQ29tcG9uZW50LCBSYW5nZVByZXNldENvbXBvbmVudCwgSGVhZGVyQ29tcG9uZW50XSxcbiAgICBwcm92aWRlcnM6IFtOaWNlRGF0ZVJhbmdlUGlja2VyU2VydmljZVNlcnZpY2VdLFxuICAgIGV4cG9ydHM6IFtOaWNlRGF0ZVJhbmdlUGlja2VyQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBOaWNlRGF0ZVJhbmdlUGlja2VyTW9kdWxlIHt9XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export * from "./public-api";
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uaWNlLXVpLWtpdC12Mi9zcmMvbGliL2NvbXBvbmVudHMvZGF0ZS1yYW5nZS1waWNrZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9wdWJsaWMtYXBpXCI7XG4iXX0=
@@ -0,0 +1,17 @@
1
+ import { Injectable } from "@angular/core";
2
+ import { BehaviorSubject } from "rxjs";
3
+ import * as i0 from "@angular/core";
4
+ export class NiceDateRangePickerServiceService {
5
+ constructor() {
6
+ this.allowClear$ = new BehaviorSubject(true);
7
+ }
8
+ setAllowClear(allowClear) {
9
+ this.allowClear$.next(allowClear);
10
+ }
11
+ }
12
+ NiceDateRangePickerServiceService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceDateRangePickerServiceService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
13
+ NiceDateRangePickerServiceService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceDateRangePickerServiceService });
14
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceDateRangePickerServiceService, decorators: [{
15
+ type: Injectable
16
+ }] });
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1yYW5nZS1waWNrZXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvY29tcG9uZW50cy9kYXRlLXJhbmdlLXBpY2tlci9wcm92aWRlcnMvZGF0ZS1yYW5nZS1waWNrZXIuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxNQUFNLENBQUM7O0FBR3ZDLE1BQU0sT0FBTyxpQ0FBaUM7SUFEOUM7UUFFVyxnQkFBVyxHQUFHLElBQUksZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDO0tBS2xEO0lBSFUsYUFBYSxDQUFDLFVBQW1CO1FBQ3BDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7OzhIQUxRLGlDQUFpQztrSUFBakMsaUNBQWlDOzJGQUFqQyxpQ0FBaUM7a0JBRDdDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCB9IGZyb20gXCJyeGpzXCI7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBOaWNlRGF0ZVJhbmdlUGlja2VyU2VydmljZVNlcnZpY2Uge1xuICAgIHB1YmxpYyBhbGxvd0NsZWFyJCA9IG5ldyBCZWhhdmlvclN1YmplY3QodHJ1ZSk7XG5cbiAgICBwdWJsaWMgc2V0QWxsb3dDbGVhcihhbGxvd0NsZWFyOiBib29sZWFuKTogdm9pZCB7XG4gICAgICAgIHRoaXMuYWxsb3dDbGVhciQubmV4dChhbGxvd0NsZWFyKTtcbiAgICB9XG59XG4iXX0=
@@ -0,0 +1,3 @@
1
+ export * from "./date-range-picker.component";
2
+ export * from "./date-range-picker.module";
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pY2UtdWkta2l0LXYyL3NyYy9saWIvY29tcG9uZW50cy9kYXRlLXJhbmdlLXBpY2tlci9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyw0QkFBNEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2RhdGUtcmFuZ2UtcGlja2VyLmNvbXBvbmVudFwiO1xuZXhwb3J0ICogZnJvbSBcIi4vZGF0ZS1yYW5nZS1waWNrZXIubW9kdWxlXCI7XG4iXX0=
@@ -0,0 +1,164 @@
1
+ import { Overlay } from "@angular/cdk/overlay";
2
+ import { Platform } from "@angular/cdk/platform";
3
+ import { ComponentPortal } from "@angular/cdk/portal";
4
+ import { Directive, ElementRef, Input, NgZone, ViewContainerRef } from "@angular/core";
5
+ import { Subject } from "rxjs";
6
+ import { takeUntil } from "rxjs/operators";
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "@angular/cdk/overlay";
9
+ import * as i2 from "@angular/cdk/platform";
10
+ export class NiceShowHintDirective {
11
+ constructor(_overlay, _elementRef, _viewContainerRef, _ngZone, _platform) {
12
+ this._overlay = _overlay;
13
+ this._elementRef = _elementRef;
14
+ this._viewContainerRef = _viewContainerRef;
15
+ this._ngZone = _ngZone;
16
+ this._platform = _platform;
17
+ this.shouldShow = false;
18
+ this._pointerExitEventsInitialized = false;
19
+ this._passiveListeners = [];
20
+ this.unsubscribeAll$ = new Subject();
21
+ }
22
+ ngAfterViewInit() {
23
+ this._setupPointerEnterEventsIfNeeded();
24
+ if (this.item.hint) {
25
+ this._portal = new ComponentPortal(this.item.hint.component, this._viewContainerRef);
26
+ }
27
+ }
28
+ ngOnDestroy() {
29
+ this.unsubscribeAll$.next();
30
+ this.unsubscribeAll$.complete();
31
+ }
32
+ show() {
33
+ if (!this.shouldShow || !this.item.hint || this._isHintVisible()) {
34
+ return;
35
+ }
36
+ const overlayRef = this._createOverlay();
37
+ this._detach();
38
+ const instance = (this._hintInstance = overlayRef.attach(this._portal).instance);
39
+ instance._triggerElement = this._elementRef.nativeElement;
40
+ instance
41
+ .afterHidden()
42
+ .pipe(takeUntil(this.unsubscribeAll$))
43
+ .subscribe(() => this._detach());
44
+ instance.show();
45
+ }
46
+ hide() {
47
+ const instance = this._hintInstance;
48
+ if (instance) {
49
+ this._detach();
50
+ }
51
+ }
52
+ _createOverlay() {
53
+ if (this._overlayRef) {
54
+ const existingStrategy = this._overlayRef.getConfig()
55
+ .positionStrategy;
56
+ // @ts-ignore
57
+ if (!origin && existingStrategy._origin instanceof ElementRef) {
58
+ return this._overlayRef;
59
+ }
60
+ this._detach();
61
+ }
62
+ // Create connected position strategy that listens for scroll events to reposition.
63
+ const strategy = this._overlay
64
+ .position()
65
+ .flexibleConnectedTo(this._elementRef)
66
+ .withPositions([
67
+ {
68
+ originX: "center",
69
+ originY: "bottom",
70
+ overlayX: "start",
71
+ overlayY: "top",
72
+ offsetY: 8
73
+ }
74
+ ])
75
+ .withFlexibleDimensions(false);
76
+ strategy.positionChanges.pipe(takeUntil(this.unsubscribeAll$)).subscribe(change => {
77
+ if (this._hintInstance) {
78
+ if (change.scrollableViewProperties.isOverlayClipped && this._hintInstance.isVisible()) {
79
+ // After position changes occur and the overlay is clipped by
80
+ // a parent scrollable then close the tooltip.
81
+ this._ngZone.run(() => this.hide());
82
+ }
83
+ }
84
+ });
85
+ this._overlayRef = this._overlay.create({
86
+ positionStrategy: strategy
87
+ });
88
+ this._overlayRef
89
+ .detachments()
90
+ .pipe(takeUntil(this.unsubscribeAll$))
91
+ .subscribe(() => this._detach());
92
+ this._overlayRef
93
+ .outsidePointerEvents()
94
+ .pipe(takeUntil(this.unsubscribeAll$))
95
+ .subscribe(() => this._hintInstance?._handleBodyInteraction());
96
+ return this._overlayRef;
97
+ }
98
+ _detach() {
99
+ if (this._overlayRef && this._overlayRef.hasAttached()) {
100
+ this._overlayRef.detach();
101
+ }
102
+ this._hintInstance = null;
103
+ }
104
+ _isHintVisible() {
105
+ return !!this._hintInstance && this._hintInstance.isVisible();
106
+ }
107
+ _setupPointerEnterEventsIfNeeded() {
108
+ // Optimization: Defer hooking up events if there's no message or the tooltip is disabled.
109
+ if (this._passiveListeners.length) {
110
+ return;
111
+ }
112
+ // The mouse events shouldn't be bound on mobile devices, because they can prevent the
113
+ // first tap from firing its click event or can cause the tooltip to open for clicks.
114
+ if (this._platformSupportsMouseEvents()) {
115
+ this._passiveListeners.push([
116
+ "mouseenter",
117
+ () => {
118
+ this._setupPointerExitEventsIfNeeded();
119
+ this.show();
120
+ },
121
+ ]);
122
+ }
123
+ this._addListeners(this._passiveListeners);
124
+ }
125
+ _setupPointerExitEventsIfNeeded() {
126
+ if (this._pointerExitEventsInitialized) {
127
+ return;
128
+ }
129
+ this._pointerExitEventsInitialized = true;
130
+ const exitListeners = [];
131
+ if (this._platformSupportsMouseEvents()) {
132
+ exitListeners.push([
133
+ "mouseleave",
134
+ event => {
135
+ const newTarget = event.relatedTarget;
136
+ if (!newTarget || !this._overlayRef?.overlayElement.contains(newTarget)) {
137
+ this.hide();
138
+ }
139
+ },
140
+ ]);
141
+ }
142
+ this._addListeners(exitListeners);
143
+ this._passiveListeners.push(...exitListeners);
144
+ }
145
+ _platformSupportsMouseEvents() {
146
+ return !this._platform.IOS && !this._platform.ANDROID;
147
+ }
148
+ _addListeners(listeners) {
149
+ listeners.forEach(([event, listener]) => {
150
+ this._elementRef.nativeElement.addEventListener(event, listener);
151
+ });
152
+ }
153
+ }
154
+ NiceShowHintDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceShowHintDirective, deps: [{ token: i1.Overlay }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i0.NgZone }, { token: i2.Platform }], target: i0.ɵɵFactoryTarget.Directive });
155
+ NiceShowHintDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.0.3", type: NiceShowHintDirective, selector: "[niceShowHint]", inputs: { shouldShow: "shouldShow", item: "item" }, ngImport: i0 });
156
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceShowHintDirective, decorators: [{
157
+ type: Directive,
158
+ args: [{ selector: "[niceShowHint]" }]
159
+ }], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i0.NgZone }, { type: i2.Platform }]; }, propDecorators: { shouldShow: [{
160
+ type: Input
161
+ }], item: [{
162
+ type: Input
163
+ }] } });
164
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"show-hint.directive.js","sourceRoot":"","sources":["../../../../../../../projects/nice-ui-kit-v2/src/lib/components/navigation/directives/show-hint.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { FlexibleConnectedPositionStrategy, Overlay, OverlayRef } from \"@angular/cdk/overlay\";\nimport { Platform } from \"@angular/cdk/platform\";\nimport { ComponentPortal } from \"@angular/cdk/portal\";\nimport { AfterViewInit, Directive, ElementRef, Input, NgZone, OnDestroy, ViewContainerRef } from \"@angular/core\";\nimport { Subject } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\nimport { NiceNavigationItem } from \"../navigation.types\";\n\n@Directive({ selector: \"[niceShowHint]\" })\nexport class NiceShowHintDirective implements AfterViewInit, OnDestroy {\n    @Input()\n    public shouldShow = false;\n\n    @Input()\n    public item: NiceNavigationItem;\n\n    private _pointerExitEventsInitialized = false;\n    private _portal: ComponentPortal<any>;\n    private _hintInstance: any;\n    private _overlayRef: OverlayRef;\n\n    private readonly _passiveListeners: (readonly [string, EventListenerOrEventListenerObject])[] = [];\n    private readonly unsubscribeAll$ = new Subject<void>();\n\n    constructor(\n        private _overlay: Overlay,\n        private _elementRef: ElementRef<HTMLElement>,\n        private _viewContainerRef: ViewContainerRef,\n        private _ngZone: NgZone,\n        private _platform: Platform\n    ) {}\n\n    public ngAfterViewInit(): void {\n        this._setupPointerEnterEventsIfNeeded();\n\n        if (this.item.hint) {\n            this._portal = new ComponentPortal<any>(this.item.hint.component, this._viewContainerRef);\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.unsubscribeAll$.next();\n        this.unsubscribeAll$.complete();\n    }\n\n    public show(): void {\n        if (!this.shouldShow || !this.item.hint || this._isHintVisible()) {\n            return;\n        }\n\n        const overlayRef = this._createOverlay();\n        this._detach();\n        const instance = (this._hintInstance = overlayRef.attach(this._portal).instance);\n        instance._triggerElement = this._elementRef.nativeElement;\n        instance\n            .afterHidden()\n            .pipe(takeUntil(this.unsubscribeAll$))\n            .subscribe(() => this._detach());\n\n        instance.show();\n    }\n\n    public hide(): void {\n        const instance = this._hintInstance;\n\n        if (instance) {\n            this._detach();\n        }\n    }\n\n    private _createOverlay(): OverlayRef {\n        if (this._overlayRef) {\n            const existingStrategy = this._overlayRef.getConfig()\n                .positionStrategy as FlexibleConnectedPositionStrategy;\n\n            // @ts-ignore\n            if (!origin && existingStrategy._origin instanceof ElementRef) {\n                return this._overlayRef;\n            }\n\n            this._detach();\n        }\n\n        // Create connected position strategy that listens for scroll events to reposition.\n        const strategy = this._overlay\n            .position()\n            .flexibleConnectedTo(this._elementRef)\n            .withPositions([\n                {\n                    originX: \"center\",\n                    originY: \"bottom\",\n                    overlayX: \"start\",\n                    overlayY: \"top\",\n                    offsetY: 8\n                }\n            ])\n            .withFlexibleDimensions(false);\n\n        strategy.positionChanges.pipe(takeUntil(this.unsubscribeAll$)).subscribe(change => {\n            if (this._hintInstance) {\n                if (change.scrollableViewProperties.isOverlayClipped && this._hintInstance.isVisible()) {\n                    // After position changes occur and the overlay is clipped by\n                    // a parent scrollable then close the tooltip.\n                    this._ngZone.run(() => this.hide());\n                }\n            }\n        });\n\n        this._overlayRef = this._overlay.create({\n            positionStrategy: strategy\n        });\n\n        this._overlayRef\n            .detachments()\n            .pipe(takeUntil(this.unsubscribeAll$))\n            .subscribe(() => this._detach());\n\n        this._overlayRef\n            .outsidePointerEvents()\n            .pipe(takeUntil(this.unsubscribeAll$))\n            .subscribe(() => this._hintInstance?._handleBodyInteraction());\n\n        return this._overlayRef;\n    }\n\n    private _detach() {\n        if (this._overlayRef && this._overlayRef.hasAttached()) {\n            this._overlayRef.detach();\n        }\n\n        this._hintInstance = null;\n    }\n\n    private _isHintVisible(): boolean {\n        return !!this._hintInstance && this._hintInstance.isVisible();\n    }\n\n    private _setupPointerEnterEventsIfNeeded() {\n        // Optimization: Defer hooking up events if there's no message or the tooltip is disabled.\n        if (this._passiveListeners.length) {\n            return;\n        }\n\n        // The mouse events shouldn't be bound on mobile devices, because they can prevent the\n        // first tap from firing its click event or can cause the tooltip to open for clicks.\n        if (this._platformSupportsMouseEvents()) {\n            this._passiveListeners.push([\n                \"mouseenter\",\n                () => {\n                    this._setupPointerExitEventsIfNeeded();\n                    this.show();\n                },\n            ]);\n        }\n\n        this._addListeners(this._passiveListeners);\n    }\n\n    private _setupPointerExitEventsIfNeeded() {\n        if (this._pointerExitEventsInitialized) {\n            return;\n        }\n        this._pointerExitEventsInitialized = true;\n\n        const exitListeners: (readonly [string, EventListenerOrEventListenerObject])[] = [];\n        if (this._platformSupportsMouseEvents()) {\n            exitListeners.push(\n                [\n                    \"mouseleave\",\n                    event => {\n                        const newTarget = (event as MouseEvent).relatedTarget as Node | null;\n                        if (!newTarget || !this._overlayRef?.overlayElement.contains(newTarget)) {\n                            this.hide();\n                        }\n                    },\n                ]\n            );\n        }\n\n        this._addListeners(exitListeners);\n        this._passiveListeners.push(...exitListeners);\n    }\n\n    private _platformSupportsMouseEvents() {\n        return !this._platform.IOS && !this._platform.ANDROID;\n    }\n\n    private _addListeners(listeners: (readonly [string, EventListenerOrEventListenerObject])[]) {\n        listeners.forEach(([event, listener]) => {\n            this._elementRef.nativeElement.addEventListener(event, listener);\n        });\n    }\n}\n"]}