@elderbyte/ngx-starter 18.12.4 → 18.12.6

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/data/data-context/indexed-entities.mjs +13 -2
  2. package/esm2022/lib/common/selection/selection-model.mjs +4 -3
  3. package/esm2022/lib/components/data-view/common/selection/data-context-selection.directive.mjs +4 -2
  4. package/esm2022/lib/components/time/elder-interval-picker/controller/interval-anchor-controller.mjs +21 -0
  5. package/esm2022/lib/components/time/elder-interval-picker/controller/interval-calendar-controller.mjs +24 -0
  6. package/esm2022/lib/components/time/elder-interval-picker/controller/interval-controller.mjs +43 -0
  7. package/esm2022/lib/components/time/elder-interval-picker/controller/interval-form-controller.mjs +69 -0
  8. package/esm2022/lib/components/time/elder-interval-picker/controller/interval-select-controller.mjs +117 -0
  9. package/esm2022/lib/components/time/elder-interval-picker/controller/interval-shift-controller.mjs +44 -0
  10. package/esm2022/lib/components/time/elder-interval-picker/elder-interval-picker.component.mjs +87 -130
  11. package/esm2022/lib/components/time/elder-interval-picker/interval-picker-binding/elder-interval-picker-binding.directive.mjs +41 -0
  12. package/esm2022/lib/components/time/elder-interval-picker/interval-picker-toggle/elder-interval-picker-toggle.component.mjs +144 -0
  13. package/esm2022/lib/components/time/elder-interval-picker/manager/interval-picker-state-manager.mjs +93 -0
  14. package/esm2022/lib/components/time/elder-interval-picker/model/anchor-state.mjs +54 -0
  15. package/esm2022/lib/components/time/elder-interval-picker/model/interval-state.mjs +37 -0
  16. package/esm2022/lib/components/time/elder-interval-picker/model/smart-shift-state.mjs +10 -0
  17. package/esm2022/lib/components/time/elder-interval-picker/presenter/interval-picker-presenter.mjs +96 -0
  18. package/esm2022/lib/components/time/elder-interval-picker/util/interval-picker-util.mjs +194 -0
  19. package/esm2022/lib/components/time/elder-time.module.mjs +5 -5
  20. package/fesm2022/elderbyte-ngx-starter.mjs +789 -892
  21. package/fesm2022/elderbyte-ngx-starter.mjs.map +1 -1
  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 +26 -34
  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
