@datarailsshared/datarailsshared 1.6.415 → 1.6.416

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.
@@ -40,3 +40,13 @@ body.sb-show-main {
40
40
  text-transform: uppercase;
41
41
  text-decoration: underline;
42
42
  }
43
+
44
+ .no-scroll {
45
+ overflow: hidden;
46
+ pointer-events: none;
47
+
48
+ .ng-dropdown-panel {
49
+ pointer-events: auto;
50
+ overflow: auto;
51
+ }
52
+ }
@@ -1,4 +1,4 @@
1
- import { Component, ContentChild, ElementRef, EventEmitter, HostBinding, Input, Output, Renderer2, TemplateRef, ViewChild, } from '@angular/core';
1
+ import { Component, ContentChild, ElementRef, EventEmitter, HostBinding, inject, InjectionToken, Input, Output, Renderer2, TemplateRef, ViewChild, } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';
4
4
  import { NgSelectComponent } from '@ng-select/ng-select';
@@ -138,6 +138,7 @@ function DrSelectComponent_11_Template(rf, ctx) { if (rf & 1) {
138
138
  function DrSelectComponent_i_12_Template(rf, ctx) { if (rf & 1) {
139
139
  i0.ɵɵelement(0, "i", 19);
140
140
  } }
141
+ export const DR_SELECT_APPEND_TO = new InjectionToken('DR_SELECT_APPEND_TO');
141
142
  const SELECT_HOST_ATTRIBUTES = ['no-left-border', 'no-left-border-radius', 'no-right-border', 'no-right-border-radius'];
142
143
  export class DrSelectComponent {
143
144
  set borderless(val) {
@@ -152,7 +153,7 @@ export class DrSelectComponent {
152
153
  this.type = 'select';
153
154
  this.clearInputTextAfterSelection = false;
154
155
  this.items = [];
155
- this.appendTo = 'body';
156
+ this.appendTo = inject(DR_SELECT_APPEND_TO, { optional: true }) ?? 'body';
156
157
  this.minItemsToDisplaySearchInHeader = 11;
157
158
  this.loadingText = 'Loading...';
158
159
  this.disabled = false;
@@ -477,4 +478,4 @@ export class DrSelectComponent {
477
478
  type: HostBinding,
478
479
  args: ['class.borderless']
479
480
  }] }); })();
