@elderbyte/ngx-starter 18.9.0 → 18.10.0

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 (22) hide show
  1. package/esm2022/lib/common/time/public_api.mjs +3 -1
  2. package/esm2022/lib/common/time/temporal-plain-date-interval.mjs +34 -0
  3. package/esm2022/lib/common/time/temporal-util.mjs +187 -0
  4. package/esm2022/lib/components/time/elder-interval-input/elder-interval-input.component.mjs +13 -4
  5. package/esm2022/lib/components/time/elder-interval-picker/elder-interval-picker-binding.directive.mjs +45 -0
  6. package/esm2022/lib/components/time/elder-interval-picker/elder-interval-picker-toggle/elder-interval-picker-toggle.component.mjs +203 -0
  7. package/esm2022/lib/components/time/elder-interval-picker/elder-interval-picker.component.mjs +269 -0
  8. package/esm2022/lib/components/time/elder-interval-picker/elder-interval-picker.service.mjs +703 -0
  9. package/esm2022/lib/components/time/elder-time.module.mjs +22 -2
  10. package/fesm2022/elderbyte-ngx-starter.mjs +1790 -375
  11. package/fesm2022/elderbyte-ngx-starter.mjs.map +1 -1
  12. package/lib/common/time/public_api.d.ts +2 -0
  13. package/lib/common/time/temporal-plain-date-interval.d.ts +15 -0
  14. package/lib/common/time/temporal-util.d.ts +34 -0
  15. package/lib/components/time/elder-interval-input/elder-interval-input.component.d.ts +4 -1
  16. package/lib/components/time/elder-interval-picker/elder-interval-picker-binding.directive.d.ts +30 -0
  17. package/lib/components/time/elder-interval-picker/elder-interval-picker-toggle/elder-interval-picker-toggle.component.d.ts +48 -0
  18. package/lib/components/time/elder-interval-picker/elder-interval-picker.component.d.ts +73 -0
  19. package/lib/components/time/elder-interval-picker/elder-interval-picker.service.d.ts +130 -0
  20. package/lib/components/time/elder-time.module.d.ts +8 -2
  21. package/package.json +3 -2
  22. package/src/lib/components/time/elder-interval-picker/elder-interval-picker.component.scss +36 -0
