@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.
- package/esm2022/lib/common/i18n/entity/elder-multi-translate-loader.mjs +4 -4
- package/esm2022/lib/common/utils/signal-input.mjs +3 -0
- package/esm2022/lib/components/time/elder-interval-picker/controller/interval-anchor-controller.mjs +21 -0
- package/esm2022/lib/components/time/elder-interval-picker/controller/interval-calendar-controller.mjs +24 -0
- package/esm2022/lib/components/time/elder-interval-picker/controller/interval-controller.mjs +43 -0
- package/esm2022/lib/components/time/elder-interval-picker/controller/interval-form-controller.mjs +69 -0
- package/esm2022/lib/components/time/elder-interval-picker/controller/interval-select-controller.mjs +117 -0
- package/esm2022/lib/components/time/elder-interval-picker/controller/interval-shift-controller.mjs +44 -0
- package/esm2022/lib/components/time/elder-interval-picker/elder-interval-picker.component.mjs +76 -127
- package/esm2022/lib/components/time/elder-interval-picker/interval-picker-binding/elder-interval-picker-binding.directive.mjs +41 -0
- package/esm2022/lib/components/time/elder-interval-picker/interval-picker-toggle/elder-interval-picker-toggle.component.mjs +144 -0
- package/esm2022/lib/components/time/elder-interval-picker/manager/interval-picker-state-manager.mjs +93 -0
- package/esm2022/lib/components/time/elder-interval-picker/model/anchor-state.mjs +54 -0
- package/esm2022/lib/components/time/elder-interval-picker/model/interval-state.mjs +37 -0
- package/esm2022/lib/components/time/elder-interval-picker/model/smart-shift-state.mjs +10 -0
- package/esm2022/lib/components/time/elder-interval-picker/presenter/interval-picker-presenter.mjs +96 -0
- package/esm2022/lib/components/time/elder-interval-picker/util/interval-picker-util.mjs +194 -0
- package/esm2022/lib/components/time/elder-time.module.mjs +5 -5
- package/fesm2022/elderbyte-ngx-starter.mjs +764 -888
- package/fesm2022/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/common/utils/signal-input.d.ts +2 -0
- package/lib/components/time/elder-interval-picker/controller/interval-anchor-controller.d.ts +9 -0
- package/lib/components/time/elder-interval-picker/controller/interval-calendar-controller.d.ts +7 -0
- package/lib/components/time/elder-interval-picker/controller/interval-controller.d.ts +35 -0
- package/lib/components/time/elder-interval-picker/controller/interval-form-controller.d.ts +12 -0
- package/lib/components/time/elder-interval-picker/controller/interval-select-controller.d.ts +22 -0
- package/lib/components/time/elder-interval-picker/controller/interval-shift-controller.d.ts +13 -0
- package/lib/components/time/elder-interval-picker/elder-interval-picker.component.d.ts +23 -33
- 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
- package/lib/components/time/elder-interval-picker/interval-picker-toggle/elder-interval-picker-toggle.component.d.ts +37 -0
- package/lib/components/time/elder-interval-picker/manager/interval-picker-state-manager.d.ts +46 -0
- package/lib/components/time/elder-interval-picker/model/anchor-state.d.ts +20 -0
- package/lib/components/time/elder-interval-picker/model/interval-state.d.ts +16 -0
- package/lib/components/time/elder-interval-picker/model/smart-shift-state.d.ts +8 -0
- package/lib/components/time/elder-interval-picker/presenter/interval-picker-presenter.d.ts +30 -0
- package/lib/components/time/elder-interval-picker/util/interval-picker-util.d.ts +20 -0
- package/lib/components/time/elder-time.module.d.ts +4 -4
- package/package.json +1 -1
- package/esm2022/lib/components/time/elder-interval-picker/elder-interval-picker-binding.directive.mjs +0 -40
- package/esm2022/lib/components/time/elder-interval-picker/elder-interval-picker-toggle/elder-interval-picker-toggle.component.mjs +0 -202
- package/esm2022/lib/components/time/elder-interval-picker/model/interval-picker-model-editor.mjs +0 -284
- package/esm2022/lib/components/time/elder-interval-picker/model/interval-picker-model.mjs +0 -445
- package/esm2022/lib/components/time/elder-interval-picker/model/plain-date-interval-message-renderer.mjs +0 -37
- package/esm2022/lib/components/time/elder-interval-picker/model/plain-temporal-duration-message-renderer.mjs +0 -25
- package/lib/components/time/elder-interval-picker/elder-interval-picker-toggle/elder-interval-picker-toggle.component.d.ts +0 -55
- package/lib/components/time/elder-interval-picker/model/interval-picker-model-editor.d.ts +0 -77
- package/lib/components/time/elder-interval-picker/model/interval-picker-model.d.ts +0 -113
- package/lib/components/time/elder-interval-picker/model/plain-date-interval-message-renderer.d.ts +0 -7
- 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"]}
|
package/esm2022/lib/components/time/elder-interval-picker/model/interval-picker-model-editor.mjs
DELETED
|
@@ -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":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAA;AAEhD,OAAO,EAAE,YAAY,EAAE,MAAM,uCAAuC,CAAA;AAGpE,MAAM,OAAO,yBAAyB;IACpC;;;;gFAI4E;IAE5E,YAA6B,KAA0B;QAA1B,UAAK,GAAL,KAAK,CAAqB;IAAG,CAAC;IAC3D;;;;gFAI4E;IAErE,UAAU,CAAC,MAAc,EAAE,UAAU,GAAG,KAAK;QAClD,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAA;QAC5D,IAAI,UAAU,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,QAAQ,EAAE,CAAC;YACnD,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAA;YAC5B,OAAM;QACR,CAAC;QACD,IAAI,CAAC,cAAc,EAAE,CAAA;QACrB,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAA;IAChC,CAAC;IAEM,QAAQ,CAAC,IAAY;QAC1B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAA;QACxD,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,OAAO,IAAI,CAAC,IAAI,KAAK,CAAC,IAAI,IAAI,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;YACnE,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAA;YAC7B,OAAM;QACR,CAAC;QACD,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAA;IAC9B,CAAC;IAEM,SAAS,CAAC,KAAa,EAAE,UAAU,GAAG,KAAK;QAChD,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAA;QAC1D,IAAI,UAAU,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,OAAO,EAAE,CAAC;YAClD,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAA;YAC5B,OAAM;QACR,CAAC;QACD,IAAI,CAAC,cAAc,EAAE,CAAA;QACrB,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAA;IAC/B,CAAC;IAED;;;;gFAI4E;IAErE,SAAS,CAAC,MAAc,EAAE,IAAyB;QACxD,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE,EAAE,CAAC;YAClC,OAAM;QACR,CAAC;QAED,MAAM,gBAAgB,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC,CAAA;QACrE,MAAM,cAAc,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC,CAAA;QAEjE,IAAI,CAAC,YAAY,CACf,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,EACzC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CACxC,CAAA;QACD,IAAI,CAAC,YAAY,CACf,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,gBAA0C,CAAC,EACnE,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,cAAwC,CAAC,CAClE,CAAA;IACH,CAAC;IAEM,UAAU,CAAC,SAAS,GAAG,CAAC;QAC7B,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,UAAU,EAAE,CAAC;YACvC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,WAAW,CAAC,SAAS,GAAG,CAAC,CAAC,CAAA;YAC5D,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAA;YAChC,OAAM;QACR,CAAC;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,QAAQ,EAAE,CAAC;YACrC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,WAAW,CAAC,SAAS,CAAC,CAAA;YACxD,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAA;YAChC,OAAM;QACR,CAAC;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,OAAO,EAAE,CAAC;YACpC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,CAAA;YACvD,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAA;YAChC,OAAM;QACR,CAAC;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,OAAO,EAAE,CAAC;YACpC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,CAAA;YAC1D,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAA;YAChC,OAAM;QACR,CAAC;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,iBAAiB,EAAE,CAAA;QACrD,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,SAAS,CAAC,QAAQ,GAAG,SAAS,CAAC,CAAA;QACjE,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAA;IAClC,CAAC;IAED;;;;gFAI4E;IAErE,gBAAgB;QACrB,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAA;QACrE,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAA;QAC5B,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAEM,eAAe;QACpB,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAA;QACpE,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAA;QAC5B,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAEM,kBAAkB;QACvB,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAA;QACvE,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAA;QAC9B,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAEM,iBAAiB;QACtB,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAA;QACtE,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAA;QAC7B,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAEM,kBAAkB;QACvB,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAA;QACvE,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAA;QAC7B,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAEM,mBAAmB;QACxB,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAA;QACxE,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAA;QAC9B,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAEM,kCAAkC;QACvC,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAA;QACzE,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAA;QAC5B,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAEM,kCAAkC;QACvC,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,+BAA+B,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAA;QACvF,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAA;QAC5B,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAEM,iBAAiB;QACtB,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAA;QACtE,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAA;QAC7B,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAEM,kBAAkB;QACvB,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAA;QACvE,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAA;QAC7B,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAEM,iBAAiB;QACtB,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAA;QACtE,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAA;QAC5B,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAEM,oBAAoB;QACzB,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAA;QACzE,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAA;QAChC,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAEM,qBAAqB;QAC1B,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAA;QAC1E,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAA;QAChC,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAEM,iCAAiC;QACtC,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,gBAAgB,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAA;QACxE,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAA;QAC5B,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAEM,iCAAiC;QACtC,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,8BAA8B,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAA;QACtF,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAA;QAC5B,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAED;;;;gFAI4E;IAE5E,wBAAwB;IACjB,cAAc;QACnB,IAAI,CAAC,oBAAoB,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAA;IACzC,CAAC;IAEM,iBAAiB;QACtB,IAAI,CAAC,oBAAoB,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC,CAAA;IACxC,CAAC;IAEM,qBAAqB;QAC1B,IAAI,CAAC,oBAAoB,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,CAAC,CAAA;IAC3C,CAAC;IAEO,oBAAoB,CAAC,QAA0C;QACrE,IAAI,CAAC,4BAA4B,EAAE,CAAA;QAEnC,MAAM,GAAG,GAAG,IAAI,CAAC,cAAc,EAAE,CAAA;QACjC,MAAM,KAAK,GAAG,GAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAA;QACpC,MAAM,cAAc,GAAG,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACrD,MAAM,cAAc,GAAG,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QAErD,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC,CAAA;QACpD,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC,CAAA;QAEpD,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAA;IAC9B,CAAC;IAED;;;;gFAI4E;IACpE,UAAU;QAChB,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAA;IAChC,CAAC;IACO,UAAU;QAChB,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAA;IAChC,CAAC;IAEO,eAAe,CAAC,IAAkB;QACxC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;IACnC,CAAC;IAEO,YAAY;QAClB,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAA;IAClC,CAAC;IAEO,SAAS;QACf,OAAO,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,CAAA;IAC/B,CAAC;IAEO,cAAc;QACpB,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAA;IACvF,CAAC;IAEO,YAAY,CAAC,KAAyB,EAAE,GAAuB;QACrE,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,CAAA;QAC9B,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAA;IAC5B,CAAC;IAEO,YAAY,CAAC,KAAyB,EAAE,GAAuB;QACrE,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,CAAA;QAC9B,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAA;IAC5B,CAAC;IAEO,iBAAiB,CAAC,KAAgC;QACxD,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,CAAA;IAC3C,CAAC;IAEM,0BAA0B;QAC/B,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,EAAE,CAAC;YAC7D,OAAM;QACR,CAAC;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,EAAE,CAAA;QAC9B,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,EAAE,CAAA;QACtC,MAAM,SAAS,GAAG,OAAO,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,KAAK,CAAC,iBAAiB,EAAE,EAAE,CAAC,CAAA;QACvE,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,OAAO,CAAC,CAAA;QAErC,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,QAAQ,EAAE,CAAC;YACrC,IAAI,CAAC,kBAAkB,EAAE,CAAA;QAC3B,CAAC;QACD,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,OAAO,EAAE,CAAC;YACpC,IAAI,CAAC,iBAAiB,EAAE,CAAA;QAC1B,CAAC;QACD,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,OAAO,EAAE,CAAC;YACpC,IAAI,CAAC,iBAAiB,EAAE,CAAA;QAC1B,CAAC;IACH,CAAC;IAEO,eAAe;QACrB,OAAO,IAAI,CAAC,KAAK,CAAC,eAAe,EAAE,CAAA;IACrC,CAAC;IAEO,eAAe;QACrB,OAAO,IAAI,CAAC,KAAK,CAAC,eAAe,EAAE,CAAA;IACrC,CAAC;IAEO,cAAc;QACpB,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,EAAE,CAAA;IACpC,CAAC;IAEO,aAAa;QACnB,OAAO,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAA;IACnC,CAAC;IAEO,WAAW;QACjB,OAAO,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAA;IACjC,CAAC;IAEO,qBAAqB;QAC3B,OAAO,IAAI,CAAC,KAAK,CAAC,qBAAqB,EAAE,CAAA;IAC3C,CAAC;IAEM,0BAA0B;QAC/B,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,EAAE,CAAC;YAC7D,OAAM;QACR,CAAC;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAA;QAC/D,MAAM,gBAAgB,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAA;QACjE,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,EAAE,CAAA;QAC5C,IAAI,CAAC,YAAY,CACf,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,EACzC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CACxC,CAAA;QACD,IAAI,CAAC,YAAY,CACf,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,EACzC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CACxC,CAAA;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,QAAQ,EAAE,CAAC;YACrC,IAAI,CAAC,kBAAkB,EAAE,CAAA;QAC3B,CAAC;QACD,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,OAAO,EAAE,CAAC;YACpC,IAAI,CAAC,iBAAiB,EAAE,CAAA;QAC1B,CAAC;QACD,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,OAAO,EAAE,CAAC;YACpC,IAAI,CAAC,iBAAiB,EAAE,CAAA;QAC1B,CAAC;IACH,CAAC;IAEO,4BAA4B;QAClC,MAAM,QAAQ,GAAG,QAAQ,CAAC,GAAG,CAAC,gBAAgB,EAAE,CAAA;QAChD,MAAM,IAAI,GAAG,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QAC9C,MAAM,IAAI,GAAG,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QAC9C,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;QACtC,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;IACxC,CAAC;CACF","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"]}
|