@energinet/watt 3.0.29 → 3.0.30

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.
@@ -1,28 +1,9 @@
1
- //#region License
2
- /**
3
- * @license
4
- * Copyright 2020 Energinet DataHub A/S
5
- *
6
- * Licensed under the Apache License, Version 2.0 (the "License2");
7
- * you may not use this file except in compliance with the License.
8
- * You may obtain a copy of the License at
9
- *
10
- * http://www.apache.org/licenses/LICENSE-2.0
11
- *
12
- * Unless required by applicable law or agreed to in writing, software
13
- * distributed under the License is distributed on an "AS IS" BASIS,
14
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
- * See the License for the specific language governing permissions and
16
- * limitations under the License.
17
- */
18
- //#endregion
19
- import { FormControl } from '@angular/forms';
20
- import { Component, EventEmitter, HostBinding, Injectable, Input, Output, ViewEncapsulation, inject, } from '@angular/core';
1
+ import { input, model, output, inject, Component, Injectable, ViewEncapsulation, } from '@angular/core';
21
2
  import { DateAdapter } from '@angular/material/core';
22
- import { DateRange, DefaultMatCalendarRangeStrategy, MAT_DATE_RANGE_SELECTION_STRATEGY, MatDatepickerModule, } from '@angular/material/datepicker';
23
- import { dayjs, WattDatePipe } from '@energinet/watt/core/date';
24
- import { WattButtonComponent } from '@energinet/watt/button';
3
+ import { DateRange, MatDatepickerModule, MAT_DATE_RANGE_SELECTION_STRATEGY, DefaultMatCalendarRangeStrategy, } from '@angular/material/datepicker';
25
4
  import { WattFieldComponent } from '@energinet/watt/field';
5
+ import { WattButtonComponent } from '@energinet/watt/button';
6
+ import { dayjs, WattDatePipe } from '@energinet/watt/core/date';
26
7
  import { WattDatepickerIntlService } from '@energinet/watt/picker/datepicker';
27
8
  import { WattMenuChipComponent } from './watt-menu-chip.component';
28
9
  import * as i0 from "@angular/core";
@@ -57,26 +38,25 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.3", ngImpor
57
38
  }]
58
39
  }] });
