@ndwnu/design-system 9.0.0 → 9.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/images/map-backgrounds/osm-basic.webp +0 -0
- package/assets/images/map-backgrounds/osm-color-blind.webp +0 -0
- package/assets/images/map-backgrounds/osm-dark-with-highlighted-main-roads.webp +0 -0
- package/assets/images/map-backgrounds/osm-dark.webp +0 -0
- package/assets/images/map-backgrounds/osm-default-no-roads.webp +0 -0
- package/assets/images/map-backgrounds/osm-default-with-fcd-links_1-5.webp +0 -0
- package/assets/images/map-backgrounds/osm-default-with-fcd-roads.webp +0 -0
- package/assets/images/map-backgrounds/osm-default-with-fcd-segments.webp +0 -0
- package/assets/images/map-backgrounds/osm-default-with-mst.webp +0 -0
- package/assets/images/map-backgrounds/osm-default-with-nwb-roads-white.webp +0 -0
- package/assets/images/map-backgrounds/osm-default-with-nwb-roads.webp +0 -0
- package/assets/images/map-backgrounds/osm-default.webp +0 -0
- package/assets/images/map-backgrounds/osm-front-office-dark.webp +0 -0
- package/assets/images/map-backgrounds/osm-front-office-light-with-nwb-roads.webp +0 -0
- package/assets/images/map-backgrounds/osm-front-office-light.webp +0 -0
- package/assets/images/map-backgrounds/osm-green.webp +0 -0
- package/assets/images/map-layers/actueelverkeer1.webp +0 -0
- package/assets/images/map-layers/actueelverkeerv2.webp +0 -0
- package/assets/images/map-layers/beeldstand1.webp +0 -0
- package/assets/images/map-layers/beeldstand2.webp +0 -0
- package/assets/images/map-layers/hectometrering.webp +0 -0
- package/assets/images/map-layers/wegwerkzaamheden.webp +0 -0
- package/fesm2022/ndwnu-design-system.mjs +286 -28
- package/fesm2022/ndwnu-design-system.mjs.map +1 -1
- package/lib/components/badge/badge.component.d.ts +6 -1
- package/lib/components/index.d.ts +2 -0
- package/lib/components/main-navigation/main-navigation-header/main-navigation-header.component.d.ts +1 -1
- package/lib/components/map-display/backgrounds.d.ts +21 -0
- package/lib/components/map-display/index.d.ts +3 -0
- package/lib/components/map-display/layers.d.ts +10 -0
- package/lib/components/map-display/map-display-option/index.d.ts +2 -0
- package/lib/components/map-display/map-display-option/map-display-option.component.d.ts +11 -0
- package/lib/components/map-display/map-display-option/map-display-option.model.d.ts +14 -0
- package/lib/components/map-display/map-display.component.d.ts +30 -0
- package/package.json +2 -2
- package/lib/components/form-field/autosuggest/match-bold.pipe.d.ts +0 -7
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { input, Component, ChangeDetectionStrategy, output, model, inject, computed, Injectable, contentChildren, DestroyRef, ElementRef, Directive, viewChild, InjectionToken, contentChild, signal, EventEmitter, ViewContainerRef, Output, ChangeDetectorRef,
|
|
2
|
+
import { input, Component, ChangeDetectionStrategy, output, model, inject, computed, Injectable, contentChildren, DestroyRef, ElementRef, Directive, viewChild, InjectionToken, contentChild, signal, EventEmitter, ViewContainerRef, Output, ChangeDetectorRef, NgZone, forwardRef, TemplateRef, ViewChildren, PLATFORM_ID, effect, Renderer2, afterNextRender, linkedSignal, untracked, viewChildren } from '@angular/core';
|
|
3
3
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
4
|
-
import { CoreIconComponent } from '@ndwnu/core';
|
|
4
|
+
import { CoreIconComponent, MatchBoldPipe } from '@ndwnu/core';
|
|
5
5
|
import { trigger, state, style, transition, animate } from '@angular/animations';
|
|
6
6
|
import { Subject, take, merge, filter, of, map, defer, switchMap, fromEvent, delay, startWith } from 'rxjs';
|
|
7
|
-
import { NgClass, NgTemplateOutlet, DOCUMENT, isPlatformBrowser, AsyncPipe } from '@angular/common';
|
|
7
|
+
import { NgClass, NgTemplateOutlet, DOCUMENT, isPlatformBrowser, CommonModule, AsyncPipe } from '@angular/common';
|
|
8
8
|
import { RouterLink, ActivatedRoute, Router, NavigationEnd } from '@angular/router';
|
|
9
9
|
import { ConfigurableFocusTrapFactory, ActiveDescendantKeyManager, AriaDescriber } from '@angular/cdk/a11y';
|
|
10
|
-
import
|
|
10
|
+
import * as i1$1 from '@angular/cdk/overlay';
|
|
11
|
+
import { Overlay, ViewportRuler, OverlayConfig, ConnectionPositionPair, OverlayModule } from '@angular/cdk/overlay';
|
|
11
12
|
import { TemplatePortal, ComponentPortal, CdkPortalOutlet } from '@angular/cdk/portal';
|
|
12
13
|
import * as i1 from '@angular/forms';
|
|
13
14
|
import { FormsModule, NG_VALUE_ACCESSOR, NgControl, Validators } from '@angular/forms';
|
|
@@ -15,7 +16,7 @@ import { hasModifierKey } from '@angular/cdk/keycodes';
|
|
|
15
16
|
import { CdkScrollable } from '@angular/cdk/scrolling';
|
|
16
17
|
import { CdkMenu, CdkMenuItem, CdkMenuTrigger } from '@angular/cdk/menu';
|
|
17
18
|
import { Dialog } from '@angular/cdk/dialog';
|
|
18
|
-
import * as i1$
|
|
19
|
+
import * as i1$2 from '@angular/cdk/drag-drop';
|
|
19
20
|
import { CdkDrag, DragDropModule } from '@angular/cdk/drag-drop';
|
|
20
21
|
|
|
21
22
|
class BadgeComponent {
|
|
@@ -27,12 +28,17 @@ class BadgeComponent {
|
|
|
27
28
|
* The aria label, used by screen readers to give context.
|
|
28
29
|
*/
|
|
29
30
|
ariaLabel = input();
|
|
31
|
+
/**
|
|
32
|
+
* When true, the badge will display values above 99.
|
|
33
|
+
* When false (default), the badge will display values above 99 as a dot
|
|
34
|
+
*/
|
|
35
|
+
displayLargeNumbers = input(false);
|
|
30
36
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.7", ngImport: i0, type: BadgeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
31
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.0.7", type: BadgeComponent, isStandalone: true, selector: "ndw-badge", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, ariaLabel: { classPropertyName: "ariaLabel", publicName: "ariaLabel", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "@if (value(); as value) {\n @if (
|
|
37
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.0.7", type: BadgeComponent, isStandalone: true, selector: "ndw-badge", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, ariaLabel: { classPropertyName: "ariaLabel", publicName: "ariaLabel", isSignal: true, isRequired: false, transformFunction: null }, displayLargeNumbers: { classPropertyName: "displayLargeNumbers", publicName: "displayLargeNumbers", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "@if (value(); as value) {\n @if (!displayLargeNumbers() && (value < -9 || value > 99)) {\n <span class=\"dot\"></span>\n } @else {\n {{ value }}\n }\n} @else {\n {{ value() }}\n}\n@if (ariaLabel()) {\n <span class=\"sr-only\"> {{ ariaLabel() }}</span>\n}\n", styles: ["@import\"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400..650;1,9..40,400..650&family=Material+Symbols+Rounded:opsz,wght,FILL@20..48,400,0..1&family=Nunito+Sans:ital,opsz,wght@0,6..12,400..650;1,6..12,400..650&display=block\";.ndw-heading-xl{font-family:var(--ndw-font-family-heading);font-size:2.5rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-heading-lg{font-family:var(--ndw-font-family-heading);font-size:2rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-heading-md{font-family:var(--ndw-font-family-heading);font-size:1.5rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-heading-sm{font-family:var(--ndw-font-family-heading);font-size:1.25rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-paragraph-bold-xl{font-family:var(--ndw-font-family-body);font-size:1.125rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-paragraph-xl{font-family:var(--ndw-font-family-body);font-size:1.125rem;font-weight:var(--ndw-font-weight-regular);line-height:150%}.ndw-paragraph-bold-lg{font-family:var(--ndw-font-family-body);font-size:1rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-paragraph-lg{font-family:var(--ndw-font-family-body);font-size:1rem;font-weight:var(--ndw-font-weight-regular);line-height:150%}.ndw-paragraph-bold-md{font-family:var(--ndw-font-family-body);font-size:.8125rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-paragraph-md{font-family:var(--ndw-font-family-body);font-size:.8125rem;font-weight:var(--ndw-font-weight-regular);line-height:150%}.ndw-paragraph-bold-sm{font-family:var(--ndw-font-family-body);font-size:.6875rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-paragraph-sm{font-family:var(--ndw-font-family-body);font-size:.6875rem;font-weight:var(--ndw-font-weight-regular);line-height:150%}:host{font-family:var(--ndw-font-family-body);font-size:.6875rem;font-weight:var(--ndw-font-weight-bold);line-height:150%;--min-badge-size: 1.25rem;background-color:var(--ndw-color-notification);border-radius:var(--min-badge-size);box-sizing:border-box;color:var(--ndw-color-white);display:flex;align-items:center;justify-content:center;height:var(--min-badge-size);letter-spacing:-1px;text-align:center;padding-inline:var(--ndw-spacing-2xs);min-width:var(--min-badge-size);max-width:fit-content}.dot{display:block;background-color:var(--ndw-color-white);border-radius:50%;height:var(--ndw-spacing-2xs);width:var(--ndw-spacing-2xs)}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
32
38
|
}
|
|
33
39
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.7", ngImport: i0, type: BadgeComponent, decorators: [{
|
|
34
40
|
type: Component,
|
|
35
|
-
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'ndw-badge', template: "@if (value(); as value) {\n @if (
|
|
41
|
+
args: [{ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'ndw-badge', template: "@if (value(); as value) {\n @if (!displayLargeNumbers() && (value < -9 || value > 99)) {\n <span class=\"dot\"></span>\n } @else {\n {{ value }}\n }\n} @else {\n {{ value() }}\n}\n@if (ariaLabel()) {\n <span class=\"sr-only\"> {{ ariaLabel() }}</span>\n}\n", styles: ["@import\"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400..650;1,9..40,400..650&family=Material+Symbols+Rounded:opsz,wght,FILL@20..48,400,0..1&family=Nunito+Sans:ital,opsz,wght@0,6..12,400..650;1,6..12,400..650&display=block\";.ndw-heading-xl{font-family:var(--ndw-font-family-heading);font-size:2.5rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-heading-lg{font-family:var(--ndw-font-family-heading);font-size:2rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-heading-md{font-family:var(--ndw-font-family-heading);font-size:1.5rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-heading-sm{font-family:var(--ndw-font-family-heading);font-size:1.25rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-paragraph-bold-xl{font-family:var(--ndw-font-family-body);font-size:1.125rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-paragraph-xl{font-family:var(--ndw-font-family-body);font-size:1.125rem;font-weight:var(--ndw-font-weight-regular);line-height:150%}.ndw-paragraph-bold-lg{font-family:var(--ndw-font-family-body);font-size:1rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-paragraph-lg{font-family:var(--ndw-font-family-body);font-size:1rem;font-weight:var(--ndw-font-weight-regular);line-height:150%}.ndw-paragraph-bold-md{font-family:var(--ndw-font-family-body);font-size:.8125rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-paragraph-md{font-family:var(--ndw-font-family-body);font-size:.8125rem;font-weight:var(--ndw-font-weight-regular);line-height:150%}.ndw-paragraph-bold-sm{font-family:var(--ndw-font-family-body);font-size:.6875rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-paragraph-sm{font-family:var(--ndw-font-family-body);font-size:.6875rem;font-weight:var(--ndw-font-weight-regular);line-height:150%}:host{font-family:var(--ndw-font-family-body);font-size:.6875rem;font-weight:var(--ndw-font-weight-bold);line-height:150%;--min-badge-size: 1.25rem;background-color:var(--ndw-color-notification);border-radius:var(--min-badge-size);box-sizing:border-box;color:var(--ndw-color-white);display:flex;align-items:center;justify-content:center;height:var(--min-badge-size);letter-spacing:-1px;text-align:center;padding-inline:var(--ndw-spacing-2xs);min-width:var(--min-badge-size);max-width:fit-content}.dot{display:block;background-color:var(--ndw-color-white);border-radius:50%;height:var(--ndw-spacing-2xs);width:var(--ndw-spacing-2xs)}\n"] }]
|
|
36
42
|
}] });
|
|
37
43
|
|
|
38
44
|
class IconComponent extends CoreIconComponent {
|
|
@@ -125,7 +131,7 @@ class CollapsibleComponent {
|
|
|
125
131
|
}
|
|
126
132
|
}
|
|
127
133
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.7", ngImport: i0, type: CollapsibleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
128
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.0.7", type: CollapsibleComponent, isStandalone: true, selector: "ndw-collapsible", inputs: { index: { classPropertyName: "index", publicName: "index", isSignal: true, isRequired: true, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: true, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, expanded: { classPropertyName: "expanded", publicName: "expanded", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { expanded: "expandedChange" }, host: { properties: { "class.expanded": "expanded()" } }, ngImport: i0, template: "<div class=\"collapsible\">\n <h3 class=\"collapsible__header\">\n <button\n class=\"collapsible__button\"\n type=\"button\"\n [id]=\"toggleUuid\"\n [attr.aria-controls]=\"sectionUuid\"\n [attr.aria-expanded]=\"expanded()\"\n (click)=\"toggle()\"\n >\n {{ title() }}\n\n @if (value(); as value) {\n <ndw-badge [value]=\"value\" />\n }\n\n <ndw-icon>keyboard_arrow_down</ndw-icon>\n </button>\n </h3>\n\n <section\n role=\"region\"\n class=\"collapsible__section\"\n [id]=\"sectionUuid\"\n [attr.aria-labelledby]=\"toggleUuid\"\n [@collapsible]=\"animationState()\"\n >\n <ng-content />\n </section>\n</div>\n", styles: [".collapsible{display:block;border-bottom:var(--ndw-border-size-sm) solid var(--ndw-color-grey-200)}.collapsible__header{margin:0}.collapsible__button{overflow:hidden;display:flex;gap:var(--ndw-spacing-xs);justify-content:space-between;align-items:center;padding:0;width:100%;padding-block:var(--ndw-spacing-md);border:none;font-size:var(--ndw-font-size-sm);font-family:var(--ndw-font-family-body);font-weight:var(--ndw-font-weight-bold);word-break:break-word;cursor:pointer;background-color:transparent;transition:color var(--ndw-animation-speed-fast) ease-in-out}.collapsible__button:hover{color:var(--ndw-color-primary)}.collapsible__button:focus-visible{box-shadow:var(--ndw-elevation-info);outline:none;color:var(--ndw-color-primary)}.collapsible__button ndw-icon{margin-left:auto;color:var(--ndw-color-primary);transition:transform var(--ndw-animation-speed-fast) ease-in-out;font-size:var(--ndw-spacing-lg)}.collapsible__section{display:none;height:fit-content;margin-block:0;overflow:hidden;transition:height var(--ndw-animation-speed-fast) ease-in-out}:host(.expanded) .collapsible__header ndw-icon{transform:rotate(-180deg)}:host(.expanded) .collapsible__section{display:block;margin-block:var(--ndw-spacing-sm) var(--ndw-spacing-md)}\n"], dependencies: [{ kind: "component", type: BadgeComponent, selector: "ndw-badge", inputs: ["value", "ariaLabel"] }, { kind: "component", type: IconComponent, selector: "ndw-icon" }], animations: [collapsibleAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
134
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.0.7", type: CollapsibleComponent, isStandalone: true, selector: "ndw-collapsible", inputs: { index: { classPropertyName: "index", publicName: "index", isSignal: true, isRequired: true, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: true, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, expanded: { classPropertyName: "expanded", publicName: "expanded", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { expanded: "expandedChange" }, host: { properties: { "class.expanded": "expanded()" } }, ngImport: i0, template: "<div class=\"collapsible\">\n <h3 class=\"collapsible__header\">\n <button\n class=\"collapsible__button\"\n type=\"button\"\n [id]=\"toggleUuid\"\n [attr.aria-controls]=\"sectionUuid\"\n [attr.aria-expanded]=\"expanded()\"\n (click)=\"toggle()\"\n >\n {{ title() }}\n\n @if (value(); as value) {\n <ndw-badge [value]=\"value\" />\n }\n\n <ndw-icon>keyboard_arrow_down</ndw-icon>\n </button>\n </h3>\n\n <section\n role=\"region\"\n class=\"collapsible__section\"\n [id]=\"sectionUuid\"\n [attr.aria-labelledby]=\"toggleUuid\"\n [@collapsible]=\"animationState()\"\n >\n <ng-content />\n </section>\n</div>\n", styles: [".collapsible{display:block;border-bottom:var(--ndw-border-size-sm) solid var(--ndw-color-grey-200)}.collapsible__header{margin:0}.collapsible__button{overflow:hidden;display:flex;gap:var(--ndw-spacing-xs);justify-content:space-between;align-items:center;padding:0;width:100%;padding-block:var(--ndw-spacing-md);border:none;font-size:var(--ndw-font-size-sm);font-family:var(--ndw-font-family-body);font-weight:var(--ndw-font-weight-bold);word-break:break-word;cursor:pointer;background-color:transparent;transition:color var(--ndw-animation-speed-fast) ease-in-out}.collapsible__button:hover{color:var(--ndw-color-primary)}.collapsible__button:focus-visible{box-shadow:var(--ndw-elevation-info);outline:none;color:var(--ndw-color-primary)}.collapsible__button ndw-icon{margin-left:auto;color:var(--ndw-color-primary);transition:transform var(--ndw-animation-speed-fast) ease-in-out;font-size:var(--ndw-spacing-lg)}.collapsible__section{display:none;height:fit-content;margin-block:0;overflow:hidden;transition:height var(--ndw-animation-speed-fast) ease-in-out}:host(.expanded) .collapsible__header ndw-icon{transform:rotate(-180deg)}:host(.expanded) .collapsible__section{display:block;margin-block:var(--ndw-spacing-sm) var(--ndw-spacing-md)}\n"], dependencies: [{ kind: "component", type: BadgeComponent, selector: "ndw-badge", inputs: ["value", "ariaLabel", "displayLargeNumbers"] }, { kind: "component", type: IconComponent, selector: "ndw-icon" }], animations: [collapsibleAnimation], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
129
135
|
}
|
|
130
136
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.7", ngImport: i0, type: CollapsibleComponent, decorators: [{
|
|
131
137
|
type: Component,
|
|
@@ -774,24 +780,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.7", ngImpor
|
|
|
774
780
|
|
|
775
781
|
const INPUT_CONTAINER_CLASS = 'input-container';
|
|
776
782
|
|
|
777
|
-
class MatchBoldPipe {
|
|
778
|
-
transform(value, searchTerm) {
|
|
779
|
-
if (!searchTerm || typeof value !== 'string') {
|
|
780
|
-
return `${value}`;
|
|
781
|
-
}
|
|
782
|
-
const regex = new RegExp(`(${searchTerm})`, 'gi');
|
|
783
|
-
return value.replace(regex, '<b>$1</b>');
|
|
784
|
-
}
|
|
785
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.7", ngImport: i0, type: MatchBoldPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
786
|
-
static ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "19.0.7", ngImport: i0, type: MatchBoldPipe, isStandalone: true, name: "matchBold" });
|
|
787
|
-
}
|
|
788
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.7", ngImport: i0, type: MatchBoldPipe, decorators: [{
|
|
789
|
-
type: Pipe,
|
|
790
|
-
args: [{
|
|
791
|
-
name: 'matchBold',
|
|
792
|
-
}]
|
|
793
|
-
}] });
|
|
794
|
-
|
|
795
783
|
class BaseAutosuggestOptionComponent {
|
|
796
784
|
value = input();
|
|
797
785
|
selectionChange = new EventEmitter();
|
|
@@ -2850,6 +2838,276 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.7", ngImpor
|
|
|
2850
2838
|
args: [{ selector: 'ndw-map-button', imports: [IconComponent, TooltipDirective], changeDetection: ChangeDetectionStrategy.OnPush, template: "<button\n [disabled]=\"disabled()\"\n [class.active]=\"active()\"\n [attr.aria-label]=\"iconLabel()\"\n (click)=\"clicked.emit()\"\n [ndwTooltip]=\"iconLabel()\"\n>\n @if (svgIcon()) {\n <svg width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <use [attr.href]=\"'images/map-button-icons.svg#' + svgIcon()\"></use>\n </svg>\n } @else {\n <ndw-icon>{{ buttonIcon() }}</ndw-icon>\n }\n <div class=\"content-wrapper\">\n <ng-content />\n </div>\n</button>\n", styles: ["@import\"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400..650;1,9..40,400..650&family=Material+Symbols+Rounded:opsz,wght,FILL@20..48,400,0..1&family=Nunito+Sans:ital,opsz,wght@0,6..12,400..650;1,6..12,400..650&display=block\";.ndw-heading-xl{font-family:var(--ndw-font-family-heading);font-size:2.5rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-heading-lg{font-family:var(--ndw-font-family-heading);font-size:2rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-heading-md{font-family:var(--ndw-font-family-heading);font-size:1.5rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-heading-sm{font-family:var(--ndw-font-family-heading);font-size:1.25rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-paragraph-bold-xl{font-family:var(--ndw-font-family-body);font-size:1.125rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-paragraph-xl{font-family:var(--ndw-font-family-body);font-size:1.125rem;font-weight:var(--ndw-font-weight-regular);line-height:150%}.ndw-paragraph-bold-lg{font-family:var(--ndw-font-family-body);font-size:1rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-paragraph-lg{font-family:var(--ndw-font-family-body);font-size:1rem;font-weight:var(--ndw-font-weight-regular);line-height:150%}.ndw-paragraph-bold-md{font-family:var(--ndw-font-family-body);font-size:.8125rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-paragraph-md{font-family:var(--ndw-font-family-body);font-size:.8125rem;font-weight:var(--ndw-font-weight-regular);line-height:150%}.ndw-paragraph-bold-sm{font-family:var(--ndw-font-family-body);font-size:.6875rem;font-weight:var(--ndw-font-weight-bold);line-height:150%}.ndw-paragraph-sm{font-family:var(--ndw-font-family-body);font-size:.6875rem;font-weight:var(--ndw-font-weight-regular);line-height:150%}:host{width:fit-content}button{display:flex;align-items:center;justify-content:center;min-height:40px;min-width:40px;border:var(--ndw-border-size-sm) solid var(--ndw-color-grey-200);border-radius:var(--ndw-border-radius-sm);box-shadow:var(--ndw-elevation-content);color:var(--ndw-color-grey-500);background-color:var(--ndw-color-white)}button .content-wrapper:not(:empty){font-family:var(--ndw-font-family-body);font-size:.8125rem;font-weight:var(--ndw-font-weight-bold);line-height:150%;line-height:1rem;padding-inline:var(--ndw-spacing-xs)}button.active{color:var(--ndw-color-primary-500)}button.active ndw-icon{font-variation-settings:\"FILL\" 1}button:hover{background-color:var(--ndw-color-grey-100)}button:disabled{pointer-events:none;color:var(--ndw-color-grey-300)}\n"] }]
|
|
2851
2839
|
}] });
|
|
2852
2840
|
|
|
2841
|
+
class MapDisplayOptionComponent {
|
|
2842
|
+
option = input.required();
|
|
2843
|
+
direction = input('row');
|
|
2844
|
+
type = input('checkbox');
|
|
2845
|
+
group = input();
|
|
2846
|
+
selectionChange = output();
|
|
2847
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.7", ngImport: i0, type: MapDisplayOptionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
2848
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.0.7", type: MapDisplayOptionComponent, isStandalone: true, selector: "ndw-map-display-option", inputs: { option: { classPropertyName: "option", publicName: "option", isSignal: true, isRequired: true, transformFunction: null }, direction: { classPropertyName: "direction", publicName: "direction", isSignal: true, isRequired: false, transformFunction: null }, type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, group: { classPropertyName: "group", publicName: "group", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selectionChange: "selectionChange" }, ngImport: i0, template: "@if (type() === 'button') {\n <button\n type=\"button\"\n [title]=\"option()?.description ?? ''\"\n [class.column]=\"direction() === 'column'\"\n (click)=\"selectionChange.emit(option())\"\n >\n <ng-container *ngTemplateOutlet=\"template\" />\n <span class=\"name\">{{ option().name }}</span>\n </button>\n} @else if (type() === 'radio' || type() === 'checkbox') {\n <label [class.column]=\"direction() === 'column'\" [title]=\"option()?.description ?? ''\">\n <input\n [type]=\"type()\"\n name=\"{{ group() }}\"\n [checked]=\"option().active\"\n (change)=\"selectionChange.emit(option())\"\n />\n <ng-container *ngTemplateOutlet=\"template\" />\n <span class=\"name\">{{ option().name }}</span>\n </label>\n} @else {\n <ng-container *ngTemplateOutlet=\"template\" />\n}\n\n<ng-template #template>\n @if (option().imageLink) {\n <img [src]=\"option().imageLink\" [alt]=\"option().name\" />\n } @else {\n <ndw-icon>stacks</ndw-icon>\n }\n</ng-template>\n", styles: ["button,label{padding:0;border:0;display:flex;align-items:center;width:100%;height:40px;gap:var(--ndw-spacing-2xs);color:var(--ndw-color-grey-700);background-color:var(--ndw-color-white);transition:background-color var(--ndw-animation-speed-default) ease-out;border-radius:var(--ndw-border-radius-sm);cursor:pointer}button.column,label.column{flex-direction:column;justify-content:end;width:64px;height:64px}button:not(.column),label:not(.column){padding:var(--ndw-spacing-2xs);gap:var(--ndw-spacing-xs)}button:not(.column):has(input:checked),label:not(.column):has(input:checked){font-weight:var(--ndw-font-weight-bold)}button:hover,label:hover{background-color:var(--ndw-color-grey-100)}button:has(input:checked) img,button:has(input:checked) ndw-icon,label:has(input:checked) img,label:has(input:checked) ndw-icon{box-shadow:0 0 0 2px var(--ndw-color-secondary-400)}button input,label input{visibility:hidden;position:absolute;width:0;height:0;opacity:0;pointer-events:none;z-index:-1;left:-9999px;top:-9999px}img,ndw-icon{display:block;overflow:hidden;padding:var(--ndw-spacing-2xs);width:32px;height:32px;object-fit:cover;border:1px solid var(--ndw-color-grey-200);border-radius:var(--ndw-border-radius-xs)}.name{font-size:var(--ndw-font-size-sm);white-space:nowrap}\n"], dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: IconComponent, selector: "ndw-icon" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
2849
|
+
}
|
|
2850
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.7", ngImport: i0, type: MapDisplayOptionComponent, decorators: [{
|
|
2851
|
+
type: Component,
|
|
2852
|
+
args: [{ selector: 'ndw-map-display-option', imports: [NgTemplateOutlet, IconComponent], changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (type() === 'button') {\n <button\n type=\"button\"\n [title]=\"option()?.description ?? ''\"\n [class.column]=\"direction() === 'column'\"\n (click)=\"selectionChange.emit(option())\"\n >\n <ng-container *ngTemplateOutlet=\"template\" />\n <span class=\"name\">{{ option().name }}</span>\n </button>\n} @else if (type() === 'radio' || type() === 'checkbox') {\n <label [class.column]=\"direction() === 'column'\" [title]=\"option()?.description ?? ''\">\n <input\n [type]=\"type()\"\n name=\"{{ group() }}\"\n [checked]=\"option().active\"\n (change)=\"selectionChange.emit(option())\"\n />\n <ng-container *ngTemplateOutlet=\"template\" />\n <span class=\"name\">{{ option().name }}</span>\n </label>\n} @else {\n <ng-container *ngTemplateOutlet=\"template\" />\n}\n\n<ng-template #template>\n @if (option().imageLink) {\n <img [src]=\"option().imageLink\" [alt]=\"option().name\" />\n } @else {\n <ndw-icon>stacks</ndw-icon>\n }\n</ng-template>\n", styles: ["button,label{padding:0;border:0;display:flex;align-items:center;width:100%;height:40px;gap:var(--ndw-spacing-2xs);color:var(--ndw-color-grey-700);background-color:var(--ndw-color-white);transition:background-color var(--ndw-animation-speed-default) ease-out;border-radius:var(--ndw-border-radius-sm);cursor:pointer}button.column,label.column{flex-direction:column;justify-content:end;width:64px;height:64px}button:not(.column),label:not(.column){padding:var(--ndw-spacing-2xs);gap:var(--ndw-spacing-xs)}button:not(.column):has(input:checked),label:not(.column):has(input:checked){font-weight:var(--ndw-font-weight-bold)}button:hover,label:hover{background-color:var(--ndw-color-grey-100)}button:has(input:checked) img,button:has(input:checked) ndw-icon,label:has(input:checked) img,label:has(input:checked) ndw-icon{box-shadow:0 0 0 2px var(--ndw-color-secondary-400)}button input,label input{visibility:hidden;position:absolute;width:0;height:0;opacity:0;pointer-events:none;z-index:-1;left:-9999px;top:-9999px}img,ndw-icon{display:block;overflow:hidden;padding:var(--ndw-spacing-2xs);width:32px;height:32px;object-fit:cover;border:1px solid var(--ndw-color-grey-200);border-radius:var(--ndw-border-radius-xs)}.name{font-size:var(--ndw-font-size-sm);white-space:nowrap}\n"] }]
|
|
2853
|
+
}] });
|
|
2854
|
+
|
|
2855
|
+
class MapDisplayComponent {
|
|
2856
|
+
title = input('Kaarweergave');
|
|
2857
|
+
backgroundsTitle = input('Achtergrond');
|
|
2858
|
+
layersTitle = input('Gegevens');
|
|
2859
|
+
enableClearLayers = input(true);
|
|
2860
|
+
layerOptionType = input('checkbox');
|
|
2861
|
+
backgroundOptions = input([], {
|
|
2862
|
+
transform: (options) => (options ?? []).map((bg) => ({ ...bg })),
|
|
2863
|
+
});
|
|
2864
|
+
layerOptions = input([], {
|
|
2865
|
+
transform: (options) => (options ?? []).map((layer) => ({ ...layer })),
|
|
2866
|
+
});
|
|
2867
|
+
backgroundChange = output();
|
|
2868
|
+
layerChange = output();
|
|
2869
|
+
clearAllLayers = output();
|
|
2870
|
+
open = model(false);
|
|
2871
|
+
htmlIsRendered = signal(false);
|
|
2872
|
+
showPopover = computed(() => this.open() && this.htmlIsRendered());
|
|
2873
|
+
linkedBackgroundOptions = linkedSignal(this.backgroundOptions);
|
|
2874
|
+
activeBackgroundOption = computed(() => this.linkedBackgroundOptions()?.find((opt) => opt.active));
|
|
2875
|
+
linkedLayerOptions = linkedSignal(this.layerOptions);
|
|
2876
|
+
numberOfSelectedLayers = computed(() => this.linkedLayerOptions()?.filter((opt) => opt.active)?.length ?? 0);
|
|
2877
|
+
constructor() {
|
|
2878
|
+
afterNextRender(() => this.htmlIsRendered.set(true));
|
|
2879
|
+
}
|
|
2880
|
+
ngOnInit() {
|
|
2881
|
+
this.#initBackgroundOptions();
|
|
2882
|
+
}
|
|
2883
|
+
selectBackground(option) {
|
|
2884
|
+
this.linkedBackgroundOptions.update((options) => options.map((opt) => ({ ...opt, active: opt.id === option.id })));
|
|
2885
|
+
this.backgroundChange.emit(option);
|
|
2886
|
+
}
|
|
2887
|
+
toggleLayer(option) {
|
|
2888
|
+
const isRadio = this.layerOptionType() === 'radio';
|
|
2889
|
+
if (isRadio) {
|
|
2890
|
+
this.#resetAllLayers();
|
|
2891
|
+
}
|
|
2892
|
+
this.linkedLayerOptions.update((options) => options.map((opt) => {
|
|
2893
|
+
let newActive = !!opt.active;
|
|
2894
|
+
if (opt.id === option.id) {
|
|
2895
|
+
newActive = isRadio ? true : !opt.active;
|
|
2896
|
+
}
|
|
2897
|
+
const newOption = { ...opt, active: newActive };
|
|
2898
|
+
if (newOption.active !== opt.active) {
|
|
2899
|
+
this.layerChange.emit(newOption);
|
|
2900
|
+
}
|
|
2901
|
+
return newOption;
|
|
2902
|
+
}));
|
|
2903
|
+
}
|
|
2904
|
+
clearLayers() {
|
|
2905
|
+
this.#resetAllLayers();
|
|
2906
|
+
this.clearAllLayers.emit();
|
|
2907
|
+
}
|
|
2908
|
+
#resetAllLayers(options) {
|
|
2909
|
+
const { emitEvent = true } = options || {};
|
|
2910
|
+
this.linkedLayerOptions.update((options) => options.map((opt) => {
|
|
2911
|
+
const newOption = { ...opt, active: false };
|
|
2912
|
+
if (opt.active && emitEvent) {
|
|
2913
|
+
this.layerChange.emit(newOption);
|
|
2914
|
+
}
|
|
2915
|
+
return newOption;
|
|
2916
|
+
}));
|
|
2917
|
+
}
|
|
2918
|
+
#initBackgroundOptions() {
|
|
2919
|
+
const options = this.linkedBackgroundOptions();
|
|
2920
|
+
const activeBackground = options?.find((opt) => opt.active);
|
|
2921
|
+
if (!activeBackground && options?.length) {
|
|
2922
|
+
this.selectBackground(options[0]);
|
|
2923
|
+
}
|
|
2924
|
+
}
|
|
2925
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.7", ngImport: i0, type: MapDisplayComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
2926
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.0.7", type: MapDisplayComponent, isStandalone: true, selector: "ndw-map-display", inputs: { title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, backgroundsTitle: { classPropertyName: "backgroundsTitle", publicName: "backgroundsTitle", isSignal: true, isRequired: false, transformFunction: null }, layersTitle: { classPropertyName: "layersTitle", publicName: "layersTitle", isSignal: true, isRequired: false, transformFunction: null }, enableClearLayers: { classPropertyName: "enableClearLayers", publicName: "enableClearLayers", isSignal: true, isRequired: false, transformFunction: null }, layerOptionType: { classPropertyName: "layerOptionType", publicName: "layerOptionType", isSignal: true, isRequired: false, transformFunction: null }, backgroundOptions: { classPropertyName: "backgroundOptions", publicName: "backgroundOptions", isSignal: true, isRequired: false, transformFunction: null }, layerOptions: { classPropertyName: "layerOptions", publicName: "layerOptions", isSignal: true, isRequired: false, transformFunction: null }, open: { classPropertyName: "open", publicName: "open", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { backgroundChange: "backgroundChange", layerChange: "layerChange", clearAllLayers: "clearAllLayers", open: "openChange" }, ngImport: i0, template: "<div class=\"display\" [class.active]=\"open()\" cdkOverlayOrigin #trigger=\"cdkOverlayOrigin\">\n @let activeBackground = activeBackgroundOption();\n @if (activeBackground) {\n <ndw-map-display-option [option]=\"activeBackground\" [type]=\"'none'\" />\n }\n\n <button type=\"button\" (click)=\"open.set(!open())\">\n {{ title() }}\n </button>\n\n @if (numberOfSelectedLayers() && enableClearLayers()) {\n <ndw-tag (clicked)=\"clearLayers()\">{{ numberOfSelectedLayers() }}</ndw-tag>\n }\n\n <ndw-icon>keyboard_arrow_down</ndw-icon>\n</div>\n\n<ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayOpen]=\"showPopover()\"\n (detach)=\"open.set(false)\"\n (overlayOutsideClick)=\"open.set(false)\"\n>\n <div class=\"display-dropdown\">\n <header>\n <h3 class=\"ndw-paragraph-bold-lg\">{{ title() }}</h3>\n <button ndwButton tertiary title=\"Button\" type=\"button\" (click)=\"open.set(false)\">\n <ndw-icon>close</ndw-icon>\n </button>\n </header>\n\n <div class=\"display-dropdown__content\">\n @if (linkedBackgroundOptions().length) {\n <section class=\"display-dropdown__section\">\n <h4 class=\"ndw-paragraph-bold-md display-dropdown__subtitle\">{{ backgroundsTitle() }}</h4>\n <ul class=\"display-dropdown__backgrounds\">\n @for (backgroundOption of linkedBackgroundOptions(); track backgroundOption.id) {\n <li>\n <ndw-map-display-option\n [option]=\"backgroundOption\"\n [group]=\"'map-backgrounds'\"\n [type]=\"'radio'\"\n [direction]=\"'column'\"\n (selectionChange)=\"selectBackground($event)\"\n />\n </li>\n }\n </ul>\n </section>\n }\n\n @if (linkedLayerOptions()?.length) {\n <section class=\"display-dropdown__section\">\n <h4 class=\"ndw-paragraph-bold-md display-dropdown__subtitle\">{{ layersTitle() }}</h4>\n <ul>\n @for (layerOption of linkedLayerOptions(); track layerOption.id) {\n <li>\n <ndw-map-display-option\n [option]=\"layerOption\"\n [group]=\"'map-layers'\"\n [type]=\"layerOptionType()\"\n [direction]=\"'row'\"\n (selectionChange)=\"toggleLayer($event)\"\n />\n </li>\n }\n </ul>\n </section>\n }\n </div>\n </div>\n</ng-template>\n", styles: [".display{position:relative;overflow:hidden;display:inline-flex;gap:var(--ndw-spacing-2xs);align-items:center;height:40px;padding:.25rem;border:1px solid var(--ndw-color-grey-200);border-radius:var(--ndw-border-radius-sm);background-color:var(--ndw-color-white);transition:var(--ndw-animation-speed-default)}.display:hover{background-color:var(--ndw-color-grey-100)}.display.active ndw-icon{rotate:180deg}.display button{border:none;background:none;padding:var(--ndw-spacing-xs);color:var(--ndw-color-grey-600);font-size:var(--ndw-font-size-sm);font-weight:var(--ndw-font-weight-bold)}.display button:after{content:\"\";position:absolute;inset:0}.display ndw-icon{pointer-events:none;padding:.25rem;color:var(--ndw-color-primary);transition-property:rotate;transition-duration:var(--ndw-animation-speed-fast);transition-timing-function:ease-out;transition-delay:0s}.display-dropdown{max-height:380px;display:grid;grid-template-rows:max-content 1fr;padding:var(--ndw-spacing-2xs);width:226px;border:1px solid var(--ndw-color-grey-200);border-radius:var(--ndw-border-radius-sm);box-shadow:var(--ndw-elevation-dropdown);background-color:var(--ndw-color-white)}.display-dropdown header{display:flex;justify-content:space-between;align-items:center;gap:var(--ndw-spacing-xs);padding:var(--ndw-spacing-xs) 0 var(--ndw-spacing-xs) var(--ndw-spacing-2xs)}.display-dropdown header h3{color:var(--ndw-color-grey-600);margin-block:0}.display-dropdown__content{overflow-y:auto}.display-dropdown__section:not(:first-of-type){margin-top:var(--ndw-spacing-md)}.display-dropdown ul{margin-block-start:var(--ndw-spacing-xs);margin-block-end:0;list-style-type:none;padding:0}.display-dropdown ul.display-dropdown__backgrounds{display:flex;flex-wrap:wrap;align-items:start;justify-content:space-between;gap:var(--ndw-spacing-2xs)}.display-dropdown__subtitle{color:var(--ndw-color-grey-600);padding-inline:var(--ndw-spacing-2xs);margin-block:0}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: MapDisplayOptionComponent, selector: "ndw-map-display-option", inputs: ["option", "direction", "type", "group"], outputs: ["selectionChange"] }, { kind: "ngmodule", type: OverlayModule }, { kind: "directive", type: i1$1.CdkConnectedOverlay, selector: "[cdk-connected-overlay], [connected-overlay], [cdkConnectedOverlay]", inputs: ["cdkConnectedOverlayOrigin", "cdkConnectedOverlayPositions", "cdkConnectedOverlayPositionStrategy", "cdkConnectedOverlayOffsetX", "cdkConnectedOverlayOffsetY", "cdkConnectedOverlayWidth", "cdkConnectedOverlayHeight", "cdkConnectedOverlayMinWidth", "cdkConnectedOverlayMinHeight", "cdkConnectedOverlayBackdropClass", "cdkConnectedOverlayPanelClass", "cdkConnectedOverlayViewportMargin", "cdkConnectedOverlayScrollStrategy", "cdkConnectedOverlayOpen", "cdkConnectedOverlayDisableClose", "cdkConnectedOverlayTransformOriginOn", "cdkConnectedOverlayHasBackdrop", "cdkConnectedOverlayLockPosition", "cdkConnectedOverlayFlexibleDimensions", "cdkConnectedOverlayGrowAfterOpen", "cdkConnectedOverlayPush", "cdkConnectedOverlayDisposeOnNavigation"], outputs: ["backdropClick", "positionChange", "attach", "detach", "overlayKeydown", "overlayOutsideClick"], exportAs: ["cdkConnectedOverlay"] }, { kind: "directive", type: i1$1.CdkOverlayOrigin, selector: "[cdk-overlay-origin], [overlay-origin], [cdkOverlayOrigin]", exportAs: ["cdkOverlayOrigin"] }, { kind: "component", type: IconComponent, selector: "ndw-icon" }, { kind: "component", type: TagComponent, selector: "ndw-tag", inputs: ["disabled", "suffixAriaLabel", "suffixIcon"], outputs: ["clicked"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
2927
|
+
}
|
|
2928
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.7", ngImport: i0, type: MapDisplayComponent, decorators: [{
|
|
2929
|
+
type: Component,
|
|
2930
|
+
args: [{ selector: 'ndw-map-display', imports: [CommonModule, MapDisplayOptionComponent, OverlayModule, IconComponent, TagComponent], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"display\" [class.active]=\"open()\" cdkOverlayOrigin #trigger=\"cdkOverlayOrigin\">\n @let activeBackground = activeBackgroundOption();\n @if (activeBackground) {\n <ndw-map-display-option [option]=\"activeBackground\" [type]=\"'none'\" />\n }\n\n <button type=\"button\" (click)=\"open.set(!open())\">\n {{ title() }}\n </button>\n\n @if (numberOfSelectedLayers() && enableClearLayers()) {\n <ndw-tag (clicked)=\"clearLayers()\">{{ numberOfSelectedLayers() }}</ndw-tag>\n }\n\n <ndw-icon>keyboard_arrow_down</ndw-icon>\n</div>\n\n<ng-template\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayOpen]=\"showPopover()\"\n (detach)=\"open.set(false)\"\n (overlayOutsideClick)=\"open.set(false)\"\n>\n <div class=\"display-dropdown\">\n <header>\n <h3 class=\"ndw-paragraph-bold-lg\">{{ title() }}</h3>\n <button ndwButton tertiary title=\"Button\" type=\"button\" (click)=\"open.set(false)\">\n <ndw-icon>close</ndw-icon>\n </button>\n </header>\n\n <div class=\"display-dropdown__content\">\n @if (linkedBackgroundOptions().length) {\n <section class=\"display-dropdown__section\">\n <h4 class=\"ndw-paragraph-bold-md display-dropdown__subtitle\">{{ backgroundsTitle() }}</h4>\n <ul class=\"display-dropdown__backgrounds\">\n @for (backgroundOption of linkedBackgroundOptions(); track backgroundOption.id) {\n <li>\n <ndw-map-display-option\n [option]=\"backgroundOption\"\n [group]=\"'map-backgrounds'\"\n [type]=\"'radio'\"\n [direction]=\"'column'\"\n (selectionChange)=\"selectBackground($event)\"\n />\n </li>\n }\n </ul>\n </section>\n }\n\n @if (linkedLayerOptions()?.length) {\n <section class=\"display-dropdown__section\">\n <h4 class=\"ndw-paragraph-bold-md display-dropdown__subtitle\">{{ layersTitle() }}</h4>\n <ul>\n @for (layerOption of linkedLayerOptions(); track layerOption.id) {\n <li>\n <ndw-map-display-option\n [option]=\"layerOption\"\n [group]=\"'map-layers'\"\n [type]=\"layerOptionType()\"\n [direction]=\"'row'\"\n (selectionChange)=\"toggleLayer($event)\"\n />\n </li>\n }\n </ul>\n </section>\n }\n </div>\n </div>\n</ng-template>\n", styles: [".display{position:relative;overflow:hidden;display:inline-flex;gap:var(--ndw-spacing-2xs);align-items:center;height:40px;padding:.25rem;border:1px solid var(--ndw-color-grey-200);border-radius:var(--ndw-border-radius-sm);background-color:var(--ndw-color-white);transition:var(--ndw-animation-speed-default)}.display:hover{background-color:var(--ndw-color-grey-100)}.display.active ndw-icon{rotate:180deg}.display button{border:none;background:none;padding:var(--ndw-spacing-xs);color:var(--ndw-color-grey-600);font-size:var(--ndw-font-size-sm);font-weight:var(--ndw-font-weight-bold)}.display button:after{content:\"\";position:absolute;inset:0}.display ndw-icon{pointer-events:none;padding:.25rem;color:var(--ndw-color-primary);transition-property:rotate;transition-duration:var(--ndw-animation-speed-fast);transition-timing-function:ease-out;transition-delay:0s}.display-dropdown{max-height:380px;display:grid;grid-template-rows:max-content 1fr;padding:var(--ndw-spacing-2xs);width:226px;border:1px solid var(--ndw-color-grey-200);border-radius:var(--ndw-border-radius-sm);box-shadow:var(--ndw-elevation-dropdown);background-color:var(--ndw-color-white)}.display-dropdown header{display:flex;justify-content:space-between;align-items:center;gap:var(--ndw-spacing-xs);padding:var(--ndw-spacing-xs) 0 var(--ndw-spacing-xs) var(--ndw-spacing-2xs)}.display-dropdown header h3{color:var(--ndw-color-grey-600);margin-block:0}.display-dropdown__content{overflow-y:auto}.display-dropdown__section:not(:first-of-type){margin-top:var(--ndw-spacing-md)}.display-dropdown ul{margin-block-start:var(--ndw-spacing-xs);margin-block-end:0;list-style-type:none;padding:0}.display-dropdown ul.display-dropdown__backgrounds{display:flex;flex-wrap:wrap;align-items:start;justify-content:space-between;gap:var(--ndw-spacing-2xs)}.display-dropdown__subtitle{color:var(--ndw-color-grey-600);padding-inline:var(--ndw-spacing-2xs);margin-block:0}\n"] }]
|
|
2931
|
+
}], ctorParameters: () => [] });
|
|
2932
|
+
|
|
2933
|
+
const MAP_BACKGROUND_IMAGES = {
|
|
2934
|
+
OSM_DEFAULT: '/assets/images/map-backgrounds/osm-default.webp',
|
|
2935
|
+
OSM_BASIC: '/assets/images/map-backgrounds/osm-basic.webp',
|
|
2936
|
+
OSM_COLOR_BLIND: '/assets/images/map-backgrounds/osm-color-blind.webp',
|
|
2937
|
+
OSM_DARK: '/assets/images/map-backgrounds/osm-dark.webp',
|
|
2938
|
+
OSM_NO_ROADS: '/assets/images/map-backgrounds/osm-default-no-roads.webp',
|
|
2939
|
+
OSM_FCD_LINKS: '/assets/images/map-backgrounds/osm-default-with-fcd-links_1-5.webp',
|
|
2940
|
+
OSM_FCD_ROADS: '/assets/images/map-backgrounds/osm-default-with-fcd-roads.webp',
|
|
2941
|
+
OSM_FCD_SEGMENTS: '/assets/images/map-backgrounds/osm-default-with-fcd-segments.webp',
|
|
2942
|
+
OSM_MST: '/assets/images/map-backgrounds/osm-default-with-mst.webp',
|
|
2943
|
+
OSM_NWB_ROADS_WHITE: '/assets/images/map-backgrounds/osm-default-with-nwb-roads-white.webp',
|
|
2944
|
+
OSM_NWB_ROADS: '/assets/images/map-backgrounds/osm-default-with-nwb-roads.webp',
|
|
2945
|
+
OSM_DEFAULT_FULL: '/assets/images/map-backgrounds/osm-default.webp',
|
|
2946
|
+
OSM_FRONT_DARK: '/assets/images/map-backgrounds/osm-front-office-dark.webp',
|
|
2947
|
+
OSM_FRONT_LIGHT_NWB: '/assets/images/map-backgrounds/osm-front-office-light-with-nwb-roads.webp',
|
|
2948
|
+
OSM_FRONT_LIGHT: '/assets/images/map-backgrounds/osm-front-office-light.webp',
|
|
2949
|
+
OSM_GREEN: '/assets/images/map-backgrounds/osm-green.webp',
|
|
2950
|
+
};
|
|
2951
|
+
const MAP_BACKGROUNDS = {
|
|
2952
|
+
OSM_BASIC: {
|
|
2953
|
+
id: 'OSM_BASIC',
|
|
2954
|
+
name: 'Basis',
|
|
2955
|
+
imageLink: MAP_BACKGROUND_IMAGES.OSM_BASIC,
|
|
2956
|
+
style: 'https://maps.ndw.nu/styles/osm-basic.json',
|
|
2957
|
+
},
|
|
2958
|
+
OSM_DEFAULT: {
|
|
2959
|
+
id: 'OSM_DEFAULT',
|
|
2960
|
+
name: 'Standaard',
|
|
2961
|
+
description: 'Standaard',
|
|
2962
|
+
imageLink: MAP_BACKGROUND_IMAGES.OSM_DEFAULT,
|
|
2963
|
+
style: 'https://maps.ndw.nu/styles/osm-default.json',
|
|
2964
|
+
},
|
|
2965
|
+
OSM_COLOR_BLIND: {
|
|
2966
|
+
id: 'OSM_COLOR_BLIND',
|
|
2967
|
+
name: 'Kleuren',
|
|
2968
|
+
description: 'Kleurenblind',
|
|
2969
|
+
imageLink: MAP_BACKGROUND_IMAGES.OSM_COLOR_BLIND,
|
|
2970
|
+
style: 'https://maps.ndw.nu/styles/osm-color-blind.json',
|
|
2971
|
+
},
|
|
2972
|
+
OSM_DARK: {
|
|
2973
|
+
id: 'OSM_DARK',
|
|
2974
|
+
name: 'Donker',
|
|
2975
|
+
description: 'Donker',
|
|
2976
|
+
imageLink: MAP_BACKGROUND_IMAGES.OSM_DARK,
|
|
2977
|
+
style: 'https://maps.ndw.nu/styles/osm-dark.json',
|
|
2978
|
+
},
|
|
2979
|
+
OSM_NO_ROADS: {
|
|
2980
|
+
id: 'OSM_NO_ROADS',
|
|
2981
|
+
name: 'OSM N.R.',
|
|
2982
|
+
description: 'OSM zonder wegen',
|
|
2983
|
+
imageLink: MAP_BACKGROUND_IMAGES.OSM_NO_ROADS,
|
|
2984
|
+
style: 'https://maps.ndw.nu/styles/osm-default-no-roads.json',
|
|
2985
|
+
},
|
|
2986
|
+
OSM_FCD_LINKS: {
|
|
2987
|
+
id: 'OSM_FCD_LINKS',
|
|
2988
|
+
name: 'FCD L.',
|
|
2989
|
+
description: 'OSM met FCD links',
|
|
2990
|
+
imageLink: MAP_BACKGROUND_IMAGES.OSM_FCD_LINKS,
|
|
2991
|
+
style: 'https://maps.ndw.nu/styles/osm-default-with-fcd-links_1-5.json',
|
|
2992
|
+
},
|
|
2993
|
+
OSM_FCD_ROADS: {
|
|
2994
|
+
id: 'OSM_FCD_ROADS',
|
|
2995
|
+
name: 'FCD R.',
|
|
2996
|
+
description: 'OSM met FCD wegen',
|
|
2997
|
+
imageLink: MAP_BACKGROUND_IMAGES.OSM_FCD_ROADS,
|
|
2998
|
+
style: 'https://maps.ndw.nu/styles/osm-default-with-fcd-roads.json',
|
|
2999
|
+
},
|
|
3000
|
+
OSM_FCD_SEGMENTS: {
|
|
3001
|
+
id: 'OSM_FCD_SEGMENTS',
|
|
3002
|
+
name: 'FCD S.',
|
|
3003
|
+
description: 'OSM met FCD segmenten',
|
|
3004
|
+
imageLink: MAP_BACKGROUND_IMAGES.OSM_FCD_SEGMENTS,
|
|
3005
|
+
style: 'https://maps.ndw.nu/styles/osm-default-with-fcd-segments.json',
|
|
3006
|
+
},
|
|
3007
|
+
OSM_MST: {
|
|
3008
|
+
id: 'OSM_MST',
|
|
3009
|
+
name: 'OSM MST',
|
|
3010
|
+
description: 'OSM met MST',
|
|
3011
|
+
imageLink: MAP_BACKGROUND_IMAGES.OSM_MST,
|
|
3012
|
+
style: 'https://maps.ndw.nu/styles/osm-default-with-mst.json',
|
|
3013
|
+
},
|
|
3014
|
+
OSM_NWB_ROADS_WHITE: {
|
|
3015
|
+
id: 'OSM_NWB_ROADS_WHITE',
|
|
3016
|
+
name: 'NWB W.',
|
|
3017
|
+
description: 'OSM met NWB wegen (wit)',
|
|
3018
|
+
imageLink: MAP_BACKGROUND_IMAGES.OSM_NWB_ROADS_WHITE,
|
|
3019
|
+
style: 'https://maps.ndw.nu/styles/osm-default-with-nwb-roads-white.json',
|
|
3020
|
+
},
|
|
3021
|
+
OSM_NWB_ROADS: {
|
|
3022
|
+
id: 'OSM_NWB_ROADS',
|
|
3023
|
+
name: 'NWB',
|
|
3024
|
+
description: 'OSM met NWB',
|
|
3025
|
+
imageLink: MAP_BACKGROUND_IMAGES.OSM_NWB_ROADS,
|
|
3026
|
+
style: 'https://maps.ndw.nu/styles/osm-default-with-nwb-roads.json',
|
|
3027
|
+
},
|
|
3028
|
+
OSM_DEFAULT_FULL: {
|
|
3029
|
+
id: 'OSM_DEFAULT_FULL',
|
|
3030
|
+
name: 'Default',
|
|
3031
|
+
description: 'OSM standaard',
|
|
3032
|
+
imageLink: MAP_BACKGROUND_IMAGES.OSM_DEFAULT_FULL,
|
|
3033
|
+
style: 'https://maps.ndw.nu/styles/osm-default.json',
|
|
3034
|
+
},
|
|
3035
|
+
OSM_FRONT_DARK: {
|
|
3036
|
+
id: 'OSM_FRONT_DARK',
|
|
3037
|
+
name: 'OSM F.D.',
|
|
3038
|
+
description: 'OSM front office donker',
|
|
3039
|
+
imageLink: MAP_BACKGROUND_IMAGES.OSM_FRONT_DARK,
|
|
3040
|
+
style: 'https://maps.ndw.nu/styles/osm-front-office-dark.json',
|
|
3041
|
+
},
|
|
3042
|
+
OSM_FRONT_LIGHT_NWB: {
|
|
3043
|
+
id: 'OSM_FRONT_LIGHT_NWB',
|
|
3044
|
+
name: 'F.L. NWB',
|
|
3045
|
+
description: 'OSM front office licht met NWB wegen',
|
|
3046
|
+
imageLink: MAP_BACKGROUND_IMAGES.OSM_FRONT_LIGHT_NWB,
|
|
3047
|
+
style: 'https://maps.ndw.nu/styles/osm-front-office-light-with-nwb-roads.json',
|
|
3048
|
+
},
|
|
3049
|
+
OSM_FRONT_LIGHT: {
|
|
3050
|
+
id: 'OSM_FRONT_LIGHT',
|
|
3051
|
+
name: 'F.L.',
|
|
3052
|
+
description: 'OSM front office licht',
|
|
3053
|
+
imageLink: MAP_BACKGROUND_IMAGES.OSM_FRONT_LIGHT,
|
|
3054
|
+
style: 'https://maps.ndw.nu/styles/osm-front-office-light.json',
|
|
3055
|
+
},
|
|
3056
|
+
OSM_GREEN: {
|
|
3057
|
+
id: 'OSM_GREEN',
|
|
3058
|
+
name: 'OSM G.',
|
|
3059
|
+
description: 'OSM groen',
|
|
3060
|
+
imageLink: MAP_BACKGROUND_IMAGES.OSM_GREEN,
|
|
3061
|
+
style: 'https://maps.ndw.nu/styles/osm-green.json',
|
|
3062
|
+
},
|
|
3063
|
+
};
|
|
3064
|
+
const DEFAULT_BACKGROUNDS = [
|
|
3065
|
+
MAP_BACKGROUNDS['OSM_NWB_ROADS'],
|
|
3066
|
+
MAP_BACKGROUNDS['OSM_COLOR_BLIND'],
|
|
3067
|
+
MAP_BACKGROUNDS['OSM_DARK'],
|
|
3068
|
+
];
|
|
3069
|
+
|
|
3070
|
+
const MAP_LAYER_IMAGES = {
|
|
3071
|
+
ACTUAL_TRAFFIC_V1: '/assets/images/map-layers/actueelverkeer1.webp',
|
|
3072
|
+
ACTUAL_TRAFFIC_V2: '/assets/images/map-layers/actueelverkeerv2.webp',
|
|
3073
|
+
IMAGE_MODE_V1: '/assets/images/map-layers/beeldstand1.webp',
|
|
3074
|
+
IMAGE_MODE_V2: '/assets/images/map-layers/beeldstand2.webp',
|
|
3075
|
+
HECTOMETRY: '/assets/images/map-layers/hectometrering.webp',
|
|
3076
|
+
ROAD_WORKS: '/assets/images/map-layers/wegwerkzaamheden.webp',
|
|
3077
|
+
};
|
|
3078
|
+
const MAP_LAYERS = {
|
|
3079
|
+
ACTUAL_TRAFFIC_V1: {
|
|
3080
|
+
id: 'ACTUAL_TRAFFIC_V1',
|
|
3081
|
+
name: 'Actueel verkeer 1',
|
|
3082
|
+
imageLink: MAP_LAYER_IMAGES.ACTUAL_TRAFFIC_V1,
|
|
3083
|
+
},
|
|
3084
|
+
ACTUAL_TRAFFIC_V2: {
|
|
3085
|
+
id: 'ACTUAL_TRAFFIC_V2',
|
|
3086
|
+
name: 'Actueel verkeer 2',
|
|
3087
|
+
imageLink: MAP_LAYER_IMAGES.ACTUAL_TRAFFIC_V2,
|
|
3088
|
+
},
|
|
3089
|
+
IMAGE_MODE_V1: {
|
|
3090
|
+
id: 'IMAGE_MODE_V1',
|
|
3091
|
+
name: 'Beeldstand 1',
|
|
3092
|
+
imageLink: MAP_LAYER_IMAGES.IMAGE_MODE_V1,
|
|
3093
|
+
},
|
|
3094
|
+
IMAGE_MODE_V2: {
|
|
3095
|
+
id: 'IMAGE_MODE_V2',
|
|
3096
|
+
name: 'Beeldstand 2',
|
|
3097
|
+
imageLink: MAP_LAYER_IMAGES.IMAGE_MODE_V2,
|
|
3098
|
+
},
|
|
3099
|
+
HECTOMETRY: {
|
|
3100
|
+
id: 'HECTOMETRY',
|
|
3101
|
+
name: 'Hectometrering',
|
|
3102
|
+
imageLink: MAP_LAYER_IMAGES.HECTOMETRY,
|
|
3103
|
+
},
|
|
3104
|
+
ROAD_WORKS: {
|
|
3105
|
+
id: 'ROAD_WORKS',
|
|
3106
|
+
name: 'Wegwerkzaamheden',
|
|
3107
|
+
imageLink: MAP_LAYER_IMAGES.ROAD_WORKS,
|
|
3108
|
+
},
|
|
3109
|
+
};
|
|
3110
|
+
|
|
2853
3111
|
class ModalContentComponent {
|
|
2854
3112
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.7", ngImport: i0, type: ModalContentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
2855
3113
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.0.7", type: ModalContentComponent, isStandalone: true, selector: "ndw-modal-content", ngImport: i0, template: "<ng-content />\n", styles: [":host{font-size:var(--ndw-font-size-sm);max-height:100%;overflow-y:auto;word-break:break-word}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
@@ -3183,7 +3441,7 @@ class SplitterComponent {
|
|
|
3183
3441
|
return clamp(width, this.safeMinPanelWidth(), this.safeMaxPanelWidth());
|
|
3184
3442
|
}
|
|
3185
3443
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.0.7", ngImport: i0, type: SplitterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
3186
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.0.7", type: SplitterComponent, isStandalone: true, selector: "ndw-splitter", inputs: { disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, initialPanelWidth: { classPropertyName: "initialPanelWidth", publicName: "initialPanelWidth", isSignal: true, isRequired: false, transformFunction: null }, minimumPanelWidth: { classPropertyName: "minimumPanelWidth", publicName: "minimumPanelWidth", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.disabled": "disabled()" } }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true, isSignal: true }, { propertyName: "splitter", first: true, predicate: ["splitter"], descendants: true, isSignal: true }, { propertyName: "cdkDrag", first: true, predicate: CdkDrag, descendants: true, isSignal: true }], ngImport: i0, template: "<div #container class=\"panels\" [class.dragging]=\"isDragging()\">\n <div class=\"panel\" [style.width]=\"firstPanelWidth() + 'px'\">\n <ng-content select=\"[first-panel]\"></ng-content>\n </div>\n <div\n #splitter\n class=\"splitter\"\n role=\"separator\"\n aria-orientation=\"vertical\"\n [attr.aria-valuenow]=\"firstPanelWidth()\"\n [attr.aria-valuemin]=\"safeMinPanelWidth()\"\n [attr.aria-valuemax]=\"safeMaxPanelWidth()\"\n cdkDrag\n cdkDragLockAxis=\"x\"\n [class.disabled]=\"disabled()\"\n [cdkDragBoundary]=\"container\"\n (cdkDragStarted)=\"onDragStarted()\"\n (cdkDragMoved)=\"onDragMoved()\"\n (cdkDragEnded)=\"onDragEnded()\"\n (mousedown)=\"onSplitterMouseDown()\"\n (mouseup)=\"onSplitterMouseUp()\"\n [cdkDragConstrainPosition]=\"constrainPosition\"\n >\n <svg viewBox=\"0 0 4 28\" xmlns=\"http://www.w3.org/2000/svg\" role=\"presentation\">\n @for (i of [0, 1, 2]; track i) {\n <circle cx=\"2\" [attr.cy]=\"2 + i * 12\" r=\"2\" fill=\"currentColor\" />\n }\n </svg>\n </div>\n <div class=\"panel\" [style.width]=\"secondPanelWidth() + 'px'\">\n <ng-content select=\"[second-panel]\"></ng-content>\n </div>\n</div>\n", styles: [":host{display:block;--splitter-width: var(--ndw-spacing-sm);--half-splitter-width: calc(var(--splitter-width) / 2)}:host.disabled{--splitter-width: var(--ndw-spacing-2xs)}.panels{position:relative;display:flex;height:100%;width:100%}.panels .panel{display:flex;height:100%;width:50%;min-width:0;flex-grow:1;overflow:auto}.panels .panel:first-of-type{margin-right:calc(var(--half-splitter-width) - .5px)}.panels .panel:last-of-type{margin-left:calc(var(--half-splitter-width) - .5px)}.panels .splitter{position:absolute;left:calc(50% - var(--half-splitter-width));height:100%;width:var(--splitter-width);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:ew-resize;background-color:var(--ndw-color-grey-200)}.panels .splitter:hover,.panels .splitter.dragging{background-color:var(--ndw-color-grey-300);transition:background-color var(--ndw-animation-speed-fast) ease-in-out}.panels .splitter svg{color:var(--ndw-color-grey-400);width:var(--ndw-spacing-2xs)}.panels .splitter.disabled{pointer-events:none}.panels .splitter.disabled svg{display:none}.panels.dragging .splitter{background-color:var(--ndw-color-grey-300)}.panels:not(:hover .dragging) .panel{transition:width var(--ndw-animation-speed-fast) ease-in-out}.panels:not(:hover .dragging) .splitter{transition:all var(--ndw-animation-speed-fast) ease-in-out}\n"], dependencies: [{ kind: "ngmodule", type: DragDropModule }, { kind: "directive", type: i1$
|
|
3444
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.0.7", type: SplitterComponent, isStandalone: true, selector: "ndw-splitter", inputs: { disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, initialPanelWidth: { classPropertyName: "initialPanelWidth", publicName: "initialPanelWidth", isSignal: true, isRequired: false, transformFunction: null }, minimumPanelWidth: { classPropertyName: "minimumPanelWidth", publicName: "minimumPanelWidth", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class.disabled": "disabled()" } }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true, isSignal: true }, { propertyName: "splitter", first: true, predicate: ["splitter"], descendants: true, isSignal: true }, { propertyName: "cdkDrag", first: true, predicate: CdkDrag, descendants: true, isSignal: true }], ngImport: i0, template: "<div #container class=\"panels\" [class.dragging]=\"isDragging()\">\n <div class=\"panel\" [style.width]=\"firstPanelWidth() + 'px'\">\n <ng-content select=\"[first-panel]\"></ng-content>\n </div>\n <div\n #splitter\n class=\"splitter\"\n role=\"separator\"\n aria-orientation=\"vertical\"\n [attr.aria-valuenow]=\"firstPanelWidth()\"\n [attr.aria-valuemin]=\"safeMinPanelWidth()\"\n [attr.aria-valuemax]=\"safeMaxPanelWidth()\"\n cdkDrag\n cdkDragLockAxis=\"x\"\n [class.disabled]=\"disabled()\"\n [cdkDragBoundary]=\"container\"\n (cdkDragStarted)=\"onDragStarted()\"\n (cdkDragMoved)=\"onDragMoved()\"\n (cdkDragEnded)=\"onDragEnded()\"\n (mousedown)=\"onSplitterMouseDown()\"\n (mouseup)=\"onSplitterMouseUp()\"\n [cdkDragConstrainPosition]=\"constrainPosition\"\n >\n <svg viewBox=\"0 0 4 28\" xmlns=\"http://www.w3.org/2000/svg\" role=\"presentation\">\n @for (i of [0, 1, 2]; track i) {\n <circle cx=\"2\" [attr.cy]=\"2 + i * 12\" r=\"2\" fill=\"currentColor\" />\n }\n </svg>\n </div>\n <div class=\"panel\" [style.width]=\"secondPanelWidth() + 'px'\">\n <ng-content select=\"[second-panel]\"></ng-content>\n </div>\n</div>\n", styles: [":host{display:block;--splitter-width: var(--ndw-spacing-sm);--half-splitter-width: calc(var(--splitter-width) / 2)}:host.disabled{--splitter-width: var(--ndw-spacing-2xs)}.panels{position:relative;display:flex;height:100%;width:100%}.panels .panel{display:flex;height:100%;width:50%;min-width:0;flex-grow:1;overflow:auto}.panels .panel:first-of-type{margin-right:calc(var(--half-splitter-width) - .5px)}.panels .panel:last-of-type{margin-left:calc(var(--half-splitter-width) - .5px)}.panels .splitter{position:absolute;left:calc(50% - var(--half-splitter-width));height:100%;width:var(--splitter-width);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:ew-resize;background-color:var(--ndw-color-grey-200)}.panels .splitter:hover,.panels .splitter.dragging{background-color:var(--ndw-color-grey-300);transition:background-color var(--ndw-animation-speed-fast) ease-in-out}.panels .splitter svg{color:var(--ndw-color-grey-400);width:var(--ndw-spacing-2xs)}.panels .splitter.disabled{pointer-events:none}.panels .splitter.disabled svg{display:none}.panels.dragging .splitter{background-color:var(--ndw-color-grey-300)}.panels:not(:hover .dragging) .panel{transition:width var(--ndw-animation-speed-fast) ease-in-out}.panels:not(:hover .dragging) .splitter{transition:all var(--ndw-animation-speed-fast) ease-in-out}\n"], dependencies: [{ kind: "ngmodule", type: DragDropModule }, { kind: "directive", type: i1$2.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer", "cdkDragScale"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
3187
3445
|
}
|
|
3188
3446
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.7", ngImport: i0, type: SplitterComponent, decorators: [{
|
|
3189
3447
|
type: Component,
|
|
@@ -3492,5 +3750,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.0.7", ngImpor
|
|
|
3492
3750
|
* Generated bundle index. Do not edit.
|
|
3493
3751
|
*/
|
|
3494
3752
|
|
|
3495
|
-
export { AccordionComponent, AccordionService, ActionIconComponent, AlertComponent, AutoGrowDirective, AutocompleteOptionSelectionChange, AutosuggestAddOptionComponent, AutosuggestDirective, AutosuggestOptionComponent, AutosuggestPanelComponent, AvatarComponent, BadgeComponent, BannerComponent, BreadcrumbComponent, BreadcrumbGroupComponent, ButtonDirective, CARD_COMPONENTS, CARD_ID_TOKEN, CardComponent, CardContentComponent, CardFooterComponent, CardHeaderComponent, CheckboxComponent, CheckboxGroupComponent, CollapsibleComponent, DashboardCardComponent, DropdownComponent, EditBarActionsComponent, EditBarComponent, EditBarMessageComponent, ErrorComponent, FavoriteComponent, FileUploadComponent, FormFieldComponent, FormFieldElement, IconComponent, InfoComponent, InputButtonComponent, InputDirective, InputIconComponent, LayoutBannersComponent, LayoutComponent, LoaderComponent, MODAL_COMPONENTS, MainNavigationComponent, MapButtonComponent, MaxCharDirective, ModalComponent, ModalContentComponent, ModalFooterComponent, ModalHeaderComponent, ModalService, MonthInputComponent, MultiSelectComponent, OptionComponent, OptionGroupComponent, PillComponent, PopoverTriggerDirective, RadioButtonComponent, RadioGroupComponent, RouterBreadcrumbsComponent, SplitterComponent, SummaryCardActionComponent, SummaryCardActionsComponent, SummaryCardComponent, SummaryCardContentComponent, SummaryCardHeaderComponent, SummaryCardSubtitleComponent, SummaryCardTagComponent, SummaryCardTagsComponent, TabComponent, TabGroupComponent, TagComponent, ToastComponent, ToastService, TooltipComponent, TooltipDirective, breadcrumbRouteDataKey, fontMapButtonIcons, mapButtonIcons, svgMapButtonIcons };
|
|
3753
|
+
export { AccordionComponent, AccordionService, ActionIconComponent, AlertComponent, AutoGrowDirective, AutocompleteOptionSelectionChange, AutosuggestAddOptionComponent, AutosuggestDirective, AutosuggestOptionComponent, AutosuggestPanelComponent, AvatarComponent, BadgeComponent, BannerComponent, BreadcrumbComponent, BreadcrumbGroupComponent, ButtonDirective, CARD_COMPONENTS, CARD_ID_TOKEN, CardComponent, CardContentComponent, CardFooterComponent, CardHeaderComponent, CheckboxComponent, CheckboxGroupComponent, CollapsibleComponent, DEFAULT_BACKGROUNDS, DashboardCardComponent, DropdownComponent, EditBarActionsComponent, EditBarComponent, EditBarMessageComponent, ErrorComponent, FavoriteComponent, FileUploadComponent, FormFieldComponent, FormFieldElement, IconComponent, InfoComponent, InputButtonComponent, InputDirective, InputIconComponent, LayoutBannersComponent, LayoutComponent, LoaderComponent, MAP_BACKGROUNDS, MAP_BACKGROUND_IMAGES, MAP_LAYERS, MAP_LAYER_IMAGES, MODAL_COMPONENTS, MainNavigationComponent, MapButtonComponent, MapDisplayComponent, MapDisplayOptionComponent, MaxCharDirective, ModalComponent, ModalContentComponent, ModalFooterComponent, ModalHeaderComponent, ModalService, MonthInputComponent, MultiSelectComponent, OptionComponent, OptionGroupComponent, PillComponent, PopoverTriggerDirective, RadioButtonComponent, RadioGroupComponent, RouterBreadcrumbsComponent, SplitterComponent, SummaryCardActionComponent, SummaryCardActionsComponent, SummaryCardComponent, SummaryCardContentComponent, SummaryCardHeaderComponent, SummaryCardSubtitleComponent, SummaryCardTagComponent, SummaryCardTagsComponent, TabComponent, TabGroupComponent, TagComponent, ToastComponent, ToastService, TooltipComponent, TooltipDirective, breadcrumbRouteDataKey, fontMapButtonIcons, mapButtonIcons, svgMapButtonIcons };
|
|
3496
3754
|
//# sourceMappingURL=ndwnu-design-system.mjs.map
|