@datarailsshared/datarailsshared 1.6.334 → 1.6.338

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 (61) hide show
  1. package/assets/styles/_styles.scss +2 -1
  2. package/datarailsshared-datarailsshared-1.6.338.tgz +0 -0
  3. package/esm2022/lib/dr-dialog/components/dialog-modal-wrapper/dialog-modal-wrapper.component.mjs +6 -6
  4. package/esm2022/lib/dr-grid/components/cells/tbl-header/tbl-header.component.mjs +3 -3
  5. package/esm2022/lib/dr-grid/components/dr-grid-columns-filter-popover/dr-grid-columns-filter-popover.component.mjs +4 -4
  6. package/esm2022/lib/dr-grid/components/dr-grid-toolbar/dr-grid-toolbar.component.mjs +3 -3
  7. package/esm2022/lib/dr-inputs/button/button.component.mjs +2 -2
  8. package/esm2022/lib/dr-inputs/button/dr-button-link.directive.mjs +34 -0
  9. package/esm2022/lib/dr-inputs/checkbox/checkbox.component.mjs +5 -4
  10. package/esm2022/lib/dr-inputs/date-pickers/date-time-picker/date-time-picker.component.mjs +5 -6
  11. package/esm2022/lib/dr-inputs/date-pickers/directives/dr-date-picker-format.directive.mjs +3 -2
  12. package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.mjs +20 -11
  13. package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker-range/dr-date-picker-range.component.mjs +9 -8
  14. package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.mjs +13 -10
  15. package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.mjs +13 -10
  16. package/esm2022/lib/dr-inputs/date-pickers/dr-fiscal-month-calendar-picker/dr-fiscal-month-calendar-header.component.mjs +11 -8
  17. package/esm2022/lib/dr-inputs/date-pickers/dr-fiscal-month-calendar-picker/dr-fiscal-month-calendar-picker.component.mjs +20 -9
  18. package/esm2022/lib/dr-inputs/date-pickers/dr-show-timeframe.pipe.mjs +3 -2
  19. package/esm2022/lib/dr-inputs/date-pickers/time-picker/time-picker.component.mjs +6 -7
  20. package/esm2022/lib/dr-inputs/dr-input/dr-input.component.mjs +12 -9
  21. package/esm2022/lib/dr-inputs/dr-inputs.module.mjs +29 -73
  22. package/esm2022/lib/dr-inputs/dr-model-debounce-change.directive.mjs +3 -2
  23. package/esm2022/lib/dr-inputs/dr-select/dr-select.component.mjs +12 -9
  24. package/esm2022/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.mjs +8 -7
  25. package/esm2022/lib/dr-inputs/dr-toggle/dr-toggle.component.mjs +5 -4
  26. package/esm2022/lib/dr-inputs/dr-toggle-button/dr-toggle-button.component.mjs +6 -4
  27. package/esm2022/lib/dr-inputs/index.mjs +3 -0
  28. package/esm2022/lib/dr-inputs/public-api.mjs +24 -0
  29. package/esm2022/lib/dr-inputs/radio-button/radio-button.component.mjs +6 -6
  30. package/esm2022/lib/dr-inputs/radio-button/radio-group.component.mjs +4 -3
  31. package/esm2022/lib/filter-dropdown/filter-dropdown.component.mjs +4 -4
  32. package/esm2022/local-api.mjs +2 -25
  33. package/fesm2022/datarailsshared-datarailsshared.mjs +5598 -5604
  34. package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
  35. package/lib/dr-inputs/button/dr-button-link.directive.d.ts +9 -0
  36. package/lib/dr-inputs/checkbox/checkbox.component.d.ts +1 -1
  37. package/lib/dr-inputs/date-pickers/directives/dr-date-picker-format.directive.d.ts +1 -1
  38. package/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.d.ts +1 -1
  39. package/lib/dr-inputs/date-pickers/dr-date-picker-range/dr-date-picker-range.component.d.ts +1 -1
  40. package/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.d.ts +1 -1
  41. package/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.d.ts +1 -1
  42. package/lib/dr-inputs/date-pickers/dr-fiscal-month-calendar-picker/dr-fiscal-month-calendar-header.component.d.ts +1 -1
  43. package/lib/dr-inputs/date-pickers/dr-fiscal-month-calendar-picker/dr-fiscal-month-calendar-picker.component.d.ts +1 -1
  44. package/lib/dr-inputs/date-pickers/dr-show-timeframe.pipe.d.ts +1 -1
  45. package/lib/dr-inputs/dr-input/dr-input.component.d.ts +1 -1
  46. package/lib/dr-inputs/dr-inputs.module.d.ts +20 -30
  47. package/lib/dr-inputs/dr-model-debounce-change.directive.d.ts +1 -1
  48. package/lib/dr-inputs/dr-select/dr-select.component.d.ts +1 -1
  49. package/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.d.ts +1 -1
  50. package/lib/dr-inputs/dr-toggle/dr-toggle.component.d.ts +1 -1
  51. package/lib/dr-inputs/dr-toggle-button/dr-toggle-button.component.d.ts +1 -1
  52. package/lib/dr-inputs/index.d.ts +2 -0
  53. package/lib/dr-inputs/public-api.d.ts +23 -0
  54. package/lib/dr-inputs/radio-button/radio-button.component.d.ts +1 -1
  55. package/lib/dr-inputs/radio-button/radio-group.component.d.ts +1 -1
  56. package/local-api.d.ts +1 -24
  57. package/package.json +1 -1
  58. package/styles.css +393 -193
  59. package/datarailsshared-datarailsshared-1.6.334.tgz +0 -0
  60. package/esm2022/lib/dr-inputs/dr-link/dr-link.component.mjs +0 -43
  61. package/lib/dr-inputs/dr-link/dr-link.component.d.ts +0 -16
@@ -1,12 +1,15 @@
1
1
  import { DrDatePickerCustomHeaderComponent } from '../dr-date-picker_custom-header/dr-date-picker_custom-header.component';
2
2
  import { ChangeDetectionStrategy, Component } from '@angular/core';
3
3
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
+ import { CommonModule } from '@angular/common';
5
+ import { FormsModule } from '@angular/forms';
6
+ import { DrSelectComponent } from '../../dr-select/dr-select.component';
7
+ import { DrTooltipModule } from '../../../dr-tooltip/dr-tooltip.module';
8
+ import { DrShowTimeframePipe } from '../dr-show-timeframe.pipe';
4
9
  import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/forms";
6
- import * as i2 from "@angular/common";
10
+ import * as i1 from "@angular/common";
11
+ import * as i2 from "@angular/forms";
7
12
  import * as i3 from "../../../dr-tooltip/dr-tooltip.directive";
8
- import * as i4 from "../../dr-select/dr-select.component";
9
- import * as i5 from "../dr-show-timeframe.pipe";
10
13
  const _c0 = ["class", "component"];
11
14
  const _c1 = function (a0) { return { "dr-datepicker-preset-date__tags__tag--selected": a0 }; };
12
15
  function DrFiscalMonthCalendarHeaderComponent_div_0_div_1_div_2_Template(rf, ctx) { if (rf & 1) {
@@ -110,7 +113,7 @@ export class DrFiscalMonthCalendarHeaderComponent extends DrDatePickerCustomHead
110
113
  });
111
114
  }
112
115
  /** @nocollapse */ static { this.ɵfac = /** @pureOrBreakMyCode */ function () { let ɵDrFiscalMonthCalendarHeaderComponent_BaseFactory; return function DrFiscalMonthCalendarHeaderComponent_Factory(t) { return (ɵDrFiscalMonthCalendarHeaderComponent_BaseFactory || (ɵDrFiscalMonthCalendarHeaderComponent_BaseFactory = i0.ɵɵgetInheritedFactory(DrFiscalMonthCalendarHeaderComponent)))(t || DrFiscalMonthCalendarHeaderComponent); }; }(); }
113
- /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrFiscalMonthCalendarHeaderComponent, selectors: [["dr-fiscal-month-calendar-header", 8, "component"]], features: [i0.ɵɵInheritDefinitionFeature], attrs: _c0, decls: 12, vars: 4, consts: [["class", "dr-datepicker__timeframe-select__wrapper", 4, "ngIf"], [1, "dr-date-paging"], [1, "dr-date-paging", "flip-page-button", 3, "click"], [1, "dr-icon-arrow-left", "presentation_buttons-navigate_input"], [1, "example-header-label"], [3, "click"], [1, "dr-icon-arrow-right", "presentation_buttons-navigate_input"], ["class", "dr-quarterly-datepicker", 4, "ngIf"], [1, "dr-datepicker__timeframe-select__wrapper"], ["class", "dr-datepicker-preset-date", 4, "ngIf"], ["class", "dr-datepicker__timeframe-select", "bindLabel", "title", "bindValue", "value", 3, "ngModel", "items", "ngModelChange", 4, "ngIf"], [1, "dr-datepicker-preset-date"], [1, "dr-datepicker-preset-date__tags", 3, "ngClass"], ["id", "preset_tag", "class", "dr-datepicker-preset-date__tags__tag", 3, "ngClass", "drTooltip", "drTooltipPosition", "click", 4, "ngFor", "ngForOf"], ["id", "preset_tag", 1, "dr-datepicker-preset-date__tags__tag", 3, "ngClass", "drTooltip", "drTooltipPosition", "click"], ["bindLabel", "title", "bindValue", "value", 1, "dr-datepicker__timeframe-select", 3, "ngModel", "items", "ngModelChange"], [1, "dr-quarterly-datepicker"], ["quarterlyDatePicker", ""], ["class", "quarter-selector quarter-selector--select-current-quarter", 3, "class", "quarter-selector--disabled", "click", 4, "ngFor", "ngForOf"], [1, "quarter-selector", "quarter-selector--select-current-quarter", 3, "click"]], template: function DrFiscalMonthCalendarHeaderComponent_Template(rf, ctx) { if (rf & 1) {
116
+ /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrFiscalMonthCalendarHeaderComponent, selectors: [["dr-fiscal-month-calendar-header", 8, "component"]], standalone: true, features: [i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], attrs: _c0, decls: 12, vars: 4, consts: [["class", "dr-datepicker__timeframe-select__wrapper", 4, "ngIf"], [1, "dr-date-paging"], [1, "dr-date-paging", "flip-page-button", 3, "click"], [1, "dr-icon-arrow-left", "presentation_buttons-navigate_input"], [1, "example-header-label"], [3, "click"], [1, "dr-icon-arrow-right", "presentation_buttons-navigate_input"], ["class", "dr-quarterly-datepicker", 4, "ngIf"], [1, "dr-datepicker__timeframe-select__wrapper"], ["class", "dr-datepicker-preset-date", 4, "ngIf"], ["class", "dr-datepicker__timeframe-select", "bindLabel", "title", "bindValue", "value", 3, "ngModel", "items", "ngModelChange", 4, "ngIf"], [1, "dr-datepicker-preset-date"], [1, "dr-datepicker-preset-date__tags", 3, "ngClass"], ["id", "preset_tag", "class", "dr-datepicker-preset-date__tags__tag", 3, "ngClass", "drTooltip", "drTooltipPosition", "click", 4, "ngFor", "ngForOf"], ["id", "preset_tag", 1, "dr-datepicker-preset-date__tags__tag", 3, "ngClass", "drTooltip", "drTooltipPosition", "click"], ["bindLabel", "title", "bindValue", "value", 1, "dr-datepicker__timeframe-select", 3, "ngModel", "items", "ngModelChange"], [1, "dr-quarterly-datepicker"], ["quarterlyDatePicker", ""], ["class", "quarter-selector quarter-selector--select-current-quarter", 3, "class", "quarter-selector--disabled", "click", 4, "ngFor", "ngForOf"], [1, "quarter-selector", "quarter-selector--select-current-quarter", 3, "click"]], template: function DrFiscalMonthCalendarHeaderComponent_Template(rf, ctx) { if (rf & 1) {
114
117
  i0.ɵɵtemplate(0, DrFiscalMonthCalendarHeaderComponent_div_0_Template, 3, 2, "div", 0);
115
118
  i0.ɵɵelementStart(1, "div", 1)(2, "div", 2);
116
119
  i0.ɵɵlistener("click", function DrFiscalMonthCalendarHeaderComponent_Template_div_click_2_listener() { return ctx.pagingClicked(false); });
@@ -137,10 +140,10 @@ export class DrFiscalMonthCalendarHeaderComponent extends DrDatePickerCustomHead
137
140
  i0.ɵɵtextInterpolate(ctx.periodYearLabel);
138
141
  i0.ɵɵadvance(3);
139
142
  i0.ɵɵproperty("ngIf", ctx.currentViewIsQuarter);
140
- } }, dependencies: [i1.NgControlStatus, i1.NgModel, i2.NgClass, i2.NgForOf, i2.NgIf, i3.DrTooltipDirective, i4.DrSelectComponent, i5.DrShowTimeframePipe], styles: ["[_nghost-%COMP%]{height:54px;align-items:center;font-family:Poppins;font-style:normal;font-weight:600;font-size:14px;line-height:22px}.dr-datepicker__timeframe-select__wrapper[_ngcontent-%COMP%]{background-color:#f9faff;padding:16px 32px;border-radius:18px 18px 0 0}.dr-datepicker-preset-date[_ngcontent-%COMP%]{display:flex;flex-direction:column}.dr-datepicker-preset-date__tags[_ngcontent-%COMP%]{display:flex;flex-wrap:wrap;row-gap:8px;padding-bottom:21px;padding-top:10px;font-size:12px}.dr-datepicker-preset-date__tags--solo[_ngcontent-%COMP%]{padding:16px 32px;gap:16px;justify-content:center}.dr-datepicker-preset-date__tags--solo[_ngcontent-%COMP%] .dr-datepicker-preset-date__tags__tag[_ngcontent-%COMP%]{padding:4px 8px;justify-content:center;display:flex;flex:1 0 0}.dr-datepicker-preset-date__tags__tag[_ngcontent-%COMP%]{cursor:pointer;font-weight:400;line-height:20px!important;padding:2px 8px;border:1px solid #9ea1aa;border-radius:18px;background:#fff;margin-right:4px}.dr-datepicker-preset-date__tags__tag--selected[_ngcontent-%COMP%]{color:#4646ce;background:#f2f2fb;border:1px solid #4646ce}.dr-date-paging[_ngcontent-%COMP%]{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:16px 32px 32px;gap:4px}.dr-date-paging.flip-page-button[_ngcontent-%COMP%]{width:20px;height:20px;padding:0;color:#4e566c}.dr-date-paging.flip-page-button[_ngcontent-%COMP%]:hover{border-radius:50%;background:#f2f2fb;color:#4646ce}.example-header-label[_ngcontent-%COMP%]{cursor:pointer}.dr-quarterly-datepicker[_ngcontent-%COMP%]{display:flex;justify-content:space-between;padding:10px}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector[_ngcontent-%COMP%]{display:block;width:74px;height:40px;text-align:center;border-radius:40px;font-weight:400;padding-top:9px}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector[_ngcontent-%COMP%]:hover{background:#f2f2fb;color:#4646ce;font-weight:600;cursor:pointer}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector.selected[_ngcontent-%COMP%]{background-color:#4646ce;color:#f3f7ff;font-weight:600}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector--disabled[_ngcontent-%COMP%], .dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector--disabled.selected[_ngcontent-%COMP%]{pointer-events:none;background-color:transparent;color:#aeabac;font-weight:400}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector--select-current-quarter.quarter-selector--disabled.selected[_ngcontent-%COMP%]{pointer-events:none;background-color:#673ab7;opacity:.4;color:#f2f2fb;font-weight:400}"], changeDetection: 0 }); }
143
+ } }, dependencies: [CommonModule, i1.NgClass, i1.NgForOf, i1.NgIf, FormsModule, i2.NgControlStatus, i2.NgModel, DrSelectComponent, DrTooltipModule, i3.DrTooltipDirective, DrShowTimeframePipe], styles: ["[_nghost-%COMP%]{height:54px;align-items:center;font-family:Poppins;font-style:normal;font-weight:600;font-size:14px;line-height:22px}.dr-datepicker__timeframe-select__wrapper[_ngcontent-%COMP%]{background-color:#f9faff;padding:16px 32px;border-radius:18px 18px 0 0}.dr-datepicker-preset-date[_ngcontent-%COMP%]{display:flex;flex-direction:column}.dr-datepicker-preset-date__tags[_ngcontent-%COMP%]{display:flex;flex-wrap:wrap;row-gap:8px;padding-bottom:21px;padding-top:10px;font-size:12px}.dr-datepicker-preset-date__tags--solo[_ngcontent-%COMP%]{padding:16px 32px;gap:16px;justify-content:center}.dr-datepicker-preset-date__tags--solo[_ngcontent-%COMP%] .dr-datepicker-preset-date__tags__tag[_ngcontent-%COMP%]{padding:4px 8px;justify-content:center;display:flex;flex:1 0 0}.dr-datepicker-preset-date__tags__tag[_ngcontent-%COMP%]{cursor:pointer;font-weight:400;line-height:20px!important;padding:2px 8px;border:1px solid #9ea1aa;border-radius:18px;background:#fff;margin-right:4px}.dr-datepicker-preset-date__tags__tag--selected[_ngcontent-%COMP%]{color:#4646ce;background:#f2f2fb;border:1px solid #4646ce}.dr-date-paging[_ngcontent-%COMP%]{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:16px 32px 32px;gap:4px}.dr-date-paging.flip-page-button[_ngcontent-%COMP%]{width:20px;height:20px;padding:0;color:#4e566c}.dr-date-paging.flip-page-button[_ngcontent-%COMP%]:hover{border-radius:50%;background:#f2f2fb;color:#4646ce}.example-header-label[_ngcontent-%COMP%]{cursor:pointer}.dr-quarterly-datepicker[_ngcontent-%COMP%]{display:flex;justify-content:space-between;padding:10px}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector[_ngcontent-%COMP%]{display:block;width:74px;height:40px;text-align:center;border-radius:40px;font-weight:400;padding-top:9px}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector[_ngcontent-%COMP%]:hover{background:#f2f2fb;color:#4646ce;font-weight:600;cursor:pointer}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector.selected[_ngcontent-%COMP%]{background-color:#4646ce;color:#f3f7ff;font-weight:600}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector--disabled[_ngcontent-%COMP%], .dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector--disabled.selected[_ngcontent-%COMP%]{pointer-events:none;background-color:transparent;color:#aeabac;font-weight:400}.dr-quarterly-datepicker[_ngcontent-%COMP%] .quarter-selector--select-current-quarter.quarter-selector--disabled.selected[_ngcontent-%COMP%]{pointer-events:none;background-color:#673ab7;opacity:.4;color:#f2f2fb;font-weight:400}"], changeDetection: 0 }); }
141
144
  }