480
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-select.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-select/dr-select.component.ts","../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-select/dr-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnDestroy,\n    Output,\n    Renderer2,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { NgSelectComponent } from '@ng-select/ng-select';\nimport { NgSelectModule } from '@ng-select/ng-select';\nimport { ItemsList } from '@ng-select/ng-select/lib/items-list';\nimport { Subject } from 'rxjs';\nimport { DrInputComponent } from '../dr-input/dr-input.component';\nimport { DrSpinnerModule } from '../../dr-spinner/dr-spinner.module';\n\nconst SELECT_HOST_ATTRIBUTES = ['no-left-border', 'no-left-border-radius', 'no-right-border', 'no-right-border-radius'];\n\ninterface INgSelectComponentAccessor {\n    close: () => void;\n    open: () => void;\n    writeValue: (value: any) => void;\n    blur: () => void;\n    itemsList: ItemsList;\n    searchTerm: string;\n    searchInput: ElementRef;\n}\n\n@Component({\n    selector: 'dr-select',\n    standalone: true,\n    imports: [CommonModule, FormsModule, NgSelectModule, DrInputComponent, DrSpinnerModule],\n    templateUrl: './dr-select.component.html',\n    styleUrls: ['./dr-select.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: DrSelectComponent,\n            multi: true,\n        },\n    ],\n})\nexport class DrSelectComponent implements ControlValueAccessor, OnDestroy {\n    @Input()\n    @HostBinding('class')\n    type: 'select' | 'search-input' = 'select';\n\n    @Input() clearInputTextAfterSelection = false;\n    @Input() className: string;\n    @Input() items: Array<any> | Readonly<Array<any>> = [];\n    @Input() addTag: boolean | ((term: string) => any | Promise<any>);\n    @Input() appendTo = 'body';\n    @Input() bindLabel: string;\n    @Input() bindValue: string;\n    @Input() clearable: boolean;\n    @Input() compareWith: (o1: any, o2: any) => boolean;\n\n    @Input() searchable: boolean;\n    @Input() isDisplayingSearchInHeader: boolean;\n    @Input() minItemsToDisplaySearchInHeader = 11;\n\n    @Input() searchFn: (term: string, item: any) => boolean;\n    @Input() multiple: boolean;\n    @Input() multipleHeightIncreased?: boolean;\n    @Input() hideSelected: boolean;\n    @Input() maxSelectedItems: number;\n    @Input() placeholder: string;\n    @Input() loading: boolean;\n    @Input() loadingText: string = 'Loading...';\n    @Input() readonly: boolean;\n    @Input() disabled = false;\n    @Input() groupBy = null;\n    @Input() optionWithDescription = false;\n    @Input() id?: string;\n    @HostBinding('attr.id') hostId = null;\n    @Input() keyDownFn: ($event: KeyboardEvent) => boolean = () => true;\n    @Input() selectedItem: any;\n    @Input() dropdownClass: string;\n    @Input() closeOnSelect = true;\n\n    @Input() set borderless(val: boolean) {\n        this.asBorderless = val;\n    }\n\n    @Input() set textView(val: boolean) {\n        this.asTextView = val;\n    }\n\n    @Input() autofocus: boolean;\n    @Input() isOpen: boolean;\n    @Input() noValuePadding = false;\n    @Input() selectOnTabKeyPress = false;\n    @Input() virtualScroll = false;\n    @Input() typeahead!: Subject<string>;\n\n    @Output() search = new EventEmitter<{\n        term: string;\n        items: any[];\n    }>();\n    @Output() scrollToEnd = new EventEmitter<any>();\n    @Output() change: EventEmitter<any> = new EventEmitter<any>();\n    @Output() open: EventEmitter<any> = new EventEmitter<any>();\n    @Output() closeUp: EventEmitter<any> = new EventEmitter<any>();\n    @ViewChild(NgSelectComponent, { read: NgSelectComponent }) private readonly ngSelect: INgSelectComponentAccessor;\n    @ContentChild('labelTemplate') labelTemplate: TemplateRef<any>;\n    @ContentChild('multiLabelTemplate') multiLabelTemplate: TemplateRef<any>;\n    @ContentChild('optionTemplate') optionTemplate: TemplateRef<any>;\n    @ContentChild('optionHeaderTemplate') optionHeaderTemplate: TemplateRef<any>;\n    @ContentChild('optionFooterTemplate') optionFooterTemplate: TemplateRef<any>;\n    @ContentChild('notFoundTemplate') notFoundTemplate: TemplateRef<any>;\n    @HostBinding('class.textView') asTextView = false;\n    @HostBinding('class.borderless') asBorderless = false;\n    backdropElement: HTMLElement | null = null;\n    constructor(\n        private elementRef: ElementRef<HTMLElement>,\n        private renderer: Renderer2,\n    ) {\n        for (const attr of SELECT_HOST_ATTRIBUTES) {\n            if (this.hasHostAttributes(attr)) {\n                this.getHostElement().classList.add(attr);\n            }\n        }\n    }\n\n    onChange: (value: boolean) => void = () => {};\n    onTouched: () => void = () => {};\n\n    writeValue(value: any): void {\n        this.selectedItem = value;\n        this.onChange(this.selectedItem);\n\n        if (this.type === 'search-input' && !this.selectedItem && this.ngSelect) {\n            this.ngSelect.searchTerm = null;\n        }\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChange = fn;\n\n        if (fn && this.selectedItem) {\n            this.onChange(this.selectedItem);\n        }\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    setDisabledState(isDisabled: boolean) {\n        this.disabled = isDisabled;\n    }\n\n    openDropdown(): void {\n        this.ngSelect.open();\n    }\n\n    close(): void {\n        this.ngSelect.close();\n    }\n\n    onDropdownOpen(): void {\n        setTimeout(() => {\n            this.createBackdrop();\n            const classesToAdd = [];\n            if (this.asTextView) {\n                classesToAdd.push('textView');\n            }\n            if (typeof this.dropdownClass === 'string') {\n                classesToAdd.push(...this.dropdownClass.split(' '));\n            }\n            if (this.isDisplayingSearchInHeader && !this.optionHeaderTemplate) {\n                classesToAdd.push('ng-dropdown-panel--with-search');\n            }\n            const dropdown = document.querySelector('.ng-dropdown-panel');\n            if (dropdown) {\n                dropdown.classList.add(...classesToAdd);\n            }\n        }, 0);\n    }\n\n    onValueSelected(selectedItem: any) {\n        if (this.clearInputTextAfterSelection && this.ngSelect) {\n            this.ngSelect.searchTerm = null;\n        }\n\n        this.onChange(selectedItem);\n        this.change.emit(selectedItem);\n\n        this.ngSelect.blur();\n\n        if (this.searchable) {\n            this.ngSelect.searchInput.nativeElement.blur();\n        }\n    }\n\n    onTabKeypress(e) {\n        if (this.selectOnTabKeyPress && this.ngSelect) {\n            e.preventDefault();\n        }\n    }\n\n    onClose(event: any) {\n        this.closeUp.emit(event);\n        this.removeBackdrop();\n        if (this.type === 'search-input' && this.ngSelect.itemsList?.lastSelectedItem?.label) {\n            this.ngSelect.searchTerm = this.ngSelect.itemsList.lastSelectedItem.label;\n            this.ngSelect.itemsList.filter(this.ngSelect.searchTerm);\n        } else if (this.isDisplayingSearchInHeader) {\n            this.ngSelect.searchTerm = null;\n            this.ngSelect.itemsList.filter(null);\n        }\n    }\n\n    createBackdrop(): void {\n        this.renderer.addClass(document.body, 'no-scroll');\n        this.backdropElement = this.renderer.createElement('div');\n        this.renderer.addClass(this.backdropElement, 'custom-backdrop');\n        this.renderer.appendChild(document.body, this.backdropElement);\n    }\n\n    removeBackdrop(): void {\n        if (this.backdropElement) {\n            this.renderer.removeClass(document.body, 'no-scroll');\n            this.renderer.removeChild(document.body, this.backdropElement);\n            this.backdropElement = null;\n        }\n    }\n\n    private getHostElement(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    private hasHostAttributes(...attributes: string[]): boolean {\n        return attributes.some((attribute) => this.getHostElement().hasAttribute(attribute));\n    }\n\n    ngOnDestroy(): void {\n        this.removeBackdrop();\n        this.ngSelect?.close();\n    }\n}\n","<ng-select\n    [(ngModel)]=\"selectedItem\"\n    [items]=\"items\"\n    [bindLabel]=\"bindLabel\"\n    [bindValue]=\"bindValue\"\n    [multiple]=\"multiple\"\n    [addTag]=\"addTag\"\n    [appendTo]=\"appendTo\"\n    [clearable]=\"clearable\"\n    [searchable]=\"searchable\"\n    [hideSelected]=\"hideSelected\"\n    [placeholder]=\"placeholder\"\n    [loading]=\"loading\"\n    [loadingText]=\"loadingText\"\n    [readonly]=\"readonly\"\n    [closeOnSelect]=\"closeOnSelect\"\n    [disabled]=\"disabled\"\n    [labelForId]=\"id\"\n    [maxSelectedItems]=\"maxSelectedItems\"\n    [keyDownFn]=\"keyDownFn\"\n    [searchFn]=\"searchFn\"\n    [isOpen]=\"(type !== 'search-input' || !!selectComponent.searchTerm?.length) && isOpen\"\n    [groupBy]=\"groupBy\"\n    [attr.autofocus]=\"autofocus\"\n    [selectOnTab]=\"selectOnTabKeyPress\"\n    [virtualScroll]=\"virtualScroll\"\n    [typeahead]=\"typeahead\"\n    (search)=\"search.emit($event)\"\n    (scrollToEnd)=\"scrollToEnd.emit($event)\"\n    (keydown.tab)=\"onTabKeypress($event)\"\n    [compareWith]=\"compareWith\"\n    (change)=\"onValueSelected(selectedItem)\"\n    (open)=\"open.emit($event); onDropdownOpen()\"\n    (close)=\"onClose($event)\"\n    class=\"dr-select\"\n    [class.ng-select--no-value-padding]=\"noValuePadding\"\n    [class.ng-select--multiple-height-increased]=\"multipleHeightIncreased\"\n    #selectComponent>\n    <ng-template *ngIf=\"optionHeaderTemplate\" ng-header-tmp let-item=\"item\">\n        <ng-container [ngTemplateOutlet]=\"optionHeaderTemplate\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-container>\n    </ng-template>\n    <ng-template\n        ng-header-tmp\n        *ngIf=\"!optionHeaderTemplate && isDisplayingSearchInHeader && items?.length >= minItemsToDisplaySearchInHeader\"\n        let-item=\"item\">\n        <dr-input\n            class=\"dr-select__search\"\n            [ngModel]=\"selectComponent.searchTerm\"\n            (ngModelChange)=\"selectComponent.itemsList.filter($event + '')\"\n            type=\"search\">\n        </dr-input>\n    </ng-template>\n    <ng-template *ngIf=\"labelTemplate\" ng-label-tmp let-item=\"item\">\n        <ng-container [ngTemplateOutlet]=\"labelTemplate\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"multiLabelTemplate\" ng-multi-label-tmp let-items=\"items\" let-clear=\"clear\">\n        <ng-container [ngTemplateOutlet]=\"multiLabelTemplate\" [ngTemplateOutletContext]=\"{ items: items, clear: clear }\">\n        </ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"optionTemplate\" ng-option-tmp let-item=\"item\" let-item$=\"item$\">\n        <ng-container [ngTemplateOutlet]=\"optionTemplate\" [ngTemplateOutletContext]=\"{ item: item, item$: item$ }\"></ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"optionWithDescription\" ng-option-tmp let-item=\"item\">\n        <div class=\"dr-select__option-with-desc__wrapper\">\n            <div>{{ item.name }}</div>\n            <div class=\"dr-select__option-with-desc__description\">{{ item?.description }}</div>\n        </div>\n    </ng-template>\n    <ng-template *ngIf=\"optionFooterTemplate\" ng-footer-tmp let-item=\"item\">\n        <ng-container\n            [ngTemplateOutlet]=\"optionFooterTemplate\"\n            [ngTemplateOutletContext]=\"{ item: item, close: selectComponent.close.bind(selectComponent) }\"></ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"groupBy\" ng-optgroup-tmp let-item=\"item\">\n        {{ item[groupBy] }}\n    </ng-template>\n    <ng-template ng-loadingspinner-tmp>\n        <div\n            *ngIf=\"loading\"\n            class=\"dr-select__loading\"\n            [drSpinner]=\"loading\"\n            [drSpinnerType]=\"'circle'\"\n            [drSpinnerSize]=\"'small'\"\n            [drSpinnerNoOverlay]=\"true\"></div>\n    </ng-template>\n    <ng-template *ngIf=\"notFoundTemplate\" ng-notfound-tmp>\n        <ng-container [ngTemplateOutlet]=\"notFoundTemplate\"></ng-container>\n    </ng-template>\n</ng-select>\n<i *ngIf=\"type === 'search-input'\" class=\"search-icon dr-icon-search\"></i>\n"]}
481
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-select.component.js","sourceRoot":"","sources":["../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-select/dr-select.component.ts","../../../../../../projects/datarailsshared/src/lib/dr-inputs/dr-select/dr-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    inject,\n    InjectionToken,\n    Input,\n    OnDestroy,\n    Output,\n    Renderer2,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { NgSelectComponent } from '@ng-select/ng-select';\nimport { NgSelectModule } from '@ng-select/ng-select';\nimport { ItemsList } from '@ng-select/ng-select/lib/items-list';\nimport { Subject } from 'rxjs';\nimport { DrInputComponent } from '../dr-input/dr-input.component';\nimport { DrSpinnerModule } from '../../dr-spinner/dr-spinner.module';\n\nexport const DR_SELECT_APPEND_TO = new InjectionToken<string>('DR_SELECT_APPEND_TO');\n\nconst SELECT_HOST_ATTRIBUTES = ['no-left-border', 'no-left-border-radius', 'no-right-border', 'no-right-border-radius'];\n\ninterface INgSelectComponentAccessor {\n    close: () => void;\n    open: () => void;\n    writeValue: (value: any) => void;\n    blur: () => void;\n    itemsList: ItemsList;\n    searchTerm: string;\n    searchInput: ElementRef;\n}\n\n@Component({\n    selector: 'dr-select',\n    standalone: true,\n    imports: [CommonModule, FormsModule, NgSelectModule, DrInputComponent, DrSpinnerModule],\n    templateUrl: './dr-select.component.html',\n    styleUrls: ['./dr-select.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: DrSelectComponent,\n            multi: true,\n        },\n    ],\n})\nexport class DrSelectComponent implements ControlValueAccessor, OnDestroy {\n    @Input()\n    @HostBinding('class')\n    type: 'select' | 'search-input' = 'select';\n\n    @Input() clearInputTextAfterSelection = false;\n    @Input() className: string;\n    @Input() items: Array<any> | Readonly<Array<any>> = [];\n    @Input() addTag: boolean | ((term: string) => any | Promise<any>);\n    @Input() appendTo = inject(DR_SELECT_APPEND_TO, { optional: true }) ?? 'body';\n    @Input() bindLabel: string;\n    @Input() bindValue: string;\n    @Input() clearable: boolean;\n    @Input() compareWith: (o1: any, o2: any) => boolean;\n\n    @Input() searchable: boolean;\n    @Input() isDisplayingSearchInHeader: boolean;\n    @Input() minItemsToDisplaySearchInHeader = 11;\n\n    @Input() searchFn: (term: string, item: any) => boolean;\n    @Input() multiple: boolean;\n    @Input() multipleHeightIncreased?: boolean;\n    @Input() hideSelected: boolean;\n    @Input() maxSelectedItems: number;\n    @Input() placeholder: string;\n    @Input() loading: boolean;\n    @Input() loadingText: string = 'Loading...';\n    @Input() readonly: boolean;\n    @Input() disabled = false;\n    @Input() groupBy = null;\n    @Input() optionWithDescription = false;\n    @Input() id?: string;\n    @HostBinding('attr.id') hostId = null;\n    @Input() keyDownFn: ($event: KeyboardEvent) => boolean = () => true;\n    @Input() selectedItem: any;\n    @Input() dropdownClass: string;\n    @Input() closeOnSelect = true;\n\n    @Input() set borderless(val: boolean) {\n        this.asBorderless = val;\n    }\n\n    @Input() set textView(val: boolean) {\n        this.asTextView = val;\n    }\n\n    @Input() autofocus: boolean;\n    @Input() isOpen: boolean;\n    @Input() noValuePadding = false;\n    @Input() selectOnTabKeyPress = false;\n    @Input() virtualScroll = false;\n    @Input() typeahead!: Subject<string>;\n\n    @Output() search = new EventEmitter<{\n        term: string;\n        items: any[];\n    }>();\n    @Output() scrollToEnd = new EventEmitter<any>();\n    @Output() change: EventEmitter<any> = new EventEmitter<any>();\n    @Output() open: EventEmitter<any> = new EventEmitter<any>();\n    @Output() closeUp: EventEmitter<any> = new EventEmitter<any>();\n    @ViewChild(NgSelectComponent, { read: NgSelectComponent }) private readonly ngSelect: INgSelectComponentAccessor;\n    @ContentChild('labelTemplate') labelTemplate: TemplateRef<any>;\n    @ContentChild('multiLabelTemplate') multiLabelTemplate: TemplateRef<any>;\n    @ContentChild('optionTemplate') optionTemplate: TemplateRef<any>;\n    @ContentChild('optionHeaderTemplate') optionHeaderTemplate: TemplateRef<any>;\n    @ContentChild('optionFooterTemplate') optionFooterTemplate: TemplateRef<any>;\n    @ContentChild('notFoundTemplate') notFoundTemplate: TemplateRef<any>;\n    @HostBinding('class.textView') asTextView = false;\n    @HostBinding('class.borderless') asBorderless = false;\n    backdropElement: HTMLElement | null = null;\n    constructor(\n        private elementRef: ElementRef<HTMLElement>,\n        private renderer: Renderer2,\n    ) {\n        for (const attr of SELECT_HOST_ATTRIBUTES) {\n            if (this.hasHostAttributes(attr)) {\n                this.getHostElement().classList.add(attr);\n            }\n        }\n    }\n\n    onChange: (value: boolean) => void = () => {};\n    onTouched: () => void = () => {};\n\n    writeValue(value: any): void {\n        this.selectedItem = value;\n        this.onChange(this.selectedItem);\n\n        if (this.type === 'search-input' && !this.selectedItem && this.ngSelect) {\n            this.ngSelect.searchTerm = null;\n        }\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChange = fn;\n\n        if (fn && this.selectedItem) {\n            this.onChange(this.selectedItem);\n        }\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    setDisabledState(isDisabled: boolean) {\n        this.disabled = isDisabled;\n    }\n\n    openDropdown(): void {\n        this.ngSelect.open();\n    }\n\n    close(): void {\n        this.ngSelect.close();\n    }\n\n    onDropdownOpen(): void {\n        setTimeout(() => {\n            this.createBackdrop();\n            const classesToAdd = [];\n            if (this.asTextView) {\n                classesToAdd.push('textView');\n            }\n            if (typeof this.dropdownClass === 'string') {\n                classesToAdd.push(...this.dropdownClass.split(' '));\n            }\n            if (this.isDisplayingSearchInHeader && !this.optionHeaderTemplate) {\n                classesToAdd.push('ng-dropdown-panel--with-search');\n            }\n            const dropdown = document.querySelector('.ng-dropdown-panel');\n            if (dropdown) {\n                dropdown.classList.add(...classesToAdd);\n            }\n        }, 0);\n    }\n\n    onValueSelected(selectedItem: any) {\n        if (this.clearInputTextAfterSelection && this.ngSelect) {\n            this.ngSelect.searchTerm = null;\n        }\n\n        this.onChange(selectedItem);\n        this.change.emit(selectedItem);\n\n        this.ngSelect.blur();\n\n        if (this.searchable) {\n            this.ngSelect.searchInput.nativeElement.blur();\n        }\n    }\n\n    onTabKeypress(e) {\n        if (this.selectOnTabKeyPress && this.ngSelect) {\n            e.preventDefault();\n        }\n    }\n\n    onClose(event: any) {\n        this.closeUp.emit(event);\n        this.removeBackdrop();\n        if (this.type === 'search-input' && this.ngSelect.itemsList?.lastSelectedItem?.label) {\n            this.ngSelect.searchTerm = this.ngSelect.itemsList.lastSelectedItem.label;\n            this.ngSelect.itemsList.filter(this.ngSelect.searchTerm);\n        } else if (this.isDisplayingSearchInHeader) {\n            this.ngSelect.searchTerm = null;\n            this.ngSelect.itemsList.filter(null);\n        }\n    }\n\n    createBackdrop(): void {\n        this.renderer.addClass(document.body, 'no-scroll');\n        this.backdropElement = this.renderer.createElement('div');\n        this.renderer.addClass(this.backdropElement, 'custom-backdrop');\n        this.renderer.appendChild(document.body, this.backdropElement);\n    }\n\n    removeBackdrop(): void {\n        if (this.backdropElement) {\n            this.renderer.removeClass(document.body, 'no-scroll');\n            this.renderer.removeChild(document.body, this.backdropElement);\n            this.backdropElement = null;\n        }\n    }\n\n    private getHostElement(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    private hasHostAttributes(...attributes: string[]): boolean {\n        return attributes.some((attribute) => this.getHostElement().hasAttribute(attribute));\n    }\n\n    ngOnDestroy(): void {\n        this.removeBackdrop();\n        this.ngSelect?.close();\n    }\n}\n","<ng-select\n    [(ngModel)]=\"selectedItem\"\n    [items]=\"items\"\n    [bindLabel]=\"bindLabel\"\n    [bindValue]=\"bindValue\"\n    [multiple]=\"multiple\"\n    [addTag]=\"addTag\"\n    [appendTo]=\"appendTo\"\n    [clearable]=\"clearable\"\n    [searchable]=\"searchable\"\n    [hideSelected]=\"hideSelected\"\n    [placeholder]=\"placeholder\"\n    [loading]=\"loading\"\n    [loadingText]=\"loadingText\"\n    [readonly]=\"readonly\"\n    [closeOnSelect]=\"closeOnSelect\"\n    [disabled]=\"disabled\"\n    [labelForId]=\"id\"\n    [maxSelectedItems]=\"maxSelectedItems\"\n    [keyDownFn]=\"keyDownFn\"\n    [searchFn]=\"searchFn\"\n    [isOpen]=\"(type !== 'search-input' || !!selectComponent.searchTerm?.length) && isOpen\"\n    [groupBy]=\"groupBy\"\n    [attr.autofocus]=\"autofocus\"\n    [selectOnTab]=\"selectOnTabKeyPress\"\n    [virtualScroll]=\"virtualScroll\"\n    [typeahead]=\"typeahead\"\n    (search)=\"search.emit($event)\"\n    (scrollToEnd)=\"scrollToEnd.emit($event)\"\n    (keydown.tab)=\"onTabKeypress($event)\"\n    [compareWith]=\"compareWith\"\n    (change)=\"onValueSelected(selectedItem)\"\n    (open)=\"open.emit($event); onDropdownOpen()\"\n    (close)=\"onClose($event)\"\n    class=\"dr-select\"\n    [class.ng-select--no-value-padding]=\"noValuePadding\"\n    [class.ng-select--multiple-height-increased]=\"multipleHeightIncreased\"\n    #selectComponent>\n    <ng-template *ngIf=\"optionHeaderTemplate\" ng-header-tmp let-item=\"item\">\n        <ng-container [ngTemplateOutlet]=\"optionHeaderTemplate\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-container>\n    </ng-template>\n    <ng-template\n        ng-header-tmp\n        *ngIf=\"!optionHeaderTemplate && isDisplayingSearchInHeader && items?.length >= minItemsToDisplaySearchInHeader\"\n        let-item=\"item\">\n        <dr-input\n            class=\"dr-select__search\"\n            [ngModel]=\"selectComponent.searchTerm\"\n            (ngModelChange)=\"selectComponent.itemsList.filter($event + '')\"\n            type=\"search\">\n        </dr-input>\n    </ng-template>\n    <ng-template *ngIf=\"labelTemplate\" ng-label-tmp let-item=\"item\">\n        <ng-container [ngTemplateOutlet]=\"labelTemplate\" [ngTemplateOutletContext]=\"{ item: item }\"></ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"multiLabelTemplate\" ng-multi-label-tmp let-items=\"items\" let-clear=\"clear\">\n        <ng-container [ngTemplateOutlet]=\"multiLabelTemplate\" [ngTemplateOutletContext]=\"{ items: items, clear: clear }\">\n        </ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"optionTemplate\" ng-option-tmp let-item=\"item\" let-item$=\"item$\">\n        <ng-container [ngTemplateOutlet]=\"optionTemplate\" [ngTemplateOutletContext]=\"{ item: item, item$: item$ }\"></ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"optionWithDescription\" ng-option-tmp let-item=\"item\">\n        <div class=\"dr-select__option-with-desc__wrapper\">\n            <div>{{ item.name }}</div>\n            <div class=\"dr-select__option-with-desc__description\">{{ item?.description }}</div>\n        </div>\n    </ng-template>\n    <ng-template *ngIf=\"optionFooterTemplate\" ng-footer-tmp let-item=\"item\">\n        <ng-container\n            [ngTemplateOutlet]=\"optionFooterTemplate\"\n            [ngTemplateOutletContext]=\"{ item: item, close: selectComponent.close.bind(selectComponent) }\"></ng-container>\n    </ng-template>\n    <ng-template *ngIf=\"groupBy\" ng-optgroup-tmp let-item=\"item\">\n        {{ item[groupBy] }}\n    </ng-template>\n    <ng-template ng-loadingspinner-tmp>\n        <div\n            *ngIf=\"loading\"\n            class=\"dr-select__loading\"\n            [drSpinner]=\"loading\"\n            [drSpinnerType]=\"'circle'\"\n            [drSpinnerSize]=\"'small'\"\n            [drSpinnerNoOverlay]=\"true\"></div>\n    </ng-template>\n    <ng-template *ngIf=\"notFoundTemplate\" ng-notfound-tmp>\n        <ng-container [ngTemplateOutlet]=\"notFoundTemplate\"></ng-container>\n    </ng-template>\n</ng-select>\n<i *ngIf=\"type === 'search-input'\" class=\"search-icon dr-icon-search\"></i>\n"]}
@@ -16,8 +16,8 @@ export class DrModalContainerComponent extends CdkDialogContainer {
16
16
  this.animationState = signal(null);
17
17
  this.animationClass = computed(() => (this.animationState() ? this.animationClasses[this.animationState()] : ''));
18
18
  this.animationTime = computed(() => this.animationNoop ? 0 : this.animationDuration[this.animationState() ?? 'enter']);
19
- this.hasTitle = signal(false); // updated from title directive
20
- this.hasSubtitle = signal(false); // updated from subtitle directive
19
+ this.labelledBy = signal(null); // updated from title directive
20
+ this.describedBy = signal(null); // updated from subtitle directive
21
21
  this.elementRef = inject(ElementRef);
22
22
  }
23
23
  _contentAttached() {
@@ -46,7 +46,7 @@ export class DrModalContainerComponent extends CdkDialogContainer {
46
46
  /** @nocollapse */ static { this.ɵfac = /** @pureOrBreakMyCode */ function () { let ɵDrModalContainerComponent_BaseFactory; return function DrModalContainerComponent_Factory(t) { return (ɵDrModalContainerComponent_BaseFactory || (ɵDrModalContainerComponent_BaseFactory = i0.ɵɵgetInheritedFactory(DrModalContainerComponent)))(t || DrModalContainerComponent); }; }(); }
47
47
  /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrModalContainerComponent, selectors: [["dr-modal-container"]], hostAttrs: [1, "dr-modal-container"], hostVars: 12, hostBindings: function DrModalContainerComponent_HostBindings(rf, ctx) { if (rf & 2) {
48
48
  i0.ɵɵhostProperty("id", "modal-" + ctx.id);
49
- i0.ɵɵattribute("tabindex", -1)("role", "dialog")("aria-modal", true)("aria-labelledby", ctx.hasTitle() ? "modal-" + ctx.id + "-title" : null)("aria-describedby", ctx.hasSubtitle() ? "modal-" + ctx.id + "-subtitle" : null);
49
+ i0.ɵɵattribute("tabindex", -1)("role", "dialog")("aria-modal", true)("aria-labelledby", ctx.labelledBy())("aria-describedby", ctx.describedBy());
50
50
  i0.ɵɵclassMap(ctx.animationClass());
51
51
  i0.ɵɵstyleProp("--dr-modal-animation-time", ctx.animationTime() + "ms");
52
52
  i0.ɵɵclassProp("animation-noop", ctx.animationNoop);
@@ -65,8 +65,8 @@ export class DrModalContainerComponent extends CdkDialogContainer {
65
65
  '[attr.tabindex]': '-1',
66
66
  '[attr.role]': '"dialog"',
67
67
  '[attr.aria-modal]': 'true',
68
- '[attr.aria-labelledby]': 'hasTitle() ? "modal-" + id + "-title" : null',
69
- '[attr.aria-describedby]': 'hasSubtitle() ? "modal-" + id + "-subtitle" : null',
68
+ '[attr.aria-labelledby]': 'labelledBy()',
69
+ '[attr.aria-describedby]': 'describedBy()',
70
70
  }, changeDetection: ChangeDetectionStrategy.OnPush, imports: [PortalModule], styles: [":host{position:relative;display:grid;margin:auto;transition:all var(--dr-modal-animation-time, 0ms) ease-in-out}:host.animation-noop{transition:none!important}:host.animation-noop ::ng-deep .dr-modal{transition:none!important}:host.mat-anchor{opacity:0}:host.mat-anchor ::ng-deep .dr-modal{transform:scale(.8);transition:transform var(--dr-modal-animation-time, 0ms) cubic-bezier(0,0,.2,1)}:host.mat-anchor.mat-enter{opacity:1}:host.mat-anchor.mat-enter ::ng-deep .dr-modal{transform:none}:host.mat-anchor.mat-leave{opacity:0}:host.mat-anchor.mat-leave ::ng-deep .dr-modal{transform:none}\n"] }]
71
71
  }], null, null); })();
72
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-modal-container.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-modal/components/dr-modal-container/dr-modal-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, inject, signal, ANIMATION_MODULE_TYPE, computed, ElementRef } from '@angular/core';\nimport { CdkDialogContainer } from '@angular/cdk/dialog';\nimport { PortalModule } from '@angular/cdk/portal';\n\nimport { DrModalConfig } from '../../dr-modal-config';\n\nimport { DrModalAnimationState, DrModalAnimationClasses, DrModalAnimationDuration } from '../../dr-modal.types';\n\n@Component({\n    standalone: true,\n    selector: 'dr-modal-container',\n    template: `<ng-template cdkPortalOutlet></ng-template>`,\n    styleUrls: ['./dr-modal-container.component.scss'],\n    host: {\n        class: 'dr-modal-container',\n\n        '[class]': 'animationClass()',\n        '[class.animation-noop]': 'animationNoop',\n\n        '[style.--dr-modal-animation-time]': 'animationTime() + \"ms\"',\n\n        '[id]': '\"modal-\" + id',\n        '[attr.tabindex]': '-1',\n\n        '[attr.role]': '\"dialog\"',\n        '[attr.aria-modal]': 'true',\n        '[attr.aria-labelledby]': 'hasTitle() ? \"modal-\" + id + \"-title\" : null',\n        '[attr.aria-describedby]': 'hasSubtitle() ? \"modal-\" + id + \"-subtitle\" : null',\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [PortalModule],\n})\nexport class DrModalContainerComponent extends CdkDialogContainer {\n    public readonly config = inject(DrModalConfig);\n    public readonly id = this.config.id;\n\n    public readonly animationNoop = inject(ANIMATION_MODULE_TYPE, { optional: true }) === 'NoopAnimations';\n\n    private readonly animationClasses = this.getAnimationClasses(this.config.animation);\n    private readonly animationDuration = this.getAnimationDuration(this.config.animation);\n\n    public readonly animationState = signal<DrModalAnimationState | null>(null);\n    public readonly animationClass = computed(() => (this.animationState() ? this.animationClasses[this.animationState()!] : ''));\n    public readonly animationTime = computed(() =>\n        this.animationNoop ? 0 : this.animationDuration[this.animationState() ?? 'enter'],\n    );\n\n    public readonly hasTitle = signal(false); // updated from title directive\n    public readonly hasSubtitle = signal(false); // updated from subtitle directive\n\n    private readonly elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n    protected override _contentAttached(): void {\n        // Set the anchor class immediately after creation so \"enter\" animation would be properly applied\n        this.elementRef.nativeElement.classList.add(this.animationClasses.anchor);\n\n        // Delegate to the original dialog-container initialization (i.e. saving the\n        // previous element, setting up the focus trap and moving focus to the container).\n        super._contentAttached();\n\n        this.animationState.set('enter'); // triggers open animation\n\n        // Wait for the opening animation to finish before trapping focus\n        setTimeout(() => this._trapFocus(), this.animationDuration.enter);\n    }\n\n    public animateClose(): void {\n        this.animationState.set('leave');\n\n        // Claim focus from any clickable elements to avoid double submits on fast click/enter press\n        this.elementRef.nativeElement.focus();\n    }\n\n    private getAnimationDuration(animation: DrModalConfig['animation']): DrModalAnimationDuration {\n        const { enter = 150, leave = 150 } = animation?.duration ?? {};\n\n        return { enter, leave };\n    }\n\n    private getAnimationClasses(animation: DrModalConfig['animation']): DrModalAnimationClasses {\n        const { enter = 'mat-enter', leave = 'mat-leave', anchor = 'mat-anchor' } = animation?.class ?? {};\n\n        return { enter, leave, anchor };\n    }\n}\n"]}
72
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-modal-container.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-modal/components/dr-modal-container/dr-modal-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, inject, signal, ANIMATION_MODULE_TYPE, computed, ElementRef } from '@angular/core';\nimport { CdkDialogContainer } from '@angular/cdk/dialog';\nimport { PortalModule } from '@angular/cdk/portal';\n\nimport { DrModalConfig } from '../../dr-modal-config';\n\nimport { DrModalAnimationState, DrModalAnimationClasses, DrModalAnimationDuration } from '../../dr-modal.types';\n\n@Component({\n    standalone: true,\n    selector: 'dr-modal-container',\n    template: `<ng-template cdkPortalOutlet></ng-template>`,\n    styleUrls: ['./dr-modal-container.component.scss'],\n    host: {\n        class: 'dr-modal-container',\n\n        '[class]': 'animationClass()',\n        '[class.animation-noop]': 'animationNoop',\n\n        '[style.--dr-modal-animation-time]': 'animationTime() + \"ms\"',\n\n        '[id]': '\"modal-\" + id',\n        '[attr.tabindex]': '-1',\n\n        '[attr.role]': '\"dialog\"',\n        '[attr.aria-modal]': 'true',\n        '[attr.aria-labelledby]': 'labelledBy()',\n        '[attr.aria-describedby]': 'describedBy()',\n    },\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [PortalModule],\n})\nexport class DrModalContainerComponent extends CdkDialogContainer {\n    public readonly config = inject(DrModalConfig);\n    public readonly id = this.config.id;\n\n    public readonly animationNoop = inject(ANIMATION_MODULE_TYPE, { optional: true }) === 'NoopAnimations';\n\n    private readonly animationClasses = this.getAnimationClasses(this.config.animation);\n    private readonly animationDuration = this.getAnimationDuration(this.config.animation);\n\n    public readonly animationState = signal<DrModalAnimationState | null>(null);\n    public readonly animationClass = computed(() => (this.animationState() ? this.animationClasses[this.animationState()!] : ''));\n    public readonly animationTime = computed(() =>\n        this.animationNoop ? 0 : this.animationDuration[this.animationState() ?? 'enter'],\n    );\n\n    public readonly labelledBy = signal<string | null>(null); // updated from title directive\n    public readonly describedBy = signal<string | null>(null); // updated from subtitle directive\n\n    private readonly elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n    protected override _contentAttached(): void {\n        // Set the anchor class immediately after creation so \"enter\" animation would be properly applied\n        this.elementRef.nativeElement.classList.add(this.animationClasses.anchor);\n\n        // Delegate to the original dialog-container initialization (i.e. saving the\n        // previous element, setting up the focus trap and moving focus to the container).\n        super._contentAttached();\n\n        this.animationState.set('enter'); // triggers open animation\n\n        // Wait for the opening animation to finish before trapping focus\n        setTimeout(() => this._trapFocus(), this.animationDuration.enter);\n    }\n\n    public animateClose(): void {\n        this.animationState.set('leave');\n\n        // Claim focus from any clickable elements to avoid double submits on fast click/enter press\n        this.elementRef.nativeElement.focus();\n    }\n\n    private getAnimationDuration(animation: DrModalConfig['animation']): DrModalAnimationDuration {\n        const { enter = 150, leave = 150 } = animation?.duration ?? {};\n\n        return { enter, leave };\n    }\n\n    private getAnimationClasses(animation: DrModalConfig['animation']): DrModalAnimationClasses {\n        const { enter = 'mat-enter', leave = 'mat-leave', anchor = 'mat-anchor' } = animation?.class ?? {};\n\n        return { enter, leave, anchor };\n    }\n}\n"]}
@@ -5,6 +5,7 @@ import { uniqueId } from 'lodash';
5
5
  import { DrModalContainerComponent } from './components/dr-modal-container/dr-modal-container.component';
6
6
  import { DrModalRef } from './dr-modal-ref';
7
7
  import { DrModalConfig } from './dr-modal-config';
8
+ import { DR_SELECT_APPEND_TO } from '../dr-inputs/dr-select/dr-select.component';
8
9
  import { DR_MODAL_DEFAULT_CONFIG } from './dr-modal-config.provider';
9
10
  import * as i0 from "@angular/core";
10
11
  import * as i1 from "@angular/cdk/dialog";
@@ -45,6 +46,7 @@ export class DrModalService {
45
46
  return [
46
47
  { provide: DrModalRef, useValue: modalRef },
47
48
  { provide: DrModalConfig, useValue: drModalConfig },
49
+ { provide: DR_SELECT_APPEND_TO, useValue: '.cdk-overlay-container' },
48
50
  ];
49
51
  },
50
52
  container: {
@@ -86,4 +88,4 @@ export class DrModalService {
86
88
  providedIn: 'root',
87
89
  }]
88
90
  }], function () { return [{ type: i1.Dialog }]; }, null); })();