59
40
  export class WattDateRangeChipComponent {
60
- disabled = false;
61
- label;
62
- value;
63
- formControl;
64
- placeholder = true;
65
- showActions = false;
66
- customSelectionStrategy;
67
- get hasPlaceholderClass() {
68
- return this.placeholder;
69
- }
70
- selectionChange = new EventEmitter();
71
- _dateAdapter = inject(DateAdapter);
72
41
  intl = inject(WattDatepickerIntlService);
42
+ dateAdapter = inject(DateAdapter);
43
+ disabled = model(false, ...(ngDevMode ? [{ debugName: "disabled" }] : []));
44
+ label = input(...(ngDevMode ? [undefined, { debugName: "label" }] : []));
45
+ value = model(null, ...(ngDevMode ? [{ debugName: "value" }] : []));
46
+ formControl = input.required(...(ngDevMode ? [{ debugName: "formControl" }] : []));
47
+ placeholder = input(true, ...(ngDevMode ? [{ debugName: "placeholder" }] : []));
48
+ showActions = input(false, ...(ngDevMode ? [{ debugName: "showActions" }] : []));
49
+ customSelectionStrategy = input(...(ngDevMode ? [undefined, { debugName: "customSelectionStrategy" }] : []));
50
+ selectionChange = output();
73
51
  selectionStrategy() {
74
- const strategy = new WattDateRangeSelectionStrategy(this._dateAdapter);
75
- strategy.setCustomSelectionStrategy(this.customSelectionStrategy);
52
+ const customStrategy = this.customSelectionStrategy();
53
+ const strategy = new WattDateRangeSelectionStrategy(this.dateAdapter);
54
+ if (customStrategy)
55
+ strategy.setCustomSelectionStrategy(customStrategy);
76
56
  return strategy;
77
57
  }
78
58
  clearInput() {
79
- this.value = undefined;
59
+ this.value.set(null);
80
60
  this.selectionChange.emit(null);
81
61
  }
82
62
  onSelectionChange(value) {
@@ -84,8 +64,17 @@ export class WattDateRangeChipComponent {
84
64
  this.selectionChange.emit(value);
85
65
  }
86
66
  }
67
+ updateStartDate(startDate) {
68
+ this.value.set({ start: startDate, end: null });
69
+ }
70
+ updateEndDate(endDate) {
71
+ const dateRange = this.value();
72
+ if (dateRange) {
73
+ this.value.set({ start: dateRange.start, end: endDate });
74
+ }
75
+ }
87
76
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.1.3", ngImport: i0, type: WattDateRangeChipComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
88
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.1.3", type: WattDateRangeChipComponent, isStandalone: true, selector: "watt-date-range-chip", inputs: { disabled: "disabled", label: "label", value: "value", formControl: "formControl", placeholder: "placeholder", showActions: "showActions", customSelectionStrategy: "customSelectionStrategy" }, outputs: { selectionChange: "selectionChange" }, host: { properties: { "class.has-placeholder": "this.hasPlaceholderClass" } }, providers: [
77
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.1.3", type: WattDateRangeChipComponent, isStandalone: true, selector: "watt-date-range-chip", inputs: { disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, formControl: { classPropertyName: "formControl", publicName: "formControl", isSignal: true, isRequired: true, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, showActions: { classPropertyName: "showActions", publicName: "showActions", isSignal: true, isRequired: false, transformFunction: null }, customSelectionStrategy: { classPropertyName: "customSelectionStrategy", publicName: "customSelectionStrategy", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { disabled: "disabledChange", value: "valueChange", selectionChange: "selectionChange" }, host: { properties: { "class.has-placeholder": "placeholder()" } }, providers: [
89
78
  {
90
79
  provide: MAT_DATE_RANGE_SELECTION_STRATEGY,
91
80
  useFactory: (comp) => comp.selectionStrategy(),
@@ -93,7 +82,7 @@ export class WattDateRangeChipComponent {
93
82
  },
94
83
  ], ngImport: i0, template: `
95
84
  <mat-date-range-picker #picker>
96
- @if (showActions) {
85
+ @if (showActions()) {
97
86
  <mat-date-range-picker-actions>
98
87
  <watt-button variant="text" (click)="clearInput()" icon="remove">{{
99
88
  intl.clear
@@ -103,11 +92,11 @@ export class WattDateRangeChipComponent {
103
92
  }
104
93
  </mat-date-range-picker>
105
94
 
106
- <watt-field [control]="formControl" [chipMode]="true">
95
+ <watt-field [control]="formControl()" [chipMode]="true">
107
96
  <watt-menu-chip
108
97
  hasPopup="dialog"
109
- [disabled]="disabled"
110
- [selected]="value?.start && value?.end ? true : false"
98
+ [disabled]="disabled()"
99
+ [selected]="value()?.start && value()?.end ? true : false"
111
100
  [opened]="picker.opened"
112
101
  (toggle)="picker.open()"
113
102
  >
@@ -122,40 +111,40 @@ export class WattDateRangeChipComponent {
122
111
  matStartDate
123
112
  tabindex="-1"
124
113
  role="none"
125
- [value]="value?.start"
126
- (dateChange)="value = input.value!"
127
- (dateChange)="showActions && onSelectionChange($event.value ? input.value! : null)"
114
+ [value]="value() ? value()?.start : null"
115
+ (dateChange)="updateStartDate($event.value!)"
116
+ (dateChange)="showActions() && onSelectionChange($event.value ? input.value! : null)"
128
117
  />
129
118
  <input
130
119
  type="text"
131
120
  matEndDate
132
121
  tabindex="-1"
133
122
  role="none"
134
- [value]="value?.end"
135
- (dateChange)="value = input.value!"
123
+ [value]="value() ? value()?.end : null"
124
+ (dateChange)="updateEndDate($event.value!)"
136
125
  (dateChange)="onSelectionChange($event.value ? input.value! : null)"
137
126
  />
138
127
  </mat-date-range-input>
139
128
  <ng-content />
140
- @if (value?.start && value?.end) {
129
+ @if (value()?.start && value()?.end) {
141
130
  <span class="value">
142
- {{ value | wattDate }}
131
+ {{ value() | wattDate }}
143
132
  </span>
144
133
  }
145
134
  </watt-menu-chip>
146
135
  <ng-content ngProjectAs="watt-field-hint" select="watt-field-hint" />
147
136
  <ng-content ngProjectAs="watt-field-error" select="watt-field-error" />
148
137
  </watt-field>
149
- `, isInline: true, styles: ["watt-date-range-chip mat-date-range-input{top:0;bottom:0;height:auto;visibility:hidden}watt-date-range-chip.has-placeholder .value:before{content:\":\"}watt-date-range-chip watt-field label .watt-field-wrapper{background-color:transparent}\n"], dependencies: [{ kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i1.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i1.MatStartDate, selector: "input[matStartDate]", outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i1.MatEndDate, selector: "input[matEndDate]", outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i1.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "component", type: i1.MatDatepickerActions, selector: "mat-datepicker-actions, mat-date-range-picker-actions" }, { kind: "directive", type: i1.MatDatepickerApply, selector: "[matDatepickerApply], [matDateRangePickerApply]" }, { kind: "component", type: WattMenuChipComponent, selector: "watt-menu-chip", inputs: ["opened", "disabled", "name", "value", "selected", "hasPopup"], outputs: ["toggle"] }, { kind: "component", type: WattFieldComponent, selector: "watt-field", inputs: ["control", "label", "id", "chipMode", "tooltip", "placeholder", "anchorName"] }, { kind: "component", type: WattButtonComponent, selector: "watt-button", inputs: ["icon", "variant", "size", "type", "formId", "disabled", "loading"] }, { kind: "pipe", type: WattDatePipe, name: "wattDate" }], encapsulation: i0.ViewEncapsulation.None });
138
+ `, isInline: true, styles: ["watt-date-range-chip mat-date-range-input{top:0;bottom:0;height:auto;visibility:hidden}watt-date-range-chip.has-placeholder .value:before{content:\":\"}watt-date-range-chip watt-field label .watt-field-wrapper{background-color:transparent}\n"], dependencies: [{ kind: "ngmodule", type: MatDatepickerModule }, { kind: "component", type: i1.MatDateRangeInput, selector: "mat-date-range-input", inputs: ["rangePicker", "required", "dateFilter", "min", "max", "disabled", "separator", "comparisonStart", "comparisonEnd"], exportAs: ["matDateRangeInput"] }, { kind: "directive", type: i1.MatStartDate, selector: "input[matStartDate]", outputs: ["dateChange", "dateInput"] }, { kind: "directive", type: i1.MatEndDate, selector: "input[matEndDate]", outputs: ["dateChange", "dateInput"] }, { kind: "component", type: i1.MatDateRangePicker, selector: "mat-date-range-picker", exportAs: ["matDateRangePicker"] }, { kind: "component", type: i1.MatDatepickerActions, selector: "mat-datepicker-actions, mat-date-range-picker-actions" }, { kind: "directive", type: i1.MatDatepickerApply, selector: "[matDatepickerApply], [matDateRangePickerApply]" }, { kind: "component", type: WattFieldComponent, selector: "watt-field", inputs: ["control", "label", "id", "chipMode", "tooltip", "placeholder", "anchorName"] }, { kind: "component", type: WattButtonComponent, selector: "watt-button", inputs: ["icon", "variant", "size", "type", "formId", "disabled", "loading"] }, { kind: "component", type: WattMenuChipComponent, selector: "watt-menu-chip", inputs: ["opened", "disabled", "name", "value", "selected", "hasPopup"], outputs: ["toggle"] }, { kind: "pipe", type: WattDatePipe, name: "wattDate" }], encapsulation: i0.ViewEncapsulation.None });
150
139
  }
151
140
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.3", ngImport: i0, type: WattDateRangeChipComponent, decorators: [{
152
141
  type: Component,
153
142
  args: [{ imports: [
154
143
  MatDatepickerModule,
155
- WattMenuChipComponent,
156
144
  WattDatePipe,
157
145
  WattFieldComponent,
158
146
  WattButtonComponent,
147
+ WattMenuChipComponent,
159
148
  ], providers: [
160
149
  {
161
150
  provide: MAT_DATE_RANGE_SELECTION_STRATEGY,
@@ -164,7 +153,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.3", ngImpor
164
153
  },
165
154
  ], selector: 'watt-date-range-chip', encapsulation: ViewEncapsulation.None, template: `
