@ecodev/natural 60.1.1 → 61.0.1
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/esm2022/lib/classes/abstract-detail.mjs +2 -3
- package/esm2022/lib/classes/abstract-editable-list.mjs +3 -5
- package/esm2022/lib/classes/abstract-list.mjs +6 -5
- package/esm2022/lib/classes/abstract-navigable-list.mjs +4 -3
- package/esm2022/lib/classes/rxjs.mjs +11 -5
- package/esm2022/lib/modules/alert/alert.service.mjs +9 -9
- package/esm2022/lib/modules/alert/confirm.component.mjs +6 -9
- package/esm2022/lib/modules/avatar/component/avatar.component.mjs +9 -9
- package/esm2022/lib/modules/columns-picker/columns-picker.component.mjs +30 -35
- package/esm2022/lib/modules/columns-picker/public-api.mjs +1 -1
- package/esm2022/lib/modules/common/directives/background-density.directive.mjs +7 -7
- package/esm2022/lib/modules/common/directives/linkable-tab.directive.mjs +16 -19
- package/esm2022/lib/modules/common/directives/src-density.directive.mjs +7 -7
- package/esm2022/lib/modules/common/pipes/enum.pipe.mjs +7 -7
- package/esm2022/lib/modules/common/public-api.mjs +2 -2
- package/esm2022/lib/modules/common/services/seo.service.mjs +13 -22
- package/esm2022/lib/modules/dialog-trigger/dialog-trigger.component.mjs +10 -10
- package/esm2022/lib/modules/dropdown-components/public-api.mjs +3 -3
- package/esm2022/lib/modules/dropdown-components/type-boolean/type-boolean.component.mjs +10 -13
- package/esm2022/lib/modules/dropdown-components/type-date/type-date.component.mjs +14 -19
- package/esm2022/lib/modules/dropdown-components/type-date-range/type-date-range.component.mjs +14 -20
- package/esm2022/lib/modules/dropdown-components/type-number/type-number.component.mjs +14 -16
- package/esm2022/lib/modules/dropdown-components/type-options/type-options.component.mjs +10 -10
- package/esm2022/lib/modules/dropdown-components/type-select/type-select.component.mjs +14 -16
- package/esm2022/lib/modules/dropdown-components/type-text/type-text.component.mjs +12 -14
- package/esm2022/lib/modules/file/abstract-file.mjs +3 -6
- package/esm2022/lib/modules/file/component/file.component.mjs +14 -17
- package/esm2022/lib/modules/file/file-drop.directive.mjs +6 -4
- package/esm2022/lib/modules/file/file.service.mjs +6 -9
- package/esm2022/lib/modules/file/public-api.mjs +1 -1
- package/esm2022/lib/modules/fixed-button-detail/fixed-button-detail.component.mjs +9 -8
- package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.mjs +19 -20
- package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.service.mjs +6 -6
- package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.mjs +8 -10
- package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.service.mjs +7 -7
- package/esm2022/lib/modules/icon/icon.directive.mjs +12 -20
- package/esm2022/lib/modules/logger/error-handler.mjs +10 -24
- package/esm2022/lib/modules/logger/public-api.mjs +2 -2
- package/esm2022/lib/modules/matomo/matomo.service.mjs +11 -19
- package/esm2022/lib/modules/panels/abstract-panel.mjs +9 -9
- package/esm2022/lib/modules/panels/panels.component.mjs +9 -8
- package/esm2022/lib/modules/panels/panels.service.mjs +13 -17
- package/esm2022/lib/modules/relations/relations.component.mjs +34 -34
- package/esm2022/lib/modules/search/dropdown-container/dropdown-container.component.mjs +12 -15
- package/esm2022/lib/modules/search/dropdown-container/dropdown.service.mjs +8 -9
- package/esm2022/lib/modules/search/facet-selector/facet-selector.component.mjs +11 -14
- package/esm2022/lib/modules/search/input/input.component.mjs +26 -27
- package/esm2022/lib/modules/search/public-api.mjs +1 -1
- package/esm2022/lib/modules/search/search/search.component.mjs +19 -20
- package/esm2022/lib/modules/select/abstract-select.component.mjs +3 -5
- package/esm2022/lib/modules/select/select/select.component.mjs +7 -5
- package/esm2022/lib/modules/select/select-enum/select-enum.component.mjs +15 -18
- package/esm2022/lib/modules/select/select-hierarchic/select-hierarchic.component.mjs +16 -19
- package/esm2022/lib/modules/sidenav/sidenav-container/sidenav-container.component.mjs +9 -10
- package/esm2022/lib/modules/sidenav/sidenav.service.mjs +18 -23
- package/esm2022/lib/services/enum.service.mjs +7 -8
- package/esm2022/lib/services/link-mutation.service.mjs +7 -8
- package/esm2022/lib/services/persistence.service.mjs +9 -19
- package/esm2022/public-api.mjs +2 -3
- package/fesm2022/ecodev-natural.mjs +377 -504
- package/fesm2022/ecodev-natural.mjs.map +1 -1
- package/lib/classes/abstract-detail.d.ts +0 -1
- package/lib/classes/abstract-editable-list.d.ts +1 -2
- package/lib/classes/abstract-list.d.ts +2 -2
- package/lib/classes/abstract-navigable-list.d.ts +2 -2
- package/lib/classes/rxjs.d.ts +9 -2
- package/lib/modules/alert/alert.service.d.ts +1 -3
- package/lib/modules/alert/confirm.component.d.ts +1 -2
- package/lib/modules/avatar/component/avatar.component.d.ts +0 -2
- package/lib/modules/columns-picker/columns-picker.component.d.ts +3 -6
- package/lib/modules/columns-picker/public-api.d.ts +1 -1
- package/lib/modules/common/directives/background-density.directive.d.ts +0 -2
- package/lib/modules/common/directives/linkable-tab.directive.d.ts +3 -5
- package/lib/modules/common/directives/src-density.directive.d.ts +0 -2
- package/lib/modules/common/pipes/enum.pipe.d.ts +0 -2
- package/lib/modules/common/public-api.d.ts +2 -1
- package/lib/modules/common/services/seo.service.d.ts +2 -3
- package/lib/modules/dialog-trigger/dialog-trigger.component.d.ts +3 -3
- package/lib/modules/dropdown-components/public-api.d.ts +9 -9
- package/lib/modules/dropdown-components/type-boolean/type-boolean.component.d.ts +1 -3
- package/lib/modules/dropdown-components/type-date/type-date.component.d.ts +1 -3
- package/lib/modules/dropdown-components/type-date-range/type-date-range.component.d.ts +2 -3
- package/lib/modules/dropdown-components/type-number/type-number.component.d.ts +1 -2
- package/lib/modules/dropdown-components/type-options/type-options.component.d.ts +3 -3
- package/lib/modules/dropdown-components/type-select/type-select.component.d.ts +4 -5
- package/lib/modules/dropdown-components/type-text/type-text.component.d.ts +1 -2
- package/lib/modules/file/abstract-file.d.ts +1 -2
- package/lib/modules/file/component/file.component.d.ts +0 -3
- package/lib/modules/file/file-drop.directive.d.ts +1 -0
- package/lib/modules/file/file.service.d.ts +0 -1
- package/lib/modules/file/public-api.d.ts +1 -1
- package/lib/modules/fixed-button-detail/fixed-button-detail.component.d.ts +1 -2
- package/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.d.ts +3 -4
- package/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.service.d.ts +0 -2
- package/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.d.ts +1 -2
- package/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.service.d.ts +1 -2
- package/lib/modules/icon/icon.directive.d.ts +3 -5
- package/lib/modules/logger/error-handler.d.ts +3 -4
- package/lib/modules/logger/public-api.d.ts +2 -1
- package/lib/modules/matomo/matomo.service.d.ts +2 -5
- package/lib/modules/panels/abstract-panel.d.ts +3 -2
- package/lib/modules/panels/panels.component.d.ts +1 -3
- package/lib/modules/panels/panels.service.d.ts +2 -6
- package/lib/modules/relations/relations.component.d.ts +4 -6
- package/lib/modules/search/dropdown-container/dropdown-container.component.d.ts +3 -4
- package/lib/modules/search/dropdown-container/dropdown.service.d.ts +1 -3
- package/lib/modules/search/facet-selector/facet-selector.component.d.ts +1 -2
- package/lib/modules/search/input/input.component.d.ts +1 -3
- package/lib/modules/search/public-api.d.ts +5 -5
- package/lib/modules/search/search/search.component.d.ts +0 -2
- package/lib/modules/select/abstract-select.component.d.ts +2 -3
- package/lib/modules/select/select/select.component.d.ts +3 -2
- package/lib/modules/select/select-enum/select-enum.component.d.ts +4 -4
- package/lib/modules/select/select-hierarchic/select-hierarchic.component.d.ts +6 -6
- package/lib/modules/sidenav/sidenav-container/sidenav-container.component.d.ts +0 -1
- package/lib/modules/sidenav/sidenav.service.d.ts +3 -8
- package/lib/services/enum.service.d.ts +0 -2
- package/lib/services/link-mutation.service.d.ts +0 -2
- package/lib/services/persistence.service.d.ts +2 -4
- package/package.json +1 -1
- package/public-api.d.ts +3 -3
- package/esm2022/lib/classes/abstract-controller.mjs +0 -31
- package/lib/classes/abstract-controller.d.ts +0 -21
|
@@ -1,6 +1,8 @@
|
|
|
1
|
-
import { Component, EventEmitter, HostBinding,
|
|
1
|
+
import { Component, EventEmitter, HostBinding, Input, Output, inject, } from '@angular/core';
|
|
2
2
|
import { of, Subject, tap } from 'rxjs';
|
|
3
|
+
import { NaturalFileService } from '../file.service';
|
|
3
4
|
import { CommonModule, DOCUMENT } from '@angular/common';
|
|
5
|
+
import { NaturalAlertService } from '../../alert/alert.service';
|
|
4
6
|
import { NaturalCapitalizePipe } from '../../common/pipes/capitalize.pipe';
|
|
5
7
|
import { NaturalIconDirective } from '../../icon/icon.directive';
|
|
6
8
|
import { MatIconModule } from '@angular/material/icon';
|
|
@@ -8,17 +10,15 @@ import { MatRippleModule } from '@angular/material/core';
|
|
|
8
10
|
import { NaturalFileDropDirective } from '../file-drop.directive';
|
|
9
11
|
import { NaturalBackgroundDensityDirective } from '../../common/directives/background-density.directive';
|
|
10
12
|
import * as i0 from "@angular/core";
|
|
11
|
-
import * as i1 from "
|
|
12
|
-
import * as i2 from "
|
|
13
|
-
import * as i3 from "@angular/material/
|
|
14
|
-
import * as i4 from "@angular/common";
|
|
15
|
-
import * as i5 from "@angular/material/icon";
|
|
13
|
+
import * as i1 from "@angular/material/core";
|
|
14
|
+
import * as i2 from "@angular/common";
|
|
15
|
+
import * as i3 from "@angular/material/icon";
|
|
16
16
|
// @dynamic
|
|
17
17
|
export class NaturalFileComponent {
|
|
18
|
-
constructor(
|
|
19
|
-
this.naturalFileService =
|
|
20
|
-
this.alertService =
|
|
21
|
-
this.document =
|
|
18
|
+
constructor() {
|
|
19
|
+
this.naturalFileService = inject(NaturalFileService);
|
|
20
|
+
this.alertService = inject(NaturalAlertService);
|
|
21
|
+
this.document = inject(DOCUMENT);
|
|
22
22
|
this.height = 250;
|
|
23
23
|
this.action = null;
|
|
24
24
|
this.backgroundSize = 'contain';
|
|
@@ -123,8 +123,8 @@ export class NaturalFileComponent {
|
|
|
123
123
|
reader.readAsBinaryString(file);
|
|
124
124
|
return subject.asObservable();
|
|
125
125
|
}
|
|
126
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileComponent, deps: [
|
|
127
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: NaturalFileComponent, isStandalone: true, selector: "natural-file", inputs: { height: "height", action: "action", backgroundSize: "backgroundSize", accept: "accept", uploader: "uploader", model: "model", formCtrl: "formCtrl" }, outputs: { modelChange: "modelChange" }, host: { properties: { "style.height.px": "this.height" } }, usesOnChanges: true, ngImport: i0, template: "<a\n (fileChange)=\"upload($event)\"\n naturalFileDrop\n [selectable]=\"true\"\n [accept]=\"accept\"\n [attr.href]=\"getDownloadLink()\"\n [class.has-action]=\"!!action\"\n [class.suggest-upload]=\"!model && action === 'upload'\"\n [fileSelectionDisabled]=\"action !== 'upload'\"\n [matRippleDisabled]=\"!action\"\n [naturalBackgroundDensity]=\"imagePreview\"\n [style.backgroundSize]=\"backgroundSize\"\n matRipple\n target=\"_blank\"\n>\n @if (filePreview) {\n <div class=\"file-preview\">\n <mat-icon [size]=\"height * 0.33\" naturalIcon=\"attachment\" />\n {{ filePreview | uppercase }}\n </div>\n }\n\n <div class=\"action-overlay\">\n @if (action === 'upload') {\n <mat-icon [size]=\"height * 0.66\" naturalIcon=\"cloud_upload\" />\n }\n @if (action === 'download') {\n <mat-icon [size]=\"height * 0.66\" naturalIcon=\"get_app\" />\n }\n {{ action | capitalize }}\n </div>\n</a>\n", styles: [":host{display:flex;position:relative;flex-direction:row;overflow:hidden}:host>a{position:relative;flex:1;background-position:center;background-repeat:no-repeat}:host>a.has-action{cursor:pointer}:host>a.has-action.suggest-upload .action-overlay{opacity:.66}:host>a.has-action:hover .action-overlay,:host>a.has-action.natural-file-over .action-overlay{opacity:1}:host .action-overlay,:host .file-preview{display:flex;position:absolute;inset:0;flex-direction:column;justify-content:center;align-items:center;font-size:36px;line-height:1.3em;text-align:center}:host .action-overlay{opacity:0}:host .action-overlay>div{display:flex;position:absolute;inset:0;justify-content:center;align-items:center;opacity:0}\n"], dependencies: [{ kind: "directive", type: NaturalFileDropDirective, selector: ":not([naturalFileSelect])[naturalFileDrop]", outputs: ["fileOver"] }, { kind: "ngmodule", type: MatRippleModule }, { kind: "directive", type:
|
|
126
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
127
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: NaturalFileComponent, isStandalone: true, selector: "natural-file", inputs: { height: "height", action: "action", backgroundSize: "backgroundSize", accept: "accept", uploader: "uploader", model: "model", formCtrl: "formCtrl" }, outputs: { modelChange: "modelChange" }, host: { properties: { "style.height.px": "this.height" } }, usesOnChanges: true, ngImport: i0, template: "<a\n (fileChange)=\"upload($event)\"\n naturalFileDrop\n [selectable]=\"true\"\n [accept]=\"accept\"\n [attr.href]=\"getDownloadLink()\"\n [class.has-action]=\"!!action\"\n [class.suggest-upload]=\"!model && action === 'upload'\"\n [fileSelectionDisabled]=\"action !== 'upload'\"\n [matRippleDisabled]=\"!action\"\n [naturalBackgroundDensity]=\"imagePreview\"\n [style.backgroundSize]=\"backgroundSize\"\n matRipple\n target=\"_blank\"\n>\n @if (filePreview) {\n <div class=\"file-preview\">\n <mat-icon [size]=\"height * 0.33\" naturalIcon=\"attachment\" />\n {{ filePreview | uppercase }}\n </div>\n }\n\n <div class=\"action-overlay\">\n @if (action === 'upload') {\n <mat-icon [size]=\"height * 0.66\" naturalIcon=\"cloud_upload\" />\n }\n @if (action === 'download') {\n <mat-icon [size]=\"height * 0.66\" naturalIcon=\"get_app\" />\n }\n {{ action | capitalize }}\n </div>\n</a>\n", styles: [":host{display:flex;position:relative;flex-direction:row;overflow:hidden}:host>a{position:relative;flex:1;background-position:center;background-repeat:no-repeat}:host>a.has-action{cursor:pointer}:host>a.has-action.suggest-upload .action-overlay{opacity:.66}:host>a.has-action:hover .action-overlay,:host>a.has-action.natural-file-over .action-overlay{opacity:1}:host .action-overlay,:host .file-preview{display:flex;position:absolute;inset:0;flex-direction:column;justify-content:center;align-items:center;font-size:36px;line-height:1.3em;text-align:center}:host .action-overlay{opacity:0}:host .action-overlay>div{display:flex;position:absolute;inset:0;justify-content:center;align-items:center;opacity:0}\n"], dependencies: [{ kind: "directive", type: NaturalFileDropDirective, selector: ":not([naturalFileSelect])[naturalFileDrop]", outputs: ["fileOver"] }, { kind: "ngmodule", type: MatRippleModule }, { kind: "directive", type: i1.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i2.UpperCasePipe, name: "uppercase" }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NaturalIconDirective, selector: "mat-icon[naturalIcon]", inputs: ["naturalIcon", "size"] }, { kind: "pipe", type: NaturalCapitalizePipe, name: "capitalize" }, { kind: "directive", type: NaturalBackgroundDensityDirective, selector: "[naturalBackgroundDensity]", inputs: ["naturalBackgroundDensity"] }] }); }
|
|
128
128
|
}
|
|
129
129
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileComponent, decorators: [{
|
|
130
130
|
type: Component,
|
|
@@ -137,10 +137,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImpor
|
|
|
137
137
|
NaturalCapitalizePipe,
|
|
138
138
|
NaturalBackgroundDensityDirective,
|
|
139
139
|
], template: "<a\n (fileChange)=\"upload($event)\"\n naturalFileDrop\n [selectable]=\"true\"\n [accept]=\"accept\"\n [attr.href]=\"getDownloadLink()\"\n [class.has-action]=\"!!action\"\n [class.suggest-upload]=\"!model && action === 'upload'\"\n [fileSelectionDisabled]=\"action !== 'upload'\"\n [matRippleDisabled]=\"!action\"\n [naturalBackgroundDensity]=\"imagePreview\"\n [style.backgroundSize]=\"backgroundSize\"\n matRipple\n target=\"_blank\"\n>\n @if (filePreview) {\n <div class=\"file-preview\">\n <mat-icon [size]=\"height * 0.33\" naturalIcon=\"attachment\" />\n {{ filePreview | uppercase }}\n </div>\n }\n\n <div class=\"action-overlay\">\n @if (action === 'upload') {\n <mat-icon [size]=\"height * 0.66\" naturalIcon=\"cloud_upload\" />\n }\n @if (action === 'download') {\n <mat-icon [size]=\"height * 0.66\" naturalIcon=\"get_app\" />\n }\n {{ action | capitalize }}\n </div>\n</a>\n", styles: [":host{display:flex;position:relative;flex-direction:row;overflow:hidden}:host>a{position:relative;flex:1;background-position:center;background-repeat:no-repeat}:host>a.has-action{cursor:pointer}:host>a.has-action.suggest-upload .action-overlay{opacity:.66}:host>a.has-action:hover .action-overlay,:host>a.has-action.natural-file-over .action-overlay{opacity:1}:host .action-overlay,:host .file-preview{display:flex;position:absolute;inset:0;flex-direction:column;justify-content:center;align-items:center;font-size:36px;line-height:1.3em;text-align:center}:host .action-overlay{opacity:0}:host .action-overlay>div{display:flex;position:absolute;inset:0;justify-content:center;align-items:center;opacity:0}\n"] }]
|
|
140
|
-
}],
|
|
141
|
-
type: Inject,
|
|
142
|
-
args: [DOCUMENT]
|
|
143
|
-
}] }], propDecorators: { height: [{
|
|
140
|
+
}], propDecorators: { height: [{
|
|
144
141
|
type: HostBinding,
|
|
145
142
|
args: ['style.height.px']
|
|
146
143
|
}, {
|
|
@@ -160,4 +157,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImpor
|
|
|
160
157
|
}], modelChange: [{
|
|
161
158
|
type: Output
|
|
162
159
|
}] } });
|
|
163
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/file/component/file.component.ts","../../../../../../../projects/natural/src/lib/modules/file/component/file.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    HostBinding,\n    Inject,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n} from '@angular/core';\nimport {AbstractControl} from '@angular/forms';\nimport {Observable, of, Subject, tap} from 'rxjs';\nimport {NaturalFileService} from '../file.service';\nimport {CommonModule, DOCUMENT} from '@angular/common';\nimport {FileModel} from '../types';\nimport {NaturalAlertService} from '../../alert/alert.service';\nimport {NaturalCapitalizePipe} from '../../common/pipes/capitalize.pipe';\nimport {NaturalIconDirective} from '../../icon/icon.directive';\nimport {MatIconModule} from '@angular/material/icon';\nimport {MatRippleModule} from '@angular/material/core';\nimport {NaturalFileDropDirective} from '../file-drop.directive';\nimport {NaturalBackgroundDensityDirective} from '../../common/directives/background-density.directive';\n\n// @dynamic\n@Component({\n    selector: 'natural-file',\n    templateUrl: './file.component.html',\n    styleUrl: './file.component.scss',\n    standalone: true,\n    imports: [\n        NaturalFileDropDirective,\n        MatRippleModule,\n        CommonModule,\n        MatIconModule,\n        NaturalIconDirective,\n        NaturalCapitalizePipe,\n        NaturalBackgroundDensityDirective,\n    ],\n})\nexport class NaturalFileComponent implements OnInit, OnChanges {\n    @HostBinding('style.height.px') @Input() public height = 250;\n\n    @Input() public action: 'upload' | 'download' | null = null;\n\n    @Input() public backgroundSize = 'contain';\n\n    /**\n     * Comma-separated list of unique file type specifiers. Like the native element,\n     * it can be a mix of mime-type and file extensions.\n     *\n     * See https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/file#accept\n     */\n    @Input() public accept = 'image/bmp,image/gif,image/jpeg,image/pjpeg,image/png,image/svg+xml,image/svg,image/webp';\n\n    /**\n     * If given, it will be called when a new file is selected. The callback should typically upload the file\n     * to the server and link the newly uploaded file to the existing related object.\n     *\n     * The callback **must** be able to run even if the calling component has been destroyed. That means in most\n     * cases you **must** `bind()` the callback explicitly, like so:\n     *\n     * ```html\n     * <natural-file [uploader]=\"myCallback.bind(this)\" />\n     * ```\n     *\n     * Also, you probably **should** set a `[formCtrl]` so that the form is updated automatically, instead of doing\n     * it manually within the callback.\n     */\n    @Input() public uploader?: (file: File) => Observable<FileModel>;\n\n    @Input() public model: FileModel | null = null;\n\n    /**\n     * If provided, its value will get updated when the model changes.\n     * But its value is never read, so if you want to set a value use `[model]` instead.\n     */\n    @Input() public formCtrl: AbstractControl | null | undefined = null;\n\n    /**\n     * This **must not** be used to mutate the server, because it is very likely it will never be called if the\n     * human navigates away from the page before the upload is finished. Instead, you should use `[uploader]`.\n     */\n    @Output() public readonly modelChange = new EventEmitter<FileModel>();\n\n    public imagePreview = '';\n    public filePreview: string | null = null;\n\n    public constructor(\n        private readonly naturalFileService: NaturalFileService,\n        private readonly alertService: NaturalAlertService,\n        @Inject(DOCUMENT) private readonly document: Document,\n    ) {}\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (changes.model && changes.model.previousValue !== changes.model.currentValue) {\n            this.updateImage();\n        }\n    }\n\n    public ngOnInit(): void {\n        this.updateImage();\n    }\n\n    public upload(file: File): void {\n        this.model = {file: file};\n        this.updateImage();\n\n        if (this.formCtrl) {\n            this.formCtrl.setValue(this.model);\n        }\n\n        const observable =\n            this.uploader?.(file).pipe(tap(() => this.alertService.info($localize`Mis à jour`))) ?? of(this.model);\n\n        observable.subscribe(result => {\n            this.model = result;\n            if (this.formCtrl) {\n                this.formCtrl.setValue(this.model);\n            }\n\n            this.modelChange.emit(this.model);\n        });\n    }\n\n    public getDownloadLink(): null | string {\n        if (this.action !== 'download') {\n            return null;\n        }\n\n        return this.naturalFileService.getDownloadLink(this.model);\n    }\n\n    private updateImage(): void {\n        this.imagePreview = '';\n        this.filePreview = null;\n        if (!this.model) {\n            return;\n        }\n\n        if (this.model.file?.type.includes('image/')) {\n            // Model from upload (before saving)\n            this.getBase64(this.model.file).subscribe(result => {\n                if (this.model?.file?.type) {\n                    const content = 'url(data:' + this.model?.file?.type + ';base64,' + result + ')';\n                    this.imagePreview = content;\n                }\n            });\n        } else if (this.model.file) {\n            this.filePreview = this.model.file.type.split('/')[1];\n        } else if (this.model.__typename === 'Image' && this.model.id) {\n            // Model image with id, use specific API to render image by size\n            const window = this.document.defaultView;\n            if (!window) {\n                throw new Error('Could not show image preview because `window` is undefined');\n            }\n\n            const loc = window.location;\n            const height = this.height ? '/' + this.height : '';\n\n            // create image url without port to stay compatible with dev mode\n            const image = loc.protocol + '//' + loc.hostname + '/api/image/' + this.model.id + height;\n            this.imagePreview = image;\n        } else if (this.model?.mime && ['File', 'AccountingDocument'].includes(this.model.__typename || '')) {\n            this.filePreview = this.model.mime.split('/')[1];\n        } else if (this.model.src) {\n            // external url\n            this.imagePreview = this.model.src;\n        }\n    }\n\n    private getBase64(file: File | null): Observable<string> {\n        if (!file) {\n            return of('');\n        }\n\n        const subject = new Subject<string>();\n\n        const reader = new FileReader();\n        reader.addEventListener('load', (ev: any) => {\n            subject.next(btoa(ev.target.result));\n            subject.complete();\n        });\n        reader.readAsBinaryString(file);\n\n        return subject.asObservable();\n    }\n}\n","<a\n    (fileChange)=\"upload($event)\"\n    naturalFileDrop\n    [selectable]=\"true\"\n    [accept]=\"accept\"\n    [attr.href]=\"getDownloadLink()\"\n    [class.has-action]=\"!!action\"\n    [class.suggest-upload]=\"!model && action === 'upload'\"\n    [fileSelectionDisabled]=\"action !== 'upload'\"\n    [matRippleDisabled]=\"!action\"\n    [naturalBackgroundDensity]=\"imagePreview\"\n    [style.backgroundSize]=\"backgroundSize\"\n    matRipple\n    target=\"_blank\"\n>\n    @if (filePreview) {\n        <div class=\"file-preview\">\n            <mat-icon [size]=\"height * 0.33\" naturalIcon=\"attachment\" />\n            {{ filePreview | uppercase }}\n        </div>\n    }\n\n    <div class=\"action-overlay\">\n        @if (action === 'upload') {\n            <mat-icon [size]=\"height * 0.66\" naturalIcon=\"cloud_upload\" />\n        }\n        @if (action === 'download') {\n            <mat-icon [size]=\"height * 0.66\" naturalIcon=\"get_app\" />\n        }\n        {{ action | capitalize }}\n    </div>\n</a>\n"]}
|
|
160
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/file/component/file.component.ts","../../../../../../../projects/natural/src/lib/modules/file/component/file.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n    inject,\n} from '@angular/core';\nimport {AbstractControl} from '@angular/forms';\nimport {Observable, of, Subject, tap} from 'rxjs';\nimport {NaturalFileService} from '../file.service';\nimport {CommonModule, DOCUMENT} from '@angular/common';\nimport {FileModel} from '../types';\nimport {NaturalAlertService} from '../../alert/alert.service';\nimport {NaturalCapitalizePipe} from '../../common/pipes/capitalize.pipe';\nimport {NaturalIconDirective} from '../../icon/icon.directive';\nimport {MatIconModule} from '@angular/material/icon';\nimport {MatRippleModule} from '@angular/material/core';\nimport {NaturalFileDropDirective} from '../file-drop.directive';\nimport {NaturalBackgroundDensityDirective} from '../../common/directives/background-density.directive';\n\n// @dynamic\n@Component({\n    selector: 'natural-file',\n    templateUrl: './file.component.html',\n    styleUrl: './file.component.scss',\n    standalone: true,\n    imports: [\n        NaturalFileDropDirective,\n        MatRippleModule,\n        CommonModule,\n        MatIconModule,\n        NaturalIconDirective,\n        NaturalCapitalizePipe,\n        NaturalBackgroundDensityDirective,\n    ],\n})\nexport class NaturalFileComponent implements OnInit, OnChanges {\n    private readonly naturalFileService = inject(NaturalFileService);\n    private readonly alertService = inject(NaturalAlertService);\n    private readonly document = inject<Document>(DOCUMENT);\n\n    @HostBinding('style.height.px') @Input() public height = 250;\n\n    @Input() public action: 'upload' | 'download' | null = null;\n\n    @Input() public backgroundSize = 'contain';\n\n    /**\n     * Comma-separated list of unique file type specifiers. Like the native element,\n     * it can be a mix of mime-type and file extensions.\n     *\n     * See https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/file#accept\n     */\n    @Input() public accept = 'image/bmp,image/gif,image/jpeg,image/pjpeg,image/png,image/svg+xml,image/svg,image/webp';\n\n    /**\n     * If given, it will be called when a new file is selected. The callback should typically upload the file\n     * to the server and link the newly uploaded file to the existing related object.\n     *\n     * The callback **must** be able to run even if the calling component has been destroyed. That means in most\n     * cases you **must** `bind()` the callback explicitly, like so:\n     *\n     * ```html\n     * <natural-file [uploader]=\"myCallback.bind(this)\" />\n     * ```\n     *\n     * Also, you probably **should** set a `[formCtrl]` so that the form is updated automatically, instead of doing\n     * it manually within the callback.\n     */\n    @Input() public uploader?: (file: File) => Observable<FileModel>;\n\n    @Input() public model: FileModel | null = null;\n\n    /**\n     * If provided, its value will get updated when the model changes.\n     * But its value is never read, so if you want to set a value use `[model]` instead.\n     */\n    @Input() public formCtrl: AbstractControl | null | undefined = null;\n\n    /**\n     * This **must not** be used to mutate the server, because it is very likely it will never be called if the\n     * human navigates away from the page before the upload is finished. Instead, you should use `[uploader]`.\n     */\n    @Output() public readonly modelChange = new EventEmitter<FileModel>();\n\n    public imagePreview = '';\n    public filePreview: string | null = null;\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (changes.model && changes.model.previousValue !== changes.model.currentValue) {\n            this.updateImage();\n        }\n    }\n\n    public ngOnInit(): void {\n        this.updateImage();\n    }\n\n    public upload(file: File): void {\n        this.model = {file: file};\n        this.updateImage();\n\n        if (this.formCtrl) {\n            this.formCtrl.setValue(this.model);\n        }\n\n        const observable =\n            this.uploader?.(file).pipe(tap(() => this.alertService.info($localize`Mis à jour`))) ?? of(this.model);\n\n        observable.subscribe(result => {\n            this.model = result;\n            if (this.formCtrl) {\n                this.formCtrl.setValue(this.model);\n            }\n\n            this.modelChange.emit(this.model);\n        });\n    }\n\n    public getDownloadLink(): null | string {\n        if (this.action !== 'download') {\n            return null;\n        }\n\n        return this.naturalFileService.getDownloadLink(this.model);\n    }\n\n    private updateImage(): void {\n        this.imagePreview = '';\n        this.filePreview = null;\n        if (!this.model) {\n            return;\n        }\n\n        if (this.model.file?.type.includes('image/')) {\n            // Model from upload (before saving)\n            this.getBase64(this.model.file).subscribe(result => {\n                if (this.model?.file?.type) {\n                    const content = 'url(data:' + this.model?.file?.type + ';base64,' + result + ')';\n                    this.imagePreview = content;\n                }\n            });\n        } else if (this.model.file) {\n            this.filePreview = this.model.file.type.split('/')[1];\n        } else if (this.model.__typename === 'Image' && this.model.id) {\n            // Model image with id, use specific API to render image by size\n            const window = this.document.defaultView;\n            if (!window) {\n                throw new Error('Could not show image preview because `window` is undefined');\n            }\n\n            const loc = window.location;\n            const height = this.height ? '/' + this.height : '';\n\n            // create image url without port to stay compatible with dev mode\n            const image = loc.protocol + '//' + loc.hostname + '/api/image/' + this.model.id + height;\n            this.imagePreview = image;\n        } else if (this.model?.mime && ['File', 'AccountingDocument'].includes(this.model.__typename || '')) {\n            this.filePreview = this.model.mime.split('/')[1];\n        } else if (this.model.src) {\n            // external url\n            this.imagePreview = this.model.src;\n        }\n    }\n\n    private getBase64(file: File | null): Observable<string> {\n        if (!file) {\n            return of('');\n        }\n\n        const subject = new Subject<string>();\n\n        const reader = new FileReader();\n        reader.addEventListener('load', (ev: any) => {\n            subject.next(btoa(ev.target.result));\n            subject.complete();\n        });\n        reader.readAsBinaryString(file);\n\n        return subject.asObservable();\n    }\n}\n","<a\n    (fileChange)=\"upload($event)\"\n    naturalFileDrop\n    [selectable]=\"true\"\n    [accept]=\"accept\"\n    [attr.href]=\"getDownloadLink()\"\n    [class.has-action]=\"!!action\"\n    [class.suggest-upload]=\"!model && action === 'upload'\"\n    [fileSelectionDisabled]=\"action !== 'upload'\"\n    [matRippleDisabled]=\"!action\"\n    [naturalBackgroundDensity]=\"imagePreview\"\n    [style.backgroundSize]=\"backgroundSize\"\n    matRipple\n    target=\"_blank\"\n>\n    @if (filePreview) {\n        <div class=\"file-preview\">\n            <mat-icon [size]=\"height * 0.33\" naturalIcon=\"attachment\" />\n            {{ filePreview | uppercase }}\n        </div>\n    }\n\n    <div class=\"action-overlay\">\n        @if (action === 'upload') {\n            <mat-icon [size]=\"height * 0.66\" naturalIcon=\"cloud_upload\" />\n        }\n        @if (action === 'download') {\n            <mat-icon [size]=\"height * 0.66\" naturalIcon=\"get_app\" />\n        }\n        {{ action | capitalize }}\n    </div>\n</a>\n"]}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import { Directive, EventEmitter, HostBinding, HostListener, Output } from '@angular/core';
|
|
1
|
+
import { DestroyRef, Directive, EventEmitter, HostBinding, HostListener, inject, Output } from '@angular/core';
|
|
2
2
|
import { NaturalAbstractFile } from './abstract-file';
|
|
3
3
|
import { eventToFiles, stopEvent } from './utils';
|
|
4
4
|
import { asyncScheduler, Subject } from 'rxjs';
|
|
5
|
-
import {
|
|
5
|
+
import { throttleTime } from 'rxjs/operators';
|
|
6
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
/**
|
|
8
9
|
* This directive has all options to select files, and adds support for drag'n'drop.
|
|
@@ -20,6 +21,7 @@ import * as i0 from "@angular/core";
|
|
|
20
21
|
export class NaturalFileDropDirective extends NaturalAbstractFile {
|
|
21
22
|
constructor() {
|
|
22
23
|
super(...arguments);
|
|
24
|
+
this.destroyRef = inject(DestroyRef);
|
|
23
25
|
this.fileOverClass = false;
|
|
24
26
|
/**
|
|
25
27
|
* Emits whenever files are being dragged over
|
|
@@ -34,7 +36,7 @@ export class NaturalFileDropDirective extends NaturalAbstractFile {
|
|
|
34
36
|
// It's not absolutely perfect and if dragging slowly and precisely we can
|
|
35
37
|
// still see flicker, but it should be better for most normal usages.
|
|
36
38
|
this.rawFileOver
|
|
37
|
-
.pipe(
|
|
39
|
+
.pipe(takeUntilDestroyed(this.destroyRef), throttleTime(200, asyncScheduler, {
|
|
38
40
|
leading: true,
|
|
39
41
|
trailing: true,
|
|
40
42
|
}))
|
|
@@ -109,4 +111,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImpor
|
|
|
109
111
|
type: HostListener,
|
|
110
112
|
args: ['dragleave', ['$event']]
|
|
111
113
|
}] } });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
114
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-drop.directive.js","sourceRoot":"","sources":["../../../../../../projects/natural/src/lib/modules/file/file-drop.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {DestroyRef, Directive, EventEmitter, HostBinding, HostListener, inject, OnInit, Output} from '@angular/core';\nimport {NaturalAbstractFile} from './abstract-file';\nimport {eventToFiles, stopEvent} from './utils';\nimport {asyncScheduler, Subject} from 'rxjs';\nimport {throttleTime} from 'rxjs/operators';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\n\n/**\n * This directive has all options to select files, and adds support for drag'n'drop.\n *\n * It will add the CSS class `natural-file-over` on the component when a file is\n * dragged over. It is up to the component to have some specific styling by using\n * this class.\n *\n * In most cases you probably also want click-to-select, so you should use:\n *\n * ```html\n * <div naturalFileDrop [selectable]=\"true\"></div>\n * ```\n */\n@Directive({\n    selector: ':not([naturalFileSelect])[naturalFileDrop]',\n    standalone: true,\n})\nexport class NaturalFileDropDirective extends NaturalAbstractFile implements OnInit {\n    private readonly destroyRef = inject(DestroyRef);\n    @HostBinding('class.natural-file-over') public fileOverClass = false;\n\n    /**\n     * Emits whenever files are being dragged over\n     */\n    @Output() public readonly fileOver = new EventEmitter<boolean>();\n\n    private readonly rawFileOver = new Subject<boolean>();\n\n    public override ngOnInit(): void {\n        super.ngOnInit();\n\n        // Automatically change the class, but not too often to avoid visual\n        // flickering in Chrome when hovering across child HTML element of our host.\n        // It's not absolutely perfect and if dragging slowly and precisely we can\n        // still see flicker, but it should be better for most normal usages.\n        this.rawFileOver\n            .pipe(\n                takeUntilDestroyed(this.destroyRef),\n                throttleTime(200, asyncScheduler, {\n                    leading: true,\n                    trailing: true,\n                }),\n            )\n            .subscribe(fileOver => {\n                this.fileOver.emit(fileOver);\n                this.fileOverClass = fileOver;\n            });\n    }\n\n    @HostListener('drop', ['$event'])\n    public onDrop(event: DragEvent): void {\n        if (this.fileSelectionDisabled) {\n            return;\n        }\n\n        this.closeDrags();\n\n        const files = eventToFiles(event);\n        if (!files.length) {\n            return;\n        }\n\n        stopEvent(event);\n        this.handleFiles(files);\n    }\n\n    @HostListener('dragover', ['$event'])\n    public onDragOver(event: DragEvent): void {\n        if (!this.hasObservers()) {\n            return;\n        }\n\n        if (this.fileSelectionDisabled) {\n            return;\n        }\n\n        stopEvent(event);\n\n        // Change cursor\n        const transfer = event.dataTransfer;\n        if (transfer) {\n            transfer.dropEffect = 'copy';\n        }\n\n        this.rawFileOver.next(true);\n    }\n\n    private closeDrags(): void {\n        this.rawFileOver.next(false);\n    }\n\n    @HostListener('dragleave', ['$event'])\n    public onDragLeave(event: DragEvent): void {\n        if (this.fileSelectionDisabled) {\n            return;\n        }\n\n        stopEvent(event);\n        this.closeDrags();\n    }\n\n    private hasObservers(): boolean {\n        return (\n            this.fileChange.observed ||\n            this.filesChange.observed ||\n            (this.broadcast && this.naturalFileService.filesChanged.observed)\n        );\n    }\n}\n"]}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Injectable, inject } from '@angular/core';
|
|
2
2
|
import { Subject } from 'rxjs';
|
|
3
3
|
import { DOCUMENT } from '@angular/common';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
// @dynamic
|
|
6
6
|
export class NaturalFileService {
|
|
7
|
-
constructor(
|
|
8
|
-
this.document =
|
|
7
|
+
constructor() {
|
|
8
|
+
this.document = inject(DOCUMENT);
|
|
9
9
|
/**
|
|
10
10
|
* Allow to subscribe to selected files in the entire application. So a
|
|
11
11
|
* child component is able to receive a file that was dropped on a parent
|
|
@@ -33,7 +33,7 @@ export class NaturalFileService {
|
|
|
33
33
|
}
|
|
34
34
|
return null;
|
|
35
35
|
}
|
|
36
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileService, deps: [
|
|
36
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
37
37
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileService, providedIn: 'root' }); }
|
|
38
38
|
}
|
|
39
39
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileService, decorators: [{
|
|
@@ -41,8 +41,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImpor
|
|
|
41
41
|
args: [{
|
|
42
42
|
providedIn: 'root',
|
|
43
43
|
}]
|
|
44
|
-
}]
|
|
45
|
-
|
|
46
|
-
args: [DOCUMENT]
|
|
47
|
-
}] }] });
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvZmlsZS9maWxlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLE1BQU0sQ0FBQztBQUc3QixPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0saUJBQWlCLENBQUM7O0FBRXpDLFdBQVc7QUFJWCxNQUFNLE9BQU8sa0JBQWtCO0lBVzNCLFlBQXNELFFBQWtCO1FBQWxCLGFBQVEsR0FBUixRQUFRLENBQVU7UUFWeEU7Ozs7Ozs7V0FPRztRQUNhLGlCQUFZLEdBQUcsSUFBSSxPQUFPLEVBQWlCLENBQUM7SUFFZSxDQUFDO0lBRXJFLGVBQWUsQ0FBQyxLQUF1QjtRQUMxQyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQztRQUN6QyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDVixNQUFNLElBQUksS0FBSyxDQUFDLDBEQUEwRCxDQUFDLENBQUM7UUFDaEYsQ0FBQztRQUVELE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsUUFBUSxHQUFHLElBQUksR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQztRQUU1RSxJQUFJLEtBQUssRUFBRSxVQUFVLEtBQUssTUFBTSxFQUFFLENBQUM7WUFDL0IsT0FBTyxRQUFRLEdBQUcsWUFBWSxHQUFHLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDOUMsQ0FBQzthQUFNLElBQUksS0FBSyxFQUFFLFVBQVUsS0FBSyxvQkFBb0IsRUFBRSxDQUFDO1lBQ3BELE9BQU8sUUFBUSxHQUFHLDJCQUEyQixHQUFHLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDN0QsQ0FBQzthQUFNLElBQUksS0FBSyxFQUFFLFVBQVUsS0FBSyxPQUFPLEVBQUUsQ0FBQztZQUN2QyxPQUFPLFFBQVEsR0FBRyxhQUFhLEdBQUcsS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUMvQyxDQUFDO1FBRUQsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQzs4R0E5QlEsa0JBQWtCLGtCQVdBLFFBQVE7a0hBWDFCLGtCQUFrQixjQUZmLE1BQU07OzJGQUVULGtCQUFrQjtrQkFIOUIsVUFBVTttQkFBQztvQkFDUixVQUFVLEVBQUUsTUFBTTtpQkFDckI7OzBCQVl1QixNQUFNOzJCQUFDLFFBQVEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdCwgSW5qZWN0YWJsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1N1YmplY3R9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtGaWxlU2VsZWN0aW9ufSBmcm9tICcuL2Fic3RyYWN0LWZpbGUnO1xuaW1wb3J0IHtGaWxlTW9kZWx9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHtET0NVTUVOVH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuLy8gQGR5bmFtaWNcbkBJbmplY3RhYmxlKHtcbiAgICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIE5hdHVyYWxGaWxlU2VydmljZSB7XG4gICAgLyoqXG4gICAgICogQWxsb3cgdG8gc3Vic2NyaWJlIHRvIHNlbGVjdGVkIGZpbGVzIGluIHRoZSBlbnRpcmUgYXBwbGljYXRpb24uIFNvIGFcbiAgICAgKiBjaGlsZCBjb21wb25lbnQgaXMgYWJsZSB0byByZWNlaXZlIGEgZmlsZSB0aGF0IHdhcyBkcm9wcGVkIG9uIGEgcGFyZW50XG4gICAgICogY29tcG9uZW50LlxuICAgICAqXG4gICAgICogVHlwaWNhbGx5IHVzZWZ1bCB0byBkcm9wIGEgZmlsZSBvbiB0aGUgZW50aXJlIHNjcmVlbiwgaW5zdGVhZCBvZiBhIHByZWNpc2VcbiAgICAgKiBjb21wb25lbnQuXG4gICAgICovXG4gICAgcHVibGljIHJlYWRvbmx5IGZpbGVzQ2hhbmdlZCA9IG5ldyBTdWJqZWN0PEZpbGVTZWxlY3Rpb24+KCk7XG5cbiAgICBwdWJsaWMgY29uc3RydWN0b3IoQEluamVjdChET0NVTUVOVCkgcHJpdmF0ZSByZWFkb25seSBkb2N1bWVudDogRG9jdW1lbnQpIHt9XG5cbiAgICBwdWJsaWMgZ2V0RG93bmxvYWRMaW5rKG1vZGVsOiBGaWxlTW9kZWwgfCBudWxsKTogbnVsbCB8IHN0cmluZyB7XG4gICAgICAgIGNvbnN0IHdpbmRvdyA9IHRoaXMuZG9jdW1lbnQuZGVmYXVsdFZpZXc7XG4gICAgICAgIGlmICghd2luZG93KSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ0Nhbm5vdCBidWlsZCBkb3dubG9hZCBsaW5rIGJlY2F1c2UgYHdpbmRvd2AgaXMgdW5kZWZpbmVkJyk7XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBob3N0bmFtZSA9IHdpbmRvdy5sb2NhdGlvbi5wcm90b2NvbCArICcvLycgKyB3aW5kb3cubG9jYXRpb24uaG9zdG5hbWU7XG5cbiAgICAgICAgaWYgKG1vZGVsPy5fX3R5cGVuYW1lID09PSAnRmlsZScpIHtcbiAgICAgICAgICAgIHJldHVybiBob3N0bmFtZSArICcvYXBpL2ZpbGUvJyArIG1vZGVsLmlkO1xuICAgICAgICB9IGVsc2UgaWYgKG1vZGVsPy5fX3R5cGVuYW1lID09PSAnQWNjb3VudGluZ0RvY3VtZW50Jykge1xuICAgICAgICAgICAgcmV0dXJuIGhvc3RuYW1lICsgJy9hcGkvYWNjb3VudGluZy1kb2N1bWVudC8nICsgbW9kZWwuaWQ7XG4gICAgICAgIH0gZWxzZSBpZiAobW9kZWw/Ll9fdHlwZW5hbWUgPT09ICdJbWFnZScpIHtcbiAgICAgICAgICAgIHJldHVybiBob3N0bmFtZSArICcvYXBpL2ltYWdlLycgKyBtb2RlbC5pZDtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBudWxsO1xuICAgIH1cbn1cbiJdfQ==
|
|
44
|
+
}] });
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvZmlsZS9maWxlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFVBQVUsRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLE1BQU0sQ0FBQztBQUc3QixPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0saUJBQWlCLENBQUM7O0FBRXpDLFdBQVc7QUFJWCxNQUFNLE9BQU8sa0JBQWtCO0lBSC9CO1FBSXFCLGFBQVEsR0FBRyxNQUFNLENBQVcsUUFBUSxDQUFDLENBQUM7UUFFdkQ7Ozs7Ozs7V0FPRztRQUNhLGlCQUFZLEdBQUcsSUFBSSxPQUFPLEVBQWlCLENBQUM7S0FvQi9EO0lBbEJVLGVBQWUsQ0FBQyxLQUF1QjtRQUMxQyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQztRQUN6QyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDVixNQUFNLElBQUksS0FBSyxDQUFDLDBEQUEwRCxDQUFDLENBQUM7UUFDaEYsQ0FBQztRQUVELE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsUUFBUSxHQUFHLElBQUksR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQztRQUU1RSxJQUFJLEtBQUssRUFBRSxVQUFVLEtBQUssTUFBTSxFQUFFLENBQUM7WUFDL0IsT0FBTyxRQUFRLEdBQUcsWUFBWSxHQUFHLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDOUMsQ0FBQzthQUFNLElBQUksS0FBSyxFQUFFLFVBQVUsS0FBSyxvQkFBb0IsRUFBRSxDQUFDO1lBQ3BELE9BQU8sUUFBUSxHQUFHLDJCQUEyQixHQUFHLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDN0QsQ0FBQzthQUFNLElBQUksS0FBSyxFQUFFLFVBQVUsS0FBSyxPQUFPLEVBQUUsQ0FBQztZQUN2QyxPQUFPLFFBQVEsR0FBRyxhQUFhLEdBQUcsS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUMvQyxDQUFDO1FBRUQsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQzs4R0E5QlEsa0JBQWtCO2tIQUFsQixrQkFBa0IsY0FGZixNQUFNOzsyRkFFVCxrQkFBa0I7a0JBSDlCLFVBQVU7bUJBQUM7b0JBQ1IsVUFBVSxFQUFFLE1BQU07aUJBQ3JCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtJbmplY3RhYmxlLCBpbmplY3R9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtTdWJqZWN0fSBmcm9tICdyeGpzJztcbmltcG9ydCB7RmlsZVNlbGVjdGlvbn0gZnJvbSAnLi9hYnN0cmFjdC1maWxlJztcbmltcG9ydCB7RmlsZU1vZGVsfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7RE9DVU1FTlR9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbi8vIEBkeW5hbWljXG5ASW5qZWN0YWJsZSh7XG4gICAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBOYXR1cmFsRmlsZVNlcnZpY2Uge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgZG9jdW1lbnQgPSBpbmplY3Q8RG9jdW1lbnQ+KERPQ1VNRU5UKTtcblxuICAgIC8qKlxuICAgICAqIEFsbG93IHRvIHN1YnNjcmliZSB0byBzZWxlY3RlZCBmaWxlcyBpbiB0aGUgZW50aXJlIGFwcGxpY2F0aW9uLiBTbyBhXG4gICAgICogY2hpbGQgY29tcG9uZW50IGlzIGFibGUgdG8gcmVjZWl2ZSBhIGZpbGUgdGhhdCB3YXMgZHJvcHBlZCBvbiBhIHBhcmVudFxuICAgICAqIGNvbXBvbmVudC5cbiAgICAgKlxuICAgICAqIFR5cGljYWxseSB1c2VmdWwgdG8gZHJvcCBhIGZpbGUgb24gdGhlIGVudGlyZSBzY3JlZW4sIGluc3RlYWQgb2YgYSBwcmVjaXNlXG4gICAgICogY29tcG9uZW50LlxuICAgICAqL1xuICAgIHB1YmxpYyByZWFkb25seSBmaWxlc0NoYW5nZWQgPSBuZXcgU3ViamVjdDxGaWxlU2VsZWN0aW9uPigpO1xuXG4gICAgcHVibGljIGdldERvd25sb2FkTGluayhtb2RlbDogRmlsZU1vZGVsIHwgbnVsbCk6IG51bGwgfCBzdHJpbmcge1xuICAgICAgICBjb25zdCB3aW5kb3cgPSB0aGlzLmRvY3VtZW50LmRlZmF1bHRWaWV3O1xuICAgICAgICBpZiAoIXdpbmRvdykge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdDYW5ub3QgYnVpbGQgZG93bmxvYWQgbGluayBiZWNhdXNlIGB3aW5kb3dgIGlzIHVuZGVmaW5lZCcpO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgaG9zdG5hbWUgPSB3aW5kb3cubG9jYXRpb24ucHJvdG9jb2wgKyAnLy8nICsgd2luZG93LmxvY2F0aW9uLmhvc3RuYW1lO1xuXG4gICAgICAgIGlmIChtb2RlbD8uX190eXBlbmFtZSA9PT0gJ0ZpbGUnKSB7XG4gICAgICAgICAgICByZXR1cm4gaG9zdG5hbWUgKyAnL2FwaS9maWxlLycgKyBtb2RlbC5pZDtcbiAgICAgICAgfSBlbHNlIGlmIChtb2RlbD8uX190eXBlbmFtZSA9PT0gJ0FjY291bnRpbmdEb2N1bWVudCcpIHtcbiAgICAgICAgICAgIHJldHVybiBob3N0bmFtZSArICcvYXBpL2FjY291bnRpbmctZG9jdW1lbnQvJyArIG1vZGVsLmlkO1xuICAgICAgICB9IGVsc2UgaWYgKG1vZGVsPy5fX3R5cGVuYW1lID09PSAnSW1hZ2UnKSB7XG4gICAgICAgICAgICByZXR1cm4gaG9zdG5hbWUgKyAnL2FwaS9pbWFnZS8nICsgbW9kZWwuaWQ7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG59XG4iXX0=
|
|
@@ -6,4 +6,4 @@ export * from './file-select.directive';
|
|
|
6
6
|
export * from './file.service';
|
|
7
7
|
export * from './component/file.component';
|
|
8
8
|
export * from './types';
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL2ZpbGUvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGdCQUFnQixDQUFDO0FBRS9CLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG5hdHVyYWxcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2ZpbGUtZHJvcC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9maWxlLXNlbGVjdC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9maWxlLnNlcnZpY2UnO1xuZXhwb3J0IHR5cGUge0ludmFsaWRGaWxlLCBGaWxlU2VsZWN0aW9ufSBmcm9tICcuL2Fic3RyYWN0LWZpbGUnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnQvZmlsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7XG4iXX0=
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
1
|
+
import { Component, EventEmitter, Input, Output, inject } from '@angular/core';
|
|
2
|
+
import { ActivatedRoute } from '@angular/router';
|
|
2
3
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
3
4
|
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
4
5
|
import { NaturalFixedButtonComponent } from '../fixed-button/fixed-button.component';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
|
-
import * as i1 from "@angular/
|
|
7
|
-
import * as i2 from "@angular/material/tooltip";
|
|
7
|
+
import * as i1 from "@angular/material/tooltip";
|
|
8
8
|
export class NaturalFixedButtonDetailComponent {
|
|
9
9
|
get model() {
|
|
10
10
|
return this._model;
|
|
@@ -16,11 +16,12 @@ export class NaturalFixedButtonDetailComponent {
|
|
|
16
16
|
this.canChange = false;
|
|
17
17
|
}
|
|
18
18
|
}
|
|
19
|
-
constructor(
|
|
19
|
+
constructor() {
|
|
20
20
|
this.canChange = true;
|
|
21
21
|
this.isCreation = false;
|
|
22
22
|
this.create = new EventEmitter();
|
|
23
23
|
this.delete = new EventEmitter();
|
|
24
|
+
const route = inject(ActivatedRoute);
|
|
24
25
|
route.params.pipe(takeUntilDestroyed()).subscribe(() => (this.canChange = true));
|
|
25
26
|
}
|
|
26
27
|
clickCreate() {
|
|
@@ -33,13 +34,13 @@ export class NaturalFixedButtonDetailComponent {
|
|
|
33
34
|
this.delete.emit();
|
|
34
35
|
}
|
|
35
36
|
}
|
|
36
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFixedButtonDetailComponent, deps: [
|
|
37
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: NaturalFixedButtonDetailComponent, isStandalone: true, selector: "natural-fixed-button-detail", inputs: { model: "model", form: "form" }, outputs: { create: "create", delete: "delete" }, ngImport: i0, template: "@if (isCreation) {\n <natural-fixed-button\n (click)=\"clickCreate()\"\n [disabled]=\"form.disabled\"\n [color]=\"form.valid ? 'accent' : 'warn'\"\n class=\"detail-speed-dial\"\n icon=\"save\"\n />\n}\n\n@if (!isCreation && (!model.permissions || model.permissions.delete)) {\n <natural-fixed-button\n (click)=\"clickDelete()\"\n [disabled]=\"form.disabled\"\n class=\"detail-speed-dial\"\n color=\"warn\"\n icon=\"delete_forever\"\n i18n-matTooltip\n matTooltip=\"Supprimer d\u00E9finitivement\"\n matTooltipPosition=\"left\"\n />\n}\n", styles: [""], dependencies: [{ kind: "component", type: NaturalFixedButtonComponent, selector: "natural-fixed-button", inputs: ["icon", "link", "color", "disabled"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type:
|
|
37
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFixedButtonDetailComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
38
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: NaturalFixedButtonDetailComponent, isStandalone: true, selector: "natural-fixed-button-detail", inputs: { model: "model", form: "form" }, outputs: { create: "create", delete: "delete" }, ngImport: i0, template: "@if (isCreation) {\n <natural-fixed-button\n (click)=\"clickCreate()\"\n [disabled]=\"form.disabled\"\n [color]=\"form.valid ? 'accent' : 'warn'\"\n class=\"detail-speed-dial\"\n icon=\"save\"\n />\n}\n\n@if (!isCreation && (!model.permissions || model.permissions.delete)) {\n <natural-fixed-button\n (click)=\"clickDelete()\"\n [disabled]=\"form.disabled\"\n class=\"detail-speed-dial\"\n color=\"warn\"\n icon=\"delete_forever\"\n i18n-matTooltip\n matTooltip=\"Supprimer d\u00E9finitivement\"\n matTooltipPosition=\"left\"\n />\n}\n", styles: [""], dependencies: [{ kind: "component", type: NaturalFixedButtonComponent, selector: "natural-fixed-button", inputs: ["icon", "link", "color", "disabled"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i1.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }] }); }
|
|
38
39
|
}
|
|
39
40
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFixedButtonDetailComponent, decorators: [{
|
|
40
41
|
type: Component,
|
|
41
42
|
args: [{ selector: 'natural-fixed-button-detail', standalone: true, imports: [NaturalFixedButtonComponent, MatTooltipModule], template: "@if (isCreation) {\n <natural-fixed-button\n (click)=\"clickCreate()\"\n [disabled]=\"form.disabled\"\n [color]=\"form.valid ? 'accent' : 'warn'\"\n class=\"detail-speed-dial\"\n icon=\"save\"\n />\n}\n\n@if (!isCreation && (!model.permissions || model.permissions.delete)) {\n <natural-fixed-button\n (click)=\"clickDelete()\"\n [disabled]=\"form.disabled\"\n class=\"detail-speed-dial\"\n color=\"warn\"\n icon=\"delete_forever\"\n i18n-matTooltip\n matTooltip=\"Supprimer d\u00E9finitivement\"\n matTooltipPosition=\"left\"\n />\n}\n" }]
|
|
42
|
-
}], ctorParameters: () => [
|
|
43
|
+
}], ctorParameters: () => [], propDecorators: { model: [{
|
|
43
44
|
type: Input,
|
|
44
45
|
args: [{ required: true }]
|
|
45
46
|
}], form: [{
|
|
@@ -50,4 +51,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImpor
|
|
|
50
51
|
}], delete: [{
|
|
51
52
|
type: Output
|
|
52
53
|
}] } });
|
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZml4ZWQtYnV0dG9uLWRldGFpbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uYXR1cmFsL3NyYy9saWIvbW9kdWxlcy9maXhlZC1idXR0b24tZGV0YWlsL2ZpeGVkLWJ1dHRvbi1kZXRhaWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvZml4ZWQtYnV0dG9uLWRldGFpbC9maXhlZC1idXR0b24tZGV0YWlsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRTdFLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUM5RCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUMzRCxPQUFPLEVBQUMsMkJBQTJCLEVBQUMsTUFBTSx3Q0FBd0MsQ0FBQzs7O0FBZ0JuRixNQUFNLE9BQU8saUNBQWlDO0lBSTFDLElBQVcsS0FBSztRQUNaLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUN2QixDQUFDO0lBRUQsSUFDVyxLQUFLLENBQUMsS0FBWTtRQUN6QixJQUFJLENBQUMsTUFBTSxHQUFHLEtBQUssQ0FBQztRQUNwQixJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUNqQixJQUFJLENBQUMsVUFBVSxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7WUFDbEMsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7UUFDM0IsQ0FBQztJQUNMLENBQUM7SUFTRDtRQXZCUSxjQUFTLEdBQUcsSUFBSSxDQUFDO1FBQ2xCLGVBQVUsR0FBRyxLQUFLLENBQUM7UUFtQkEsV0FBTSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFDbEMsV0FBTSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFHeEQsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBRXJDLEtBQUssQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLGtCQUFrQixFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDckYsQ0FBQztJQUVNLFdBQVc7UUFDZCxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDcEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN2QixDQUFDO0lBQ0wsQ0FBQztJQUVNLFdBQVc7UUFDZCxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDcEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN2QixDQUFDO0lBQ0wsQ0FBQzs4R0F4Q1EsaUNBQWlDO2tHQUFqQyxpQ0FBaUMsa0xDckI5Qyxpb0JBc0JBLDBEREhjLDJCQUEyQiwrR0FBRSxnQkFBZ0I7OzJGQUU5QyxpQ0FBaUM7a0JBUDdDLFNBQVM7K0JBQ0ksNkJBQTZCLGNBRzNCLElBQUksV0FDUCxDQUFDLDJCQUEyQixFQUFFLGdCQUFnQixDQUFDO3dEQVc3QyxLQUFLO3NCQURmLEtBQUs7dUJBQUMsRUFBQyxRQUFRLEVBQUUsSUFBSSxFQUFDO2dCQVdTLElBQUk7c0JBQW5DLEtBQUs7dUJBQUMsRUFBQyxRQUFRLEVBQUUsSUFBSSxFQUFDO2dCQUVHLE1BQU07c0JBQS9CLE1BQU07Z0JBQ21CLE1BQU07c0JBQS9CLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0LCBpbmplY3R9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtGb3JtR3JvdXB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7QWN0aXZhdGVkUm91dGV9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQge3Rha2VVbnRpbERlc3Ryb3llZH0gZnJvbSAnQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3AnO1xuaW1wb3J0IHtNYXRUb29sdGlwTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sdGlwJztcbmltcG9ydCB7TmF0dXJhbEZpeGVkQnV0dG9uQ29tcG9uZW50fSBmcm9tICcuLi9maXhlZC1idXR0b24vZml4ZWQtYnV0dG9uLmNvbXBvbmVudCc7XG5cbnR5cGUgTW9kZWwgPSB7XG4gICAgaWQ/OiBzdHJpbmc7XG4gICAgcGVybWlzc2lvbnM/OiB7XG4gICAgICAgIGRlbGV0ZTogYm9vbGVhbjtcbiAgICB9O1xufTtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICduYXR1cmFsLWZpeGVkLWJ1dHRvbi1kZXRhaWwnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9maXhlZC1idXR0b24tZGV0YWlsLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybDogJy4vZml4ZWQtYnV0dG9uLWRldGFpbC5jb21wb25lbnQuc2NzcycsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbTmF0dXJhbEZpeGVkQnV0dG9uQ29tcG9uZW50LCBNYXRUb29sdGlwTW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgTmF0dXJhbEZpeGVkQnV0dG9uRGV0YWlsQ29tcG9uZW50IHtcbiAgICBwcml2YXRlIGNhbkNoYW5nZSA9IHRydWU7XG4gICAgcHVibGljIGlzQ3JlYXRpb24gPSBmYWxzZTtcblxuICAgIHB1YmxpYyBnZXQgbW9kZWwoKTogTW9kZWwge1xuICAgICAgICByZXR1cm4gdGhpcy5fbW9kZWw7XG4gICAgfVxuXG4gICAgQElucHV0KHtyZXF1aXJlZDogdHJ1ZX0pXG4gICAgcHVibGljIHNldCBtb2RlbCh2YWx1ZTogTW9kZWwpIHtcbiAgICAgICAgdGhpcy5fbW9kZWwgPSB2YWx1ZTtcbiAgICAgICAgaWYgKHRoaXMuY2FuQ2hhbmdlKSB7XG4gICAgICAgICAgICB0aGlzLmlzQ3JlYXRpb24gPSAhdGhpcy5fbW9kZWwuaWQ7XG4gICAgICAgICAgICB0aGlzLmNhbkNoYW5nZSA9IGZhbHNlO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBfbW9kZWwhOiBNb2RlbDtcblxuICAgIEBJbnB1dCh7cmVxdWlyZWQ6IHRydWV9KSBwdWJsaWMgZm9ybSE6IEZvcm1Hcm91cDtcblxuICAgIEBPdXRwdXQoKSBwdWJsaWMgcmVhZG9ubHkgY3JlYXRlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICAgIEBPdXRwdXQoKSBwdWJsaWMgcmVhZG9ubHkgZGVsZXRlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gICAgcHVibGljIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBjb25zdCByb3V0ZSA9IGluamVjdChBY3RpdmF0ZWRSb3V0ZSk7XG5cbiAgICAgICAgcm91dGUucGFyYW1zLnBpcGUodGFrZVVudGlsRGVzdHJveWVkKCkpLnN1YnNjcmliZSgoKSA9PiAodGhpcy5jYW5DaGFuZ2UgPSB0cnVlKSk7XG4gICAgfVxuXG4gICAgcHVibGljIGNsaWNrQ3JlYXRlKCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5mb3JtLmVuYWJsZWQpIHtcbiAgICAgICAgICAgIHRoaXMuY3JlYXRlLmVtaXQoKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHB1YmxpYyBjbGlja0RlbGV0ZSgpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuZm9ybS5lbmFibGVkKSB7XG4gICAgICAgICAgICB0aGlzLmRlbGV0ZS5lbWl0KCk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iLCJAaWYgKGlzQ3JlYXRpb24pIHtcbiAgICA8bmF0dXJhbC1maXhlZC1idXR0b25cbiAgICAgICAgKGNsaWNrKT1cImNsaWNrQ3JlYXRlKClcIlxuICAgICAgICBbZGlzYWJsZWRdPVwiZm9ybS5kaXNhYmxlZFwiXG4gICAgICAgIFtjb2xvcl09XCJmb3JtLnZhbGlkID8gJ2FjY2VudCcgOiAnd2FybidcIlxuICAgICAgICBjbGFzcz1cImRldGFpbC1zcGVlZC1kaWFsXCJcbiAgICAgICAgaWNvbj1cInNhdmVcIlxuICAgIC8+XG59XG5cbkBpZiAoIWlzQ3JlYXRpb24gJiYgKCFtb2RlbC5wZXJtaXNzaW9ucyB8fCBtb2RlbC5wZXJtaXNzaW9ucy5kZWxldGUpKSB7XG4gICAgPG5hdHVyYWwtZml4ZWQtYnV0dG9uXG4gICAgICAgIChjbGljayk9XCJjbGlja0RlbGV0ZSgpXCJcbiAgICAgICAgW2Rpc2FibGVkXT1cImZvcm0uZGlzYWJsZWRcIlxuICAgICAgICBjbGFzcz1cImRldGFpbC1zcGVlZC1kaWFsXCJcbiAgICAgICAgY29sb3I9XCJ3YXJuXCJcbiAgICAgICAgaWNvbj1cImRlbGV0ZV9mb3JldmVyXCJcbiAgICAgICAgaTE4bi1tYXRUb29sdGlwXG4gICAgICAgIG1hdFRvb2x0aXA9XCJTdXBwcmltZXIgZMOpZmluaXRpdmVtZW50XCJcbiAgICAgICAgbWF0VG9vbHRpcFBvc2l0aW9uPVwibGVmdFwiXG4gICAgLz5cbn1cbiJdfQ==
|