142
145
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrFiscalMonthCalendarHeaderComponent, [{
143
146
  type: Component,
144
- args: [{ selector: 'dr-fiscal-month-calendar-header.component', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"datePickerService.isTimeframeSelectionEnabled\" class=\"dr-datepicker__timeframe-select__wrapper\">\n <div *ngIf=\"datePickerService.isUsingDateTagPresets\" class=\"dr-datepicker-preset-date\">\n <div\n class=\"dr-datepicker-preset-date__tags\"\n [ngClass]=\"{ 'dr-datepicker-preset-date__tags--solo': !datePickerService.isUsingTimeFrameSelect }\">\n <div\n *ngFor=\"let tag of datePickerService.availableDateTagPresets\"\n id=\"preset_tag\"\n class=\"dr-datepicker-preset-date__tags__tag\"\n (click)=\"onSelectPresetTag(tag)\"\n [ngClass]=\"{ 'dr-datepicker-preset-date__tags__tag--selected': tag.key === selectedPresetTag }\"\n [drTooltip]=\"selectedPresetTag === tag.key ? 'Unselect preset' : ''\"\n [drTooltipPosition]=\"'top'\">\n {{ tag.label }}\n </div>\n </div>\n </div>\n <dr-select\n *ngIf=\"datePickerService.isUsingTimeFrameSelect\"\n class=\"dr-datepicker__timeframe-select\"\n [ngModel]=\"selectedTimeframe\"\n [items]=\"timeframeOptions | drShowTimeframePipe: datePickerService.availableTimeframes\"\n bindLabel=\"title\"\n bindValue=\"value\"\n (ngModelChange)=\"setTimeframe($event)\">\n </dr-select>\n</div>\n\n<div class=\"dr-date-paging\">\n <div class=\"dr-date-paging flip-page-button\" (click)=\"pagingClicked(false)\">\n <i class=\"dr-icon-arrow-left presentation_buttons-navigate_input\"></i>\n </div>\n <span class=\"example-header-label\">\n <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_MONTHS)\">{{ periodMonthLabel + ' ' }}</span>\n <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_YEARS)\">{{ periodYearLabel }}</span>\n </span>\n <div class=\"dr-date-paging flip-page-button\" (click)=\"pagingClicked(true)\">\n <i class=\"dr-icon-arrow-right presentation_buttons-navigate_input\"></i>\n </div>\n</div>\n<div #quarterlyDatePicker class=\"dr-quarterly-datepicker\" *ngIf=\"currentViewIsQuarter\">\n <div\n *ngFor=\"let quarter of quarters\"\n class=\"quarter-selector quarter-selector--select-current-quarter\"\n (click)=\"onSelectQuarter(quarter)\"\n [class]=\"quarter === selectedQuarter ? 'selected' : ''\"\n [class.quarter-selector--disabled]=\"isQuarterDisabled(quarter)\">\n Q{{ quarter }}\n </div>\n</div>\n", styles: [":host{height:54px;align-items:center;font-family:Poppins;font-style:normal;font-weight:600;font-size:14px;line-height:22px}.dr-datepicker__timeframe-select__wrapper{background-color:#f9faff;padding:16px 32px;border-radius:18px 18px 0 0}.dr-datepicker-preset-date{display:flex;flex-direction:column}.dr-datepicker-preset-date__tags{display:flex;flex-wrap:wrap;row-gap:8px;padding-bottom:21px;padding-top:10px;font-size:12px}.dr-datepicker-preset-date__tags--solo{padding:16px 32px;gap:16px;justify-content:center}.dr-datepicker-preset-date__tags--solo .dr-datepicker-preset-date__tags__tag{padding:4px 8px;justify-content:center;display:flex;flex:1 0 0}.dr-datepicker-preset-date__tags__tag{cursor:pointer;font-weight:400;line-height:20px!important;padding:2px 8px;border:1px solid #9ea1aa;border-radius:18px;background:#fff;margin-right:4px}.dr-datepicker-preset-date__tags__tag--selected{color:#4646ce;background:#f2f2fb;border:1px solid #4646ce}.dr-date-paging{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:16px 32px 32px;gap:4px}.dr-date-paging.flip-page-button{width:20px;height:20px;padding:0;color:#4e566c}.dr-date-paging.flip-page-button:hover{border-radius:50%;background:#f2f2fb;color:#4646ce}.example-header-label{cursor:pointer}.dr-quarterly-datepicker{display:flex;justify-content:space-between;padding:10px}.dr-quarterly-datepicker .quarter-selector{display:block;width:74px;height:40px;text-align:center;border-radius:40px;font-weight:400;padding-top:9px}.dr-quarterly-datepicker .quarter-selector:hover{background:#f2f2fb;color:#4646ce;font-weight:600;cursor:pointer}.dr-quarterly-datepicker .quarter-selector.selected{background-color:#4646ce;color:#f3f7ff;font-weight:600}.dr-quarterly-datepicker .quarter-selector--disabled,.dr-quarterly-datepicker .quarter-selector--disabled.selected{pointer-events:none;background-color:transparent;color:#aeabac;font-weight:400}.dr-quarterly-datepicker .quarter-selector--select-current-quarter.quarter-selector--disabled.selected{pointer-events:none;background-color:#673ab7;opacity:.4;color:#f2f2fb;font-weight:400}\n"] }]
147
+ args: [{ selector: 'dr-fiscal-month-calendar-header.component', standalone: true, imports: [CommonModule, FormsModule, DrSelectComponent, DrTooltipModule, DrShowTimeframePipe], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"datePickerService.isTimeframeSelectionEnabled\" class=\"dr-datepicker__timeframe-select__wrapper\">\n <div *ngIf=\"datePickerService.isUsingDateTagPresets\" class=\"dr-datepicker-preset-date\">\n <div\n class=\"dr-datepicker-preset-date__tags\"\n [ngClass]=\"{ 'dr-datepicker-preset-date__tags--solo': !datePickerService.isUsingTimeFrameSelect }\">\n <div\n *ngFor=\"let tag of datePickerService.availableDateTagPresets\"\n id=\"preset_tag\"\n class=\"dr-datepicker-preset-date__tags__tag\"\n (click)=\"onSelectPresetTag(tag)\"\n [ngClass]=\"{ 'dr-datepicker-preset-date__tags__tag--selected': tag.key === selectedPresetTag }\"\n [drTooltip]=\"selectedPresetTag === tag.key ? 'Unselect preset' : ''\"\n [drTooltipPosition]=\"'top'\">\n {{ tag.label }}\n </div>\n </div>\n </div>\n <dr-select\n *ngIf=\"datePickerService.isUsingTimeFrameSelect\"\n class=\"dr-datepicker__timeframe-select\"\n [ngModel]=\"selectedTimeframe\"\n [items]=\"timeframeOptions | drShowTimeframePipe: datePickerService.availableTimeframes\"\n bindLabel=\"title\"\n bindValue=\"value\"\n (ngModelChange)=\"setTimeframe($event)\">\n </dr-select>\n</div>\n\n<div class=\"dr-date-paging\">\n <div class=\"dr-date-paging flip-page-button\" (click)=\"pagingClicked(false)\">\n <i class=\"dr-icon-arrow-left presentation_buttons-navigate_input\"></i>\n </div>\n <span class=\"example-header-label\">\n <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_MONTHS)\">{{ periodMonthLabel + ' ' }}</span>\n <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_YEARS)\">{{ periodYearLabel }}</span>\n </span>\n <div class=\"dr-date-paging flip-page-button\" (click)=\"pagingClicked(true)\">\n <i class=\"dr-icon-arrow-right presentation_buttons-navigate_input\"></i>\n </div>\n</div>\n<div #quarterlyDatePicker class=\"dr-quarterly-datepicker\" *ngIf=\"currentViewIsQuarter\">\n <div\n *ngFor=\"let quarter of quarters\"\n class=\"quarter-selector quarter-selector--select-current-quarter\"\n (click)=\"onSelectQuarter(quarter)\"\n [class]=\"quarter === selectedQuarter ? 'selected' : ''\"\n [class.quarter-selector--disabled]=\"isQuarterDisabled(quarter)\">\n Q{{ quarter }}\n </div>\n</div>\n", styles: [":host{height:54px;align-items:center;font-family:Poppins;font-style:normal;font-weight:600;font-size:14px;line-height:22px}.dr-datepicker__timeframe-select__wrapper{background-color:#f9faff;padding:16px 32px;border-radius:18px 18px 0 0}.dr-datepicker-preset-date{display:flex;flex-direction:column}.dr-datepicker-preset-date__tags{display:flex;flex-wrap:wrap;row-gap:8px;padding-bottom:21px;padding-top:10px;font-size:12px}.dr-datepicker-preset-date__tags--solo{padding:16px 32px;gap:16px;justify-content:center}.dr-datepicker-preset-date__tags--solo .dr-datepicker-preset-date__tags__tag{padding:4px 8px;justify-content:center;display:flex;flex:1 0 0}.dr-datepicker-preset-date__tags__tag{cursor:pointer;font-weight:400;line-height:20px!important;padding:2px 8px;border:1px solid #9ea1aa;border-radius:18px;background:#fff;margin-right:4px}.dr-datepicker-preset-date__tags__tag--selected{color:#4646ce;background:#f2f2fb;border:1px solid #4646ce}.dr-date-paging{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:16px 32px 32px;gap:4px}.dr-date-paging.flip-page-button{width:20px;height:20px;padding:0;color:#4e566c}.dr-date-paging.flip-page-button:hover{border-radius:50%;background:#f2f2fb;color:#4646ce}.example-header-label{cursor:pointer}.dr-quarterly-datepicker{display:flex;justify-content:space-between;padding:10px}.dr-quarterly-datepicker .quarter-selector{display:block;width:74px;height:40px;text-align:center;border-radius:40px;font-weight:400;padding-top:9px}.dr-quarterly-datepicker .quarter-selector:hover{background:#f2f2fb;color:#4646ce;font-weight:600;cursor:pointer}.dr-quarterly-datepicker .quarter-selector.selected{background-color:#4646ce;color:#f3f7ff;font-weight:600}.dr-quarterly-datepicker .quarter-selector--disabled,.dr-quarterly-datepicker .quarter-selector--disabled.selected{pointer-events:none;background-color:transparent;color:#aeabac;font-weight:400}.dr-quarterly-datepicker .quarter-selector--select-current-quarter.quarter-selector--disabled.selected{pointer-events:none;background-color:#673ab7;opacity:.4;color:#f2f2fb;font-weight:400}\n"] }]
145
148
  }], null, null); })();
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-fiscal-month-calendar-header.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-fiscal-month-calendar-picker/dr-fiscal-month-calendar-header.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DrDatePickerCustomHeaderComponent } from '../dr-date-picker_custom-header/dr-date-picker_custom-header.component';\nimport { ChangeDetectionStrategy, Component } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\n\n@Component({\n    selector: 'dr-fiscal-month-calendar-header.component',\n    templateUrl: '../dr-date-picker_custom-header/dr-date-picker_custom-header.component.html',\n    styleUrls: ['../dr-date-picker_custom-header/dr-date-picker_custom-header.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrFiscalMonthCalendarHeaderComponent<Moment> extends DrDatePickerCustomHeaderComponent<Moment> {\n    override ngOnInit(): void {\n        setTimeout(() => {\n            if (this._calendar.multiYearView) {\n                this.transformDateInMultiyearViewAccordingToFY();\n            }\n            if (this._calendar.yearView) {\n                this.transformDateInFiscalMonthViewAccordingToFY();\n            }\n            this.goToCurrentDateInViewByFY();\n        });\n    }\n\n    transformDateInFiscalMonthViewAccordingToFY(): void {\n        if (this._calendar.selected) {\n            this._calendar.selected = this.datePickerService.subtractFiscalYearMonthsFromDate(this._calendar.activeDate);\n            this._calendar.activeDate = this._calendar.selected;\n            (this._calendar as any)._changeDetectorRef.markForCheck();\n        }\n    }\n\n    protected override listenToCalendarViewChanges() {\n        this._calendar.viewChanged.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {\n            this.setPeriodLabels();\n            if (this._calendar.multiYearView) {\n                this.transformDateInMultiyearViewAccordingToFY();\n            }\n\n            if (this._calendar.yearView) {\n                this.transformDateInFiscalMonthViewAccordingToFY();\n            }\n        });\n    }\n}\n","<div *ngIf=\"datePickerService.isTimeframeSelectionEnabled\" class=\"dr-datepicker__timeframe-select__wrapper\">\n    <div *ngIf=\"datePickerService.isUsingDateTagPresets\" class=\"dr-datepicker-preset-date\">\n        <div\n            class=\"dr-datepicker-preset-date__tags\"\n            [ngClass]=\"{ 'dr-datepicker-preset-date__tags--solo': !datePickerService.isUsingTimeFrameSelect }\">\n            <div\n                *ngFor=\"let tag of datePickerService.availableDateTagPresets\"\n                id=\"preset_tag\"\n                class=\"dr-datepicker-preset-date__tags__tag\"\n                (click)=\"onSelectPresetTag(tag)\"\n                [ngClass]=\"{ 'dr-datepicker-preset-date__tags__tag--selected': tag.key === selectedPresetTag }\"\n                [drTooltip]=\"selectedPresetTag === tag.key ? 'Unselect preset' : ''\"\n                [drTooltipPosition]=\"'top'\">\n                {{ tag.label }}\n            </div>\n        </div>\n    </div>\n    <dr-select\n        *ngIf=\"datePickerService.isUsingTimeFrameSelect\"\n        class=\"dr-datepicker__timeframe-select\"\n        [ngModel]=\"selectedTimeframe\"\n        [items]=\"timeframeOptions | drShowTimeframePipe: datePickerService.availableTimeframes\"\n        bindLabel=\"title\"\n        bindValue=\"value\"\n        (ngModelChange)=\"setTimeframe($event)\">\n    </dr-select>\n</div>\n\n<div class=\"dr-date-paging\">\n    <div class=\"dr-date-paging flip-page-button\" (click)=\"pagingClicked(false)\">\n        <i class=\"dr-icon-arrow-left presentation_buttons-navigate_input\"></i>\n    </div>\n    <span class=\"example-header-label\">\n        <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_MONTHS)\">{{ periodMonthLabel + ' ' }}</span>\n        <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_YEARS)\">{{ periodYearLabel }}</span>\n    </span>\n    <div class=\"dr-date-paging flip-page-button\" (click)=\"pagingClicked(true)\">\n        <i class=\"dr-icon-arrow-right presentation_buttons-navigate_input\"></i>\n    </div>\n</div>\n<div #quarterlyDatePicker class=\"dr-quarterly-datepicker\" *ngIf=\"currentViewIsQuarter\">\n    <div\n        *ngFor=\"let quarter of quarters\"\n        class=\"quarter-selector quarter-selector--select-current-quarter\"\n        (click)=\"onSelectQuarter(quarter)\"\n        [class]=\"quarter === selectedQuarter ? 'selected' : ''\"\n        [class.quarter-selector--disabled]=\"isQuarterDisabled(quarter)\">\n        Q{{ quarter }}\n    </div>\n</div>\n"]}
149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-fiscal-month-calendar-header.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-fiscal-month-calendar-picker/dr-fiscal-month-calendar-header.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DrDatePickerCustomHeaderComponent } from '../dr-date-picker_custom-header/dr-date-picker_custom-header.component';\nimport { ChangeDetectionStrategy, Component } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { DrSelectComponent } from '../../dr-select/dr-select.component';\nimport { DrTooltipModule } from '../../../dr-tooltip/dr-tooltip.module';\nimport { DrShowTimeframePipe } from '../dr-show-timeframe.pipe';\n\n@Component({\n    selector: 'dr-fiscal-month-calendar-header.component',\n    standalone: true,\n    imports: [CommonModule, FormsModule, DrSelectComponent, DrTooltipModule, DrShowTimeframePipe],\n    templateUrl: '../dr-date-picker_custom-header/dr-date-picker_custom-header.component.html',\n    styleUrls: ['../dr-date-picker_custom-header/dr-date-picker_custom-header.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrFiscalMonthCalendarHeaderComponent<Moment> extends DrDatePickerCustomHeaderComponent<Moment> {\n    override ngOnInit(): void {\n        setTimeout(() => {\n            if (this._calendar.multiYearView) {\n                this.transformDateInMultiyearViewAccordingToFY();\n            }\n            if (this._calendar.yearView) {\n                this.transformDateInFiscalMonthViewAccordingToFY();\n            }\n            this.goToCurrentDateInViewByFY();\n        });\n    }\n\n    transformDateInFiscalMonthViewAccordingToFY(): void {\n        if (this._calendar.selected) {\n            this._calendar.selected = this.datePickerService.subtractFiscalYearMonthsFromDate(this._calendar.activeDate);\n            this._calendar.activeDate = this._calendar.selected;\n            (this._calendar as any)._changeDetectorRef.markForCheck();\n        }\n    }\n\n    protected override listenToCalendarViewChanges() {\n        this._calendar.viewChanged.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {\n            this.setPeriodLabels();\n            if (this._calendar.multiYearView) {\n                this.transformDateInMultiyearViewAccordingToFY();\n            }\n\n            if (this._calendar.yearView) {\n                this.transformDateInFiscalMonthViewAccordingToFY();\n            }\n        });\n    }\n}\n","<div *ngIf=\"datePickerService.isTimeframeSelectionEnabled\" class=\"dr-datepicker__timeframe-select__wrapper\">\n    <div *ngIf=\"datePickerService.isUsingDateTagPresets\" class=\"dr-datepicker-preset-date\">\n        <div\n            class=\"dr-datepicker-preset-date__tags\"\n            [ngClass]=\"{ 'dr-datepicker-preset-date__tags--solo': !datePickerService.isUsingTimeFrameSelect }\">\n            <div\n                *ngFor=\"let tag of datePickerService.availableDateTagPresets\"\n                id=\"preset_tag\"\n                class=\"dr-datepicker-preset-date__tags__tag\"\n                (click)=\"onSelectPresetTag(tag)\"\n                [ngClass]=\"{ 'dr-datepicker-preset-date__tags__tag--selected': tag.key === selectedPresetTag }\"\n                [drTooltip]=\"selectedPresetTag === tag.key ? 'Unselect preset' : ''\"\n                [drTooltipPosition]=\"'top'\">\n                {{ tag.label }}\n            </div>\n        </div>\n    </div>\n    <dr-select\n        *ngIf=\"datePickerService.isUsingTimeFrameSelect\"\n        class=\"dr-datepicker__timeframe-select\"\n        [ngModel]=\"selectedTimeframe\"\n        [items]=\"timeframeOptions | drShowTimeframePipe: datePickerService.availableTimeframes\"\n        bindLabel=\"title\"\n        bindValue=\"value\"\n        (ngModelChange)=\"setTimeframe($event)\">\n    </dr-select>\n</div>\n\n<div class=\"dr-date-paging\">\n    <div class=\"dr-date-paging flip-page-button\" (click)=\"pagingClicked(false)\">\n        <i class=\"dr-icon-arrow-left presentation_buttons-navigate_input\"></i>\n    </div>\n    <span class=\"example-header-label\">\n        <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_MONTHS)\">{{ periodMonthLabel + ' ' }}</span>\n        <span (click)=\"switchViewOnClickOnPeriodLabel(calendarView.FOR_YEARS)\">{{ periodYearLabel }}</span>\n    </span>\n    <div class=\"dr-date-paging flip-page-button\" (click)=\"pagingClicked(true)\">\n        <i class=\"dr-icon-arrow-right presentation_buttons-navigate_input\"></i>\n    </div>\n</div>\n<div #quarterlyDatePicker class=\"dr-quarterly-datepicker\" *ngIf=\"currentViewIsQuarter\">\n    <div\n        *ngFor=\"let quarter of quarters\"\n        class=\"quarter-selector quarter-selector--select-current-quarter\"\n        (click)=\"onSelectQuarter(quarter)\"\n        [class]=\"quarter === selectedQuarter ? 'selected' : ''\"\n        [class.quarter-selector--disabled]=\"isQuarterDisabled(quarter)\">\n        Q{{ quarter }}\n    </div>\n</div>\n"]}
@@ -7,12 +7,15 @@ import * as moment from 'moment';
7
7
  import { ForecastTagService } from '../../../dr-tags/dr-tag/dr-tag-date/dr-tag-forecast/forecast-tag.service';
8
8
  import { TimeframeOption } from '../../../models/datePicker';
9
9
  import { DrFiscalMonthCalendarHeaderComponent } from './dr-fiscal-month-calendar-header.component';
10
+ import { CommonModule } from '@angular/common';
11
+ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
12
+ import { MatDatepickerModule } from '@angular/material/datepicker';
13
+ import { DrButtonComponent } from '../../button/button.component';
14
+ import { DrDatePickerFormatDirective } from '../directives/dr-date-picker-format.directive';
10
15
  import * as i0 from "@angular/core";
11
- import * as i1 from "../../button/button.component";
16
+ import * as i1 from "@angular/common";
12
17
  import * as i2 from "@angular/forms";
13
- import * as i3 from "@angular/common";
14
- import * as i4 from "@angular/material/datepicker";
15
- import * as i5 from "../directives/dr-date-picker-format.directive";
18
+ import * as i3 from "@angular/material/datepicker";
16
19
  function DrFiscalMonthCalendarPickerComponent_i_0_Template(rf, ctx) { if (rf & 1) {
17
20
  const _r4 = i0.ɵɵgetCurrentView();
18
21
  i0.ɵɵelementStart(0, "i", 2);
@@ -143,11 +146,11 @@ export class DrFiscalMonthCalendarPickerComponent extends DrDatePickerComponent
143
146
  return valueToReturn;
144
147
  }
145
148
  /** @nocollapse */ static { this.ɵfac = /** @pureOrBreakMyCode */ function () { let ɵDrFiscalMonthCalendarPickerComponent_BaseFactory; return function DrFiscalMonthCalendarPickerComponent_Factory(t) { return (ɵDrFiscalMonthCalendarPickerComponent_BaseFactory || (ɵDrFiscalMonthCalendarPickerComponent_BaseFactory = i0.ɵɵgetInheritedFactory(DrFiscalMonthCalendarPickerComponent)))(t || DrFiscalMonthCalendarPickerComponent); }; }(); }
146
- /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrFiscalMonthCalendarPickerComponent, selectors: [["dr-fiscal-month-picker"]], features: [i0.ɵɵProvidersFeature([
149
+ /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrFiscalMonthCalendarPickerComponent, selectors: [["dr-fiscal-month-picker"]], standalone: true, features: [i0.ɵɵProvidersFeature([
147
150
  { provide: NG_VALUE_ACCESSOR, useExisting: DrFiscalMonthCalendarPickerComponent, multi: true },
148
151
  { provide: DateAdapter, useClass: FiscalMonthAdapter },
149
152
  DrDatePickerService,
150
- ]), i0.ɵɵInheritDefinitionFeature], decls: 5, vars: 7, consts: [["class", "dr-icon-date", 3, "click", 4, "ngIf"], [4, "ngIf"], [1, "dr-icon-date", 3, "click"], [3, "ngModel", "disabled", "placeholder", "readonly", "min", "max", "click"], [1, "range-input", 3, "formGroup", "rangePicker", "dateFilter"], ["matStartDate", "", "formControlName", "start", 3, "drDatePickerFormat", "dateChange"], ["input", ""], ["matEndDate", "", "formControlName", "end", 3, "drDatePickerFormat"], [3, "startAt", "panelClass", "calendarHeaderComponent", "yearSelected", "monthSelected", "opened", "closed"], ["datePicker", ""], [3, "ngModel", "matDatepicker", "matDatepickerFilter", "disabled", "placeholder", "drDatePickerFormat", "readonly", "min", "max", "ngModelChange", "click"], ["class", "datepicker-button", 3, "icon", "iconAfter", "click", 4, "ngIf"], [3, "panelClass", "startAt", "calendarHeaderComponent", "yearSelected", "monthSelected", "opened", "closed"], [1, "datepicker-button", 3, "icon", "iconAfter", "click"]], template: function DrFiscalMonthCalendarPickerComponent_Template(rf, ctx) { if (rf & 1) {
153
+ ]), i0.ɵɵInheritDefinitionFeature, i0.ɵɵStandaloneFeature], decls: 5, vars: 7, consts: [["class", "dr-icon-date", 3, "click", 4, "ngIf"], [4, "ngIf"], [1, "dr-icon-date", 3, "click"], [3, "ngModel", "disabled", "placeholder", "readonly", "min", "max", "click"], [1, "range-input", 3, "formGroup", "rangePicker", "dateFilter"], ["matStartDate", "", "formControlName", "start", 3, "drDatePickerFormat", "dateChange"], ["input", ""], ["matEndDate", "", "formControlName", "end", 3, "drDatePickerFormat"], [3, "startAt", "panelClass", "calendarHeaderComponent", "yearSelected", "monthSelected", "opened", "closed"], ["datePicker", ""], [3, "ngModel", "matDatepicker", "matDatepickerFilter", "disabled", "placeholder", "drDatePickerFormat", "readonly", "min", "max", "ngModelChange", "click"], ["class", "datepicker-button", 3, "icon", "iconAfter", "click", 4, "ngIf"], [3, "panelClass", "startAt", "calendarHeaderComponent", "yearSelected", "monthSelected", "opened", "closed"], [1, "datepicker-button", 3, "icon", "iconAfter", "click"]], template: function DrFiscalMonthCalendarPickerComponent_Template(rf, ctx) { if (rf & 1) {
151
154
  i0.ɵɵtemplate(0, DrFiscalMonthCalendarPickerComponent_i_0_Template, 1, 0, "i", 0);
152
155
  i0.ɵɵtemplate(1, DrFiscalMonthCalendarPickerComponent_ng_container_1_Template, 10, 19, "ng-container", 1);
153
156
  i0.ɵɵpipe(2, "async");
@@ -159,14 +162,22 @@ export class DrFiscalMonthCalendarPickerComponent extends DrDatePickerComponent
159
162
  i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind1(2, 3, ctx.datePickerService.timeframe$) === ctx.timeframeOption.WEEK);
160
163
  i0.ɵɵadvance(2);
161
164
  i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind1(4, 5, ctx.datePickerService.timeframe$) !== ctx.timeframeOption.WEEK);
162
- } }, dependencies: [i1.DrButtonComponent, i2.DefaultValueAccessor, i2.NgControlStatus, i2.NgControlStatusGroup, i2.NgModel, i2.FormGroupDirective, i2.FormControlName, i3.NgIf, i4.MatDatepicker, i4.MatDatepickerInput, i4.MatDateRangeInput, i4.MatStartDate, i4.MatEndDate, i4.MatDateRangePicker, i5.DrDatePickerFormatDirective, i3.AsyncPipe], styles: ["[_nghost-%COMP%]{position:relative;width:100%;display:flex;flex-direction:row;min-height:32px;height:32px;font-size:14px;font-family:Poppins,sans-serif;background-color:#fff;border:1px solid #9ea1aa;border-radius:6px;color:#333;overflow:hidden;outline:none;cursor:pointer}.use-button-picker[_nghost-%COMP%]{border:none}[_nghost-%COMP%]:hover{border-color:#9ea1aa}.active[_nghost-%COMP%], [_nghost-%COMP%]:focus-within{border-color:#4646ce!important;color:#333}.disabled[_nghost-%COMP%]{pointer-events:none;border:1px solid #aeabac;background:#f0f1f4;color:#aeabac}.disabled[_nghost-%COMP%]:after{color:#aeabac}.ng-valid.ng-dirty[_nghost-%COMP%]{border-color:#037c5a}.ng-invalid.ng-dirty[_nghost-%COMP%]:not(:focus-within){border-color:#bf1d30!important}.ng-untouched.ng-valid[_nghost-%COMP%]{border-color:#9ea1aa}.use-button-picker[_nghost-%COMP%]:after{display:none}[_nghost-%COMP%]:not(.use-button-picker):after, [_nghost-%COMP%]:not(.use-button-picker):before{position:absolute;display:flex;border-color:#6d6e6f transparent transparent;color:#6d6e6f}[_nghost-%COMP%]:not(.use-button-picker):after{font-family:DataRails!important;content:var(--dr-icon-arrow-down, \"\\ea18\");font-size:24px;color:#6d6e6f;top:0;bottom:0;right:8px;pointer-events:none;position:absolute;display:flex;align-items:center;justify-content:center}[_nghost-%COMP%] i[_ngcontent-%COMP%]{display:flex;align-items:center;position:absolute;color:#6d6e6f;left:8px;top:0;bottom:0}[_nghost-%COMP%] input[_ngcontent-%COMP%]{display:flex;flex-grow:1;height:100%;border:none;text-align:left;padding-left:35px;padding-right:25px;cursor:pointer!important;outline:none}[_nghost-%COMP%] input.when-quarter[_ngcontent-%COMP%]{position:absolute;visibility:hidden}[_nghost-%COMP%] input[_ngcontent-%COMP%]:disabled{border:none;color:#aeabac;background:transparent}[_nghost-%COMP%] input[_ngcontent-%COMP%]::-webkit-search-decoration, [_nghost-%COMP%] input[_ngcontent-%COMP%]::-webkit-search-cancel-button, [_nghost-%COMP%] input[_ngcontent-%COMP%]::-webkit-search-results-button, [_nghost-%COMP%] input[_ngcontent-%COMP%]::-webkit-search-results-decoration{-webkit-appearance:none}[_nghost-%COMP%] input[_ngcontent-%COMP%]::placeholder{color:#6d6e6f;font-size:14px;line-height:18px}[_nghost-%COMP%] input.hidden-calendar-input[_ngcontent-%COMP%]{width:0;height:0;padding:0}[_nghost-%COMP%] .datepicker-button[_ngcontent-%COMP%]{width:100%}[_nghost-%COMP%] .range-input[_ngcontent-%COMP%]{position:absolute;height:0;width:0;bottom:0;left:0;z-index:-1} .mat-datepicker-popup .dr-week-datepicker{min-width:min(400px,100vw)!important} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-today{background:#f2f2fb;color:#4646ce;border:none;font-weight:600} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-cell-preview{border:none} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-range-start .mat-calendar-body-cell-preview, .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-preview-start .mat-calendar-body-cell-preview{left:5%;width:95%;border-top-left-radius:40px;border-bottom-left-radius:40px} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-range-end .mat-calendar-body-cell-preview, .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-preview-end .mat-calendar-body-cell-preview{right:5%;width:95%;border-top-right-radius:40px;border-bottom-right-radius:40px} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-preview:not(.mat-calendar-body-in-range) .mat-calendar-body-cell-preview{background-color:#f5f5f5} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-preview:not(.mat-calendar-body-in-range)>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background-color:transparent!important} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-preview:not(.mat-calendar-body-in-range)>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical):not(.mat-calendar-body-today){color:#19181a!important;font-weight:400!important} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-range .mat-calendar-body-cell-preview{background:#4646ce!important} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-range:before{background:initial!important} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-range .mat-calendar-body-selected, .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-range .mat-calendar-body-cell-content{background:transparent!important;color:#f2f2fb!important;font-weight:600!important} .mat-datepicker-popup .mat-datepicker-content{margin:7px 0;box-shadow:0 4px 8px 1px #00000040;border-radius:12px!important} .mat-datepicker-popup .mat-datepicker-content button[disabled]{border:inherit;color:inherit;background-color:inherit} .mat-datepicker-popup .mat-datepicker-content button[disabled]:hover{border:inherit} .mat-datepicker-popup .cdk-keyboard-focused .mat-calendar-body-active>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical), .mat-datepicker-popup .cdk-program-focused .mat-calendar-body-active>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background-color:#fff} .mat-datepicker-popup .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background:#f2f2fb;color:#4646ce;font-weight:600} .mat-datepicker-popup .mat-calendar-body-selected{background-color:#4646ce;color:#f2f2fb;font-weight:600} .mat-datepicker-popup .mat-calendar-body-today.mat-calendar-body-selected{box-shadow:none} .mat-datepicker-popup .mat-button-focus-overlay{background:#f5f5f5} .mat-datepicker-popup .mat-calendar-controls .mat-icon-button:hover .mat-button-focus-overlay{opacity:1!important;background:#f5f5f5;transition:opacity .2s cubic-bezier(.35,0,.25,1)} .mat-datepicker-popup .mat-calendar-controls .mat-calendar-period-button:hover{background:#f5f5f5;transition:background .2s cubic-bezier(.35,0,.25,1)} .mat-datepicker-popup .mat-calendar-table-header th{font-size:14px;font-weight:600;color:#333} .mat-datepicker-popup .mat-calendar-table-header-divider{display:none} .mat-datepicker-popup .mat-calendar-body-label{color:#fff;padding:0} .mat-datepicker-popup .mat-calendar-body>tr[aria-hidden=true]>.mat-calendar-body-label{display:none} .mat-datepicker-popup .mat-calendar-content{display:flex} .mat-datepicker-popup .mat-calendar-content dr-week-selector{flex:0} .mat-datepicker-popup .mat-calendar-content mat-month-view, .mat-datepicker-popup .mat-calendar-content mat-multi-year-view, .mat-datepicker-popup .mat-calendar-content mat-year-view{flex:1}"], changeDetection: 0 }); }
165
+ } }, dependencies: [CommonModule, i1.NgIf, i1.AsyncPipe, FormsModule, i2.DefaultValueAccessor, i2.NgControlStatus, i2.NgControlStatusGroup, i2.NgModel, ReactiveFormsModule, i2.FormGroupDirective, i2.FormControlName, MatDatepickerModule, i3.MatDatepicker, i3.MatDatepickerInput, i3.MatDateRangeInput, i3.MatStartDate, i3.MatEndDate, i3.MatDateRangePicker, DrButtonComponent,
166
+ DrDatePickerFormatDirective], styles: ["[_nghost-%COMP%]{position:relative;width:100%;display:flex;flex-direction:row;min-height:32px;height:32px;font-size:14px;font-family:Poppins,sans-serif;background-color:#fff;border:1px solid #9ea1aa;border-radius:6px;color:#333;overflow:hidden;outline:none;cursor:pointer}.use-button-picker[_nghost-%COMP%]{border:none}[_nghost-%COMP%]:hover{border-color:#9ea1aa}.active[_nghost-%COMP%], [_nghost-%COMP%]:focus-within{border-color:#4646ce!important;color:#333}.disabled[_nghost-%COMP%]{pointer-events:none;border:1px solid #aeabac;background:#f0f1f4;color:#aeabac}.disabled[_nghost-%COMP%]:after{color:#aeabac}.ng-valid.ng-dirty[_nghost-%COMP%]{border-color:#037c5a}.ng-invalid.ng-dirty[_nghost-%COMP%]:not(:focus-within){border-color:#bf1d30!important}.ng-untouched.ng-valid[_nghost-%COMP%]{border-color:#9ea1aa}.use-button-picker[_nghost-%COMP%]:after{display:none}[_nghost-%COMP%]:not(.use-button-picker):after, [_nghost-%COMP%]:not(.use-button-picker):before{position:absolute;display:flex;border-color:#6d6e6f transparent transparent;color:#6d6e6f}[_nghost-%COMP%]:not(.use-button-picker):after{font-family:DataRails!important;content:var(--dr-icon-arrow-down, \"\\ea18\");font-size:24px;color:#6d6e6f;top:0;bottom:0;right:8px;pointer-events:none;position:absolute;display:flex;align-items:center;justify-content:center}[_nghost-%COMP%] i[_ngcontent-%COMP%]{display:flex;align-items:center;position:absolute;color:#6d6e6f;left:8px;top:0;bottom:0}[_nghost-%COMP%] input[_ngcontent-%COMP%]{display:flex;flex-grow:1;height:100%;border:none;text-align:left;padding-left:35px;padding-right:25px;cursor:pointer!important;outline:none}[_nghost-%COMP%] input.when-quarter[_ngcontent-%COMP%]{position:absolute;visibility:hidden}[_nghost-%COMP%] input[_ngcontent-%COMP%]:disabled{border:none;color:#aeabac;background:transparent}[_nghost-%COMP%] input[_ngcontent-%COMP%]::-webkit-search-decoration, [_nghost-%COMP%] input[_ngcontent-%COMP%]::-webkit-search-cancel-button, [_nghost-%COMP%] input[_ngcontent-%COMP%]::-webkit-search-results-button, [_nghost-%COMP%] input[_ngcontent-%COMP%]::-webkit-search-results-decoration{-webkit-appearance:none}[_nghost-%COMP%] input[_ngcontent-%COMP%]::placeholder{color:#6d6e6f;font-size:14px;line-height:18px}[_nghost-%COMP%] input.hidden-calendar-input[_ngcontent-%COMP%]{width:0;height:0;padding:0}[_nghost-%COMP%] .datepicker-button[_ngcontent-%COMP%]{width:100%}[_nghost-%COMP%] .range-input[_ngcontent-%COMP%]{position:absolute;height:0;width:0;bottom:0;left:0;z-index:-1} .mat-datepicker-popup .dr-week-datepicker{min-width:min(400px,100vw)!important} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-today{background:#f2f2fb;color:#4646ce;border:none;font-weight:600} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-cell-preview{border:none} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-range-start .mat-calendar-body-cell-preview, .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-preview-start .mat-calendar-body-cell-preview{left:5%;width:95%;border-top-left-radius:40px;border-bottom-left-radius:40px} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-range-end .mat-calendar-body-cell-preview, .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-preview-end .mat-calendar-body-cell-preview{right:5%;width:95%;border-top-right-radius:40px;border-bottom-right-radius:40px} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-preview:not(.mat-calendar-body-in-range) .mat-calendar-body-cell-preview{background-color:#f5f5f5} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-preview:not(.mat-calendar-body-in-range)>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background-color:transparent!important} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-preview:not(.mat-calendar-body-in-range)>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical):not(.mat-calendar-body-today){color:#19181a!important;font-weight:400!important} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-range .mat-calendar-body-cell-preview{background:#4646ce!important} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-range:before{background:initial!important} .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-range .mat-calendar-body-selected, .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-range .mat-calendar-body-cell-content{background:transparent!important;color:#f2f2fb!important;font-weight:600!important} .mat-datepicker-popup .mat-datepicker-content{margin:7px 0;box-shadow:0 4px 8px 1px #00000040;border-radius:12px!important} .mat-datepicker-popup .mat-datepicker-content button[disabled]{border:inherit;color:inherit;background-color:inherit} .mat-datepicker-popup .mat-datepicker-content button[disabled]:hover{border:inherit} .mat-datepicker-popup .cdk-keyboard-focused .mat-calendar-body-active>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical), .mat-datepicker-popup .cdk-program-focused .mat-calendar-body-active>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background-color:#fff} .mat-datepicker-popup .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background:#f2f2fb;color:#4646ce;font-weight:600} .mat-datepicker-popup .mat-calendar-body-selected{background-color:#4646ce;color:#f2f2fb;font-weight:600} .mat-datepicker-popup .mat-calendar-body-today.mat-calendar-body-selected{box-shadow:none} .mat-datepicker-popup .mat-button-focus-overlay{background:#f5f5f5} .mat-datepicker-popup .mat-calendar-controls .mat-icon-button:hover .mat-button-focus-overlay{opacity:1!important;background:#f5f5f5;transition:opacity .2s cubic-bezier(.35,0,.25,1)} .mat-datepicker-popup .mat-calendar-controls .mat-calendar-period-button:hover{background:#f5f5f5;transition:background .2s cubic-bezier(.35,0,.25,1)} .mat-datepicker-popup .mat-calendar-table-header th{font-size:14px;font-weight:600;color:#333} .mat-datepicker-popup .mat-calendar-table-header-divider{display:none} .mat-datepicker-popup .mat-calendar-body-label{color:#fff;padding:0} .mat-datepicker-popup .mat-calendar-body>tr[aria-hidden=true]>.mat-calendar-body-label{display:none} .mat-datepicker-popup .mat-calendar-content{display:flex} .mat-datepicker-popup .mat-calendar-content dr-week-selector{flex:0} .mat-datepicker-popup .mat-calendar-content mat-month-view, .mat-datepicker-popup .mat-calendar-content mat-multi-year-view, .mat-datepicker-popup .mat-calendar-content mat-year-view{flex:1}"], changeDetection: 0 }); }
163
167
  }
