@energinet/watt 4.1.29 → 4.1.31

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.
@@ -15,6 +15,8 @@ export declare class WattDropZone implements ControlValueAccessor {
15
15
  showProgressBar: import("@angular/core").InputSignal<boolean>;
16
16
  /** Value for the progress bar. Only shown when `showProgressBar` is true. */
17
17
  progress: import("@angular/core").InputSignal<number>;
18
+ /** Message to display when `showProgressBar` is true. Overrides default implementation. */
19
+ loadingMessage: import("@angular/core").InputSignal<string | undefined>;
18
20
  /** Emits when one or more files are selected. */
19
21
  selected: import("@angular/core").OutputEmitterRef<File[]>;
20
22
  dragOver: import("@angular/core").WritableSignal<boolean>;
@@ -25,5 +27,5 @@ export declare class WattDropZone implements ControlValueAccessor {
25
27
  registerOnTouched: (fn: () => void) => import("@angular/core").OutputRefSubscription;
26
28
  registerOnChange: (fn: (value: File[]) => void) => import("@angular/core").OutputRefSubscription;
27
29
  static ɵfac: i0.ɵɵFactoryDeclaration<WattDropZone, never>;
28
- static ɵcmp: i0.ɵɵComponentDeclaration<WattDropZone, "watt-dropzone", never, { "multiple": { "alias": "multiple"; "required": false; "isSignal": true; }; "label": { "alias": "label"; "required": false; "isSignal": true; }; "accept": { "alias": "accept"; "required": false; "isSignal": true; }; "showProgressBar": { "alias": "showProgressBar"; "required": false; "isSignal": true; }; "progress": { "alias": "progress"; "required": false; "isSignal": true; }; }, { "selected": "selected"; }, never, ["*", "watt-field-error", "watt-field-warning", "watt-field-hint"], true, [{ directive: typeof i1.FileTypeValidator; inputs: {}; outputs: {}; }, { directive: typeof i1.MultipleFilesValidator; inputs: {}; outputs: {}; }]>;
30
+ static ɵcmp: i0.ɵɵComponentDeclaration<WattDropZone, "watt-dropzone", never, { "multiple": { "alias": "multiple"; "required": false; "isSignal": true; }; "label": { "alias": "label"; "required": false; "isSignal": true; }; "accept": { "alias": "accept"; "required": false; "isSignal": true; }; "showProgressBar": { "alias": "showProgressBar"; "required": false; "isSignal": true; }; "progress": { "alias": "progress"; "required": false; "isSignal": true; }; "loadingMessage": { "alias": "loadingMessage"; "required": false; "isSignal": true; }; }, { "selected": "selected"; }, never, ["*", "watt-field-error", "watt-field-warning", "watt-field-hint"], true, [{ directive: typeof i1.FileTypeValidator; inputs: {}; outputs: {}; }, { directive: typeof i1.MultipleFilesValidator; inputs: {}; outputs: {}; }]>;
29
31
  }
@@ -40,6 +40,8 @@ export class WattDropZone {
40
40
  showProgressBar = input(false, ...(ngDevMode ? [{ debugName: "showProgressBar" }] : []));
41
41
  /** Value for the progress bar. Only shown when `showProgressBar` is true. */
42
42
  progress = input(0, ...(ngDevMode ? [{ debugName: "progress" }] : []));
43
+ /** Message to display when `showProgressBar` is true. Overrides default implementation. */
44
+ loadingMessage = input(...(ngDevMode ? [undefined, { debugName: "loadingMessage" }] : []));
43
45
  /** Emits when one or more files are selected. */
44
46
  selected = output();
45
47
  // Tracks (valid) drag over state
@@ -74,7 +76,7 @@ export class WattDropZone {
74
76
  registerOnTouched = (fn) => this.selected.subscribe(fn);
75
77
  registerOnChange = (fn) => this.selected.subscribe(fn);
76
78
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.6", ngImport: i0, type: WattDropZone, deps: [], target: i0.ɵɵFactoryTarget.Component });
77
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.6", type: WattDropZone, isStandalone: true, selector: "watt-dropzone", inputs: { multiple: { classPropertyName: "multiple", publicName: "multiple", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, accept: { classPropertyName: "accept", publicName: "accept", isSignal: true, isRequired: false, transformFunction: null }, showProgressBar: { classPropertyName: "showProgressBar", publicName: "showProgressBar", isSignal: true, isRequired: false, transformFunction: null }, progress: { classPropertyName: "progress", publicName: "progress", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selected: "selected" }, providers: [
79
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "20.3.6", type: WattDropZone, isStandalone: true, selector: "watt-dropzone", inputs: { multiple: { classPropertyName: "multiple", publicName: "multiple", isSignal: true, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, accept: { classPropertyName: "accept", publicName: "accept", isSignal: true, isRequired: false, transformFunction: null }, showProgressBar: { classPropertyName: "showProgressBar", publicName: "showProgressBar", isSignal: true, isRequired: false, transformFunction: null }, progress: { classPropertyName: "progress", publicName: "progress", isSignal: true, isRequired: false, transformFunction: null }, loadingMessage: { classPropertyName: "loadingMessage", publicName: "loadingMessage", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selected: "selected" }, providers: [
78
80
  {
79
81
  provide: NG_VALUE_ACCESSOR,
80
82
  useExisting: forwardRef(() => WattDropZone),
@@ -98,7 +100,11 @@ export class WattDropZone {
98
100
  >
99
101
  @if (showProgressBar()) {
100
102
  <vater-stack center gap="s" fill="horizontal" align="start">
101
- <span>{{ intl.loadingMessage }} ( {{ progress() + '%' }} )</span>
103
+ <vater-stack fill="horizontal" direction="row" justify="space-between">
104
+ <span>{{ loadingMessage() ?? intl.loadingMessage }}</span>
105
+ <span>{{ progress() }}%</span>
106
+ </vater-stack>
107
+
102
108
  <mat-progress-bar mode="determinate" [value]="progress()" />
103
109
  </vater-stack>
104
110
  } @else {
@@ -156,7 +162,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.6", ngImpor
156
162
  >
157
163
  @if (showProgressBar()) {
158
164
  <vater-stack center gap="s" fill="horizontal" align="start">
159
- <span>{{ intl.loadingMessage }} ( {{ progress() + '%' }} )</span>
165
+ <vater-stack fill="horizontal" direction="row" justify="space-between">
166
+ <span>{{ loadingMessage() ?? intl.loadingMessage }}</span>
167
+ <span>{{ progress() }}%</span>
168
+ </vater-stack>
169
+
160
170
  <mat-progress-bar mode="determinate" [value]="progress()" />
161
171
  </vater-stack>
162
172
  } @else {
@@ -180,5 +190,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.6", ngImpor
180
190
  </span>
181
191
  </watt-field>
182
192
  `, styles: [".wrapper{display:block;min-height:184px}.dropzone{padding:var(--watt-space-l);background:var(--watt-color-neutral-grey-200)}.dragOver{background:var(--watt-color-state-info-light)}.mat-mdc-progress-bar{--mat-progress-bar-active-indicator-color: var(--watt-color-primary);--mat-progress-bar-track-color: var(--watt-color-primary-light)}\n"] }]
183
- }], propDecorators: { multiple: [{ type: i0.Input, args: [{ isSignal: true, alias: "multiple", required: false }] }], label: [{ type: i0.Input, args: [{ isSignal: true, alias: "label", required: false }] }], accept: [{ type: i0.Input, args: [{ isSignal: true, alias: "accept", required: false }] }], showProgressBar: [{ type: i0.Input, args: [{ isSignal: true, alias: "showProgressBar", required: false }] }], progress: [{ type: i0.Input, args: [{ isSignal: true, alias: "progress", required: false }] }], selected: [{ type: i0.Output, args: ["selected"] }] } });
184
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-dropzone.js","sourceRoot":"","sources":["../../../../libs/watt/package/dropzone/watt-dropzone.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 {\n  Component,\n  booleanAttribute,\n  forwardRef,\n  inject,\n  input,\n  output,\n  signal,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\nimport { MatProgressBarModule } from '@angular/material/progress-bar';\n\nimport { WattButtonComponent } from '@energinet/watt/button';\nimport { WattFieldComponent } from '@energinet/watt/field';\nimport { VaterStackComponent, VaterUtilityDirective } from '@energinet/watt/vater';\nimport { WattDropZoneIntlService } from './watt-dropzone-intl';\nimport { FileTypeValidator, MultipleFilesValidator } from './watt-dropzone-validators';\n\n// Slightly better typing than just raw string\nexport type MimeType = `${string}/${string}`;\n\n@Component({\n  imports: [\n    ReactiveFormsModule,\n    VaterStackComponent,\n    VaterUtilityDirective,\n    WattButtonComponent,\n    WattFieldComponent,\n    MatProgressBarModule,\n  ],\n  selector: 'watt-dropzone',\n  hostDirectives: [FileTypeValidator, MultipleFilesValidator],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => WattDropZone),\n      multi: true,\n    },\n  ],\n  styles: `\n    .wrapper {\n      display: block;\n      min-height: 184px; /* Magic UX number */\n    }\n\n    .dropzone {\n      padding: var(--watt-space-l);\n      background: var(--watt-color-neutral-grey-200);\n    }\n\n    .dragOver {\n      background: var(--watt-color-state-info-light);\n    }\n\n    .mat-mdc-progress-bar {\n      --mat-progress-bar-active-indicator-color: var(--watt-color-primary);\n      --mat-progress-bar-track-color: var(--watt-color-primary-light);\n    }\n  `,\n  template: `\n    <watt-field [label]=\"label()\">\n      <ng-content />\n      <ng-content select=\"watt-field-error\" ngProjectAs=\"watt-field-error\" />\n      <ng-content select=\"watt-field-warning\" ngProjectAs=\"watt-field-warning\" />\n      <ng-content select=\"watt-field-hint\" ngProjectAs=\"watt-field-hint\" />\n      <span class=\"wrapper\">\n        <vater-stack\n          inset=\"0\"\n          class=\"dropzone\"\n          [class.dragOver]=\"dragOver()\"\n          (dragover)=\"handleDragOver($event)\"\n          (drop)=\"handleDrop($event)\"\n          (drop)=\"dragOver.set(false)\"\n          (dragleave)=\"dragOver.set(false)\"\n        >\n          @if (showProgressBar()) {\n            <vater-stack center gap=\"s\" fill=\"horizontal\" align=\"start\">\n              <span>{{ intl.loadingMessage }} ( {{ progress() + '%' }} )</span>\n              <mat-progress-bar mode=\"determinate\" [value]=\"progress()\" />\n            </vater-stack>\n          } @else {\n            <vater-stack center gap=\"xs\">\n              <input\n                #input\n                hidden\n                type=\"file\"\n                [multiple]=\"multiple()\"\n                [accept]=\"accept().join(',')\"\n                (change)=\"handleChange(input)\"\n              />\n              <span>{{ multiple() ? intl.promptMultiple : intl.prompt }}</span>\n              <span class=\"watt-on-light--medium-emphasis\">{{ intl.separator }}</span>\n              <watt-button size=\"small\" variant=\"secondary\" (click)=\"input.click()\">\n                {{ multiple() ? intl.buttonMultiple : intl.button }}\n              </watt-button>\n            </vater-stack>\n          }\n        </vater-stack>\n      </span>\n    </watt-field>\n  `,\n})\n// eslint-disable-next-line @angular-eslint/component-class-suffix\nexport class WattDropZone implements ControlValueAccessor {\n  intl = inject(WattDropZoneIntlService);\n\n  /** Whether the dropzone should accept multiple files. */\n  multiple = input(false, { transform: booleanAttribute });\n\n  /** Label for the dropzone. */\n  label = input<string>();\n\n  /** Comma-separated list of MIME types that the dropzone accepts. */\n  accept = input([], { transform: (value: MimeType) => value.split(',') as MimeType[] });\n\n  /** Whether to show the progress bar. Use in conjunction with `progress`. */\n  showProgressBar = input(false);\n\n  /** Value for the progress bar. Only shown when `showProgressBar` is true. */\n  progress = input(0);\n\n  /** Emits when one or more files are selected. */\n  selected = output<File[]>();\n\n  // Tracks (valid) drag over state\n  dragOver = signal(false);\n\n  handleChange(input: HTMLInputElement) {\n    if (!input.files) return;\n    this.selected.emit(Array.from(input.files));\n    input.value = ''; // fix for chrome not emitting event when selecting the same file\n  }\n\n  handleDrop(event: DragEvent) {\n    if (!event.dataTransfer) return;\n    if (!this.dragOver()) return;\n\n    // Prevent opening the file in the browser\n    event.preventDefault();\n\n    this.selected.emit(Array.from(event.dataTransfer.files));\n  }\n\n  handleDragOver(event: DragEvent) {\n    if (!event.dataTransfer) return;\n\n    // Ignore non-file items such as strings\n    if (Array.from(event.dataTransfer.items).some((i) => i.kind !== 'file')) return;\n\n    // Prevent opening the file in the browser\n    event.preventDefault();\n\n    this.dragOver.set(true);\n  }\n\n  // Implementation for ControlValueAccessor\n  writeValue = () => {}; // eslint-disable-line @typescript-eslint/no-empty-function\n  registerOnTouched = (fn: () => void) => this.selected.subscribe(fn);\n  registerOnChange = (fn: (value: File[]) => void) => this.selected.subscribe(fn);\n}\n"]}
193
+ }], propDecorators: { multiple: [{ type: i0.Input, args: [{ isSignal: true, alias: "multiple", required: false }] }], label: [{ type: i0.Input, args: [{ isSignal: true, alias: "label", required: false }] }], accept: [{ type: i0.Input, args: [{ isSignal: true, alias: "accept", required: false }] }], showProgressBar: [{ type: i0.Input, args: [{ isSignal: true, alias: "showProgressBar", required: false }] }], progress: [{ type: i0.Input, args: [{ isSignal: true, alias: "progress", required: false }] }], loadingMessage: [{ type: i0.Input, args: [{ isSignal: true, alias: "loadingMessage", required: false }] }], selected: [{ type: i0.Output, args: ["selected"] }] } });
194
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-dropzone.js","sourceRoot":"","sources":["../../../../libs/watt/package/dropzone/watt-dropzone.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 {\n  Component,\n  booleanAttribute,\n  forwardRef,\n  inject,\n  input,\n  output,\n  signal,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\nimport { MatProgressBarModule } from '@angular/material/progress-bar';\n\nimport { WattButtonComponent } from '@energinet/watt/button';\nimport { WattFieldComponent } from '@energinet/watt/field';\nimport { VaterStackComponent, VaterUtilityDirective } from '@energinet/watt/vater';\nimport { WattDropZoneIntlService } from './watt-dropzone-intl';\nimport { FileTypeValidator, MultipleFilesValidator } from './watt-dropzone-validators';\n\n// Slightly better typing than just raw string\nexport type MimeType = `${string}/${string}`;\n\n@Component({\n  imports: [\n    ReactiveFormsModule,\n    VaterStackComponent,\n    VaterUtilityDirective,\n    WattButtonComponent,\n    WattFieldComponent,\n    MatProgressBarModule,\n  ],\n  selector: 'watt-dropzone',\n  hostDirectives: [FileTypeValidator, MultipleFilesValidator],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => WattDropZone),\n      multi: true,\n    },\n  ],\n  styles: `\n    .wrapper {\n      display: block;\n      min-height: 184px; /* Magic UX number */\n    }\n\n    .dropzone {\n      padding: var(--watt-space-l);\n      background: var(--watt-color-neutral-grey-200);\n    }\n\n    .dragOver {\n      background: var(--watt-color-state-info-light);\n    }\n\n    .mat-mdc-progress-bar {\n      --mat-progress-bar-active-indicator-color: var(--watt-color-primary);\n      --mat-progress-bar-track-color: var(--watt-color-primary-light);\n    }\n  `,\n  template: `\n    <watt-field [label]=\"label()\">\n      <ng-content />\n      <ng-content select=\"watt-field-error\" ngProjectAs=\"watt-field-error\" />\n      <ng-content select=\"watt-field-warning\" ngProjectAs=\"watt-field-warning\" />\n      <ng-content select=\"watt-field-hint\" ngProjectAs=\"watt-field-hint\" />\n      <span class=\"wrapper\">\n        <vater-stack\n          inset=\"0\"\n          class=\"dropzone\"\n          [class.dragOver]=\"dragOver()\"\n          (dragover)=\"handleDragOver($event)\"\n          (drop)=\"handleDrop($event)\"\n          (drop)=\"dragOver.set(false)\"\n          (dragleave)=\"dragOver.set(false)\"\n        >\n          @if (showProgressBar()) {\n            <vater-stack center gap=\"s\" fill=\"horizontal\" align=\"start\">\n              <vater-stack fill=\"horizontal\" direction=\"row\" justify=\"space-between\">\n                <span>{{ loadingMessage() ?? intl.loadingMessage }}</span>\n                <span>{{ progress() }}%</span>\n              </vater-stack>\n\n              <mat-progress-bar mode=\"determinate\" [value]=\"progress()\" />\n            </vater-stack>\n          } @else {\n            <vater-stack center gap=\"xs\">\n              <input\n                #input\n                hidden\n                type=\"file\"\n                [multiple]=\"multiple()\"\n                [accept]=\"accept().join(',')\"\n                (change)=\"handleChange(input)\"\n              />\n              <span>{{ multiple() ? intl.promptMultiple : intl.prompt }}</span>\n              <span class=\"watt-on-light--medium-emphasis\">{{ intl.separator }}</span>\n              <watt-button size=\"small\" variant=\"secondary\" (click)=\"input.click()\">\n                {{ multiple() ? intl.buttonMultiple : intl.button }}\n              </watt-button>\n            </vater-stack>\n          }\n        </vater-stack>\n      </span>\n    </watt-field>\n  `,\n})\n// eslint-disable-next-line @angular-eslint/component-class-suffix\nexport class WattDropZone implements ControlValueAccessor {\n  intl = inject(WattDropZoneIntlService);\n\n  /** Whether the dropzone should accept multiple files. */\n  multiple = input(false, { transform: booleanAttribute });\n\n  /** Label for the dropzone. */\n  label = input<string>();\n\n  /** Comma-separated list of MIME types that the dropzone accepts. */\n  accept = input([], { transform: (value: MimeType) => value.split(',') as MimeType[] });\n\n  /** Whether to show the progress bar. Use in conjunction with `progress`. */\n  showProgressBar = input(false);\n\n  /** Value for the progress bar. Only shown when `showProgressBar` is true. */\n  progress = input(0);\n\n  /** Message to display when `showProgressBar` is true. Overrides default implementation. */\n  loadingMessage = input<string>();\n\n  /** Emits when one or more files are selected. */\n  selected = output<File[]>();\n\n  // Tracks (valid) drag over state\n  dragOver = signal(false);\n\n  handleChange(input: HTMLInputElement) {\n    if (!input.files) return;\n    this.selected.emit(Array.from(input.files));\n    input.value = ''; // fix for chrome not emitting event when selecting the same file\n  }\n\n  handleDrop(event: DragEvent) {\n    if (!event.dataTransfer) return;\n    if (!this.dragOver()) return;\n\n    // Prevent opening the file in the browser\n    event.preventDefault();\n\n    this.selected.emit(Array.from(event.dataTransfer.files));\n  }\n\n  handleDragOver(event: DragEvent) {\n    if (!event.dataTransfer) return;\n\n    // Ignore non-file items such as strings\n    if (Array.from(event.dataTransfer.items).some((i) => i.kind !== 'file')) return;\n\n    // Prevent opening the file in the browser\n    event.preventDefault();\n\n    this.dragOver.set(true);\n  }\n\n  // Implementation for ControlValueAccessor\n  writeValue = () => {}; // eslint-disable-line @typescript-eslint/no-empty-function\n  registerOnTouched = (fn: () => void) => this.selected.subscribe(fn);\n  registerOnChange = (fn: (value: File[]) => void) => this.selected.subscribe(fn);\n}\n"]}
@@ -20,9 +20,10 @@ import { Component, input, TemplateRef, viewChild } from '@angular/core';
20
20
  import * as i0 from "@angular/core";
21
21
  export class WattSegmentedButtonComponent {
22
22
  templateRef = viewChild.required(TemplateRef);
23
- value = input.required(...(ngDevMode ? [{ debugName: "value" }] : []));
23
+ value = input(...(ngDevMode ? [undefined, { debugName: "value" }] : []));
24
+ link = input(...(ngDevMode ? [undefined, { debugName: "link" }] : []));
24
25
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.6", ngImport: i0, type: WattSegmentedButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
25
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "20.3.6", type: WattSegmentedButtonComponent, isStandalone: true, selector: "watt-segmented-button", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: true, transformFunction: null } }, viewQueries: [{ propertyName: "templateRef", first: true, predicate: TemplateRef, descendants: true, isSignal: true }], ngImport: i0, template: ` <ng-template>
26
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "20.3.6", type: WattSegmentedButtonComponent, isStandalone: true, selector: "watt-segmented-button", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, link: { classPropertyName: "link", publicName: "link", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "templateRef", first: true, predicate: TemplateRef, descendants: true, isSignal: true }], ngImport: i0, template: ` <ng-template>
26
27
  <ng-content />
27
28
  </ng-template>`, isInline: true });
28
29
  }
@@ -34,5 +35,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.6", ngImpor
34
35
  <ng-content />
35
36
  </ng-template>`,
36
37
  }]
37
- }], propDecorators: { templateRef: [{ type: i0.ViewChild, args: [i0.forwardRef(() => TemplateRef), { isSignal: true }] }], value: [{ type: i0.Input, args: [{ isSignal: true, alias: "value", required: true }] }] } });
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2F0dC1zZWdtZW50ZWQtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnMvd2F0dC9wYWNrYWdlL3NlZ21lbnRlZC1idXR0b25zL3dhdHQtc2VnbWVudGVkLWJ1dHRvbi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsaUJBQWlCO0FBQ2pCOzs7Ozs7Ozs7Ozs7Ozs7R0FlRztBQUNILFlBQVk7QUFDWixPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVF6RSxNQUFNLE9BQU8sNEJBQTRCO0lBQ3ZDLFdBQVcsR0FBRyxTQUFTLENBQUMsUUFBUSxDQUF1QixXQUFXLENBQUMsQ0FBQztJQUNwRSxLQUFLLEdBQUcsS0FBSyxDQUFDLFFBQVEsZ0RBQVUsQ0FBQzt1R0FGdEIsNEJBQTRCOzJGQUE1Qiw0QkFBNEIsaVFBQ2dCLFdBQVcsZ0VBTHhEOztpQkFFSzs7MkZBRUosNEJBQTRCO2tCQU54QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx1QkFBdUI7b0JBQ2pDLFFBQVEsRUFBRTs7aUJBRUs7aUJBQ2hCOzZGQUV3RCxXQUFXIiwic291cmNlc0NvbnRlbnQiOlsiLy8jcmVnaW9uIExpY2Vuc2Vcbi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCAyMDIwIEVuZXJnaW5ldCBEYXRhSHViIEEvU1xuICpcbiAqIExpY2Vuc2VkIHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZSBcIkxpY2Vuc2UyXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogICAgIGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMFxuICpcbiAqIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbiAqIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBCQVNJUyxcbiAqIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICogU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuICogbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cbi8vI2VuZHJlZ2lvblxuaW1wb3J0IHsgQ29tcG9uZW50LCBpbnB1dCwgVGVtcGxhdGVSZWYsIHZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd3YXR0LXNlZ21lbnRlZC1idXR0b24nLFxuICB0ZW1wbGF0ZTogYCA8bmctdGVtcGxhdGU+XG4gICAgPG5nLWNvbnRlbnQgLz5cbiAgPC9uZy10ZW1wbGF0ZT5gLFxufSlcbmV4cG9ydCBjbGFzcyBXYXR0U2VnbWVudGVkQnV0dG9uQ29tcG9uZW50IHtcbiAgdGVtcGxhdGVSZWYgPSB2aWV3Q2hpbGQucmVxdWlyZWQ8VGVtcGxhdGVSZWY8dW5rbm93bj4+KFRlbXBsYXRlUmVmKTtcbiAgdmFsdWUgPSBpbnB1dC5yZXF1aXJlZDxzdHJpbmc+KCk7XG59XG4iXX0=
38
+ }], propDecorators: { templateRef: [{ type: i0.ViewChild, args: [i0.forwardRef(() => TemplateRef), { isSignal: true }] }], value: [{ type: i0.Input, args: [{ isSignal: true, alias: "value", required: false }] }], link: [{ type: i0.Input, args: [{ isSignal: true, alias: "link", required: false }] }] } });
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2F0dC1zZWdtZW50ZWQtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnMvd2F0dC9wYWNrYWdlL3NlZ21lbnRlZC1idXR0b25zL3dhdHQtc2VnbWVudGVkLWJ1dHRvbi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsaUJBQWlCO0FBQ2pCOzs7Ozs7Ozs7Ozs7Ozs7R0FlRztBQUNILFlBQVk7QUFDWixPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVF6RSxNQUFNLE9BQU8sNEJBQTRCO0lBQ3ZDLFdBQVcsR0FBRyxTQUFTLENBQUMsUUFBUSxDQUF1QixXQUFXLENBQUMsQ0FBQztJQUNwRSxLQUFLLEdBQUcsS0FBSywyREFBVSxDQUFDO0lBQ3hCLElBQUksR0FBRyxLQUFLLDBEQUFVLENBQUM7dUdBSFosNEJBQTRCOzJGQUE1Qiw0QkFBNEIsdVhBQ2dCLFdBQVcsZ0VBTHhEOztpQkFFSzs7MkZBRUosNEJBQTRCO2tCQU54QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx1QkFBdUI7b0JBQ2pDLFFBQVEsRUFBRTs7aUJBRUs7aUJBQ2hCOzZGQUV3RCxXQUFXIiwic291cmNlc0NvbnRlbnQiOlsiLy8jcmVnaW9uIExpY2Vuc2Vcbi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCAyMDIwIEVuZXJnaW5ldCBEYXRhSHViIEEvU1xuICpcbiAqIExpY2Vuc2VkIHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZSBcIkxpY2Vuc2UyXCIpO1xuICogeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZSB3aXRoIHRoZSBMaWNlbnNlLlxuICogWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4gKlxuICogICAgIGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMFxuICpcbiAqIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZywgc29mdHdhcmVcbiAqIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuIFwiQVMgSVNcIiBCQVNJUyxcbiAqIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWSBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLlxuICogU2VlIHRoZSBMaWNlbnNlIGZvciB0aGUgc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZFxuICogbGltaXRhdGlvbnMgdW5kZXIgdGhlIExpY2Vuc2UuXG4gKi9cbi8vI2VuZHJlZ2lvblxuaW1wb3J0IHsgQ29tcG9uZW50LCBpbnB1dCwgVGVtcGxhdGVSZWYsIHZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd3YXR0LXNlZ21lbnRlZC1idXR0b24nLFxuICB0ZW1wbGF0ZTogYCA8bmctdGVtcGxhdGU+XG4gICAgPG5nLWNvbnRlbnQgLz5cbiAgPC9uZy10ZW1wbGF0ZT5gLFxufSlcbmV4cG9ydCBjbGFzcyBXYXR0U2VnbWVudGVkQnV0dG9uQ29tcG9uZW50IHtcbiAgdGVtcGxhdGVSZWYgPSB2aWV3Q2hpbGQucmVxdWlyZWQ8VGVtcGxhdGVSZWY8dW5rbm93bj4+KFRlbXBsYXRlUmVmKTtcbiAgdmFsdWUgPSBpbnB1dDxzdHJpbmc+KCk7XG4gIGxpbmsgPSBpbnB1dDxzdHJpbmc+KCk7XG59XG4iXX0=
@@ -16,10 +16,11 @@
16
16
  * limitations under the License.