89
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-modal.service.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-modal/dr-modal.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable, StaticProvider } from '@angular/core';\nimport { Dialog, DialogConfig, DialogRef } from '@angular/cdk/dialog';\nimport { firstValueFrom } from 'rxjs';\nimport { uniqueId } from 'lodash';\n\nimport { DrModalContainerComponent } from './components/dr-modal-container/dr-modal-container.component';\n\nimport { DrModalRef } from './dr-modal-ref';\nimport { DrModalConfig } from './dr-modal-config';\n\nimport { DrModalFormField } from './dr-modal-form.types';\nimport { DrModalComponentRef, DrModalConfirmData } from './dr-modal.types';\n\nimport { DR_MODAL_DEFAULT_CONFIG } from './dr-modal-config.provider';\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class DrModalService {\n    private readonly _modals: DrModalRef[] = [];\n\n    private readonly defaultConfig = inject<DialogConfig<any>>(DR_MODAL_DEFAULT_CONFIG);\n\n    // start lazy loading of confirmation modal on creation\n    private readonly confirmComponentPromise = import('./components/dr-confirm-modal/dr-confirm-modal.component').then(\n        (m) => m.DrConfirmModalComponent,\n    );\n\n    constructor(private readonly dialog: Dialog) {}\n\n    public get modals(): readonly DrModalRef[] {\n        return this._modals;\n    }\n\n    public open<TData, TResult = unknown>(\n        component: DrModalComponentRef<TData, TResult>,\n        config?: DrModalConfig<TData>,\n    ): DrModalRef<TData, TResult> {\n        // Prevent from opening modal with same id\n        const existingModal = config?.id ? this.modals.find((modal) => modal.config.id === config.id) : null;\n\n        if (existingModal) {\n            return existingModal as DrModalRef<TData, TResult>;\n        }\n\n        let modalRef!: DrModalRef<TData, TResult>;\n        let drModalConfig!: DrModalConfig<TData>;\n\n        const id = config.id ?? uniqueId();\n        const newConfig = {\n            ...this.defaultConfig,\n\n            ...config,\n\n            id,\n\n            // Disable closing since we need to sync it up to the animation ourselves.\n            disableClose: true,\n\n            // Disable closing on destroy, because this service cleans up its open modals as well.\n            // We want to do the cleanup here, rather than the CDK service, because the CDK destroys\n            // the dialogs immediately whereas we want it to wait for the animations to finish.\n            closeOnDestroy: false,\n\n            // Disable closing on detachments so that we can sync up the animation\n            closeOnOverlayDetachments: false,\n\n            providers: (dialogRef: DialogRef<TResult>, _config: DialogConfig<TData>): StaticProvider[] => {\n                modalRef = new DrModalRef<TData, TResult>(dialogRef, drModalConfig);\n\n                return [\n                    { provide: DrModalRef, useValue: modalRef },\n                    { provide: DrModalConfig, useValue: drModalConfig },\n                ];\n            },\n\n            container: {\n                type: DrModalContainerComponent,\n                providers: (_config) => {\n                    drModalConfig = { ...config, id };\n\n                    return [{ provide: DrModalConfig, useValue: drModalConfig }];\n                },\n            },\n        } satisfies DialogConfig<TData, DialogRef<TResult>>;\n\n        this.dialog.open<TResult, TData>(component, newConfig);\n\n        this._modals[modalRef.id] = modalRef;\n        modalRef.afterClosed$.subscribe(() => delete this._modals[modalRef.id]);\n\n        return modalRef;\n    }\n\n    public async confirm<Fields extends readonly DrModalFormField<any>[] = DrModalFormField<any>[]>(\n        data: DrModalConfirmData<Fields> = {},\n    ): Promise<boolean> {\n        const modalRef = this.open(await this.confirmComponentPromise, { data: this.getConfirmData(data) });\n\n        return (await firstValueFrom(modalRef.afterClosed$)) || false;\n    }\n\n    public closeAll(): void {\n        [...this.modals].reverse().forEach((modal) => modal.close());\n    }\n\n    private getConfirmData<Fields extends readonly DrModalFormField<any>[] = DrModalFormField<any>[]>(\n        data: DrModalConfirmData<Fields>,\n    ): DrModalConfirmData<Fields> {\n        return {\n            size: 'xs',\n            maxHeight: 'size',\n\n            withCloseBtn: true,\n\n            cancelBtn: { theme: 'secondary', label: 'Cancel' },\n            acceptBtn: { theme: 'primary', label: 'Confirm' },\n\n            ...data,\n        };\n    }\n}\n"]}
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-modal.service.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/dr-modal/dr-modal.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable, StaticProvider } from '@angular/core';\nimport { Dialog, DialogConfig, DialogRef } from '@angular/cdk/dialog';\nimport { firstValueFrom } from 'rxjs';\nimport { uniqueId } from 'lodash';\n\nimport { DrModalContainerComponent } from './components/dr-modal-container/dr-modal-container.component';\n\nimport { DrModalRef } from './dr-modal-ref';\nimport { DrModalConfig } from './dr-modal-config';\n\nimport { DrModalFormField } from './dr-modal-form.types';\nimport { DrModalComponentRef, DrModalConfirmData } from './dr-modal.types';\n\nimport { DR_SELECT_APPEND_TO } from '../dr-inputs/dr-select/dr-select.component';\n\nimport { DR_MODAL_DEFAULT_CONFIG } from './dr-modal-config.provider';\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class DrModalService {\n    private readonly _modals: DrModalRef[] = [];\n\n    private readonly defaultConfig = inject<DialogConfig<any>>(DR_MODAL_DEFAULT_CONFIG);\n\n    // start lazy loading of confirmation modal on creation\n    private readonly confirmComponentPromise = import('./components/dr-confirm-modal/dr-confirm-modal.component').then(\n        (m) => m.DrConfirmModalComponent,\n    );\n\n    constructor(private readonly dialog: Dialog) {}\n\n    public get modals(): readonly DrModalRef[] {\n        return this._modals;\n    }\n\n    public open<TData, TResult = unknown>(\n        component: DrModalComponentRef<TData, TResult>,\n        config?: DrModalConfig<TData>,\n    ): DrModalRef<TData, TResult> {\n        // Prevent from opening modal with same id\n        const existingModal = config?.id ? this.modals.find((modal) => modal.config.id === config.id) : null;\n\n        if (existingModal) {\n            return existingModal as DrModalRef<TData, TResult>;\n        }\n\n        let modalRef!: DrModalRef<TData, TResult>;\n        let drModalConfig!: DrModalConfig<TData>;\n\n        const id = config.id ?? uniqueId();\n        const newConfig = {\n            ...this.defaultConfig,\n\n            ...config,\n\n            id,\n\n            // Disable closing since we need to sync it up to the animation ourselves.\n            disableClose: true,\n\n            // Disable closing on destroy, because this service cleans up its open modals as well.\n            // We want to do the cleanup here, rather than the CDK service, because the CDK destroys\n            // the dialogs immediately whereas we want it to wait for the animations to finish.\n            closeOnDestroy: false,\n\n            // Disable closing on detachments so that we can sync up the animation\n            closeOnOverlayDetachments: false,\n\n            providers: (dialogRef: DialogRef<TResult>, _config: DialogConfig<TData>): StaticProvider[] => {\n                modalRef = new DrModalRef<TData, TResult>(dialogRef, drModalConfig);\n\n                return [\n                    { provide: DrModalRef, useValue: modalRef },\n                    { provide: DrModalConfig, useValue: drModalConfig },\n\n                    { provide: DR_SELECT_APPEND_TO, useValue: '.cdk-overlay-container' },\n                ];\n            },\n\n            container: {\n                type: DrModalContainerComponent,\n                providers: (_config) => {\n                    drModalConfig = { ...config, id };\n\n                    return [{ provide: DrModalConfig, useValue: drModalConfig }];\n                },\n            },\n        } satisfies DialogConfig<TData, DialogRef<TResult>>;\n\n        this.dialog.open<TResult, TData>(component, newConfig);\n\n        this._modals[modalRef.id] = modalRef;\n        modalRef.afterClosed$.subscribe(() => delete this._modals[modalRef.id]);\n\n        return modalRef;\n    }\n\n    public async confirm<Fields extends readonly DrModalFormField<any>[] = DrModalFormField<any>[]>(\n        data: DrModalConfirmData<Fields> = {},\n    ): Promise<boolean> {\n        const modalRef = this.open(await this.confirmComponentPromise, { data: this.getConfirmData(data) });\n\n        return (await firstValueFrom(modalRef.afterClosed$)) || false;\n    }\n\n    public closeAll(): void {\n        [...this.modals].reverse().forEach((modal) => modal.close());\n    }\n\n    private getConfirmData<Fields extends readonly DrModalFormField<any>[] = DrModalFormField<any>[]>(\n        data: DrModalConfirmData<Fields>,\n    ): DrModalConfirmData<Fields> {\n        return {\n            size: 'xs',\n            maxHeight: 'size',\n\n            withCloseBtn: true,\n\n            cancelBtn: { theme: 'secondary', label: 'Cancel' },\n            acceptBtn: { theme: 'primary', label: 'Confirm' },\n\n            ...data,\n        };\n    }\n}\n"]}
@@ -1,7 +1,7 @@
1
- import { Directive, inject } from '@angular/core';
2
- import { DrModalConfig } from './dr-modal-config';
1
+ import { Directive } from '@angular/core';
3
2
  import { DrModalRef } from './dr-modal-ref';
4
3
  import * as i0 from "@angular/core";
4
+ import * as i1 from "./dr-modal-ref";
5
5
  export class DrModalHeaderDirective {
6
6
  /** @nocollapse */ static { this.ɵfac = function DrModalHeaderDirective_Factory(t) { return new (t || DrModalHeaderDirective)(); }; }
7
7
  /** @nocollapse */ static { this.ɵdir = /** @pureOrBreakMyCode */ i0.ɵɵdefineDirective({ type: DrModalHeaderDirective, selectors: [["dr-modal-header"], ["", "dr-modal-header", ""], ["", "drModalHeader", ""]], hostAttrs: [1, "dr-modal-header"], standalone: true }); }
@@ -15,14 +15,15 @@ export class DrModalHeaderDirective {
15
15
  }]
16
16
  }], null, null); })();