164
168
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrFiscalMonthCalendarPickerComponent, [{
165
169
  type: Component,
166
- args: [{ selector: 'dr-fiscal-month-picker', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
170
+ args: [{ selector: 'dr-fiscal-month-picker', standalone: true, imports: [
171
+ CommonModule,
172
+ FormsModule,
173
+ ReactiveFormsModule,
174
+ MatDatepickerModule,
175
+ DrButtonComponent,
176
+ DrDatePickerFormatDirective,
177
+ ], changeDetection: ChangeDetectionStrategy.OnPush, providers: [
167
178
  { provide: NG_VALUE_ACCESSOR, useExisting: DrFiscalMonthCalendarPickerComponent, multi: true },
168
179
  { provide: DateAdapter, useClass: FiscalMonthAdapter },
169
180
  DrDatePickerService,
170
181
  ], template: "<i *ngIf=\"!useButton\" class=\"dr-icon-date\" (click)=\"datePicker.open()\"></i>\n\n<ng-container *ngIf=\"(datePickerService.timeframe$ | async) === timeframeOption.WEEK\">\n <input\n [attr.id]=\"id\"\n [ngModel]=\"input.value\"\n (click)=\"datePicker.open()\"\n [disabled]=\"disabled\"\n [placeholder]=\"placeholder\"\n [readonly]=\"readonly\"\n [min]=\"_min\"\n [max]=\"_max\" />\n\n <mat-date-range-input [formGroup]=\"rangeForm\" [rangePicker]=\"datePicker\" [dateFilter]=\"dateFilter\" class=\"range-input\">\n <input\n matStartDate\n #input\n [drDatePickerFormat]=\"datePickerService.format$ | async\"\n formControlName=\"start\"\n (dateChange)=\"valueChangedInCalendar(rangeForm.value.start)\" />\n <input matEndDate [drDatePickerFormat]=\"datePickerService.format$ | async\" formControlName=\"end\" />\n </mat-date-range-input>\n\n <mat-date-range-picker\n #datePicker\n [startAt]=\"_startAt\"\n [panelClass]=\"'dr-week-datepicker' + (panelClass ? ' ' + panelClass : '')\"\n [calendarHeaderComponent]=\"customHeader\"\n (yearSelected)=\"chosenPeriodHandler($event, timeframeOption.YEAR, datePicker)\"\n (monthSelected)=\"chosenPeriodHandler($event, timeframeOption.MONTH, datePicker)\"\n (opened)=\"onOpen()\"\n (closed)=\"onCLose()\">\n </mat-date-range-picker>\n</ng-container>\n\n<ng-container *ngIf=\"(datePickerService.timeframe$ | async) !== timeframeOption.WEEK\">\n <input\n [attr.id]=\"id\"\n [ngModel]=\"displayValue$ | async\"\n (ngModelChange)=\"valueChangedInCalendar($event)\"\n (click)=\"datePicker.open()\"\n [matDatepicker]=\"datePicker\"\n [matDatepickerFilter]=\"dateFilter\"\n [disabled]=\"disabled\"\n [placeholder]=\"placeholder\"\n [drDatePickerFormat]=\"datePickerService.format$ | async\"\n [readonly]=\"readonly\"\n [min]=\"_min\"\n [max]=\"_max\"\n [class.hidden-calendar-input]=\"useButton\" />\n\n <dr-button\n *ngIf=\"useButton\"\n [icon]=\"'dr-icon-date'\"\n [iconAfter]=\"iconAfterButton\"\n (click)=\"datePicker.open()\"\n class=\"datepicker-button\">\n {{ buttonLabel || 'Select Date' }}\n </dr-button>\n\n <mat-datepicker\n #datePicker\n [panelClass]=\"panelClass\"\n [startAt]=\"_startAt\"\n [calendarHeaderComponent]=\"customHeader\"\n (yearSelected)=\"chosenPeriodHandler($event, timeframeOption.YEAR, datePicker)\"\n (monthSelected)=\"chosenPeriodHandler($event, timeframeOption.MONTH, datePicker)\"\n (opened)=\"onOpen()\"\n (closed)=\"onCLose()\">\n </mat-datepicker>\n</ng-container>\n", styles: [":host{position:relative;width:100%;display:flex;flex-direction:row;min-height:32px;height:32px;font-size:14px;font-family:Poppins,sans-serif;background-color:#fff;border:1px solid #9ea1aa;border-radius:6px;color:#333;overflow:hidden;outline:none;cursor:pointer}:host.use-button-picker{border:none}:host:hover{border-color:#9ea1aa}:host.active,:host:focus-within{border-color:#4646ce!important;color:#333}:host.disabled{pointer-events:none;border:1px solid #aeabac;background:#f0f1f4;color:#aeabac}:host.disabled:after{color:#aeabac}:host.ng-valid.ng-dirty{border-color:#037c5a}:host.ng-invalid.ng-dirty:not(:focus-within){border-color:#bf1d30!important}:host.ng-untouched.ng-valid{border-color:#9ea1aa}:host.use-button-picker:after{display:none}:host:not(.use-button-picker):after,:host:not(.use-button-picker):before{position:absolute;display:flex;border-color:#6d6e6f transparent transparent;color:#6d6e6f}:host:not(.use-button-picker):after{font-family:DataRails!important;content:var(--dr-icon-arrow-down, \"\\ea18\");font-size:24px;color:#6d6e6f;top:0;bottom:0;right:8px;pointer-events:none;position:absolute;display:flex;align-items:center;justify-content:center}:host i{display:flex;align-items:center;position:absolute;color:#6d6e6f;left:8px;top:0;bottom:0}:host input{display:flex;flex-grow:1;height:100%;border:none;text-align:left;padding-left:35px;padding-right:25px;cursor:pointer!important;outline:none}:host input.when-quarter{position:absolute;visibility:hidden}:host input:disabled{border:none;color:#aeabac;background:transparent}:host input::-webkit-search-decoration,:host input::-webkit-search-cancel-button,:host input::-webkit-search-results-button,:host input::-webkit-search-results-decoration{-webkit-appearance:none}:host input::placeholder{color:#6d6e6f;font-size:14px;line-height:18px}:host input.hidden-calendar-input{width:0;height:0;padding:0}:host .datepicker-button{width:100%}:host .range-input{position:absolute;height:0;width:0;bottom:0;left:0;z-index:-1}::ng-deep .mat-datepicker-popup .dr-week-datepicker{min-width:min(400px,100vw)!important}::ng-deep .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-today{background:#f2f2fb;color:#4646ce;border:none;font-weight:600}::ng-deep .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-cell-preview{border:none}::ng-deep .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-range-start .mat-calendar-body-cell-preview,::ng-deep .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-preview-start .mat-calendar-body-cell-preview{left:5%;width:95%;border-top-left-radius:40px;border-bottom-left-radius:40px}::ng-deep .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-range-end .mat-calendar-body-cell-preview,::ng-deep .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-preview-end .mat-calendar-body-cell-preview{right:5%;width:95%;border-top-right-radius:40px;border-bottom-right-radius:40px}::ng-deep .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-preview:not(.mat-calendar-body-in-range) .mat-calendar-body-cell-preview{background-color:#f5f5f5}::ng-deep .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-preview:not(.mat-calendar-body-in-range)>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background-color:transparent!important}::ng-deep .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-preview:not(.mat-calendar-body-in-range)>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical):not(.mat-calendar-body-today){color:#19181a!important;font-weight:400!important}::ng-deep .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-range .mat-calendar-body-cell-preview{background:#4646ce!important}::ng-deep .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-range:before{background:initial!important}::ng-deep .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-range .mat-calendar-body-selected,::ng-deep .mat-datepicker-popup .dr-week-datepicker .mat-calendar-body-in-range .mat-calendar-body-cell-content{background:transparent!important;color:#f2f2fb!important;font-weight:600!important}::ng-deep .mat-datepicker-popup .mat-datepicker-content{margin:7px 0;box-shadow:0 4px 8px 1px #00000040;border-radius:12px!important}::ng-deep .mat-datepicker-popup .mat-datepicker-content button[disabled]{border:inherit;color:inherit;background-color:inherit}::ng-deep .mat-datepicker-popup .mat-datepicker-content button[disabled]:hover{border:inherit}::ng-deep .mat-datepicker-popup .cdk-keyboard-focused .mat-calendar-body-active>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical),::ng-deep .mat-datepicker-popup .cdk-program-focused .mat-calendar-body-active>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background-color:#fff}::ng-deep .mat-datepicker-popup .mat-calendar-body-cell:not(.mat-calendar-body-disabled):hover>.mat-calendar-body-cell-content:not(.mat-calendar-body-selected):not(.mat-calendar-body-comparison-identical){background:#f2f2fb;color:#4646ce;font-weight:600}::ng-deep .mat-datepicker-popup .mat-calendar-body-selected{background-color:#4646ce;color:#f2f2fb;font-weight:600}::ng-deep .mat-datepicker-popup .mat-calendar-body-today.mat-calendar-body-selected{box-shadow:none}::ng-deep .mat-datepicker-popup .mat-button-focus-overlay{background:#f5f5f5}::ng-deep .mat-datepicker-popup .mat-calendar-controls .mat-icon-button:hover .mat-button-focus-overlay{opacity:1!important;background:#f5f5f5;transition:opacity .2s cubic-bezier(.35,0,.25,1)}::ng-deep .mat-datepicker-popup .mat-calendar-controls .mat-calendar-period-button:hover{background:#f5f5f5;transition:background .2s cubic-bezier(.35,0,.25,1)}::ng-deep .mat-datepicker-popup .mat-calendar-table-header th{font-size:14px;font-weight:600;color:#333}::ng-deep .mat-datepicker-popup .mat-calendar-table-header-divider{display:none}::ng-deep .mat-datepicker-popup .mat-calendar-body-label{color:#fff;padding:0}::ng-deep .mat-datepicker-popup .mat-calendar-body>tr[aria-hidden=true]>.mat-calendar-body-label{display:none}::ng-deep .mat-datepicker-popup .mat-calendar-content{display:flex}::ng-deep .mat-datepicker-popup .mat-calendar-content dr-week-selector{flex:0}::ng-deep .mat-datepicker-popup .mat-calendar-content mat-month-view,::ng-deep .mat-datepicker-popup .mat-calendar-content mat-multi-year-view,::ng-deep .mat-datepicker-popup .mat-calendar-content mat-year-view{flex:1}\n"] }]
171
182
  }], null, null); })();
