ngssm-toolkit 15.2.12 → 15.3.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/esm2020/lib/confirmation-dialog/ngssm-confirmation-dialog/ngssm-confirmation-dialog.component.mjs +3 -3
- package/esm2020/lib/confirmation-dialog/ngssm-confirmation-dialog.service.mjs +3 -3
- package/esm2020/lib/file-picker/index.mjs +3 -3
- package/esm2020/lib/file-picker/ngssm-file-picker.component.mjs +138 -0
- package/esm2020/lib/file-picker/ngssm-file-size.pipe.mjs +32 -0
- package/esm2020/lib/material/material-imports.module.mjs +4 -4
- package/esm2020/lib/not-found.component.mjs +6 -5
- package/esm2020/lib/notification/ngssm-notification-error/ngssm-notification-error.component.mjs +3 -3
- package/esm2020/lib/notification/ngssm-notification-success/ngssm-notification-success.component.mjs +3 -3
- package/esm2020/lib/notification/ngssm-notifier.service.mjs +3 -3
- package/esm2020/lib/overlay/index.mjs +4 -4
- package/esm2020/lib/overlay/ngssm-component-overlay.directive.mjs +94 -0
- package/esm2020/lib/overlay/ngssm-empty-overlay.component.mjs +11 -0
- package/esm2020/lib/overlay/ngssm-message-overlay.component.mjs +35 -0
- package/esm2020/lib/overlay/ngssm-overlay-builder.mjs +7 -7
- package/esm2020/lib/regex-editor/ngssm-regex-editor/ngssm-regex-editor.component.mjs +3 -3
- package/esm2020/lib/regex-editor/ngssm-regex-editor-toggle/ngssm-regex-editor-toggle.component.mjs +3 -3
- package/esm2020/public-api.mjs +1 -2
- package/fesm2015/ngssm-toolkit.mjs +92 -118
- package/fesm2015/ngssm-toolkit.mjs.map +1 -1
- package/fesm2020/ngssm-toolkit.mjs +92 -118
- package/fesm2020/ngssm-toolkit.mjs.map +1 -1
- package/lib/file-picker/index.d.ts +2 -2
- package/lib/file-picker/{file-picker.component.d.ts → ngssm-file-picker.component.d.ts} +3 -3
- package/lib/file-picker/ngssm-file-size.pipe.d.ts +8 -0
- package/lib/not-found.component.d.ts +1 -1
- package/lib/overlay/index.d.ts +3 -3
- package/lib/overlay/{component-overlay.directive.d.ts → ngssm-component-overlay.directive.d.ts} +3 -3
- package/lib/overlay/ngssm-empty-overlay.component.d.ts +5 -0
- package/lib/overlay/ngssm-message-overlay.component.d.ts +7 -0
- package/package.json +1 -1
- package/public-api.d.ts +0 -1
- package/esm2020/lib/file-picker/file-picker.component.mjs +0 -137
- package/esm2020/lib/file-picker/file-size.pipe.mjs +0 -31
- package/esm2020/lib/ngssm-toolkit.module.mjs +0 -34
- package/esm2020/lib/overlay/component-overlay.directive.mjs +0 -94
- package/esm2020/lib/overlay/empty-overlay.component.mjs +0 -11
- package/esm2020/lib/overlay/message-overlay.component.mjs +0 -32
- package/lib/file-picker/file-size.pipe.d.ts +0 -8
- package/lib/ngssm-toolkit.module.d.ts +0 -14
- package/lib/overlay/empty-overlay.component.d.ts +0 -5
- package/lib/overlay/message-overlay.component.d.ts +0 -7
|
@@ -13,9 +13,9 @@ export class NgssmConfirmationDialogComponent extends NgSsmComponent {
|
|
|
13
13
|
this.data = data;
|
|
14
14
|
}
|
|
15
15
|
}
|
|
16
|
-
NgssmConfirmationDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.
|
|
17
|
-
NgssmConfirmationDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.
|
|
18
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.
|
|
16
|
+
NgssmConfirmationDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmConfirmationDialogComponent, deps: [{ token: i1.Store }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
|
|
17
|
+
NgssmConfirmationDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: NgssmConfirmationDialogComponent, isStandalone: true, selector: "ngssm-confirmation-dialog", usesInheritance: true, ngImport: i0, template: "<mat-dialog-content class=\"flex-column-stretch fxFlex message-container\">\n{{data.message}}\n</mat-dialog-content>\n<mat-dialog-actions class=\"flex-row-center\">\n <span class=\"fxFlex\"></span>\n <button mat-button [matDialogClose]=\"data.cancelLabel\" id=\"cancelButton\">{{data.cancelLabel}}</button>\n <button mat-raised-button [color]=\"data.submitButtonColor\" [matDialogClose]=\"data.submitLabel\" id=\"submitButton\">\n {{data.submitLabel}}\n </button>\n</mat-dialog-actions>\n", styles: [":host .message-container{font-weight:700}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: MatDialogModule }, { kind: "directive", type: i2.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i2.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "directive", type: i2.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i3.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
18
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmConfirmationDialogComponent, decorators: [{
|
|
19
19
|
type: Component,
|
|
20
20
|
args: [{ selector: 'ngssm-confirmation-dialog', standalone: true, imports: [CommonModule, MatDialogModule, MatButtonModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-dialog-content class=\"flex-column-stretch fxFlex message-container\">\n{{data.message}}\n</mat-dialog-content>\n<mat-dialog-actions class=\"flex-row-center\">\n <span class=\"fxFlex\"></span>\n <button mat-button [matDialogClose]=\"data.cancelLabel\" id=\"cancelButton\">{{data.cancelLabel}}</button>\n <button mat-raised-button [color]=\"data.submitButtonColor\" [matDialogClose]=\"data.submitLabel\" id=\"submitButton\">\n {{data.submitLabel}}\n </button>\n</mat-dialog-actions>\n", styles: [":host .message-container{font-weight:700}\n"] }]
|
|
21
21
|
}], ctorParameters: function () { return [{ type: i1.Store }, { type: undefined, decorators: [{
|
|
@@ -17,9 +17,9 @@ export class NgssmConfirmationDialogService {
|
|
|
17
17
|
.afterClosed();
|
|
18
18
|
}
|
|
19
19
|
}
|
|
20
|
-
NgssmConfirmationDialogService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.
|
|
21
|
-
NgssmConfirmationDialogService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.
|
|
22
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.
|
|
20
|
+
NgssmConfirmationDialogService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmConfirmationDialogService, deps: [{ token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
21
|
+
NgssmConfirmationDialogService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmConfirmationDialogService, providedIn: 'root' });
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmConfirmationDialogService, decorators: [{
|
|
23
23
|
type: Injectable,
|
|
24
24
|
args: [{
|
|
25
25
|
providedIn: 'root'
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export * from './file-picker.component';
|
|
2
|
-
export * from './file-size.pipe';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
export * from './ngssm-file-picker.component';
|
|
2
|
+
export * from './ngssm-file-size.pipe';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3NzbS10b29sa2l0L3NyYy9saWIvZmlsZS1waWNrZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHdCQUF3QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9uZ3NzbS1maWxlLXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9uZ3NzbS1maWxlLXNpemUucGlwZSc7XG4iXX0=
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { Component, HostBinding, Input, Optional, Self, ViewChild } from '@angular/core';
|
|
4
|
+
import { MatFormFieldControl } from '@angular/material/form-field';
|
|
5
|
+
import { BehaviorSubject, Subject } from 'rxjs';
|
|
6
|
+
import { NgssmFileSizePipe } from './ngssm-file-size.pipe';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/forms";
|
|
9
|
+
import * as i2 from "@angular/common";
|
|
10
|
+
export const noop = () => { };
|
|
11
|
+
export class NgssmFilePickerComponent {
|
|
12
|
+
constructor(ngControl) {
|
|
13
|
+
this.ngControl = ngControl;
|
|
14
|
+
this._displayDetails$ = new BehaviorSubject(true);
|
|
15
|
+
this.onChangeCallback = noop;
|
|
16
|
+
this._required = false;
|
|
17
|
+
this._disabled = false;
|
|
18
|
+
this.id = `file-picker-${NgssmFilePickerComponent.nextId++}`;
|
|
19
|
+
this.controlType = 'file-picker';
|
|
20
|
+
this.placeholder = '';
|
|
21
|
+
this.focused = false;
|
|
22
|
+
this.stateChanges = new Subject();
|
|
23
|
+
this.value = null;
|
|
24
|
+
// Replace the provider from above with this.
|
|
25
|
+
if (this.ngControl != null) {
|
|
26
|
+
// Setting the value accessor directly (instead of using
|
|
27
|
+
// the providers) to avoid running into a circular import.
|
|
28
|
+
this.ngControl.valueAccessor = this;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
get empty() {
|
|
32
|
+
return this.value === null;
|
|
33
|
+
}
|
|
34
|
+
get shouldLabelFloat() {
|
|
35
|
+
return this.value !== null;
|
|
36
|
+
}
|
|
37
|
+
get required() {
|
|
38
|
+
return this._required;
|
|
39
|
+
}
|
|
40
|
+
set required(value) {
|
|
41
|
+
this._required = coerceBooleanProperty(value);
|
|
42
|
+
this.stateChanges.next();
|
|
43
|
+
}
|
|
44
|
+
get disabled() {
|
|
45
|
+
return this._disabled;
|
|
46
|
+
}
|
|
47
|
+
set disabled(value) {
|
|
48
|
+
this._disabled = coerceBooleanProperty(value);
|
|
49
|
+
this.stateChanges.next();
|
|
50
|
+
}
|
|
51
|
+
get errorState() {
|
|
52
|
+
return this.ngControl.invalid ?? false;
|
|
53
|
+
}
|
|
54
|
+
get lastModificationDate() {
|
|
55
|
+
if (this.value) {
|
|
56
|
+
const date = new Date(this.value.lastModified);
|
|
57
|
+
return date.toISOString();
|
|
58
|
+
}
|
|
59
|
+
return '';
|
|
60
|
+
}
|
|
61
|
+
get displayDetails$() {
|
|
62
|
+
return this._displayDetails$.asObservable();
|
|
63
|
+
}
|
|
64
|
+
set displayDetails(value) {
|
|
65
|
+
this._displayDetails$.next(value);
|
|
66
|
+
}
|
|
67
|
+
setDescribedByIds(ids) { }
|
|
68
|
+
setDisabledState(isDisabled) {
|
|
69
|
+
this.disabled = isDisabled;
|
|
70
|
+
}
|
|
71
|
+
onContainerClick(event) {
|
|
72
|
+
if (!this.disabled) {
|
|
73
|
+
this.fileInput?.nativeElement.click();
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
writeValue(obj) {
|
|
77
|
+
if (obj !== undefined && obj !== null) {
|
|
78
|
+
this.updateValue(obj);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
registerOnChange(fn) {
|
|
82
|
+
this.onChangeCallback = fn;
|
|
83
|
+
}
|
|
84
|
+
registerOnTouched(fn) { }
|
|
85
|
+
ngOnDestroy() {
|
|
86
|
+
this.stateChanges.complete();
|
|
87
|
+
}
|
|
88
|
+
onDrop(event) {
|
|
89
|
+
this.preventAndStop(event);
|
|
90
|
+
if (!this.disabled) {
|
|
91
|
+
this.updateValue(event.dataTransfer.files);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
onDragOver(event) {
|
|
95
|
+
this.preventAndStop(event);
|
|
96
|
+
}
|
|
97
|
+
onDragLeave(event) {
|
|
98
|
+
this.preventAndStop(event);
|
|
99
|
+
}
|
|
100
|
+
onFileSelected(event) {
|
|
101
|
+
this.updateValue(this.fileInput?.nativeElement.files);
|
|
102
|
+
}
|
|
103
|
+
preventAndStop(event) {
|
|
104
|
+
event.stopPropagation();
|
|
105
|
+
event.preventDefault();
|
|
106
|
+
}
|
|
107
|
+
updateValue(files) {
|
|
108
|
+
if (files.length > 0) {
|
|
109
|
+
this.value = files[0];
|
|
110
|
+
this.stateChanges.next();
|
|
111
|
+
this.onChangeCallback(this.value);
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
NgssmFilePickerComponent.nextId = 0;
|
|
116
|
+
NgssmFilePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmFilePickerComponent, deps: [{ token: i1.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
117
|
+
NgssmFilePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: NgssmFilePickerComponent, isStandalone: true, selector: "ngssm-file-picker", inputs: { required: "required", disabled: "disabled", displayDetails: "displayDetails" }, host: { properties: { "id": "this.id" } }, providers: [{ provide: MatFormFieldControl, useExisting: NgssmFilePickerComponent }], viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"file-picker-container\" (drop)=\"onDrop($event)\" (dragover)=\"onDragOver($event)\"\n (dragleave)=\"onDragLeave($event)\" [ngClass]=\"{'picker-disabled': disabled}\">\n <input type=\"file\" class=\"hidden\" #fileInput (change)=\"onFileSelected($event)\">\n <div *ngIf=\"empty === false\" class=\"flex-row-center\">\n <div class=\"file-picker-file-name\">\n {{value?.name}}\n </div>\n <div class=\"file-picker-file-information\" *ngIf=\"(displayDetails$ | async) === true\">\n {{value?.size | ngssmFileSize}}, last modified on {{lastModificationDate}}\n </div>\n </div>\n</div>", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: NgssmFileSizePipe, name: "ngssmFileSize" }] });
|
|
118
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmFilePickerComponent, decorators: [{
|
|
119
|
+
type: Component,
|
|
120
|
+
args: [{ selector: 'ngssm-file-picker', standalone: true, imports: [CommonModule, NgssmFileSizePipe], providers: [{ provide: MatFormFieldControl, useExisting: NgssmFilePickerComponent }], template: "<div class=\"file-picker-container\" (drop)=\"onDrop($event)\" (dragover)=\"onDragOver($event)\"\n (dragleave)=\"onDragLeave($event)\" [ngClass]=\"{'picker-disabled': disabled}\">\n <input type=\"file\" class=\"hidden\" #fileInput (change)=\"onFileSelected($event)\">\n <div *ngIf=\"empty === false\" class=\"flex-row-center\">\n <div class=\"file-picker-file-name\">\n {{value?.name}}\n </div>\n <div class=\"file-picker-file-information\" *ngIf=\"(displayDetails$ | async) === true\">\n {{value?.size | ngssmFileSize}}, last modified on {{lastModificationDate}}\n </div>\n </div>\n</div>" }]
|
|
121
|
+
}], ctorParameters: function () { return [{ type: i1.NgControl, decorators: [{
|
|
122
|
+
type: Optional
|
|
123
|
+
}, {
|
|
124
|
+
type: Self
|
|
125
|
+
}] }]; }, propDecorators: { fileInput: [{
|
|
126
|
+
type: ViewChild,
|
|
127
|
+
args: ['fileInput', { static: true }]
|
|
128
|
+
}], id: [{
|
|
129
|
+
type: HostBinding,
|
|
130
|
+
args: ['id']
|
|
131
|
+
}], required: [{
|
|
132
|
+
type: Input
|
|
133
|
+
}], disabled: [{
|
|
134
|
+
type: Input
|
|
135
|
+
}], displayDetails: [{
|
|
136
|
+
type: Input
|
|
137
|
+
}] } });
|
|
138
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngssm-file-picker.component.js","sourceRoot":"","sources":["../../../../../projects/ngssm-toolkit/src/lib/file-picker/ngssm-file-picker.component.ts","../../../../../projects/ngssm-toolkit/src/lib/file-picker/ngssm-file-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { CommonModule } from '@angular/common';\nimport { Component, ElementRef, HostBinding, Input, OnDestroy, Optional, Self, ViewChild } from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { MatFormFieldControl } from '@angular/material/form-field';\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\n\nimport { NgssmFileSizePipe } from './ngssm-file-size.pipe';\n\nexport const noop = () => {};\n\n@Component({\n  selector: 'ngssm-file-picker',\n  standalone: true,\n  imports: [CommonModule, NgssmFileSizePipe],\n  templateUrl: './ngssm-file-picker.component.html',\n  styleUrls: ['./ngssm-file-picker.component.scss'],\n  providers: [{ provide: MatFormFieldControl, useExisting: NgssmFilePickerComponent }]\n})\nexport class NgssmFilePickerComponent implements MatFormFieldControl<File>, ControlValueAccessor, OnDestroy {\n  private static nextId = 0;\n\n  private readonly _displayDetails$ = new BehaviorSubject<boolean>(true);\n\n  private onChangeCallback: (_: any) => void = noop;\n  private _required = false;\n  private _disabled = false;\n\n  @ViewChild('fileInput', { static: true }) fileInput: ElementRef | undefined;\n\n  constructor(@Optional() @Self() public ngControl: NgControl) {\n    // Replace the provider from above with this.\n    if (this.ngControl != null) {\n      // Setting the value accessor directly (instead of using\n      // the providers) to avoid running into a circular import.\n      this.ngControl.valueAccessor = this;\n    }\n  }\n\n  @HostBinding('id') public id = `file-picker-${NgssmFilePickerComponent.nextId++}`;\n  public controlType = 'file-picker';\n  public placeholder: string = '';\n  public focused: boolean = false;\n  public stateChanges = new Subject<void>();\n  public value: File | null = null;\n  public autofilled?: boolean | undefined;\n  public userAriaDescribedBy?: string | undefined;\n\n  public get empty(): boolean {\n    return this.value === null;\n  }\n\n  public get shouldLabelFloat(): boolean {\n    return this.value !== null;\n  }\n\n  @Input()\n  public get required(): boolean {\n    return this._required;\n  }\n\n  public set required(value: boolean) {\n    this._required = coerceBooleanProperty(value);\n    this.stateChanges.next();\n  }\n\n  @Input()\n  public get disabled(): boolean {\n    return this._disabled;\n  }\n\n  public set disabled(value: boolean) {\n    this._disabled = coerceBooleanProperty(value);\n    this.stateChanges.next();\n  }\n\n  public get errorState(): boolean {\n    return this.ngControl.invalid ?? false;\n  }\n\n  public get lastModificationDate(): string {\n    if (this.value) {\n      const date = new Date(this.value.lastModified);\n      return date.toISOString();\n    }\n\n    return '';\n  }\n\n  public get displayDetails$(): Observable<boolean> {\n    return this._displayDetails$.asObservable();\n  }\n\n  @Input()\n  public set displayDetails(value: boolean) {\n    this._displayDetails$.next(value);\n  }\n\n  public setDescribedByIds(ids: string[]): void {}\n\n  public setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  public onContainerClick(event: MouseEvent): void {\n    if (!this.disabled) {\n      this.fileInput?.nativeElement.click();\n    }\n  }\n\n  public writeValue(obj: any): void {\n    if (obj !== undefined && obj !== null) {\n      this.updateValue(obj);\n    }\n  }\n\n  public registerOnChange(fn: any): void {\n    this.onChangeCallback = fn;\n  }\n\n  public registerOnTouched(fn: any): void {}\n\n  public ngOnDestroy(): void {\n    this.stateChanges.complete();\n  }\n\n  public onDrop(event: any): void {\n    this.preventAndStop(event);\n    if (!this.disabled) {\n      this.updateValue(event.dataTransfer.files);\n    }\n  }\n\n  public onDragOver(event: any): void {\n    this.preventAndStop(event);\n  }\n\n  public onDragLeave(event: any): void {\n    this.preventAndStop(event);\n  }\n\n  public onFileSelected(event: any): void {\n    this.updateValue(this.fileInput?.nativeElement.files);\n  }\n\n  private preventAndStop(event: any): void {\n    event.stopPropagation();\n    event.preventDefault();\n  }\n\n  private updateValue(files: FileList): void {\n    if (files.length > 0) {\n      this.value = files[0];\n      this.stateChanges.next();\n      this.onChangeCallback(this.value);\n    }\n  }\n}\n","<div class=\"file-picker-container\" (drop)=\"onDrop($event)\" (dragover)=\"onDragOver($event)\"\n    (dragleave)=\"onDragLeave($event)\" [ngClass]=\"{'picker-disabled': disabled}\">\n    <input type=\"file\" class=\"hidden\" #fileInput (change)=\"onFileSelected($event)\">\n    <div *ngIf=\"empty === false\" class=\"flex-row-center\">\n        <div class=\"file-picker-file-name\">\n            {{value?.name}}\n        </div>\n        <div class=\"file-picker-file-information\" *ngIf=\"(displayDetails$ | async) === true\">\n            {{value?.size | ngssmFileSize}}, last modified on {{lastModificationDate}}\n        </div>\n    </div>\n</div>"]}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class NgssmFileSizePipe {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.units = ['bytes', 'KB', 'MB', 'GB'];
|
|
6
|
+
}
|
|
7
|
+
transform(value, precision = 2) {
|
|
8
|
+
let bytes = +value;
|
|
9
|
+
if (isNaN(bytes) || !isFinite(bytes)) {
|
|
10
|
+
return '?';
|
|
11
|
+
}
|
|
12
|
+
let unit = 0;
|
|
13
|
+
while (bytes >= 1024 && unit < this.units.length) {
|
|
14
|
+
bytes /= 1024;
|
|
15
|
+
unit++;
|
|
16
|
+
}
|
|
17
|
+
if (unit === 0) {
|
|
18
|
+
return `${bytes} ${this.units[unit]}`;
|
|
19
|
+
}
|
|
20
|
+
return `${bytes.toFixed(+precision)} ${this.units[unit]}`;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
NgssmFileSizePipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmFileSizePipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
24
|
+
NgssmFileSizePipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "15.2.0", ngImport: i0, type: NgssmFileSizePipe, isStandalone: true, name: "ngssmFileSize" });
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmFileSizePipe, decorators: [{
|
|
26
|
+
type: Pipe,
|
|
27
|
+
args: [{
|
|
28
|
+
name: 'ngssmFileSize',
|
|
29
|
+
standalone: true
|
|
30
|
+
}]
|
|
31
|
+
}] });
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdzc20tZmlsZS1zaXplLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3NzbS10b29sa2l0L3NyYy9saWIvZmlsZS1waWNrZXIvbmdzc20tZmlsZS1zaXplLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBTXBELE1BQU0sT0FBTyxpQkFBaUI7SUFKOUI7UUFLbUIsVUFBSyxHQUFHLENBQUMsT0FBTyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7S0FvQnREO0lBbEJRLFNBQVMsQ0FBQyxLQUFVLEVBQUUsWUFBb0IsQ0FBQztRQUNoRCxJQUFJLEtBQUssR0FBRyxDQUFDLEtBQUssQ0FBQztRQUNuQixJQUFJLEtBQUssQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUNwQyxPQUFPLEdBQUcsQ0FBQztTQUNaO1FBRUQsSUFBSSxJQUFJLEdBQUcsQ0FBQyxDQUFDO1FBQ2IsT0FBTyxLQUFLLElBQUksSUFBSSxJQUFJLElBQUksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRTtZQUNoRCxLQUFLLElBQUksSUFBSSxDQUFDO1lBQ2QsSUFBSSxFQUFFLENBQUM7U0FDUjtRQUVELElBQUksSUFBSSxLQUFLLENBQUMsRUFBRTtZQUNkLE9BQU8sR0FBRyxLQUFLLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDO1NBQ3ZDO1FBRUQsT0FBTyxHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxTQUFTLENBQUMsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7SUFDNUQsQ0FBQzs7OEdBcEJVLGlCQUFpQjs0R0FBakIsaUJBQWlCOzJGQUFqQixpQkFBaUI7a0JBSjdCLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLGVBQWU7b0JBQ3JCLFVBQVUsRUFBRSxJQUFJO2lCQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQFBpcGUoe1xuICBuYW1lOiAnbmdzc21GaWxlU2l6ZScsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgTmdzc21GaWxlU2l6ZVBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcbiAgcHJpdmF0ZSByZWFkb25seSB1bml0cyA9IFsnYnl0ZXMnLCAnS0InLCAnTUInLCAnR0InXTtcblxuICBwdWJsaWMgdHJhbnNmb3JtKHZhbHVlOiBhbnksIHByZWNpc2lvbjogbnVtYmVyID0gMik6IGFueSB7XG4gICAgbGV0IGJ5dGVzID0gK3ZhbHVlO1xuICAgIGlmIChpc05hTihieXRlcykgfHwgIWlzRmluaXRlKGJ5dGVzKSkge1xuICAgICAgcmV0dXJuICc/JztcbiAgICB9XG5cbiAgICBsZXQgdW5pdCA9IDA7XG4gICAgd2hpbGUgKGJ5dGVzID49IDEwMjQgJiYgdW5pdCA8IHRoaXMudW5pdHMubGVuZ3RoKSB7XG4gICAgICBieXRlcyAvPSAxMDI0O1xuICAgICAgdW5pdCsrO1xuICAgIH1cblxuICAgIGlmICh1bml0ID09PSAwKSB7XG4gICAgICByZXR1cm4gYCR7Ynl0ZXN9ICR7dGhpcy51bml0c1t1bml0XX1gO1xuICAgIH1cblxuICAgIHJldHVybiBgJHtieXRlcy50b0ZpeGVkKCtwcmVjaXNpb24pfSAke3RoaXMudW5pdHNbdW5pdF19YDtcbiAgfVxufVxuIl19
|
|
@@ -50,8 +50,8 @@ const modules = [
|
|
|
50
50
|
];
|
|
51
51
|
export class MaterialImportsModule {
|
|
52
52
|
}
|
|
53
|
-
MaterialImportsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.
|
|
54
|
-
MaterialImportsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.
|
|
53
|
+
MaterialImportsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: MaterialImportsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
54
|
+
MaterialImportsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.0", ngImport: i0, type: MaterialImportsModule, imports: [CommonModule,
|
|
55
55
|
MatToolbarModule,
|
|
56
56
|
MatSidenavModule,
|
|
57
57
|
MatButtonModule,
|
|
@@ -96,7 +96,7 @@ MaterialImportsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", v
|
|
|
96
96
|
MatSnackBarModule,
|
|
97
97
|
MatTabsModule,
|
|
98
98
|
MatExpansionModule] });
|
|
99
|
-
MaterialImportsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.
|
|
99
|
+
MaterialImportsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: MaterialImportsModule, imports: [modules, CommonModule,
|
|
100
100
|
MatToolbarModule,
|
|
101
101
|
MatSidenavModule,
|
|
102
102
|
MatButtonModule,
|
|
@@ -119,7 +119,7 @@ MaterialImportsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", v
|
|
|
119
119
|
MatSnackBarModule,
|
|
120
120
|
MatTabsModule,
|
|
121
121
|
MatExpansionModule] });
|
|
122
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.
|
|
122
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: MaterialImportsModule, decorators: [{
|
|
123
123
|
type: NgModule,
|
|
124
124
|
args: [{
|
|
125
125
|
declarations: [],
|
|
@@ -1,11 +1,12 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
1
2
|
import { Component } from '@angular/core';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
export class NotFoundComponent {
|
|
4
5
|
}
|
|
5
|
-
NotFoundComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.
|
|
6
|
-
NotFoundComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.
|
|
7
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.
|
|
6
|
+
NotFoundComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NotFoundComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
7
|
+
NotFoundComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: NotFoundComponent, isStandalone: true, selector: "ngssm-not-found", ngImport: i0, template: ` <img src="./assets/404-not-found.png" /> `, isInline: true, styles: [":host{display:flex;flex-direction:row;flex:1;align-items:center;justify-content:center}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }] });
|
|
8
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NotFoundComponent, decorators: [{
|
|
8
9
|
type: Component,
|
|
9
|
-
args: [{ selector: 'ngssm-not-found', template: ` <img src="./assets/404-not-found.png" /> `, styles: [":host{display:flex;flex-direction:row;flex:1;align-items:center;justify-content:center}\n"] }]
|
|
10
|
+
args: [{ selector: 'ngssm-not-found', standalone: true, imports: [CommonModule], template: ` <img src="./assets/404-not-found.png" /> `, styles: [":host{display:flex;flex-direction:row;flex:1;align-items:center;justify-content:center}\n"] }]
|
|
10
11
|
}] });
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90LWZvdW5kLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25nc3NtLXRvb2xraXQvc3JjL2xpYi9ub3QtZm91bmQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQW1CMUMsTUFBTSxPQUFPLGlCQUFpQjs7OEdBQWpCLGlCQUFpQjtrR0FBakIsaUJBQWlCLDJFQWJsQiw0Q0FBNEMsa0tBRDVDLFlBQVk7MkZBY1gsaUJBQWlCO2tCQWpCN0IsU0FBUzsrQkFDRSxpQkFBaUIsY0FDZixJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUMsWUFDYiw0Q0FBNEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ25nc3NtLW5vdC1mb3VuZCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZTogYCA8aW1nIHNyYz1cIi4vYXNzZXRzLzQwNC1ub3QtZm91bmQucG5nXCIgLz4gYCxcbiAgc3R5bGVzOiBbXG4gICAgYFxuICAgICAgOmhvc3Qge1xuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBmbGV4LWRpcmVjdGlvbjogcm93O1xuICAgICAgICBmbGV4OiAxO1xuICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgICAgIH1cbiAgICBgXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgTm90Rm91bmRDb21wb25lbnQge31cbiJdfQ==
|
package/esm2020/lib/notification/ngssm-notification-error/ngssm-notification-error.component.mjs
CHANGED
|
@@ -9,9 +9,9 @@ export class NgssmNotificationErrorComponent {
|
|
|
9
9
|
this.message = message;
|
|
10
10
|
}
|
|
11
11
|
}
|
|
12
|
-
NgssmNotificationErrorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.
|
|
13
|
-
NgssmNotificationErrorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.
|
|
14
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.
|
|
12
|
+
NgssmNotificationErrorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmNotificationErrorComponent, deps: [{ token: MAT_SNACK_BAR_DATA }], target: i0.ɵɵFactoryTarget.Component });
|
|
13
|
+
NgssmNotificationErrorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: NgssmNotificationErrorComponent, isStandalone: true, selector: "ngssm-notification-error", ngImport: i0, template: "<mat-icon class=\"fa-solid fa-triangle-exclamation with-margin-right-12\" color=\"accent\"></mat-icon>\n<span class=\"ngssm-notification-error-message\">{{message}}</span>\n", styles: [":host{display:flex;flex-direction:row;align-items:center}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmNotificationErrorComponent, decorators: [{
|
|
15
15
|
type: Component,
|
|
16
16
|
args: [{ selector: 'ngssm-notification-error', standalone: true, imports: [CommonModule, MatIconModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-icon class=\"fa-solid fa-triangle-exclamation with-margin-right-12\" color=\"accent\"></mat-icon>\n<span class=\"ngssm-notification-error-message\">{{message}}</span>\n", styles: [":host{display:flex;flex-direction:row;align-items:center}\n"] }]
|
|
17
17
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
package/esm2020/lib/notification/ngssm-notification-success/ngssm-notification-success.component.mjs
CHANGED
|
@@ -9,9 +9,9 @@ export class NgssmNotificationSuccessComponent {
|
|
|
9
9
|
this.message = message;
|
|
10
10
|
}
|
|
11
11
|
}
|
|
12
|
-
NgssmNotificationSuccessComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.
|
|
13
|
-
NgssmNotificationSuccessComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.
|
|
14
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.
|
|
12
|
+
NgssmNotificationSuccessComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmNotificationSuccessComponent, deps: [{ token: MAT_SNACK_BAR_DATA }], target: i0.ɵɵFactoryTarget.Component });
|
|
13
|
+
NgssmNotificationSuccessComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: NgssmNotificationSuccessComponent, isStandalone: true, selector: "ngssm-notification-success", ngImport: i0, template: "<mat-icon class=\"fa-solid fa-check with-margin-right-12 ngssm-notification-success-icon\" color=\"primary\"></mat-icon>\n<span class=\"ngssm-notification-success-message\">{{message}}</span>\n\n", styles: [":host{display:flex;flex-direction:row;align-items:center}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmNotificationSuccessComponent, decorators: [{
|
|
15
15
|
type: Component,
|
|
16
16
|
args: [{ selector: 'ngssm-notification-success', standalone: true, imports: [CommonModule, MatIconModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-icon class=\"fa-solid fa-check with-margin-right-12 ngssm-notification-success-icon\" color=\"primary\"></mat-icon>\n<span class=\"ngssm-notification-success-message\">{{message}}</span>\n\n", styles: [":host{display:flex;flex-direction:row;align-items:center}\n"] }]
|
|
17
17
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
@@ -20,9 +20,9 @@ export class NgssmNotifierService {
|
|
|
20
20
|
});
|
|
21
21
|
}
|
|
22
22
|
}
|
|
23
|
-
NgssmNotifierService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.
|
|
24
|
-
NgssmNotifierService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.
|
|
25
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.
|
|
23
|
+
NgssmNotifierService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmNotifierService, deps: [{ token: i1.MatSnackBar }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
24
|
+
NgssmNotifierService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmNotifierService, providedIn: 'root' });
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmNotifierService, decorators: [{
|
|
26
26
|
type: Injectable,
|
|
27
27
|
args: [{
|
|
28
28
|
providedIn: 'root'
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
export * from './component-overlay.directive';
|
|
2
|
-
export * from './empty-overlay.component';
|
|
3
|
-
export * from './message-overlay.component';
|
|
1
|
+
export * from './ngssm-component-overlay.directive';
|
|
2
|
+
export * from './ngssm-empty-overlay.component';
|
|
3
|
+
export * from './ngssm-message-overlay.component';
|
|
4
4
|
export * from './ngssm-overlay-builder';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3NzbS10b29sa2l0L3NyYy9saWIvb3ZlcmxheS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLHlCQUF5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9uZ3NzbS1jb21wb25lbnQtb3ZlcmxheS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9uZ3NzbS1lbXB0eS1vdmVybGF5LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL25nc3NtLW1lc3NhZ2Utb3ZlcmxheS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9uZ3NzbS1vdmVybGF5LWJ1aWxkZXInO1xuIl19
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { Overlay } from '@angular/cdk/overlay';
|
|
2
|
+
import { DOCUMENT } from '@angular/common';
|
|
3
|
+
import { Directive, Inject, Input } from '@angular/core';
|
|
4
|
+
import { ComponentPortal, TemplatePortal } from '@angular/cdk/portal';
|
|
5
|
+
import { BehaviorSubject, Subject, takeUntil } from 'rxjs';
|
|
6
|
+
import { NgssmMessageOverlayComponent } from './ngssm-message-overlay.component';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/cdk/overlay";
|
|
9
|
+
import * as i2 from "@angular/cdk/bidi";
|
|
10
|
+
import * as i3 from "@angular/common";
|
|
11
|
+
export class NgssmComponentOverlayDirective {
|
|
12
|
+
constructor(elementRef, viewContainerRef, document, scrollStrategies,
|
|
13
|
+
// eslint-disable-next-line deprecation/deprecation
|
|
14
|
+
componentFactoryResolver, positionBuilder, keyboardDispatcher, injector, ngZone, directionality, location, outsideClickDispatcher, renderer) {
|
|
15
|
+
this.elementRef = elementRef;
|
|
16
|
+
this.viewContainerRef = viewContainerRef;
|
|
17
|
+
this.unSubscribeAll$ = new Subject();
|
|
18
|
+
this._displayOverlay$ = new BehaviorSubject(false);
|
|
19
|
+
this._overlayMessage$ = new BehaviorSubject('Please wait');
|
|
20
|
+
renderer.setStyle(this.elementRef.nativeElement, 'position', 'relative');
|
|
21
|
+
const container = {
|
|
22
|
+
getContainerElement: () => this.elementRef.nativeElement
|
|
23
|
+
};
|
|
24
|
+
this.overlay = new Overlay(scrollStrategies, container, componentFactoryResolver, positionBuilder, keyboardDispatcher, injector, ngZone, document, directionality, location, outsideClickDispatcher);
|
|
25
|
+
this.overlayRef = this.overlay.create({
|
|
26
|
+
positionStrategy: this.overlay.position().global().centerHorizontally().centerVertically(),
|
|
27
|
+
hasBackdrop: true
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
set overlayMessage(value) {
|
|
31
|
+
this._overlayMessage$.next(value);
|
|
32
|
+
}
|
|
33
|
+
set dispalyOverlay(value) {
|
|
34
|
+
this._displayOverlay$.next(value);
|
|
35
|
+
}
|
|
36
|
+
ngAfterViewInit() {
|
|
37
|
+
this._displayOverlay$.pipe(takeUntil(this.unSubscribeAll$)).subscribe((v) => {
|
|
38
|
+
if (v) {
|
|
39
|
+
this.showOverlay();
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
this.hideOverlay();
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
ngOnDestroy() {
|
|
47
|
+
this.unSubscribeAll$.next();
|
|
48
|
+
this.unSubscribeAll$.complete();
|
|
49
|
+
if (this._displayOverlay$.getValue()) {
|
|
50
|
+
this.overlayRef.detach();
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
showOverlay() {
|
|
54
|
+
if (this.overLayTemplate) {
|
|
55
|
+
this.overlayRef.attach(new TemplatePortal(this.overLayTemplate, this.viewContainerRef));
|
|
56
|
+
}
|
|
57
|
+
else if (this.overlayComponent) {
|
|
58
|
+
const ref = this.overlayRef.attach(new ComponentPortal(this.overlayComponent));
|
|
59
|
+
if (this.overlayComponent === NgssmMessageOverlayComponent) {
|
|
60
|
+
ref.instance.message$ = this._overlayMessage$.asObservable();
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
const ref = this.overlayRef.attach(new ComponentPortal(NgssmMessageOverlayComponent));
|
|
65
|
+
ref.instance.message$ = this._overlayMessage$.asObservable();
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
hideOverlay() {
|
|
69
|
+
this.overlayRef.detach();
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
NgssmComponentOverlayDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmComponentOverlayDirective, deps: [{ token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: DOCUMENT }, { token: i1.ScrollStrategyOptions }, { token: i0.ComponentFactoryResolver }, { token: i1.OverlayPositionBuilder }, { token: i1.OverlayKeyboardDispatcher }, { token: i0.Injector }, { token: i0.NgZone }, { token: i2.Directionality }, { token: i3.Location }, { token: i1.OverlayOutsideClickDispatcher }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
|
|
73
|
+
NgssmComponentOverlayDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.0", type: NgssmComponentOverlayDirective, isStandalone: true, selector: "[ngssmDisplayOverlay]", inputs: { overLayTemplate: ["overlayTemplate", "overLayTemplate"], overlayComponent: "overlayComponent", overlayMessage: "overlayMessage", dispalyOverlay: ["ngssmDisplayOverlay", "dispalyOverlay"] }, ngImport: i0 });
|
|
74
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmComponentOverlayDirective, decorators: [{
|
|
75
|
+
type: Directive,
|
|
76
|
+
args: [{
|
|
77
|
+
selector: '[ngssmDisplayOverlay]',
|
|
78
|
+
standalone: true
|
|
79
|
+
}]
|
|
80
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: undefined, decorators: [{
|
|
81
|
+
type: Inject,
|
|
82
|
+
args: [DOCUMENT]
|
|
83
|
+
}] }, { type: i1.ScrollStrategyOptions }, { type: i0.ComponentFactoryResolver }, { type: i1.OverlayPositionBuilder }, { type: i1.OverlayKeyboardDispatcher }, { type: i0.Injector }, { type: i0.NgZone }, { type: i2.Directionality }, { type: i3.Location }, { type: i1.OverlayOutsideClickDispatcher }, { type: i0.Renderer2 }]; }, propDecorators: { overLayTemplate: [{
|
|
84
|
+
type: Input,
|
|
85
|
+
args: ['overlayTemplate']
|
|
86
|
+
}], overlayComponent: [{
|
|
87
|
+
type: Input
|
|
88
|
+
}], overlayMessage: [{
|
|
89
|
+
type: Input
|
|
90
|
+
}], dispalyOverlay: [{
|
|
91
|
+
type: Input,
|
|
92
|
+
args: ['ngssmDisplayOverlay']
|
|
93
|
+
}] } });
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngssm-component-overlay.directive.js","sourceRoot":"","sources":["../../../../../projects/ngssm-toolkit/src/lib/overlay/ngssm-component-overlay.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Overlay,\n  OverlayKeyboardDispatcher,\n  OverlayOutsideClickDispatcher,\n  OverlayPositionBuilder,\n  OverlayRef,\n  ScrollStrategyOptions\n} from '@angular/cdk/overlay';\nimport { DOCUMENT } from '@angular/common';\nimport {\n  AfterViewInit,\n  ComponentFactoryResolver,\n  Directive,\n  ElementRef,\n  Inject,\n  Injector,\n  Input,\n  NgZone,\n  OnDestroy,\n  Renderer2,\n  TemplateRef,\n  ViewContainerRef\n} from '@angular/core';\nimport { Location } from '@angular/common';\nimport { Directionality } from '@angular/cdk/bidi';\nimport { ComponentPortal, ComponentType, TemplatePortal } from '@angular/cdk/portal';\nimport { BehaviorSubject, Subject, takeUntil } from 'rxjs';\n\nimport { NgssmMessageOverlayComponent } from './ngssm-message-overlay.component';\n\n@Directive({\n  selector: '[ngssmDisplayOverlay]',\n  standalone: true\n})\nexport class NgssmComponentOverlayDirective implements OnDestroy, AfterViewInit {\n  private readonly unSubscribeAll$ = new Subject<void>();\n  private readonly _displayOverlay$ = new BehaviorSubject<boolean>(false);\n  private readonly _overlayMessage$ = new BehaviorSubject<string>('Please wait');\n\n  private overlay: Overlay;\n  private overlayRef: OverlayRef;\n\n  constructor(\n    private elementRef: ElementRef,\n    private viewContainerRef: ViewContainerRef,\n    @Inject(DOCUMENT) document: any,\n    scrollStrategies: ScrollStrategyOptions,\n    // eslint-disable-next-line deprecation/deprecation\n    componentFactoryResolver: ComponentFactoryResolver,\n    positionBuilder: OverlayPositionBuilder,\n    keyboardDispatcher: OverlayKeyboardDispatcher,\n    injector: Injector,\n    ngZone: NgZone,\n    directionality: Directionality,\n    location: Location,\n    outsideClickDispatcher: OverlayOutsideClickDispatcher,\n    renderer: Renderer2\n  ) {\n    renderer.setStyle(this.elementRef.nativeElement, 'position', 'relative');\n    const container = {\n      getContainerElement: () => this.elementRef.nativeElement\n    };\n\n    this.overlay = new Overlay(\n      scrollStrategies,\n      container as any,\n      componentFactoryResolver,\n      positionBuilder,\n      keyboardDispatcher,\n      injector,\n      ngZone,\n      document,\n      directionality,\n      location,\n      outsideClickDispatcher\n    );\n\n    this.overlayRef = this.overlay.create({\n      positionStrategy: this.overlay.position().global().centerHorizontally().centerVertically(),\n      hasBackdrop: true\n    });\n  }\n\n  // eslint-disable-next-line @angular-eslint/no-input-rename\n  @Input('overlayTemplate') overLayTemplate: TemplateRef<any> | undefined;\n\n  @Input() overlayComponent: ComponentType<any> | undefined;\n\n  @Input() public set overlayMessage(value: string) {\n    this._overlayMessage$.next(value);\n  }\n\n  @Input('ngssmDisplayOverlay') public set dispalyOverlay(value: boolean) {\n    this._displayOverlay$.next(value);\n  }\n\n  public ngAfterViewInit(): void {\n    this._displayOverlay$.pipe(takeUntil(this.unSubscribeAll$)).subscribe((v) => {\n      if (v) {\n        this.showOverlay();\n      } else {\n        this.hideOverlay();\n      }\n    });\n  }\n\n  public ngOnDestroy(): void {\n    this.unSubscribeAll$.next();\n    this.unSubscribeAll$.complete();\n    if (this._displayOverlay$.getValue()) {\n      this.overlayRef.detach();\n    }\n  }\n\n  private showOverlay(): void {\n    if (this.overLayTemplate) {\n      this.overlayRef.attach(new TemplatePortal(this.overLayTemplate, this.viewContainerRef));\n    } else if (this.overlayComponent) {\n      const ref = this.overlayRef.attach(new ComponentPortal(this.overlayComponent));\n      if (this.overlayComponent === NgssmMessageOverlayComponent) {\n        ref.instance.message$ = this._overlayMessage$.asObservable();\n      }\n    } else {\n      const ref = this.overlayRef.attach(new ComponentPortal(NgssmMessageOverlayComponent));\n      ref.instance.message$ = this._overlayMessage$.asObservable();\n    }\n  }\n\n  private hideOverlay(): void {\n    this.overlayRef.detach();\n  }\n}\n"]}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class NgssmEmptyOverlayComponent {
|
|
4
|
+
}
|
|
5
|
+
NgssmEmptyOverlayComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmEmptyOverlayComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
6
|
+
NgssmEmptyOverlayComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: NgssmEmptyOverlayComponent, isStandalone: true, selector: "ngssm-empty-overlay", ngImport: i0, template: ``, isInline: true });
|
|
7
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmEmptyOverlayComponent, decorators: [{
|
|
8
|
+
type: Component,
|
|
9
|
+
args: [{ selector: 'ngssm-empty-overlay', standalone: true, template: `` }]
|
|
10
|
+
}] });
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdzc20tZW1wdHktb3ZlcmxheS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3NzbS10b29sa2l0L3NyYy9saWIvb3ZlcmxheS9uZ3NzbS1lbXB0eS1vdmVybGF5LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVExQyxNQUFNLE9BQU8sMEJBQTBCOzt1SEFBMUIsMEJBQTBCOzJHQUExQiwwQkFBMEIsK0VBSDNCLEVBQUU7MkZBR0QsMEJBQTBCO2tCQU50QyxTQUFTOytCQUNFLHFCQUFxQixjQUNuQixJQUFJLFlBQ04sRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICduZ3NzbS1lbXB0eS1vdmVybGF5JyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgdGVtcGxhdGU6IGBgLFxuICBzdHlsZXM6IFtdXG59KVxuZXhwb3J0IGNsYXNzIE5nc3NtRW1wdHlPdmVybGF5Q29tcG9uZW50IHt9XG4iXX0=
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component } from '@angular/core';
|
|
3
|
+
import { MatCardModule } from '@angular/material/card';
|
|
4
|
+
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
|
5
|
+
import { Subject } from 'rxjs';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
import * as i2 from "@angular/material/card";
|
|
9
|
+
import * as i3 from "@angular/material/progress-spinner";
|
|
10
|
+
export class NgssmMessageOverlayComponent {
|
|
11
|
+
constructor() {
|
|
12
|
+
this.message$ = new Subject();
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
NgssmMessageOverlayComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmMessageOverlayComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
16
|
+
NgssmMessageOverlayComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.0", type: NgssmMessageOverlayComponent, isStandalone: true, selector: "ngssm-message-overlay", ngImport: i0, template: `
|
|
17
|
+
<mat-card>
|
|
18
|
+
<mat-card-content class="message-container">
|
|
19
|
+
<mat-spinner></mat-spinner>
|
|
20
|
+
{{ message$ | async }}
|
|
21
|
+
</mat-card-content>
|
|
22
|
+
</mat-card>
|
|
23
|
+
`, isInline: true, styles: [".message-container{display:flex!important;flex-direction:column;align-items:center}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "ngmodule", type: MatCardModule }, { kind: "component", type: i2.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i2.MatCardContent, selector: "mat-card-content" }, { kind: "ngmodule", type: MatProgressSpinnerModule }, { kind: "component", type: i3.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }] });
|
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.0", ngImport: i0, type: NgssmMessageOverlayComponent, decorators: [{
|
|
25
|
+
type: Component,
|
|
26
|
+
args: [{ selector: 'ngssm-message-overlay', standalone: true, imports: [CommonModule, MatCardModule, MatProgressSpinnerModule], template: `
|
|
27
|
+
<mat-card>
|
|
28
|
+
<mat-card-content class="message-container">
|
|
29
|
+
<mat-spinner></mat-spinner>
|
|
30
|
+
{{ message$ | async }}
|
|
31
|
+
</mat-card-content>
|
|
32
|
+
</mat-card>
|
|
33
|
+
`, styles: [".message-container{display:flex!important;flex-direction:column;align-items:center}\n"] }]
|
|
34
|
+
}] });
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmdzc20tbWVzc2FnZS1vdmVybGF5LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nc3NtLXRvb2xraXQvc3JjL2xpYi9vdmVybGF5L25nc3NtLW1lc3NhZ2Utb3ZlcmxheS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQzlFLE9BQU8sRUFBYyxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7Ozs7O0FBd0IzQyxNQUFNLE9BQU8sNEJBQTRCO0lBdEJ6QztRQXVCUyxhQUFRLEdBQXVCLElBQUksT0FBTyxFQUFVLENBQUM7S0FDN0Q7O3lIQUZZLDRCQUE0Qjs2R0FBNUIsNEJBQTRCLGlGQWxCN0I7Ozs7Ozs7R0FPVCw4SkFSUyxZQUFZLG1GQUFFLGFBQWEsME5BQUUsd0JBQXdCOzJGQW1CcEQsNEJBQTRCO2tCQXRCeEMsU0FBUzsrQkFDRSx1QkFBdUIsY0FDckIsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLGFBQWEsRUFBRSx3QkFBd0IsQ0FBQyxZQUN0RDs7Ozs7OztHQU9UIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0Q2FyZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NhcmQnO1xuaW1wb3J0IHsgTWF0UHJvZ3Jlc3NTcGlubmVyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcHJvZ3Jlc3Mtc3Bpbm5lcic7XG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ25nc3NtLW1lc3NhZ2Utb3ZlcmxheScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE1hdENhcmRNb2R1bGUsIE1hdFByb2dyZXNzU3Bpbm5lck1vZHVsZV0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPG1hdC1jYXJkPlxuICAgICAgPG1hdC1jYXJkLWNvbnRlbnQgY2xhc3M9XCJtZXNzYWdlLWNvbnRhaW5lclwiPlxuICAgICAgICA8bWF0LXNwaW5uZXI+PC9tYXQtc3Bpbm5lcj5cbiAgICAgICAge3sgbWVzc2FnZSQgfCBhc3luYyB9fVxuICAgICAgPC9tYXQtY2FyZC1jb250ZW50PlxuICAgIDwvbWF0LWNhcmQ+XG4gIGAsXG4gIHN0eWxlczogW1xuICAgIGBcbiAgICAgIC5tZXNzYWdlLWNvbnRhaW5lciB7XG4gICAgICAgIGRpc3BsYXk6IGZsZXggIWltcG9ydGFudDtcbiAgICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgIH1cbiAgICBgXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgTmdzc21NZXNzYWdlT3ZlcmxheUNvbXBvbmVudCB7XG4gIHB1YmxpYyBtZXNzYWdlJDogT2JzZXJ2YWJsZTxzdHJpbmc+ID0gbmV3IFN1YmplY3Q8c3RyaW5nPigpO1xufVxuIl19
|