@elderbyte/ngx-starter 18.12.5 → 18.12.7

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 (49) hide show
  1. package/esm2022/lib/common/i18n/entity/elder-multi-translate-loader.mjs +4 -4
  2. package/esm2022/lib/common/utils/signal-input.mjs +3 -0
  3. package/esm2022/lib/components/time/elder-interval-picker/controller/interval-anchor-controller.mjs +21 -0
  4. package/esm2022/lib/components/time/elder-interval-picker/controller/interval-calendar-controller.mjs +24 -0
  5. package/esm2022/lib/components/time/elder-interval-picker/controller/interval-controller.mjs +43 -0
  6. package/esm2022/lib/components/time/elder-interval-picker/controller/interval-form-controller.mjs +69 -0
  7. package/esm2022/lib/components/time/elder-interval-picker/controller/interval-select-controller.mjs +117 -0
  8. package/esm2022/lib/components/time/elder-interval-picker/controller/interval-shift-controller.mjs +44 -0
  9. package/esm2022/lib/components/time/elder-interval-picker/elder-interval-picker.component.mjs +76 -127
  10. package/esm2022/lib/components/time/elder-interval-picker/interval-picker-binding/elder-interval-picker-binding.directive.mjs +41 -0
  11. package/esm2022/lib/components/time/elder-interval-picker/interval-picker-toggle/elder-interval-picker-toggle.component.mjs +144 -0
  12. package/esm2022/lib/components/time/elder-interval-picker/manager/interval-picker-state-manager.mjs +93 -0
  13. package/esm2022/lib/components/time/elder-interval-picker/model/anchor-state.mjs +54 -0
  14. package/esm2022/lib/components/time/elder-interval-picker/model/interval-state.mjs +37 -0
  15. package/esm2022/lib/components/time/elder-interval-picker/model/smart-shift-state.mjs +10 -0
  16. package/esm2022/lib/components/time/elder-interval-picker/presenter/interval-picker-presenter.mjs +96 -0
  17. package/esm2022/lib/components/time/elder-interval-picker/util/interval-picker-util.mjs +194 -0
  18. package/esm2022/lib/components/time/elder-time.module.mjs +5 -5
  19. package/fesm2022/elderbyte-ngx-starter.mjs +764 -888
  20. package/fesm2022/elderbyte-ngx-starter.mjs.map +1 -1
  21. package/lib/common/utils/signal-input.d.ts +2 -0
  22. package/lib/components/time/elder-interval-picker/controller/interval-anchor-controller.d.ts +9 -0
  23. package/lib/components/time/elder-interval-picker/controller/interval-calendar-controller.d.ts +7 -0
  24. package/lib/components/time/elder-interval-picker/controller/interval-controller.d.ts +35 -0
  25. package/lib/components/time/elder-interval-picker/controller/interval-form-controller.d.ts +12 -0
  26. package/lib/components/time/elder-interval-picker/controller/interval-select-controller.d.ts +22 -0
  27. package/lib/components/time/elder-interval-picker/controller/interval-shift-controller.d.ts +13 -0
  28. package/lib/components/time/elder-interval-picker/elder-interval-picker.component.d.ts +23 -33
  29. package/lib/components/time/elder-interval-picker/{elder-interval-picker-binding.directive.d.ts → interval-picker-binding/elder-interval-picker-binding.directive.d.ts} +3 -4
  30. package/lib/components/time/elder-interval-picker/interval-picker-toggle/elder-interval-picker-toggle.component.d.ts +37 -0
  31. package/lib/components/time/elder-interval-picker/manager/interval-picker-state-manager.d.ts +46 -0
  32. package/lib/components/time/elder-interval-picker/model/anchor-state.d.ts +20 -0
  33. package/lib/components/time/elder-interval-picker/model/interval-state.d.ts +16 -0
  34. package/lib/components/time/elder-interval-picker/model/smart-shift-state.d.ts +8 -0
  35. package/lib/components/time/elder-interval-picker/presenter/interval-picker-presenter.d.ts +30 -0
  36. package/lib/components/time/elder-interval-picker/util/interval-picker-util.d.ts +20 -0
  37. package/lib/components/time/elder-time.module.d.ts +4 -4
  38. package/package.json +1 -1
  39. package/esm2022/lib/components/time/elder-interval-picker/elder-interval-picker-binding.directive.mjs +0 -40
  40. package/esm2022/lib/components/time/elder-interval-picker/elder-interval-picker-toggle/elder-interval-picker-toggle.component.mjs +0 -202
  41. package/esm2022/lib/components/time/elder-interval-picker/model/interval-picker-model-editor.mjs +0 -284
  42. package/esm2022/lib/components/time/elder-interval-picker/model/interval-picker-model.mjs +0 -445
  43. package/esm2022/lib/components/time/elder-interval-picker/model/plain-date-interval-message-renderer.mjs +0 -37
  44. package/esm2022/lib/components/time/elder-interval-picker/model/plain-temporal-duration-message-renderer.mjs +0 -25
  45. package/lib/components/time/elder-interval-picker/elder-interval-picker-toggle/elder-interval-picker-toggle.component.d.ts +0 -55
  46. package/lib/components/time/elder-interval-picker/model/interval-picker-model-editor.d.ts +0 -77
  47. package/lib/components/time/elder-interval-picker/model/interval-picker-model.d.ts +0 -113
  48. package/lib/components/time/elder-interval-picker/model/plain-date-interval-message-renderer.d.ts +0 -7
  49. package/lib/components/time/elder-interval-picker/model/plain-temporal-duration-message-renderer.d.ts +0 -4