17
17
  export class DrModalTitleDirective {
18
- constructor() {
19
- this.id = inject(DrModalConfig).id;
20
- const modalRef = inject(DrModalRef);
21
- setTimeout(() => modalRef.container.hasTitle.set(true));
18
+ constructor(modalRef) {
19
+ this.modalRef = modalRef;
20
+ this.id = `modal-${this.modalRef.id}-title`;
21
+ // setTimeout to avoid NG0100 error: Expression Changed After Checked
22
+ setTimeout(() => this.modalRef.container.labelledBy.set(this.id));
22
23
  }
23
- /** @nocollapse */ static { this.ɵfac = function DrModalTitleDirective_Factory(t) { return new (t || DrModalTitleDirective)(); }; }
24
+ /** @nocollapse */ static { this.ɵfac = function DrModalTitleDirective_Factory(t) { return new (t || DrModalTitleDirective)(i0.ɵɵdirectiveInject(i1.DrModalRef)); }; }
24
25
  /** @nocollapse */ static { this.ɵdir = /** @pureOrBreakMyCode */ i0.ɵɵdefineDirective({ type: DrModalTitleDirective, selectors: [["dr-modal-title"], ["", "dr-modal-title", ""], ["", "drModalTitle", ""]], hostAttrs: ["role", "heading", "aria-level", "1", "data-test", "dialogTitle", 1, "dr-modal-title"], hostVars: 1, hostBindings: function DrModalTitleDirective_HostBindings(rf, ctx) { if (rf & 2) {
25
- i0.ɵɵhostProperty("id", "modal-" + ctx.id + "-title");
26
+ i0.ɵɵhostProperty("id", ctx.id);
26
27
  } }, standalone: true }); }
27
28
  }
28
29
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrModalTitleDirective, [{
@@ -30,24 +31,19 @@ export class DrModalTitleDirective {
30
31
  args: [{
31
32
  standalone: true,
32
33
  selector: 'dr-modal-title, [dr-modal-title], [drModalTitle]',
33
- host: {
34
- '[id]': "'modal-' + id + '-title'",
35
- class: 'dr-modal-title',
36
- role: 'heading',
37
- 'aria-level': '1',
38
- 'data-test': 'dialogTitle',
39
- },
34
+ host: { '[id]': 'id', class: 'dr-modal-title', role: 'heading', 'aria-level': '1', 'data-test': 'dialogTitle' },
40
35
  }]
41
- }], function () { return []; }, null); })();
36
+ }], function () { return [{ type: i1.DrModalRef }]; }, null); })();
42
37
  export class DrModalSubtitleDirective {
43
- constructor() {
44
- this.id = inject(DrModalConfig).id;
45
- const modalRef = inject(DrModalRef);
46
- setTimeout(() => modalRef.container.hasSubtitle.set(true));
38
+ constructor(modalRef) {
39
+ this.modalRef = modalRef;
40
+ this.id = `modal-${this.modalRef.id}-subtitle`;
41
+ // setTimeout to avoid NG0100 error: Expression Changed After Checked
42
+ setTimeout(() => this.modalRef.container.describedBy.set(this.id));
47
43
  }
48
- /** @nocollapse */ static { this.ɵfac = function DrModalSubtitleDirective_Factory(t) { return new (t || DrModalSubtitleDirective)(); }; }
44
+ /** @nocollapse */ static { this.ɵfac = function DrModalSubtitleDirective_Factory(t) { return new (t || DrModalSubtitleDirective)(i0.ɵɵdirectiveInject(i1.DrModalRef)); }; }
49
45
  /** @nocollapse */ static { this.ɵdir = /** @pureOrBreakMyCode */ i0.ɵɵdefineDirective({ type: DrModalSubtitleDirective, selectors: [["dr-modal-subtitle"], ["", "dr-modal-subtitle", ""], ["", "drModalSubtitle", ""]], hostAttrs: ["role", "heading", "aria-level", "2", "data-test", "dialogSubtitle", 1, "dr-modal-subtitle"], hostVars: 1, hostBindings: function DrModalSubtitleDirective_HostBindings(rf, ctx) { if (rf & 2) {
50
- i0.ɵɵhostProperty("id", "modal-" + ctx.id + "-subtitle");
46
+ i0.ɵɵhostProperty("id", ctx.id);
51
47
  } }, standalone: true }); }
52
48
  }
53
49
  (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrModalSubtitleDirective, [{
@@ -55,15 +51,9 @@ export class DrModalSubtitleDirective {
55
51
  args: [{
56
52
  standalone: true,
57
53
  selector: 'dr-modal-subtitle, [dr-modal-subtitle], [drModalSubtitle]',
58
- host: {
59
- '[id]': "'modal-' + id + '-subtitle'",
60
- class: 'dr-modal-subtitle',
61
- role: 'heading',
62
- 'aria-level': '2',
63
- 'data-test': 'dialogSubtitle',
64
- },
54
+ host: { '[id]': 'id', class: 'dr-modal-subtitle', role: 'heading', 'aria-level': '2', 'data-test': 'dialogSubtitle' },
65
55
  }]
66
- }], function () { return []; }, null); })();
56
+ }], function () { return [{ type: i1.DrModalRef }]; }, null); })();
67
57
  export class DrModalBodyDirective {
68
58
  /** @nocollapse */ static { this.ɵfac = function DrModalBodyDirective_Factory(t) { return new (t || DrModalBodyDirective)(); }; }
69
59
  /** @nocollapse */ static { this.ɵdir = /** @pureOrBreakMyCode */ i0.ɵɵdefineDirective({ type: DrModalBodyDirective, selectors: [["dr-modal-body"], ["", "dr-modal-body", ""], ["", "drModalBody", ""]], hostAttrs: ["data-test", "modalBody", 1, "dr-modal-body"], standalone: true }); }
@@ -88,4 +78,4 @@ export class DrModalFooterDirective {
88
78
  host: { class: 'dr-modal-footer' },
89
79
  }]