@@ -0,0 +1,41 @@
1
+ import { ContentChild, Directive } from '@angular/core';
2
+ import { ElderIntervalInputComponent } from '../../elder-interval-input/elder-interval-input.component';
3
+ import { ElderIntervalPickerToggleComponent } from '../interval-picker-toggle/elder-interval-picker-toggle.component';
4
+ import * as i0 from "@angular/core";
5
+ export class ElderIntervalPickerBindingDirective {
6
+ /***************************************************************************
7
+ * *
8
+ * Constructor *
9
+ * *
10
+ **************************************************************************/
11
+ constructor() { }
12
+ /***************************************************************************
13
+ * *
14
+ * Life Cycle *
15
+ * *
16
+ **************************************************************************/
17
+ ngAfterContentInit() {
18
+ if (!this.intervalInputComponent || !this.intervalPickerToggleComponent) {
19
+ console.error('ElderIntervalPickerBindingDirective: Both components are required, IntervalInputComponent and IntervalPickerToggleComponent.');
20
+ return;
21
+ }
22
+ this.intervalPickerToggleComponent.connectedIntervalInput = this.intervalInputComponent;
23
+ this.intervalInputComponent.isDefaultDatePickerDisabled = true;
24
+ }
25
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: ElderIntervalPickerBindingDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
26
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.5", type: ElderIntervalPickerBindingDirective, isStandalone: true, selector: "[elderIntervalPickerBinding]", queries: [{ propertyName: "intervalInputComponent", first: true, predicate: ElderIntervalInputComponent, descendants: true }, { propertyName: "intervalPickerToggleComponent", first: true, predicate: ElderIntervalPickerToggleComponent, descendants: true }], ngImport: i0 }); }
27
+ }
28
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: ElderIntervalPickerBindingDirective, decorators: [{
29
+ type: Directive,
30
+ args: [{
31
+ selector: '[elderIntervalPickerBinding]',
32
+ standalone: true,
33
+ }]
34
+ }], ctorParameters: () => [], propDecorators: { intervalInputComponent: [{
35
+ type: ContentChild,
36
+ args: [ElderIntervalInputComponent]
37
+ }], intervalPickerToggleComponent: [{
38
+ type: ContentChild,
39
+ args: [ElderIntervalPickerToggleComponent]
40
+ }] } });
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItaW50ZXJ2YWwtcGlja2VyLWJpbmRpbmcuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy90aW1lL2VsZGVyLWludGVydmFsLXBpY2tlci9pbnRlcnZhbC1waWNrZXItYmluZGluZy9lbGRlci1pbnRlcnZhbC1waWNrZXItYmluZGluZy5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDdkQsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sMkRBQTJELENBQUE7QUFDdkcsT0FBTyxFQUFFLGtDQUFrQyxFQUFFLE1BQU0sa0VBQWtFLENBQUE7O0FBTXJILE1BQU0sT0FBTyxtQ0FBbUM7SUFZOUM7Ozs7Z0ZBSTRFO0lBRTVFLGdCQUFlLENBQUM7SUFFaEI7Ozs7Z0ZBSTRFO0lBRXJFLGtCQUFrQjtRQUN2QixJQUFJLENBQUMsSUFBSSxDQUFDLHNCQUFzQixJQUFJLENBQUMsSUFBSSxDQUFDLDZCQUE2QixFQUFFLENBQUM7WUFDeEUsT0FBTyxDQUFDLEtBQUssQ0FDWCw4SEFBOEgsQ0FDL0gsQ0FBQTtZQUNELE9BQU07UUFDUixDQUFDO1FBRUQsSUFBSSxDQUFDLDZCQUE2QixDQUFDLHNCQUFzQixHQUFHLElBQUksQ0FBQyxzQkFBc0IsQ0FBQTtRQUN2RixJQUFJLENBQUMsc0JBQXNCLENBQUMsMkJBQTJCLEdBQUcsSUFBSSxDQUFBO0lBQ2hFLENBQUM7OEdBcENVLG1DQUFtQztrR0FBbkMsbUNBQW1DLDRJQU9oQywyQkFBMkIsZ0dBRTNCLGtDQUFrQzs7MkZBVHJDLG1DQUFtQztrQkFKL0MsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsOEJBQThCO29CQUN4QyxVQUFVLEVBQUUsSUFBSTtpQkFDakI7d0RBU0Msc0JBQXNCO3NCQURyQixZQUFZO3VCQUFDLDJCQUEyQjtnQkFHekMsNkJBQTZCO3NCQUQ1QixZQUFZO3VCQUFDLGtDQUFrQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbnRlbnRDaGlsZCwgRGlyZWN0aXZlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IEVsZGVySW50ZXJ2YWxJbnB1dENvbXBvbmVudCB9IGZyb20gJy4uLy4uL2VsZGVyLWludGVydmFsLWlucHV0L2VsZGVyLWludGVydmFsLWlucHV0LmNvbXBvbmVudCdcbmltcG9ydCB7IEVsZGVySW50ZXJ2YWxQaWNrZXJUb2dnbGVDb21wb25lbnQgfSBmcm9tICcuLi9pbnRlcnZhbC1waWNrZXItdG9nZ2xlL2VsZGVyLWludGVydmFsLXBpY2tlci10b2dnbGUuY29tcG9uZW50J1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZWxkZXJJbnRlcnZhbFBpY2tlckJpbmRpbmddJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgRWxkZXJJbnRlcnZhbFBpY2tlckJpbmRpbmdEaXJlY3RpdmUge1xuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogRmllbGRzICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBAQ29udGVudENoaWxkKEVsZGVySW50ZXJ2YWxJbnB1dENvbXBvbmVudClcbiAgaW50ZXJ2YWxJbnB1dENvbXBvbmVudDogRWxkZXJJbnRlcnZhbElucHV0Q29tcG9uZW50XG4gIEBDb250ZW50Q2hpbGQoRWxkZXJJbnRlcnZhbFBpY2tlclRvZ2dsZUNvbXBvbmVudClcbiAgaW50ZXJ2YWxQaWNrZXJUb2dnbGVDb21wb25lbnQ6IEVsZGVySW50ZXJ2YWxQaWNrZXJUb2dnbGVDb21wb25lbnRcblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogQ29uc3RydWN0b3IgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBjb25zdHJ1Y3RvcigpIHt9XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIExpZmUgQ3ljbGUgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHVibGljIG5nQWZ0ZXJDb250ZW50SW5pdCgpOiB2b2lkIHtcbiAgICBpZiAoIXRoaXMuaW50ZXJ2YWxJbnB1dENvbXBvbmVudCB8fCAhdGhpcy5pbnRlcnZhbFBpY2tlclRvZ2dsZUNvbXBvbmVudCkge1xuICAgICAgY29uc29sZS5lcnJvcihcbiAgICAgICAgJ0VsZGVySW50ZXJ2YWxQaWNrZXJCaW5kaW5nRGlyZWN0aXZlOiBCb3RoIGNvbXBvbmVudHMgYXJlIHJlcXVpcmVkLCBJbnRlcnZhbElucHV0Q29tcG9uZW50IGFuZCBJbnRlcnZhbFBpY2tlclRvZ2dsZUNvbXBvbmVudC4nXG4gICAgICApXG4gICAgICByZXR1cm5cbiAgICB9XG5cbiAgICB0aGlzLmludGVydmFsUGlja2VyVG9nZ2xlQ29tcG9uZW50LmNvbm5lY3RlZEludGVydmFsSW5wdXQgPSB0aGlzLmludGVydmFsSW5wdXRDb21wb25lbnRcbiAgICB0aGlzLmludGVydmFsSW5wdXRDb21wb25lbnQuaXNEZWZhdWx0RGF0ZVBpY2tlckRpc2FibGVkID0gdHJ1ZVxuICB9XG59XG4iXX0=
@@ -0,0 +1,144 @@
1
+ import { booleanAttribute, ChangeDetectionStrategy, Component, Input, 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 { ElderOverlayOriginDirective } from '../../../overlays/elder-overlay-origin.directive';
7
+ import { ElderOverlayTriggerDirective } from '../../../overlays/elder-overlay-trigger.directive';
8
+ import { ElderOverlayComponent } from '../../../overlays/elder-overlay.component';
9
+ import { ElderDialogPanelComponent } from '../../../panels/elder-dialog-panel/elder-dialog-panel.component';
10
+ import { ElderIntervalInputComponent, } from '../../elder-interval-input/elder-interval-input.component';
11
+ import { ElderIntervalPickerComponent } from '../elder-interval-picker.component';
12
+ import * as i0 from "@angular/core";
13
+ export class ElderIntervalPickerToggleComponent {
14
+ constructor() {
15
+ this.log = LoggerFactory.getLogger(this.constructor.name);
16
+ this.connectedIntervalInput = null;
17
+ this.intervalInputMode = signal('date-time-range');
18
+ this.emitType = signal('interval');
19
+ this.externalInterval = signal(null);
20
+ this.showAnchor = input(false);
21
+ this.anchorReadOnly = input(false);
22
+ this.externalAnchorDateTime = input(null);
23
+ this.disabled = booleanAttribute(false);
24
+ }
25
+ /***************************************************************************
26
+ * *
27
+ * Life Cycle *
28
+ * *
29
+ **************************************************************************/
30
+ ngAfterViewInit() {
31
+ if (!this.connectedIntervalInput) {
32
+ this.log.error('ElderIntervalPickerToggleComponent: connectedIntervalInput is required.');
33
+ return;
34
+ }
35
+ this.intervalInputMode.set(this.connectedIntervalInput.mode);
36
+ this.emitType.set(this.connectedIntervalInput.valueAsIsoStr ? 'iso' : 'interval');
37
+ this.connectedIntervalInput.valueChange.subscribe((interval) => {
38
+ this.externalInterval.set(interval);
39
+ });
40
+ if (this.connectedIntervalInput.value) {
41
+ // this is necessary to set the value of the interval picker
42
+ this.externalInterval.set(this.connectedIntervalInput.value);
43
+ }
44
+ }
45
+ /***************************************************************************
46
+ * *
47
+ * Public API *
48
+ * *
49
+ **************************************************************************/
50
+ setConnectedIntervalInput(intervalInput) {
51
+ this.connectedIntervalInput = intervalInput;
52
+ }
53
+ handleIntervalPickerDateChange(interval) {
54
+ this.connectedIntervalInput.value = interval;
55
+ }
56
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: ElderIntervalPickerToggleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
57
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.5", type: ElderIntervalPickerToggleComponent, isStandalone: true, selector: "elder-interval-picker-toggle", inputs: { connectedIntervalInput: { classPropertyName: "connectedIntervalInput", publicName: "connectedIntervalInput", isSignal: false, 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 }, externalAnchorDateTime: { classPropertyName: "externalAnchorDateTime", publicName: "externalAnchorDateTime", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: false, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "connectedIntervalPicker", first: true, predicate: ["connectedIntervalPicker"], descendants: true }], ngImport: i0, template: `
58
+ <span style="padding-right: 8px">
59
+ <button
60
+ mat-icon-button
61
+ [elderOverlayOrigin]="dateIntervalOverlay"
62
+ [elderOverlayTrigger]="dateIntervalOverlay"
63
+ class="elder-control-icon-button mat-datepicker-toggle"
64
+ >
65
+ <mat-icon>date_range</mat-icon>
66
+ </button>
67
+ </span>
68
+
69
+ <elder-overlay #dateIntervalOverlay>
70
+ <elder-dialog-panel>
71
+ <div class="pb-md pt-xs">
72
+ <elder-interval-picker
73
+ #connectedIntervalPicker
74
+ [intervalInputMode]="intervalInputMode()"
75
+ (intervalChange)="handleIntervalPickerDateChange($event)"
76
+ [externalInterval]="externalInterval()"
77
+ [showAnchor]="showAnchor()"
78
+ [anchorReadOnly]="anchorReadOnly()"
79
+ [externalAnchorDateTime]="externalAnchorDateTime()"
80
+ [emitType]="emitType()"
81
+ ></elder-interval-picker>
82
+ </div>
83
+ </elder-dialog-panel>
84
+ </elder-overlay>
85
+ `, isInline: true, dependencies: [{ kind: "component", type: ElderIntervalPickerComponent, selector: "elder-interval-picker", inputs: ["autoEmitMode", "emitOnChange", "emitType", "intervalInputMode", "showAnchor", "anchorReadOnly", "externalAnchorDateTime", "externalInterval"], outputs: ["intervalChange"] }, { 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 }); }
86
+ }
87
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.5", ngImport: i0, type: ElderIntervalPickerToggleComponent, decorators: [{
88
+ type: Component,
89
+ args: [{
90
+ selector: 'elder-interval-picker-toggle',
91
+ standalone: true,
92
+ imports: [
93
+ ElderIntervalPickerComponent,
94
+ ElderIntervalInputComponent,
95
+ MatFormField,
96
+ MatLabel,
97
+ ElderOverlayComponent,
98
+ ElderDialogPanelComponent,
99
+ MatIcon,
100
+ MatIconButton,
101
+ MatSuffix,
102
+ ElderOverlayTriggerDirective,
103
+ ElderOverlayOriginDirective,
104
+ ],
105
+ template: `
106
+ <span style="padding-right: 8px">
107
+ <button
108
+ mat-icon-button
109
+ [elderOverlayOrigin]="dateIntervalOverlay"
110
+ [elderOverlayTrigger]="dateIntervalOverlay"
111
+ class="elder-control-icon-button mat-datepicker-toggle"
112
+ >
113
+ <mat-icon>date_range</mat-icon>
114
+ </button>
115
+ </span>
116
+
117
+ <elder-overlay #dateIntervalOverlay>
118
+ <elder-dialog-panel>
119
+ <div class="pb-md pt-xs">
120
+ <elder-interval-picker
121
+ #connectedIntervalPicker
122
+ [intervalInputMode]="intervalInputMode()"
123
+ (intervalChange)="handleIntervalPickerDateChange($event)"
124
+ [externalInterval]="externalInterval()"
125
+ [showAnchor]="showAnchor()"
126
+ [anchorReadOnly]="anchorReadOnly()"
127
+ [externalAnchorDateTime]="externalAnchorDateTime()"
128
+ [emitType]="emitType()"
129
+ ></elder-interval-picker>
130
+ </div>
131
+ </elder-dialog-panel>
132
+ </elder-overlay>
133
+ `,
134
+ changeDetection: ChangeDetectionStrategy.OnPush,
135
+ }]
136
+ }], propDecorators: { connectedIntervalPicker: [{
137
+ type: ViewChild,
138
+ args: ['connectedIntervalPicker']
139
+ }], connectedIntervalInput: [{
140
+ type: Input
141
+ }], disabled: [{
142
+ type: Input
143
+ }] } });
144
+ //# 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/interval-picker-toggle/elder-interval-picker-toggle.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,gBAAgB,EAChB,uBAAuB,EACvB,SAAS,EACT,KAAK,EACL,KAAK,EACL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAA;AACtB,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAA;AACxD,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,8BAA8B,CAAA;AAChF,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAA;AAChD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAGpD,OAAO,EAAE,2BAA2B,EAAE,MAAM,kDAAkD,CAAA;AAC9F,OAAO,EAAE,4BAA4B,EAAE,MAAM,mDAAmD,CAAA;AAChG,OAAO,EAAE,qBAAqB,EAAE,MAAM,2CAA2C,CAAA;AACjF,OAAO,EAAE,yBAAyB,EAAE,MAAM,iEAAiE,CAAA;AAC3G,OAAO,EACL,2BAA2B,GAE5B,MAAM,2DAA2D,CAAA;AAClE,OAAO,EAAE,4BAA4B,EAAE,MAAM,oCAAoC,CAAA;;AAiDjF,MAAM,OAAO,kCAAkC;IA/C/C;QAwDmB,QAAG,GAAG,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAA;QAGrE,2BAAsB,GAAgC,IAAI,CAAA;QAE1C,sBAAiB,GAAG,MAAM,CAAoB,iBAAiB,CAAC,CAAA;QAChE,aAAQ,GAAG,MAAM,CAAqB,UAAU,CAAC,CAAA;QACjD,qBAAgB,GAAG,MAAM,CAAkB,IAAI,CAAC,CAAA;QAEhE,eAAU,GAAG,KAAK,CAAU,KAAK,CAAC,CAAA;QAClC,mBAAc,GAAG,KAAK,CAAU,KAAK,CAAC,CAAA;QACtC,2BAAsB,GAAG,KAAK,CAAgC,IAAI,CAAC,CAAA;QAGnE,aAAQ,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAA;KAwCnC;IAtCC;;;;gFAI4E;IAE5E,eAAe;QACb,IAAI,CAAC,IAAI,CAAC,sBAAsB,EAAE,CAAC;YACjC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,yEAAyE,CAAC,CAAA;YACzF,OAAM;QACR,CAAC;QAED,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,CAAA;QAC5D,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,UAAU,CAAC,CAAA;QAEjF,IAAI,CAAC,sBAAsB,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,QAA2B,EAAE,EAAE;YAChF,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,QAAoB,CAAC,CAAA;QACjD,CAAC,CAAC,CAAA;QAEF,IAAI,IAAI,CAAC,sBAAsB,CAAC,KAAK,EAAE,CAAC;YACtC,4DAA4D;YAC5D,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,sBAAsB,CAAC,KAAiB,CAAC,CAAA;QAC1E,CAAC;IACH,CAAC;IAED;;;;gFAI4E;IAErE,yBAAyB,CAAC,aAA0C;QACzE,IAAI,CAAC,sBAAsB,GAAG,aAAa,CAAA;IAC7C,CAAC;IAEM,8BAA8B,CAAC,QAAa;QACjD,IAAI,CAAC,sBAAsB,CAAC,KAAK,GAAG,QAAQ,CAAA;IAC9C,CAAC;8GA9DU,kCAAkC;kGAAlC,kCAAkC,29BA/BnC;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BT,4DAxCC,4BAA4B,wPAI5B,qBAAqB,8RACrB,yBAAyB,+DACzB,OAAO,2IACP,aAAa,6FAEb,4BAA4B,4JAC5B,2BAA2B;;2FAiClB,kCAAkC;kBA/C9C,SAAS;mBAAC;oBACT,QAAQ,EAAE,8BAA8B;oBACxC,UAAU,EAAE,IAAI;oBAChB,OAAO,EAAE;wBACP,4BAA4B;wBAC5B,2BAA2B;wBAC3B,YAAY;wBACZ,QAAQ;wBACR,qBAAqB;wBACrB,yBAAyB;wBACzB,OAAO;wBACP,aAAa;wBACb,SAAS;wBACT,4BAA4B;wBAC5B,2BAA2B;qBAC5B;oBACD,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BT;oBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAChD;8BAQuC,uBAAuB;sBAA5D,SAAS;uBAAC,yBAAyB;gBAKpC,sBAAsB;sBADrB,KAAK;gBAYN,QAAQ;sBADP,KAAK","sourcesContent":["import {\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  input,\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 { Temporal } from '@js-temporal/polyfill'\nimport { Interval } from '../../../../common/time/interval'\nimport { ElderOverlayOriginDirective } from '../../../overlays/elder-overlay-origin.directive'\nimport { ElderOverlayTriggerDirective } from '../../../overlays/elder-overlay-trigger.directive'\nimport { ElderOverlayComponent } from '../../../overlays/elder-overlay.component'\nimport { ElderDialogPanelComponent } from '../../../panels/elder-dialog-panel/elder-dialog-panel.component'\nimport {\n  ElderIntervalInputComponent,\n  IntervalInputMode,\n} from '../../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        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>\n      <elder-dialog-panel>\n        <div class=\"pb-md pt-xs\">\n          <elder-interval-picker\n            #connectedIntervalPicker\n            [intervalInputMode]=\"intervalInputMode()\"\n            (intervalChange)=\"handleIntervalPickerDateChange($event)\"\n            [externalInterval]=\"externalInterval()\"\n            [showAnchor]=\"showAnchor()\"\n            [anchorReadOnly]=\"anchorReadOnly()\"\n            [externalAnchorDateTime]=\"externalAnchorDateTime()\"\n            [emitType]=\"emitType()\"\n          ></elder-interval-picker>\n        </div>\n      </elder-dialog-panel>\n    </elder-overlay>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ElderIntervalPickerToggleComponent {\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  @ViewChild('connectedIntervalPicker') connectedIntervalPicker!: ElderIntervalPickerComponent\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name)\n\n  @Input()\n  connectedIntervalInput: ElderIntervalInputComponent = null\n\n  public readonly intervalInputMode = signal<IntervalInputMode>('date-time-range')\n  public readonly emitType = signal<'iso' | 'interval'>('interval')\n  public readonly externalInterval = signal<Interval | null>(null)\n\n  showAnchor = input<boolean>(false)\n  anchorReadOnly = input<boolean>(false)\n  externalAnchorDateTime = input<Temporal.PlainDateTime | null>(null)\n\n  @Input()\n  disabled = booleanAttribute(false)\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  ngAfterViewInit(): void {\n    if (!this.connectedIntervalInput) {\n      this.log.error('ElderIntervalPickerToggleComponent: connectedIntervalInput is required.')\n      return\n    }\n\n    this.intervalInputMode.set(this.connectedIntervalInput.mode)\n    this.emitType.set(this.connectedIntervalInput.valueAsIsoStr ? 'iso' : 'interval')\n\n    this.connectedIntervalInput.valueChange.subscribe((interval: Interval | string) => {\n      this.externalInterval.set(interval as Interval)\n    })\n\n    if (this.connectedIntervalInput.value) {\n      // this is necessary to set the value of the interval picker\n      this.externalInterval.set(this.connectedIntervalInput.value as Interval)\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public setConnectedIntervalInput(intervalInput: ElderIntervalInputComponent): void {\n    this.connectedIntervalInput = intervalInput\n  }\n\n  public handleIntervalPickerDateChange(interval: any): void {\n    this.connectedIntervalInput.value = interval\n  }\n}\n"]}
@@ -0,0 +1,93 @@
1
+ import { LoggerFactory } from '@elderbyte/ts-logger';
2
+ import { BehaviorSubject, Subject } from 'rxjs';
3
+ import AnchorState from '../model/anchor-state';
4
+ import IntervalState from '../model/interval-state';
5
+ import IntervalPickerUtil from '../util/interval-picker-util';
6
+ export default class IntervalPickerStateManager {
7
+ /***************************************************************************
8
+ * *
9
+ * Constructor *
10
+ * *
11
+ **************************************************************************/
12
+ constructor() {
13
+ /***************************************************************************
14
+ * *
15
+ * Fields *
16
+ * *
17
+ **************************************************************************/
18
+ this.log = LoggerFactory.getLogger(this.constructor.name);
19
+ this._anchor = new BehaviorSubject(AnchorState.empty());
20
+ this._interval = new BehaviorSubject(null);
21
+ this._smartShift = new BehaviorSubject(null);
22
+ this._intervalChange = new Subject();
23
+ this.isInitialized = false;
24
+ }
25
+ /***************************************************************************
26
+ * *
27
+ * Properties *
28
+ * *
29
+ **************************************************************************/
30
+ get interval$() {
31
+ return this._interval.asObservable();
32
+ }
33
+ get anchor$() {
34
+ return this._anchor.asObservable();
35
+ }
36
+ get smartShift$() {
37
+ return this._smartShift.asObservable();
38
+ }
39
+ get intervalValue() {
40
+ return this._interval.getValue();
41
+ }
42
+ get anchorValue() {
43
+ return this._anchor.getValue();
44
+ }
45
+ get smartShiftValue() {
46
+ return this._smartShift.getValue();
47
+ }
48
+ get intervalChange() {
49
+ return this._intervalChange.asObservable();
50
+ }
51
+ /***************************************************************************
52
+ * *
53
+ * Public API *
54
+ * *
55
+ **************************************************************************/
56
+ setAnchor(anchor) {
57
+ this._anchor.next(anchor);
58
+ }
59
+ setExternalAnchor(TemporalDateTime) {
60
+ if (!TemporalDateTime) {
61
+ this.setAnchor(AnchorState.empty());
62
+ return;
63
+ }
64
+ this.setAnchor(AnchorState.createFromDateTime(TemporalDateTime));
65
+ }
66
+ setExternalInterval(interval) {
67
+ if (!interval) {
68
+ this.setInterval(new IntervalState(null, null));
69
+ return;
70
+ }
71
+ if (!interval) {
72
+ this.setInterval(new IntervalState(null, null));
73
+ return;
74
+ }
75
+ this.setInterval(interval);
76
+ }
77
+ setSmartShift(smartShift) {
78
+ this._smartShift.next(smartShift);
79
+ }
80
+ setInterval(interval) {
81
+ if (!this.isInitialized && !interval) {
82
+ return;
83
+ }
84
+ if (this._interval.getValue() &&
85
+ IntervalPickerUtil.isIntervalEquals(this._interval.getValue(), interval)) {
86
+ return;
87
+ }
88
+ const newInterval = interval ? IntervalPickerUtil.setMillisecondsToZero(interval) : null;
89
+ this._interval.next(newInterval);
90
+ this._intervalChange.next(newInterval);
91
+ }
92
+ }
93
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interval-picker-state-manager.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/elder-interval-picker/manager/interval-picker-state-manager.ts"],"names":[],"mappings":"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","sourcesContent":["import { LoggerFactory } from '@elderbyte/ts-logger'\nimport { Temporal } from '@js-temporal/polyfill'\nimport { BehaviorSubject, Observable, Subject } from 'rxjs'\nimport AnchorState from '../model/anchor-state'\nimport IntervalState from '../model/interval-state'\nimport SmartShiftState from '../model/smart-shift-state'\nimport IntervalPickerUtil from '../util/interval-picker-util'\n\nexport default class IntervalPickerStateManager {\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name)\n\n  private readonly _anchor = new BehaviorSubject<AnchorState>(AnchorState.empty())\n  private readonly _interval = new BehaviorSubject<IntervalState>(null)\n  private readonly _smartShift = new BehaviorSubject<SmartShiftState>(null)\n  private readonly _intervalChange = new Subject<IntervalState>()\n  public isInitialized = false\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor() {}\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get interval$(): Observable<IntervalState> {\n    return this._interval.asObservable()\n  }\n\n  public get anchor$(): Observable<AnchorState> {\n    return this._anchor.asObservable()\n  }\n\n  public get smartShift$(): Observable<SmartShiftState> {\n    return this._smartShift.asObservable()\n  }\n\n  public get intervalValue(): IntervalState {\n    return this._interval.getValue()\n  }\n\n  public get anchorValue(): AnchorState {\n    return this._anchor.getValue()\n  }\n\n  public get smartShiftValue(): SmartShiftState {\n    return this._smartShift.getValue()\n  }\n\n  public get intervalChange(): Observable<IntervalState> {\n    return this._intervalChange.asObservable()\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public setAnchor(anchor: AnchorState) {\n    this._anchor.next(anchor)\n  }\n\n  public setExternalAnchor(TemporalDateTime: Temporal.PlainDateTime) {\n    if (!TemporalDateTime) {\n      this.setAnchor(AnchorState.empty())\n      return\n    }\n    this.setAnchor(AnchorState.createFromDateTime(TemporalDateTime))\n  }\n\n  public setExternalInterval(interval: IntervalState) {\n    if (!interval) {\n      this.setInterval(new IntervalState(null, null))\n      return\n    }\n    if (!interval) {\n      this.setInterval(new IntervalState(null, null))\n      return\n    }\n    this.setInterval(interval)\n  }\n\n  public setSmartShift(smartShift: SmartShiftState) {\n    this._smartShift.next(smartShift)\n  }\n\n  public setInterval(interval: IntervalState): void {\n    if (!this.isInitialized && !interval) {\n      return\n    }\n\n    if (\n      this._interval.getValue() &&\n      IntervalPickerUtil.isIntervalEquals(this._interval.getValue(), interval)\n    ) {\n      return\n    }\n\n    const newInterval = interval ? IntervalPickerUtil.setMillisecondsToZero(interval) : null\n\n    this._interval.next(newInterval)\n    this._intervalChange.next(newInterval)\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n}\n"]}
@@ -0,0 +1,54 @@
1
+ import { Temporal } from '@js-temporal/polyfill';
2
+ import { TemporalUtil } from '../../../../common/time/temporal-util';
3
+ import IntervalPickerUtil from '../util/interval-picker-util';
4
+ export default class AnchorState {
5
+ constructor(fixedDate, fixedTime = Temporal.PlainTime.from('00:00'), referenceDateTime = IntervalPickerUtil.roundUpToSeconds(Temporal.Now.plainDateTimeISO())) {
6
+ this.fixedDate = fixedDate;
7
+ this.fixedTime = fixedTime;
8
+ this.referenceDateTime = referenceDateTime;
9
+ }
10
+ static createFromDateTime(dateTime) {
11
+ return new AnchorState(dateTime.toPlainDate(), dateTime.toPlainTime());
12
+ }
13
+ static createFromJsDate(date) {
14
+ const dateTime = TemporalUtil.getPlainDateTimeFromJSDate(date);
15
+ return new AnchorState(dateTime.toPlainDate(), dateTime.toPlainTime());
16
+ }
17
+ static empty() {
18
+ return new AnchorState(null);
19
+ }
20
+ withDate(date) {
21
+ return new AnchorState(date, this.fixedTime);
22
+ }
23
+ withTime(time) {
24
+ return new AnchorState(this.fixedDate, time);
25
+ }
26
+ withTimeMidnight() {
27
+ return new AnchorState(this.fixedDate, Temporal.PlainTime.from('00:00'));
28
+ }
29
+ withReferenceDateTimeNow() {
30
+ return new AnchorState(this.fixedDate, this.fixedTime, IntervalPickerUtil.roundUpToSeconds(Temporal.Now.plainDateTimeISO()));
31
+ }
32
+ get fixedDateTime() {
33
+ if (!this.fixedDate) {
34
+ return null;
35
+ }
36
+ return IntervalPickerUtil.createTemporalDateTime(this.fixedDate, this.fixedTime);
37
+ }
38
+ get isFixed() {
39
+ return this.fixedDate !== null;
40
+ }
41
+ get date() {
42
+ return this.fixedDate || this.referenceDateTime.toPlainDate();
43
+ }
44
+ get time() {
45
+ return this.fixedTime || this.referenceDateTime.toPlainTime();
46
+ }
47
+ get dateTime() {
48
+ return this.fixedDateTime || this.referenceDateTime;
49
+ }
50
+ get isTimeMidnight() {
51
+ return this.fixedTime.hour === 0 && this.fixedTime.minute === 0 && this.fixedTime.second === 0;
52
+ }
53
+ }
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5jaG9yLXN0YXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy90aW1lL2VsZGVyLWludGVydmFsLXBpY2tlci9tb2RlbC9hbmNob3Itc3RhdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLHVCQUF1QixDQUFBO0FBQ2hELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQTtBQUNwRSxPQUFPLGtCQUFrQixNQUFNLDhCQUE4QixDQUFBO0FBRTdELE1BQU0sQ0FBQyxPQUFPLE9BQU8sV0FBVztJQUM5QixZQUNrQixTQUE2QixFQUM3QixZQUFnQyxRQUFRLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsRUFDaEUsb0JBQTRDLGtCQUFrQixDQUFDLGdCQUFnQixDQUM3RixRQUFRLENBQUMsR0FBRyxDQUFDLGdCQUFnQixFQUFFLENBQ2hDO1FBSmUsY0FBUyxHQUFULFNBQVMsQ0FBb0I7UUFDN0IsY0FBUyxHQUFULFNBQVMsQ0FBdUQ7UUFDaEUsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUVoQztJQUNBLENBQUM7SUFFRyxNQUFNLENBQUMsa0JBQWtCLENBQUMsUUFBZ0M7UUFDL0QsT0FBTyxJQUFJLFdBQVcsQ0FBQyxRQUFRLENBQUMsV0FBVyxFQUFFLEVBQUUsUUFBUSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUE7SUFDeEUsQ0FBQztJQUVNLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFVO1FBQ3ZDLE1BQU0sUUFBUSxHQUFHLFlBQVksQ0FBQywwQkFBMEIsQ0FBQyxJQUFJLENBQUMsQ0FBQTtRQUM5RCxPQUFPLElBQUksV0FBVyxDQUFDLFFBQVEsQ0FBQyxXQUFXLEVBQUUsRUFBRSxRQUFRLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQTtJQUN4RSxDQUFDO0lBRU0sTUFBTSxDQUFDLEtBQUs7UUFDakIsT0FBTyxJQUFJLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUM5QixDQUFDO0lBRU0sUUFBUSxDQUFDLElBQXdCO1FBQ3RDLE9BQU8sSUFBSSxXQUFXLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQTtJQUM5QyxDQUFDO0lBRU0sUUFBUSxDQUFDLElBQXdCO1FBQ3RDLE9BQU8sSUFBSSxXQUFXLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsQ0FBQTtJQUM5QyxDQUFDO0lBRU0sZ0JBQWdCO1FBQ3JCLE9BQU8sSUFBSSxXQUFXLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxRQUFRLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFBO0lBQzFFLENBQUM7SUFFTSx3QkFBd0I7UUFDN0IsT0FBTyxJQUFJLFdBQVcsQ0FDcEIsSUFBSSxDQUFDLFNBQVMsRUFDZCxJQUFJLENBQUMsU0FBUyxFQUNkLGtCQUFrQixDQUFDLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxDQUNyRSxDQUFBO0lBQ0gsQ0FBQztJQUVELElBQVcsYUFBYTtRQUN0QixJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ3BCLE9BQU8sSUFBSSxDQUFBO1FBQ2IsQ0FBQztRQUNELE9BQU8sa0JBQWtCLENBQUMsc0JBQXNCLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUE7SUFDbEYsQ0FBQztJQUVELElBQVcsT0FBTztRQUNoQixPQUFPLElBQUksQ0FBQyxTQUFTLEtBQUssSUFBSSxDQUFBO0lBQ2hDLENBQUM7SUFFRCxJQUFXLElBQUk7UUFDYixPQUFPLElBQUksQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLGlCQUFpQixDQUFDLFdBQVcsRUFBRSxDQUFBO0lBQy9ELENBQUM7SUFFRCxJQUFXLElBQUk7UUFDYixPQUFPLElBQUksQ0FBQyxTQUFTLElBQUksSUFBSSxDQUFDLGlCQUFpQixDQUFDLFdBQVcsRUFBRSxDQUFBO0lBQy9ELENBQUM7SUFFRCxJQUFXLFFBQVE7UUFDakIsT0FBTyxJQUFJLENBQUMsYUFBYSxJQUFJLElBQUksQ0FBQyxpQkFBaUIsQ0FBQTtJQUNyRCxDQUFDO0lBRUQsSUFBVyxjQUFjO1FBQ3ZCLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLEtBQUssQ0FBQyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsTUFBTSxLQUFLLENBQUMsSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sS0FBSyxDQUFDLENBQUE7SUFDaEcsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVtcG9yYWwgfSBmcm9tICdAanMtdGVtcG9yYWwvcG9seWZpbGwnXG5pbXBvcnQgeyBUZW1wb3JhbFV0aWwgfSBmcm9tICcuLi8uLi8uLi8uLi9jb21tb24vdGltZS90ZW1wb3JhbC11dGlsJ1xuaW1wb3J0IEludGVydmFsUGlja2VyVXRpbCBmcm9tICcuLi91dGlsL2ludGVydmFsLXBpY2tlci11dGlsJ1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBBbmNob3JTdGF0ZSB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyByZWFkb25seSBmaXhlZERhdGU6IFRlbXBvcmFsLlBsYWluRGF0ZSxcbiAgICBwdWJsaWMgcmVhZG9ubHkgZml4ZWRUaW1lOiBUZW1wb3JhbC5QbGFpblRpbWUgPSBUZW1wb3JhbC5QbGFpblRpbWUuZnJvbSgnMDA6MDAnKSxcbiAgICBwdWJsaWMgcmVhZG9ubHkgcmVmZXJlbmNlRGF0ZVRpbWU6IFRlbXBvcmFsLlBsYWluRGF0ZVRpbWUgPSBJbnRlcnZhbFBpY2tlclV0aWwucm91bmRVcFRvU2Vjb25kcyhcbiAgICAgIFRlbXBvcmFsLk5vdy5wbGFpbkRhdGVUaW1lSVNPKClcbiAgICApXG4gICkge31cblxuICBwdWJsaWMgc3RhdGljIGNyZWF0ZUZyb21EYXRlVGltZShkYXRlVGltZTogVGVtcG9yYWwuUGxhaW5EYXRlVGltZSk6IEFuY2hvclN0YXRlIHtcbiAgICByZXR1cm4gbmV3IEFuY2hvclN0YXRlKGRhdGVUaW1lLnRvUGxhaW5EYXRlKCksIGRhdGVUaW1lLnRvUGxhaW5UaW1lKCkpXG4gIH1cblxuICBwdWJsaWMgc3RhdGljIGNyZWF0ZUZyb21Kc0RhdGUoZGF0ZTogRGF0ZSk6IEFuY2hvclN0YXRlIHtcbiAgICBjb25zdCBkYXRlVGltZSA9IFRlbXBvcmFsVXRpbC5nZXRQbGFpbkRhdGVUaW1lRnJvbUpTRGF0ZShkYXRlKVxuICAgIHJldHVybiBuZXcgQW5jaG9yU3RhdGUoZGF0ZVRpbWUudG9QbGFpbkRhdGUoKSwgZGF0ZVRpbWUudG9QbGFpblRpbWUoKSlcbiAgfVxuXG4gIHB1YmxpYyBzdGF0aWMgZW1wdHkoKTogQW5jaG9yU3RhdGUge1xuICAgIHJldHVybiBuZXcgQW5jaG9yU3RhdGUobnVsbClcbiAgfVxuXG4gIHB1YmxpYyB3aXRoRGF0ZShkYXRlOiBUZW1wb3JhbC5QbGFpbkRhdGUpOiBBbmNob3JTdGF0ZSB7XG4gICAgcmV0dXJuIG5ldyBBbmNob3JTdGF0ZShkYXRlLCB0aGlzLmZpeGVkVGltZSlcbiAgfVxuXG4gIHB1YmxpYyB3aXRoVGltZSh0aW1lOiBUZW1wb3JhbC5QbGFpblRpbWUpOiBBbmNob3JTdGF0ZSB7XG4gICAgcmV0dXJuIG5ldyBBbmNob3JTdGF0ZSh0aGlzLmZpeGVkRGF0ZSwgdGltZSlcbiAgfVxuXG4gIHB1YmxpYyB3aXRoVGltZU1pZG5pZ2h0KCk6IEFuY2hvclN0YXRlIHtcbiAgICByZXR1cm4gbmV3IEFuY2hvclN0YXRlKHRoaXMuZml4ZWREYXRlLCBUZW1wb3JhbC5QbGFpblRpbWUuZnJvbSgnMDA6MDAnKSlcbiAgfVxuXG4gIHB1YmxpYyB3aXRoUmVmZXJlbmNlRGF0ZVRpbWVOb3coKTogQW5jaG9yU3RhdGUge1xuICAgIHJldHVybiBuZXcgQW5jaG9yU3RhdGUoXG4gICAgICB0aGlzLmZpeGVkRGF0ZSxcbiAgICAgIHRoaXMuZml4ZWRUaW1lLFxuICAgICAgSW50ZXJ2YWxQaWNrZXJVdGlsLnJvdW5kVXBUb1NlY29uZHMoVGVtcG9yYWwuTm93LnBsYWluRGF0ZVRpbWVJU08oKSlcbiAgICApXG4gIH1cblxuICBwdWJsaWMgZ2V0IGZpeGVkRGF0ZVRpbWUoKTogVGVtcG9yYWwuUGxhaW5EYXRlVGltZSB7XG4gICAgaWYgKCF0aGlzLmZpeGVkRGF0ZSkge1xuICAgICAgcmV0dXJuIG51bGxcbiAgICB9XG4gICAgcmV0dXJuIEludGVydmFsUGlja2VyVXRpbC5jcmVhdGVUZW1wb3JhbERhdGVUaW1lKHRoaXMuZml4ZWREYXRlLCB0aGlzLmZpeGVkVGltZSlcbiAgfVxuXG4gIHB1YmxpYyBnZXQgaXNGaXhlZCgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5maXhlZERhdGUgIT09IG51bGxcbiAgfVxuXG4gIHB1YmxpYyBnZXQgZGF0ZSgpOiBUZW1wb3JhbC5QbGFpbkRhdGUge1xuICAgIHJldHVybiB0aGlzLmZpeGVkRGF0ZSB8fCB0aGlzLnJlZmVyZW5jZURhdGVUaW1lLnRvUGxhaW5EYXRlKClcbiAgfVxuXG4gIHB1YmxpYyBnZXQgdGltZSgpOiBUZW1wb3JhbC5QbGFpblRpbWUge1xuICAgIHJldHVybiB0aGlzLmZpeGVkVGltZSB8fCB0aGlzLnJlZmVyZW5jZURhdGVUaW1lLnRvUGxhaW5UaW1lKClcbiAgfVxuXG4gIHB1YmxpYyBnZXQgZGF0ZVRpbWUoKTogVGVtcG9yYWwuUGxhaW5EYXRlVGltZSB7XG4gICAgcmV0dXJuIHRoaXMuZml4ZWREYXRlVGltZSB8fCB0aGlzLnJlZmVyZW5jZURhdGVUaW1lXG4gIH1cblxuICBwdWJsaWMgZ2V0IGlzVGltZU1pZG5pZ2h0KCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLmZpeGVkVGltZS5ob3VyID09PSAwICYmIHRoaXMuZml4ZWRUaW1lLm1pbnV0ZSA9PT0gMCAmJiB0aGlzLmZpeGVkVGltZS5zZWNvbmQgPT09IDBcbiAgfVxufVxuIl19
@@ -0,0 +1,37 @@
1
+ import { Temporal } from '@js-temporal/polyfill';
2
+ import IntervalPickerUtil from '../util/interval-picker-util';
3
+ export default class IntervalState {
4
+ constructor(startDate, endDate, startTime, endTime) {
5
+ this.startDate = startDate;
6
+ this.endDate = endDate;
7
+ this.startTime = startTime;
8
+ this.endTime = endTime;
9
+ this.startTime = this.startTime || Temporal.PlainTime.from('00:00');
10
+ this.endTime = this.endTime || Temporal.PlainTime.from('00:00');
11
+ }
12
+ static createFromDateTimes(startDateTime, endDateTime) {
13
+ return new IntervalState(startDateTime.toPlainDate(), endDateTime.toPlainDate(), startDateTime.toPlainTime(), endDateTime.toPlainTime());
14
+ }
15
+ get startDateTime() {
16
+ return IntervalPickerUtil.createTemporalDateTime(this.startDate, this.startTime);
17
+ }
18
+ get endDateTime() {
19
+ return IntervalPickerUtil.createTemporalDateTime(this.endDate, this.endTime);
20
+ }
21
+ withStartDate(newStartDate) {
22
+ return new IntervalState(newStartDate, this.endDate, this.startTime, this.endTime);
23
+ }
24
+ withEndDate(newEndDate) {
25
+ return new IntervalState(this.startDate, newEndDate, this.startTime, this.endTime);
26
+ }
27
+ withStartTime(newStartTime) {
28
+ return new IntervalState(this.startDate, this.endDate, newStartTime, this.endTime);
29
+ }
30
+ withEndTime(newEndTime) {
31
+ return new IntervalState(this.startDate, this.endDate, this.startTime, newEndTime);
32
+ }
33
+ withTime(newStartTime, newEndTime) {
34
+ return new IntervalState(this.startDate, this.endDate, newStartTime, newEndTime);
35
+ }
36
+ }
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJ2YWwtc3RhdGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL3RpbWUvZWxkZXItaW50ZXJ2YWwtcGlja2VyL21vZGVsL2ludGVydmFsLXN0YXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQTtBQUNoRCxPQUFPLGtCQUFrQixNQUFNLDhCQUE4QixDQUFBO0FBRTdELE1BQU0sQ0FBQyxPQUFPLE9BQU8sYUFBYTtJQUNoQyxZQUNrQixTQUE2QixFQUM3QixPQUEyQixFQUMzQixTQUE4QixFQUM5QixPQUE0QjtRQUg1QixjQUFTLEdBQVQsU0FBUyxDQUFvQjtRQUM3QixZQUFPLEdBQVAsT0FBTyxDQUFvQjtRQUMzQixjQUFTLEdBQVQsU0FBUyxDQUFxQjtRQUM5QixZQUFPLEdBQVAsT0FBTyxDQUFxQjtRQUU1QyxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxTQUFTLElBQUksUUFBUSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUE7UUFDbkUsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsT0FBTyxJQUFJLFFBQVEsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFBO0lBQ2pFLENBQUM7SUFFRCxNQUFNLENBQUMsbUJBQW1CLENBQ3hCLGFBQXFDLEVBQ3JDLFdBQW1DO1FBRW5DLE9BQU8sSUFBSSxhQUFhLENBQ3RCLGFBQWEsQ0FBQyxXQUFXLEVBQUUsRUFDM0IsV0FBVyxDQUFDLFdBQVcsRUFBRSxFQUN6QixhQUFhLENBQUMsV0FBVyxFQUFFLEVBQzNCLFdBQVcsQ0FBQyxXQUFXLEVBQUUsQ0FDMUIsQ0FBQTtJQUNILENBQUM7SUFFRCxJQUFXLGFBQWE7UUFDdEIsT0FBTyxrQkFBa0IsQ0FBQyxzQkFBc0IsQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQTtJQUNsRixDQUFDO0lBRUQsSUFBVyxXQUFXO1FBQ3BCLE9BQU8sa0JBQWtCLENBQUMsc0JBQXNCLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUE7SUFDOUUsQ0FBQztJQUVNLGFBQWEsQ0FBQyxZQUFnQztRQUNuRCxPQUFPLElBQUksYUFBYSxDQUFDLFlBQVksRUFBRSxJQUFJLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFBO0lBQ3BGLENBQUM7SUFFTSxXQUFXLENBQUMsVUFBOEI7UUFDL0MsT0FBTyxJQUFJLGFBQWEsQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLFVBQVUsRUFBRSxJQUFJLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQTtJQUNwRixDQUFDO0lBRU0sYUFBYSxDQUFDLFlBQWdDO1FBQ25ELE9BQU8sSUFBSSxhQUFhLENBQUMsSUFBSSxDQUFDLFNBQVMsRUFBRSxJQUFJLENBQUMsT0FBTyxFQUFFLFlBQVksRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUE7SUFDcEYsQ0FBQztJQUVNLFdBQVcsQ0FBQyxVQUE4QjtRQUMvQyxPQUFPLElBQUksYUFBYSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsU0FBUyxFQUFFLFVBQVUsQ0FBQyxDQUFBO0lBQ3BGLENBQUM7SUFFTSxRQUFRLENBQUMsWUFBZ0MsRUFBRSxVQUE4QjtRQUM5RSxPQUFPLElBQUksYUFBYSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRSxZQUFZLEVBQUUsVUFBVSxDQUFDLENBQUE7SUFDbEYsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVtcG9yYWwgfSBmcm9tICdAanMtdGVtcG9yYWwvcG9seWZpbGwnXG5pbXBvcnQgSW50ZXJ2YWxQaWNrZXJVdGlsIGZyb20gJy4uL3V0aWwvaW50ZXJ2YWwtcGlja2VyLXV0aWwnXG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIEludGVydmFsU3RhdGUge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgcmVhZG9ubHkgc3RhcnREYXRlOiBUZW1wb3JhbC5QbGFpbkRhdGUsXG4gICAgcHVibGljIHJlYWRvbmx5IGVuZERhdGU6IFRlbXBvcmFsLlBsYWluRGF0ZSxcbiAgICBwdWJsaWMgcmVhZG9ubHkgc3RhcnRUaW1lPzogVGVtcG9yYWwuUGxhaW5UaW1lLFxuICAgIHB1YmxpYyByZWFkb25seSBlbmRUaW1lPzogVGVtcG9yYWwuUGxhaW5UaW1lXG4gICkge1xuICAgIHRoaXMuc3RhcnRUaW1lID0gdGhpcy5zdGFydFRpbWUgfHwgVGVtcG9yYWwuUGxhaW5UaW1lLmZyb20oJzAwOjAwJylcbiAgICB0aGlzLmVuZFRpbWUgPSB0aGlzLmVuZFRpbWUgfHwgVGVtcG9yYWwuUGxhaW5UaW1lLmZyb20oJzAwOjAwJylcbiAgfVxuXG4gIHN0YXRpYyBjcmVhdGVGcm9tRGF0ZVRpbWVzKFxuICAgIHN0YXJ0RGF0ZVRpbWU6IFRlbXBvcmFsLlBsYWluRGF0ZVRpbWUsXG4gICAgZW5kRGF0ZVRpbWU6IFRlbXBvcmFsLlBsYWluRGF0ZVRpbWVcbiAgKTogSW50ZXJ2YWxTdGF0ZSB7XG4gICAgcmV0dXJuIG5ldyBJbnRlcnZhbFN0YXRlKFxuICAgICAgc3RhcnREYXRlVGltZS50b1BsYWluRGF0ZSgpLFxuICAgICAgZW5kRGF0ZVRpbWUudG9QbGFpbkRhdGUoKSxcbiAgICAgIHN0YXJ0RGF0ZVRpbWUudG9QbGFpblRpbWUoKSxcbiAgICAgIGVuZERhdGVUaW1lLnRvUGxhaW5UaW1lKClcbiAgICApXG4gIH1cblxuICBwdWJsaWMgZ2V0IHN0YXJ0RGF0ZVRpbWUoKTogVGVtcG9yYWwuUGxhaW5EYXRlVGltZSB7XG4gICAgcmV0dXJuIEludGVydmFsUGlja2VyVXRpbC5jcmVhdGVUZW1wb3JhbERhdGVUaW1lKHRoaXMuc3RhcnREYXRlLCB0aGlzLnN0YXJ0VGltZSlcbiAgfVxuXG4gIHB1YmxpYyBnZXQgZW5kRGF0ZVRpbWUoKTogVGVtcG9yYWwuUGxhaW5EYXRlVGltZSB7XG4gICAgcmV0dXJuIEludGVydmFsUGlja2VyVXRpbC5jcmVhdGVUZW1wb3JhbERhdGVUaW1lKHRoaXMuZW5kRGF0ZSwgdGhpcy5lbmRUaW1lKVxuICB9XG5cbiAgcHVibGljIHdpdGhTdGFydERhdGUobmV3U3RhcnREYXRlOiBUZW1wb3JhbC5QbGFpbkRhdGUpOiBJbnRlcnZhbFN0YXRlIHtcbiAgICByZXR1cm4gbmV3IEludGVydmFsU3RhdGUobmV3U3RhcnREYXRlLCB0aGlzLmVuZERhdGUsIHRoaXMuc3RhcnRUaW1lLCB0aGlzLmVuZFRpbWUpXG4gIH1cblxuICBwdWJsaWMgd2l0aEVuZERhdGUobmV3RW5kRGF0ZTogVGVtcG9yYWwuUGxhaW5EYXRlKTogSW50ZXJ2YWxTdGF0ZSB7XG4gICAgcmV0dXJuIG5ldyBJbnRlcnZhbFN0YXRlKHRoaXMuc3RhcnREYXRlLCBuZXdFbmREYXRlLCB0aGlzLnN0YXJ0VGltZSwgdGhpcy5lbmRUaW1lKVxuICB9XG5cbiAgcHVibGljIHdpdGhTdGFydFRpbWUobmV3U3RhcnRUaW1lOiBUZW1wb3JhbC5QbGFpblRpbWUpOiBJbnRlcnZhbFN0YXRlIHtcbiAgICByZXR1cm4gbmV3IEludGVydmFsU3RhdGUodGhpcy5zdGFydERhdGUsIHRoaXMuZW5kRGF0ZSwgbmV3U3RhcnRUaW1lLCB0aGlzLmVuZFRpbWUpXG4gIH1cblxuICBwdWJsaWMgd2l0aEVuZFRpbWUobmV3RW5kVGltZTogVGVtcG9yYWwuUGxhaW5UaW1lKTogSW50ZXJ2YWxTdGF0ZSB7XG4gICAgcmV0dXJuIG5ldyBJbnRlcnZhbFN0YXRlKHRoaXMuc3RhcnREYXRlLCB0aGlzLmVuZERhdGUsIHRoaXMuc3RhcnRUaW1lLCBuZXdFbmRUaW1lKVxuICB9XG5cbiAgcHVibGljIHdpdGhUaW1lKG5ld1N0YXJ0VGltZTogVGVtcG9yYWwuUGxhaW5UaW1lLCBuZXdFbmRUaW1lOiBUZW1wb3JhbC5QbGFpblRpbWUpOiBJbnRlcnZhbFN0YXRlIHtcbiAgICByZXR1cm4gbmV3IEludGVydmFsU3RhdGUodGhpcy5zdGFydERhdGUsIHRoaXMuZW5kRGF0ZSwgbmV3U3RhcnRUaW1lLCBuZXdFbmRUaW1lKVxuICB9XG59XG4iXX0=
@@ -0,0 +1,10 @@
1
+ export default class SmartShiftState {
2
+ constructor(duration, mode) {
3
+ this.duration = duration;
4
+ this.mode = mode;
5
+ }
6
+ static empty() {
7
+ return new SmartShiftState(null, null);
8
+ }
9
+ }
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnQtc2hpZnQtc3RhdGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL3RpbWUvZWxkZXItaW50ZXJ2YWwtcGlja2VyL21vZGVsL3NtYXJ0LXNoaWZ0LXN0YXRlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE1BQU0sQ0FBQyxPQUFPLE9BQU8sZUFBZTtJQUNsQyxZQUNTLFFBQTJCLEVBQzNCLElBQW9CO1FBRHBCLGFBQVEsR0FBUixRQUFRLENBQW1CO1FBQzNCLFNBQUksR0FBSixJQUFJLENBQWdCO0lBQzFCLENBQUM7SUFFRyxNQUFNLENBQUMsS0FBSztRQUNqQixPQUFPLElBQUksZUFBZSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQTtJQUN4QyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUZW1wb3JhbCB9IGZyb20gJ0Bqcy10ZW1wb3JhbC9wb2x5ZmlsbCdcblxuZXhwb3J0IHR5cGUgU21hcnRTaGlmdE1vZGUgPSAnZGF5cycgfCAnd2Vla3MnIHwgJ21vbnRocycgfCAncXVhcnRlcnMnIHwgJ3llYXJzJyB8ICd0aW1lJ1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBTbWFydFNoaWZ0U3RhdGUge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgZHVyYXRpb246IFRlbXBvcmFsLkR1cmF0aW9uLFxuICAgIHB1YmxpYyBtb2RlOiBTbWFydFNoaWZ0TW9kZVxuICApIHt9XG5cbiAgcHVibGljIHN0YXRpYyBlbXB0eSgpOiBTbWFydFNoaWZ0U3RhdGUge1xuICAgIHJldHVybiBuZXcgU21hcnRTaGlmdFN0YXRlKG51bGwsIG51bGwpXG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,96 @@
1
+ import { computed } from '@angular/core';
2
+ import { toSignal } from '@angular/core/rxjs-interop';
3
+ import { DateRange } from '@angular/material/datepicker';
4
+ import { TemporalUtil } from '../../../../common/time/temporal-util';
5
+ import IntervalPickerUtil from '../util/interval-picker-util';
6
+ export default class IntervalPickerPresenter {
7
+ constructor(interval$, anchor$, smartShift$) {
8
+ this.startDateHtmlString = computed(() => {
9
+ return TemporalUtil.getHtmlDateString(this.intervalState()?.startDate);
10
+ });
11
+ this.endDateHtmlString = computed(() => {
12
+ return TemporalUtil.getHtmlDateString(this.intervalState()?.endDate);
13
+ });
14
+ this.anchorDateHtmlString = computed(() => {
15
+ return TemporalUtil.getHtmlDateString(this.anchorState()?.fixedDate);
16
+ });
17
+ this.startTimeHtmlString = computed(() => {
18
+ return TemporalUtil.getHtmlTimeStringFromPlainTime(this.intervalState()?.startTime);
19
+ });
20
+ this.endTimeHtmlString = computed(() => {
21
+ return TemporalUtil.getHtmlTimeStringFromPlainTime(this.intervalState()?.endTime);
22
+ });
23
+ this.anchorTimeHtmlString = computed(() => {
24
+ return TemporalUtil.getHtmlTimeStringFromPlainTime(this.anchorState()?.fixedTime);
25
+ });
26
+ this.isValidIntervalSet = computed(() => {
27
+ return IntervalPickerUtil.isIntervalWithStartAndEnd(this.intervalState());
28
+ });
29
+ this.deltaHumanReadable = computed(() => {
30
+ return IntervalPickerUtil.getDeltaHumanReadable(this.intervalState());
31
+ });
32
+ this.smartShiftMessage = computed(() => {
33
+ try {
34
+ return IntervalPickerUtil.getSmartShiftMessage(this.smartShiftState().mode, this.intervalState());
35
+ }
36
+ catch (e) {
37
+ return '-';
38
+ }
39
+ });
40
+ this.startDateTimeAsJSDate = computed(() => {
41
+ if (!this.intervalState()?.startDateTime) {
42
+ return null;
43
+ }
44
+ return TemporalUtil.getJSDateFromPlainDateTime(this.intervalState()?.startDateTime);
45
+ });
46
+ this.endDateTimeAsJSDate = computed(() => {
47
+ if (!this.intervalState()?.endDateTime) {
48
+ return null;
49
+ }
50
+ return TemporalUtil.getJSDateFromPlainDateTime(this.intervalState()?.endDateTime);
51
+ });
52
+ this.dateRangeForCalendar = computed(() => {
53
+ const start = this.startDateTimeAsJSDate();
54
+ const end = this.endDateTimeAsJSDate();
55
+ return new DateRange(start, end);
56
+ });
57
+ this.isStartTimeSetAndNotMidnight = computed(() => {
58
+ return IntervalPickerUtil.isTimeSetAndNotMidnight(this.intervalState()?.startTime);
59
+ });
60
+ this.isEndTimeSetAndNotMidnight = computed(() => {
61
+ return IntervalPickerUtil.isTimeSetAndNotMidnight(this.intervalState()?.endTime);
62
+ });
63
+ this.isFixedAnchorDateSet = computed(() => {
64
+ return this.anchorState().isFixed;
65
+ });
66
+ this.isAnchorTimeMidnight = computed(() => {
67
+ return this.anchorState().isTimeMidnight;
68
+ });
69
+ this.isAnchorMenuDisabled = computed(() => {
70
+ return !this.startDateHtmlString() && !this.endDateHtmlString() && !this.anchorState().isFixed;
71
+ });
72
+ this.calendarAnchorDateCssClassFn = (cellDate, view) => {
73
+ const calendarAnchorDateCssClassFnBody = (cellDate, view) => {
74
+ const anchorDate = this.anchorState()?.fixedDate;
75
+ if (!anchorDate) {
76
+ return '';
77
+ }
78
+ const date = TemporalUtil.getJSDateFromPlainDateTime(anchorDate);
79
+ if (!date) {
80
+ return '';
81
+ }
82
+ if (cellDate.getDate() === date.getDate() &&
83
+ cellDate.getMonth() === date.getMonth() &&
84
+ cellDate.getFullYear() === date.getFullYear()) {
85
+ return 'elder-custom-anchor-date';
86
+ }
87
+ return '';
88
+ };
89
+ return calendarAnchorDateCssClassFnBody(cellDate, view);
90
+ };
91
+ this.intervalState = toSignal(interval$);
92
+ this.anchorState = toSignal(anchor$);
93
+ this.smartShiftState = toSignal(smartShift$);
94
+ }
95
+ }
96
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interval-picker-presenter.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/time/elder-interval-picker/presenter/interval-picker-presenter.ts"],"names":[],"mappings":"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","sourcesContent":["import { computed, Signal } from '@angular/core'\nimport { toSignal } from '@angular/core/rxjs-interop'\nimport { DateRange, MatCalendarCellClassFunction } from '@angular/material/datepicker'\nimport { Observable } from 'rxjs'\nimport { TemporalUtil } from '../../../../common/time/temporal-util'\nimport AnchorState from '../model/anchor-state'\nimport IntervalState from '../model/interval-state'\nimport SmartShiftState from '../model/smart-shift-state'\nimport IntervalPickerUtil from '../util/interval-picker-util'\n\nexport default class IntervalPickerPresenter {\n  private readonly intervalState: Signal<IntervalState>\n  private readonly anchorState: Signal<AnchorState>\n  private readonly smartShiftState: Signal<SmartShiftState>\n\n  constructor(\n    interval$: Observable<IntervalState>,\n    anchor$: Observable<AnchorState>,\n    smartShift$: Observable<SmartShiftState>\n  ) {\n    this.intervalState = toSignal(interval$)\n    this.anchorState = toSignal(anchor$)\n    this.smartShiftState = toSignal(smartShift$)\n  }\n\n  public readonly startDateHtmlString = computed<string>(() => {\n    return TemporalUtil.getHtmlDateString(this.intervalState()?.startDate)\n  })\n\n  public readonly endDateHtmlString = computed<string>(() => {\n    return TemporalUtil.getHtmlDateString(this.intervalState()?.endDate)\n  })\n\n  public readonly anchorDateHtmlString = computed<string>(() => {\n    return TemporalUtil.getHtmlDateString(this.anchorState()?.fixedDate)\n  })\n\n  public readonly startTimeHtmlString = computed<string>(() => {\n    return TemporalUtil.getHtmlTimeStringFromPlainTime(this.intervalState()?.startTime)\n  })\n\n  public readonly endTimeHtmlString = computed<string>(() => {\n    return TemporalUtil.getHtmlTimeStringFromPlainTime(this.intervalState()?.endTime)\n  })\n\n  public readonly anchorTimeHtmlString = computed<string>(() => {\n    return TemporalUtil.getHtmlTimeStringFromPlainTime(this.anchorState()?.fixedTime)\n  })\n\n  public readonly isValidIntervalSet = computed<boolean>(() => {\n    return IntervalPickerUtil.isIntervalWithStartAndEnd(this.intervalState())\n  })\n\n  public readonly deltaHumanReadable = computed<string>(() => {\n    return IntervalPickerUtil.getDeltaHumanReadable(this.intervalState())\n  })\n\n  public readonly smartShiftMessage = computed<string>(() => {\n    try {\n      return IntervalPickerUtil.getSmartShiftMessage(\n        this.smartShiftState().mode,\n        this.intervalState()\n      )\n    } catch (e) {\n      return '-'\n    }\n  })\n\n  public readonly startDateTimeAsJSDate = computed<Date | null>(() => {\n    if (!this.intervalState()?.startDateTime) {\n      return null\n    }\n\n    return TemporalUtil.getJSDateFromPlainDateTime(this.intervalState()?.startDateTime)\n  })\n\n  public readonly endDateTimeAsJSDate = computed<Date | null>(() => {\n    if (!this.intervalState()?.endDateTime) {\n      return null\n    }\n\n    return TemporalUtil.getJSDateFromPlainDateTime(this.intervalState()?.endDateTime)\n  })\n\n  public readonly dateRangeForCalendar = computed<DateRange<Date>>(() => {\n    const start = this.startDateTimeAsJSDate()\n    const end = this.endDateTimeAsJSDate()\n    return new DateRange<Date>(start, end)\n  })\n\n  public readonly isStartTimeSetAndNotMidnight = computed<boolean>(() => {\n    return IntervalPickerUtil.isTimeSetAndNotMidnight(this.intervalState()?.startTime)\n  })\n\n  public readonly isEndTimeSetAndNotMidnight = computed<boolean>(() => {\n    return IntervalPickerUtil.isTimeSetAndNotMidnight(this.intervalState()?.endTime)\n  })\n\n  public readonly isFixedAnchorDateSet = computed<boolean>(() => {\n    return this.anchorState().isFixed\n  })\n\n  public readonly isAnchorTimeMidnight = computed<boolean>(() => {\n    return this.anchorState().isTimeMidnight\n  })\n\n  public readonly isAnchorMenuDisabled = computed<boolean>(() => {\n    return !this.startDateHtmlString() && !this.endDateHtmlString() && !this.anchorState().isFixed\n  })\n\n  public readonly calendarAnchorDateCssClassFn: MatCalendarCellClassFunction<Date> = (\n    cellDate: Date,\n    view: string\n  ): string => {\n    const calendarAnchorDateCssClassFnBody = (cellDate: Date, view: string): string => {\n      const anchorDate = this.anchorState()?.fixedDate\n\n      if (!anchorDate) {\n        return ''\n      }\n\n      const date = TemporalUtil.getJSDateFromPlainDateTime(anchorDate)\n\n      if (!date) {\n        return ''\n      }\n\n      if (\n        cellDate.getDate() === date.getDate() &&\n        cellDate.getMonth() === date.getMonth() &&\n        cellDate.getFullYear() === date.getFullYear()\n      ) {\n        return 'elder-custom-anchor-date'\n      }\n\n      return ''\n    }\n\n    return calendarAnchorDateCssClassFnBody(cellDate, view)\n  }\n}\n"]}