166
155
  <mat-date-range-picker #picker>
167
- @if (showActions) {
156
+ @if (showActions()) {
168
157
  <mat-date-range-picker-actions>
169
158
  <watt-button variant="text" (click)="clearInput()" icon="remove">{{
170
159
  intl.clear
@@ -174,11 +163,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.3", ngImpor
174
163
  }
175
164
  </mat-date-range-picker>
176
165
 
177
- <watt-field [control]="formControl" [chipMode]="true">
166
+ <watt-field [control]="formControl()" [chipMode]="true">
178
167
  <watt-menu-chip
179
168
  hasPopup="dialog"
180
- [disabled]="disabled"
181
- [selected]="value?.start && value?.end ? true : false"
169
+ [disabled]="disabled()"
170
+ [selected]="value()?.start && value()?.end ? true : false"
182
171
  [opened]="picker.opened"
183
172
  (toggle)="picker.open()"
184
173
  >
@@ -193,50 +182,32 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.3", ngImpor
193
182
  matStartDate
194
183
  tabindex="-1"
195
184
  role="none"
196
- [value]="value?.start"
197
- (dateChange)="value = input.value!"
198
- (dateChange)="showActions && onSelectionChange($event.value ? input.value! : null)"
185
+ [value]="value() ? value()?.start : null"
186
+ (dateChange)="updateStartDate($event.value!)"
187
+ (dateChange)="showActions() && onSelectionChange($event.value ? input.value! : null)"
199
188
  />
200
189
  <input
201
190
  type="text"
202
191
  matEndDate
203
192
  tabindex="-1"
204
193
  role="none"
205
- [value]="value?.end"
206
- (dateChange)="value = input.value!"
194
+ [value]="value() ? value()?.end : null"
195
+ (dateChange)="updateEndDate($event.value!)"
207
196
  (dateChange)="onSelectionChange($event.value ? input.value! : null)"
208
197
  />
209
198
  </mat-date-range-input>
210
199
  <ng-content />
211
- @if (value?.start && value?.end) {
200
+ @if (value()?.start && value()?.end) {
212
201
  <span class="value">
213
- {{ value | wattDate }}
202
+ {{ value() | wattDate }}
214
203
  </span>
215
204
  }
216
205
  </watt-menu-chip>
217
206
  <ng-content ngProjectAs="watt-field-hint" select="watt-field-hint" />
218
207
  <ng-content ngProjectAs="watt-field-error" select="watt-field-error" />
219
208
  </watt-field>
220
- `, styles: ["watt-date-range-chip mat-date-range-input{top:0;bottom:0;height:auto;visibility:hidden}watt-date-range-chip.has-placeholder .value:before{content:\":\"}watt-date-range-chip watt-field label .watt-field-wrapper{background-color:transparent}\n"] }]
221
- }], propDecorators: { disabled: [{
222
- type: Input
223
- }], label: [{
224
- type: Input
225
- }], value: [{
226
- type: Input
227
- }], formControl: [{
228
- type: Input,
229
- args: [{ required: true }]
230
- }], placeholder: [{
231
- type: Input
232
- }], showActions: [{
233
- type: Input
234
- }], customSelectionStrategy: [{
235
- type: Input
236
- }], hasPlaceholderClass: [{
237
- type: HostBinding,
238
- args: ['class.has-placeholder']
239
- }], selectionChange: [{
240
- type: Output
241
- }] } });
242
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-date-range-chip.component.js","sourceRoot":"","sources":["../../../../libs/watt/package/chip/watt-date-range-chip.component.ts"],"names":[],"mappings":"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","sourcesContent":["//#region License\n/**\n * @license\n * Copyright 2020 Energinet DataHub A/S\n *\n * Licensed under the Apache License, Version 2.0 (the \"License2\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n//#endregion\nimport { FormControl } from '@angular/forms';\nimport {\n  Component,\n  EventEmitter,\n  HostBinding,\n  Injectable,\n  Input,\n  Output,\n  ViewEncapsulation,\n  inject,\n} from '@angular/core';\nimport { DateAdapter } from '@angular/material/core';\n\nimport {\n  DateRange,\n  DefaultMatCalendarRangeStrategy,\n  MAT_DATE_RANGE_SELECTION_STRATEGY,\n  MatDatepickerModule,\n} from '@angular/material/datepicker';\nimport { dayjs, WattDatePipe, WattRange } from '@energinet/watt/core/date';\nimport { WattButtonComponent } from '@energinet/watt/button';\nimport { WattFieldComponent } from '@energinet/watt/field';\nimport { WattDatepickerIntlService } from '@energinet/watt/picker/datepicker';\n\nimport { WattMenuChipComponent } from './watt-menu-chip.component';\n\ntype customSelectionStrategy = (date: Date | null) => DateRange<Date>;\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class WattDateRangeSelectionStrategy extends DefaultMatCalendarRangeStrategy<Date> {\n  private customSelectionStrategy!: customSelectionStrategy;\n\n  setCustomSelectionStrategy(strategy: customSelectionStrategy) {\n    this.customSelectionStrategy = strategy;\n  }\n\n  override selectionFinished(date: Date, currentRange: DateRange<Date>): DateRange<Date> {\n    let range: DateRange<Date> = super.selectionFinished(date, currentRange);\n\n    if (this.customSelectionStrategy) {\n      range = this.customSelectionStrategy(date);\n    }\n\n    return range.end ? new DateRange(range.start, dayjs(range.end).endOf('day').toDate()) : range;\n  }\n\n  override createPreview(activeDate: Date | null, currentRange: DateRange<Date>): DateRange<Date> {\n    if (!this.customSelectionStrategy) {\n      return super.createPreview(activeDate, currentRange);\n    } else {\n      return this.customSelectionStrategy(activeDate);\n    }\n  }\n}\n\n@Component({\n  imports: [\n    MatDatepickerModule,\n    WattMenuChipComponent,\n    WattDatePipe,\n    WattFieldComponent,\n    WattButtonComponent,\n  ],\n  providers: [\n    {\n      provide: MAT_DATE_RANGE_SELECTION_STRATEGY,\n      useFactory: (comp: WattDateRangeChipComponent) => comp.selectionStrategy(),\n      deps: [WattDateRangeChipComponent],\n    },\n  ],\n  selector: 'watt-date-range-chip',\n  encapsulation: ViewEncapsulation.None,\n  styles: [\n    `\n      watt-date-range-chip {\n        mat-date-range-input {\n          top: 0;\n          bottom: 0;\n          height: auto;\n          visibility: hidden;\n        }\n\n        &.has-placeholder .value::before {\n          content: ':';\n        }\n\n        watt-field label .watt-field-wrapper {\n          background-color: transparent;\n        }\n      }\n    `,\n  ],\n  template: `\n    <mat-date-range-picker #picker>\n      @if (showActions) {\n        <mat-date-range-picker-actions>\n          <watt-button variant=\"text\" (click)=\"clearInput()\" icon=\"remove\">{{\n            intl.clear\n          }}</watt-button>\n          <watt-button variant=\"primary\" matDateRangePickerApply>{{ intl.select }}</watt-button>\n        </mat-date-range-picker-actions>\n      }\n    </mat-date-range-picker>\n\n    <watt-field [control]=\"formControl\" [chipMode]=\"true\">\n      <watt-menu-chip\n        hasPopup=\"dialog\"\n        [disabled]=\"disabled\"\n        [selected]=\"value?.start && value?.end ? true : false\"\n        [opened]=\"picker.opened\"\n        (toggle)=\"picker.open()\"\n      >\n        <mat-date-range-input\n          #input\n          class=\"cdk-visually-hidden\"\n          separator=\"\"\n          [rangePicker]=\"picker\"\n        >\n          <input\n            type=\"text\"\n            matStartDate\n            tabindex=\"-1\"\n            role=\"none\"\n            [value]=\"value?.start\"\n            (dateChange)=\"value = input.value!\"\n            (dateChange)=\"showActions && onSelectionChange($event.value ? input.value! : null)\"\n          />\n          <input\n            type=\"text\"\n            matEndDate\n            tabindex=\"-1\"\n            role=\"none\"\n            [value]=\"value?.end\"\n            (dateChange)=\"value = input.value!\"\n            (dateChange)=\"onSelectionChange($event.value ? input.value! : null)\"\n          />\n        </mat-date-range-input>\n        <ng-content />\n        @if (value?.start && value?.end) {\n          <span class=\"value\">\n            {{ value | wattDate }}\n          </span>\n        }\n      </watt-menu-chip>\n      <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n      <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n    </watt-field>\n  `,\n})\nexport class WattDateRangeChipComponent {\n  @Input() disabled = false;\n  @Input() label?: string;\n  @Input() value?: WattRange<Date>;\n  @Input({ required: true }) formControl!: FormControl;\n  @Input() placeholder = true;\n  @Input() showActions = false;\n  @Input() customSelectionStrategy!: (date: Date | null) => DateRange<Date>;\n\n  @HostBinding('class.has-placeholder')\n  get hasPlaceholderClass(): boolean {\n    return this.placeholder;\n  }\n\n  @Output() selectionChange = new EventEmitter<WattRange<Date> | null>();\n\n  private _dateAdapter = inject(DateAdapter);\n  protected intl = inject(WattDatepickerIntlService);\n\n  selectionStrategy() {\n    const strategy = new WattDateRangeSelectionStrategy(this._dateAdapter);\n    strategy.setCustomSelectionStrategy(this.customSelectionStrategy);\n    return strategy;\n  }\n\n  clearInput(): void {\n    this.value = undefined;\n    this.selectionChange.emit(null);\n  }\n\n  onSelectionChange(value: WattRange<Date> | null): void {\n    if (value === null || (value?.start && value?.end)) {\n      this.selectionChange.emit(value);\n    }\n  }\n}\n"]}
209
+ `, host: {
210
+ '[class.has-placeholder]': 'placeholder()',
211
+ }, styles: ["watt-date-range-chip mat-date-range-input{top:0;bottom:0;height:auto;visibility:hidden}watt-date-range-chip.has-placeholder .value:before{content:\":\"}watt-date-range-chip watt-field label .watt-field-wrapper{background-color:transparent}\n"] }]
212
+ }] });
213
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-date-range-chip.component.js","sourceRoot":"","sources":["../../../../libs/watt/package/chip/watt-date-range-chip.component.ts"],"names":[],"mappings":"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","sourcesContent":["//#region License\n/**\n * @license\n * Copyright 2020 Energinet DataHub A/S\n *\n * Licensed under the Apache License, Version 2.0 (the \"License2\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n//#endregion\nimport { FormControl } from '@angular/forms';\nimport {\n  input,\n  model,\n  output,\n  inject,\n  Component,\n  Injectable,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { DateAdapter } from '@angular/material/core';\n\nimport {\n  DateRange,\n  MatDatepickerModule,\n  MAT_DATE_RANGE_SELECTION_STRATEGY,\n  DefaultMatCalendarRangeStrategy,\n} from '@angular/material/datepicker';\n\nimport { WattFieldComponent } from '@energinet/watt/field';\nimport { WattButtonComponent } from '@energinet/watt/button';\nimport { dayjs, WattDatePipe, WattRange } from '@energinet/watt/core/date';\nimport { WattDatepickerIntlService } from '@energinet/watt/picker/datepicker';\n\nimport { WattMenuChipComponent } from './watt-menu-chip.component';\n\ntype customSelectionStrategy = (date: Date | null) => DateRange<Date>;\n@Injectable({\n  providedIn: 'root',\n})\nexport class WattDateRangeSelectionStrategy extends DefaultMatCalendarRangeStrategy<Date> {\n  private customSelectionStrategy!: customSelectionStrategy;\n\n  setCustomSelectionStrategy(strategy: customSelectionStrategy) {\n    this.customSelectionStrategy = strategy;\n  }\n\n  override selectionFinished(date: Date, currentRange: DateRange<Date>): DateRange<Date> {\n    let range: DateRange<Date> = super.selectionFinished(date, currentRange);\n\n    if (this.customSelectionStrategy) {\n      range = this.customSelectionStrategy(date);\n    }\n\n    return range.end ? new DateRange(range.start, dayjs(range.end).endOf('day').toDate()) : range;\n  }\n\n  override createPreview(activeDate: Date | null, currentRange: DateRange<Date>): DateRange<Date> {\n    if (!this.customSelectionStrategy) {\n      return super.createPreview(activeDate, currentRange);\n    } else {\n      return this.customSelectionStrategy(activeDate);\n    }\n  }\n}\n\n@Component({\n  imports: [\n    MatDatepickerModule,\n    WattDatePipe,\n    WattFieldComponent,\n    WattButtonComponent,\n    WattMenuChipComponent,\n  ],\n  providers: [\n    {\n      provide: MAT_DATE_RANGE_SELECTION_STRATEGY,\n      useFactory: (comp: WattDateRangeChipComponent) => comp.selectionStrategy(),\n      deps: [WattDateRangeChipComponent],\n    },\n  ],\n  selector: 'watt-date-range-chip',\n  encapsulation: ViewEncapsulation.None,\n  styles: [\n    `\n      watt-date-range-chip {\n        mat-date-range-input {\n          top: 0;\n          bottom: 0;\n          height: auto;\n          visibility: hidden;\n        }\n\n        &.has-placeholder .value::before {\n          content: ':';\n        }\n\n        watt-field label .watt-field-wrapper {\n          background-color: transparent;\n        }\n      }\n    `,\n  ],\n  template: `\n    <mat-date-range-picker #picker>\n      @if (showActions()) {\n        <mat-date-range-picker-actions>\n          <watt-button variant=\"text\" (click)=\"clearInput()\" icon=\"remove\">{{\n            intl.clear\n          }}</watt-button>\n          <watt-button variant=\"primary\" matDateRangePickerApply>{{ intl.select }}</watt-button>\n        </mat-date-range-picker-actions>\n      }\n    </mat-date-range-picker>\n\n    <watt-field [control]=\"formControl()\" [chipMode]=\"true\">\n      <watt-menu-chip\n        hasPopup=\"dialog\"\n        [disabled]=\"disabled()\"\n        [selected]=\"value()?.start && value()?.end ? true : false\"\n        [opened]=\"picker.opened\"\n        (toggle)=\"picker.open()\"\n      >\n        <mat-date-range-input\n          #input\n          class=\"cdk-visually-hidden\"\n          separator=\"\"\n          [rangePicker]=\"picker\"\n        >\n          <input\n            type=\"text\"\n            matStartDate\n            tabindex=\"-1\"\n            role=\"none\"\n            [value]=\"value() ? value()?.start : null\"\n            (dateChange)=\"updateStartDate($event.value!)\"\n            (dateChange)=\"showActions() && onSelectionChange($event.value ? input.value! : null)\"\n          />\n          <input\n            type=\"text\"\n            matEndDate\n            tabindex=\"-1\"\n            role=\"none\"\n            [value]=\"value() ? value()?.end : null\"\n            (dateChange)=\"updateEndDate($event.value!)\"\n            (dateChange)=\"onSelectionChange($event.value ? input.value! : null)\"\n          />\n        </mat-date-range-input>\n        <ng-content />\n        @if (value()?.start && value()?.end) {\n          <span class=\"value\">\n            {{ value() | wattDate }}\n          </span>\n        }\n      </watt-menu-chip>\n      <ng-content ngProjectAs=\"watt-field-hint\" select=\"watt-field-hint\" />\n      <ng-content ngProjectAs=\"watt-field-error\" select=\"watt-field-error\" />\n    </watt-field>\n  `,\n  host: {\n    '[class.has-placeholder]': 'placeholder()',\n  },\n})\nexport class WattDateRangeChipComponent {\n  protected intl = inject(WattDatepickerIntlService);\n  private dateAdapter = inject(DateAdapter);\n\n  disabled = model(false);\n  label = input<string>();\n  value = model<WattRange<Date> | null>(null);\n  formControl = input.required<FormControl>();\n  placeholder = input(true);\n  showActions = input(false);\n  customSelectionStrategy = input<(date: Date | null) => DateRange<Date>>();\n\n  selectionChange = output<WattRange<Date> | null>();\n\n  selectionStrategy() {\n    const customStrategy = this.customSelectionStrategy();\n    const strategy = new WattDateRangeSelectionStrategy(this.dateAdapter);\n    if (customStrategy) strategy.setCustomSelectionStrategy(customStrategy);\n    return strategy;\n  }\n\n  clearInput() {\n    this.value.set(null);\n    this.selectionChange.emit(null);\n  }\n\n  onSelectionChange(value: WattRange<Date> | null) {\n    if (value === null || (value?.start && value?.end)) {\n      this.selectionChange.emit(value);\n    }\n  }\n\n  updateStartDate(startDate: Date) {\n    this.value.set({ start: startDate, end: null });\n  }\n\n  updateEndDate(endDate: Date | null) {\n    const dateRange = this.value();\n    if (dateRange) {\n      this.value.set({ start: dateRange.start, end: endDate });\n    }\n  }\n}\n"]}
@@ -16,7 +16,7 @@
16
16
  * limitations under the License.
17
17
  */
18
18
  //#endregion
19
- import { Component, EventEmitter, Input, Output } from '@angular/core';
19
+ import { Component, input, model, output } from '@angular/core';
20
20
  import { WattChipComponent } from './watt-chip.component';
21
21
  import * as i0 from "@angular/core";
22
22
  function isFirstRender() {
@@ -29,28 +29,28 @@ function isFirstRender() {
29
29
  };
30
30
  }
31
31
  export class WattFilterChipComponent {
32
- selected = false;
33
- disabled = false;
34
- name;
35
- value;
36
- choice;
37
- selectionChange = new EventEmitter();
32
+ selected = input(false, ...(ngDevMode ? [{ debugName: "selected" }] : []));
33
+ disabled = model(false, ...(ngDevMode ? [{ debugName: "disabled" }] : []));
34
+ name = input(...(ngDevMode ? [undefined, { debugName: "name" }] : []));
35
+ value = model(...(ngDevMode ? [undefined, { debugName: "value" }] : []));
36
+ choice = input(...(ngDevMode ? [undefined, { debugName: "choice" }] : []));
37
+ selectionChange = output();
38
38
  isFirstRender = isFirstRender();
39
39
  onChange(input) {
40
- const value = this.choice !== undefined ? input.value : input.checked;
40
+ const value = this.choice() !== undefined ? input.value : input.checked;
41
41
  this.selectionChange.emit(value);
42
42
  }
43
43
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.1.3", ngImport: i0, type: WattFilterChipComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
44
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "20.1.3", type: WattFilterChipComponent, isStandalone: true, selector: "watt-filter-chip", inputs: { selected: "selected", disabled: "disabled", name: "name", value: "value", choice: "choice" }, outputs: { selectionChange: "selectionChange" }, ngImport: i0, template: `
45
- <watt-chip [disabled]="disabled" [selected]="isFirstRender() ? selected : input.checked">
44
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "20.1.3", type: WattFilterChipComponent, isStandalone: true, selector: "watt-filter-chip", inputs: { selected: { classPropertyName: "selected", publicName: "selected", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, name: { classPropertyName: "name", publicName: "name", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, choice: { classPropertyName: "choice", publicName: "choice", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { disabled: "disabledChange", value: "valueChange", selectionChange: "selectionChange" }, ngImport: i0, template: `
45
+ <watt-chip [disabled]="disabled()" [selected]="isFirstRender() ? selected() : input.checked">
46
46
  <input
47
47
  #input
48
48
  class="cdk-visually-hidden"
49
- [type]="choice === undefined ? 'checkbox' : 'radio'"
50
- [name]="name"
51
- [value]="value"
52
- [checked]="selected"
53
- [disabled]="disabled"
49
+ [type]="choice() === undefined ? 'checkbox' : 'radio'"
50
+ [name]="name()"
51
+ [value]="value()"
52
+ [checked]="selected()"
53
+ [disabled]="disabled()"
54
54
  (change)="onChange(input)"
55
55
  />
56
56
  <ng-content />
@@ -63,32 +63,20 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.1.3", ngImpor
63
63
  imports: [WattChipComponent],
64
64
  selector: 'watt-filter-chip',
65
65
  template: `
66
- <watt-chip [disabled]="disabled" [selected]="isFirstRender() ? selected : input.checked">
66
+ <watt-chip [disabled]="disabled()" [selected]="isFirstRender() ? selected() : input.checked">
67
67
  <input
68
68
  #input
69
69
  class="cdk-visually-hidden"
70
- [type]="choice === undefined ? 'checkbox' : 'radio'"
71
- [name]="name"
72
- [value]="value"
73
- [checked]="selected"
74
- [disabled]="disabled"
70
+ [type]="choice() === undefined ? 'checkbox' : 'radio'"
71
+ [name]="name()"
72
+ [value]="value()"
73
+ [checked]="selected()"
74
+ [disabled]="disabled()"
75
75
  (change)="onChange(input)"
76
76
  />
77
77
  <ng-content />
78
78
  </watt-chip>
79
79
  `,
80
80
  }]
81
- }], propDecorators: { selected: [{
82
- type: Input
83
- }], disabled: [{
84
- type: Input
85
- }], name: [{
86
- type: Input
87
- }], value: [{
88
- type: Input
89
- }], choice: [{
90
- type: Input
91
- }], selectionChange: [{
92
- type: Output
93
- }] } });
94
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2F0dC1maWx0ZXItY2hpcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL3dhdHQvcGFja2FnZS9jaGlwL3dhdHQtZmlsdGVyLWNoaXAuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGlCQUFpQjtBQUNqQjs7Ozs7Ozs7Ozs7Ozs7O0dBZUc7QUFDSCxZQUFZO0FBQ1osT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV2RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7QUFFMUQsU0FBUyxhQUFhO0lBQ3BCLElBQUksYUFBYSxHQUFHLElBQUksQ0FBQztJQUN6QixPQUFPLEdBQUcsRUFBRTtRQUNWLElBQUksQ0FBQyxhQUFhO1lBQUUsT0FBTyxLQUFLLENBQUM7UUFDakMsYUFBYSxHQUFHLEtBQUssQ0FBQztRQUN0QixPQUFPLElBQUksQ0FBQztJQUNkLENBQUMsQ0FBQztBQUNKLENBQUM7QUFxQkQsTUFBTSxPQUFPLHVCQUF1QjtJQUN6QixRQUFRLEdBQUcsS0FBSyxDQUFDO0lBQ2pCLFFBQVEsR0FBRyxLQUFLLENBQUM7SUFDakIsSUFBSSxDQUFVO0lBQ2QsS0FBSyxDQUFLO0lBQ1YsTUFBTSxDQUFVO0lBQ2YsZUFBZSxHQUFHLElBQUksWUFBWSxFQUFLLENBQUM7SUFDbEQsYUFBYSxHQUFHLGFBQWEsRUFBRSxDQUFDO0lBRWhDLFFBQVEsQ0FBQyxLQUF1QjtRQUM5QixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsTUFBTSxLQUFLLFNBQVMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQztRQUN0RSxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxLQUFVLENBQUMsQ0FBQztJQUN4QyxDQUFDO3VHQVpVLHVCQUF1QjsyRkFBdkIsdUJBQXVCLHFPQWhCeEI7Ozs7Ozs7Ozs7Ozs7O0dBY1QsNERBaEJTLGlCQUFpQjs7MkZBa0JoQix1QkFBdUI7a0JBbkJuQyxTQUFTO21CQUFDO29CQUNULE9BQU8sRUFBRSxDQUFDLGlCQUFpQixDQUFDO29CQUM1QixRQUFRLEVBQUUsa0JBQWtCO29CQUM1QixRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7O0dBY1Q7aUJBQ0Y7OEJBRVUsUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csTUFBTTtzQkFBZCxLQUFLO2dCQUNJLGVBQWU7c0JBQXhCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyIvLyNyZWdpb24gTGljZW5zZVxuLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IDIwMjAgRW5lcmdpbmV0IERhdGFIdWIgQS9TXG4gKlxuICogTGljZW5zZWQgdW5kZXIgdGhlIEFwYWNoZSBMaWNlbnNlLCBWZXJzaW9uIDIuMCAodGhlIFwiTGljZW5zZTJcIik7XG4gKiB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuXG4gKiBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2YgdGhlIExpY2Vuc2UgYXRcbiAqXG4gKiAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4gKlxuICogVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuICogZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIEJBU0lTLFxuICogV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuXG4gKiBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kXG4gKiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAqL1xuLy8jZW5kcmVnaW9uXG5pbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBXYXR0Q2hpcENvbXBvbmVudCB9IGZyb20gJy4vd2F0dC1jaGlwLmNvbXBvbmVudCc7XG5cbmZ1bmN0aW9uIGlzRmlyc3RSZW5kZXIoKSB7XG4gIGxldCBpc0ZpcnN0UmVuZGVyID0gdHJ1ZTtcbiAgcmV0dXJuICgpID0+IHtcbiAgICBpZiAoIWlzRmlyc3RSZW5kZXIpIHJldHVybiBmYWxzZTtcbiAgICBpc0ZpcnN0UmVuZGVyID0gZmFsc2U7XG4gICAgcmV0dXJuIHRydWU7XG4gIH07XG59XG5cbkBDb21wb25lbnQoe1xuICBpbXBvcnRzOiBbV2F0dENoaXBDb21wb25lbnRdLFxuICBzZWxlY3RvcjogJ3dhdHQtZmlsdGVyLWNoaXAnLFxuICB0ZW1wbGF0ZTogYFxuICAgIDx3YXR0LWNoaXAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCIgW3NlbGVjdGVkXT1cImlzRmlyc3RSZW5kZXIoKSA/IHNlbGVjdGVkIDogaW5wdXQuY2hlY2tlZFwiPlxuICAgICAgPGlucHV0XG4gICAgICAgICNpbnB1dFxuICAgICAgICBjbGFzcz1cImNkay12aXN1YWxseS1oaWRkZW5cIlxuICAgICAgICBbdHlwZV09XCJjaG9pY2UgPT09IHVuZGVmaW5lZCA/ICdjaGVja2JveCcgOiAncmFkaW8nXCJcbiAgICAgICAgW25hbWVdPVwibmFtZVwiXG4gICAgICAgIFt2YWx1ZV09XCJ2YWx1ZVwiXG4gICAgICAgIFtjaGVja2VkXT1cInNlbGVjdGVkXCJcbiAgICAgICAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgICAgICAgKGNoYW5nZSk9XCJvbkNoYW5nZShpbnB1dClcIlxuICAgICAgLz5cbiAgICAgIDxuZy1jb250ZW50IC8+XG4gICAgPC93YXR0LWNoaXA+XG4gIGAsXG59KVxuZXhwb3J0IGNsYXNzIFdhdHRGaWx0ZXJDaGlwQ29tcG9uZW50PFQgPSBzdHJpbmc+IHtcbiAgQElucHV0KCkgc2VsZWN0ZWQgPSBmYWxzZTtcbiAgQElucHV0KCkgZGlzYWJsZWQgPSBmYWxzZTtcbiAgQElucHV0KCkgbmFtZT86IHN0cmluZztcbiAgQElucHV0KCkgdmFsdWU/OiBUO1xuICBASW5wdXQoKSBjaG9pY2U/OiBzdHJpbmc7XG4gIEBPdXRwdXQoKSBzZWxlY3Rpb25DaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPFQ+KCk7XG4gIGlzRmlyc3RSZW5kZXIgPSBpc0ZpcnN0UmVuZGVyKCk7XG5cbiAgb25DaGFuZ2UoaW5wdXQ6IEhUTUxJbnB1dEVsZW1lbnQpOiB2b2lkIHtcbiAgICBjb25zdCB2YWx1ZSA9IHRoaXMuY2hvaWNlICE9PSB1bmRlZmluZWQgPyBpbnB1dC52YWx1ZSA6IGlucHV0LmNoZWNrZWQ7XG4gICAgdGhpcy5zZWxlY3Rpb25DaGFuZ2UuZW1pdCh2YWx1ZSBhcyBUKTtcbiAgfVxufVxuIl19
81
+ }] });
82
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2F0dC1maWx0ZXItY2hpcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL3dhdHQvcGFja2FnZS9jaGlwL3dhdHQtZmlsdGVyLWNoaXAuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGlCQUFpQjtBQUNqQjs7Ozs7Ozs7Ozs7Ozs7O0dBZUc7QUFDSCxZQUFZO0FBQ1osT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVoRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7QUFFMUQsU0FBUyxhQUFhO0lBQ3BCLElBQUksYUFBYSxHQUFHLElBQUksQ0FBQztJQUN6QixPQUFPLEdBQUcsRUFBRTtRQUNWLElBQUksQ0FBQyxhQUFhO1lBQUUsT0FBTyxLQUFLLENBQUM7UUFDakMsYUFBYSxHQUFHLEtBQUssQ0FBQztRQUN0QixPQUFPLElBQUksQ0FBQztJQUNkLENBQUMsQ0FBQztBQUNKLENBQUM7QUFxQkQsTUFBTSxPQUFPLHVCQUF1QjtJQUNsQyxRQUFRLEdBQUcsS0FBSyxDQUFDLEtBQUssb0RBQUMsQ0FBQztJQUN4QixRQUFRLEdBQUcsS0FBSyxDQUFDLEtBQUssb0RBQUMsQ0FBQztJQUN4QixJQUFJLEdBQUcsS0FBSywwREFBVSxDQUFDO0lBQ3ZCLEtBQUssR0FBRyxLQUFLLDJEQUFLLENBQUM7SUFDbkIsTUFBTSxHQUFHLEtBQUssNERBQVUsQ0FBQztJQUN6QixlQUFlLEdBQUcsTUFBTSxFQUFLLENBQUM7SUFDOUIsYUFBYSxHQUFHLGFBQWEsRUFBRSxDQUFDO0lBRWhDLFFBQVEsQ0FBQyxLQUF1QjtRQUM5QixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLEtBQUssU0FBUyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDO1FBQ3hFLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLEtBQVUsQ0FBQyxDQUFDO0lBQ3hDLENBQUM7dUdBWlUsdUJBQXVCOzJGQUF2Qix1QkFBdUIscXlCQWhCeEI7Ozs7Ozs7Ozs7Ozs7O0dBY1QsNERBaEJTLGlCQUFpQjs7MkZBa0JoQix1QkFBdUI7a0JBbkJuQyxTQUFTO21CQUFDO29CQUNULE9BQU8sRUFBRSxDQUFDLGlCQUFpQixDQUFDO29CQUM1QixRQUFRLEVBQUUsa0JBQWtCO29CQUM1QixRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7O0dBY1Q7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvLyNyZWdpb24gTGljZW5zZVxuLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IDIwMjAgRW5lcmdpbmV0IERhdGFIdWIgQS9TXG4gKlxuICogTGljZW5zZWQgdW5kZXIgdGhlIEFwYWNoZSBMaWNlbnNlLCBWZXJzaW9uIDIuMCAodGhlIFwiTGljZW5zZTJcIik7XG4gKiB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlIHdpdGggdGhlIExpY2Vuc2UuXG4gKiBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2YgdGhlIExpY2Vuc2UgYXRcbiAqXG4gKiAgICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4gKlxuICogVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLCBzb2Z0d2FyZVxuICogZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW4gXCJBUyBJU1wiIEJBU0lTLFxuICogV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuXG4gKiBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZSBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kXG4gKiBsaW1pdGF0aW9ucyB1bmRlciB0aGUgTGljZW5zZS5cbiAqL1xuLy8jZW5kcmVnaW9uXG5pbXBvcnQgeyBDb21wb25lbnQsIGlucHV0LCBtb2RlbCwgb3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFdhdHRDaGlwQ29tcG9uZW50IH0gZnJvbSAnLi93YXR0LWNoaXAuY29tcG9uZW50JztcblxuZnVuY3Rpb24gaXNGaXJzdFJlbmRlcigpIHtcbiAgbGV0IGlzRmlyc3RSZW5kZXIgPSB0cnVlO1xuICByZXR1cm4gKCkgPT4ge1xuICAgIGlmICghaXNGaXJzdFJlbmRlcikgcmV0dXJuIGZhbHNlO1xuICAgIGlzRmlyc3RSZW5kZXIgPSBmYWxzZTtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfTtcbn1cblxuQENvbXBvbmVudCh7XG4gIGltcG9ydHM6IFtXYXR0Q2hpcENvbXBvbmVudF0sXG4gIHNlbGVjdG9yOiAnd2F0dC1maWx0ZXItY2hpcCcsXG4gIHRlbXBsYXRlOiBgXG4gICAgPHdhdHQtY2hpcCBbZGlzYWJsZWRdPVwiZGlzYWJsZWQoKVwiIFtzZWxlY3RlZF09XCJpc0ZpcnN0UmVuZGVyKCkgPyBzZWxlY3RlZCgpIDogaW5wdXQuY2hlY2tlZFwiPlxuICAgICAgPGlucHV0XG4gICAgICAgICNpbnB1dFxuICAgICAgICBjbGFzcz1cImNkay12aXN1YWxseS1oaWRkZW5cIlxuICAgICAgICBbdHlwZV09XCJjaG9pY2UoKSA9PT0gdW5kZWZpbmVkID8gJ2NoZWNrYm94JyA6ICdyYWRpbydcIlxuICAgICAgICBbbmFtZV09XCJuYW1lKClcIlxuICAgICAgICBbdmFsdWVdPVwidmFsdWUoKVwiXG4gICAgICAgIFtjaGVja2VkXT1cInNlbGVjdGVkKClcIlxuICAgICAgICBbZGlzYWJsZWRdPVwiZGlzYWJsZWQoKVwiXG4gICAgICAgIChjaGFuZ2UpPVwib25DaGFuZ2UoaW5wdXQpXCJcbiAgICAgIC8+XG4gICAgICA8bmctY29udGVudCAvPlxuICAgIDwvd2F0dC1jaGlwPlxuICBgLFxufSlcbmV4cG9ydCBjbGFzcyBXYXR0RmlsdGVyQ2hpcENvbXBvbmVudDxUID0gc3RyaW5nPiB7XG4gIHNlbGVjdGVkID0gaW5wdXQoZmFsc2UpO1xuICBkaXNhYmxlZCA9IG1vZGVsKGZhbHNlKTtcbiAgbmFtZSA9IGlucHV0PHN0cmluZz4oKTtcbiAgdmFsdWUgPSBtb2RlbDxUPigpO1xuICBjaG9pY2UgPSBpbnB1dDxzdHJpbmc+KCk7XG4gIHNlbGVjdGlvbkNoYW5nZSA9IG91dHB1dDxUPigpO1xuICBpc0ZpcnN0UmVuZGVyID0gaXNGaXJzdFJlbmRlcigpO1xuXG4gIG9uQ2hhbmdlKGlucHV0OiBIVE1MSW5wdXRFbGVtZW50KTogdm9pZCB7XG4gICAgY29uc3QgdmFsdWUgPSB0aGlzLmNob2ljZSgpICE9PSB1bmRlZmluZWQgPyBpbnB1dC52YWx1ZSA6IGlucHV0LmNoZWNrZWQ7XG4gICAgdGhpcy5zZWxlY3Rpb25DaGFuZ2UuZW1pdCh2YWx1ZSBhcyBUKTtcbiAgfVxufVxuIl19