90
80
  }], null, null); })();
91
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItbW9kYWwuc2xvdHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1tb2RhbC9kci1tb2RhbC5zbG90cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDbEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGdCQUFnQixDQUFDOztBQU81QyxNQUFNLE9BQU8sc0JBQXNCOzBHQUF0QixzQkFBc0I7bUdBQXRCLHNCQUFzQjs7dUZBQXRCLHNCQUFzQjtjQUxsQyxTQUFTO2VBQUM7Z0JBQ1AsVUFBVSxFQUFFLElBQUk7Z0JBQ2hCLFFBQVEsRUFBRSxxREFBcUQ7Z0JBQy9ELElBQUksRUFBRSxFQUFFLEtBQUssRUFBRSxpQkFBaUIsRUFBRTthQUNyQzs7QUFjRCxNQUFNLE9BQU8scUJBQXFCO0lBRzlCO1FBRm1CLE9BQUUsR0FBRyxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUMsRUFBRSxDQUFDO1FBRzdDLE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUVwQyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDNUQsQ0FBQzt5R0FQUSxxQkFBcUI7bUdBQXJCLHFCQUFxQjs7Ozt1RkFBckIscUJBQXFCO2NBWGpDLFNBQVM7ZUFBQztnQkFDUCxVQUFVLEVBQUUsSUFBSTtnQkFDaEIsUUFBUSxFQUFFLGtEQUFrRDtnQkFDNUQsSUFBSSxFQUFFO29CQUNGLE1BQU0sRUFBRSwwQkFBMEI7b0JBQ2xDLEtBQUssRUFBRSxnQkFBZ0I7b0JBQ3ZCLElBQUksRUFBRSxTQUFTO29CQUNmLFlBQVksRUFBRSxHQUFHO29CQUNqQixXQUFXLEVBQUUsYUFBYTtpQkFDN0I7YUFDSjs7QUFzQkQsTUFBTSxPQUFPLHdCQUF3QjtJQUdqQztRQUZtQixPQUFFLEdBQUcsTUFBTSxDQUFDLGFBQWEsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUc3QyxNQUFNLFFBQVEsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7UUFFcEMsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsV0FBVyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQy9ELENBQUM7NEdBUFEsd0JBQXdCO21HQUF4Qix3QkFBd0I7Ozs7dUZBQXhCLHdCQUF3QjtjQVhwQyxTQUFTO2VBQUM7Z0JBQ1AsVUFBVSxFQUFFLElBQUk7Z0JBQ2hCLFFBQVEsRUFBRSwyREFBMkQ7Z0JBQ3JFLElBQUksRUFBRTtvQkFDRixNQUFNLEVBQUUsNkJBQTZCO29CQUNyQyxLQUFLLEVBQUUsbUJBQW1CO29CQUMxQixJQUFJLEVBQUUsU0FBUztvQkFDZixZQUFZLEVBQUUsR0FBRztvQkFDakIsV0FBVyxFQUFFLGdCQUFnQjtpQkFDaEM7YUFDSjs7QUFnQkQsTUFBTSxPQUFPLG9CQUFvQjt3R0FBcEIsb0JBQW9CO21HQUFwQixvQkFBb0I7O3VGQUFwQixvQkFBb0I7Y0FMaEMsU0FBUztlQUFDO2dCQUNQLFVBQVUsRUFBRSxJQUFJO2dCQUNoQixRQUFRLEVBQUUsK0NBQStDO2dCQUN6RCxJQUFJLEVBQUUsRUFBRSxLQUFLLEVBQUUsZUFBZSxFQUFFLFdBQVcsRUFBRSxXQUFXLEVBQUU7YUFDN0Q7O0FBUUQsTUFBTSxPQUFPLHNCQUFzQjswR0FBdEIsc0JBQXNCO21HQUF0QixzQkFBc0I7O3VGQUF0QixzQkFBc0I7Y0FMbEMsU0FBUztlQUFDO2dCQUNQLFVBQVUsRUFBRSxJQUFJO2dCQUNoQixRQUFRLEVBQUUscURBQXFEO2dCQUMvRCxJQUFJLEVBQUUsRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUU7YUFDckMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRHJNb2RhbENvbmZpZyB9IGZyb20gJy4vZHItbW9kYWwtY29uZmlnJztcbmltcG9ydCB7IERyTW9kYWxSZWYgfSBmcm9tICcuL2RyLW1vZGFsLXJlZic7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc2VsZWN0b3I6ICdkci1tb2RhbC1oZWFkZXIsIFtkci1tb2RhbC1oZWFkZXJdLCBbZHJNb2RhbEhlYWRlcl0nLFxuICAgIGhvc3Q6IHsgY2xhc3M6ICdkci1tb2RhbC1oZWFkZXInIH0sXG59KVxuZXhwb3J0IGNsYXNzIERyTW9kYWxIZWFkZXJEaXJlY3RpdmUge31cblxuQERpcmVjdGl2ZSh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBzZWxlY3RvcjogJ2RyLW1vZGFsLXRpdGxlLCBbZHItbW9kYWwtdGl0bGVdLCBbZHJNb2RhbFRpdGxlXScsXG4gICAgaG9zdDoge1xuICAgICAgICAnW2lkXSc6IFwiJ21vZGFsLScgKyBpZCArICctdGl0bGUnXCIsIC8vIGFyaWEtbGFiZWxsZWRieVxuICAgICAgICBjbGFzczogJ2RyLW1vZGFsLXRpdGxlJyxcbiAgICAgICAgcm9sZTogJ2hlYWRpbmcnLFxuICAgICAgICAnYXJpYS1sZXZlbCc6ICcxJyxcbiAgICAgICAgJ2RhdGEtdGVzdCc6ICdkaWFsb2dUaXRsZScsXG4gICAgfSxcbn0pXG5leHBvcnQgY2xhc3MgRHJNb2RhbFRpdGxlRGlyZWN0aXZlIHtcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgaWQgPSBpbmplY3QoRHJNb2RhbENvbmZpZykuaWQ7XG5cbiAgICBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgY29uc3QgbW9kYWxSZWYgPSBpbmplY3QoRHJNb2RhbFJlZik7XG5cbiAgICAgICAgc2V0VGltZW91dCgoKSA9PiBtb2RhbFJlZi5jb250YWluZXIuaGFzVGl0bGUuc2V0KHRydWUpKTtcbiAgICB9XG59XG5cbkBEaXJlY3RpdmUoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc2VsZWN0b3I6ICdkci1tb2RhbC1zdWJ0aXRsZSwgW2RyLW1vZGFsLXN1YnRpdGxlXSwgW2RyTW9kYWxTdWJ0aXRsZV0nLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgJ1tpZF0nOiBcIidtb2RhbC0nICsgaWQgKyAnLXN1YnRpdGxlJ1wiLCAvLyBhcmlhLWRlc2NyaWJlZGJ5XG4gICAgICAgIGNsYXNzOiAnZHItbW9kYWwtc3VidGl0bGUnLFxuICAgICAgICByb2xlOiAnaGVhZGluZycsXG4gICAgICAgICdhcmlhLWxldmVsJzogJzInLFxuICAgICAgICAnZGF0YS10ZXN0JzogJ2RpYWxvZ1N1YnRpdGxlJyxcbiAgICB9LFxufSlcbmV4cG9ydCBjbGFzcyBEck1vZGFsU3VidGl0bGVEaXJlY3RpdmUge1xuICAgIHByb3RlY3RlZCByZWFkb25seSBpZCA9IGluamVjdChEck1vZGFsQ29uZmlnKS5pZDtcblxuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBjb25zdCBtb2RhbFJlZiA9IGluamVjdChEck1vZGFsUmVmKTtcblxuICAgICAgICBzZXRUaW1lb3V0KCgpID0+IG1vZGFsUmVmLmNvbnRhaW5lci5oYXNTdWJ0aXRsZS5zZXQodHJ1ZSkpO1xuICAgIH1cbn1cblxuQERpcmVjdGl2ZSh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBzZWxlY3RvcjogJ2RyLW1vZGFsLWJvZHksIFtkci1tb2RhbC1ib2R5XSwgW2RyTW9kYWxCb2R5XScsXG4gICAgaG9zdDogeyBjbGFzczogJ2RyLW1vZGFsLWJvZHknLCAnZGF0YS10ZXN0JzogJ21vZGFsQm9keScgfSxcbn0pXG5leHBvcnQgY2xhc3MgRHJNb2RhbEJvZHlEaXJlY3RpdmUge31cblxuQERpcmVjdGl2ZSh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBzZWxlY3RvcjogJ2RyLW1vZGFsLWZvb3RlciwgW2RyLW1vZGFsLWZvb3Rlcl0sIFtkck1vZGFsRm9vdGVyXScsXG4gICAgaG9zdDogeyBjbGFzczogJ2RyLW1vZGFsLWZvb3RlcicgfSxcbn0pXG5leHBvcnQgY2xhc3MgRHJNb2RhbEZvb3RlckRpcmVjdGl2ZSB7fVxuIl19
81
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItbW9kYWwuc2xvdHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1tb2RhbC9kci1tb2RhbC5zbG90cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7O0FBTzVDLE1BQU0sT0FBTyxzQkFBc0I7MEdBQXRCLHNCQUFzQjttR0FBdEIsc0JBQXNCOzt1RkFBdEIsc0JBQXNCO2NBTGxDLFNBQVM7ZUFBQztnQkFDUCxVQUFVLEVBQUUsSUFBSTtnQkFDaEIsUUFBUSxFQUFFLHFEQUFxRDtnQkFDL0QsSUFBSSxFQUFFLEVBQUUsS0FBSyxFQUFFLGlCQUFpQixFQUFFO2FBQ3JDOztBQVFELE1BQU0sT0FBTyxxQkFBcUI7SUFHOUIsWUFBNkIsUUFBb0I7UUFBcEIsYUFBUSxHQUFSLFFBQVEsQ0FBWTtRQUY5QixPQUFFLEdBQUcsU0FBUyxJQUFJLENBQUMsUUFBUSxDQUFDLEVBQUUsUUFBUSxDQUFDO1FBR3RELHFFQUFxRTtRQUNyRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUN0RSxDQUFDO3lHQU5RLHFCQUFxQjttR0FBckIscUJBQXFCOzs7O3VGQUFyQixxQkFBcUI7Y0FMakMsU0FBUztlQUFDO2dCQUNQLFVBQVUsRUFBRSxJQUFJO2dCQUNoQixRQUFRLEVBQUUsa0RBQWtEO2dCQUM1RCxJQUFJLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxnQkFBZ0IsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxHQUFHLEVBQUUsV0FBVyxFQUFFLGFBQWEsRUFBRTthQUNsSDs7QUFlRCxNQUFNLE9BQU8sd0JBQXdCO0lBR2pDLFlBQTZCLFFBQW9CO1FBQXBCLGFBQVEsR0FBUixRQUFRLENBQVk7UUFGOUIsT0FBRSxHQUFHLFNBQVMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxFQUFFLFdBQVcsQ0FBQztRQUd6RCxxRUFBcUU7UUFDckUsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDdkUsQ0FBQzs0R0FOUSx3QkFBd0I7bUdBQXhCLHdCQUF3Qjs7Ozt1RkFBeEIsd0JBQXdCO2NBTHBDLFNBQVM7ZUFBQztnQkFDUCxVQUFVLEVBQUUsSUFBSTtnQkFDaEIsUUFBUSxFQUFFLDJEQUEyRDtnQkFDckUsSUFBSSxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsbUJBQW1CLEVBQUUsSUFBSSxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsR0FBRyxFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRTthQUN4SDs7QUFlRCxNQUFNLE9BQU8sb0JBQW9CO3dHQUFwQixvQkFBb0I7bUdBQXBCLG9CQUFvQjs7dUZBQXBCLG9CQUFvQjtjQUxoQyxTQUFTO2VBQUM7Z0JBQ1AsVUFBVSxFQUFFLElBQUk7Z0JBQ2hCLFFBQVEsRUFBRSwrQ0FBK0M7Z0JBQ3pELElBQUksRUFBRSxFQUFFLEtBQUssRUFBRSxlQUFlLEVBQUUsV0FBVyxFQUFFLFdBQVcsRUFBRTthQUM3RDs7QUFRRCxNQUFNLE9BQU8sc0JBQXNCOzBHQUF0QixzQkFBc0I7bUdBQXRCLHNCQUFzQjs7dUZBQXRCLHNCQUFzQjtjQUxsQyxTQUFTO2VBQUM7Z0JBQ1AsVUFBVSxFQUFFLElBQUk7Z0JBQ2hCLFFBQVEsRUFBRSxxREFBcUQ7Z0JBQy9ELElBQUksRUFBRSxFQUFFLEtBQUssRUFBRSxpQkFBaUIsRUFBRTthQUNyQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRHJNb2RhbFJlZiB9IGZyb20gJy4vZHItbW9kYWwtcmVmJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBzZWxlY3RvcjogJ2RyLW1vZGFsLWhlYWRlciwgW2RyLW1vZGFsLWhlYWRlcl0sIFtkck1vZGFsSGVhZGVyXScsXG4gICAgaG9zdDogeyBjbGFzczogJ2RyLW1vZGFsLWhlYWRlcicgfSxcbn0pXG5leHBvcnQgY2xhc3MgRHJNb2RhbEhlYWRlckRpcmVjdGl2ZSB7fVxuXG5ARGlyZWN0aXZlKHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiAnZHItbW9kYWwtdGl0bGUsIFtkci1tb2RhbC10aXRsZV0sIFtkck1vZGFsVGl0bGVdJyxcbiAgICBob3N0OiB7ICdbaWRdJzogJ2lkJywgY2xhc3M6ICdkci1tb2RhbC10aXRsZScsIHJvbGU6ICdoZWFkaW5nJywgJ2FyaWEtbGV2ZWwnOiAnMScsICdkYXRhLXRlc3QnOiAnZGlhbG9nVGl0bGUnIH0sXG59KVxuZXhwb3J0IGNsYXNzIERyTW9kYWxUaXRsZURpcmVjdGl2ZSB7XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IGlkID0gYG1vZGFsLSR7dGhpcy5tb2RhbFJlZi5pZH0tdGl0bGVgO1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBtb2RhbFJlZjogRHJNb2RhbFJlZikge1xuICAgICAgICAvLyBzZXRUaW1lb3V0IHRvIGF2b2lkIE5HMDEwMCBlcnJvcjogRXhwcmVzc2lvbiBDaGFuZ2VkIEFmdGVyIENoZWNrZWRcbiAgICAgICAgc2V0VGltZW91dCgoKSA9PiB0aGlzLm1vZGFsUmVmLmNvbnRhaW5lci5sYWJlbGxlZEJ5LnNldCh0aGlzLmlkKSk7XG4gICAgfVxufVxuXG5ARGlyZWN0aXZlKHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiAnZHItbW9kYWwtc3VidGl0bGUsIFtkci1tb2RhbC1zdWJ0aXRsZV0sIFtkck1vZGFsU3VidGl0bGVdJyxcbiAgICBob3N0OiB7ICdbaWRdJzogJ2lkJywgY2xhc3M6ICdkci1tb2RhbC1zdWJ0aXRsZScsIHJvbGU6ICdoZWFkaW5nJywgJ2FyaWEtbGV2ZWwnOiAnMicsICdkYXRhLXRlc3QnOiAnZGlhbG9nU3VidGl0bGUnIH0sXG59KVxuZXhwb3J0IGNsYXNzIERyTW9kYWxTdWJ0aXRsZURpcmVjdGl2ZSB7XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IGlkID0gYG1vZGFsLSR7dGhpcy5tb2RhbFJlZi5pZH0tc3VidGl0bGVgO1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBtb2RhbFJlZjogRHJNb2RhbFJlZikge1xuICAgICAgICAvLyBzZXRUaW1lb3V0IHRvIGF2b2lkIE5HMDEwMCBlcnJvcjogRXhwcmVzc2lvbiBDaGFuZ2VkIEFmdGVyIENoZWNrZWRcbiAgICAgICAgc2V0VGltZW91dCgoKSA9PiB0aGlzLm1vZGFsUmVmLmNvbnRhaW5lci5kZXNjcmliZWRCeS5zZXQodGhpcy5pZCkpO1xuICAgIH1cbn1cblxuQERpcmVjdGl2ZSh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBzZWxlY3RvcjogJ2RyLW1vZGFsLWJvZHksIFtkci1tb2RhbC1ib2R5XSwgW2RyTW9kYWxCb2R5XScsXG4gICAgaG9zdDogeyBjbGFzczogJ2RyLW1vZGFsLWJvZHknLCAnZGF0YS10ZXN0JzogJ21vZGFsQm9keScgfSxcbn0pXG5leHBvcnQgY2xhc3MgRHJNb2RhbEJvZHlEaXJlY3RpdmUge31cblxuQERpcmVjdGl2ZSh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBzZWxlY3RvcjogJ2RyLW1vZGFsLWZvb3RlciwgW2RyLW1vZGFsLWZvb3Rlcl0sIFtkck1vZGFsRm9vdGVyXScsXG4gICAgaG9zdDogeyBjbGFzczogJ2RyLW1vZGFsLWZvb3RlcicgfSxcbn0pXG5leHBvcnQgY2xhc3MgRHJNb2RhbEZvb3RlckRpcmVjdGl2ZSB7fVxuIl19