@ecodev/natural-editor 61.0.0 → 61.0.2
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/class-dialog/class-dialog.component.mjs +16 -18
- package/esm2022/lib/color-dialog/color-dialog.component.mjs +158 -160
- package/esm2022/lib/custom-css/custom-css.directive.mjs +8 -13
- package/esm2022/lib/editor/editor.component.mjs +44 -46
- package/esm2022/lib/id-dialog/id-dialog.component.mjs +16 -18
- package/esm2022/lib/link-dialog/link-dialog.component.mjs +15 -17
- package/esm2022/lib/utils/image.mjs +8 -9
- package/esm2022/lib/utils/items/item.mjs +14 -13
- package/esm2022/public-api.mjs +1 -1
- package/fesm2022/ecodev-natural-editor.mjs +261 -275
- package/fesm2022/ecodev-natural-editor.mjs.map +1 -1
- package/lib/class-dialog/class-dialog.component.d.ts +1 -2
- package/lib/color-dialog/color-dialog.component.d.ts +1 -2
- package/lib/custom-css/custom-css.directive.d.ts +0 -1
- package/lib/editor/editor.component.d.ts +5 -6
- package/lib/id-dialog/id-dialog.component.d.ts +1 -2
- package/lib/link-dialog/link-dialog.component.d.ts +1 -2
- package/lib/utils/image.d.ts +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +1 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { Component,
|
|
2
|
-
import { MAT_DIALOG_DATA, MatDialogModule } from '@angular/material/dialog';
|
|
1
|
+
import { Component, inject } from '@angular/core';
|
|
2
|
+
import { MAT_DIALOG_DATA, MatDialogRef, MatDialogModule } from '@angular/material/dialog';
|
|
3
3
|
import { FormControl, FormGroup, Validators, FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
4
4
|
import { ifValid } from '@ecodev/natural';
|
|
5
5
|
import { MatButtonModule } from '@angular/material/button';
|
|
@@ -12,15 +12,16 @@ import * as i3 from "@angular/material/form-field";
|
|
|
12
12
|
import * as i4 from "@angular/material/input";
|
|
13
13
|
import * as i5 from "@angular/material/button";
|
|
14
14
|
export class ClassDialogComponent {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
this.
|
|
22
|
-
|
|
23
|
-
|
|
15
|
+
dialogRef = inject(MatDialogRef);
|
|
16
|
+
classControl = new FormControl('', {
|
|
17
|
+
validators: Validators.pattern(/(^\s*(-?[_a-zA-Z]+[_a-zA-Z0-9-]*\s*)+)/),
|
|
18
|
+
nonNullable: true,
|
|
19
|
+
});
|
|
20
|
+
form = new FormGroup({
|
|
21
|
+
class: this.classControl,
|
|
22
|
+
});
|
|
23
|
+
constructor() {
|
|
24
|
+
const data = inject(MAT_DIALOG_DATA);
|
|
24
25
|
this.form.setValue(data);
|
|
25
26
|
}
|
|
26
27
|
maybeConfirm() {
|
|
@@ -29,14 +30,11 @@ export class ClassDialogComponent {
|
|
|
29
30
|
confirm() {
|
|
30
31
|
this.dialogRef.close(this.form.getRawValue());
|
|
31
32
|
}
|
|
32
|
-
static
|
|
33
|
-
static
|
|
33
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: ClassDialogComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
34
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: ClassDialogComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<h2 i18n mat-dialog-title>Saisir les classes CSS</h2>\n\n<mat-dialog-content [formGroup]=\"form\">\n <mat-form-field>\n <mat-label i18n>Classes CSS</mat-label>\n <input matInput [formControl]=\"classControl\" (keydown.enter)=\"maybeConfirm()\" cdkFocusInitial />\n @if (classControl.hasError('pattern')) {\n <mat-error i18n>Doit \u00EAtre un ou plusieurs nom de classe CSS</mat-error>\n }\n </mat-form-field>\n</mat-dialog-content>\n\n<mat-dialog-actions align=\"end\">\n <button mat-button mat-dialog-close i18n>Annuler</button>\n <button mat-stroked-button (click)=\"maybeConfirm()\" [disabled]=\"!form.valid\"><span i18n>Valider</span></button>\n</mat-dialog-actions>\n", styles: ["mat-dialog-content{display:grid;width:70vw;max-width:30em}\n"], dependencies: [{ kind: "ngmodule", type: MatDialogModule }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i5.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }] });
|
|
34
35
|
}
|
|
35
36
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: ClassDialogComponent, decorators: [{
|
|
36
37
|
type: Component,
|
|
37
38
|
args: [{ standalone: true, imports: [MatDialogModule, FormsModule, ReactiveFormsModule, MatFormFieldModule, MatInputModule, MatButtonModule], template: "<h2 i18n mat-dialog-title>Saisir les classes CSS</h2>\n\n<mat-dialog-content [formGroup]=\"form\">\n <mat-form-field>\n <mat-label i18n>Classes CSS</mat-label>\n <input matInput [formControl]=\"classControl\" (keydown.enter)=\"maybeConfirm()\" cdkFocusInitial />\n @if (classControl.hasError('pattern')) {\n <mat-error i18n>Doit \u00EAtre un ou plusieurs nom de classe CSS</mat-error>\n }\n </mat-form-field>\n</mat-dialog-content>\n\n<mat-dialog-actions align=\"end\">\n <button mat-button mat-dialog-close i18n>Annuler</button>\n <button mat-stroked-button (click)=\"maybeConfirm()\" [disabled]=\"!form.valid\"><span i18n>Valider</span></button>\n</mat-dialog-actions>\n", styles: ["mat-dialog-content{display:grid;width:70vw;max-width:30em}\n"] }]
|
|
38
|
-
}], ctorParameters: () => [
|
|
39
|
-
|
|
40
|
-
args: [MAT_DIALOG_DATA]
|
|
41
|
-
}] }, { type: i1.MatDialogRef }] });
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xhc3MtZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwtZWRpdG9yL3NyYy9saWIvY2xhc3MtZGlhbG9nL2NsYXNzLWRpYWxvZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uYXR1cmFsLWVkaXRvci9zcmMvbGliL2NsYXNzLWRpYWxvZy9jbGFzcy1kaWFsb2cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDaEQsT0FBTyxFQUFDLGVBQWUsRUFBZ0IsZUFBZSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDeEYsT0FBTyxFQUFDLFdBQVcsRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQ3BHLE9BQU8sRUFBQyxPQUFPLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUN4QyxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ3ZELE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLDhCQUE4QixDQUFDOzs7Ozs7O0FBb0JoRSxNQUFNLE9BQU8sb0JBQW9CO0lBUzdCLFlBQzZCLElBQXFCLEVBQ3RDLFNBQThEO1FBQTlELGNBQVMsR0FBVCxTQUFTLENBQXFEO1FBVjFELGlCQUFZLEdBQUcsSUFBSSxXQUFXLENBQUMsRUFBRSxFQUFFO1lBQy9DLFVBQVUsRUFBRSxVQUFVLENBQUMsT0FBTyxDQUFDLHdDQUF3QyxDQUFDO1lBQ3hFLFdBQVcsRUFBRSxJQUFJO1NBQ3BCLENBQUMsQ0FBQztRQUNhLFNBQUksR0FBRyxJQUFJLFNBQVMsQ0FBQztZQUNqQyxLQUFLLEVBQUUsSUFBSSxDQUFDLFlBQVk7U0FDM0IsQ0FBQyxDQUFDO1FBTUMsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDN0IsQ0FBQztJQUVNLFlBQVk7UUFDZixPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztJQUN2RCxDQUFDO0lBRU8sT0FBTztRQUNYLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztJQUNsRCxDQUFDOzhHQXRCUSxvQkFBb0Isa0JBVWpCLGVBQWU7a0dBVmxCLG9CQUFvQix3RUMxQmpDLHF0QkFnQkEscUhEUWMsZUFBZSwrbkJBQUUsV0FBVyxrakJBQUUsbUJBQW1CLGtXQUFFLGtCQUFrQix1WUFBRSxjQUFjLDBXQUFFLGVBQWU7OzJGQUV2RyxvQkFBb0I7a0JBTmhDLFNBQVM7aUNBR00sSUFBSSxXQUNQLENBQUMsZUFBZSxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxrQkFBa0IsRUFBRSxjQUFjLEVBQUUsZUFBZSxDQUFDOzswQkFZNUcsTUFBTTsyQkFBQyxlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIEluamVjdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge01BVF9ESUFMT0dfREFUQSwgTWF0RGlhbG9nUmVmLCBNYXREaWFsb2dNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5pbXBvcnQge0Zvcm1Db250cm9sLCBGb3JtR3JvdXAsIFZhbGlkYXRvcnMsIEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge2lmVmFsaWR9IGZyb20gJ0BlY29kZXYvbmF0dXJhbCc7XG5pbXBvcnQge01hdEJ1dHRvbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7TWF0SW5wdXRNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcbmltcG9ydCB7TWF0Rm9ybUZpZWxkTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkJztcblxuZXhwb3J0IHR5cGUgQ2xhc3NEaWFsb2dEYXRhID0ge1xuICAgIC8qKlxuICAgICAqIENTUyBjbGFzcyBuYW1lc1xuICAgICAqXG4gICAgICogRWc6XG4gICAgICpcbiAgICAgKiAtIGBcIlwiYFxuICAgICAqIC0gYFwibXktY2xhc3MgbXktb3RoZXItY2xhc3NcImBcbiAgICAgKi9cbiAgICBjbGFzczogc3RyaW5nO1xufTtcblxuQENvbXBvbmVudCh7XG4gICAgdGVtcGxhdGVVcmw6ICcuL2NsYXNzLWRpYWxvZy5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmw6ICcuL2NsYXNzLWRpYWxvZy5jb21wb25lbnQuc2NzcycsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbTWF0RGlhbG9nTW9kdWxlLCBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSwgTWF0Rm9ybUZpZWxkTW9kdWxlLCBNYXRJbnB1dE1vZHVsZSwgTWF0QnV0dG9uTW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgQ2xhc3NEaWFsb2dDb21wb25lbnQge1xuICAgIHB1YmxpYyByZWFkb25seSBjbGFzc0NvbnRyb2wgPSBuZXcgRm9ybUNvbnRyb2woJycsIHtcbiAgICAgICAgdmFsaWRhdG9yczogVmFsaWRhdG9ycy5wYXR0ZXJuKC8oXlxccyooLT9bX2EtekEtWl0rW19hLXpBLVowLTktXSpcXHMqKSspLyksXG4gICAgICAgIG5vbk51bGxhYmxlOiB0cnVlLFxuICAgIH0pO1xuICAgIHB1YmxpYyByZWFkb25seSBmb3JtID0gbmV3IEZvcm1Hcm91cCh7XG4gICAgICAgIGNsYXNzOiB0aGlzLmNsYXNzQ29udHJvbCxcbiAgICB9KTtcblxuICAgIHB1YmxpYyBjb25zdHJ1Y3RvcihcbiAgICAgICAgQEluamVjdChNQVRfRElBTE9HX0RBVEEpIGRhdGE6IENsYXNzRGlhbG9nRGF0YSxcbiAgICAgICAgcHJpdmF0ZSBkaWFsb2dSZWY6IE1hdERpYWxvZ1JlZjxDbGFzc0RpYWxvZ0NvbXBvbmVudCwgQ2xhc3NEaWFsb2dEYXRhPixcbiAgICApIHtcbiAgICAgICAgdGhpcy5mb3JtLnNldFZhbHVlKGRhdGEpO1xuICAgIH1cblxuICAgIHB1YmxpYyBtYXliZUNvbmZpcm0oKTogdm9pZCB7XG4gICAgICAgIGlmVmFsaWQodGhpcy5mb3JtKS5zdWJzY3JpYmUoKCkgPT4gdGhpcy5jb25maXJtKCkpO1xuICAgIH1cblxuICAgIHByaXZhdGUgY29uZmlybSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5kaWFsb2dSZWYuY2xvc2UodGhpcy5mb3JtLmdldFJhd1ZhbHVlKCkpO1xuICAgIH1cbn1cbiIsIjxoMiBpMThuIG1hdC1kaWFsb2ctdGl0bGU+U2Fpc2lyIGxlcyBjbGFzc2VzIENTUzwvaDI+XG5cbjxtYXQtZGlhbG9nLWNvbnRlbnQgW2Zvcm1Hcm91cF09XCJmb3JtXCI+XG4gICAgPG1hdC1mb3JtLWZpZWxkPlxuICAgICAgICA8bWF0LWxhYmVsIGkxOG4+Q2xhc3NlcyBDU1M8L21hdC1sYWJlbD5cbiAgICAgICAgPGlucHV0IG1hdElucHV0IFtmb3JtQ29udHJvbF09XCJjbGFzc0NvbnRyb2xcIiAoa2V5ZG93bi5lbnRlcik9XCJtYXliZUNvbmZpcm0oKVwiIGNka0ZvY3VzSW5pdGlhbCAvPlxuICAgICAgICBAaWYgKGNsYXNzQ29udHJvbC5oYXNFcnJvcigncGF0dGVybicpKSB7XG4gICAgICAgICAgICA8bWF0LWVycm9yIGkxOG4+RG9pdCDDqnRyZSB1biBvdSBwbHVzaWV1cnMgbm9tIGRlIGNsYXNzZSBDU1M8L21hdC1lcnJvcj5cbiAgICAgICAgfVxuICAgIDwvbWF0LWZvcm0tZmllbGQ+XG48L21hdC1kaWFsb2ctY29udGVudD5cblxuPG1hdC1kaWFsb2ctYWN0aW9ucyBhbGlnbj1cImVuZFwiPlxuICAgIDxidXR0b24gbWF0LWJ1dHRvbiBtYXQtZGlhbG9nLWNsb3NlIGkxOG4+QW5udWxlcjwvYnV0dG9uPlxuICAgIDxidXR0b24gbWF0LXN0cm9rZWQtYnV0dG9uIChjbGljayk9XCJtYXliZUNvbmZpcm0oKVwiIFtkaXNhYmxlZF09XCIhZm9ybS52YWxpZFwiPjxzcGFuIGkxOG4+VmFsaWRlcjwvc3Bhbj48L2J1dHRvbj5cbjwvbWF0LWRpYWxvZy1hY3Rpb25zPlxuIl19
|
|
39
|
+
}], ctorParameters: () => [] });
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xhc3MtZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwtZWRpdG9yL3NyYy9saWIvY2xhc3MtZGlhbG9nL2NsYXNzLWRpYWxvZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uYXR1cmFsLWVkaXRvci9zcmMvbGliL2NsYXNzLWRpYWxvZy9jbGFzcy1kaWFsb2cuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDaEQsT0FBTyxFQUFDLGVBQWUsRUFBRSxZQUFZLEVBQUUsZUFBZSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDeEYsT0FBTyxFQUFDLFdBQVcsRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQ3BHLE9BQU8sRUFBQyxPQUFPLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUN4QyxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDekQsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ3ZELE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLDhCQUE4QixDQUFDOzs7Ozs7O0FBb0JoRSxNQUFNLE9BQU8sb0JBQW9CO0lBQ3JCLFNBQVMsR0FBRyxNQUFNLENBQXNELFlBQVksQ0FBQyxDQUFDO0lBRTlFLFlBQVksR0FBRyxJQUFJLFdBQVcsQ0FBQyxFQUFFLEVBQUU7UUFDL0MsVUFBVSxFQUFFLFVBQVUsQ0FBQyxPQUFPLENBQUMsd0NBQXdDLENBQUM7UUFDeEUsV0FBVyxFQUFFLElBQUk7S0FDcEIsQ0FBQyxDQUFDO0lBQ2EsSUFBSSxHQUFHLElBQUksU0FBUyxDQUFDO1FBQ2pDLEtBQUssRUFBRSxJQUFJLENBQUMsWUFBWTtLQUMzQixDQUFDLENBQUM7SUFFSDtRQUNJLE1BQU0sSUFBSSxHQUFHLE1BQU0sQ0FBa0IsZUFBZSxDQUFDLENBQUM7UUFFdEQsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDN0IsQ0FBQztJQUVNLFlBQVk7UUFDZixPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztJQUN2RCxDQUFDO0lBRU8sT0FBTztRQUNYLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztJQUNsRCxDQUFDO3VHQXZCUSxvQkFBb0I7MkZBQXBCLG9CQUFvQix3RUMxQmpDLHF0QkFnQkEscUhEUWMsZUFBZSwrbkJBQUUsV0FBVyxrakJBQUUsbUJBQW1CLGtXQUFFLGtCQUFrQix1WUFBRSxjQUFjLDBXQUFFLGVBQWU7OzJGQUV2RyxvQkFBb0I7a0JBTmhDLFNBQVM7aUNBR00sSUFBSSxXQUNQLENBQUMsZUFBZSxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxrQkFBa0IsRUFBRSxjQUFjLEVBQUUsZUFBZSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIGluamVjdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge01BVF9ESUFMT0dfREFUQSwgTWF0RGlhbG9nUmVmLCBNYXREaWFsb2dNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5pbXBvcnQge0Zvcm1Db250cm9sLCBGb3JtR3JvdXAsIFZhbGlkYXRvcnMsIEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge2lmVmFsaWR9IGZyb20gJ0BlY29kZXYvbmF0dXJhbCc7XG5pbXBvcnQge01hdEJ1dHRvbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcbmltcG9ydCB7TWF0SW5wdXRNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcbmltcG9ydCB7TWF0Rm9ybUZpZWxkTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkJztcblxuZXhwb3J0IHR5cGUgQ2xhc3NEaWFsb2dEYXRhID0ge1xuICAgIC8qKlxuICAgICAqIENTUyBjbGFzcyBuYW1lc1xuICAgICAqXG4gICAgICogRWc6XG4gICAgICpcbiAgICAgKiAtIGBcIlwiYFxuICAgICAqIC0gYFwibXktY2xhc3MgbXktb3RoZXItY2xhc3NcImBcbiAgICAgKi9cbiAgICBjbGFzczogc3RyaW5nO1xufTtcblxuQENvbXBvbmVudCh7XG4gICAgdGVtcGxhdGVVcmw6ICcuL2NsYXNzLWRpYWxvZy5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmw6ICcuL2NsYXNzLWRpYWxvZy5jb21wb25lbnQuc2NzcycsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbTWF0RGlhbG9nTW9kdWxlLCBGb3Jtc01vZHVsZSwgUmVhY3RpdmVGb3Jtc01vZHVsZSwgTWF0Rm9ybUZpZWxkTW9kdWxlLCBNYXRJbnB1dE1vZHVsZSwgTWF0QnV0dG9uTW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgQ2xhc3NEaWFsb2dDb21wb25lbnQge1xuICAgIHByaXZhdGUgZGlhbG9nUmVmID0gaW5qZWN0PE1hdERpYWxvZ1JlZjxDbGFzc0RpYWxvZ0NvbXBvbmVudCwgQ2xhc3NEaWFsb2dEYXRhPj4oTWF0RGlhbG9nUmVmKTtcblxuICAgIHB1YmxpYyByZWFkb25seSBjbGFzc0NvbnRyb2wgPSBuZXcgRm9ybUNvbnRyb2woJycsIHtcbiAgICAgICAgdmFsaWRhdG9yczogVmFsaWRhdG9ycy5wYXR0ZXJuKC8oXlxccyooLT9bX2EtekEtWl0rW19hLXpBLVowLTktXSpcXHMqKSspLyksXG4gICAgICAgIG5vbk51bGxhYmxlOiB0cnVlLFxuICAgIH0pO1xuICAgIHB1YmxpYyByZWFkb25seSBmb3JtID0gbmV3IEZvcm1Hcm91cCh7XG4gICAgICAgIGNsYXNzOiB0aGlzLmNsYXNzQ29udHJvbCxcbiAgICB9KTtcblxuICAgIHB1YmxpYyBjb25zdHJ1Y3RvcigpIHtcbiAgICAgICAgY29uc3QgZGF0YSA9IGluamVjdDxDbGFzc0RpYWxvZ0RhdGE+KE1BVF9ESUFMT0dfREFUQSk7XG5cbiAgICAgICAgdGhpcy5mb3JtLnNldFZhbHVlKGRhdGEpO1xuICAgIH1cblxuICAgIHB1YmxpYyBtYXliZUNvbmZpcm0oKTogdm9pZCB7XG4gICAgICAgIGlmVmFsaWQodGhpcy5mb3JtKS5zdWJzY3JpYmUoKCkgPT4gdGhpcy5jb25maXJtKCkpO1xuICAgIH1cblxuICAgIHByaXZhdGUgY29uZmlybSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5kaWFsb2dSZWYuY2xvc2UodGhpcy5mb3JtLmdldFJhd1ZhbHVlKCkpO1xuICAgIH1cbn1cbiIsIjxoMiBpMThuIG1hdC1kaWFsb2ctdGl0bGU+U2Fpc2lyIGxlcyBjbGFzc2VzIENTUzwvaDI+XG5cbjxtYXQtZGlhbG9nLWNvbnRlbnQgW2Zvcm1Hcm91cF09XCJmb3JtXCI+XG4gICAgPG1hdC1mb3JtLWZpZWxkPlxuICAgICAgICA8bWF0LWxhYmVsIGkxOG4+Q2xhc3NlcyBDU1M8L21hdC1sYWJlbD5cbiAgICAgICAgPGlucHV0IG1hdElucHV0IFtmb3JtQ29udHJvbF09XCJjbGFzc0NvbnRyb2xcIiAoa2V5ZG93bi5lbnRlcik9XCJtYXliZUNvbmZpcm0oKVwiIGNka0ZvY3VzSW5pdGlhbCAvPlxuICAgICAgICBAaWYgKGNsYXNzQ29udHJvbC5oYXNFcnJvcigncGF0dGVybicpKSB7XG4gICAgICAgICAgICA8bWF0LWVycm9yIGkxOG4+RG9pdCDDqnRyZSB1biBvdSBwbHVzaWV1cnMgbm9tIGRlIGNsYXNzZSBDU1M8L21hdC1lcnJvcj5cbiAgICAgICAgfVxuICAgIDwvbWF0LWZvcm0tZmllbGQ+XG48L21hdC1kaWFsb2ctY29udGVudD5cblxuPG1hdC1kaWFsb2ctYWN0aW9ucyBhbGlnbj1cImVuZFwiPlxuICAgIDxidXR0b24gbWF0LWJ1dHRvbiBtYXQtZGlhbG9nLWNsb3NlIGkxOG4+QW5udWxlcjwvYnV0dG9uPlxuICAgIDxidXR0b24gbWF0LXN0cm9rZWQtYnV0dG9uIChjbGljayk9XCJtYXliZUNvbmZpcm0oKVwiIFtkaXNhYmxlZF09XCIhZm9ybS52YWxpZFwiPjxzcGFuIGkxOG4+VmFsaWRlcjwvc3Bhbj48L2J1dHRvbj5cbjwvbWF0LWRpYWxvZy1hY3Rpb25zPlxuIl19
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { Component,
|
|
2
|
-
import { MAT_DIALOG_DATA, MatDialogModule } from '@angular/material/dialog';
|
|
1
|
+
import { Component, inject } from '@angular/core';
|
|
2
|
+
import { MAT_DIALOG_DATA, MatDialogRef, MatDialogModule } from '@angular/material/dialog';
|
|
3
3
|
import { FormControl, FormGroup, Validators, FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
4
4
|
import { ifValid } from '@ecodev/natural';
|
|
5
5
|
import { MatInputModule } from '@angular/material/input';
|
|
@@ -15,157 +15,158 @@ import * as i4 from "@angular/material/icon";
|
|
|
15
15
|
import * as i5 from "@angular/material/form-field";
|
|
16
16
|
import * as i6 from "@angular/material/input";
|
|
17
17
|
export class ColorDialogComponent {
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
this.
|
|
167
|
-
|
|
168
|
-
|
|
18
|
+
dialogRef = inject(MatDialogRef);
|
|
19
|
+
colors = [
|
|
20
|
+
[
|
|
21
|
+
'#000000',
|
|
22
|
+
'#111111',
|
|
23
|
+
'#1c1c1c',
|
|
24
|
+
'#333333',
|
|
25
|
+
'#666666',
|
|
26
|
+
'#808080',
|
|
27
|
+
'#999999',
|
|
28
|
+
'#b2b2b2',
|
|
29
|
+
'#cccccc',
|
|
30
|
+
'#dddddd',
|
|
31
|
+
'#eeeeee',
|
|
32
|
+
'#ffffff',
|
|
33
|
+
],
|
|
34
|
+
[
|
|
35
|
+
'#ffff00',
|
|
36
|
+
'#ffbf00',
|
|
37
|
+
'#ff8000',
|
|
38
|
+
'#ff4000',
|
|
39
|
+
'#ff0000',
|
|
40
|
+
'#bf0041',
|
|
41
|
+
'#800080',
|
|
42
|
+
'#55308d',
|
|
43
|
+
'#2a6099',
|
|
44
|
+
'#158466',
|
|
45
|
+
'#00a933',
|
|
46
|
+
'#81d41a',
|
|
47
|
+
],
|
|
48
|
+
[
|
|
49
|
+
'#ffffd7',
|
|
50
|
+
'#fff5ce',
|
|
51
|
+
'#ffdbb6',
|
|
52
|
+
'#ffd8ce',
|
|
53
|
+
'#ffd7d7',
|
|
54
|
+
'#f7d1d5',
|
|
55
|
+
'#e0c2cd',
|
|
56
|
+
'#dedce6',
|
|
57
|
+
'#dee6ef',
|
|
58
|
+
'#dee7e5',
|
|
59
|
+
'#dde8cb',
|
|
60
|
+
'#f6f9d4',
|
|
61
|
+
],
|
|
62
|
+
[
|
|
63
|
+
'#ffffa6',
|
|
64
|
+
'#ffe994',
|
|
65
|
+
'#ffb66c',
|
|
66
|
+
'#ffaa95',
|
|
67
|
+
'#ffa6a6',
|
|
68
|
+
'#ec9ba4',
|
|
69
|
+
'#bf819e',
|
|
70
|
+
'#b7b3ca',
|
|
71
|
+
'#b4c7dc',
|
|
72
|
+
'#b3cac7',
|
|
73
|
+
'#afd095',
|
|
74
|
+
'#e8f2a1',
|
|
75
|
+
],
|
|
76
|
+
[
|
|
77
|
+
'#ffff6d',
|
|
78
|
+
'#ffde59',
|
|
79
|
+
'#ff972f',
|
|
80
|
+
'#ff7b59',
|
|
81
|
+
'#ff6d6d',
|
|
82
|
+
'#e16173',
|
|
83
|
+
'#a1467e',
|
|
84
|
+
'#8e86ae',
|
|
85
|
+
'#729fcf',
|
|
86
|
+
'#81aca6',
|
|
87
|
+
'#77bc65',
|
|
88
|
+
'#d4ea6b',
|
|
89
|
+
],
|
|
90
|
+
[
|
|
91
|
+
'#ffff38',
|
|
92
|
+
'#ffd428',
|
|
93
|
+
'#ff860d',
|
|
94
|
+
'#ff5429',
|
|
95
|
+
'#ff3838',
|
|
96
|
+
'#d62e4e',
|
|
97
|
+
'#8d1d75',
|
|
98
|
+
'#6b5e9b',
|
|
99
|
+
'#5983b0',
|
|
100
|
+
'#50938a',
|
|
101
|
+
'#3faf46',
|
|
102
|
+
'#bbe33d',
|
|
103
|
+
],
|
|
104
|
+
[
|
|
105
|
+
'#e6e905',
|
|
106
|
+
'#e8a202',
|
|
107
|
+
'#ea7500',
|
|
108
|
+
'#ed4c05',
|
|
109
|
+
'#f10d0c',
|
|
110
|
+
'#a7074b',
|
|
111
|
+
'#780373',
|
|
112
|
+
'#5b277d',
|
|
113
|
+
'#3465a4',
|
|
114
|
+
'#168253',
|
|
115
|
+
'#069a2e',
|
|
116
|
+
'#5eb91e',
|
|
117
|
+
],
|
|
118
|
+
[
|
|
119
|
+
'#acb20c',
|
|
120
|
+
'#b47804',
|
|
121
|
+
'#b85c00',
|
|
122
|
+
'#be480a',
|
|
123
|
+
'#c9211e',
|
|
124
|
+
'#861141',
|
|
125
|
+
'#650953',
|
|
126
|
+
'#55215b',
|
|
127
|
+
'#355269',
|
|
128
|
+
'#1e6a39',
|
|
129
|
+
'#127622',
|
|
130
|
+
'#468a1a',
|
|
131
|
+
],
|
|
132
|
+
[
|
|
133
|
+
'#706e0c',
|
|
134
|
+
'#784b04',
|
|
135
|
+
'#7b3d00',
|
|
136
|
+
'#813709',
|
|
137
|
+
'#8d281e',
|
|
138
|
+
'#611729',
|
|
139
|
+
'#4e102d',
|
|
140
|
+
'#481d32',
|
|
141
|
+
'#383d3c',
|
|
142
|
+
'#28471f',
|
|
143
|
+
'#224b12',
|
|
144
|
+
'#395511',
|
|
145
|
+
],
|
|
146
|
+
[
|
|
147
|
+
'#443205',
|
|
148
|
+
'#472702',
|
|
149
|
+
'#492300',
|
|
150
|
+
'#4b2204',
|
|
151
|
+
'#50200c',
|
|
152
|
+
'#41190d',
|
|
153
|
+
'#3b160e',
|
|
154
|
+
'#3a1a0f',
|
|
155
|
+
'#362413',
|
|
156
|
+
'#302709',
|
|
157
|
+
'#2e2706',
|
|
158
|
+
'#342a06',
|
|
159
|
+
],
|
|
160
|
+
];
|
|
161
|
+
colorControl = new FormControl('', {
|
|
162
|
+
validators: Validators.pattern(/^#\p{Hex_Digit}{6}/u),
|
|
163
|
+
nonNullable: true,
|
|
164
|
+
});
|
|
165
|
+
form = new FormGroup({
|
|
166
|
+
color: this.colorControl,
|
|
167
|
+
});
|
|
168
|
+
constructor() {
|
|
169
|
+
const data = inject(MAT_DIALOG_DATA);
|
|
169
170
|
this.form.setValue(data);
|
|
170
171
|
}
|
|
171
172
|
maybeConfirm() {
|
|
@@ -178,8 +179,8 @@ export class ColorDialogComponent {
|
|
|
178
179
|
this.colorControl.setValue(color);
|
|
179
180
|
this.maybeConfirm();
|
|
180
181
|
}
|
|
181
|
-
static
|
|
182
|
-
static
|
|
182
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: ColorDialogComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
183
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: ColorDialogComponent, isStandalone: true, selector: "ng-component", ngImport: i0, template: "<h2 i18n mat-dialog-title>S\u00E9lectionner une couleur</h2>\n\n<mat-dialog-content [formGroup]=\"form\">\n <div>\n @for (row of colors; track row) {\n <div>\n @for (color of row; track color) {\n <div class=\"color\" [style]=\"{backgroundColor: color}\" (click)=\"selectColor(color)\"> </div>\n }\n </div>\n }\n </div>\n\n <div>\n <button mat-button (click)=\"selectColor('')\">\n <mat-icon naturalIcon=\"format_color_reset\" />\n <span i18n>Transparent</span></button\n >\n </div>\n\n <mat-form-field>\n <mat-label i18n>Couleur</mat-label>\n <input matInput [formControl]=\"colorControl\" (keydown.enter)=\"maybeConfirm()\" cdkFocusInitial />\n <div\n class=\"sample\"\n matTextSuffix\n [style]=\"{backgroundColor: colorControl.valid ? colorControl.value : ''}\"\n ></div>\n @if (colorControl.hasError('pattern')) {\n <mat-error i18n>Doit \u00EAtre le format hexadecimal. Par exemple: #ff4000 </mat-error>\n }\n </mat-form-field>\n</mat-dialog-content>\n\n<mat-dialog-actions align=\"end\">\n <button mat-button mat-dialog-close i18n>Annuler</button>\n <button mat-stroked-button (click)=\"maybeConfirm()\" [disabled]=\"!form.valid\"><span i18n>Valider</span></button>\n</mat-dialog-actions>\n", styles: ["mat-dialog-content{display:grid;row-gap:25px;justify-content:center;width:70vw;max-width:30em}.color{display:inline-block;cursor:pointer;margin:3px;width:25px;height:25px}.color:hover{margin:0;padding:3px}.sample{width:27px;height:27px}\n"], dependencies: [{ kind: "ngmodule", type: MatDialogModule }, { kind: "directive", type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["aria-label", "type", "mat-dialog-close", "matDialogClose"], exportAs: ["matDialogClose"] }, { kind: "directive", type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { kind: "directive", type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]", inputs: ["align"] }, { kind: "directive", type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { 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] ", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NaturalIconDirective, selector: "mat-icon[naturalIcon]", inputs: ["naturalIcon", "size"] }, { kind: "ngmodule", type: MatFormFieldModule }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "directive", type: i5.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i5.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "ngmodule", type: MatInputModule }, { kind: "directive", type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }] });
|
|
183
184
|
}
|
|
184
185
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: ColorDialogComponent, decorators: [{
|
|
185
186
|
type: Component,
|
|
@@ -193,8 +194,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImpor
|
|
|
193
194
|
MatFormFieldModule,
|
|
194
195
|
MatInputModule,
|
|
195
196
|
], template: "<h2 i18n mat-dialog-title>S\u00E9lectionner une couleur</h2>\n\n<mat-dialog-content [formGroup]=\"form\">\n <div>\n @for (row of colors; track row) {\n <div>\n @for (color of row; track color) {\n <div class=\"color\" [style]=\"{backgroundColor: color}\" (click)=\"selectColor(color)\"> </div>\n }\n </div>\n }\n </div>\n\n <div>\n <button mat-button (click)=\"selectColor('')\">\n <mat-icon naturalIcon=\"format_color_reset\" />\n <span i18n>Transparent</span></button\n >\n </div>\n\n <mat-form-field>\n <mat-label i18n>Couleur</mat-label>\n <input matInput [formControl]=\"colorControl\" (keydown.enter)=\"maybeConfirm()\" cdkFocusInitial />\n <div\n class=\"sample\"\n matTextSuffix\n [style]=\"{backgroundColor: colorControl.valid ? colorControl.value : ''}\"\n ></div>\n @if (colorControl.hasError('pattern')) {\n <mat-error i18n>Doit \u00EAtre le format hexadecimal. Par exemple: #ff4000 </mat-error>\n }\n </mat-form-field>\n</mat-dialog-content>\n\n<mat-dialog-actions align=\"end\">\n <button mat-button mat-dialog-close i18n>Annuler</button>\n <button mat-stroked-button (click)=\"maybeConfirm()\" [disabled]=\"!form.valid\"><span i18n>Valider</span></button>\n</mat-dialog-actions>\n", styles: ["mat-dialog-content{display:grid;row-gap:25px;justify-content:center;width:70vw;max-width:30em}.color{display:inline-block;cursor:pointer;margin:3px;width:25px;height:25px}.color:hover{margin:0;padding:3px}.sample{width:27px;height:27px}\n"] }]
|
|
196
|
-
}], ctorParameters: () => [
|
|
197
|
-
type: Inject,
|
|
198
|
-
args: [MAT_DIALOG_DATA]
|
|
199
|
-
}] }, { type: i1.MatDialogRef }] });
|
|
200
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/natural-editor/src/lib/color-dialog/color-dialog.component.ts","../../../../../projects/natural-editor/src/lib/color-dialog/color-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject} from '@angular/core';\nimport {MAT_DIALOG_DATA, MatDialogRef, MatDialogModule} from '@angular/material/dialog';\nimport {FormControl, FormGroup, Validators, FormsModule, ReactiveFormsModule} from '@angular/forms';\nimport {ifValid} from '@ecodev/natural';\nimport {MatInputModule} from '@angular/material/input';\nimport {MatFormFieldModule} from '@angular/material/form-field';\nimport {NaturalIconDirective} from '@ecodev/natural';\nimport {MatIconModule} from '@angular/material/icon';\nimport {MatButtonModule} from '@angular/material/button';\n\nexport type ColorDialogData = {\n    /**\n     * Empty string means no color set at all. Anything else must be a valid CSS color in hexa format.\n     *\n     * Eg:\n     *\n     * - `\"\"`\n     * - `\"#ff4000\"`\n     */\n    color: string;\n};\n\n@Component({\n    templateUrl: './color-dialog.component.html',\n    styleUrl: './color-dialog.component.scss',\n    standalone: true,\n    imports: [\n        MatDialogModule,\n        FormsModule,\n        ReactiveFormsModule,\n        MatButtonModule,\n        MatIconModule,\n        NaturalIconDirective,\n        MatFormFieldModule,\n        MatInputModule,\n    ],\n})\nexport class ColorDialogComponent {\n    public readonly colors: string[][] = [\n        [\n            '#000000',\n            '#111111',\n            '#1c1c1c',\n            '#333333',\n            '#666666',\n            '#808080',\n            '#999999',\n            '#b2b2b2',\n            '#cccccc',\n            '#dddddd',\n            '#eeeeee',\n            '#ffffff',\n        ],\n        [\n            '#ffff00',\n            '#ffbf00',\n            '#ff8000',\n            '#ff4000',\n            '#ff0000',\n            '#bf0041',\n            '#800080',\n            '#55308d',\n            '#2a6099',\n            '#158466',\n            '#00a933',\n            '#81d41a',\n        ],\n        [\n            '#ffffd7',\n            '#fff5ce',\n            '#ffdbb6',\n            '#ffd8ce',\n            '#ffd7d7',\n            '#f7d1d5',\n            '#e0c2cd',\n            '#dedce6',\n            '#dee6ef',\n            '#dee7e5',\n            '#dde8cb',\n            '#f6f9d4',\n        ],\n        [\n            '#ffffa6',\n            '#ffe994',\n            '#ffb66c',\n            '#ffaa95',\n            '#ffa6a6',\n            '#ec9ba4',\n            '#bf819e',\n            '#b7b3ca',\n            '#b4c7dc',\n            '#b3cac7',\n            '#afd095',\n            '#e8f2a1',\n        ],\n        [\n            '#ffff6d',\n            '#ffde59',\n            '#ff972f',\n            '#ff7b59',\n            '#ff6d6d',\n            '#e16173',\n            '#a1467e',\n            '#8e86ae',\n            '#729fcf',\n            '#81aca6',\n            '#77bc65',\n            '#d4ea6b',\n        ],\n        [\n            '#ffff38',\n            '#ffd428',\n            '#ff860d',\n            '#ff5429',\n            '#ff3838',\n            '#d62e4e',\n            '#8d1d75',\n            '#6b5e9b',\n            '#5983b0',\n            '#50938a',\n            '#3faf46',\n            '#bbe33d',\n        ],\n        [\n            '#e6e905',\n            '#e8a202',\n            '#ea7500',\n            '#ed4c05',\n            '#f10d0c',\n            '#a7074b',\n            '#780373',\n            '#5b277d',\n            '#3465a4',\n            '#168253',\n            '#069a2e',\n            '#5eb91e',\n        ],\n        [\n            '#acb20c',\n            '#b47804',\n            '#b85c00',\n            '#be480a',\n            '#c9211e',\n            '#861141',\n            '#650953',\n            '#55215b',\n            '#355269',\n            '#1e6a39',\n            '#127622',\n            '#468a1a',\n        ],\n        [\n            '#706e0c',\n            '#784b04',\n            '#7b3d00',\n            '#813709',\n            '#8d281e',\n            '#611729',\n            '#4e102d',\n            '#481d32',\n            '#383d3c',\n            '#28471f',\n            '#224b12',\n            '#395511',\n        ],\n        [\n            '#443205',\n            '#472702',\n            '#492300',\n            '#4b2204',\n            '#50200c',\n            '#41190d',\n            '#3b160e',\n            '#3a1a0f',\n            '#362413',\n            '#302709',\n            '#2e2706',\n            '#342a06',\n        ],\n    ];\n\n    public readonly colorControl = new FormControl('', {\n        validators: Validators.pattern(/^#\\p{Hex_Digit}{6}/u),\n        nonNullable: true,\n    });\n    public readonly form = new FormGroup({\n        color: this.colorControl,\n    });\n\n    public constructor(\n        @Inject(MAT_DIALOG_DATA) data: ColorDialogData,\n        private dialogRef: MatDialogRef<ColorDialogComponent, ColorDialogData>,\n    ) {\n        this.form.setValue(data);\n    }\n\n    public maybeConfirm(): void {\n        ifValid(this.form).subscribe(() => this.confirm());\n    }\n\n    private confirm(): void {\n        this.dialogRef.close(this.form.getRawValue());\n    }\n\n    public selectColor(color: string): void {\n        this.colorControl.setValue(color);\n        this.maybeConfirm();\n    }\n}\n","<h2 i18n mat-dialog-title>Sélectionner une couleur</h2>\n\n<mat-dialog-content [formGroup]=\"form\">\n    <div>\n        @for (row of colors; track row) {\n            <div>\n                @for (color of row; track color) {\n                    <div class=\"color\" [style]=\"{backgroundColor: color}\" (click)=\"selectColor(color)\"> </div>\n                }\n            </div>\n        }\n    </div>\n\n    <div>\n        <button mat-button (click)=\"selectColor('')\">\n            <mat-icon naturalIcon=\"format_color_reset\" />\n            <span i18n>Transparent</span></button\n        >\n    </div>\n\n    <mat-form-field>\n        <mat-label i18n>Couleur</mat-label>\n        <input matInput [formControl]=\"colorControl\" (keydown.enter)=\"maybeConfirm()\" cdkFocusInitial />\n        <div\n            class=\"sample\"\n            matTextSuffix\n            [style]=\"{backgroundColor: colorControl.valid ? colorControl.value : ''}\"\n        ></div>\n        @if (colorControl.hasError('pattern')) {\n            <mat-error i18n>Doit être le format hexadecimal. Par exemple: #ff4000 </mat-error>\n        }\n    </mat-form-field>\n</mat-dialog-content>\n\n<mat-dialog-actions align=\"end\">\n    <button mat-button mat-dialog-close i18n>Annuler</button>\n    <button mat-stroked-button (click)=\"maybeConfirm()\" [disabled]=\"!form.valid\"><span i18n>Valider</span></button>\n</mat-dialog-actions>\n"]}
|
|
197
|
+
}], ctorParameters: () => [] });
|
|
198
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/natural-editor/src/lib/color-dialog/color-dialog.component.ts","../../../../../projects/natural-editor/src/lib/color-dialog/color-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, inject} from '@angular/core';\nimport {MAT_DIALOG_DATA, MatDialogRef, MatDialogModule} from '@angular/material/dialog';\nimport {FormControl, FormGroup, Validators, FormsModule, ReactiveFormsModule} from '@angular/forms';\nimport {ifValid} from '@ecodev/natural';\nimport {MatInputModule} from '@angular/material/input';\nimport {MatFormFieldModule} from '@angular/material/form-field';\nimport {NaturalIconDirective} from '@ecodev/natural';\nimport {MatIconModule} from '@angular/material/icon';\nimport {MatButtonModule} from '@angular/material/button';\n\nexport type ColorDialogData = {\n    /**\n     * Empty string means no color set at all. Anything else must be a valid CSS color in hexa format.\n     *\n     * Eg:\n     *\n     * - `\"\"`\n     * - `\"#ff4000\"`\n     */\n    color: string;\n};\n\n@Component({\n    templateUrl: './color-dialog.component.html',\n    styleUrl: './color-dialog.component.scss',\n    standalone: true,\n    imports: [\n        MatDialogModule,\n        FormsModule,\n        ReactiveFormsModule,\n        MatButtonModule,\n        MatIconModule,\n        NaturalIconDirective,\n        MatFormFieldModule,\n        MatInputModule,\n    ],\n})\nexport class ColorDialogComponent {\n    private dialogRef = inject<MatDialogRef<ColorDialogComponent, ColorDialogData>>(MatDialogRef);\n\n    public readonly colors: string[][] = [\n        [\n            '#000000',\n            '#111111',\n            '#1c1c1c',\n            '#333333',\n            '#666666',\n            '#808080',\n            '#999999',\n            '#b2b2b2',\n            '#cccccc',\n            '#dddddd',\n            '#eeeeee',\n            '#ffffff',\n        ],\n        [\n            '#ffff00',\n            '#ffbf00',\n            '#ff8000',\n            '#ff4000',\n            '#ff0000',\n            '#bf0041',\n            '#800080',\n            '#55308d',\n            '#2a6099',\n            '#158466',\n            '#00a933',\n            '#81d41a',\n        ],\n        [\n            '#ffffd7',\n            '#fff5ce',\n            '#ffdbb6',\n            '#ffd8ce',\n            '#ffd7d7',\n            '#f7d1d5',\n            '#e0c2cd',\n            '#dedce6',\n            '#dee6ef',\n            '#dee7e5',\n            '#dde8cb',\n            '#f6f9d4',\n        ],\n        [\n            '#ffffa6',\n            '#ffe994',\n            '#ffb66c',\n            '#ffaa95',\n            '#ffa6a6',\n            '#ec9ba4',\n            '#bf819e',\n            '#b7b3ca',\n            '#b4c7dc',\n            '#b3cac7',\n            '#afd095',\n            '#e8f2a1',\n        ],\n        [\n            '#ffff6d',\n            '#ffde59',\n            '#ff972f',\n            '#ff7b59',\n            '#ff6d6d',\n            '#e16173',\n            '#a1467e',\n            '#8e86ae',\n            '#729fcf',\n            '#81aca6',\n            '#77bc65',\n            '#d4ea6b',\n        ],\n        [\n            '#ffff38',\n            '#ffd428',\n            '#ff860d',\n            '#ff5429',\n            '#ff3838',\n            '#d62e4e',\n            '#8d1d75',\n            '#6b5e9b',\n            '#5983b0',\n            '#50938a',\n            '#3faf46',\n            '#bbe33d',\n        ],\n        [\n            '#e6e905',\n            '#e8a202',\n            '#ea7500',\n            '#ed4c05',\n            '#f10d0c',\n            '#a7074b',\n            '#780373',\n            '#5b277d',\n            '#3465a4',\n            '#168253',\n            '#069a2e',\n            '#5eb91e',\n        ],\n        [\n            '#acb20c',\n            '#b47804',\n            '#b85c00',\n            '#be480a',\n            '#c9211e',\n            '#861141',\n            '#650953',\n            '#55215b',\n            '#355269',\n            '#1e6a39',\n            '#127622',\n            '#468a1a',\n        ],\n        [\n            '#706e0c',\n            '#784b04',\n            '#7b3d00',\n            '#813709',\n            '#8d281e',\n            '#611729',\n            '#4e102d',\n            '#481d32',\n            '#383d3c',\n            '#28471f',\n            '#224b12',\n            '#395511',\n        ],\n        [\n            '#443205',\n            '#472702',\n            '#492300',\n            '#4b2204',\n            '#50200c',\n            '#41190d',\n            '#3b160e',\n            '#3a1a0f',\n            '#362413',\n            '#302709',\n            '#2e2706',\n            '#342a06',\n        ],\n    ];\n\n    public readonly colorControl = new FormControl('', {\n        validators: Validators.pattern(/^#\\p{Hex_Digit}{6}/u),\n        nonNullable: true,\n    });\n    public readonly form = new FormGroup({\n        color: this.colorControl,\n    });\n\n    public constructor() {\n        const data = inject<ColorDialogData>(MAT_DIALOG_DATA);\n\n        this.form.setValue(data);\n    }\n\n    public maybeConfirm(): void {\n        ifValid(this.form).subscribe(() => this.confirm());\n    }\n\n    private confirm(): void {\n        this.dialogRef.close(this.form.getRawValue());\n    }\n\n    public selectColor(color: string): void {\n        this.colorControl.setValue(color);\n        this.maybeConfirm();\n    }\n}\n","<h2 i18n mat-dialog-title>Sélectionner une couleur</h2>\n\n<mat-dialog-content [formGroup]=\"form\">\n    <div>\n        @for (row of colors; track row) {\n            <div>\n                @for (color of row; track color) {\n                    <div class=\"color\" [style]=\"{backgroundColor: color}\" (click)=\"selectColor(color)\"> </div>\n                }\n            </div>\n        }\n    </div>\n\n    <div>\n        <button mat-button (click)=\"selectColor('')\">\n            <mat-icon naturalIcon=\"format_color_reset\" />\n            <span i18n>Transparent</span></button\n        >\n    </div>\n\n    <mat-form-field>\n        <mat-label i18n>Couleur</mat-label>\n        <input matInput [formControl]=\"colorControl\" (keydown.enter)=\"maybeConfirm()\" cdkFocusInitial />\n        <div\n            class=\"sample\"\n            matTextSuffix\n            [style]=\"{backgroundColor: colorControl.valid ? colorControl.value : ''}\"\n        ></div>\n        @if (colorControl.hasError('pattern')) {\n            <mat-error i18n>Doit être le format hexadecimal. Par exemple: #ff4000 </mat-error>\n        }\n    </mat-form-field>\n</mat-dialog-content>\n\n<mat-dialog-actions align=\"end\">\n    <button mat-button mat-dialog-close i18n>Annuler</button>\n    <button mat-stroked-button (click)=\"maybeConfirm()\" [disabled]=\"!form.valid\"><span i18n>Valider</span></button>\n</mat-dialog-actions>\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Directive, HostBinding,
|
|
1
|
+
import { Directive, HostBinding, Input, inject } from '@angular/core';
|
|
2
2
|
import { DOCUMENT } from '@angular/common';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
/**
|
|
@@ -36,6 +36,9 @@ let componentCount = 0;
|
|
|
36
36
|
* ```
|
|
37
37
|
*/
|
|
38
38
|
export class NaturalCustomCssDirective {
|
|
39
|
+
document = inject(DOCUMENT);
|
|
40
|
+
style = null;
|
|
41
|
+
id = 'n' + ++uniqueId;
|
|
39
42
|
set naturalCustomCss(value) {
|
|
40
43
|
if (value && !this.style) {
|
|
41
44
|
this.style = this.document.createElement('style');
|
|
@@ -45,11 +48,6 @@ export class NaturalCustomCssDirective {
|
|
|
45
48
|
this.style.innerHTML = value ? prefixCss(`[data-natural-id=${this.id}]`, value) : '';
|
|
46
49
|
}
|
|
47
50
|
}
|
|
48
|
-
constructor(document) {
|
|
49
|
-
this.document = document;
|
|
50
|
-
this.style = null;
|
|
51
|
-
this.id = 'n' + ++uniqueId;
|
|
52
|
-
}
|
|
53
51
|
ngOnDestroy() {
|
|
54
52
|
this.style?.remove();
|
|
55
53
|
// Reset uniqueId if we have no component alive anymore, so that we never reach max int
|
|
@@ -58,8 +56,8 @@ export class NaturalCustomCssDirective {
|
|
|
58
56
|
uniqueId = 0;
|
|
59
57
|
}
|
|
60
58
|
}
|
|
61
|
-
static
|
|
62
|
-
static
|
|
59
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalCustomCssDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
60
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.3", type: NaturalCustomCssDirective, isStandalone: true, selector: "[naturalCustomCss]", inputs: { naturalCustomCss: "naturalCustomCss" }, host: { properties: { "attr.data-natural-id": "this.id" } }, ngImport: i0 });
|
|
63
61
|
}
|
|
64
62
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalCustomCssDirective, decorators: [{
|
|
65
63
|
type: Directive,
|
|
@@ -67,14 +65,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImpor
|
|
|
67
65
|
selector: '[naturalCustomCss]',
|
|
68
66
|
standalone: true,
|
|
69
67
|
}]
|
|
70
|
-
}],
|
|
71
|
-
type: Inject,
|
|
72
|
-
args: [DOCUMENT]
|
|
73
|
-
}] }], propDecorators: { id: [{
|
|
68
|
+
}], propDecorators: { id: [{
|
|
74
69
|
type: HostBinding,
|
|
75
70
|
args: ['attr.data-natural-id']
|
|
76
71
|
}], naturalCustomCss: [{
|
|
77
72
|
type: Input,
|
|
78
73
|
args: [{ required: true }]
|
|
79
74
|
}] } });
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLWNzcy5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uYXR1cmFsLWVkaXRvci9zcmMvbGliL2N1c3RvbS1jc3MvY3VzdG9tLWNzcy5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFhLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUMvRSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0saUJBQWlCLENBQUM7O0FBRXpDOzs7O0dBSUc7QUFDSCxNQUFNLFVBQVUsU0FBUyxDQUFDLE1BQWMsRUFBRSxHQUFXO0lBQ2pELE1BQU0sR0FBRyxJQUFJLEdBQUcsTUFBTSxHQUFHLEdBQUcsQ0FBQztJQUU3QixPQUFPLEdBQUc7U0FDTCxPQUFPLENBQUMsYUFBYSxFQUFFLFNBQVMsQ0FBQyxFQUFFLENBQ2hDLFNBQVM7U0FDSixLQUFLLENBQUMsR0FBRyxDQUFDO1NBQ1YsR0FBRyxDQUFDLFFBQVEsQ0FBQyxFQUFFO1FBQ1osSUFBSSxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUM7WUFDdkMsT0FBTyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDM0IsQ0FBQzthQUFNLENBQUM7WUFDSixPQUFPLE1BQU0sR0FBRyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDcEMsQ0FBQztJQUNMLENBQUMsQ0FBQztTQUNELElBQUksQ0FBQyxHQUFHLENBQUMsQ0FDakI7U0FDQSxJQUFJLEVBQUUsQ0FBQztBQUNoQixDQUFDO0FBRUQsSUFBSSxRQUFRLEdBQUcsQ0FBQyxDQUFDO0FBQ2pCLElBQUksY0FBYyxHQUFHLENBQUMsQ0FBQztBQUV2Qjs7Ozs7Ozs7OztHQVVHO0FBS0gsTUFBTSxPQUFPLHlCQUF5QjtJQUNqQixRQUFRLEdBQUcsTUFBTSxDQUFXLFFBQVEsQ0FBQyxDQUFDO0lBRS9DLEtBQUssR0FBNEIsSUFBSSxDQUFDO0lBRVEsRUFBRSxHQUFHLEdBQUcsR0FBRyxFQUFFLFFBQVEsQ0FBQztJQUU1RSxJQUNXLGdCQUFnQixDQUFDLEtBQXlCO1FBQ2pELElBQUksS0FBSyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ3ZCLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDbEQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMvQyxDQUFDO1FBRUQsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDYixJQUFJLENBQUMsS0FBSyxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxvQkFBb0IsSUFBSSxDQUFDLEVBQUUsR0FBRyxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7UUFDekYsQ0FBQztJQUNMLENBQUM7SUFFTSxXQUFXO1FBQ2QsSUFBSSxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUUsQ0FBQztRQUVyQix1RkFBdUY7UUFDdkYsY0FBYyxFQUFFLENBQUM7UUFDakIsSUFBSSxjQUFjLElBQUksQ0FBQyxFQUFFLENBQUM7WUFDdEIsUUFBUSxHQUFHLENBQUMsQ0FBQztRQUNqQixDQUFDO0lBQ0wsQ0FBQzt1R0EzQlEseUJBQXlCOzJGQUF6Qix5QkFBeUI7OzJGQUF6Qix5QkFBeUI7a0JBSnJDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLG9CQUFvQjtvQkFDOUIsVUFBVSxFQUFFLElBQUk7aUJBQ25COzhCQU15RCxFQUFFO3NCQUF2RCxXQUFXO3VCQUFDLHNCQUFzQjtnQkFHeEIsZ0JBQWdCO3NCQUQxQixLQUFLO3VCQUFDLEVBQUMsUUFBUSxFQUFFLElBQUksRUFBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RGlyZWN0aXZlLCBIb3N0QmluZGluZywgSW5wdXQsIE9uRGVzdHJveSwgaW5qZWN0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7RE9DVU1FTlR9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbi8qKlxuICogUHJlZml4IGFsbCBDU1Mgc2VsZWN0b3JzIHdpdGggdGhlIGdpdmVuIHNlbGVjdG9yXG4gKlxuICogVGhpcyBpcyBtZWFudCB0byBiZSByZWxhdGl2ZWx5IHNpbXBsZSBhbmQgbWlnaHQgbm90IGNvdmVyIGFkdmFuY2VkIENTUyBzeW50YXhcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHByZWZpeENzcyhwcmVmaXg6IHN0cmluZywgY3NzOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHByZWZpeCA9ICdcXG4nICsgcHJlZml4ICsgJyAnO1xuXG4gICAgcmV0dXJuIGNzc1xuICAgICAgICAucmVwbGFjZSgvKFtee31dKil7L2dzLCBzZWxlY3RvcnMgPT5cbiAgICAgICAgICAgIHNlbGVjdG9yc1xuICAgICAgICAgICAgICAgIC5zcGxpdCgnLCcpXG4gICAgICAgICAgICAgICAgLm1hcChzZWxlY3RvciA9PiB7XG4gICAgICAgICAgICAgICAgICAgIGlmIChzZWxlY3Rvci50cmltKCkuc3RhcnRzV2l0aCgnQG1lZGlhJykpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHJldHVybiBzZWxlY3Rvci50cmltKCk7XG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgICAgICByZXR1cm4gcHJlZml4ICsgc2VsZWN0b3IudHJpbSgpO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgICAuam9pbignLCcpLFxuICAgICAgICApXG4gICAgICAgIC50cmltKCk7XG59XG5cbmxldCB1bmlxdWVJZCA9IDA7XG5sZXQgY29tcG9uZW50Q291bnQgPSAwO1xuXG4vKipcbiAqIEluamVjdCBjdXN0b20gQ1NTIGludG8gY29tcG9uZW50IGFuZCBzY29wZSB0aGUgQ1NTIG9ubHkgdG8gdGhpcyBjb21wb25lbnRcbiAqXG4gKiBVc2FnZSA6XG4gKlxuICogYGBgaHRtbFxuICogPGRpdiBbbmF0dXJhbEN1c3RvbUNzc109XCIubXktY2xhc3Mge2JhY2tncm91bmQ6IHJlZH1cIj5cbiAqICAgICA8cCBjbGFzcz1cIm15LWNsYXNzXCI+Zm9vIGJhcjwvcD5cbiAqIDwvZGl2PlxuICogYGBgXG4gKi9cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW25hdHVyYWxDdXN0b21Dc3NdJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBOYXR1cmFsQ3VzdG9tQ3NzRGlyZWN0aXZlIGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGRvY3VtZW50ID0gaW5qZWN0PERvY3VtZW50PihET0NVTUVOVCk7XG5cbiAgICBwcml2YXRlIHN0eWxlOiBIVE1MU3R5bGVFbGVtZW50IHwgbnVsbCA9IG51bGw7XG5cbiAgICBASG9zdEJpbmRpbmcoJ2F0dHIuZGF0YS1uYXR1cmFsLWlkJykgcHJpdmF0ZSByZWFkb25seSBpZCA9ICduJyArICsrdW5pcXVlSWQ7XG5cbiAgICBASW5wdXQoe3JlcXVpcmVkOiB0cnVlfSlcbiAgICBwdWJsaWMgc2V0IG5hdHVyYWxDdXN0b21Dc3ModmFsdWU6IHN0cmluZyB8IHVuZGVmaW5lZCkge1xuICAgICAgICBpZiAodmFsdWUgJiYgIXRoaXMuc3R5bGUpIHtcbiAgICAgICAgICAgIHRoaXMuc3R5bGUgPSB0aGlzLmRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ3N0eWxlJyk7XG4gICAgICAgICAgICB0aGlzLmRvY3VtZW50LmhlYWQuYXBwZW5kQ2hpbGQodGhpcy5zdHlsZSk7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAodGhpcy5zdHlsZSkge1xuICAgICAgICAgICAgdGhpcy5zdHlsZS5pbm5lckhUTUwgPSB2YWx1ZSA/IHByZWZpeENzcyhgW2RhdGEtbmF0dXJhbC1pZD0ke3RoaXMuaWR9XWAsIHZhbHVlKSA6ICcnO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHVibGljIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLnN0eWxlPy5yZW1vdmUoKTtcblxuICAgICAgICAvLyBSZXNldCB1bmlxdWVJZCBpZiB3ZSBoYXZlIG5vIGNvbXBvbmVudCBhbGl2ZSBhbnltb3JlLCBzbyB0aGF0IHdlIG5ldmVyIHJlYWNoIG1heCBpbnRcbiAgICAgICAgY29tcG9uZW50Q291bnQtLTtcbiAgICAgICAgaWYgKGNvbXBvbmVudENvdW50IDw9IDApIHtcbiAgICAgICAgICAgIHVuaXF1ZUlkID0gMDtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==
|