172
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-fiscal-month-calendar-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-fiscal-month-calendar-picker/dr-fiscal-month-calendar-picker.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, inject, OnInit } from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DateAdapter } from '@angular/material/core';\nimport { DrDatePickerService } from '../services/dr-date-picker.service';\nimport { CustomDateAdapter, DrDatePickerComponent } from '../dr-date-picker/dr-date-picker.component';\nimport * as moment from 'moment';\nimport { ForecastTagService } from '../../../dr-tags/dr-tag/dr-tag-date/dr-tag-forecast/forecast-tag.service';\nimport { TimeframeOption } from '../../../models/datePicker';\nimport { MatDatepicker } from '@angular/material/datepicker';\nimport { DrFiscalMonthCalendarHeaderComponent } from './dr-fiscal-month-calendar-header.component';\n\nexport class FiscalMonthAdapter extends CustomDateAdapter {\n    readonly datePickerService = inject(DrDatePickerService);\n\n    override getMonthNames(style: 'long' | 'short' | 'narrow'): string[] {\n        return ForecastTagService.getForecastMonthTemplates();\n    }\n\n    override format(date: moment.Moment, displayFormat: string): string | any {\n        if (!date) return '';\n        const dateToFormat = this.datePickerService.subtractFiscalYearMonthsFromDate(date.clone());\n        const month = dateToFormat.month();\n        const year = dateToFormat.year();\n        return `${ForecastTagService.getForecastLabel(month + 1)} (${year})`;\n    }\n\n    override today(): moment.Moment {\n        const currentMoment = moment.utc();\n        const momentWithSubstrMonth = this.datePickerService.subtractFiscalYearMonthsFromDate(currentMoment);\n        const momentWithShiftedYear = this.datePickerService.addFiscalYearShiftForYear(momentWithSubstrMonth);\n        return momentWithShiftedYear ? momentWithShiftedYear : momentWithSubstrMonth;\n    }\n}\n\n@Component({\n    selector: 'dr-fiscal-month-picker',\n    templateUrl: '../dr-date-picker/dr-date-picker.component.html',\n    styleUrls: ['../dr-date-picker/dr-date-picker.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        { provide: NG_VALUE_ACCESSOR, useExisting: DrFiscalMonthCalendarPickerComponent, multi: true },\n        { provide: DateAdapter, useClass: FiscalMonthAdapter },\n        DrDatePickerService,\n    ],\n})\nexport class DrFiscalMonthCalendarPickerComponent extends DrDatePickerComponent implements OnInit {\n    public override readonly customHeader = DrFiscalMonthCalendarHeaderComponent;\n    override format = TimeframeOption.MONTH;\n\n    ngOnInit() {\n        this.updateFormat();\n    }\n\n    override chosenPeriodHandler(chosenDate: moment.Moment, timeframe: TimeframeOption, picker: MatDatepicker<any>): void {\n        if (timeframe === TimeframeOption.YEAR) {\n            chosenDate = this.datePickerService.addFiscalYearMonthsToDate(chosenDate);\n        }\n\n        if (timeframe === TimeframeOption.MONTH) {\n            const momentWithShiftedYear = this.datePickerService.subtractFiscalYearShiftForYear(chosenDate);\n            chosenDate = this.datePickerService.addFiscalYearMonthsToDate(\n                momentWithShiftedYear ? momentWithShiftedYear : chosenDate,\n            );\n        }\n\n        if (this.datePickerService.timeframe === timeframe) {\n            this.valueChangedInCalendar(chosenDate);\n            picker.close();\n        }\n    }\n\n    protected override transformDisplayedValue(value: moment.Moment, timeframe: TimeframeOption): moment.Moment {\n        const valueToReturn = value?.clone();\n        if (\n            valueToReturn &&\n            (this.datePickerService.isTimeframeDependingOnFY(timeframe) || timeframe === TimeframeOption.MONTH)\n        ) {\n            this.datePickerService.addFiscalYearShiftForYear(valueToReturn);\n        }\n        return valueToReturn;\n    }\n}\n","<i *ngIf=\"!useButton\" class=\"dr-icon-date\" (click)=\"datePicker.open()\"></i>\n\n<ng-container *ngIf=\"(datePickerService.timeframe$ | async) === timeframeOption.WEEK\">\n    <input\n        [attr.id]=\"id\"\n        [ngModel]=\"input.value\"\n        (click)=\"datePicker.open()\"\n        [disabled]=\"disabled\"\n        [placeholder]=\"placeholder\"\n        [readonly]=\"readonly\"\n        [min]=\"_min\"\n        [max]=\"_max\" />\n\n    <mat-date-range-input [formGroup]=\"rangeForm\" [rangePicker]=\"datePicker\" [dateFilter]=\"dateFilter\" class=\"range-input\">\n        <input\n            matStartDate\n            #input\n            [drDatePickerFormat]=\"datePickerService.format$ | async\"\n            formControlName=\"start\"\n            (dateChange)=\"valueChangedInCalendar(rangeForm.value.start)\" />\n        <input matEndDate [drDatePickerFormat]=\"datePickerService.format$ | async\" formControlName=\"end\" />\n    </mat-date-range-input>\n\n    <mat-date-range-picker\n        #datePicker\n        [startAt]=\"_startAt\"\n        [panelClass]=\"'dr-week-datepicker' + (panelClass ? ' ' + panelClass : '')\"\n        [calendarHeaderComponent]=\"customHeader\"\n        (yearSelected)=\"chosenPeriodHandler($event, timeframeOption.YEAR, datePicker)\"\n        (monthSelected)=\"chosenPeriodHandler($event, timeframeOption.MONTH, datePicker)\"\n        (opened)=\"onOpen()\"\n        (closed)=\"onCLose()\">\n    </mat-date-range-picker>\n</ng-container>\n\n<ng-container *ngIf=\"(datePickerService.timeframe$ | async) !== timeframeOption.WEEK\">\n    <input\n        [attr.id]=\"id\"\n        [ngModel]=\"displayValue$ | async\"\n        (ngModelChange)=\"valueChangedInCalendar($event)\"\n        (click)=\"datePicker.open()\"\n        [matDatepicker]=\"datePicker\"\n        [matDatepickerFilter]=\"dateFilter\"\n        [disabled]=\"disabled\"\n        [placeholder]=\"placeholder\"\n        [drDatePickerFormat]=\"datePickerService.format$ | async\"\n        [readonly]=\"readonly\"\n        [min]=\"_min\"\n        [max]=\"_max\"\n        [class.hidden-calendar-input]=\"useButton\" />\n\n    <dr-button\n        *ngIf=\"useButton\"\n        [icon]=\"'dr-icon-date'\"\n        [iconAfter]=\"iconAfterButton\"\n        (click)=\"datePicker.open()\"\n        class=\"datepicker-button\">\n        {{ buttonLabel || 'Select Date' }}\n    </dr-button>\n\n    <mat-datepicker\n        #datePicker\n        [panelClass]=\"panelClass\"\n        [startAt]=\"_startAt\"\n        [calendarHeaderComponent]=\"customHeader\"\n        (yearSelected)=\"chosenPeriodHandler($event, timeframeOption.YEAR, datePicker)\"\n        (monthSelected)=\"chosenPeriodHandler($event, timeframeOption.MONTH, datePicker)\"\n        (opened)=\"onOpen()\"\n        (closed)=\"onCLose()\">\n    </mat-datepicker>\n</ng-container>\n"]}
183
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-fiscal-month-calendar-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-fiscal-month-calendar-picker/dr-fiscal-month-calendar-picker.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAU,MAAM,eAAe,CAAC;AACnF,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,iBAAiB,EAAE,qBAAqB,EAAE,MAAM,4CAA4C,CAAC;AACtG,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AACjC,OAAO,EAAE,kBAAkB,EAAE,MAAM,0EAA0E,CAAC;AAC9G,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAE7D,OAAO,EAAE,oCAAoC,EAAE,MAAM,6CAA6C,CAAC;AACnG,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAClE,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AACnE,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,EAAE,2BAA2B,EAAE,MAAM,+CAA+C,CAAC;;;;;;;ICd5F,4BAAuE;IAA5B,0KAAS,eAAA,wBAAiB,CAAA,IAAC;IAAC,iBAAI;;;;IAE3E,6BAAsF;IAClF,gCAQmB;IALf,qLAAS,eAAA,UAAiB,CAAA,IAAC;IAH/B,iBAQmB;IAEnB,+CAAuH,kBAAA;IAM/G,mMAAc,eAAA,2DAA6C,CAAA,IAAC;;IALhE,iBAKmE;IACnE,2BAAmG;;IACvG,iBAAuB;IAEvB,mDAQyB;IAHrB,6PAAgB,eAAA,sEAA6D,CAAA,IAAC,kPAC7D,eAAA,uEAA8D,CAAA,IADD,+LAEpE,eAAA,gBAAQ,CAAA,IAF4D,+LAGpE,eAAA,iBAAS,CAAA,IAH2D;IAIlF,iBAAwB;IAC5B,0BAAe;;;;;IA5BP,eAAuB;IAAvB,mCAAuB,6BAAA,mCAAA,6BAAA,oBAAA,oBAAA;IADvB,+BAAc;IASI,eAAuB;IAAvB,4CAAuB,oBAAA,iCAAA;IAIrC,eAAwD;IAAxD,4FAAwD;IAG1C,eAAwD;IAAxD,4FAAwD;IAK1E,eAAoB;IAApB,yCAAoB,yFAAA,gDAAA;;;;IA0BxB,qCAK8B;IAD1B,2NAAS,eAAA,WAAiB,CAAA,IAAC;IAE3B,YACJ;IAAA,iBAAY;;;IALR,qCAAuB,sCAAA;IAIvB,eACJ;IADI,qEACJ;;;;IAvBJ,6BAAsF;IAClF,iCAagD;IAV5C,iNAAiB,eAAA,sCAA8B,CAAA,IAAC,0KACvC,eAAA,WAAiB,CAAA,IADsB;;;IAHpD,iBAagD;IAEhD,iHAOY;IAEZ,6CAQyB;IAHrB,wPAAgB,eAAA,uEAA6D,CAAA,IAAC,6OAC7D,eAAA,wEAA8D,CAAA,IADD,yLAEpE,eAAA,gBAAQ,CAAA,IAF4D,yLAGpE,eAAA,iBAAS,CAAA,IAH2D;IAIlF,iBAAiB;IACrB,0BAAe;;;;IArBP,eAAyC;IAAzC,yDAAyC;IAXzC,qEAAiC,uBAAA,0CAAA,6BAAA,mCAAA,+EAAA,6BAAA,oBAAA,oBAAA;IADjC,+BAAc;IAeb,eAAe;IAAf,uCAAe;IAUhB,eAAyB;IAAzB,8CAAyB,4BAAA,gDAAA;;AD9CjC,MAAM,OAAO,kBAAmB,SAAQ,iBAAiB;IAAzD;;QACa,sBAAiB,GAAG,MAAM,CAAC,mBAAmB,CAAC,CAAC;IAoB7D,CAAC;IAlBY,aAAa,CAAC,KAAkC;QACrD,OAAO,kBAAkB,CAAC,yBAAyB,EAAE,CAAC;IAC1D,CAAC;IAEQ,MAAM,CAAC,IAAmB,EAAE,aAAqB;QACtD,IAAI,CAAC,IAAI;YAAE,OAAO,EAAE,CAAC;QACrB,MAAM,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,gCAAgC,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QAC3F,MAAM,KAAK,GAAG,YAAY,CAAC,KAAK,EAAE,CAAC;QACnC,MAAM,IAAI,GAAG,YAAY,CAAC,IAAI,EAAE,CAAC;QACjC,OAAO,GAAG,kBAAkB,CAAC,gBAAgB,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,IAAI,GAAG,CAAC;IACzE,CAAC;IAEQ,KAAK;QACV,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,EAAE,CAAC;QACnC,MAAM,qBAAqB,GAAG,IAAI,CAAC,iBAAiB,CAAC,gCAAgC,CAAC,aAAa,CAAC,CAAC;QACrG,MAAM,qBAAqB,GAAG,IAAI,CAAC,iBAAiB,CAAC,yBAAyB,CAAC,qBAAqB,CAAC,CAAC;QACtG,OAAO,qBAAqB,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,qBAAqB,CAAC;IACjF,CAAC;CACJ;AAsBD,MAAM,OAAO,oCAAqC,SAAQ,qBAAqB;IApB/E;;QAqB6B,iBAAY,GAAG,oCAAoC,CAAC;QACpE,WAAM,GAAG,eAAe,CAAC,KAAK,CAAC;KAkC3C;IAhCG,QAAQ;QACJ,IAAI,CAAC,YAAY,EAAE,CAAC;IACxB,CAAC;IAEQ,mBAAmB,CAAC,UAAyB,EAAE,SAA0B,EAAE,MAA0B;QAC1G,IAAI,SAAS,KAAK,eAAe,CAAC,IAAI,EAAE;YACpC,UAAU,GAAG,IAAI,CAAC,iBAAiB,CAAC,yBAAyB,CAAC,UAAU,CAAC,CAAC;SAC7E;QAED,IAAI,SAAS,KAAK,eAAe,CAAC,KAAK,EAAE;YACrC,MAAM,qBAAqB,GAAG,IAAI,CAAC,iBAAiB,CAAC,8BAA8B,CAAC,UAAU,CAAC,CAAC;YAChG,UAAU,GAAG,IAAI,CAAC,iBAAiB,CAAC,yBAAyB,CACzD,qBAAqB,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,UAAU,CAC7D,CAAC;SACL;QAED,IAAI,IAAI,CAAC,iBAAiB,CAAC,SAAS,KAAK,SAAS,EAAE;YAChD,IAAI,CAAC,sBAAsB,CAAC,UAAU,CAAC,CAAC;YACxC,MAAM,CAAC,KAAK,EAAE,CAAC;SAClB;IACL,CAAC;IAEkB,uBAAuB,CAAC,KAAoB,EAAE,SAA0B;QACvF,MAAM,aAAa,GAAG,KAAK,EAAE,KAAK,EAAE,CAAC;QACrC,IACI,aAAa;YACb,CAAC,IAAI,CAAC,iBAAiB,CAAC,wBAAwB,CAAC,SAAS,CAAC,IAAI,SAAS,KAAK,eAAe,CAAC,KAAK,CAAC,EACrG;YACE,IAAI,CAAC,iBAAiB,CAAC,yBAAyB,CAAC,aAAa,CAAC,CAAC;SACnE;QACD,OAAO,aAAa,CAAC;IACzB,CAAC;wVAnCQ,oCAAoC,SAApC,oCAAoC;mGAApC,oCAAoC,8FANlC;gBACP,EAAE,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,oCAAoC,EAAE,KAAK,EAAE,IAAI,EAAE;gBAC9F,EAAE,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,kBAAkB,EAAE;gBACtD,mBAAmB;aACtB;YCzDL,iFAA2E;YAE3E,yGA+Be;;YAEf,wGAmCe;;;YAtEX,qCAAgB;YAEL,eAAqE;YAArE,0GAAqE;YAiCrE,eAAqE;YAArE,0GAAqE;4BDQ5E,YAAY,yBACZ,WAAW,oFACX,mBAAmB,6CACnB,mBAAmB,wHACnB,iBAAiB;YACjB,2BAA2B;;uFAWtB,oCAAoC;cApBhD,SAAS;2BACI,wBAAwB,cACtB,IAAI,WACP;oBACL,YAAY;oBACZ,WAAW;oBACX,mBAAmB;oBACnB,mBAAmB;oBACnB,iBAAiB;oBACjB,2BAA2B;iBAC9B,mBAGgB,uBAAuB,CAAC,MAAM,aACpC;oBACP,EAAE,OAAO,EAAE,iBAAiB,EAAE,WAAW,sCAAsC,EAAE,KAAK,EAAE,IAAI,EAAE;oBAC9F,EAAE,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,kBAAkB,EAAE;oBACtD,mBAAmB;iBACtB","sourcesContent":["import { ChangeDetectionStrategy, Component, inject, OnInit } from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DateAdapter } from '@angular/material/core';\nimport { DrDatePickerService } from '../services/dr-date-picker.service';\nimport { CustomDateAdapter, DrDatePickerComponent } from '../dr-date-picker/dr-date-picker.component';\nimport * as moment from 'moment';\nimport { ForecastTagService } from '../../../dr-tags/dr-tag/dr-tag-date/dr-tag-forecast/forecast-tag.service';\nimport { TimeframeOption } from '../../../models/datePicker';\nimport { MatDatepicker } from '@angular/material/datepicker';\nimport { DrFiscalMonthCalendarHeaderComponent } from './dr-fiscal-month-calendar-header.component';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { MatDatepickerModule } from '@angular/material/datepicker';\nimport { DrButtonComponent } from '../../button/button.component';\nimport { DrDatePickerFormatDirective } from '../directives/dr-date-picker-format.directive';\n\nexport class FiscalMonthAdapter extends CustomDateAdapter {\n    readonly datePickerService = inject(DrDatePickerService);\n\n    override getMonthNames(style: 'long' | 'short' | 'narrow'): string[] {\n        return ForecastTagService.getForecastMonthTemplates();\n    }\n\n    override format(date: moment.Moment, displayFormat: string): string | any {\n        if (!date) return '';\n        const dateToFormat = this.datePickerService.subtractFiscalYearMonthsFromDate(date.clone());\n        const month = dateToFormat.month();\n        const year = dateToFormat.year();\n        return `${ForecastTagService.getForecastLabel(month + 1)} (${year})`;\n    }\n\n    override today(): moment.Moment {\n        const currentMoment = moment.utc();\n        const momentWithSubstrMonth = this.datePickerService.subtractFiscalYearMonthsFromDate(currentMoment);\n        const momentWithShiftedYear = this.datePickerService.addFiscalYearShiftForYear(momentWithSubstrMonth);\n        return momentWithShiftedYear ? momentWithShiftedYear : momentWithSubstrMonth;\n    }\n}\n\n@Component({\n    selector: 'dr-fiscal-month-picker',\n    standalone: true,\n    imports: [\n        CommonModule,\n        FormsModule,\n        ReactiveFormsModule,\n        MatDatepickerModule,\n        DrButtonComponent,\n        DrDatePickerFormatDirective,\n    ],\n    templateUrl: '../dr-date-picker/dr-date-picker.component.html',\n    styleUrls: ['../dr-date-picker/dr-date-picker.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        { provide: NG_VALUE_ACCESSOR, useExisting: DrFiscalMonthCalendarPickerComponent, multi: true },\n        { provide: DateAdapter, useClass: FiscalMonthAdapter },\n        DrDatePickerService,\n    ],\n})\nexport class DrFiscalMonthCalendarPickerComponent extends DrDatePickerComponent implements OnInit {\n    public override readonly customHeader = DrFiscalMonthCalendarHeaderComponent;\n    override format = TimeframeOption.MONTH;\n\n    ngOnInit() {\n        this.updateFormat();\n    }\n\n    override chosenPeriodHandler(chosenDate: moment.Moment, timeframe: TimeframeOption, picker: MatDatepicker<any>): void {\n        if (timeframe === TimeframeOption.YEAR) {\n            chosenDate = this.datePickerService.addFiscalYearMonthsToDate(chosenDate);\n        }\n\n        if (timeframe === TimeframeOption.MONTH) {\n            const momentWithShiftedYear = this.datePickerService.subtractFiscalYearShiftForYear(chosenDate);\n            chosenDate = this.datePickerService.addFiscalYearMonthsToDate(\n                momentWithShiftedYear ? momentWithShiftedYear : chosenDate,\n            );\n        }\n\n        if (this.datePickerService.timeframe === timeframe) {\n            this.valueChangedInCalendar(chosenDate);\n            picker.close();\n        }\n    }\n\n    protected override transformDisplayedValue(value: moment.Moment, timeframe: TimeframeOption): moment.Moment {\n        const valueToReturn = value?.clone();\n        if (\n            valueToReturn &&\n            (this.datePickerService.isTimeframeDependingOnFY(timeframe) || timeframe === TimeframeOption.MONTH)\n        ) {\n            this.datePickerService.addFiscalYearShiftForYear(valueToReturn);\n        }\n        return valueToReturn;\n    }\n}\n","<i *ngIf=\"!useButton\" class=\"dr-icon-date\" (click)=\"datePicker.open()\"></i>\n\n<ng-container *ngIf=\"(datePickerService.timeframe$ | async) === timeframeOption.WEEK\">\n    <input\n        [attr.id]=\"id\"\n        [ngModel]=\"input.value\"\n        (click)=\"datePicker.open()\"\n        [disabled]=\"disabled\"\n        [placeholder]=\"placeholder\"\n        [readonly]=\"readonly\"\n        [min]=\"_min\"\n        [max]=\"_max\" />\n\n    <mat-date-range-input [formGroup]=\"rangeForm\" [rangePicker]=\"datePicker\" [dateFilter]=\"dateFilter\" class=\"range-input\">\n        <input\n            matStartDate\n            #input\n            [drDatePickerFormat]=\"datePickerService.format$ | async\"\n            formControlName=\"start\"\n            (dateChange)=\"valueChangedInCalendar(rangeForm.value.start)\" />\n        <input matEndDate [drDatePickerFormat]=\"datePickerService.format$ | async\" formControlName=\"end\" />\n    </mat-date-range-input>\n\n    <mat-date-range-picker\n        #datePicker\n        [startAt]=\"_startAt\"\n        [panelClass]=\"'dr-week-datepicker' + (panelClass ? ' ' + panelClass : '')\"\n        [calendarHeaderComponent]=\"customHeader\"\n        (yearSelected)=\"chosenPeriodHandler($event, timeframeOption.YEAR, datePicker)\"\n        (monthSelected)=\"chosenPeriodHandler($event, timeframeOption.MONTH, datePicker)\"\n        (opened)=\"onOpen()\"\n        (closed)=\"onCLose()\">\n    </mat-date-range-picker>\n</ng-container>\n\n<ng-container *ngIf=\"(datePickerService.timeframe$ | async) !== timeframeOption.WEEK\">\n    <input\n        [attr.id]=\"id\"\n        [ngModel]=\"displayValue$ | async\"\n        (ngModelChange)=\"valueChangedInCalendar($event)\"\n        (click)=\"datePicker.open()\"\n        [matDatepicker]=\"datePicker\"\n        [matDatepickerFilter]=\"dateFilter\"\n        [disabled]=\"disabled\"\n        [placeholder]=\"placeholder\"\n        [drDatePickerFormat]=\"datePickerService.format$ | async\"\n        [readonly]=\"readonly\"\n        [min]=\"_min\"\n        [max]=\"_max\"\n        [class.hidden-calendar-input]=\"useButton\" />\n\n    <dr-button\n        *ngIf=\"useButton\"\n        [icon]=\"'dr-icon-date'\"\n        [iconAfter]=\"iconAfterButton\"\n        (click)=\"datePicker.open()\"\n        class=\"datepicker-button\">\n        {{ buttonLabel || 'Select Date' }}\n    </dr-button>\n\n    <mat-datepicker\n        #datePicker\n        [panelClass]=\"panelClass\"\n        [startAt]=\"_startAt\"\n        [calendarHeaderComponent]=\"customHeader\"\n        (yearSelected)=\"chosenPeriodHandler($event, timeframeOption.YEAR, datePicker)\"\n        (monthSelected)=\"chosenPeriodHandler($event, timeframeOption.MONTH, datePicker)\"\n        (opened)=\"onOpen()\"\n        (closed)=\"onCLose()\">\n    </mat-datepicker>\n</ng-container>\n"]}
@@ -5,12 +5,13 @@ export class DrShowTimeframePipe {
5
5
  return arr.filter((item) => showOptions.includes(item.timeframe));
6
6
  }
7
7
  /** @nocollapse */ static { this.ɵfac = function DrShowTimeframePipe_Factory(t) { return new (t || DrShowTimeframePipe)(); }; }
8
- /** @nocollapse */ static { this.ɵpipe = /** @pureOrBreakMyCode */ i0.ɵɵdefinePipe({ name: "drShowTimeframePipe", type: DrShowTimeframePipe, pure: true }); }
8
+ /** @nocollapse */ static { this.ɵpipe = /** @pureOrBreakMyCode */ i0.ɵɵdefinePipe({ name: "drShowTimeframePipe", type: DrShowTimeframePipe, pure: true, standalone: true }); }
9
9
  }
10
10
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrShowTimeframePipe, [{
11
11
  type: Pipe,
12
12
  args: [{
13
13
  name: 'drShowTimeframePipe',
14
+ standalone: true,
14
15
  }]
15
16
  }], null, null); })();
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItc2hvdy10aW1lZnJhbWUucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWlucHV0cy9kYXRlLXBpY2tlcnMvZHItc2hvdy10aW1lZnJhbWUucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQzs7QUFNcEQsTUFBTSxPQUFPLG1CQUFtQjtJQUM1QixTQUFTLENBQUMsR0FBdUIsRUFBRSxXQUE4QjtRQUM3RCxPQUFPLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7SUFDdEUsQ0FBQzt1R0FIUSxtQkFBbUI7NEhBQW5CLG1CQUFtQjs7dUZBQW5CLG1CQUFtQjtjQUgvQixJQUFJO2VBQUM7Z0JBQ0YsSUFBSSxFQUFFLHFCQUFxQjthQUM5QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRpbWVmcmFtZU9wdGlvbiwgSVRpbWVmcmFtZU9wdGlvbiB9IGZyb20gJy4uLy4uL21vZGVscy9kYXRlUGlja2VyJztcblxuQFBpcGUoe1xuICAgIG5hbWU6ICdkclNob3dUaW1lZnJhbWVQaXBlJyxcbn0pXG5leHBvcnQgY2xhc3MgRHJTaG93VGltZWZyYW1lUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICAgIHRyYW5zZm9ybShhcnI6IElUaW1lZnJhbWVPcHRpb25bXSwgc2hvd09wdGlvbnM6IFRpbWVmcmFtZU9wdGlvbltdKTogSVRpbWVmcmFtZU9wdGlvbltdIHtcbiAgICAgICAgcmV0dXJuIGFyci5maWx0ZXIoKGl0ZW0pID0+IHNob3dPcHRpb25zLmluY2x1ZGVzKGl0ZW0udGltZWZyYW1lKSk7XG4gICAgfVxufVxuIl19
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItc2hvdy10aW1lZnJhbWUucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWlucHV0cy9kYXRlLXBpY2tlcnMvZHItc2hvdy10aW1lZnJhbWUucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQzs7QUFPcEQsTUFBTSxPQUFPLG1CQUFtQjtJQUM1QixTQUFTLENBQUMsR0FBdUIsRUFBRSxXQUE4QjtRQUM3RCxPQUFPLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7SUFDdEUsQ0FBQzt1R0FIUSxtQkFBbUI7NEhBQW5CLG1CQUFtQjs7dUZBQW5CLG1CQUFtQjtjQUovQixJQUFJO2VBQUM7Z0JBQ0YsSUFBSSxFQUFFLHFCQUFxQjtnQkFDM0IsVUFBVSxFQUFFLElBQUk7YUFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaW1lZnJhbWVPcHRpb24sIElUaW1lZnJhbWVPcHRpb24gfSBmcm9tICcuLi8uLi9tb2RlbHMvZGF0ZVBpY2tlcic7XG5cbkBQaXBlKHtcbiAgICBuYW1lOiAnZHJTaG93VGltZWZyYW1lUGlwZScsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgRHJTaG93VGltZWZyYW1lUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICAgIHRyYW5zZm9ybShhcnI6IElUaW1lZnJhbWVPcHRpb25bXSwgc2hvd09wdGlvbnM6IFRpbWVmcmFtZU9wdGlvbltdKTogSVRpbWVmcmFtZU9wdGlvbltdIHtcbiAgICAgICAgcmV0dXJuIGFyci5maWx0ZXIoKGl0ZW0pID0+IHNob3dPcHRpb25zLmluY2x1ZGVzKGl0ZW0udGltZWZyYW1lKSk7XG4gICAgfVxufVxuIl19
@@ -2,12 +2,11 @@ import { CommonModule } from '@angular/common';
2
2
  import { Component, forwardRef, ChangeDetectionStrategy, ViewEncapsulation, inject, ChangeDetectorRef, Input, HostBinding, } from '@angular/core';
3
3
  import { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';
4
4
  import { isNil } from 'lodash';
5
- import { DrInputsModule } from '../../dr-inputs.module';
5
+ import { DrInputComponent } from '../../dr-input/dr-input.component';
6
+ import { DrSelectComponent } from '../../dr-select/dr-select.component';
6
7
  import * as i0 from "@angular/core";
7
8
  import * as i1 from "@angular/common";
8
- import * as i2 from "../../dr-input/dr-input.component";
9
- import * as i3 from "../../dr-select/dr-select.component";
10
- import * as i4 from "@angular/forms";
9
+ import * as i2 from "@angular/forms";
11
10
  function TimePickerComponent_ng_template_16_Template(rf, ctx) { if (rf & 1) {
12
11
  i0.ɵɵtext(0);
13
12
  } if (rf & 2) {
@@ -167,11 +166,11 @@ export class TimePickerComponent {
167
166
  i0.ɵɵproperty("for", ctx.timezoneSelectId);
168
167
  i0.ɵɵadvance(2);
169
168
  i0.ɵɵproperty("id", ctx.timezoneSelectId)("ngModel", ctx.cronModel.timeZone)("items", ctx.GMT_OFFSETS)("textView", true)("disabled", !!ctx._disabled);
170
- } }, dependencies: [CommonModule, i1.JsonPipe, DrInputsModule, i2.DrInputComponent, i3.DrSelectComponent, FormsModule, i4.NgControlStatus, i4.NgModel], styles: ["dr-time-picker{display:flex;align-items:center}dr-time-picker .hours-input{min-width:62px;flex:1;margin-left:8px}dr-time-picker .minutes-input{min-width:62px;flex:1}dr-time-picker .time-period-selector{min-width:64px;flex:1;margin-left:8px}dr-time-picker .time-dots{margin:0 4px}dr-time-picker .gmt-offsets{margin-left:16px}dr-time-picker .visually-hidden{position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}\n"], encapsulation: 2, changeDetection: 0 }); }
169
+ } }, dependencies: [CommonModule, i1.JsonPipe, FormsModule, i2.NgControlStatus, i2.NgModel, DrInputComponent, DrSelectComponent], styles: ["dr-time-picker{display:flex;align-items:center}dr-time-picker .hours-input{min-width:62px;flex:1;margin-left:8px}dr-time-picker .minutes-input{min-width:62px;flex:1}dr-time-picker .time-period-selector{min-width:64px;flex:1;margin-left:8px}dr-time-picker .time-dots{margin:0 4px}dr-time-picker .gmt-offsets{margin-left:16px}dr-time-picker .visually-hidden{position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}\n"], encapsulation: 2, changeDetection: 0 }); }
171
170
  }