@@ -1,202 +0,0 @@
1
- import { booleanAttribute, ChangeDetectionStrategy, Component, computed, input, signal, ViewChild, } from '@angular/core';
2
- import { MatIconButton } from '@angular/material/button';
3
- import { MatFormField, MatLabel, MatSuffix } from '@angular/material/form-field';
4
- import { MatIcon } from '@angular/material/icon';
5
- import { LoggerFactory } from '@elderbyte/ts-logger';
6
- import { Interval } from '../../../../common/time/interval';
7
- import { ElderOverlayOriginDirective } from '../../../../components/overlays/elder-overlay-origin.directive';
8
- import { ElderOverlayTriggerDirective } from '../../../../components/overlays/elder-overlay-trigger.directive';
9
- import { ElderOverlayComponent } from '../../../../components/overlays/elder-overlay.component';
10
- import { ElderDialogPanelComponent } from '../../../../components/panels/elder-dialog-panel/elder-dialog-panel.component';
11
- import { ElderIntervalInputComponent, } from '../../../../components/time/elder-interval-input/elder-interval-input.component';
12
- import { ElderIntervalPickerComponent } from '../elder-interval-picker.component';
13
- import * as i0 from "@angular/core";
14
- export class ElderIntervalPickerToggleComponent {
15
- constructor() {
16
- /***************************************************************************
17
- * *
18
- * Fields *
19
- * *
20
- **************************************************************************/
21
- this.log = LoggerFactory.getLogger(this.constructor.name);
22
- this.intervalInputElement = signal(undefined);
23
- this.emitOnChange = input(true, { transform: (v) => booleanAttribute(v) });
24
- this.showAnchor = input(false, { transform: (v) => booleanAttribute(v) });
25
- this.anchorReadOnly = input(false, { transform: (v) => booleanAttribute(v) });
26
- this.disabled = input(false, { transform: (v) => booleanAttribute(v) });
27
- this.buttonDisabled = computed(() => this.intervalInputDisabled() || this.disabled());
28
- this.intervalInputDisabled = signal(false);
29
- this.showResultText = input(true, { transform: (v) => booleanAttribute(v) });
30
- this.showHelpText = input(true, { transform: (v) => booleanAttribute(v) });
31
- this.lastExcludesToday = input(false, { transform: (v) => booleanAttribute(v) });
32
- this.anchorDateTime = input(null);
33
- this.inputInterval = null;
34
- this.intervalInputMode = 'date-range'; // will be overwritten by connected element after view init
35
- }
36
- /***************************************************************************
37
- * *
38
- * Life Cycle *
39
- * *
40
- **************************************************************************/
41
- ngOnDestroy() {
42
- this.inputIntervalElSubscription.unsubscribe();
43
- }
44
- ngAfterViewInit() {
45
- const intervalControl = this.intervalInputElement();
46
- if (intervalControl.disabled) {
47
- this.intervalInputDisabled.set(true);
48
- }
49
- this.inputIntervalElSubscription = intervalControl.valueUpdated.subscribe({
50
- next: (value) => this.updateModelInterval(this.coerceInterval(value)),
51
- });
52
- this.intervalInputMode = intervalControl.mode;
53
- this.updateModelInterval(this.readIntervalInputValue(intervalControl));
54
- }
55
- /***************************************************************************
56
- * *
57
- * Public API *
58
- * *
59
- **************************************************************************/
60
- handleOverlayAttachedChange(attached) {
61
- if (this.emitOnChange()) {
62
- return;
63
- }
64
- this.updateModelFromIntervalInput();
65
- }
66
- updateModelFromIntervalInput() {
67
- this.updateModelInterval(this.readIntervalInputValue(this.intervalInputElement()));
68
- }
69
- handleIntervalPickerDateChange(interval) {
70
- this.inputInterval = interval;
71
- this.updateIntervalInputElement(this.inputInterval);
72
- }
73
- registerInputComponent(inputComponent) {
74
- this.intervalInputElement.set(inputComponent);
75
- }
76
- /***************************************************************************
77
- * *
78
- * Private methods *
79
- * *
80
- **************************************************************************/
81
- updateModelInterval(value) {
82
- this.inputInterval = value;
83
- this.connectedIntervalPicker.model.setInterval(value);
84
- }
85
- updateIntervalInputElement(interval) {
86
- const intervalControl = this.intervalInputElement();
87
- if (intervalControl) {
88
- intervalControl.value = interval;
89
- }
90
- }
91
- readIntervalInputValue(intervalComponent) {
92
- if (intervalComponent) {
93
- return this.coerceInterval(intervalComponent.value);
94
- }
95
- return undefined;
96
- }
97
- coerceInterval(value) {
98
- if (value instanceof Interval) {
99
- return value;
100
- }
101
- else if (value != undefined) {
102
- return Interval.parse(value);
103
- }
104
- else {
105
- return undefined;
106
- }
107
- }
108
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: ElderIntervalPickerToggleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
109
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.5", type: ElderIntervalPickerToggleComponent, isStandalone: true, selector: "elder-interval-picker-toggle", inputs: { emitOnChange: { classPropertyName: "emitOnChange", publicName: "emitOnChange", isSignal: true, isRequired: false, transformFunction: null }, showAnchor: { classPropertyName: "showAnchor", publicName: "showAnchor", isSignal: true, isRequired: false, transformFunction: null }, anchorReadOnly: { classPropertyName: "anchorReadOnly", publicName: "anchorReadOnly", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, showResultText: { classPropertyName: "showResultText", publicName: "showResultText", isSignal: true, isRequired: false, transformFunction: null }, showHelpText: { classPropertyName: "showHelpText", publicName: "showHelpText", isSignal: true, isRequired: false, transformFunction: null }, lastExcludesToday: { classPropertyName: "lastExcludesToday", publicName: "lastExcludesToday", isSignal: true, isRequired: false, transformFunction: null }, anchorDateTime: { classPropertyName: "anchorDateTime", publicName: "anchorDateTime", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "connectedIntervalPicker", first: true, predicate: ["connectedIntervalPicker"], descendants: true }], ngImport: i0, template: `
110
- <span style="padding-right: 8px">
111
- <button
112
- mat-icon-button
113
- [elderOverlayOrigin]="dateIntervalOverlay"
114
- [elderOverlayTrigger]="dateIntervalOverlay"
115
- [disabled]="buttonDisabled()"
116
- (click)="updateModelFromIntervalInput()"
117
- class="elder-control-icon-button mat-datepicker-toggle"
118
- >
119
- <mat-icon>date_range</mat-icon>
120
- </button>
121
- </span>
122
-
123
- <elder-overlay #dateIntervalOverlay (attachedChange)="handleOverlayAttachedChange($event)">
124
- <elder-dialog-panel>
125
- <div class="pb-md pt-xs">
126
- <elder-interval-picker
127
- #connectedIntervalPicker
128
- [intervalInputMode]="intervalInputMode"
129
- [emitOnChange]="emitOnChange()"
130
- [interval]="inputInterval"
131
- (dateChange)="handleIntervalPickerDateChange($event)"
132
- [showAnchor]="showAnchor()"
133
- [anchorDateTime]="anchorDateTime()"
134
- [anchorReadOnly]="anchorReadOnly()"
135
- [showResultText]="showResultText()"
136
- [showHelpText]="showHelpText()"
137
- [lastExcludesToday]="lastExcludesToday()"
138
- ></elder-interval-picker>
139
- </div>
140
- </elder-dialog-panel>
141
- </elder-overlay>
142
- `, isInline: true, dependencies: [{ kind: "component", type: ElderIntervalPickerComponent, selector: "elder-interval-picker", inputs: ["emitOnChange", "intervalInputMode", "showAnchor", "anchorReadOnly", "showResultText", "showHelpText", "lastExcludesToday", "interval", "anchorDateTime"], outputs: ["dateChange"] }, { kind: "component", type: ElderOverlayComponent, selector: "elder-overlay", inputs: ["originX", "originY", "overlayX", "overlayY", "offsetY", "offsetX", "backdrop", "backdropVisible", "origin", "positionStrategy", "overlaySize"], outputs: ["keydownEvents", "attachedChange"], exportAs: ["elderOverlay"] }, { kind: "component", type: ElderDialogPanelComponent, selector: "elder-dialog-panel" }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "directive", type: ElderOverlayTriggerDirective, selector: "[elderOverlayTrigger]", inputs: ["elderOverlayTrigger", "elderOverlayTriggerType", "elderOverlayTriggerEnabled"] }, { kind: "directive", type: ElderOverlayOriginDirective, selector: "[elderOverlayOrigin]", inputs: ["elderOverlayOrigin"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
143
- }
144
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: ElderIntervalPickerToggleComponent, decorators: [{
145
- type: Component,
146
- args: [{
147
- selector: 'elder-interval-picker-toggle',
148
- standalone: true,
149
- imports: [
150
- ElderIntervalPickerComponent,
151
- ElderIntervalInputComponent,
152
- MatFormField,
153
- MatLabel,
154
- ElderOverlayComponent,
155
- ElderDialogPanelComponent,
156
- MatIcon,
157
- MatIconButton,
158
- MatSuffix,
159
- ElderOverlayTriggerDirective,
160
- ElderOverlayOriginDirective,
161
- ],
162
- template: `
163
- <span style="padding-right: 8px">
164
- <button
165
- mat-icon-button
166
- [elderOverlayOrigin]="dateIntervalOverlay"
167
- [elderOverlayTrigger]="dateIntervalOverlay"
168
- [disabled]="buttonDisabled()"
169
- (click)="updateModelFromIntervalInput()"
170
- class="elder-control-icon-button mat-datepicker-toggle"
171
- >
172
- <mat-icon>date_range</mat-icon>
173
- </button>
174
- </span>
175
-
176
- <elder-overlay #dateIntervalOverlay (attachedChange)="handleOverlayAttachedChange($event)">
177
- <elder-dialog-panel>
178
- <div class="pb-md pt-xs">
179
- <elder-interval-picker
180
- #connectedIntervalPicker
181
- [intervalInputMode]="intervalInputMode"
182
- [emitOnChange]="emitOnChange()"
183
- [interval]="inputInterval"
184
- (dateChange)="handleIntervalPickerDateChange($event)"
185
- [showAnchor]="showAnchor()"
186
- [anchorDateTime]="anchorDateTime()"
187
- [anchorReadOnly]="anchorReadOnly()"
188
- [showResultText]="showResultText()"
189
- [showHelpText]="showHelpText()"
190
- [lastExcludesToday]="lastExcludesToday()"
191
- ></elder-interval-picker>
192
- </div>
193
- </elder-dialog-panel>
194
- </elder-overlay>
195
- `,
196
- changeDetection: ChangeDetectionStrategy.OnPush,
197
- }]
198
- }], propDecorators: { connectedIntervalPicker: [{
199
- type: ViewChild,
200
- args: ['connectedIntervalPicker']
201
- }] } });
202
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-interval-picker-toggle.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/elder-interval-picker/elder-interval-picker-toggle/elder-interval-picker-toggle.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  Component,\n  computed,\n  input,\n  OnDestroy,\n  signal,\n  ViewChild,\n} from '@angular/core'\nimport { MatIconButton } from '@angular/material/button'\nimport { MatFormField, MatLabel, MatSuffix } from '@angular/material/form-field'\nimport { MatIcon } from '@angular/material/icon'\nimport { LoggerFactory } from '@elderbyte/ts-logger'\nimport { Subscription } from 'rxjs'\nimport { Interval } from '../../../../common/time/interval'\nimport { ElderOverlayOriginDirective } from '../../../../components/overlays/elder-overlay-origin.directive'\nimport { ElderOverlayTriggerDirective } from '../../../../components/overlays/elder-overlay-trigger.directive'\nimport { ElderOverlayComponent } from '../../../../components/overlays/elder-overlay.component'\nimport { ElderDialogPanelComponent } from '../../../../components/panels/elder-dialog-panel/elder-dialog-panel.component'\nimport {\n  ElderIntervalInputComponent,\n  IntervalInputMode,\n} from '../../../../components/time/elder-interval-input/elder-interval-input.component'\nimport { ElderIntervalPickerComponent } from '../elder-interval-picker.component'\n\n@Component({\n  selector: 'elder-interval-picker-toggle',\n  standalone: true,\n  imports: [\n    ElderIntervalPickerComponent,\n    ElderIntervalInputComponent,\n    MatFormField,\n    MatLabel,\n    ElderOverlayComponent,\n    ElderDialogPanelComponent,\n    MatIcon,\n    MatIconButton,\n    MatSuffix,\n    ElderOverlayTriggerDirective,\n    ElderOverlayOriginDirective,\n  ],\n  template: `\n    <span style=\"padding-right: 8px\">\n      <button\n        mat-icon-button\n        [elderOverlayOrigin]=\"dateIntervalOverlay\"\n        [elderOverlayTrigger]=\"dateIntervalOverlay\"\n        [disabled]=\"buttonDisabled()\"\n        (click)=\"updateModelFromIntervalInput()\"\n        class=\"elder-control-icon-button mat-datepicker-toggle\"\n      >\n        <mat-icon>date_range</mat-icon>\n      </button>\n    </span>\n\n    <elder-overlay #dateIntervalOverlay (attachedChange)=\"handleOverlayAttachedChange($event)\">\n      <elder-dialog-panel>\n        <div class=\"pb-md pt-xs\">\n          <elder-interval-picker\n            #connectedIntervalPicker\n            [intervalInputMode]=\"intervalInputMode\"\n            [emitOnChange]=\"emitOnChange()\"\n            [interval]=\"inputInterval\"\n            (dateChange)=\"handleIntervalPickerDateChange($event)\"\n            [showAnchor]=\"showAnchor()\"\n            [anchorDateTime]=\"anchorDateTime()\"\n            [anchorReadOnly]=\"anchorReadOnly()\"\n            [showResultText]=\"showResultText()\"\n            [showHelpText]=\"showHelpText()\"\n            [lastExcludesToday]=\"lastExcludesToday()\"\n          ></elder-interval-picker>\n        </div>\n      </elder-dialog-panel>\n    </elder-overlay>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ElderIntervalPickerToggleComponent implements AfterViewInit, OnDestroy {\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name)\n\n  @ViewChild('connectedIntervalPicker')\n  connectedIntervalPicker!: ElderIntervalPickerComponent\n\n  public readonly intervalInputElement = signal<ElderIntervalInputComponent>(undefined)\n  public readonly emitOnChange = input(true, { transform: (v) => booleanAttribute(v) })\n\n  public readonly showAnchor = input(false, { transform: (v) => booleanAttribute(v) })\n  public readonly anchorReadOnly = input(false, { transform: (v) => booleanAttribute(v) })\n  public readonly disabled = input(false, { transform: (v) => booleanAttribute(v) })\n\n  public readonly buttonDisabled = computed<boolean>(\n    () => this.intervalInputDisabled() || this.disabled()\n  )\n  private readonly intervalInputDisabled = signal<boolean>(false)\n\n  public readonly showResultText = input(true, { transform: (v) => booleanAttribute(v) })\n  public readonly showHelpText = input(true, { transform: (v) => booleanAttribute(v) })\n\n  public readonly lastExcludesToday = input(false, { transform: (v) => booleanAttribute(v) })\n\n  public readonly anchorDateTime = input<Date>(null)\n\n  public inputInterval: Interval = null\n  public intervalInputMode: IntervalInputMode = 'date-range' // will be overwritten by connected element after view init\n\n  private inputIntervalElSubscription: Subscription\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnDestroy(): void {\n    this.inputIntervalElSubscription.unsubscribe()\n  }\n\n  public ngAfterViewInit(): void {\n    const intervalControl = this.intervalInputElement()\n\n    if (intervalControl.disabled) {\n      this.intervalInputDisabled.set(true)\n    }\n\n    this.inputIntervalElSubscription = intervalControl.valueUpdated.subscribe({\n      next: (value) => this.updateModelInterval(this.coerceInterval(value)),\n    })\n    this.intervalInputMode = intervalControl.mode\n    this.updateModelInterval(this.readIntervalInputValue(intervalControl))\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public handleOverlayAttachedChange(attached: boolean): void {\n    if (this.emitOnChange()) {\n      return\n    }\n    this.updateModelFromIntervalInput()\n  }\n\n  public updateModelFromIntervalInput(): void {\n    this.updateModelInterval(this.readIntervalInputValue(this.intervalInputElement()))\n  }\n\n  public handleIntervalPickerDateChange(interval: Interval): void {\n    this.inputInterval = interval\n    this.updateIntervalInputElement(this.inputInterval)\n  }\n\n  public registerInputComponent(inputComponent: ElderIntervalInputComponent) {\n    this.intervalInputElement.set(inputComponent)\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private updateModelInterval(value: Interval): void {\n    this.inputInterval = value\n    this.connectedIntervalPicker.model.setInterval(value)\n  }\n\n  private updateIntervalInputElement(interval: Interval): void {\n    const intervalControl = this.intervalInputElement()\n    if (intervalControl) {\n      intervalControl.value = interval\n    }\n  }\n\n  private readIntervalInputValue(\n    intervalComponent: ElderIntervalInputComponent\n  ): Interval | undefined {\n    if (intervalComponent) {\n      return this.coerceInterval(intervalComponent!.value)\n    }\n    return undefined\n  }\n\n  private coerceInterval(value: undefined | string | Interval): Interval | undefined {\n    if (value instanceof Interval) {\n      return value\n    } else if (value != undefined) {\n      return Interval.parse(value)\n    } else {\n      return undefined\n    }\n  }\n}\n"]}
@@ -1,284 +0,0 @@
1
- import { Temporal } from '@js-temporal/polyfill';
2
- import { TemporalUtil } from '../../../../common/time/temporal-util';
3
- export class IntervalPickerModelEditor {
4
- /***************************************************************************
5
- * *
6
- * Constructor *
7
- * *
8
- **************************************************************************/
9
- constructor(model) {
10
- this.model = model;
11
- }
12
- /***************************************************************************
13
- * *
14
- * Date Shift API *
15
- * *
16
- **************************************************************************/
17
- shiftMonth(months, staticMode = false) {
18
- this.setDatesFromRange(this.dateRange().shiftMonths(months));
19
- if (staticMode && this.calendarMode() !== 'months') {
20
- this.setCalendarMode('days');
21
- return;
22
- }
23
- this.resetTimeRange();
24
- this.setCalendarMode('months');
25
- }
26
- shiftDay(days) {
27
- this.setDatesFromRange(this.dateRange().shiftDays(days));
28
- if (this.calendarMode() === 'weeks' && (days === 7 || days === -7)) {
29
- this.setCalendarMode('weeks');
30
- return;
31
- }
32
- this.setCalendarMode('days');
33
- }
34
- shiftYear(years, staticMode = false) {
35
- this.setDatesFromRange(this.dateRange().shiftYears(years));
36
- if (staticMode && this.calendarMode() !== 'years') {
37
- this.setCalendarMode('days');
38
- return;
39
- }
40
- this.resetTimeRange();
41
- this.setCalendarMode('years');
42
- }
43
- /***************************************************************************
44
- * *
45
- * Time Shift API *
46
- * *
47
- **************************************************************************/
48
- shiftTime(amount, unit) {
49
- if (!this.isStartAndEndDatesSet()) {
50
- return;
51
- }
52
- const newStartDateTime = this.startDateTime().add({ [unit]: amount });
53
- const newEndDateTime = this.endDateTime().add({ [unit]: amount });
54
- this.setDateRange(Temporal.PlainDate.from(newStartDateTime), Temporal.PlainDate.from(newEndDateTime));
55
- this.setTimeRange(Temporal.PlainTime.from(newStartDateTime), Temporal.PlainTime.from(newEndDateTime));
56
- }
57
- smartShift(direction = 1) {
58
- if (this.calendarMode() === 'quarters') {
59
- const newRange = this.dateRange().shiftMonths(direction * 3);
60
- this.setDatesFromRange(newRange);
61
- return;
62
- }
63
- if (this.calendarMode() === 'months') {
64
- const newRange = this.dateRange().shiftMonths(direction);
65
- this.setDatesFromRange(newRange);
66
- return;
67
- }
68
- if (this.calendarMode() === 'years') {
69
- const newRange = this.dateRange().shiftYears(direction);
70
- this.setDatesFromRange(newRange);
71
- return;
72
- }
73
- if (this.calendarMode() === 'weeks') {
74
- const newRange = this.dateRange().shiftDays(7 * direction);
75
- this.setDatesFromRange(newRange);
76
- return;
77
- }
78
- const daysDiff = this.dateRange().getDurationInDays();
79
- const newRange = this.dateRange().shiftDays(daysDiff * direction);
80
- this.setDatesFromRange(newRange);
81
- }
82
- /***************************************************************************
83
- * *
84
- * Date Selection API *
85
- * *
86
- **************************************************************************/
87
- selectCurrentDay() {
88
- this.setDatesFromRange(TemporalUtil.getCurrentDay(this.anchorDate()));
89
- this.setCalendarMode('days');
90
- this.resetTimeRange();
91
- }
92
- selectYesterday() {
93
- this.setDatesFromRange(TemporalUtil.getYesterday(this.anchorDate()));
94
- this.setCalendarMode('days');
95
- this.resetTimeRange();
96
- }
97
- selectCurrentMonth() {
98
- this.setDatesFromRange(TemporalUtil.getCurrentMonth(this.anchorDate()));
99
- this.setCalendarMode('months');
100
- this.resetTimeRange();
101
- }
102
- selectCurrentWeek() {
103
- this.setDatesFromRange(TemporalUtil.getCurrentWeek(this.anchorDate()));
104
- this.setCalendarMode('weeks');
105
- this.resetTimeRange();
106
- }
107
- selectPreviousWeek() {
108
- this.setDatesFromRange(TemporalUtil.getPreviousWeek(this.anchorDate()));
109
- this.setCalendarMode('weeks');
110
- this.resetTimeRange();
111
- }
112
- selectPreviousMonth() {
113
- this.setDatesFromRange(TemporalUtil.getPreviousMonth(this.anchorDate()));
114
- this.setCalendarMode('months');
115
- this.resetTimeRange();
116
- }
117
- selectLastThirtyDaysExcludingToday() {
118
- this.setDatesFromRange(TemporalUtil.getLastThirtyDays(this.anchorDate()));
119
- this.setCalendarMode('days');
120
- this.resetTimeRange();
121
- }
122
- selectLastThirtyDaysIncludingToday() {
123
- this.setDatesFromRange(TemporalUtil.getLastThirtyDaysIncludingToday(this.anchorDate()));
124
- this.setCalendarMode('days');
125
- this.resetTimeRange();
126
- }
127
- selectCurrentYear() {
128
- this.setDatesFromRange(TemporalUtil.getCurrentYear(this.anchorDate()));
129
- this.setCalendarMode('years');
130
- this.resetTimeRange();
131
- }
132
- selectPreviousYear() {
133
- this.setDatesFromRange(TemporalUtil.getPreviousYear(this.anchorDate()));
134
- this.setCalendarMode('years');
135
- this.resetTimeRange();
136
- }
137
- selectLast365Days() {
138
- this.setDatesFromRange(TemporalUtil.getLast365Days(this.anchorDate()));
139
- this.setCalendarMode('days');
140
- this.resetTimeRange();
141
- }
142
- selectCurrentQuarter() {
143
- this.setDatesFromRange(TemporalUtil.getCurrentQuarter(this.anchorDate()));
144
- this.setCalendarMode('quarters');
145
- this.resetTimeRange();
146
- }
147
- selectPreviousQuarter() {
148
- this.setDatesFromRange(TemporalUtil.getPreviousQuarter(this.anchorDate()));
149
- this.setCalendarMode('quarters');
150
- this.resetTimeRange();
151
- }
152
- selectLastSevenDaysExcludingToday() {
153
- this.setDatesFromRange(TemporalUtil.getLastSevenDays(this.anchorDate()));
154
- this.setCalendarMode('days');
155
- this.resetTimeRange();
156
- }
157
- selectLastSevenDaysIncludingToday() {
158
- this.setDatesFromRange(TemporalUtil.getLastSevenDaysIncludingToday(this.anchorDate()));
159
- this.setCalendarMode('days');
160
- this.resetTimeRange();
161
- }
162
- /***************************************************************************
163
- * *
164
- * Time Selection API *
165
- * *
166
- **************************************************************************/
167
- // time range selections
168
- selectLastHour() {
169
- this.selectLastByDuration({ hours: 1 });
170
- }
171
- selectLast24Hours() {
172
- this.selectLastByDuration({ days: 1 });
173
- }
174
- selectLastFiveMinutes() {
175
- this.selectLastByDuration({ minutes: 5 });
176
- }
177
- selectLastByDuration(duration) {
178
- this.refreshBaseReferenceDateTime();
179
- const end = this.anchorDateTime();
180
- const start = end.subtract(duration);
181
- const startPlainDate = Temporal.PlainDate.from(start);
182
- const startPlainTime = Temporal.PlainTime.from(start);
183
- this.setDateRange(startPlainDate, this.anchorDate());
184
- this.setTimeRange(startPlainTime, this.anchorTime());
185
- this.setCalendarMode('days');
186
- }
187
- /***************************************************************************
188
- * *
189
- * Private methods *
190
- * *
191
- **************************************************************************/
192
- anchorTime() {
193
- return this.model.anchorTime();
194
- }
195
- anchorDate() {
196
- return this.model.anchorDate();
197
- }
198
- setCalendarMode(mode) {
199
- this.model.calendarMode.set(mode);
200
- }
201
- calendarMode() {
202
- return this.model.calendarMode();
203
- }
204
- dateRange() {
205
- return this.model.dateRange();
206
- }
207
- resetTimeRange() {
208
- this.setTimeRange(Temporal.PlainTime.from('00:00'), Temporal.PlainTime.from('00:00'));
209
- }
210
- setTimeRange(start, end) {
211
- this.model.setStartTime(start);
212
- this.model.setEndTime(end);
213
- }
214
- setDateRange(start, end) {
215
- this.model.setStartDate(start);
216
- this.model.setEndDate(end);
217
- }
218
- setDatesFromRange(range) {
219
- this.setDateRange(range.start, range.end);
220
- }
221
- shiftSelectionToAnchorDate() {
222
- if (!this.isStartAndEndDatesSet() || !this.fixedAnchorDate()) {
223
- return;
224
- }
225
- const range = this.dateRange();
226
- const endDate = this.fixedAnchorDate();
227
- const startDate = endDate.subtract({ days: range.getDurationInDays() });
228
- this.setDateRange(startDate, endDate);
229
- if (this.calendarMode() === 'months') {
230
- this.selectCurrentMonth();
231
- }
232
- if (this.calendarMode() === 'years') {
233
- this.selectCurrentYear();
234
- }
235
- if (this.calendarMode() === 'weeks') {
236
- this.selectCurrentWeek();
237
- }
238
- }
239
- fixedAnchorDate() {
240
- return this.model.fixedAnchorDate();
241
- }
242
- fixedAnchorTime() {
243
- return this.model.fixedAnchorTime();
244
- }
245
- anchorDateTime() {
246
- return this.model.anchorDateTime();
247
- }
248
- startDateTime() {
249
- return this.model.startDateTime();
250
- }
251
- endDateTime() {
252
- return this.model.endDateTime();
253
- }
254
- isStartAndEndDatesSet() {
255
- return this.model.isStartAndEndDatesSet();
256
- }
257
- shiftSelectionToAnchorTime() {
258
- if (!this.isStartAndEndDatesSet() || !this.fixedAnchorTime()) {
259
- return;
260
- }
261
- const duration = this.startDateTime().until(this.endDateTime());
262
- const newStartDateTime = this.anchorDateTime().subtract(duration);
263
- const newEndDateTime = this.anchorDateTime();
264
- this.setDateRange(Temporal.PlainDate.from(newStartDateTime), Temporal.PlainDate.from(newEndDateTime));
265
- this.setTimeRange(Temporal.PlainTime.from(newStartDateTime), Temporal.PlainTime.from(newEndDateTime));
266
- if (this.calendarMode() === 'months') {
267
- this.selectCurrentMonth();
268
- }
269
- if (this.calendarMode() === 'years') {
270
- this.selectCurrentYear();
271
- }
272
- if (this.calendarMode() === 'weeks') {
273
- this.selectCurrentWeek();
274
- }
275
- }
276
- refreshBaseReferenceDateTime() {
277
- const dateTime = Temporal.Now.zonedDateTimeISO();
278
- const date = Temporal.PlainDate.from(dateTime);
279
- const time = Temporal.PlainTime.from(dateTime);
280
- this.model.baseReferenceDate.set(date);
281
- this.model.baseReferenceTime.set(time);
282
- }
283
- }
284
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interval-picker-model-editor.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/elder-interval-picker/model/interval-picker-model-editor.ts"],"names":[],"mappings":"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","sourcesContent":["import { CalendarMode, IntervalPickerModel } from './interval-picker-model'\nimport { Temporal } from '@js-temporal/polyfill'\nimport { TemporalPlainDateInterval } from '../../../../common/time/temporal-plain-date-interval'\nimport { TemporalUtil } from '../../../../common/time/temporal-util'\nimport DurationLike = Temporal.DurationLike\n\nexport class IntervalPickerModelEditor {\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(private readonly model: IntervalPickerModel) {}\n  /***************************************************************************\n   *                                                                         *\n   * Date Shift API                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n  public shiftMonth(months: number, staticMode = false): void {\n    this.setDatesFromRange(this.dateRange().shiftMonths(months))\n    if (staticMode && this.calendarMode() !== 'months') {\n      this.setCalendarMode('days')\n      return\n    }\n    this.resetTimeRange()\n    this.setCalendarMode('months')\n  }\n\n  public shiftDay(days: number): void {\n    this.setDatesFromRange(this.dateRange().shiftDays(days))\n    if (this.calendarMode() === 'weeks' && (days === 7 || days === -7)) {\n      this.setCalendarMode('weeks')\n      return\n    }\n    this.setCalendarMode('days')\n  }\n\n  public shiftYear(years: number, staticMode = false): void {\n    this.setDatesFromRange(this.dateRange().shiftYears(years))\n    if (staticMode && this.calendarMode() !== 'years') {\n      this.setCalendarMode('days')\n      return\n    }\n    this.resetTimeRange()\n    this.setCalendarMode('years')\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Time Shift API                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n  public shiftTime(amount: number, unit: 'hours' | 'minutes'): void {\n    if (!this.isStartAndEndDatesSet()) {\n      return\n    }\n\n    const newStartDateTime = this.startDateTime().add({ [unit]: amount })\n    const newEndDateTime = this.endDateTime().add({ [unit]: amount })\n\n    this.setDateRange(\n      Temporal.PlainDate.from(newStartDateTime),\n      Temporal.PlainDate.from(newEndDateTime)\n    )\n    this.setTimeRange(\n      Temporal.PlainTime.from(newStartDateTime as Temporal.PlainDateTime),\n      Temporal.PlainTime.from(newEndDateTime as Temporal.PlainDateTime)\n    )\n  }\n\n  public smartShift(direction = 1): void {\n    if (this.calendarMode() === 'quarters') {\n      const newRange = this.dateRange().shiftMonths(direction * 3)\n      this.setDatesFromRange(newRange)\n      return\n    }\n\n    if (this.calendarMode() === 'months') {\n      const newRange = this.dateRange().shiftMonths(direction)\n      this.setDatesFromRange(newRange)\n      return\n    }\n\n    if (this.calendarMode() === 'years') {\n      const newRange = this.dateRange().shiftYears(direction)\n      this.setDatesFromRange(newRange)\n      return\n    }\n\n    if (this.calendarMode() === 'weeks') {\n      const newRange = this.dateRange().shiftDays(7 * direction)\n      this.setDatesFromRange(newRange)\n      return\n    }\n\n    const daysDiff = this.dateRange().getDurationInDays()\n    const newRange = this.dateRange().shiftDays(daysDiff * direction)\n    this.setDatesFromRange(newRange)\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Date Selection API                                                      *\n   *                                                                         *\n   **************************************************************************/\n\n  public selectCurrentDay(): void {\n    this.setDatesFromRange(TemporalUtil.getCurrentDay(this.anchorDate()))\n    this.setCalendarMode('days')\n    this.resetTimeRange()\n  }\n\n  public selectYesterday(): void {\n    this.setDatesFromRange(TemporalUtil.getYesterday(this.anchorDate()))\n    this.setCalendarMode('days')\n    this.resetTimeRange()\n  }\n\n  public selectCurrentMonth(): void {\n    this.setDatesFromRange(TemporalUtil.getCurrentMonth(this.anchorDate()))\n    this.setCalendarMode('months')\n    this.resetTimeRange()\n  }\n\n  public selectCurrentWeek(): void {\n    this.setDatesFromRange(TemporalUtil.getCurrentWeek(this.anchorDate()))\n    this.setCalendarMode('weeks')\n    this.resetTimeRange()\n  }\n\n  public selectPreviousWeek(): void {\n    this.setDatesFromRange(TemporalUtil.getPreviousWeek(this.anchorDate()))\n    this.setCalendarMode('weeks')\n    this.resetTimeRange()\n  }\n\n  public selectPreviousMonth(): void {\n    this.setDatesFromRange(TemporalUtil.getPreviousMonth(this.anchorDate()))\n    this.setCalendarMode('months')\n    this.resetTimeRange()\n  }\n\n  public selectLastThirtyDaysExcludingToday(): void {\n    this.setDatesFromRange(TemporalUtil.getLastThirtyDays(this.anchorDate()))\n    this.setCalendarMode('days')\n    this.resetTimeRange()\n  }\n\n  public selectLastThirtyDaysIncludingToday(): void {\n    this.setDatesFromRange(TemporalUtil.getLastThirtyDaysIncludingToday(this.anchorDate()))\n    this.setCalendarMode('days')\n    this.resetTimeRange()\n  }\n\n  public selectCurrentYear(): void {\n    this.setDatesFromRange(TemporalUtil.getCurrentYear(this.anchorDate()))\n    this.setCalendarMode('years')\n    this.resetTimeRange()\n  }\n\n  public selectPreviousYear(): void {\n    this.setDatesFromRange(TemporalUtil.getPreviousYear(this.anchorDate()))\n    this.setCalendarMode('years')\n    this.resetTimeRange()\n  }\n\n  public selectLast365Days(): void {\n    this.setDatesFromRange(TemporalUtil.getLast365Days(this.anchorDate()))\n    this.setCalendarMode('days')\n    this.resetTimeRange()\n  }\n\n  public selectCurrentQuarter(): void {\n    this.setDatesFromRange(TemporalUtil.getCurrentQuarter(this.anchorDate()))\n    this.setCalendarMode('quarters')\n    this.resetTimeRange()\n  }\n\n  public selectPreviousQuarter(): void {\n    this.setDatesFromRange(TemporalUtil.getPreviousQuarter(this.anchorDate()))\n    this.setCalendarMode('quarters')\n    this.resetTimeRange()\n  }\n\n  public selectLastSevenDaysExcludingToday(): void {\n    this.setDatesFromRange(TemporalUtil.getLastSevenDays(this.anchorDate()))\n    this.setCalendarMode('days')\n    this.resetTimeRange()\n  }\n\n  public selectLastSevenDaysIncludingToday(): void {\n    this.setDatesFromRange(TemporalUtil.getLastSevenDaysIncludingToday(this.anchorDate()))\n    this.setCalendarMode('days')\n    this.resetTimeRange()\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Time Selection API                                                      *\n   *                                                                         *\n   **************************************************************************/\n\n  // time range selections\n  public selectLastHour(): void {\n    this.selectLastByDuration({ hours: 1 })\n  }\n\n  public selectLast24Hours(): void {\n    this.selectLastByDuration({ days: 1 })\n  }\n\n  public selectLastFiveMinutes(): void {\n    this.selectLastByDuration({ minutes: 5 })\n  }\n\n  private selectLastByDuration(duration: Temporal.Duration | DurationLike): void {\n    this.refreshBaseReferenceDateTime()\n\n    const end = this.anchorDateTime()\n    const start = end.subtract(duration)\n    const startPlainDate = Temporal.PlainDate.from(start)\n    const startPlainTime = Temporal.PlainTime.from(start)\n\n    this.setDateRange(startPlainDate, this.anchorDate())\n    this.setTimeRange(startPlainTime, this.anchorTime())\n\n    this.setCalendarMode('days')\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n  private anchorTime(): Temporal.PlainTime {\n    return this.model.anchorTime()\n  }\n  private anchorDate(): Temporal.PlainDate {\n    return this.model.anchorDate()\n  }\n\n  private setCalendarMode(mode: CalendarMode) {\n    this.model.calendarMode.set(mode)\n  }\n\n  private calendarMode(): CalendarMode {\n    return this.model.calendarMode()\n  }\n\n  private dateRange(): TemporalPlainDateInterval {\n    return this.model.dateRange()\n  }\n\n  private resetTimeRange(): void {\n    this.setTimeRange(Temporal.PlainTime.from('00:00'), Temporal.PlainTime.from('00:00'))\n  }\n\n  private setTimeRange(start: Temporal.PlainTime, end: Temporal.PlainTime) {\n    this.model.setStartTime(start)\n    this.model.setEndTime(end)\n  }\n\n  private setDateRange(start: Temporal.PlainDate, end: Temporal.PlainDate) {\n    this.model.setStartDate(start)\n    this.model.setEndDate(end)\n  }\n\n  private setDatesFromRange(range: TemporalPlainDateInterval): void {\n    this.setDateRange(range.start, range.end)\n  }\n\n  public shiftSelectionToAnchorDate(): void {\n    if (!this.isStartAndEndDatesSet() || !this.fixedAnchorDate()) {\n      return\n    }\n\n    const range = this.dateRange()\n    const endDate = this.fixedAnchorDate()\n    const startDate = endDate.subtract({ days: range.getDurationInDays() })\n    this.setDateRange(startDate, endDate)\n\n    if (this.calendarMode() === 'months') {\n      this.selectCurrentMonth()\n    }\n    if (this.calendarMode() === 'years') {\n      this.selectCurrentYear()\n    }\n    if (this.calendarMode() === 'weeks') {\n      this.selectCurrentWeek()\n    }\n  }\n\n  private fixedAnchorDate(): Temporal.PlainDate {\n    return this.model.fixedAnchorDate()\n  }\n\n  private fixedAnchorTime(): Temporal.PlainTime {\n    return this.model.fixedAnchorTime()\n  }\n\n  private anchorDateTime(): Temporal.PlainDateTime {\n    return this.model.anchorDateTime()\n  }\n\n  private startDateTime(): Temporal.PlainDate | Temporal.PlainDateTime {\n    return this.model.startDateTime()\n  }\n\n  private endDateTime(): Temporal.PlainDate | Temporal.PlainDateTime {\n    return this.model.endDateTime()\n  }\n\n  private isStartAndEndDatesSet(): boolean {\n    return this.model.isStartAndEndDatesSet()\n  }\n\n  public shiftSelectionToAnchorTime(): void {\n    if (!this.isStartAndEndDatesSet() || !this.fixedAnchorTime()) {\n      return\n    }\n\n    const duration = this.startDateTime().until(this.endDateTime())\n    const newStartDateTime = this.anchorDateTime().subtract(duration)\n    const newEndDateTime = this.anchorDateTime()\n    this.setDateRange(\n      Temporal.PlainDate.from(newStartDateTime),\n      Temporal.PlainDate.from(newEndDateTime)\n    )\n    this.setTimeRange(\n      Temporal.PlainTime.from(newStartDateTime),\n      Temporal.PlainTime.from(newEndDateTime)\n    )\n\n    if (this.calendarMode() === 'months') {\n      this.selectCurrentMonth()\n    }\n    if (this.calendarMode() === 'years') {\n      this.selectCurrentYear()\n    }\n    if (this.calendarMode() === 'weeks') {\n      this.selectCurrentWeek()\n    }\n  }\n\n  private refreshBaseReferenceDateTime(): void {\n    const dateTime = Temporal.Now.zonedDateTimeISO()\n    const date = Temporal.PlainDate.from(dateTime)\n    const time = Temporal.PlainTime.from(dateTime)\n    this.model.baseReferenceDate.set(date)\n    this.model.baseReferenceTime.set(time)\n  }\n}\n"]}