17
17
  */
18
18
  //#endregion
19
+ import { NgTemplateOutlet } from '@angular/common';
20
+ import { RouterLinkWithHref, RouterLinkActive } from '@angular/router';
19
21
  import { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';
20
- import { ChangeDetectionStrategy, Component, contentChildren, ElementRef, forwardRef, inject, model, signal, ViewEncapsulation, } from '@angular/core';
22
+ import { model, signal, inject, Component, ElementRef, forwardRef, contentChildren, ViewEncapsulation, ChangeDetectionStrategy, } from '@angular/core';
21
23
  import { MatButtonToggleModule } from '@angular/material/button-toggle';
22
- import { NgTemplateOutlet } from '@angular/common';
23
24
  import { WattSegmentedButtonComponent } from './watt-segmented-button.component';
24
25
  import * as i0 from "@angular/core";
25
26
  import * as i1 from "@angular/material/button-toggle";
@@ -28,10 +29,10 @@ import * as i2 from "@angular/forms";
28
29
  * Segmented buttons.
29
30
  */
30
31
  export class WattSegmentedButtonsComponent {
32
+ element = inject(ElementRef);
31
33
  segmentedButtonElements = contentChildren(WattSegmentedButtonComponent, ...(ngDevMode ? [{ debugName: "segmentedButtonElements" }] : []));
32
34
  selected = model('', ...(ngDevMode ? [{ debugName: "selected" }] : []));
33
35
  disabled = signal(false, ...(ngDevMode ? [{ debugName: "disabled" }] : []));
34
- element = inject(ElementRef);
35
36
  writeValue(selected) {
36
37
  this.selected.set(selected);
37
38
  }
@@ -51,38 +52,58 @@ export class WattSegmentedButtonsComponent {
51
52
  useExisting: forwardRef(() => WattSegmentedButtonsComponent),
52
53
  multi: true,
53
54
  },
54
- ], queries: [{ propertyName: "segmentedButtonElements", predicate: WattSegmentedButtonComponent, isSignal: true }], ngImport: i0, template: ` <mat-button-toggle-group
55
- [(ngModel)]="selected"
56
- [multiple]="false"
57
- [hideSingleSelectionIndicator]="true"
58
- [disabled]="disabled()"
59
- >
60
- @for (segmentedButton of segmentedButtonElements(); track segmentedButton) {
61
- <mat-button-toggle [disableRipple]="true" [value]="segmentedButton.value()">
62
- <ng-container *ngTemplateOutlet="segmentedButton.templateRef()" />
63
- </mat-button-toggle>
64
- }
65
- </mat-button-toggle-group>`, isInline: true, styles: [":root{--mat-button-toggle-selected-state-text-color: white;--mat-button-toggle-selected-state-background-color: var(--watt-color-primary);--mat-button-toggle-height: 2.5rem}:root mat-button-toggle-group{border-color:var(--watt-color-neutral-grey-700)}:root mat-button-toggle-group mat-button-toggle{border-color:var(--watt-color-neutral-grey-700)!important}:root mat-button-toggle-group mat-button-toggle button{min-width:6.5rem}:root mat-button-toggle-group mat-button-toggle button span{font-size:.875rem;font-weight:600}\n"], dependencies: [{ kind: "ngmodule", type: MatButtonToggleModule }, { kind: "directive", type: i1.MatButtonToggleGroup, selector: "mat-button-toggle-group", inputs: ["appearance", "name", "vertical", "value", "multiple", "disabled", "disabledInteractive", "hideSingleSelectionIndicator", "hideMultipleSelectionIndicator"], outputs: ["valueChange", "change"], exportAs: ["matButtonToggleGroup"] }, { kind: "component", type: i1.MatButtonToggle, selector: "mat-button-toggle", inputs: ["aria-label", "aria-labelledby", "id", "name", "value", "tabIndex", "disableRipple", "appearance", "checked", "disabled", "disabledInteractive"], outputs: ["change"], exportAs: ["matButtonToggle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
55
+ ], queries: [{ propertyName: "segmentedButtonElements", predicate: WattSegmentedButtonComponent, isSignal: true }], ngImport: i0, template: `
56
+ <mat-button-toggle-group
57
+ [(ngModel)]="selected"
58
+ [multiple]="false"
59
+ [hideSingleSelectionIndicator]="true"
60
+ [disabled]="disabled()"
61
+ >
62
+ @for (segmentedButton of segmentedButtonElements(); track segmentedButton) {
63
+ <mat-button-toggle
64
+ [routerLink]="segmentedButton.link()"
65
+ routerLinkActive="mat-button-toggle-checked"
66
+ [disableRipple]="true"
67
+ [value]="segmentedButton.value()"
68
+ >
69
+ <ng-container *ngTemplateOutlet="segmentedButton.templateRef()" />
70
+ </mat-button-toggle>
71
+ }
72
+ </mat-button-toggle-group>
73
+ `, isInline: true, styles: ["@use \"@energinet/watt/utils\" as watt;@use \"@angular/material\" as mat;:root{@include mat.button-toggle-overrides((selected-state-text-color: white,selected-state-background-color: var(--watt-color-primary),height: 2.5rem,));}:root mat-button-toggle-group{border-color:var(--watt-color-neutral-grey-700)}:root mat-button-toggle-group mat-button-toggle{border-color:var(--watt-color-neutral-grey-700)!important}:root mat-button-toggle-group mat-button-toggle button{min-width:6.5rem}:root mat-button-toggle-group mat-button-toggle button span{font-size:.875rem;font-weight:600}\n"], dependencies: [{ kind: "ngmodule", type: MatButtonToggleModule }, { kind: "directive", type: i1.MatButtonToggleGroup, selector: "mat-button-toggle-group", inputs: ["appearance", "name", "vertical", "value", "multiple", "disabled", "disabledInteractive", "hideSingleSelectionIndicator", "hideMultipleSelectionIndicator"], outputs: ["valueChange", "change"], exportAs: ["matButtonToggleGroup"] }, { kind: "component", type: i1.MatButtonToggle, selector: "mat-button-toggle", inputs: ["aria-label", "aria-labelledby", "id", "name", "value", "tabIndex", "disableRipple", "appearance", "checked", "disabled", "disabledInteractive"], outputs: ["change"], exportAs: ["matButtonToggle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: RouterLinkWithHref, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
66
74
  }
67
75
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.6", ngImport: i0, type: WattSegmentedButtonsComponent, decorators: [{
68
76
  type: Component,
69
- args: [{ changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, imports: [MatButtonToggleModule, FormsModule, NgTemplateOutlet], providers: [
77
+ args: [{ changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, imports: [
78
+ MatButtonToggleModule,
79
+ FormsModule,
80
+ NgTemplateOutlet,
81
+ RouterLinkWithHref,
82
+ RouterLinkActive,
83
+ ], providers: [
70
84
  {
71
85
  provide: NG_VALUE_ACCESSOR,
72
86
  useExisting: forwardRef(() => WattSegmentedButtonsComponent),
73
87
  multi: true,
74
88
  },
75
- ], selector: 'watt-segmented-buttons', template: ` <mat-button-toggle-group
76
- [(ngModel)]="selected"
77
- [multiple]="false"
78
- [hideSingleSelectionIndicator]="true"
79
- [disabled]="disabled()"
80
- >
81
- @for (segmentedButton of segmentedButtonElements(); track segmentedButton) {
82
- <mat-button-toggle [disableRipple]="true" [value]="segmentedButton.value()">
83
- <ng-container *ngTemplateOutlet="segmentedButton.templateRef()" />
84
- </mat-button-toggle>
85
- }
86
- </mat-button-toggle-group>`, styles: [":root{--mat-button-toggle-selected-state-text-color: white;--mat-button-toggle-selected-state-background-color: var(--watt-color-primary);--mat-button-toggle-height: 2.5rem}:root mat-button-toggle-group{border-color:var(--watt-color-neutral-grey-700)}:root mat-button-toggle-group mat-button-toggle{border-color:var(--watt-color-neutral-grey-700)!important}:root mat-button-toggle-group mat-button-toggle button{min-width:6.5rem}:root mat-button-toggle-group mat-button-toggle button span{font-size:.875rem;font-weight:600}\n"] }]
89
+ ], selector: 'watt-segmented-buttons', template: `
90
+ <mat-button-toggle-group
91
+ [(ngModel)]="selected"
92
+ [multiple]="false"
93
+ [hideSingleSelectionIndicator]="true"
94
+ [disabled]="disabled()"
95
+ >
96
+ @for (segmentedButton of segmentedButtonElements(); track segmentedButton) {
97
+ <mat-button-toggle
98
+ [routerLink]="segmentedButton.link()"
99
+ routerLinkActive="mat-button-toggle-checked"
100
+ [disableRipple]="true"
101
+ [value]="segmentedButton.value()"
102
+ >
103
+ <ng-container *ngTemplateOutlet="segmentedButton.templateRef()" />
104
+ </mat-button-toggle>
105
+ }
106
+ </mat-button-toggle-group>
107
+ `, styles: ["@use \"@energinet/watt/utils\" as watt;@use \"@angular/material\" as mat;:root{@include mat.button-toggle-overrides((selected-state-text-color: white,selected-state-background-color: var(--watt-color-primary),height: 2.5rem,));}:root mat-button-toggle-group{border-color:var(--watt-color-neutral-grey-700)}:root mat-button-toggle-group mat-button-toggle{border-color:var(--watt-color-neutral-grey-700)!important}:root mat-button-toggle-group mat-button-toggle button{min-width:6.5rem}:root mat-button-toggle-group mat-button-toggle button span{font-size:.875rem;font-weight:600}\n"] }]
87
108
  }], propDecorators: { segmentedButtonElements: [{ type: i0.ContentChildren, args: [i0.forwardRef(() => WattSegmentedButtonComponent), { isSignal: true }] }], selected: [{ type: i0.Input, args: [{ isSignal: true, alias: "selected", required: false }] }, { type: i0.Output, args: ["selectedChange"] }] } });
88
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2F0dC1zZWdtZW50ZWQtYnV0dG9ucy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL3dhdHQvcGFja2FnZS9zZWdtZW50ZWQtYnV0dG9ucy93YXR0LXNlZ21lbnRlZC1idXR0b25zLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxpQkFBaUI7QUFDakI7Ozs7Ozs7Ozs7Ozs7OztHQWVHO0FBQ0gsWUFBWTtBQUNaLE9BQU8sRUFBd0IsV0FBVyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDdEYsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsZUFBZSxFQUNmLFVBQVUsRUFDVixVQUFVLEVBQ1YsTUFBTSxFQUNOLEtBQUssRUFDTCxNQUFNLEVBQ04saUJBQWlCLEdBQ2xCLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ25ELE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDOzs7O0FBRWpGOztHQUVHO0FBMkJILE1BQU0sT0FBTyw2QkFBNkI7SUFDeEMsdUJBQXVCLEdBQUcsZUFBZSxDQUFDLDRCQUE0QixtRUFBQyxDQUFDO0lBQ3hFLFFBQVEsR0FBRyxLQUFLLENBQVMsRUFBRSxvREFBQyxDQUFDO0lBQzdCLFFBQVEsR0FBRyxNQUFNLENBQUMsS0FBSyxvREFBQyxDQUFDO0lBQ2pCLE9BQU8sR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7SUFFckMsVUFBVSxDQUFDLFFBQWdCO1FBQ3pCLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxFQUEyQjtRQUMxQyxJQUFJLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUM5QixDQUFDO0lBRUQsaUJBQWlCLENBQUMsRUFBNEI7UUFDNUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLENBQUMsVUFBVSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFFRCxnQkFBZ0IsQ0FBRSxVQUFtQjtRQUNuQyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNoQyxDQUFDO3VHQXBCVSw2QkFBNkI7MkZBQTdCLDZCQUE2QiwyUEF0QjdCO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyw2QkFBNkIsQ0FBQztnQkFDNUQsS0FBSyxFQUFFLElBQUk7YUFDWjtTQUNGLGtFQWlCeUMsNEJBQTRCLDZDQWQ1RDs7Ozs7Ozs7Ozs7NkJBV2lCLHNsQkFyQmpCLHFCQUFxQixzb0JBQUUsV0FBVywrVkFBRSxnQkFBZ0I7OzJGQXVCbkQsNkJBQTZCO2tCQTFCekMsU0FBUztzQ0FDUyx1QkFBdUIsQ0FBQyxNQUFNLGlCQUNoQyxpQkFBaUIsQ0FBQyxJQUFJLFdBQzVCLENBQUMscUJBQXFCLEVBQUUsV0FBVyxFQUFFLGdCQUFnQixDQUFDLGFBQ3BEO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLDhCQUE4QixDQUFDOzRCQUM1RCxLQUFLLEVBQUUsSUFBSTt5QkFDWjtxQkFDRixZQUNTLHdCQUF3QixZQUV4Qjs7Ozs7Ozs7Ozs7NkJBV2lCOytHQUdlLDRCQUE0QiIsInNvdXJjZXNDb250ZW50IjpbIi8vI3JlZ2lvbiBMaWNlbnNlXG4vKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgMjAyMCBFbmVyZ2luZXQgRGF0YUh1YiBBL1NcbiAqXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlMlwiKTtcbiAqIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS5cbiAqIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuICpcbiAqICAgICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbiAqXG4gKiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gKiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgQkFTSVMsXG4gKiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbiAqIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAqIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG4vLyNlbmRyZWdpb25cbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBGb3Jtc01vZHVsZSwgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBjb250ZW50Q2hpbGRyZW4sXG4gIEVsZW1lbnRSZWYsXG4gIGZvcndhcmRSZWYsXG4gIGluamVjdCxcbiAgbW9kZWwsXG4gIHNpZ25hbCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0QnV0dG9uVG9nZ2xlTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uLXRvZ2dsZSc7XG5pbXBvcnQgeyBOZ1RlbXBsYXRlT3V0bGV0IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IFdhdHRTZWdtZW50ZWRCdXR0b25Db21wb25lbnQgfSBmcm9tICcuL3dhdHQtc2VnbWVudGVkLWJ1dHRvbi5jb21wb25lbnQnO1xuXG4vKipcbiAqIFNlZ21lbnRlZCBidXR0b25zLlxuICovXG5AQ29tcG9uZW50KHtcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGltcG9ydHM6IFtNYXRCdXR0b25Ub2dnbGVNb2R1bGUsIEZvcm1zTW9kdWxlLCBOZ1RlbXBsYXRlT3V0bGV0XSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBXYXR0U2VnbWVudGVkQnV0dG9uc0NvbXBvbmVudCksXG4gICAgICBtdWx0aTogdHJ1ZSxcbiAgICB9LFxuICBdLFxuICBzZWxlY3RvcjogJ3dhdHQtc2VnbWVudGVkLWJ1dHRvbnMnLFxuICBzdHlsZVVybHM6IFsnLi93YXR0LXNlZ21lbnRlZC1idXR0b25zLmNvbXBvbmVudC5zY3NzJ10sXG4gIHRlbXBsYXRlOiBgIDxtYXQtYnV0dG9uLXRvZ2dsZS1ncm91cFxuICAgIFsobmdNb2RlbCldPVwic2VsZWN0ZWRcIlxuICAgIFttdWx0aXBsZV09XCJmYWxzZVwiXG4gICAgW2hpZGVTaW5nbGVTZWxlY3Rpb25JbmRpY2F0b3JdPVwidHJ1ZVwiXG4gICAgW2Rpc2FibGVkXT1cImRpc2FibGVkKClcIlxuICA+XG4gICAgQGZvciAoc2VnbWVudGVkQnV0dG9uIG9mIHNlZ21lbnRlZEJ1dHRvbkVsZW1lbnRzKCk7IHRyYWNrIHNlZ21lbnRlZEJ1dHRvbikge1xuICAgICAgPG1hdC1idXR0b24tdG9nZ2xlIFtkaXNhYmxlUmlwcGxlXT1cInRydWVcIiBbdmFsdWVdPVwic2VnbWVudGVkQnV0dG9uLnZhbHVlKClcIj5cbiAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdUZW1wbGF0ZU91dGxldD1cInNlZ21lbnRlZEJ1dHRvbi50ZW1wbGF0ZVJlZigpXCIgLz5cbiAgICAgIDwvbWF0LWJ1dHRvbi10b2dnbGU+XG4gICAgfVxuICA8L21hdC1idXR0b24tdG9nZ2xlLWdyb3VwPmAsXG59KVxuZXhwb3J0IGNsYXNzIFdhdHRTZWdtZW50ZWRCdXR0b25zQ29tcG9uZW50IGltcGxlbWVudHMgQ29udHJvbFZhbHVlQWNjZXNzb3Ige1xuICBzZWdtZW50ZWRCdXR0b25FbGVtZW50cyA9IGNvbnRlbnRDaGlsZHJlbihXYXR0U2VnbWVudGVkQnV0dG9uQ29tcG9uZW50KTtcbiAgc2VsZWN0ZWQgPSBtb2RlbDxzdHJpbmc+KCcnKTtcbiAgZGlzYWJsZWQgPSBzaWduYWwoZmFsc2UpO1xuICBwcml2YXRlIGVsZW1lbnQgPSBpbmplY3QoRWxlbWVudFJlZik7XG5cbiAgd3JpdGVWYWx1ZShzZWxlY3RlZDogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5zZWxlY3RlZC5zZXQoc2VsZWN0ZWQpO1xuICB9XG5cbiAgcmVnaXN0ZXJPbkNoYW5nZShmbjogKHZhbHVlOiBzdHJpbmcpID0+IHZvaWQpOiB2b2lkIHtcbiAgICB0aGlzLnNlbGVjdGVkLnN1YnNjcmliZShmbik7XG4gIH1cblxuICByZWdpc3Rlck9uVG91Y2hlZChmbjogKHZhbHVlOiBib29sZWFuKSA9PiB2b2lkKTogdm9pZCB7XG4gICAgdGhpcy5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQuYWRkRXZlbnRMaXN0ZW5lcignZm9jdXNvdXQnLCBmbik7XG4gIH1cblxuICBzZXREaXNhYmxlZFN0YXRlPyhpc0Rpc2FibGVkOiBib29sZWFuKTogdm9pZCB7XG4gICAgdGhpcy5kaXNhYmxlZC5zZXQoaXNEaXNhYmxlZCk7XG4gIH1cbn1cbiJdfQ==
109
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2F0dC1zZWdtZW50ZWQtYnV0dG9ucy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL3dhdHQvcGFja2FnZS9zZWdtZW50ZWQtYnV0dG9ucy93YXR0LXNlZ21lbnRlZC1idXR0b25zLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxpQkFBaUI7QUFDakI7Ozs7Ozs7Ozs7Ozs7OztHQWVHO0FBQ0gsWUFBWTtBQUNaLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3ZFLE9BQU8sRUFBd0IsV0FBVyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDdEYsT0FBTyxFQUNMLEtBQUssRUFDTCxNQUFNLEVBQ04sTUFBTSxFQUNOLFNBQVMsRUFDVCxVQUFVLEVBQ1YsVUFBVSxFQUNWLGVBQWUsRUFDZixpQkFBaUIsRUFDakIsdUJBQXVCLEdBQ3hCLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDOzs7O0FBRWpGOztHQUVHO0FBc0VILE1BQU0sT0FBTyw2QkFBNkI7SUFDaEMsT0FBTyxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNyQyx1QkFBdUIsR0FBRyxlQUFlLENBQUMsNEJBQTRCLG1FQUFDLENBQUM7SUFDeEUsUUFBUSxHQUFHLEtBQUssQ0FBUyxFQUFFLG9EQUFDLENBQUM7SUFDN0IsUUFBUSxHQUFHLE1BQU0sQ0FBQyxLQUFLLG9EQUFDLENBQUM7SUFFekIsVUFBVSxDQUFDLFFBQWdCO1FBQ3pCLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQzlCLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxFQUEyQjtRQUMxQyxJQUFJLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsQ0FBQztJQUM5QixDQUFDO0lBRUQsaUJBQWlCLENBQUMsRUFBNEI7UUFDNUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLENBQUMsVUFBVSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFFRCxnQkFBZ0IsQ0FBRSxVQUFtQjtRQUNuQyxJQUFJLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUNoQyxDQUFDO3VHQXBCVSw2QkFBNkI7MkZBQTdCLDZCQUE2QiwyUEEzRDdCO1lBQ1Q7Z0JBQ0UsT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyw2QkFBNkIsQ0FBQztnQkFDNUQsS0FBSyxFQUFFLElBQUk7YUFDWjtTQUNGLGtFQXVEeUMsNEJBQTRCLDZDQXRCNUQ7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQWtCVCw2b0JBL0RDLHFCQUFxQixzb0JBQ3JCLFdBQVcsK1ZBQ1gsZ0JBQWdCLG9KQUNoQixrQkFBa0Isb09BQ2xCLGdCQUFnQjs7MkZBNkRQLDZCQUE2QjtrQkFyRXpDLFNBQVM7c0NBQ1MsdUJBQXVCLENBQUMsTUFBTSxpQkFDaEMsaUJBQWlCLENBQUMsSUFBSSxXQUM1Qjt3QkFDUCxxQkFBcUI7d0JBQ3JCLFdBQVc7d0JBQ1gsZ0JBQWdCO3dCQUNoQixrQkFBa0I7d0JBQ2xCLGdCQUFnQjtxQkFDakIsYUFDVTt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSw4QkFBOEIsQ0FBQzs0QkFDNUQsS0FBSyxFQUFFLElBQUk7eUJBQ1o7cUJBQ0YsWUFDUyx3QkFBd0IsWUFnQ3hCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FrQlQ7K0dBSXlDLDRCQUE0QiIsInNvdXJjZXNDb250ZW50IjpbIi8vI3JlZ2lvbiBMaWNlbnNlXG4vKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgMjAyMCBFbmVyZ2luZXQgRGF0YUh1YiBBL1NcbiAqXG4gKiBMaWNlbnNlZCB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGUgXCJMaWNlbnNlMlwiKTtcbiAqIHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Ugd2l0aCB0aGUgTGljZW5zZS5cbiAqIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuICpcbiAqICAgICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbiAqXG4gKiBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsIHNvZnR3YXJlXG4gKiBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhbiBcIkFTIElTXCIgQkFTSVMsXG4gKiBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTlkgS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC5cbiAqIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmRcbiAqIGxpbWl0YXRpb25zIHVuZGVyIHRoZSBMaWNlbnNlLlxuICovXG4vLyNlbmRyZWdpb25cbmltcG9ydCB7IE5nVGVtcGxhdGVPdXRsZXQgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgUm91dGVyTGlua1dpdGhIcmVmLCBSb3V0ZXJMaW5rQWN0aXZlIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBGb3Jtc01vZHVsZSwgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge1xuICBtb2RlbCxcbiAgc2lnbmFsLFxuICBpbmplY3QsXG4gIENvbXBvbmVudCxcbiAgRWxlbWVudFJlZixcbiAgZm9yd2FyZFJlZixcbiAgY29udGVudENoaWxkcmVuLFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBNYXRCdXR0b25Ub2dnbGVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24tdG9nZ2xlJztcbmltcG9ydCB7IFdhdHRTZWdtZW50ZWRCdXR0b25Db21wb25lbnQgfSBmcm9tICcuL3dhdHQtc2VnbWVudGVkLWJ1dHRvbi5jb21wb25lbnQnO1xuXG4vKipcbiAqIFNlZ21lbnRlZCBidXR0b25zLlxuICovXG5AQ29tcG9uZW50KHtcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGltcG9ydHM6IFtcbiAgICBNYXRCdXR0b25Ub2dnbGVNb2R1bGUsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgTmdUZW1wbGF0ZU91dGxldCxcbiAgICBSb3V0ZXJMaW5rV2l0aEhyZWYsXG4gICAgUm91dGVyTGlua0FjdGl2ZSxcbiAgXSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBXYXR0U2VnbWVudGVkQnV0dG9uc0NvbXBvbmVudCksXG4gICAgICBtdWx0aTogdHJ1ZSxcbiAgICB9LFxuICBdLFxuICBzZWxlY3RvcjogJ3dhdHQtc2VnbWVudGVkLWJ1dHRvbnMnLFxuICBzdHlsZXM6IGBcbiAgICBAdXNlICdAZW5lcmdpbmV0L3dhdHQvdXRpbHMnIGFzIHdhdHQ7XG4gICAgQHVzZSAnQGFuZ3VsYXIvbWF0ZXJpYWwnIGFzIG1hdDtcblxuICAgIDpyb290IHtcbiAgICAgIEBpbmNsdWRlIG1hdC5idXR0b24tdG9nZ2xlLW92ZXJyaWRlcyhcbiAgICAgICAgKFxuICAgICAgICAgIHNlbGVjdGVkLXN0YXRlLXRleHQtY29sb3I6IHdoaXRlLFxuICAgICAgICAgIHNlbGVjdGVkLXN0YXRlLWJhY2tncm91bmQtY29sb3I6IHZhcigtLXdhdHQtY29sb3ItcHJpbWFyeSksXG4gICAgICAgICAgaGVpZ2h0OiAyLjVyZW0sXG4gICAgICAgIClcbiAgICAgICk7XG5cbiAgICAgIG1hdC1idXR0b24tdG9nZ2xlLWdyb3VwIHtcbiAgICAgICAgYm9yZGVyLWNvbG9yOiB2YXIoLS13YXR0LWNvbG9yLW5ldXRyYWwtZ3JleS03MDApO1xuXG4gICAgICAgIG1hdC1idXR0b24tdG9nZ2xlIHtcbiAgICAgICAgICBib3JkZXItY29sb3I6IHZhcigtLXdhdHQtY29sb3ItbmV1dHJhbC1ncmV5LTcwMCkgIWltcG9ydGFudDtcblxuICAgICAgICAgIGJ1dHRvbiB7XG4gICAgICAgICAgICBtaW4td2lkdGg6IDYuNXJlbTtcblxuICAgICAgICAgICAgc3BhbiB7XG4gICAgICAgICAgICAgIGZvbnQtc2l6ZTogMC44NzVyZW07XG4gICAgICAgICAgICAgIGZvbnQtd2VpZ2h0OiA2MDA7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICBgLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxtYXQtYnV0dG9uLXRvZ2dsZS1ncm91cFxuICAgICAgWyhuZ01vZGVsKV09XCJzZWxlY3RlZFwiXG4gICAgICBbbXVsdGlwbGVdPVwiZmFsc2VcIlxuICAgICAgW2hpZGVTaW5nbGVTZWxlY3Rpb25JbmRpY2F0b3JdPVwidHJ1ZVwiXG4gICAgICBbZGlzYWJsZWRdPVwiZGlzYWJsZWQoKVwiXG4gICAgPlxuICAgICAgQGZvciAoc2VnbWVudGVkQnV0dG9uIG9mIHNlZ21lbnRlZEJ1dHRvbkVsZW1lbnRzKCk7IHRyYWNrIHNlZ21lbnRlZEJ1dHRvbikge1xuICAgICAgICA8bWF0LWJ1dHRvbi10b2dnbGVcbiAgICAgICAgICBbcm91dGVyTGlua109XCJzZWdtZW50ZWRCdXR0b24ubGluaygpXCJcbiAgICAgICAgICByb3V0ZXJMaW5rQWN0aXZlPVwibWF0LWJ1dHRvbi10b2dnbGUtY2hlY2tlZFwiXG4gICAgICAgICAgW2Rpc2FibGVSaXBwbGVdPVwidHJ1ZVwiXG4gICAgICAgICAgW3ZhbHVlXT1cInNlZ21lbnRlZEJ1dHRvbi52YWx1ZSgpXCJcbiAgICAgICAgPlxuICAgICAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJzZWdtZW50ZWRCdXR0b24udGVtcGxhdGVSZWYoKVwiIC8+XG4gICAgICAgIDwvbWF0LWJ1dHRvbi10b2dnbGU+XG4gICAgICB9XG4gICAgPC9tYXQtYnV0dG9uLXRvZ2dsZS1ncm91cD5cbiAgYCxcbn0pXG5leHBvcnQgY2xhc3MgV2F0dFNlZ21lbnRlZEJ1dHRvbnNDb21wb25lbnQgaW1wbGVtZW50cyBDb250cm9sVmFsdWVBY2Nlc3NvciB7XG4gIHByaXZhdGUgZWxlbWVudCA9IGluamVjdChFbGVtZW50UmVmKTtcbiAgc2VnbWVudGVkQnV0dG9uRWxlbWVudHMgPSBjb250ZW50Q2hpbGRyZW4oV2F0dFNlZ21lbnRlZEJ1dHRvbkNvbXBvbmVudCk7XG4gIHNlbGVjdGVkID0gbW9kZWw8c3RyaW5nPignJyk7XG4gIGRpc2FibGVkID0gc2lnbmFsKGZhbHNlKTtcblxuICB3cml0ZVZhbHVlKHNlbGVjdGVkOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLnNlbGVjdGVkLnNldChzZWxlY3RlZCk7XG4gIH1cblxuICByZWdpc3Rlck9uQ2hhbmdlKGZuOiAodmFsdWU6IHN0cmluZykgPT4gdm9pZCk6IHZvaWQge1xuICAgIHRoaXMuc2VsZWN0ZWQuc3Vic2NyaWJlKGZuKTtcbiAgfVxuXG4gIHJlZ2lzdGVyT25Ub3VjaGVkKGZuOiAodmFsdWU6IGJvb2xlYW4pID0+IHZvaWQpOiB2b2lkIHtcbiAgICB0aGlzLmVsZW1lbnQubmF0aXZlRWxlbWVudC5hZGRFdmVudExpc3RlbmVyKCdmb2N1c291dCcsIGZuKTtcbiAgfVxuXG4gIHNldERpc2FibGVkU3RhdGU/KGlzRGlzYWJsZWQ6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICB0aGlzLmRpc2FibGVkLnNldChpc0Rpc2FibGVkKTtcbiAgfVxufVxuIl19
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "type": "module",
3
3
  "name": "@energinet/watt",
4
- "version": "4.1.29",
4
+ "version": "4.1.31",
5
5
  "license": "Apache-2.0",
6
6
  "exports": {
7
7
  ".": {
@@ -18,7 +18,8 @@ import { TemplateRef } from '@angular/core';
18
18
  import * as i0 from "@angular/core";
19
19
  export declare class WattSegmentedButtonComponent {
20
20
  templateRef: import("@angular/core").Signal<TemplateRef<unknown>>;
21
- value: import("@angular/core").InputSignal<string>;
21
+ value: import("@angular/core").InputSignal<string | undefined>;
22
+ link: import("@angular/core").InputSignal<string | undefined>;
22
23
  static ɵfac: i0.ɵɵFactoryDeclaration<WattSegmentedButtonComponent, never>;
23
- static ɵcmp: i0.ɵɵComponentDeclaration<WattSegmentedButtonComponent, "watt-segmented-button", never, { "value": { "alias": "value"; "required": true; "isSignal": true; }; }, {}, never, ["*"], true, never>;
24
+ static ɵcmp: i0.ɵɵComponentDeclaration<WattSegmentedButtonComponent, "watt-segmented-button", never, { "value": { "alias": "value"; "required": false; "isSignal": true; }; "link": { "alias": "link"; "required": false; "isSignal": true; }; }, {}, never, ["*"], true, never>;
24
25
  }
@@ -1,19 +1,3 @@
1
- /**
2
- * @license
3
- * Copyright 2020 Energinet DataHub A/S
4
- *
5
- * Licensed under the Apache License, Version 2.0 (the "License2");
6
- * you may not use this file except in compliance with the License.
7
- * You may obtain a copy of the License at
8
- *
9
- * http://www.apache.org/licenses/LICENSE-2.0
10
- *
11
- * Unless required by applicable law or agreed to in writing, software
12
- * distributed under the License is distributed on an "AS IS" BASIS,
13
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
- * See the License for the specific language governing permissions and
15
- * limitations under the License.
16
- */
17
1
  import { ControlValueAccessor } from '@angular/forms';
18
2
  import { WattSegmentedButtonComponent } from './watt-segmented-button.component';
19
3
  import * as i0 from "@angular/core";
@@ -21,10 +5,10 @@ import * as i0 from "@angular/core";
21
5
  * Segmented buttons.
22
6
  */
23
7
  export declare class WattSegmentedButtonsComponent implements ControlValueAccessor {
8
+ private element;
24
9
  segmentedButtonElements: import("@angular/core").Signal<readonly WattSegmentedButtonComponent[]>;
25
10
  selected: import("@angular/core").ModelSignal<string>;
26
11
  disabled: import("@angular/core").WritableSignal<boolean>;
27
- private element;
28
12
  writeValue(selected: string): void;
29
13
  registerOnChange(fn: (value: string) => void): void;
30
14
  registerOnTouched(fn: (value: boolean) => void): void;