172
171
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TimePickerComponent, [{
173
172
  type: Component,
174
- args: [{ selector: 'dr-time-picker', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CommonModule, DrInputsModule, FormsModule], providers: [
173
+ args: [{ selector: 'dr-time-picker', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CommonModule, FormsModule, DrInputComponent, DrSelectComponent], providers: [
175
174
  {
176
175
  provide: NG_VALUE_ACCESSOR,
177
176
  useExisting: forwardRef((() => TimePickerComponent)),
@@ -184,4 +183,4 @@ export class TimePickerComponent {
184
183
  type: HostBinding,
185
184
  args: ['attr.id']
186
185
  }] }); })();
187
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/time-picker/time-picker.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/time-picker/time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    Component,\n    forwardRef,\n    ChangeDetectionStrategy,\n    ViewEncapsulation,\n    inject,\n    ChangeDetectorRef,\n    Input,\n    HostBinding,\n} from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { isNil } from 'lodash';\nimport { DrInputsModule } from '../../dr-inputs.module';\n\nexport type TimepickerModel = {\n    hour: number;\n    minute: number;\n    timePeriod: 'AM' | 'PM';\n    timeZone: number;\n};\n\nexport const LOCAL_TIME_ZONE_OFFSET = new Date().getTimezoneOffset() / 60;\n\nexport const getGMTLabel = (offset: number): string => {\n    const sign = offset < 0 ? '-' : '+';\n    const offsetPrefix = Math.abs(offset) > 9 ? '' : '0';\n    return `GMT${sign}${offsetPrefix}${Math.abs(offset)}:00`;\n};\n\nexport const GMT_OFFSETS = new Array(27).fill(null).map((v, index) => {\n    const offset = index - 12;\n    return {\n        value: -offset,\n        label: `${getGMTLabel(offset)}${LOCAL_TIME_ZONE_OFFSET === -offset ? ' (Local Time)' : ''}`,\n    };\n});\n\n@Component({\n    selector: 'dr-time-picker',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [CommonModule, DrInputsModule, FormsModule],\n    templateUrl: './time-picker.component.html',\n    styleUrls: ['./time-picker.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => TimePickerComponent),\n            multi: true,\n        },\n    ],\n    // eslint-disable-next-line @angular-eslint/use-component-view-encapsulation\n    encapsulation: ViewEncapsulation.None,\n})\nexport class TimePickerComponent implements ControlValueAccessor {\n    private readonly cdr = inject(ChangeDetectorRef);\n\n    @Input()\n    id?: string;\n    @HostBinding('attr.id')\n    hostId = null;\n\n    // Unique ID for each instance\n    private static nextUniqueId = 0;\n    readonly uniqueId = `time-picker-${TimePickerComponent.nextUniqueId++}`;\n\n    readonly CRON_TIME_PERIOD_ARRAY: ('AM' | 'PM')[] = ['AM', 'PM'];\n\n    readonly LOCAL_TIME_ZONE_OFFSET = LOCAL_TIME_ZONE_OFFSET;\n\n    readonly GMT_OFFSETS = GMT_OFFSETS;\n\n    cronModel: TimepickerModel = {\n        hour: 12,\n        minute: 0,\n        timePeriod: 'AM',\n        timeZone: this.LOCAL_TIME_ZONE_OFFSET,\n    };\n\n    _disabled?: boolean;\n\n    private onChange: (value: any) => void = () => {};\n    private onTouched: () => void = () => {};\n\n    // Helper to generate unique IDs for controls\n    get hourInputId() {\n        return `${this.uniqueId}-hour`;\n    }\n    get minuteInputId() {\n        return `${this.uniqueId}-minute`;\n    }\n    get periodSelectId() {\n        return `${this.uniqueId}-period`;\n    }\n    get timezoneSelectId() {\n        return `${this.uniqueId}-timezone`;\n    }\n    get labelId() {\n        return `${this.uniqueId}-label`;\n    }\n\n    onSelectionChange(model: Partial<TimepickerModel>): void {\n        const value = { ...this.getTimeValue(), ...model };\n\n        this.onChange(value);\n        this.onTouched();\n    }\n\n    private getTimeValue(): TimepickerModel {\n        return {\n            hour: this.cronModel.hour,\n            minute: this.cronModel.minute,\n            timePeriod: this.cronModel.timePeriod,\n            timeZone: this.cronModel.timeZone,\n        };\n    }\n\n    writeValue(value: any): void {\n        if (value && typeof value === 'object') {\n            this.cronModel = {\n                hour: value.hour !== undefined ? value.hour : this.cronModel.hour,\n                minute: value.minute !== undefined ? value.minute : this.cronModel.minute,\n                timePeriod: TimePickerComponent.validTimePeriod(value.timePeriod) ? value.timePeriod : this.cronModel.timePeriod,\n                timeZone: isNil(value.timeZone) ? this.cronModel.timeZone : value.timeZone,\n            };\n            this.cdr.detectChanges();\n            return;\n        }\n        this.cronModel = {\n            hour: 12,\n            minute: 0,\n            timePeriod: 'AM',\n            timeZone: this.LOCAL_TIME_ZONE_OFFSET,\n        };\n        this.cdr.detectChanges();\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        this._disabled = isDisabled;\n        this.cdr.markForCheck();\n    }\n\n    static validTimePeriod(value: unknown): value is TimepickerModel['timePeriod'] {\n        return value === 'AM' || value === 'PM';\n    }\n}\n","<label [id]=\"labelId\" class=\"visually-hidden\" [for]=\"id\">Time Picker</label>\n<input type=\"hidden\" [attr.id]=\"id\" [value]=\"cronModel | json\" name=\"time-picker-value\" />\n<dr-input\n    [id]=\"hourInputId\"\n    aria-label=\"Hour\"\n    [(ngModel)]=\"cronModel.hour\"\n    (ngModelChange)=\"onSelectionChange({ hour: $event })\"\n    [mask]=\"'00'\"\n    [min]=\"0\"\n    [max]=\"12\"\n    [disabled]=\"!!_disabled\"\n    type=\"number\"\n    class=\"hours-input\">\n</dr-input>\n<span class=\"time-dots\" aria-hidden=\"true\">:</span>\n<label class=\"visually-hidden\" [for]=\"minuteInputId\">Minute</label>\n<dr-input\n    [id]=\"minuteInputId\"\n    aria-label=\"Minute\"\n    [(ngModel)]=\"cronModel.minute\"\n    (ngModelChange)=\"onSelectionChange({ minute: $event })\"\n    [mask]=\"'00'\"\n    [min]=\"0\"\n    [max]=\"59\"\n    [disabled]=\"!!_disabled\"\n    type=\"number\"\n    class=\"minutes-input\">\n</dr-input>\n<label class=\"visually-hidden\" [for]=\"periodSelectId\">AM or PM</label>\n<dr-select\n    [id]=\"periodSelectId\"\n    aria-label=\"AM or PM\"\n    [(ngModel)]=\"cronModel.timePeriod\"\n    (change)=\"onSelectionChange({ timePeriod: $event })\"\n    [items]=\"CRON_TIME_PERIOD_ARRAY\"\n    [disabled]=\"!!_disabled\"\n    class=\"time-period-selector\"></dr-select>\n<label class=\"visually-hidden\" [for]=\"timezoneSelectId\">Time Zone</label>\n<dr-select\n    [id]=\"timezoneSelectId\"\n    aria-label=\"Time Zone\"\n    [(ngModel)]=\"cronModel.timeZone\"\n    (change)=\"onSelectionChange({ timeZone: $event })\"\n    [items]=\"GMT_OFFSETS\"\n    [textView]=\"true\"\n    [disabled]=\"!!_disabled\"\n    bindLabel=\"label\"\n    bindValue=\"value\"\n    class=\"gmt-offsets\">\n    <ng-template #labelTemplate let-item=\"item\">\n        {{ LOCAL_TIME_ZONE_OFFSET !== cronModel.timeZone ? item.label : 'Local Time' }}\n    </ng-template>\n</dr-select>\n"]}
186
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/time-picker/time-picker.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-inputs/date-pickers/time-picker/time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    Component,\n    forwardRef,\n    ChangeDetectionStrategy,\n    ViewEncapsulation,\n    inject,\n    ChangeDetectorRef,\n    Input,\n    HostBinding,\n} from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { isNil } from 'lodash';\nimport { DrInputComponent } from '../../dr-input/dr-input.component';\nimport { DrSelectComponent } from '../../dr-select/dr-select.component';\n\nexport type TimepickerModel = {\n    hour: number;\n    minute: number;\n    timePeriod: 'AM' | 'PM';\n    timeZone: number;\n};\n\nexport const LOCAL_TIME_ZONE_OFFSET = new Date().getTimezoneOffset() / 60;\n\nexport const getGMTLabel = (offset: number): string => {\n    const sign = offset < 0 ? '-' : '+';\n    const offsetPrefix = Math.abs(offset) > 9 ? '' : '0';\n    return `GMT${sign}${offsetPrefix}${Math.abs(offset)}:00`;\n};\n\nexport const GMT_OFFSETS = new Array(27).fill(null).map((v, index) => {\n    const offset = index - 12;\n    return {\n        value: -offset,\n        label: `${getGMTLabel(offset)}${LOCAL_TIME_ZONE_OFFSET === -offset ? ' (Local Time)' : ''}`,\n    };\n});\n\n@Component({\n    selector: 'dr-time-picker',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [CommonModule, FormsModule, DrInputComponent, DrSelectComponent],\n    templateUrl: './time-picker.component.html',\n    styleUrls: ['./time-picker.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => TimePickerComponent),\n            multi: true,\n        },\n    ],\n    // eslint-disable-next-line @angular-eslint/use-component-view-encapsulation\n    encapsulation: ViewEncapsulation.None,\n})\nexport class TimePickerComponent implements ControlValueAccessor {\n    private readonly cdr = inject(ChangeDetectorRef);\n\n    @Input()\n    id?: string;\n    @HostBinding('attr.id')\n    hostId = null;\n\n    // Unique ID for each instance\n    private static nextUniqueId = 0;\n    readonly uniqueId = `time-picker-${TimePickerComponent.nextUniqueId++}`;\n\n    readonly CRON_TIME_PERIOD_ARRAY: ('AM' | 'PM')[] = ['AM', 'PM'];\n\n    readonly LOCAL_TIME_ZONE_OFFSET = LOCAL_TIME_ZONE_OFFSET;\n\n    readonly GMT_OFFSETS = GMT_OFFSETS;\n\n    cronModel: TimepickerModel = {\n        hour: 12,\n        minute: 0,\n        timePeriod: 'AM',\n        timeZone: this.LOCAL_TIME_ZONE_OFFSET,\n    };\n\n    _disabled?: boolean;\n\n    private onChange: (value: any) => void = () => {};\n    private onTouched: () => void = () => {};\n\n    // Helper to generate unique IDs for controls\n    get hourInputId() {\n        return `${this.uniqueId}-hour`;\n    }\n    get minuteInputId() {\n        return `${this.uniqueId}-minute`;\n    }\n    get periodSelectId() {\n        return `${this.uniqueId}-period`;\n    }\n    get timezoneSelectId() {\n        return `${this.uniqueId}-timezone`;\n    }\n    get labelId() {\n        return `${this.uniqueId}-label`;\n    }\n\n    onSelectionChange(model: Partial<TimepickerModel>): void {\n        const value = { ...this.getTimeValue(), ...model };\n\n        this.onChange(value);\n        this.onTouched();\n    }\n\n    private getTimeValue(): TimepickerModel {\n        return {\n            hour: this.cronModel.hour,\n            minute: this.cronModel.minute,\n            timePeriod: this.cronModel.timePeriod,\n            timeZone: this.cronModel.timeZone,\n        };\n    }\n\n    writeValue(value: any): void {\n        if (value && typeof value === 'object') {\n            this.cronModel = {\n                hour: value.hour !== undefined ? value.hour : this.cronModel.hour,\n                minute: value.minute !== undefined ? value.minute : this.cronModel.minute,\n                timePeriod: TimePickerComponent.validTimePeriod(value.timePeriod) ? value.timePeriod : this.cronModel.timePeriod,\n                timeZone: isNil(value.timeZone) ? this.cronModel.timeZone : value.timeZone,\n            };\n            this.cdr.detectChanges();\n            return;\n        }\n        this.cronModel = {\n            hour: 12,\n            minute: 0,\n            timePeriod: 'AM',\n            timeZone: this.LOCAL_TIME_ZONE_OFFSET,\n        };\n        this.cdr.detectChanges();\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        this._disabled = isDisabled;\n        this.cdr.markForCheck();\n    }\n\n    static validTimePeriod(value: unknown): value is TimepickerModel['timePeriod'] {\n        return value === 'AM' || value === 'PM';\n    }\n}\n","<label [id]=\"labelId\" class=\"visually-hidden\" [for]=\"id\">Time Picker</label>\n<input type=\"hidden\" [attr.id]=\"id\" [value]=\"cronModel | json\" name=\"time-picker-value\" />\n<dr-input\n    [id]=\"hourInputId\"\n    aria-label=\"Hour\"\n    [(ngModel)]=\"cronModel.hour\"\n    (ngModelChange)=\"onSelectionChange({ hour: $event })\"\n    [mask]=\"'00'\"\n    [min]=\"0\"\n    [max]=\"12\"\n    [disabled]=\"!!_disabled\"\n    type=\"number\"\n    class=\"hours-input\">\n</dr-input>\n<span class=\"time-dots\" aria-hidden=\"true\">:</span>\n<label class=\"visually-hidden\" [for]=\"minuteInputId\">Minute</label>\n<dr-input\n    [id]=\"minuteInputId\"\n    aria-label=\"Minute\"\n    [(ngModel)]=\"cronModel.minute\"\n    (ngModelChange)=\"onSelectionChange({ minute: $event })\"\n    [mask]=\"'00'\"\n    [min]=\"0\"\n    [max]=\"59\"\n    [disabled]=\"!!_disabled\"\n    type=\"number\"\n    class=\"minutes-input\">\n</dr-input>\n<label class=\"visually-hidden\" [for]=\"periodSelectId\">AM or PM</label>\n<dr-select\n    [id]=\"periodSelectId\"\n    aria-label=\"AM or PM\"\n    [(ngModel)]=\"cronModel.timePeriod\"\n    (change)=\"onSelectionChange({ timePeriod: $event })\"\n    [items]=\"CRON_TIME_PERIOD_ARRAY\"\n    [disabled]=\"!!_disabled\"\n    class=\"time-period-selector\"></dr-select>\n<label class=\"visually-hidden\" [for]=\"timezoneSelectId\">Time Zone</label>\n<dr-select\n    [id]=\"timezoneSelectId\"\n    aria-label=\"Time Zone\"\n    [(ngModel)]=\"cronModel.timeZone\"\n    (change)=\"onSelectionChange({ timeZone: $event })\"\n    [items]=\"GMT_OFFSETS\"\n    [textView]=\"true\"\n    [disabled]=\"!!_disabled\"\n    bindLabel=\"label\"\n    bindValue=\"value\"\n    class=\"gmt-offsets\">\n    <ng-template #labelTemplate let-item=\"item\">\n        {{ LOCAL_TIME_ZONE_OFFSET !== cronModel.timeZone ? item.label : 'Local Time' }}\n    </ng-template>\n</dr-select>\n"]}