@@ -0,0 +1,203 @@
1
+ import { ChangeDetectionStrategy, Component, input, Input, 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 '../../../../components/overlays/elder-overlay-origin.directive';
7
+ import { ElderOverlayTriggerDirective } from '../../../../components/overlays/elder-overlay-trigger.directive';
8
+ import { ElderOverlayComponent } from '../../../../components/overlays/elder-overlay.component';
9
+ import { ElderDialogPanelComponent } from '../../../../components/panels/elder-dialog-panel/elder-dialog-panel.component';
10
+ import { ElderIntervalInputComponent, } from '../../../../components/time/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
+ /***************************************************************************
16
+ * *
17
+ * Fields *
18
+ * *
19
+ **************************************************************************/
20
+ this.log = LoggerFactory.getLogger(this.constructor.name);
21
+ this.isEmittingOnChange = true;
22
+ this.showAnchor = false;
23
+ this.isAnchorReadOnly = false;
24
+ this.isDisabledInput = false;
25
+ this.isResultTextVisible = true;
26
+ this.isHelpTextsVisible = false;
27
+ this.isOverlayCenteredToScreen = false;
28
+ this.inputAnchorDateTime = input(null);
29
+ this.inputInterval = null;
30
+ this.anchorDateTime = null;
31
+ this.intervalInputMode = 'date-range'; // will be overwritten by connected element after view init
32
+ this.isButtonDisabled = false;
33
+ }
34
+ /***************************************************************************
35
+ * *
36
+ * Life Cycle *
37
+ * *
38
+ **************************************************************************/
39
+ ngOnInit() { }
40
+ ngOnDestroy() {
41
+ this.inputIntervalElSubscription.unsubscribe();
42
+ }
43
+ ngAfterViewInit() {
44
+ if (this.intervalInputElement.disabled) {
45
+ this.isButtonDisabled = true;
46
+ }
47
+ if (this.isDisabledInput) {
48
+ this.isButtonDisabled = true;
49
+ }
50
+ this.inputIntervalElSubscription =
51
+ this.intervalInputElement.valueUpdated.subscribe((interval) => {
52
+ this.pullIntervalData();
53
+ });
54
+ this.intervalInputMode = this.intervalInputElement.mode;
55
+ if (this.intervalInputElement?.value) {
56
+ this.inputInterval = this.intervalInputElement.interval;
57
+ }
58
+ this.pullIntervalData();
59
+ }
60
+ /***************************************************************************
61
+ * *
62
+ * Public API *
63
+ * *
64
+ **************************************************************************/
65
+ handleOverlayAttachedChange(attached) {
66
+ if (this.isEmittingOnChange) {
67
+ return;
68
+ }
69
+ this.pullIntervalData();
70
+ }
71
+ updateIntervalInputElement(interval) {
72
+ this.intervalInputElement.value = interval;
73
+ }
74
+ pullIntervalData() {
75
+ if (!this.intervalInputElement) {
76
+ this.connectedIntervalPicker.svc.pullInputInterval();
77
+ return;
78
+ }
79
+ this.inputInterval = this.intervalInputElement.value;
80
+ this.connectedIntervalPicker.svc.setDateTimesFromElderInterval(this.inputInterval);
81
+ }
82
+ handleIntervalPickerDateChange(interval) {
83
+ this.inputInterval = interval;
84
+ if (this.intervalInputElement) {
85
+ this.updateIntervalInputElement(this.inputInterval);
86
+ }
87
+ }
88
+ registerInputComponent(inputComponent) {
89
+ this.intervalInputElement = inputComponent;
90
+ }
91
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ElderIntervalPickerToggleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
92
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.2", type: ElderIntervalPickerToggleComponent, isStandalone: true, selector: "elder-interval-picker-toggle", inputs: { intervalInputElement: { classPropertyName: "intervalInputElement", publicName: "intervalInputElement", isSignal: false, isRequired: false, transformFunction: null }, isEmittingOnChange: { classPropertyName: "isEmittingOnChange", publicName: "isEmittingOnChange", isSignal: false, isRequired: false, transformFunction: null }, showAnchor: { classPropertyName: "showAnchor", publicName: "showAnchor", isSignal: false, isRequired: false, transformFunction: null }, isAnchorReadOnly: { classPropertyName: "isAnchorReadOnly", publicName: "isAnchorReadOnly", isSignal: false, isRequired: false, transformFunction: null }, isDisabledInput: { classPropertyName: "isDisabledInput", publicName: "isDisabledInput", isSignal: false, isRequired: false, transformFunction: null }, isResultTextVisible: { classPropertyName: "isResultTextVisible", publicName: "isResultTextVisible", isSignal: false, isRequired: false, transformFunction: null }, isHelpTextsVisible: { classPropertyName: "isHelpTextsVisible", publicName: "isHelpTextsVisible", isSignal: false, isRequired: false, transformFunction: null }, isOverlayCenteredToScreen: { classPropertyName: "isOverlayCenteredToScreen", publicName: "isOverlayCenteredToScreen", isSignal: false, isRequired: false, transformFunction: null }, inputAnchorDateTime: { classPropertyName: "inputAnchorDateTime", publicName: "inputAnchorDateTime", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "connectedIntervalPicker", first: true, predicate: ["connectedIntervalPicker"], descendants: true }], ngImport: i0, template: `
93
+ <span style="padding-right: 8px">
94
+ <button
95
+ mat-icon-button
96
+ [elderOverlayOrigin]="dateIntervalOverlay"
97
+ [elderOverlayTrigger]="dateIntervalOverlay"
98
+ [disabled]="isButtonDisabled"
99
+ class="elder-control-icon-button mat-datepicker-toggle"
100
+ >
101
+ <mat-icon>date_range</mat-icon>
102
+ </button>
103
+ </span>
104
+
105
+ <elder-overlay
106
+ #dateIntervalOverlay
107
+ (attachedChange)="handleOverlayAttachedChange($event)"
108
+ >
109
+ <elder-dialog-panel>
110
+ <div class="pb-md pt-xs">
111
+ <elder-interval-picker
112
+ #connectedIntervalPicker
113
+ [intervalInputMode]="intervalInputMode"
114
+ [isEmittingOnChange]="isEmittingOnChange"
115
+ [inputInterval]="inputInterval"
116
+ (dateChange)="handleIntervalPickerDateChange($event)"
117
+ [showAnchor]="showAnchor"
118
+ [inputAnchorDateTime]="inputAnchorDateTime()"
119
+ [isAnchorReadOnly]="isAnchorReadOnly"
120
+ [isResultTextVisible]="isResultTextVisible"
121
+ [isHelpTextsVisible]="isHelpTextsVisible"
122
+ ></elder-interval-picker>
123
+ </div>
124
+ </elder-dialog-panel>
125
+ </elder-overlay>
126
+ `, isInline: true, dependencies: [{ kind: "component", type: ElderIntervalPickerComponent, selector: "elder-interval-picker", inputs: ["isEmittingOnChange", "intervalInputMode", "showAnchor", "isAnchorReadOnly", "isResultTextVisible", "isHelpTextsVisible", "inputInterval", "inputAnchorDateTime"], 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 }); }
127
+ }
128
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ElderIntervalPickerToggleComponent, decorators: [{
129
+ type: Component,
130
+ args: [{
131
+ selector: 'elder-interval-picker-toggle',
132
+ standalone: true,
133
+ imports: [
134
+ ElderIntervalPickerComponent,
135
+ ElderIntervalInputComponent,
136
+ MatFormField,
137
+ MatLabel,
138
+ ElderOverlayComponent,
139
+ ElderDialogPanelComponent,
140
+ MatIcon,
141
+ MatIconButton,
142
+ MatSuffix,
143
+ ElderOverlayTriggerDirective,
144
+ ElderOverlayOriginDirective,
145
+ ],
146
+ template: `
147
+ <span style="padding-right: 8px">
148
+ <button
149
+ mat-icon-button
150
+ [elderOverlayOrigin]="dateIntervalOverlay"
151
+ [elderOverlayTrigger]="dateIntervalOverlay"
152
+ [disabled]="isButtonDisabled"
153
+ class="elder-control-icon-button mat-datepicker-toggle"
154
+ >
155
+ <mat-icon>date_range</mat-icon>
156
+ </button>
157
+ </span>
158
+
159
+ <elder-overlay
160
+ #dateIntervalOverlay
161
+ (attachedChange)="handleOverlayAttachedChange($event)"
162
+ >
163
+ <elder-dialog-panel>
164
+ <div class="pb-md pt-xs">
165
+ <elder-interval-picker
166
+ #connectedIntervalPicker
167
+ [intervalInputMode]="intervalInputMode"
168
+ [isEmittingOnChange]="isEmittingOnChange"
169
+ [inputInterval]="inputInterval"
170
+ (dateChange)="handleIntervalPickerDateChange($event)"
171
+ [showAnchor]="showAnchor"
172
+ [inputAnchorDateTime]="inputAnchorDateTime()"
173
+ [isAnchorReadOnly]="isAnchorReadOnly"
174
+ [isResultTextVisible]="isResultTextVisible"
175
+ [isHelpTextsVisible]="isHelpTextsVisible"
176
+ ></elder-interval-picker>
177
+ </div>
178
+ </elder-dialog-panel>
179
+ </elder-overlay>
180
+ `,
181
+ changeDetection: ChangeDetectionStrategy.OnPush,
182
+ }]
183
+ }], propDecorators: { connectedIntervalPicker: [{
184
+ type: ViewChild,
185
+ args: ['connectedIntervalPicker']
186
+ }], intervalInputElement: [{
187
+ type: Input
188
+ }], isEmittingOnChange: [{
189
+ type: Input
190
+ }], showAnchor: [{
191
+ type: Input
192
+ }], isAnchorReadOnly: [{
193
+ type: Input
194
+ }], isDisabledInput: [{
195
+ type: Input
196
+ }], isResultTextVisible: [{
197
+ type: Input
198
+ }], isHelpTextsVisible: [{
199
+ type: Input
200
+ }], isOverlayCenteredToScreen: [{
201
+ type: Input
202
+ }] } });
203
+ //# 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  ChangeDetectionStrategy,\n  Component,\n  input,\n  Input,\n  ViewChild\n} from '@angular/core';\nimport { MatIconButton } from '@angular/material/button';\nimport {\n  MatFormField,\n  MatLabel,\n  MatSuffix,\n} 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]=\"isButtonDisabled\"\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\n      #dateIntervalOverlay\n      (attachedChange)=\"handleOverlayAttachedChange($event)\"\n    >\n      <elder-dialog-panel>\n        <div class=\"pb-md pt-xs\">\n          <elder-interval-picker\n            #connectedIntervalPicker\n            [intervalInputMode]=\"intervalInputMode\"\n            [isEmittingOnChange]=\"isEmittingOnChange\"\n            [inputInterval]=\"inputInterval\"\n            (dateChange)=\"handleIntervalPickerDateChange($event)\"\n            [showAnchor]=\"showAnchor\"\n            [inputAnchorDateTime]=\"inputAnchorDateTime()\"\n            [isAnchorReadOnly]=\"isAnchorReadOnly\"\n            [isResultTextVisible]=\"isResultTextVisible\"\n            [isHelpTextsVisible]=\"isHelpTextsVisible\"\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  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  @ViewChild('connectedIntervalPicker')\n  connectedIntervalPicker!: ElderIntervalPickerComponent;\n\n  @Input() intervalInputElement?: ElderIntervalInputComponent;\n  @Input() isEmittingOnChange: boolean = true;\n  @Input() showAnchor: boolean = false;\n  @Input() isAnchorReadOnly = false;\n  @Input() isDisabledInput = false;\n  @Input() isResultTextVisible = true;\n  @Input() isHelpTextsVisible = false;\n  @Input() isOverlayCenteredToScreen = false;\n\n  readonly inputAnchorDateTime = input<Date>(null);\n\n  inputInterval: Interval = null;\n  anchorDateTime: Date = null;\n  intervalInputMode: IntervalInputMode = 'date-range'; // will be overwritten by connected element after view init\n  isButtonDisabled = false;\n\n  inputIntervalElSubscription: Subscription;\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  ngOnInit(): void {}\n\n  ngOnDestroy(): void {\n    this.inputIntervalElSubscription.unsubscribe();\n  }\n\n  ngAfterViewInit(): void {\n    if (this.intervalInputElement.disabled) {\n      this.isButtonDisabled = true;\n    }\n\n    if (this.isDisabledInput) {\n      this.isButtonDisabled = true;\n    }\n\n    this.inputIntervalElSubscription =\n      this.intervalInputElement.valueUpdated.subscribe((interval) => {\n        this.pullIntervalData();\n      });\n    this.intervalInputMode = this.intervalInputElement.mode;\n\n    if (this.intervalInputElement?.value) {\n      this.inputInterval = this.intervalInputElement.interval;\n    }\n\n    this.pullIntervalData();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  handleOverlayAttachedChange(attached: boolean): void {\n    if (this.isEmittingOnChange) {\n      return;\n    }\n    this.pullIntervalData();\n  }\n\n  updateIntervalInputElement(interval: Interval): void {\n    this.intervalInputElement.value = interval;\n  }\n\n  pullIntervalData(): void {\n    if (!this.intervalInputElement) {\n      this.connectedIntervalPicker.svc.pullInputInterval();\n      return;\n    }\n\n    this.inputInterval = this.intervalInputElement!.value as Interval;\n    this.connectedIntervalPicker.svc.setDateTimesFromElderInterval(\n      this.inputInterval\n    );\n  }\n\n  handleIntervalPickerDateChange(interval: Interval): void {\n    this.inputInterval = interval;\n\n    if (this.intervalInputElement) {\n      this.updateIntervalInputElement(this.inputInterval);\n    }\n  }\n\n  registerInputComponent(inputComponent: ElderIntervalInputComponent) {\n    this.intervalInputElement = inputComponent;\n  }\n}\n"]}