@provoly/dashboard 0.13.7 → 0.13.8
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/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.d.ts +4 -4
- package/admin/components/admin-dataset/store/admin-dataset.actions.d.ts +3 -3
- package/esm2022/admin/components/admin-classes/admin-classes-customize/tooltip/admin-classes-customize-tooltip.component.mjs +3 -3
- package/esm2022/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.mjs +2 -2
- package/esm2022/admin/components/admin-dataset/store/admin-dataset.actions.mjs +1 -1
- package/esm2022/lib/core/components/overlay/dialog-confirm.component.mjs +5 -12
- package/esm2022/lib/core/components/overlay/overlay.module.mjs +5 -4
- package/esm2022/lib/core/components/select/select.component.mjs +2 -2
- package/esm2022/lib/core/components/share/share.component.mjs +3 -3
- package/esm2022/lib/core/model/admin-api.model.mjs +1 -1
- package/esm2022/lib/core/model/dataset.interface.mjs +1 -1
- package/esm2022/lib/core/model/display-options.interface.mjs +4 -2
- package/esm2022/lib/core/model/manifest.interface.mjs +1 -1
- package/esm2022/lib/core/store/config/config.actions.mjs +2 -1
- package/esm2022/lib/core/store/config/config.effects.mjs +25 -4
- package/esm2022/lib/core/store/data-source/data-source.actions.mjs +1 -1
- package/esm2022/lib/core/store/data-source/data-source.effects.mjs +1 -1
- package/esm2022/lib/core/store/data-source/data-source.model.mjs +1 -1
- package/esm2022/lib/core/store/data-source/data-source.reducer.mjs +1 -1
- package/esm2022/lib/core/store/data-source/data-source.service.mjs +1 -1
- package/esm2022/lib/dashboard/components/context-menu/context-menu.component.mjs +3 -7
- package/esm2022/lib/dashboard/components/widgets/datasource-selector/datasource-selector.component.mjs +1 -1
- package/esm2022/lib/dashboard/components/widgets/settings/settings.component.mjs +6 -3
- package/esm2022/lib/dashboard/public-api.mjs +2 -1
- package/esm2022/lib/dashboard/store/dashboard.actions.mjs +2 -3
- package/esm2022/lib/dashboard/store/dashboard.effects.mjs +25 -11
- package/esm2022/lib/dashboard/store/dashboard.reducers.mjs +2 -11
- package/esm2022/lib/dashboard/store/dashboard.selectors.mjs +3 -5
- package/esm2022/lib/dashboard/store/manifest-utils.class.mjs +11 -0
- package/esm2022/lib/dashboard/store/manifest.service.mjs +3 -10
- package/esm2022/lib/dashboard/tooltip/components/default/default.tooltip.component.mjs +5 -4
- package/esm2022/pipeline/components/pipeline-list/pipeline-list.component.mjs +5 -8
- package/esm2022/presentation/components/presentation.component.mjs +5 -42
- package/esm2022/presentation/presentation.module.mjs +8 -4
- package/esm2022/restitution/components/restitution-catalog/restitution-catalog.component.mjs +9 -65
- package/esm2022/search/components/save-query/save-query.component.mjs +5 -8
- package/esm2022/toolbox/components/filter-settings/filter-settings.component.mjs +3 -3
- package/esm2022/toolbox/components/refresh-datasets/refresh-datasets.component.mjs +3 -3
- package/esm2022/toolbox/components/select-grid-layout/select-grid-layout.component.mjs +5 -16
- package/esm2022/toolbox/toolbox.module.mjs +8 -4
- package/esm2022/tooltips/attribute/attribute-tooltip.component.mjs +3 -3
- package/esm2022/widgets/widget-chart/component/widget-chart.component.mjs +3 -3
- package/esm2022/widgets/widget-map/component/widget-map.component.mjs +46 -23
- package/esm2022/widgets/widget-map/i18n/en.translations.mjs +4 -2
- package/esm2022/widgets/widget-map/i18n/fr.translations.mjs +4 -2
- package/esm2022/widgets/widget-map/interaction/interaction-manager.class.mjs +4 -23
- package/esm2022/widgets/widget-tile/component/widget-tile.component.mjs +3 -3
- package/fesm2022/provoly-dashboard-admin.mjs +2 -2
- package/fesm2022/provoly-dashboard-admin.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-pipeline.mjs +4 -7
- package/fesm2022/provoly-dashboard-pipeline.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-presentation.mjs +11 -44
- package/fesm2022/provoly-dashboard-presentation.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-restitution.mjs +9 -65
- package/fesm2022/provoly-dashboard-restitution.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-search.mjs +4 -7
- package/fesm2022/provoly-dashboard-search.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-toolbox.mjs +14 -21
- package/fesm2022/provoly-dashboard-toolbox.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-tooltips-attribute.mjs +2 -2
- package/fesm2022/provoly-dashboard-tooltips-attribute.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-chart.mjs +2 -2
- package/fesm2022/provoly-dashboard-widgets-widget-chart.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-map.mjs +57 -111
- package/fesm2022/provoly-dashboard-widgets-widget-map.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-tile.mjs +2 -2
- package/fesm2022/provoly-dashboard-widgets-widget-tile.mjs.map +1 -1
- package/fesm2022/provoly-dashboard.mjs +153 -135
- package/fesm2022/provoly-dashboard.mjs.map +1 -1
- package/lib/core/components/overlay/overlay.module.d.ts +2 -1
- package/lib/core/model/admin-api.model.d.ts +1 -1
- package/lib/core/model/dataset.interface.d.ts +0 -10
- package/lib/core/model/display-options.interface.d.ts +1 -0
- package/lib/core/model/manifest.interface.d.ts +2 -0
- package/lib/core/store/config/config.actions.d.ts +5 -0
- package/lib/core/store/config/config.effects.d.ts +6 -1
- package/lib/core/store/data-source/data-source.actions.d.ts +2 -2
- package/lib/core/store/data-source/data-source.effects.d.ts +2 -3
- package/lib/core/store/data-source/data-source.model.d.ts +11 -3
- package/lib/core/store/data-source/data-source.reducer.d.ts +2 -2
- package/lib/core/store/data-source/data-source.selectors.d.ts +5 -5
- package/lib/core/store/data-source/data-source.service.d.ts +4 -4
- package/lib/dashboard/components/context-menu/context-menu.component.d.ts +0 -1
- package/lib/dashboard/components/widgets/datasource-selector/datasource-selector.component.d.ts +1 -2
- package/lib/dashboard/components/widgets/settings/settings.component.d.ts +1 -0
- package/lib/dashboard/public-api.d.ts +1 -0
- package/lib/dashboard/store/dashboard.actions.d.ts +6 -17
- package/lib/dashboard/store/dashboard.effects.d.ts +6 -7
- package/lib/dashboard/store/dashboard.reducers.d.ts +1 -5
- package/lib/dashboard/store/dashboard.selectors.d.ts +0 -57
- package/lib/dashboard/store/manifest-utils.class.d.ts +4 -0
- package/lib/dashboard/store/manifest.service.d.ts +0 -1
- package/package.json +31 -31
- package/pipeline/components/pipeline-list/pipeline-list.component.d.ts +1 -2
- package/presentation/components/presentation.component.d.ts +0 -5
- package/presentation/presentation.module.d.ts +2 -1
- package/restitution/components/restitution-catalog/restitution-catalog.component.d.ts +4 -15
- package/schematics/ng-update/version-0-13/index.js +18 -1
- package/schematics/ng-update/version-0-13/index.js.map +1 -1
- package/schematics/ng-update/version-0-13/index.spec.js +8 -1
- package/schematics/ng-update/version-0-13/index.spec.js.map +1 -1
- package/search/components/save-query/save-query.component.d.ts +1 -2
- package/styles/components/_m-tooltip.scss +18 -2
- package/styles-theme/components-theme/_m-tooltip.theme.scss +0 -12
- package/toolbox/components/select-grid-layout/select-grid-layout.component.d.ts +0 -4
- package/toolbox/toolbox.module.d.ts +2 -1
- package/widgets/widget-map/component/widget-map.component.d.ts +8 -3
- package/widgets/widget-map/i18n/en.translations.d.ts +2 -0
- package/widgets/widget-map/i18n/fr.translations.d.ts +2 -0
- package/widgets/widget-map/interaction/interaction-manager.class.d.ts +3 -5
- package/esm2022/widgets/widget-map/search-bar/search-bar.control.mjs +0 -66
- package/widgets/widget-map/search-bar/search-bar.control.d.ts +0 -27
package/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.d.ts
CHANGED
|
@@ -2,7 +2,7 @@ import { OnDestroy, OnInit } from '@angular/core';
|
|
|
2
2
|
import { FormBuilder, FormGroup } from '@angular/forms';
|
|
3
3
|
import { ActivatedRoute, Router } from '@angular/router';
|
|
4
4
|
import { Store } from '@ngrx/store';
|
|
5
|
-
import { Associations, Dataset,
|
|
5
|
+
import { Associations, Dataset, IMetadata, MetadataValue, SubscriptionnerDirective } from '@provoly/dashboard';
|
|
6
6
|
import { Observable, Subscription } from 'rxjs';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export declare class AdminSelectDatasetComponent extends SubscriptionnerDirective implements OnInit, OnDestroy {
|
|
@@ -17,7 +17,7 @@ export declare class AdminSelectDatasetComponent extends SubscriptionnerDirectiv
|
|
|
17
17
|
sub: Subscription;
|
|
18
18
|
currentTypeTranslation: string;
|
|
19
19
|
tab: number;
|
|
20
|
-
datasetMetadata$: Observable<
|
|
20
|
+
datasetMetadata$: Observable<MetadataValue[]>;
|
|
21
21
|
metadata$: Observable<IMetadata[]>;
|
|
22
22
|
availableMetadata$?: Observable<IMetadata[]>;
|
|
23
23
|
form: FormGroup;
|
|
@@ -29,8 +29,8 @@ export declare class AdminSelectDatasetComponent extends SubscriptionnerDirectiv
|
|
|
29
29
|
closePanel(): void;
|
|
30
30
|
addDatasetMetadata(): void;
|
|
31
31
|
onMetaChange(metadata: IMetadata): void;
|
|
32
|
-
removeMetadata(metadata:
|
|
33
|
-
editMetadata(currentMetadata:
|
|
32
|
+
removeMetadata(metadata: MetadataValue): void;
|
|
33
|
+
editMetadata(currentMetadata: MetadataValue): void;
|
|
34
34
|
switch(number: number): void;
|
|
35
35
|
static ɵfac: i0.ɵɵFactoryDeclaration<AdminSelectDatasetComponent, never>;
|
|
36
36
|
static ɵcmp: i0.ɵɵComponentDeclaration<AdminSelectDatasetComponent, "pry-admin-select-dataset", never, {}, {}, never, never, false, never>;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { MetadataValue } from '@provoly/dashboard';
|
|
2
2
|
export declare const AdminDatasetActions: {
|
|
3
3
|
isEditable: import("@ngrx/store").ActionCreator<"[Admin/Datasource] Is editable", (props: {
|
|
4
4
|
editable: boolean;
|
|
@@ -11,9 +11,9 @@ export declare const AdminDatasetActions: {
|
|
|
11
11
|
datasetId: string;
|
|
12
12
|
} & import("@ngrx/store/src/models").TypedAction<"[Admin/Datasource] Load Metadata of selected Datasets">>;
|
|
13
13
|
loadDatasetMetadataSuccess: import("@ngrx/store").ActionCreator<"[Admin/Datasource] Load Metadata of selected Datasets Success", (props: {
|
|
14
|
-
metadata:
|
|
14
|
+
metadata: MetadataValue[];
|
|
15
15
|
}) => {
|
|
16
|
-
metadata:
|
|
16
|
+
metadata: MetadataValue[];
|
|
17
17
|
} & import("@ngrx/store/src/models").TypedAction<"[Admin/Datasource] Load Metadata of selected Datasets Success">>;
|
|
18
18
|
loadDatasetMetadataFailure: import("@ngrx/store").ActionCreator<"[Admin/Datasource] Load Metadata of selected Datasets Failure", (props: {
|
|
19
19
|
error: any;
|
|
@@ -111,11 +111,11 @@ export class AdminClassesCustomizeTooltipComponent extends SubscriptionnerDirect
|
|
|
111
111
|
this.currentClassConfig.options.attributes = $event;
|
|
112
112
|
}
|
|
113
113
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: AdminClassesCustomizeTooltipComponent, deps: [{ token: i1.TooltipFactoryService }, { token: i0.Injector }, { token: i1.PryI18nService }, { token: i2.Store }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
114
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: AdminClassesCustomizeTooltipComponent, selector: "pry-admin-classes-customize-tooltip", inputs: { currentClass: "currentClass" }, outputs: { backPressed: "backPressed" }, viewQueries: [{ propertyName: "example", first: true, predicate: ["example"], descendants: true, read: ViewContainerRef }], usesInheritance: true, ngImport: i0, template: "<div>\n <div class=\"m-form-label-field -width-xl\">\n <label class=\"a-label\" for=\"tooltip_type\">{{ '@pry.admin.customize.type' | i18n }}</label>\n <pry-select\n id=\"tooltip_type\"\n class=\"a-pry-select\"\n (ngModelChange)=\"tooltipTypeChanged($event)\"\n [ngModel]=\"currentClassConfig.type\"\n [items]=\"possibleTooltipTypes$ | async\"\n [itemsAsOption]=\"true\"\n bindValue=\"value\"\n bindLabel=\"label\"\n [labelTranslate]=\"true\"\n ></pry-select>\n </div>\n\n <div>\n <pry-checkbox [(ngModel)]=\"advancedTooltip\">{{ '@pry.admin.customize.advanced' | i18n }}</pry-checkbox>\n </div>\n\n <ng-container *ngIf=\"!advancedTooltip && currentClassConfig.type === 'attribute'\">\n <label class=\"a-label\" for=\"customize_simplified\">{{ '@pry.admin.customize.simplified' | i18n }}</label>\n <pry-select\n id=\"customize_simplified\"\n class=\"a-pry-select\"\n (ngModelChange)=\"changeAttributes($event)\"\n [ngModel]=\"currentClassConfig.options.attributes\"\n [itemsAsOption]=\"true\"\n [items]=\"possibleAttributes\"\n [multiple]=\"true\"\n bindLabel=\"name\"\n bindValue=\"name\"\n ></pry-select>\n </ng-container>\n\n <ng-container *ngIf=\"advancedTooltip\">\n <textarea\n cols=\"100\"\n rows=\"15\"\n class=\"a-form-field\"\n [(ngModel)]=\"strOptions\"\n (focusout)=\"optionsChanged()\"\n ></textarea>\n </ng-container>\n</div>\n\n<div class=\"m-tooltip m-tooltip--example\" [class.-hidden]=\"noTooltip\">\n <div #example></div>\n</div>\n\n<div class=\"m-btn-group -width-md\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--secondary\"\n (click)=\"goBack()\"\n [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n ></button>\n <button class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTemplate()\">\n {{ '@pry.admin.customize.update' | i18n }}\n </button>\n</div>\n", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.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: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.PryCheckboxComponent, selector: "pry-checkbox", inputs: ["circle"] }, { kind: "component", type: i1.PrySelectComponent, selector: "pry-select", inputs: ["labelTranslate", "baseTranslate", "translationFn", "translationFnArgs", "clearable", "multiple", "multipleClearRight", "closeOnSelect", "placeholder", "isForm", "required", "name", "readonly", "items", "itemsAsOption", "bindData", "bindValue", "bindLabel", "bindIcon", "iconSize", "templateLabel", "templateOption", "autocomplete"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.I18nPipe, name: "i18n" }] }); }
|
|
114
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: AdminClassesCustomizeTooltipComponent, selector: "pry-admin-classes-customize-tooltip", inputs: { currentClass: "currentClass" }, outputs: { backPressed: "backPressed" }, viewQueries: [{ propertyName: "example", first: true, predicate: ["example"], descendants: true, read: ViewContainerRef }], usesInheritance: true, ngImport: i0, template: "<div>\n <div class=\"m-form-label-field -width-xl\">\n <label class=\"a-label\" for=\"tooltip_type\">{{ '@pry.admin.customize.type' | i18n }}</label>\n <pry-select\n id=\"tooltip_type\"\n class=\"a-pry-select\"\n (ngModelChange)=\"tooltipTypeChanged($event)\"\n [ngModel]=\"currentClassConfig.type\"\n [items]=\"possibleTooltipTypes$ | async\"\n [itemsAsOption]=\"true\"\n bindValue=\"value\"\n bindLabel=\"label\"\n [labelTranslate]=\"true\"\n ></pry-select>\n </div>\n\n <div>\n <pry-checkbox [(ngModel)]=\"advancedTooltip\">{{ '@pry.admin.customize.advanced' | i18n }}</pry-checkbox>\n </div>\n\n <ng-container *ngIf=\"!advancedTooltip && currentClassConfig.type === 'attribute'\">\n <label class=\"a-label\" for=\"customize_simplified\">{{ '@pry.admin.customize.simplified' | i18n }}</label>\n <pry-select\n id=\"customize_simplified\"\n class=\"a-pry-select\"\n (ngModelChange)=\"changeAttributes($event)\"\n [ngModel]=\"currentClassConfig.options.attributes\"\n [itemsAsOption]=\"true\"\n [items]=\"possibleAttributes\"\n [multiple]=\"true\"\n [closeOnSelect]=\"false\"\n bindLabel=\"name\"\n bindValue=\"name\"\n ></pry-select>\n </ng-container>\n\n <ng-container *ngIf=\"advancedTooltip\">\n <textarea\n cols=\"100\"\n rows=\"15\"\n class=\"a-form-field\"\n [(ngModel)]=\"strOptions\"\n (focusout)=\"optionsChanged()\"\n ></textarea>\n </ng-container>\n</div>\n\n<div class=\"m-tooltip m-tooltip--example\" [class.-hidden]=\"noTooltip\">\n <div #example></div>\n</div>\n\n<div class=\"m-btn-group -width-md\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--secondary\"\n (click)=\"goBack()\"\n [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n ></button>\n <button class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTemplate()\">\n {{ '@pry.admin.customize.update' | i18n }}\n </button>\n</div>\n", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.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: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.PryCheckboxComponent, selector: "pry-checkbox", inputs: ["circle"] }, { kind: "component", type: i1.PrySelectComponent, selector: "pry-select", inputs: ["labelTranslate", "baseTranslate", "translationFn", "translationFnArgs", "clearable", "multiple", "multipleClearRight", "closeOnSelect", "placeholder", "isForm", "required", "name", "readonly", "items", "itemsAsOption", "bindData", "bindValue", "bindLabel", "bindIcon", "iconSize", "templateLabel", "templateOption", "autocomplete"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.I18nPipe, name: "i18n" }] }); }
|
|
115
115
|
}
|
|
116
116
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: AdminClassesCustomizeTooltipComponent, decorators: [{
|
|
117
117
|
type: Component,
|
|
118
|
-
args: [{ selector: 'pry-admin-classes-customize-tooltip', template: "<div>\n <div class=\"m-form-label-field -width-xl\">\n <label class=\"a-label\" for=\"tooltip_type\">{{ '@pry.admin.customize.type' | i18n }}</label>\n <pry-select\n id=\"tooltip_type\"\n class=\"a-pry-select\"\n (ngModelChange)=\"tooltipTypeChanged($event)\"\n [ngModel]=\"currentClassConfig.type\"\n [items]=\"possibleTooltipTypes$ | async\"\n [itemsAsOption]=\"true\"\n bindValue=\"value\"\n bindLabel=\"label\"\n [labelTranslate]=\"true\"\n ></pry-select>\n </div>\n\n <div>\n <pry-checkbox [(ngModel)]=\"advancedTooltip\">{{ '@pry.admin.customize.advanced' | i18n }}</pry-checkbox>\n </div>\n\n <ng-container *ngIf=\"!advancedTooltip && currentClassConfig.type === 'attribute'\">\n <label class=\"a-label\" for=\"customize_simplified\">{{ '@pry.admin.customize.simplified' | i18n }}</label>\n <pry-select\n id=\"customize_simplified\"\n class=\"a-pry-select\"\n (ngModelChange)=\"changeAttributes($event)\"\n [ngModel]=\"currentClassConfig.options.attributes\"\n [itemsAsOption]=\"true\"\n [items]=\"possibleAttributes\"\n [multiple]=\"true\"\n bindLabel=\"name\"\n bindValue=\"name\"\n ></pry-select>\n </ng-container>\n\n <ng-container *ngIf=\"advancedTooltip\">\n <textarea\n cols=\"100\"\n rows=\"15\"\n class=\"a-form-field\"\n [(ngModel)]=\"strOptions\"\n (focusout)=\"optionsChanged()\"\n ></textarea>\n </ng-container>\n</div>\n\n<div class=\"m-tooltip m-tooltip--example\" [class.-hidden]=\"noTooltip\">\n <div #example></div>\n</div>\n\n<div class=\"m-btn-group -width-md\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--secondary\"\n (click)=\"goBack()\"\n [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n ></button>\n <button class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTemplate()\">\n {{ '@pry.admin.customize.update' | i18n }}\n </button>\n</div>\n" }]
|
|
118
|
+
args: [{ selector: 'pry-admin-classes-customize-tooltip', template: "<div>\n <div class=\"m-form-label-field -width-xl\">\n <label class=\"a-label\" for=\"tooltip_type\">{{ '@pry.admin.customize.type' | i18n }}</label>\n <pry-select\n id=\"tooltip_type\"\n class=\"a-pry-select\"\n (ngModelChange)=\"tooltipTypeChanged($event)\"\n [ngModel]=\"currentClassConfig.type\"\n [items]=\"possibleTooltipTypes$ | async\"\n [itemsAsOption]=\"true\"\n bindValue=\"value\"\n bindLabel=\"label\"\n [labelTranslate]=\"true\"\n ></pry-select>\n </div>\n\n <div>\n <pry-checkbox [(ngModel)]=\"advancedTooltip\">{{ '@pry.admin.customize.advanced' | i18n }}</pry-checkbox>\n </div>\n\n <ng-container *ngIf=\"!advancedTooltip && currentClassConfig.type === 'attribute'\">\n <label class=\"a-label\" for=\"customize_simplified\">{{ '@pry.admin.customize.simplified' | i18n }}</label>\n <pry-select\n id=\"customize_simplified\"\n class=\"a-pry-select\"\n (ngModelChange)=\"changeAttributes($event)\"\n [ngModel]=\"currentClassConfig.options.attributes\"\n [itemsAsOption]=\"true\"\n [items]=\"possibleAttributes\"\n [multiple]=\"true\"\n [closeOnSelect]=\"false\"\n bindLabel=\"name\"\n bindValue=\"name\"\n ></pry-select>\n </ng-container>\n\n <ng-container *ngIf=\"advancedTooltip\">\n <textarea\n cols=\"100\"\n rows=\"15\"\n class=\"a-form-field\"\n [(ngModel)]=\"strOptions\"\n (focusout)=\"optionsChanged()\"\n ></textarea>\n </ng-container>\n</div>\n\n<div class=\"m-tooltip m-tooltip--example\" [class.-hidden]=\"noTooltip\">\n <div #example></div>\n</div>\n\n<div class=\"m-btn-group -width-md\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--secondary\"\n (click)=\"goBack()\"\n [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n ></button>\n <button class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTemplate()\">\n {{ '@pry.admin.customize.update' | i18n }}\n </button>\n</div>\n" }]
|
|
119
119
|
}], ctorParameters: function () { return [{ type: i1.TooltipFactoryService }, { type: i0.Injector }, { type: i1.PryI18nService }, { type: i2.Store }]; }, propDecorators: { example: [{
|
|
120
120
|
type: ViewChild,
|
|
121
121
|
args: ['example', { read: ViewContainerRef }]
|
|
@@ -124,4 +124,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
|
|
|
124
124
|
}], currentClass: [{
|
|
125
125
|
type: Input
|
|
126
126
|
}] } });
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-classes-customize-tooltip.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-customize/tooltip/admin-classes-customize-tooltip.component.ts","../../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-customize/tooltip/admin-classes-customize-tooltip.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ComponentRef,\n  EventEmitter,\n  Injector,\n  Input,\n  OnDestroy,\n  Output,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport {\n  Attribute,\n  AttributeSimpleValue,\n  BaseTooltipComponent,\n  Class,\n  ConfigActions,\n  ConfigSelectors,\n  Item,\n  PryI18nService,\n  SubscriptionnerDirective,\n  TooltipFactoryService,\n  TooltipOfClass\n} from '@provoly/dashboard';\nimport { map, Observable } from 'rxjs';\nimport { v4 } from 'uuid';\n\n@Component({\n  selector: 'pry-admin-classes-customize-tooltip',\n  templateUrl: './admin-classes-customize-tooltip.component.html'\n})\nexport class AdminClassesCustomizeTooltipComponent extends SubscriptionnerDirective implements OnDestroy {\n  @ViewChild('example', { read: ViewContainerRef }) example!: ViewContainerRef;\n  currentClassConfig: TooltipOfClass = { type: 'default' };\n  possibleTooltipTypes$: Observable<{ value: string; label: string }[]>;\n  advancedTooltip: boolean = false;\n  attributesForTooltip: string[] = [];\n  possibleAttributes: Attribute[] = [];\n  possibleNonAttributesFields = [\n    {\n      name: 'id',\n      field: ''\n    },\n    {\n      name: 'oClass',\n      field: ''\n    }\n  ] as Attribute[];\n  @Output() backPressed = new EventEmitter<void>();\n  private _currentClass: Class = {} as Class;\n  private fields: Attribute[] = [];\n  strOptions: string = '';\n  tmpComponent?: ComponentRef<BaseTooltipComponent>;\n  defs: { [p: string]: TooltipOfClass } = {};\n  noTooltip: boolean = false;\n\n  @Input() set currentClass(clazz: Class | null | undefined) {\n    this._currentClass = clazz ?? ({} as Class);\n    this.fields = (clazz ?? { attributes: [] }).attributes ?? [];\n    this.possibleAttributes = this.possibleNonAttributesFields\n      .concat(this.fields)\n      .sort((f1, f2) => f1.name.localeCompare(f2.name));\n    this.currentClassConfig = JSON.parse(JSON.stringify(this.defs[this.currentClass.id] ?? { type: 'default' }));\n  }\n\n  get currentClass(): Class {\n    return this._currentClass;\n  }\n\n  constructor(\n    private tooltipFactoryService: TooltipFactoryService,\n    private injector: Injector,\n    private translateService: PryI18nService,\n    private store: Store\n  ) {\n    super();\n    this.possibleTooltipTypes$ = this.tooltipFactoryService.types$.pipe(\n      map((types) =>\n        types.map((type) => ({\n          value: type,\n          label: this.translateService.instant('@pry.tooltip.' + type)\n        }))\n      )\n    );\n    this.subscriptions.add(\n      this.store.select(ConfigSelectors.tooltipDefinitions).subscribe((defs) => {\n        this.defs = defs;\n        this.currentClassConfig = JSON.parse(JSON.stringify(defs[this.currentClass.id] ?? { type: 'default' }));\n      })\n    );\n  }\n\n  tooltipTypeChanged($event: any) {\n    this.currentClassConfig.type = $event;\n    if (this.currentClassConfig.type === 'attribute') {\n      this.currentClassConfig.options = { attributes: this.possibleAttributes.map((attr) => attr.name) };\n    } else {\n      this.currentClassConfig.options = {};\n    }\n    this.strOptions = JSON.stringify(this.currentClassConfig.options);\n    this.updateExample();\n  }\n\n  optionsChanged() {\n    this.currentClassConfig.options = JSON.parse(this.strOptions);\n    if (this.tmpComponent) {\n      this.tmpComponent.instance.context = this.currentClassConfig.options;\n    }\n    this.updateExample();\n  }\n\n  updateExample() {\n    this.example?.clear();\n    const component$ = this.tooltipFactoryService.generateTooltip(\n      this.currentClassConfig.type,\n      this.injector,\n      this.example\n    );\n    component$.subscribe((component) => {\n      this.noTooltip = !component;\n      if (component) {\n        component.instance.data.item = this.fields\n          .map((attr) => ({\n            [attr.name]: {\n              type: 'VALUE',\n              value: '«' + this.translateService.instant('@pry.admin.customize.exemple', { expr: attr.name }) + '»',\n              visible: true\n            } as AttributeSimpleValue\n          }))\n          .reduce((p, c) => ({ ...p, attributes: { ...p.attributes, ...c } }), {\n            oClass: this.currentClass.id,\n            id: v4(),\n            label: '«' + this.translateService.instant('@pry.admin.customize.exemple', { expr: 'label' }) + '»',\n            attributes: {} as { [key: string]: AttributeSimpleValue }\n          } as Item);\n\n        this.tmpComponent = component;\n\n        component.instance.context = this.currentClassConfig.options;\n      }\n    });\n  }\n\n  updateTemplate() {\n    this.store.dispatch(\n      ConfigActions.saveTooltip({\n        definitions: { [this.currentClass.id]: this.currentClassConfig }\n      })\n    );\n    this.goBack();\n  }\n\n  goBack() {\n    this.backPressed.emit();\n  }\n\n  changeAttributes($event: any) {\n    this.currentClassConfig.options.attributes = $event;\n  }\n}\n","<div>\n  <div class=\"m-form-label-field -width-xl\">\n    <label class=\"a-label\" for=\"tooltip_type\">{{ '@pry.admin.customize.type' | i18n }}</label>\n    <pry-select\n      id=\"tooltip_type\"\n      class=\"a-pry-select\"\n      (ngModelChange)=\"tooltipTypeChanged($event)\"\n      [ngModel]=\"currentClassConfig.type\"\n      [items]=\"possibleTooltipTypes$ | async\"\n      [itemsAsOption]=\"true\"\n      bindValue=\"value\"\n      bindLabel=\"label\"\n      [labelTranslate]=\"true\"\n    ></pry-select>\n  </div>\n\n  <div>\n    <pry-checkbox [(ngModel)]=\"advancedTooltip\">{{ '@pry.admin.customize.advanced' | i18n }}</pry-checkbox>\n  </div>\n\n  <ng-container *ngIf=\"!advancedTooltip && currentClassConfig.type === 'attribute'\">\n    <label class=\"a-label\" for=\"customize_simplified\">{{ '@pry.admin.customize.simplified' | i18n }}</label>\n    <pry-select\n      id=\"customize_simplified\"\n      class=\"a-pry-select\"\n      (ngModelChange)=\"changeAttributes($event)\"\n      [ngModel]=\"currentClassConfig.options.attributes\"\n      [itemsAsOption]=\"true\"\n      [items]=\"possibleAttributes\"\n      [multiple]=\"true\"\n      bindLabel=\"name\"\n      bindValue=\"name\"\n    ></pry-select>\n  </ng-container>\n\n  <ng-container *ngIf=\"advancedTooltip\">\n    <textarea\n      cols=\"100\"\n      rows=\"15\"\n      class=\"a-form-field\"\n      [(ngModel)]=\"strOptions\"\n      (focusout)=\"optionsChanged()\"\n    ></textarea>\n  </ng-container>\n</div>\n\n<div class=\"m-tooltip m-tooltip--example\" [class.-hidden]=\"noTooltip\">\n  <div #example></div>\n</div>\n\n<div class=\"m-btn-group -width-md\">\n  <button\n    type=\"button\"\n    class=\"a-btn a-btn--secondary\"\n    (click)=\"goBack()\"\n    [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n  ></button>\n  <button class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTemplate()\">\n    {{ '@pry.admin.customize.update' | i18n }}\n  </button>\n</div>\n"]}
|
|
127
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-classes-customize-tooltip.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-customize/tooltip/admin-classes-customize-tooltip.component.ts","../../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-customize/tooltip/admin-classes-customize-tooltip.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ComponentRef,\n  EventEmitter,\n  Injector,\n  Input,\n  OnDestroy,\n  Output,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport {\n  Attribute,\n  AttributeSimpleValue,\n  BaseTooltipComponent,\n  Class,\n  ConfigActions,\n  ConfigSelectors,\n  Item,\n  PryI18nService,\n  SubscriptionnerDirective,\n  TooltipFactoryService,\n  TooltipOfClass\n} from '@provoly/dashboard';\nimport { map, Observable } from 'rxjs';\nimport { v4 } from 'uuid';\n\n@Component({\n  selector: 'pry-admin-classes-customize-tooltip',\n  templateUrl: './admin-classes-customize-tooltip.component.html'\n})\nexport class AdminClassesCustomizeTooltipComponent extends SubscriptionnerDirective implements OnDestroy {\n  @ViewChild('example', { read: ViewContainerRef }) example!: ViewContainerRef;\n  currentClassConfig: TooltipOfClass = { type: 'default' };\n  possibleTooltipTypes$: Observable<{ value: string; label: string }[]>;\n  advancedTooltip: boolean = false;\n  attributesForTooltip: string[] = [];\n  possibleAttributes: Attribute[] = [];\n  possibleNonAttributesFields = [\n    {\n      name: 'id',\n      field: ''\n    },\n    {\n      name: 'oClass',\n      field: ''\n    }\n  ] as Attribute[];\n  @Output() backPressed = new EventEmitter<void>();\n  private _currentClass: Class = {} as Class;\n  private fields: Attribute[] = [];\n  strOptions: string = '';\n  tmpComponent?: ComponentRef<BaseTooltipComponent>;\n  defs: { [p: string]: TooltipOfClass } = {};\n  noTooltip: boolean = false;\n\n  @Input() set currentClass(clazz: Class | null | undefined) {\n    this._currentClass = clazz ?? ({} as Class);\n    this.fields = (clazz ?? { attributes: [] }).attributes ?? [];\n    this.possibleAttributes = this.possibleNonAttributesFields\n      .concat(this.fields)\n      .sort((f1, f2) => f1.name.localeCompare(f2.name));\n    this.currentClassConfig = JSON.parse(JSON.stringify(this.defs[this.currentClass.id] ?? { type: 'default' }));\n  }\n\n  get currentClass(): Class {\n    return this._currentClass;\n  }\n\n  constructor(\n    private tooltipFactoryService: TooltipFactoryService,\n    private injector: Injector,\n    private translateService: PryI18nService,\n    private store: Store\n  ) {\n    super();\n    this.possibleTooltipTypes$ = this.tooltipFactoryService.types$.pipe(\n      map((types) =>\n        types.map((type) => ({\n          value: type,\n          label: this.translateService.instant('@pry.tooltip.' + type)\n        }))\n      )\n    );\n    this.subscriptions.add(\n      this.store.select(ConfigSelectors.tooltipDefinitions).subscribe((defs) => {\n        this.defs = defs;\n        this.currentClassConfig = JSON.parse(JSON.stringify(defs[this.currentClass.id] ?? { type: 'default' }));\n      })\n    );\n  }\n\n  tooltipTypeChanged($event: any) {\n    this.currentClassConfig.type = $event;\n    if (this.currentClassConfig.type === 'attribute') {\n      this.currentClassConfig.options = { attributes: this.possibleAttributes.map((attr) => attr.name) };\n    } else {\n      this.currentClassConfig.options = {};\n    }\n    this.strOptions = JSON.stringify(this.currentClassConfig.options);\n    this.updateExample();\n  }\n\n  optionsChanged() {\n    this.currentClassConfig.options = JSON.parse(this.strOptions);\n    if (this.tmpComponent) {\n      this.tmpComponent.instance.context = this.currentClassConfig.options;\n    }\n    this.updateExample();\n  }\n\n  updateExample() {\n    this.example?.clear();\n    const component$ = this.tooltipFactoryService.generateTooltip(\n      this.currentClassConfig.type,\n      this.injector,\n      this.example\n    );\n    component$.subscribe((component) => {\n      this.noTooltip = !component;\n      if (component) {\n        component.instance.data.item = this.fields\n          .map((attr) => ({\n            [attr.name]: {\n              type: 'VALUE',\n              value: '«' + this.translateService.instant('@pry.admin.customize.exemple', { expr: attr.name }) + '»',\n              visible: true\n            } as AttributeSimpleValue\n          }))\n          .reduce((p, c) => ({ ...p, attributes: { ...p.attributes, ...c } }), {\n            oClass: this.currentClass.id,\n            id: v4(),\n            label: '«' + this.translateService.instant('@pry.admin.customize.exemple', { expr: 'label' }) + '»',\n            attributes: {} as { [key: string]: AttributeSimpleValue }\n          } as Item);\n\n        this.tmpComponent = component;\n\n        component.instance.context = this.currentClassConfig.options;\n      }\n    });\n  }\n\n  updateTemplate() {\n    this.store.dispatch(\n      ConfigActions.saveTooltip({\n        definitions: { [this.currentClass.id]: this.currentClassConfig }\n      })\n    );\n    this.goBack();\n  }\n\n  goBack() {\n    this.backPressed.emit();\n  }\n\n  changeAttributes($event: any) {\n    this.currentClassConfig.options.attributes = $event;\n  }\n}\n","<div>\n  <div class=\"m-form-label-field -width-xl\">\n    <label class=\"a-label\" for=\"tooltip_type\">{{ '@pry.admin.customize.type' | i18n }}</label>\n    <pry-select\n      id=\"tooltip_type\"\n      class=\"a-pry-select\"\n      (ngModelChange)=\"tooltipTypeChanged($event)\"\n      [ngModel]=\"currentClassConfig.type\"\n      [items]=\"possibleTooltipTypes$ | async\"\n      [itemsAsOption]=\"true\"\n      bindValue=\"value\"\n      bindLabel=\"label\"\n      [labelTranslate]=\"true\"\n    ></pry-select>\n  </div>\n\n  <div>\n    <pry-checkbox [(ngModel)]=\"advancedTooltip\">{{ '@pry.admin.customize.advanced' | i18n }}</pry-checkbox>\n  </div>\n\n  <ng-container *ngIf=\"!advancedTooltip && currentClassConfig.type === 'attribute'\">\n    <label class=\"a-label\" for=\"customize_simplified\">{{ '@pry.admin.customize.simplified' | i18n }}</label>\n    <pry-select\n      id=\"customize_simplified\"\n      class=\"a-pry-select\"\n      (ngModelChange)=\"changeAttributes($event)\"\n      [ngModel]=\"currentClassConfig.options.attributes\"\n      [itemsAsOption]=\"true\"\n      [items]=\"possibleAttributes\"\n      [multiple]=\"true\"\n      [closeOnSelect]=\"false\"\n      bindLabel=\"name\"\n      bindValue=\"name\"\n    ></pry-select>\n  </ng-container>\n\n  <ng-container *ngIf=\"advancedTooltip\">\n    <textarea\n      cols=\"100\"\n      rows=\"15\"\n      class=\"a-form-field\"\n      [(ngModel)]=\"strOptions\"\n      (focusout)=\"optionsChanged()\"\n    ></textarea>\n  </ng-container>\n</div>\n\n<div class=\"m-tooltip m-tooltip--example\" [class.-hidden]=\"noTooltip\">\n  <div #example></div>\n</div>\n\n<div class=\"m-btn-group -width-md\">\n  <button\n    type=\"button\"\n    class=\"a-btn a-btn--secondary\"\n    (click)=\"goBack()\"\n    [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n  ></button>\n  <button class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTemplate()\">\n    {{ '@pry.admin.customize.update' | i18n }}\n  </button>\n</div>\n"]}
|
|
@@ -3,11 +3,11 @@ import { Validators } from '@angular/forms';
|
|
|
3
3
|
import { DataSourceActions, DataSourceSelectors, SubscriptionnerDirective } from '@provoly/dashboard';
|
|
4
4
|
import { combineLatest, map, Subscription } from 'rxjs';
|
|
5
5
|
import { AdminActions } from '../../../store/admin.actions';
|
|
6
|
+
import { AdminSelectors } from '../../../store/admin.selectors';
|
|
6
7
|
import { MetadataActions } from '../../admin-metadata/store/metadata.action';
|
|
7
8
|
import { MetadataSelectors } from '../../admin-metadata/store/metadata.selector';
|
|
8
9
|
import { AdminDatasetActions } from '../store/admin-dataset.actions';
|
|
9
10
|
import { AdminDatasetSelectors } from '../store/admin-dataset.selector';
|
|
10
|
-
import { AdminSelectors } from '../../../store/admin.selectors';
|
|
11
11
|
import * as i0 from "@angular/core";
|
|
12
12
|
import * as i1 from "@ngrx/store";
|
|
13
13
|
import * as i2 from "@angular/router";
|
|
@@ -155,4 +155,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
|
|
|
155
155
|
type: Component,
|
|
156
156
|
args: [{ selector: 'pry-admin-select-dataset', template: "<div\n *ngIf=\"selectedDataset$ | async as dataset\"\n [id]=\"'panel-dataset-' + dataset.id\"\n [attr.aria-labelledby]=\"'button-dataset-' + dataset.id\"\n class=\"o-panel\"\n>\n <div>\n <div class=\"o-panel__header\">\n <button type=\"button\" class=\"a-btn a-btn--icon-only\" (click)=\"closePanel()\">\n <span class=\"u-visually-hidden\">{{ '@pry.action.closePanel' | i18n }}</span>\n <pry-icon iconSvg=\"close\"></pry-icon>\n </button>\n\n <h3 [id]=\"'tab-title-' + compId\" class=\"a-h3\">\n {{ '@pry.admin.metadata.details' | i18n }}\n </h3>\n </div>\n\n <div class=\"o-tabs\">\n <div class=\"o-tabs__list\" role=\"tablist\" [attr.aria-labelledby]=\"'tab-title-' + compId\">\n <button\n type=\"button\"\n class=\"o-tabs__list__btn\"\n role=\"tab\"\n [id]=\"'tab-' + compId + '-0'\"\n [attr.aria-selected]=\"tab === 0\"\n [attr.tabindex]=\"tab === 0 ? 0 : -1\"\n [attr.aria-controls]=\"'tabpanel-' + compId + '-0'\"\n (click)=\"switch(0)\"\n >\n {{ '@pry.admin.metadata.title' | i18n }}\n </button>\n <button\n type=\"button\"\n class=\"o-tabs__list__btn\"\n role=\"tab\"\n [id]=\"'tab-' + compId + '-1'\"\n [attr.aria-selected]=\"tab === 1\"\n [attr.tabindex]=\"tab === 1 ? 1 : -1\"\n [attr.aria-controls]=\"'tabpanel-' + compId + '-1'\"\n (click)=\"switch(1)\"\n >\n {{ '@pry.admin.classes.associations' | i18n }}\n </button>\n </div>\n\n <div class=\"o-tabs__panels\">\n <div\n class=\"o-tabs__panels__item\"\n [class.is-hidden]=\"tab !== 0\"\n [id]=\"'tabpanel-' + compId + '-0'\"\n role=\"tabpanel\"\n [attr.aria-labelledby]=\"'tab-' + compId + '-0'\"\n tabindex=\"0\"\n >\n <div class=\"o-tabs__panels__item__content o-tabs__panels__item__content--profil\">\n <div *ngFor=\"let metadata of datasetMetadata$ | async\">\n <div class=\"o-tabs__panels__item__content\">\n <div class=\"o-tabs__panels__item__content__actions\">\n <div class=\"o-tabs__panels__item__content__actions__text\">\n <span class=\"o-tabs__panels__item__content__actions__text__label\"\n >{{ metadata.metadataDef.name }} :</span\n >\n <span class=\"o-tabs__panels__item__content__actions__text__value\">{{ metadata.value }}</span>\n </div>\n\n <div class=\"o-tabs__panels__item__content__actions__buttons\">\n <ng-container *pryAccess=\"{ module: 'admin', page: 'dataset', action: 'write' }\">\n <button type=\"button\" class=\"a-btn a-btn--icon-only\" aria-pressed=\"false\">\n <span class=\"u-visually-hidden\"\n >{{ '@pry.action.edit' | i18n }} {{ metadata.metadataDef.name }}</span\n >\n <pry-icon\n class=\"edit-icon\"\n iconSvg=\"edit\"\n [width]=\"15\"\n [height]=\"15\"\n (click)=\"editMetadata(metadata)\"\n ></pry-icon>\n </button>\n <button type=\"button\" class=\"a-btn a-btn--icon-only\" aria-pressed=\"false\">\n <span class=\"u-visually-hidden\"\n >{{ '@pry.action.delete' | i18n }} {{ metadata.metadataDef.name }}</span\n >\n <pry-icon\n class=\"delete-icon\"\n iconSvg=\"delete\"\n [width]=\"15\"\n [height]=\"15\"\n (click)=\"removeMetadata(metadata)\"\n ></pry-icon>\n </button>\n </ng-container>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <ng-container *pryAccess=\"{ module: 'admin', page: 'dataset', action: 'write' }\">\n <ng-container *ngIf=\"form.value.metadata\">\n <form class=\"o-form -border-top\" [formGroup]=\"form\" (ngSubmit)=\"addDatasetMetadata()\">\n <fieldset>\n <legend class=\"u-visually-hidden\">{{ '@pry.action.editProfil' | i18n }}</legend>\n\n <div class=\"m-form-label-field\">\n <label for=\"metadata\" id=\"metadata-label\" class=\"a-label\">Data</label>\n <pry-select\n id=\"metadata\"\n class=\"a-pry-select\"\n formControlName=\"metadata\"\n [items]=\"availableMetadata$ | async\"\n (ngModelChange)=\"onMetaChange($event)\"\n [isForm]=\"true\"\n [itemsAsOption]=\"true\"\n bindLabel=\"name\"\n [readonly]=\"(editable$ | async) ?? false\"\n [attr.aria-labelledby]=\"\n isSubmitted && form.get('metadata')?.invalid\n ? 'metadata-label metadata-error'\n : 'metadata-label'\n \"\n [attr.aria-invalid]=\"isSubmitted && form.get('metadata')?.invalid\"\n >\n </pry-select>\n <label\n *ngIf=\"isSubmitted && form.get('metadata')?.invalid\"\n id=\"metadata-error\"\n for=\"metadata\"\n class=\"a-label a-label--help -error\"\n >\n {{ '@pry.admin.required' | i18n }}\n </label>\n </div>\n\n <ng-container *ngIf=\"form.value['metadata']['type'] === 'DATE'; else inputList\">\n <div class=\"m-form-label-field\">\n <label id=\"form_date-label\" for=\"form_date\" class=\"a-label\">\n {{ '@pry.action.selectDate' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <input\n id=\"form_date\"\n type=\"date\"\n class=\"a-form-field\"\n formControlName=\"value\"\n [attr.aria-labelledby]=\"\n isSubmitted && form.get('value')?.invalid\n ? 'form-date-label form-date-error'\n : 'form-date-label'\n \"\n [attr.aria-invalid]=\"isSubmitted && form.get('value')?.invalid\"\n required\n />\n <label\n *ngIf=\"isSubmitted && form.get('value')?.invalid\"\n id=\"form_date-error\"\n for=\"form_date\"\n class=\"a-label a-label--help -error\"\n >\n {{ '@pry.admin.required' | i18n }}\n </label>\n </div>\n </ng-container>\n\n <ng-template #inputList>\n <ng-container *ngIf=\"form.value['metadata']['type'] === 'LIST'; else inputText\">\n <div class=\"m-form-label-field\">\n <label id=\"list-label\" class=\"a-label\" for=\"list\">{{\n '@pry.action.choiceInList' | i18n\n }}</label>\n <pry-select\n id=\"list\"\n class=\"a-pry-select\"\n formControlName=\"value\"\n [items]=\"form.value['metadata']['allowedValues']\"\n [isForm]=\"true\"\n aria-labelledby=\"list-label\"\n ></pry-select>\n </div>\n </ng-container>\n </ng-template>\n\n <ng-template #inputText>\n <div class=\"m-form-label-field\">\n <label id=\"text-label\" class=\"a-label\" for=\"text\">\n {{ '@pry.action.text' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <input\n id=\"text\"\n type=\"text\"\n class=\"a-form-field\"\n formControlName=\"value\"\n [attr.aria-labelledby]=\"\n isSubmitted && form.get('value')?.invalid ? 'text-label text-error' : 'text-label'\n \"\n [attr.aria-invalid]=\"isSubmitted && form.get('value')?.invalid\"\n required\n />\n <label\n *ngIf=\"isSubmitted && form.get('value')?.invalid\"\n id=\"test-error\"\n for=\"text\"\n class=\"a-label a-label--help -error\"\n >\n <span *ngIf=\"form.get('value')?.hasError('required')\">{{ '@pry.admin.required' | i18n }}</span>\n <ng-container *ngIf=\"form.get('value')?.hasError('pattern')\">\n <span *ngIf=\"form.value['metadata']['type'] === 'DOUBLE'\">\n {{ '@pry.admin.environment.formatDouble' | i18n }}\n </span>\n <span *ngIf=\"form.value['metadata']['type'] === 'INTEGER'\">\n {{ '@pry.admin.environment.formatInt' | i18n }}\n </span>\n </ng-container>\n </label>\n </div>\n </ng-template>\n </fieldset>\n\n <div class=\"m-btn-group -end\">\n <button\n type=\"submit\"\n class=\"a-btn a-btn--primary\"\n [innerHTML]=\"\n ((editable$ | async) ? '@pry.admin.userInfo.editMetadata' : '@pry.admin.userInfo.addMetadata')\n | i18n\n \"\n ></button>\n </div>\n </form>\n </ng-container>\n </ng-container>\n </div>\n <div\n class=\"o-tabs__panels__item\"\n [class.is-hidden]=\"tab !== 1\"\n [id]=\"'tabpanel-' + compId + '-1'\"\n role=\"tabpanel\"\n [attr.aria-labelledby]=\"'tab-' + compId + '-1'\"\n tabindex=\"1\"\n >\n <div *ngIf=\"associations$ | async as associations\" class=\"o-tabs__panels__item__content\">\n <h4 class=\"a-h4\">{{ '@pry.admin.classes.associations' | i18n }}</h4>\n <pry-association [associations]=\"associations\"></pry-association>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n" }]
|
|
157
157
|
}], ctorParameters: function () { return [{ type: i1.Store }, { type: i2.Router }, { type: i2.ActivatedRoute }, { type: i3.FormBuilder }]; } });
|
|
158
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-select-dataset.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/dashboard/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.ts","../../../../../../../../projects/provoly/dashboard/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, OnInit } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  Associations,\n  Dataset,\n  DatasetMetadata,\n  DataSourceActions,\n  DataSourceSelectors,\n  IMetadata,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { combineLatest, map, Observable, Subscription } from 'rxjs';\nimport { AdminActions } from '../../../store/admin.actions';\nimport { MetadataActions } from '../../admin-metadata/store/metadata.action';\nimport { MetadataSelectors } from '../../admin-metadata/store/metadata.selector';\nimport { AdminDatasetActions } from '../store/admin-dataset.actions';\nimport { AdminDatasetSelectors } from '../store/admin-dataset.selector';\nimport { AdminSelectors } from '../../../store/admin.selectors';\n\nlet nextCompId = 0;\n\n@Component({\n  selector: 'pry-admin-select-dataset',\n  templateUrl: './admin-select-dataset.component.html'\n})\nexport class AdminSelectDatasetComponent extends SubscriptionnerDirective implements OnInit, OnDestroy {\n  static id = 'AdminSelectDatasetComponent';\n  compId: number;\n  selectedDataset$: Observable<Dataset | null>;\n  associations$: Observable<Associations | undefined>;\n  sub = new Subscription();\n  currentTypeTranslation = '';\n  tab: number = 0;\n  datasetMetadata$: Observable<DatasetMetadata[]>;\n  metadata$: Observable<IMetadata[]>;\n  availableMetadata$?: Observable<IMetadata[]>;\n  form: FormGroup;\n  isSubmitted = false;\n  editable$: Observable<boolean>;\n  datasetId = '';\n\n  constructor(\n    private store: Store<any>,\n    private router: Router,\n    private route: ActivatedRoute,\n    private formBuilder: FormBuilder\n  ) {\n    super();\n    this.store.dispatch(MetadataActions.loadMetadata());\n    this.selectedDataset$ = this.store.select(DataSourceSelectors.selectedDataset);\n    this.datasetMetadata$ = this.store.select(DataSourceSelectors.selectedDatasetMetadata);\n    this.associations$ = this.store.select(AdminSelectors.selectedAssociation);\n    this.metadata$ = this.store.select(MetadataSelectors.metadata);\n    this.editable$ = this.store.select(AdminDatasetSelectors.editable);\n    this.compId = nextCompId++;\n\n    this.form = this.formBuilder.group({\n      metadata: [{}, [Validators.required]],\n      value: ['', [Validators.required, Validators.pattern('^[+-]?[0-9]*$')]]\n    });\n  }\n\n  ngOnInit(): void {\n    this.subscriptions.add(\n      this.selectedDataset$.subscribe((dataset) => {\n        if (dataset) {\n          this.datasetId = dataset.id;\n          const editPath = this.router.createUrlTree(['.', 'dataset', 'edit', dataset.id], {\n            relativeTo: this.route\n          });\n          this.store.dispatch(\n            AdminActions.mainActions({\n              actions: [\n                {\n                  action: AdminActions.routeTo({ path: editPath.toString() }),\n                  label: 'edit',\n                  icon: 'edit',\n                  moduleAccess: 'admin',\n                  pageAccess: 'dataset',\n                  actionAccess: 'write'\n                },\n                {\n                  action: DataSourceActions.dataset.confirmDataSourceDeletion({\n                    name: dataset.id,\n                    route: this.router.createUrlTree(['.', 'dataset'], { relativeTo: this.route }).toString(),\n                    addRoute: this.router.createUrlTree(['.', 'dataset', 'new'], { relativeTo: this.route }).toString()\n                  }),\n                  label: 'delete',\n                  icon: 'delete',\n                  moduleAccess: 'admin',\n                  pageAccess: 'dataset',\n                  actionAccess: 'write'\n                }\n              ]\n            })\n          );\n        }\n      })\n    );\n    this.subscriptions.add(\n      this.selectedDataset$.subscribe((dataset) => {\n        if (dataset) {\n          this.availableMetadata$?.subscribe((meta) => {\n            this.form.patchValue({\n              metadata: meta[0]\n            });\n            this.onMetaChange(meta[0]);\n            this.form.patchValue({ value: '' });\n          });\n        }\n      })\n    );\n    this.availableMetadata$ = combineLatest([this.datasetMetadata$, this.metadata$]).pipe(\n      map(([datasetMetadata, metaDefs]) => {\n        let datasetMetadataIds = datasetMetadata?.map((u) => u.metadataDef.id);\n        return metaDefs.filter((meta) => !datasetMetadataIds?.includes(meta.id));\n      })\n    );\n  }\n\n  closePanel() {\n    const path = this.router.createUrlTree(['.', 'dataset', 'new'], { relativeTo: this.route });\n    this.store.dispatch(DataSourceActions.dataset.unselectDataset());\n    this.store.dispatch(AdminActions.togglePanel({ panelOpen: false }));\n    this.store.dispatch(\n      AdminActions.mainActions({\n        actions: [\n          {\n            action: AdminActions.routeTo({ path: path.toString() }),\n            label: 'add',\n            icon: 'add_column',\n            moduleAccess: 'admin',\n            pageAccess: 'metadata_rules',\n            actionAccess: 'write'\n          }\n        ]\n      })\n    );\n  }\n\n  addDatasetMetadata() {\n    this.isSubmitted = true;\n    if (this.form.valid) {\n      this.isSubmitted = false;\n      let payload = {\n        datasetId: this.datasetId,\n        metadataId: this.form.value['metadata']['id'],\n        value: this.form.value['value']\n      };\n      this.store.dispatch(AdminDatasetActions.addDatasetMetadata(payload));\n    }\n  }\n\n  onMetaChange(metadata: IMetadata) {\n    if (metadata) {\n      if (metadata.type === 'INTEGER') {\n        this.form.controls['value'].setValidators([Validators.required, Validators.pattern('^[+-]?[0-9]*$')]);\n      } else if (metadata.type === 'DOUBLE') {\n        this.form.controls['value'].setValidators([Validators.required, Validators.pattern('[+-]?([0-9]*[.])?[0-9]+')]);\n      } else {\n        this.form.controls['value'].setValidators([Validators.required]);\n      }\n    }\n  }\n\n  removeMetadata(metadata: DatasetMetadata) {\n    this.store.dispatch(\n      AdminDatasetActions.deleteDatasetMetadata({ datasetId: this.datasetId, metadataId: metadata.metadataDef.id })\n    );\n  }\n\n  editMetadata(currentMetadata: DatasetMetadata) {\n    this.store.dispatch(AdminDatasetActions.isEditable({ editable: true }));\n    let value = currentMetadata.value;\n    let datasetMetadataDef = currentMetadata.metadataDef;\n\n    this.form.patchValue({\n      metadata: datasetMetadataDef,\n      value: value\n    });\n    this.onMetaChange(datasetMetadataDef);\n  }\n\n  switch(number: number) {\n    this.tab = number;\n  }\n}\n","<div\n  *ngIf=\"selectedDataset$ | async as dataset\"\n  [id]=\"'panel-dataset-' + dataset.id\"\n  [attr.aria-labelledby]=\"'button-dataset-' + dataset.id\"\n  class=\"o-panel\"\n>\n  <div>\n    <div class=\"o-panel__header\">\n      <button type=\"button\" class=\"a-btn a-btn--icon-only\" (click)=\"closePanel()\">\n        <span class=\"u-visually-hidden\">{{ '@pry.action.closePanel' | i18n }}</span>\n        <pry-icon iconSvg=\"close\"></pry-icon>\n      </button>\n\n      <h3 [id]=\"'tab-title-' + compId\" class=\"a-h3\">\n        {{ '@pry.admin.metadata.details' | i18n }}\n      </h3>\n    </div>\n\n    <div class=\"o-tabs\">\n      <div class=\"o-tabs__list\" role=\"tablist\" [attr.aria-labelledby]=\"'tab-title-' + compId\">\n        <button\n          type=\"button\"\n          class=\"o-tabs__list__btn\"\n          role=\"tab\"\n          [id]=\"'tab-' + compId + '-0'\"\n          [attr.aria-selected]=\"tab === 0\"\n          [attr.tabindex]=\"tab === 0 ? 0 : -1\"\n          [attr.aria-controls]=\"'tabpanel-' + compId + '-0'\"\n          (click)=\"switch(0)\"\n        >\n          {{ '@pry.admin.metadata.title' | i18n }}\n        </button>\n        <button\n          type=\"button\"\n          class=\"o-tabs__list__btn\"\n          role=\"tab\"\n          [id]=\"'tab-' + compId + '-1'\"\n          [attr.aria-selected]=\"tab === 1\"\n          [attr.tabindex]=\"tab === 1 ? 1 : -1\"\n          [attr.aria-controls]=\"'tabpanel-' + compId + '-1'\"\n          (click)=\"switch(1)\"\n        >\n          {{ '@pry.admin.classes.associations' | i18n }}\n        </button>\n      </div>\n\n      <div class=\"o-tabs__panels\">\n        <div\n          class=\"o-tabs__panels__item\"\n          [class.is-hidden]=\"tab !== 0\"\n          [id]=\"'tabpanel-' + compId + '-0'\"\n          role=\"tabpanel\"\n          [attr.aria-labelledby]=\"'tab-' + compId + '-0'\"\n          tabindex=\"0\"\n        >\n          <div class=\"o-tabs__panels__item__content o-tabs__panels__item__content--profil\">\n            <div *ngFor=\"let metadata of datasetMetadata$ | async\">\n              <div class=\"o-tabs__panels__item__content\">\n                <div class=\"o-tabs__panels__item__content__actions\">\n                  <div class=\"o-tabs__panels__item__content__actions__text\">\n                    <span class=\"o-tabs__panels__item__content__actions__text__label\"\n                      >{{ metadata.metadataDef.name }} :</span\n                    >\n                    <span class=\"o-tabs__panels__item__content__actions__text__value\">{{ metadata.value }}</span>\n                  </div>\n\n                  <div class=\"o-tabs__panels__item__content__actions__buttons\">\n                    <ng-container *pryAccess=\"{ module: 'admin', page: 'dataset', action: 'write' }\">\n                      <button type=\"button\" class=\"a-btn a-btn--icon-only\" aria-pressed=\"false\">\n                        <span class=\"u-visually-hidden\"\n                          >{{ '@pry.action.edit' | i18n }} {{ metadata.metadataDef.name }}</span\n                        >\n                        <pry-icon\n                          class=\"edit-icon\"\n                          iconSvg=\"edit\"\n                          [width]=\"15\"\n                          [height]=\"15\"\n                          (click)=\"editMetadata(metadata)\"\n                        ></pry-icon>\n                      </button>\n                      <button type=\"button\" class=\"a-btn a-btn--icon-only\" aria-pressed=\"false\">\n                        <span class=\"u-visually-hidden\"\n                          >{{ '@pry.action.delete' | i18n }} {{ metadata.metadataDef.name }}</span\n                        >\n                        <pry-icon\n                          class=\"delete-icon\"\n                          iconSvg=\"delete\"\n                          [width]=\"15\"\n                          [height]=\"15\"\n                          (click)=\"removeMetadata(metadata)\"\n                        ></pry-icon>\n                      </button>\n                    </ng-container>\n                  </div>\n                </div>\n              </div>\n            </div>\n          </div>\n\n          <ng-container *pryAccess=\"{ module: 'admin', page: 'dataset', action: 'write' }\">\n            <ng-container *ngIf=\"form.value.metadata\">\n              <form class=\"o-form -border-top\" [formGroup]=\"form\" (ngSubmit)=\"addDatasetMetadata()\">\n                <fieldset>\n                  <legend class=\"u-visually-hidden\">{{ '@pry.action.editProfil' | i18n }}</legend>\n\n                  <div class=\"m-form-label-field\">\n                    <label for=\"metadata\" id=\"metadata-label\" class=\"a-label\">Data</label>\n                    <pry-select\n                      id=\"metadata\"\n                      class=\"a-pry-select\"\n                      formControlName=\"metadata\"\n                      [items]=\"availableMetadata$ | async\"\n                      (ngModelChange)=\"onMetaChange($event)\"\n                      [isForm]=\"true\"\n                      [itemsAsOption]=\"true\"\n                      bindLabel=\"name\"\n                      [readonly]=\"(editable$ | async) ?? false\"\n                      [attr.aria-labelledby]=\"\n                        isSubmitted && form.get('metadata')?.invalid\n                          ? 'metadata-label metadata-error'\n                          : 'metadata-label'\n                      \"\n                      [attr.aria-invalid]=\"isSubmitted && form.get('metadata')?.invalid\"\n                    >\n                    </pry-select>\n                    <label\n                      *ngIf=\"isSubmitted && form.get('metadata')?.invalid\"\n                      id=\"metadata-error\"\n                      for=\"metadata\"\n                      class=\"a-label a-label--help -error\"\n                    >\n                      {{ '@pry.admin.required' | i18n }}\n                    </label>\n                  </div>\n\n                  <ng-container *ngIf=\"form.value['metadata']['type'] === 'DATE'; else inputList\">\n                    <div class=\"m-form-label-field\">\n                      <label id=\"form_date-label\" for=\"form_date\" class=\"a-label\">\n                        {{ '@pry.action.selectDate' | i18n }} *\n                        <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n                      </label>\n                      <input\n                        id=\"form_date\"\n                        type=\"date\"\n                        class=\"a-form-field\"\n                        formControlName=\"value\"\n                        [attr.aria-labelledby]=\"\n                          isSubmitted && form.get('value')?.invalid\n                            ? 'form-date-label form-date-error'\n                            : 'form-date-label'\n                        \"\n                        [attr.aria-invalid]=\"isSubmitted && form.get('value')?.invalid\"\n                        required\n                      />\n                      <label\n                        *ngIf=\"isSubmitted && form.get('value')?.invalid\"\n                        id=\"form_date-error\"\n                        for=\"form_date\"\n                        class=\"a-label a-label--help -error\"\n                      >\n                        {{ '@pry.admin.required' | i18n }}\n                      </label>\n                    </div>\n                  </ng-container>\n\n                  <ng-template #inputList>\n                    <ng-container *ngIf=\"form.value['metadata']['type'] === 'LIST'; else inputText\">\n                      <div class=\"m-form-label-field\">\n                        <label id=\"list-label\" class=\"a-label\" for=\"list\">{{\n                          '@pry.action.choiceInList' | i18n\n                        }}</label>\n                        <pry-select\n                          id=\"list\"\n                          class=\"a-pry-select\"\n                          formControlName=\"value\"\n                          [items]=\"form.value['metadata']['allowedValues']\"\n                          [isForm]=\"true\"\n                          aria-labelledby=\"list-label\"\n                        ></pry-select>\n                      </div>\n                    </ng-container>\n                  </ng-template>\n\n                  <ng-template #inputText>\n                    <div class=\"m-form-label-field\">\n                      <label id=\"text-label\" class=\"a-label\" for=\"text\">\n                        {{ '@pry.action.text' | i18n }} *\n                        <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n                      </label>\n                      <input\n                        id=\"text\"\n                        type=\"text\"\n                        class=\"a-form-field\"\n                        formControlName=\"value\"\n                        [attr.aria-labelledby]=\"\n                          isSubmitted && form.get('value')?.invalid ? 'text-label text-error' : 'text-label'\n                        \"\n                        [attr.aria-invalid]=\"isSubmitted && form.get('value')?.invalid\"\n                        required\n                      />\n                      <label\n                        *ngIf=\"isSubmitted && form.get('value')?.invalid\"\n                        id=\"test-error\"\n                        for=\"text\"\n                        class=\"a-label a-label--help -error\"\n                      >\n                        <span *ngIf=\"form.get('value')?.hasError('required')\">{{ '@pry.admin.required' | i18n }}</span>\n                        <ng-container *ngIf=\"form.get('value')?.hasError('pattern')\">\n                          <span *ngIf=\"form.value['metadata']['type'] === 'DOUBLE'\">\n                            {{ '@pry.admin.environment.formatDouble' | i18n }}\n                          </span>\n                          <span *ngIf=\"form.value['metadata']['type'] === 'INTEGER'\">\n                            {{ '@pry.admin.environment.formatInt' | i18n }}\n                          </span>\n                        </ng-container>\n                      </label>\n                    </div>\n                  </ng-template>\n                </fieldset>\n\n                <div class=\"m-btn-group -end\">\n                  <button\n                    type=\"submit\"\n                    class=\"a-btn a-btn--primary\"\n                    [innerHTML]=\"\n                      ((editable$ | async) ? '@pry.admin.userInfo.editMetadata' : '@pry.admin.userInfo.addMetadata')\n                        | i18n\n                    \"\n                  ></button>\n                </div>\n              </form>\n            </ng-container>\n          </ng-container>\n        </div>\n        <div\n          class=\"o-tabs__panels__item\"\n          [class.is-hidden]=\"tab !== 1\"\n          [id]=\"'tabpanel-' + compId + '-1'\"\n          role=\"tabpanel\"\n          [attr.aria-labelledby]=\"'tab-' + compId + '-1'\"\n          tabindex=\"1\"\n        >\n          <div *ngIf=\"associations$ | async as associations\" class=\"o-tabs__panels__item__content\">\n            <h4 class=\"a-h4\">{{ '@pry.admin.classes.associations' | i18n }}</h4>\n            <pry-association [associations]=\"associations\"></pry-association>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
158
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-select-dataset.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/dashboard/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.ts","../../../../../../../../projects/provoly/dashboard/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, OnInit } from '@angular/core';\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  Associations,\n  Dataset,\n  DataSourceActions,\n  DataSourceSelectors,\n  IMetadata,\n  MetadataValue,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { combineLatest, map, Observable, Subscription } from 'rxjs';\nimport { AdminActions } from '../../../store/admin.actions';\nimport { AdminSelectors } from '../../../store/admin.selectors';\nimport { MetadataActions } from '../../admin-metadata/store/metadata.action';\nimport { MetadataSelectors } from '../../admin-metadata/store/metadata.selector';\nimport { AdminDatasetActions } from '../store/admin-dataset.actions';\nimport { AdminDatasetSelectors } from '../store/admin-dataset.selector';\n\nlet nextCompId = 0;\n\n@Component({\n  selector: 'pry-admin-select-dataset',\n  templateUrl: './admin-select-dataset.component.html'\n})\nexport class AdminSelectDatasetComponent extends SubscriptionnerDirective implements OnInit, OnDestroy {\n  static id = 'AdminSelectDatasetComponent';\n  compId: number;\n  selectedDataset$: Observable<Dataset | null>;\n  associations$: Observable<Associations | undefined>;\n  sub = new Subscription();\n  currentTypeTranslation = '';\n  tab: number = 0;\n  datasetMetadata$: Observable<MetadataValue[]>;\n  metadata$: Observable<IMetadata[]>;\n  availableMetadata$?: Observable<IMetadata[]>;\n  form: FormGroup;\n  isSubmitted = false;\n  editable$: Observable<boolean>;\n  datasetId = '';\n\n  constructor(\n    private store: Store<any>,\n    private router: Router,\n    private route: ActivatedRoute,\n    private formBuilder: FormBuilder\n  ) {\n    super();\n    this.store.dispatch(MetadataActions.loadMetadata());\n    this.selectedDataset$ = this.store.select(DataSourceSelectors.selectedDataset);\n    this.datasetMetadata$ = this.store.select(DataSourceSelectors.selectedDatasetMetadata);\n    this.associations$ = this.store.select(AdminSelectors.selectedAssociation);\n    this.metadata$ = this.store.select(MetadataSelectors.metadata);\n    this.editable$ = this.store.select(AdminDatasetSelectors.editable);\n    this.compId = nextCompId++;\n\n    this.form = this.formBuilder.group({\n      metadata: [{}, [Validators.required]],\n      value: ['', [Validators.required, Validators.pattern('^[+-]?[0-9]*$')]]\n    });\n  }\n\n  ngOnInit(): void {\n    this.subscriptions.add(\n      this.selectedDataset$.subscribe((dataset) => {\n        if (dataset) {\n          this.datasetId = dataset.id;\n          const editPath = this.router.createUrlTree(['.', 'dataset', 'edit', dataset.id], {\n            relativeTo: this.route\n          });\n          this.store.dispatch(\n            AdminActions.mainActions({\n              actions: [\n                {\n                  action: AdminActions.routeTo({ path: editPath.toString() }),\n                  label: 'edit',\n                  icon: 'edit',\n                  moduleAccess: 'admin',\n                  pageAccess: 'dataset',\n                  actionAccess: 'write'\n                },\n                {\n                  action: DataSourceActions.dataset.confirmDataSourceDeletion({\n                    name: dataset.id,\n                    route: this.router.createUrlTree(['.', 'dataset'], { relativeTo: this.route }).toString(),\n                    addRoute: this.router.createUrlTree(['.', 'dataset', 'new'], { relativeTo: this.route }).toString()\n                  }),\n                  label: 'delete',\n                  icon: 'delete',\n                  moduleAccess: 'admin',\n                  pageAccess: 'dataset',\n                  actionAccess: 'write'\n                }\n              ]\n            })\n          );\n        }\n      })\n    );\n    this.subscriptions.add(\n      this.selectedDataset$.subscribe((dataset) => {\n        if (dataset) {\n          this.availableMetadata$?.subscribe((meta) => {\n            this.form.patchValue({\n              metadata: meta[0]\n            });\n            this.onMetaChange(meta[0]);\n            this.form.patchValue({ value: '' });\n          });\n        }\n      })\n    );\n    this.availableMetadata$ = combineLatest([this.datasetMetadata$, this.metadata$]).pipe(\n      map(([datasetMetadata, metaDefs]) => {\n        let datasetMetadataIds = datasetMetadata?.map((u) => u.metadataDef.id);\n        return metaDefs.filter((meta) => !datasetMetadataIds?.includes(meta.id));\n      })\n    );\n  }\n\n  closePanel() {\n    const path = this.router.createUrlTree(['.', 'dataset', 'new'], { relativeTo: this.route });\n    this.store.dispatch(DataSourceActions.dataset.unselectDataset());\n    this.store.dispatch(AdminActions.togglePanel({ panelOpen: false }));\n    this.store.dispatch(\n      AdminActions.mainActions({\n        actions: [\n          {\n            action: AdminActions.routeTo({ path: path.toString() }),\n            label: 'add',\n            icon: 'add_column',\n            moduleAccess: 'admin',\n            pageAccess: 'metadata_rules',\n            actionAccess: 'write'\n          }\n        ]\n      })\n    );\n  }\n\n  addDatasetMetadata() {\n    this.isSubmitted = true;\n    if (this.form.valid) {\n      this.isSubmitted = false;\n      let payload = {\n        datasetId: this.datasetId,\n        metadataId: this.form.value['metadata']['id'],\n        value: this.form.value['value']\n      };\n      this.store.dispatch(AdminDatasetActions.addDatasetMetadata(payload));\n    }\n  }\n\n  onMetaChange(metadata: IMetadata) {\n    if (metadata) {\n      if (metadata.type === 'INTEGER') {\n        this.form.controls['value'].setValidators([Validators.required, Validators.pattern('^[+-]?[0-9]*$')]);\n      } else if (metadata.type === 'DOUBLE') {\n        this.form.controls['value'].setValidators([Validators.required, Validators.pattern('[+-]?([0-9]*[.])?[0-9]+')]);\n      } else {\n        this.form.controls['value'].setValidators([Validators.required]);\n      }\n    }\n  }\n\n  removeMetadata(metadata: MetadataValue) {\n    this.store.dispatch(\n      AdminDatasetActions.deleteDatasetMetadata({ datasetId: this.datasetId, metadataId: metadata.metadataDef.id })\n    );\n  }\n\n  editMetadata(currentMetadata: MetadataValue) {\n    this.store.dispatch(AdminDatasetActions.isEditable({ editable: true }));\n    let value = currentMetadata.value;\n    let datasetMetadataDef = currentMetadata.metadataDef;\n\n    this.form.patchValue({\n      metadata: datasetMetadataDef,\n      value: value\n    });\n    this.onMetaChange(datasetMetadataDef);\n  }\n\n  switch(number: number) {\n    this.tab = number;\n  }\n}\n","<div\n  *ngIf=\"selectedDataset$ | async as dataset\"\n  [id]=\"'panel-dataset-' + dataset.id\"\n  [attr.aria-labelledby]=\"'button-dataset-' + dataset.id\"\n  class=\"o-panel\"\n>\n  <div>\n    <div class=\"o-panel__header\">\n      <button type=\"button\" class=\"a-btn a-btn--icon-only\" (click)=\"closePanel()\">\n        <span class=\"u-visually-hidden\">{{ '@pry.action.closePanel' | i18n }}</span>\n        <pry-icon iconSvg=\"close\"></pry-icon>\n      </button>\n\n      <h3 [id]=\"'tab-title-' + compId\" class=\"a-h3\">\n        {{ '@pry.admin.metadata.details' | i18n }}\n      </h3>\n    </div>\n\n    <div class=\"o-tabs\">\n      <div class=\"o-tabs__list\" role=\"tablist\" [attr.aria-labelledby]=\"'tab-title-' + compId\">\n        <button\n          type=\"button\"\n          class=\"o-tabs__list__btn\"\n          role=\"tab\"\n          [id]=\"'tab-' + compId + '-0'\"\n          [attr.aria-selected]=\"tab === 0\"\n          [attr.tabindex]=\"tab === 0 ? 0 : -1\"\n          [attr.aria-controls]=\"'tabpanel-' + compId + '-0'\"\n          (click)=\"switch(0)\"\n        >\n          {{ '@pry.admin.metadata.title' | i18n }}\n        </button>\n        <button\n          type=\"button\"\n          class=\"o-tabs__list__btn\"\n          role=\"tab\"\n          [id]=\"'tab-' + compId + '-1'\"\n          [attr.aria-selected]=\"tab === 1\"\n          [attr.tabindex]=\"tab === 1 ? 1 : -1\"\n          [attr.aria-controls]=\"'tabpanel-' + compId + '-1'\"\n          (click)=\"switch(1)\"\n        >\n          {{ '@pry.admin.classes.associations' | i18n }}\n        </button>\n      </div>\n\n      <div class=\"o-tabs__panels\">\n        <div\n          class=\"o-tabs__panels__item\"\n          [class.is-hidden]=\"tab !== 0\"\n          [id]=\"'tabpanel-' + compId + '-0'\"\n          role=\"tabpanel\"\n          [attr.aria-labelledby]=\"'tab-' + compId + '-0'\"\n          tabindex=\"0\"\n        >\n          <div class=\"o-tabs__panels__item__content o-tabs__panels__item__content--profil\">\n            <div *ngFor=\"let metadata of datasetMetadata$ | async\">\n              <div class=\"o-tabs__panels__item__content\">\n                <div class=\"o-tabs__panels__item__content__actions\">\n                  <div class=\"o-tabs__panels__item__content__actions__text\">\n                    <span class=\"o-tabs__panels__item__content__actions__text__label\"\n                      >{{ metadata.metadataDef.name }} :</span\n                    >\n                    <span class=\"o-tabs__panels__item__content__actions__text__value\">{{ metadata.value }}</span>\n                  </div>\n\n                  <div class=\"o-tabs__panels__item__content__actions__buttons\">\n                    <ng-container *pryAccess=\"{ module: 'admin', page: 'dataset', action: 'write' }\">\n                      <button type=\"button\" class=\"a-btn a-btn--icon-only\" aria-pressed=\"false\">\n                        <span class=\"u-visually-hidden\"\n                          >{{ '@pry.action.edit' | i18n }} {{ metadata.metadataDef.name }}</span\n                        >\n                        <pry-icon\n                          class=\"edit-icon\"\n                          iconSvg=\"edit\"\n                          [width]=\"15\"\n                          [height]=\"15\"\n                          (click)=\"editMetadata(metadata)\"\n                        ></pry-icon>\n                      </button>\n                      <button type=\"button\" class=\"a-btn a-btn--icon-only\" aria-pressed=\"false\">\n                        <span class=\"u-visually-hidden\"\n                          >{{ '@pry.action.delete' | i18n }} {{ metadata.metadataDef.name }}</span\n                        >\n                        <pry-icon\n                          class=\"delete-icon\"\n                          iconSvg=\"delete\"\n                          [width]=\"15\"\n                          [height]=\"15\"\n                          (click)=\"removeMetadata(metadata)\"\n                        ></pry-icon>\n                      </button>\n                    </ng-container>\n                  </div>\n                </div>\n              </div>\n            </div>\n          </div>\n\n          <ng-container *pryAccess=\"{ module: 'admin', page: 'dataset', action: 'write' }\">\n            <ng-container *ngIf=\"form.value.metadata\">\n              <form class=\"o-form -border-top\" [formGroup]=\"form\" (ngSubmit)=\"addDatasetMetadata()\">\n                <fieldset>\n                  <legend class=\"u-visually-hidden\">{{ '@pry.action.editProfil' | i18n }}</legend>\n\n                  <div class=\"m-form-label-field\">\n                    <label for=\"metadata\" id=\"metadata-label\" class=\"a-label\">Data</label>\n                    <pry-select\n                      id=\"metadata\"\n                      class=\"a-pry-select\"\n                      formControlName=\"metadata\"\n                      [items]=\"availableMetadata$ | async\"\n                      (ngModelChange)=\"onMetaChange($event)\"\n                      [isForm]=\"true\"\n                      [itemsAsOption]=\"true\"\n                      bindLabel=\"name\"\n                      [readonly]=\"(editable$ | async) ?? false\"\n                      [attr.aria-labelledby]=\"\n                        isSubmitted && form.get('metadata')?.invalid\n                          ? 'metadata-label metadata-error'\n                          : 'metadata-label'\n                      \"\n                      [attr.aria-invalid]=\"isSubmitted && form.get('metadata')?.invalid\"\n                    >\n                    </pry-select>\n                    <label\n                      *ngIf=\"isSubmitted && form.get('metadata')?.invalid\"\n                      id=\"metadata-error\"\n                      for=\"metadata\"\n                      class=\"a-label a-label--help -error\"\n                    >\n                      {{ '@pry.admin.required' | i18n }}\n                    </label>\n                  </div>\n\n                  <ng-container *ngIf=\"form.value['metadata']['type'] === 'DATE'; else inputList\">\n                    <div class=\"m-form-label-field\">\n                      <label id=\"form_date-label\" for=\"form_date\" class=\"a-label\">\n                        {{ '@pry.action.selectDate' | i18n }} *\n                        <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n                      </label>\n                      <input\n                        id=\"form_date\"\n                        type=\"date\"\n                        class=\"a-form-field\"\n                        formControlName=\"value\"\n                        [attr.aria-labelledby]=\"\n                          isSubmitted && form.get('value')?.invalid\n                            ? 'form-date-label form-date-error'\n                            : 'form-date-label'\n                        \"\n                        [attr.aria-invalid]=\"isSubmitted && form.get('value')?.invalid\"\n                        required\n                      />\n                      <label\n                        *ngIf=\"isSubmitted && form.get('value')?.invalid\"\n                        id=\"form_date-error\"\n                        for=\"form_date\"\n                        class=\"a-label a-label--help -error\"\n                      >\n                        {{ '@pry.admin.required' | i18n }}\n                      </label>\n                    </div>\n                  </ng-container>\n\n                  <ng-template #inputList>\n                    <ng-container *ngIf=\"form.value['metadata']['type'] === 'LIST'; else inputText\">\n                      <div class=\"m-form-label-field\">\n                        <label id=\"list-label\" class=\"a-label\" for=\"list\">{{\n                          '@pry.action.choiceInList' | i18n\n                        }}</label>\n                        <pry-select\n                          id=\"list\"\n                          class=\"a-pry-select\"\n                          formControlName=\"value\"\n                          [items]=\"form.value['metadata']['allowedValues']\"\n                          [isForm]=\"true\"\n                          aria-labelledby=\"list-label\"\n                        ></pry-select>\n                      </div>\n                    </ng-container>\n                  </ng-template>\n\n                  <ng-template #inputText>\n                    <div class=\"m-form-label-field\">\n                      <label id=\"text-label\" class=\"a-label\" for=\"text\">\n                        {{ '@pry.action.text' | i18n }} *\n                        <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n                      </label>\n                      <input\n                        id=\"text\"\n                        type=\"text\"\n                        class=\"a-form-field\"\n                        formControlName=\"value\"\n                        [attr.aria-labelledby]=\"\n                          isSubmitted && form.get('value')?.invalid ? 'text-label text-error' : 'text-label'\n                        \"\n                        [attr.aria-invalid]=\"isSubmitted && form.get('value')?.invalid\"\n                        required\n                      />\n                      <label\n                        *ngIf=\"isSubmitted && form.get('value')?.invalid\"\n                        id=\"test-error\"\n                        for=\"text\"\n                        class=\"a-label a-label--help -error\"\n                      >\n                        <span *ngIf=\"form.get('value')?.hasError('required')\">{{ '@pry.admin.required' | i18n }}</span>\n                        <ng-container *ngIf=\"form.get('value')?.hasError('pattern')\">\n                          <span *ngIf=\"form.value['metadata']['type'] === 'DOUBLE'\">\n                            {{ '@pry.admin.environment.formatDouble' | i18n }}\n                          </span>\n                          <span *ngIf=\"form.value['metadata']['type'] === 'INTEGER'\">\n                            {{ '@pry.admin.environment.formatInt' | i18n }}\n                          </span>\n                        </ng-container>\n                      </label>\n                    </div>\n                  </ng-template>\n                </fieldset>\n\n                <div class=\"m-btn-group -end\">\n                  <button\n                    type=\"submit\"\n                    class=\"a-btn a-btn--primary\"\n                    [innerHTML]=\"\n                      ((editable$ | async) ? '@pry.admin.userInfo.editMetadata' : '@pry.admin.userInfo.addMetadata')\n                        | i18n\n                    \"\n                  ></button>\n                </div>\n              </form>\n            </ng-container>\n          </ng-container>\n        </div>\n        <div\n          class=\"o-tabs__panels__item\"\n          [class.is-hidden]=\"tab !== 1\"\n          [id]=\"'tabpanel-' + compId + '-1'\"\n          role=\"tabpanel\"\n          [attr.aria-labelledby]=\"'tab-' + compId + '-1'\"\n          tabindex=\"1\"\n        >\n          <div *ngIf=\"associations$ | async as associations\" class=\"o-tabs__panels__item__content\">\n            <h4 class=\"a-h4\">{{ '@pry.admin.classes.associations' | i18n }}</h4>\n            <pry-association [associations]=\"associations\"></pry-association>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -11,4 +11,4 @@ export const AdminDatasetActions = {
|
|
|
11
11
|
deleteDatasetMetadataSuccess: createAction(`[Admin/Datasource] Delete Metadata of selected Datasets Success`, props()),
|
|
12
12
|
deleteDatasetMetadataFailure: createAction(`[Admin/Datasource] Delete Metadata of selected Datasets Failure`, props())
|
|
13
13
|
};
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRtaW4tZGF0YXNldC5hY3Rpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvYWRtaW4vY29tcG9uZW50cy9hZG1pbi1kYXRhc2V0L3N0b3JlL2FkbWluLWRhdGFzZXQuYWN0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUdsRCxNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRztJQUNqQyxVQUFVLEVBQUUsWUFBWSxDQUFDLGdDQUFnQyxFQUFFLEtBQUssRUFBeUIsQ0FBQztJQUUxRixtQkFBbUIsRUFBRSxZQUFZLENBQy9CLHVEQUF1RCxFQUN2RCxLQUFLLEVBQXlCLENBQy9CO0lBQ0QsMEJBQTBCLEVBQUUsWUFBWSxDQUN0QywrREFBK0QsRUFDL0QsS0FBSyxFQUFpQyxDQUN2QztJQUNELDBCQUEwQixFQUFFLFlBQVksQ0FDdEMsK0RBQStELEVBQy9ELEtBQUssRUFBa0IsQ0FDeEI7SUFFRCxrQkFBa0IsRUFBRSxZQUFZLENBQzlCLHNEQUFzRCxFQUN0RCxLQUFLLEVBQXlELENBQy9EO0lBQ0QseUJBQXlCLEVBQUUsWUFBWSxDQUNyQyw4REFBOEQsRUFDOUQsS0FBSyxFQUF5QixDQUMvQjtJQUNELHlCQUF5QixFQUFFLFlBQVksQ0FDckMsOERBQThELEVBQzlELEtBQUssRUFBa0IsQ0FDeEI7SUFFRCxxQkFBcUIsRUFBRSxZQUFZLENBQ2pDLHlEQUF5RCxFQUN6RCxLQUFLLEVBQTZDLENBQ25EO0lBQ0QsNEJBQTRCLEVBQUUsWUFBWSxDQUN4QyxpRUFBaUUsRUFDakUsS0FBSyxFQUF5QixDQUMvQjtJQUNELDRCQUE0QixFQUFFLFlBQVksQ0FDeEMsaUVBQWlFLEVBQ2pFLEtBQUssRUFBa0IsQ0FDeEI7Q0FDRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3JlYXRlQWN0aW9uLCBwcm9wcyB9IGZyb20gJ0BuZ3J4L3N0b3JlJztcbmltcG9ydCB7IE1ldGFkYXRhVmFsdWUgfSBmcm9tICdAcHJvdm9seS9kYXNoYm9hcmQnO1xuXG5leHBvcnQgY29uc3QgQWRtaW5EYXRhc2V0QWN0aW9ucyA9IHtcbiAgaXNFZGl0YWJsZTogY3JlYXRlQWN0aW9uKGBbQWRtaW4vRGF0YXNvdXJjZV0gSXMgZWRpdGFibGVgLCBwcm9wczx7IGVkaXRhYmxlOiBib29sZWFuIH0+KCkpLFxuXG4gIGxvYWREYXRhc2V0TWV0YWRhdGE6IGNyZWF0ZUFjdGlvbihcbiAgICBgW0FkbWluL0RhdGFzb3VyY2VdIExvYWQgTWV0YWRhdGEgb2Ygc2VsZWN0ZWQgRGF0YXNldHNgLFxuICAgIHByb3BzPHsgZGF0YXNldElkOiBzdHJpbmcgfT4oKVxuICApLFxuICBsb2FkRGF0YXNldE1ldGFkYXRhU3VjY2VzczogY3JlYXRlQWN0aW9uKFxuICAgIGBbQWRtaW4vRGF0YXNvdXJjZV0gTG9hZCBNZXRhZGF0YSBvZiBzZWxlY3RlZCBEYXRhc2V0cyBTdWNjZXNzYCxcbiAgICBwcm9wczx7IG1ldGFkYXRhOiBNZXRhZGF0YVZhbHVlW10gfT4oKVxuICApLFxuICBsb2FkRGF0YXNldE1ldGFkYXRhRmFpbHVyZTogY3JlYXRlQWN0aW9uKFxuICAgIGBbQWRtaW4vRGF0YXNvdXJjZV0gTG9hZCBNZXRhZGF0YSBvZiBzZWxlY3RlZCBEYXRhc2V0cyBGYWlsdXJlYCxcbiAgICBwcm9wczx7IGVycm9yOiBhbnkgfT4oKVxuICApLFxuXG4gIGFkZERhdGFzZXRNZXRhZGF0YTogY3JlYXRlQWN0aW9uKFxuICAgIGBbQWRtaW4vRGF0YXNvdXJjZV0gQWRkIE1ldGFkYXRhIG9mIHNlbGVjdGVkIERhdGFzZXRzYCxcbiAgICBwcm9wczx7IGRhdGFzZXRJZDogc3RyaW5nOyBtZXRhZGF0YUlkOiBzdHJpbmc7IHZhbHVlOiBhbnkgfT4oKVxuICApLFxuICBhZGREYXRhc2V0TWV0YWRhdGFTdWNjZXNzOiBjcmVhdGVBY3Rpb24oXG4gICAgYFtBZG1pbi9EYXRhc291cmNlXSBBZGQgTWV0YWRhdGEgb2Ygc2VsZWN0ZWQgRGF0YXNldHMgU3VjY2Vzc2AsXG4gICAgcHJvcHM8eyBkYXRhc2V0SWQ6IHN0cmluZyB9PigpXG4gICksXG4gIGFkZERhdGFzZXRNZXRhZGF0YUZhaWx1cmU6IGNyZWF0ZUFjdGlvbihcbiAgICBgW0FkbWluL0RhdGFzb3VyY2VdIEFkZCBNZXRhZGF0YSBvZiBzZWxlY3RlZCBEYXRhc2V0cyBGYWlsdXJlYCxcbiAgICBwcm9wczx7IGVycm9yOiBhbnkgfT4oKVxuICApLFxuXG4gIGRlbGV0ZURhdGFzZXRNZXRhZGF0YTogY3JlYXRlQWN0aW9uKFxuICAgIGBbQWRtaW4vRGF0YXNvdXJjZV0gRGVsZXRlIE1ldGFkYXRhIG9mIHNlbGVjdGVkIERhdGFzZXRzYCxcbiAgICBwcm9wczx7IGRhdGFzZXRJZDogc3RyaW5nOyBtZXRhZGF0YUlkOiBzdHJpbmcgfT4oKVxuICApLFxuICBkZWxldGVEYXRhc2V0TWV0YWRhdGFTdWNjZXNzOiBjcmVhdGVBY3Rpb24oXG4gICAgYFtBZG1pbi9EYXRhc291cmNlXSBEZWxldGUgTWV0YWRhdGEgb2Ygc2VsZWN0ZWQgRGF0YXNldHMgU3VjY2Vzc2AsXG4gICAgcHJvcHM8eyBkYXRhc2V0SWQ6IHN0cmluZyB9PigpXG4gICksXG4gIGRlbGV0ZURhdGFzZXRNZXRhZGF0YUZhaWx1cmU6IGNyZWF0ZUFjdGlvbihcbiAgICBgW0FkbWluL0RhdGFzb3VyY2VdIERlbGV0ZSBNZXRhZGF0YSBvZiBzZWxlY3RlZCBEYXRhc2V0cyBGYWlsdXJlYCxcbiAgICBwcm9wczx7IGVycm9yOiBhbnkgfT4oKVxuICApXG59O1xuIl19
|
|
@@ -6,20 +6,13 @@ import * as i1 from "./dialog-ref";
|
|
|
6
6
|
import * as i2 from "@ngrx/store";
|
|
7
7
|
import * as i3 from "@angular/common";
|
|
8
8
|
import * as i4 from "../icon/icon.component";
|
|
9
|
-
import * as i5 from "
|
|
9
|
+
import * as i5 from "@angular/cdk/a11y";
|
|
10
|
+
import * as i6 from "../../i18n/i18n.pipe";
|
|
10
11
|
export class PryDialogConfirmComponent {
|
|
11
12
|
constructor(dialog, data, store) {
|
|
12
13
|
this.dialog = dialog;
|
|
13
14
|
this.data = data;
|
|
14
15
|
this.store = store;
|
|
15
|
-
setTimeout(() => {
|
|
16
|
-
this.cross.nativeElement.focus();
|
|
17
|
-
this.buttonAction.nativeElement.parentElement?.children[1].addEventListener('keydown', (event) => {
|
|
18
|
-
if (event.key === 'Tab') {
|
|
19
|
-
this.focusCrossElement();
|
|
20
|
-
}
|
|
21
|
-
});
|
|
22
|
-
}, 10);
|
|
23
16
|
}
|
|
24
17
|
onClick(action) {
|
|
25
18
|
if (action) {
|
|
@@ -39,11 +32,11 @@ export class PryDialogConfirmComponent {
|
|
|
39
32
|
this.cross.nativeElement.focus();
|
|
40
33
|
}
|
|
41
34
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryDialogConfirmComponent, deps: [{ token: i1.PryDialogRef }, { token: PRY_DIALOG_DATA }, { token: i2.Store }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
42
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: PryDialogConfirmComponent, selector: "pry-dialog-confirm", viewQueries: [{ propertyName: "cross", first: true, predicate: ["cross"], descendants: true }, { propertyName: "buttonAction", first: true, predicate: ["buttonAction"], descendants: true }], ngImport: i0, template: "<div\n class=\"o-modal-wrapper\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"dialog_confirmDelete\"\n (keydown.escape)=\"onClick()\"\n>\n <div class=\"o-modal\">\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\" id=\"dialog_title\">\n {{ data.title | i18n }}\n </h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" (click)=\"closeDialog()\" #cross>\n <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n </button>\n </div>\n </div>\n <div>\n <p *ngIf=\"data?.message as message\" class=\"a-p\">{{ message | i18n }}</p>\n </div>\n <div class=\"m-btn-group\">\n <ng-container *ngFor=\"let action of data.actions\" #buttonAction>\n <button\n (click)=\"onClick(action)\"\n class=\"a-btn\"\n type=\"button\"\n [class.a-btn--primary]=\"action.color === 'primary' || action.color === undefined\"\n [class.a-btn--secondary]=\"action.color === 'secondary'\"\n [class.a-btn--tertiary]=\"action.color === 'tertiary'\"\n [class.a-btn--ghost]=\"action.color === 'ghost'\"\n [ngClass]=\"{ 'a-btn--icon-text': action.icon }\"\n >\n <pry-icon *ngIf=\"action.icon\" [iconSvg]=\"action.icon\"></pry-icon>\n {{ action.label | i18n }}\n </button>\n </ng-container>\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "
|
|
35
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: PryDialogConfirmComponent, selector: "pry-dialog-confirm", viewQueries: [{ propertyName: "cross", first: true, predicate: ["cross"], descendants: true }, { propertyName: "buttonAction", first: true, predicate: ["buttonAction"], descendants: true }], ngImport: i0, template: "<div\n class=\"o-modal-wrapper\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"dialog_confirmDelete\"\n (keydown.escape)=\"onClick()\"\n cdkTrapFocus\n [cdkTrapFocusAutoCapture]=\"true\"\n>\n <div class=\"o-modal\">\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\" id=\"dialog_title\">\n {{ data.title | i18n }}\n </h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" (click)=\"closeDialog()\" #cross>\n <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n </button>\n </div>\n </div>\n <div>\n <p *ngIf=\"data?.message as message\" class=\"a-p\">{{ message | i18n }}</p>\n </div>\n <div class=\"m-btn-group\">\n <ng-container *ngFor=\"let action of data.actions\" #buttonAction>\n <button\n (click)=\"onClick(action)\"\n class=\"a-btn\"\n type=\"button\"\n [class.a-btn--primary]=\"action.color === 'primary' || action.color === undefined\"\n [class.a-btn--secondary]=\"action.color === 'secondary'\"\n [class.a-btn--tertiary]=\"action.color === 'tertiary'\"\n [class.a-btn--ghost]=\"action.color === 'ghost'\"\n [ngClass]=\"{ 'a-btn--icon-text': action.icon }\"\n >\n <pry-icon *ngIf=\"action.icon\" [iconSvg]=\"action.icon\"></pry-icon>\n {{ action.label | i18n }}\n </button>\n </ng-container>\n </div>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "directive", type: i5.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { kind: "pipe", type: i6.I18nPipe, name: "i18n" }] }); }
|
|
43
36
|
}
|
|
44
37
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryDialogConfirmComponent, decorators: [{
|
|
45
38
|
type: Component,
|
|
46
|
-
args: [{ selector: 'pry-dialog-confirm', template: "<div\n class=\"o-modal-wrapper\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"dialog_confirmDelete\"\n (keydown.escape)=\"onClick()\"\n>\n <div class=\"o-modal\">\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\" id=\"dialog_title\">\n {{ data.title | i18n }}\n </h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" (click)=\"closeDialog()\" #cross>\n <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n </button>\n </div>\n </div>\n <div>\n <p *ngIf=\"data?.message as message\" class=\"a-p\">{{ message | i18n }}</p>\n </div>\n <div class=\"m-btn-group\">\n <ng-container *ngFor=\"let action of data.actions\" #buttonAction>\n <button\n (click)=\"onClick(action)\"\n class=\"a-btn\"\n type=\"button\"\n [class.a-btn--primary]=\"action.color === 'primary' || action.color === undefined\"\n [class.a-btn--secondary]=\"action.color === 'secondary'\"\n [class.a-btn--tertiary]=\"action.color === 'tertiary'\"\n [class.a-btn--ghost]=\"action.color === 'ghost'\"\n [ngClass]=\"{ 'a-btn--icon-text': action.icon }\"\n >\n <pry-icon *ngIf=\"action.icon\" [iconSvg]=\"action.icon\"></pry-icon>\n {{ action.label | i18n }}\n </button>\n </ng-container>\n </div>\n </div>\n</div>\n" }]
|
|
39
|
+
args: [{ selector: 'pry-dialog-confirm', template: "<div\n class=\"o-modal-wrapper\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"dialog_confirmDelete\"\n (keydown.escape)=\"onClick()\"\n cdkTrapFocus\n [cdkTrapFocusAutoCapture]=\"true\"\n>\n <div class=\"o-modal\">\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\" id=\"dialog_title\">\n {{ data.title | i18n }}\n </h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" (click)=\"closeDialog()\" #cross>\n <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n </button>\n </div>\n </div>\n <div>\n <p *ngIf=\"data?.message as message\" class=\"a-p\">{{ message | i18n }}</p>\n </div>\n <div class=\"m-btn-group\">\n <ng-container *ngFor=\"let action of data.actions\" #buttonAction>\n <button\n (click)=\"onClick(action)\"\n class=\"a-btn\"\n type=\"button\"\n [class.a-btn--primary]=\"action.color === 'primary' || action.color === undefined\"\n [class.a-btn--secondary]=\"action.color === 'secondary'\"\n [class.a-btn--tertiary]=\"action.color === 'tertiary'\"\n [class.a-btn--ghost]=\"action.color === 'ghost'\"\n [ngClass]=\"{ 'a-btn--icon-text': action.icon }\"\n >\n <pry-icon *ngIf=\"action.icon\" [iconSvg]=\"action.icon\"></pry-icon>\n {{ action.label | i18n }}\n </button>\n </ng-container>\n </div>\n </div>\n</div>\n" }]
|
|
47
40
|
}], ctorParameters: function () { return [{ type: i1.PryDialogRef }, { type: undefined, decorators: [{
|
|
48
41
|
type: Inject,
|
|
49
42
|
args: [PRY_DIALOG_DATA]
|
|
@@ -54,4 +47,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImpor
|
|
|
54
47
|
type: ViewChild,
|
|
55
48
|
args: ['buttonAction']
|
|
56
49
|
}] } });
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLWNvbmZpcm0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvbGliL2NvcmUvY29tcG9uZW50cy9vdmVybGF5L2RpYWxvZy1jb25maXJtLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL2xpYi9jb3JlL2NvbXBvbmVudHMvb3ZlcmxheS9kaWFsb2ctY29uZmlybS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLE1BQU0sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFekUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBRWxFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7Ozs7Ozs7QUFvQm5ELE1BQU0sT0FBTyx5QkFBeUI7SUFJcEMsWUFDVSxNQUErQyxFQUN2QixJQUEwQixFQUNsRCxLQUFZO1FBRlosV0FBTSxHQUFOLE1BQU0sQ0FBeUM7UUFDdkIsU0FBSSxHQUFKLElBQUksQ0FBc0I7UUFDbEQsVUFBSyxHQUFMLEtBQUssQ0FBTztJQUNuQixDQUFDO0lBRUosT0FBTyxDQUFDLE1BQStCO1FBQ3JDLElBQUksTUFBTSxFQUFFO1lBQ1YsSUFBSSxNQUFNLENBQUMsT0FBTztnQkFBRSxNQUFNLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztZQUNwRixJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztTQUMzQjthQUFNO1lBQ0wsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQztTQUNyQjtRQUNELElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUMsRUFBRSxFQUFFLEVBQUUsMkJBQTJCLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDdkYsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ3RCLENBQUM7SUFFRCxpQkFBaUI7UUFDZixJQUFJLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUNuQyxDQUFDOzhHQTFCVSx5QkFBeUIsOENBTTFCLGVBQWU7a0dBTmQseUJBQXlCLHlQQ3hCdEMsaW5EQTZDQTs7MkZEckJhLHlCQUF5QjtrQkFKckMsU0FBUzsrQkFDRSxvQkFBb0I7OzBCQVMzQixNQUFNOzJCQUFDLGVBQWU7Z0VBTEwsS0FBSztzQkFBeEIsU0FBUzt1QkFBQyxPQUFPO2dCQUNTLFlBQVk7c0JBQXRDLFNBQVM7dUJBQUMsY0FBYyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRWxlbWVudFJlZiwgSW5qZWN0LCBWaWV3Q2hpbGQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFjdGlvbiwgU3RvcmUgfSBmcm9tICdAbmdyeC9zdG9yZSc7XG5pbXBvcnQgeyBDb25maWdBY3Rpb25zIH0gZnJvbSAnLi4vLi4vc3RvcmUvY29uZmlnL2NvbmZpZy5hY3Rpb25zJztcbmltcG9ydCB7IFByeURpYWxvZ1JlZiB9IGZyb20gJy4vZGlhbG9nLXJlZic7XG5pbXBvcnQgeyBQUllfRElBTE9HX0RBVEEgfSBmcm9tICcuL2RpYWxvZy5zZXJ2aWNlJztcblxuZXhwb3J0IGludGVyZmFjZSBQcnlEaWFsb2dDb25maXJtRGF0YSB7XG4gIHRpdGxlOiBzdHJpbmc7XG4gIG1lc3NhZ2U/OiBzdHJpbmc7XG4gIGFjdGlvbnM/OiBQcnlEaWFsb2dDb25maXJtQWN0aW9uW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUHJ5RGlhbG9nQ29uZmlybUFjdGlvbiB7XG4gIGlkOiBudW1iZXI7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIGljb24/OiBzdHJpbmc7XG4gIGNvbG9yPzogJ3ByaW1hcnknIHwgJ3NlY29uZGFyeScgfCAndGVydGlhcnknIHwgJ2dob3N0JztcbiAgYWN0aW9ucz86IEFjdGlvbltdO1xufVxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdwcnktZGlhbG9nLWNvbmZpcm0nLFxuICB0ZW1wbGF0ZVVybDogJy4vZGlhbG9nLWNvbmZpcm0uY29tcG9uZW50Lmh0bWwnXG59KVxuZXhwb3J0IGNsYXNzIFByeURpYWxvZ0NvbmZpcm1Db21wb25lbnQge1xuICBAVmlld0NoaWxkKCdjcm9zcycpIGNyb3NzITogRWxlbWVudFJlZjxIVE1MQnV0dG9uRWxlbWVudD47XG4gIEBWaWV3Q2hpbGQoJ2J1dHRvbkFjdGlvbicpIGJ1dHRvbkFjdGlvbiE6IEVsZW1lbnRSZWY8SFRNTERpdkVsZW1lbnQ+O1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgZGlhbG9nOiBQcnlEaWFsb2dSZWY8UHJ5RGlhbG9nQ29uZmlybUNvbXBvbmVudD4sXG4gICAgQEluamVjdChQUllfRElBTE9HX0RBVEEpIHB1YmxpYyBkYXRhOiBQcnlEaWFsb2dDb25maXJtRGF0YSxcbiAgICBwcml2YXRlIHN0b3JlOiBTdG9yZVxuICApIHt9XG5cbiAgb25DbGljayhhY3Rpb24/OiBQcnlEaWFsb2dDb25maXJtQWN0aW9uKSB7XG4gICAgaWYgKGFjdGlvbikge1xuICAgICAgaWYgKGFjdGlvbi5hY3Rpb25zKSBhY3Rpb24uYWN0aW9ucy5mb3JFYWNoKChhY3Rpb24pID0+IHRoaXMuc3RvcmUuZGlzcGF0Y2goYWN0aW9uKSk7XG4gICAgICB0aGlzLmRpYWxvZy5jbG9zZShhY3Rpb24pO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLmRpYWxvZy5jbG9zZSgpO1xuICAgIH1cbiAgICB0aGlzLnN0b3JlLmRpc3BhdGNoKENvbmZpZ0FjdGlvbnMuY2xvc2VPdmVybGF5KHsgaWQ6ICdQcnlEaWFsb2dDb25maXJtQ29tcG9uZW50JyB9KSk7XG4gIH1cblxuICBjbG9zZURpYWxvZygpIHtcbiAgICB0aGlzLmRpYWxvZy5jbG9zZSgpO1xuICB9XG5cbiAgZm9jdXNDcm9zc0VsZW1lbnQoKSB7XG4gICAgdGhpcy5jcm9zcy5uYXRpdmVFbGVtZW50LmZvY3VzKCk7XG4gIH1cbn1cbiIsIjxkaXZcbiAgY2xhc3M9XCJvLW1vZGFsLXdyYXBwZXJcIlxuICByb2xlPVwiZGlhbG9nXCJcbiAgYXJpYS1tb2RhbD1cInRydWVcIlxuICBhcmlhLWxhYmVsbGVkYnk9XCJkaWFsb2dfY29uZmlybURlbGV0ZVwiXG4gIChrZXlkb3duLmVzY2FwZSk9XCJvbkNsaWNrKClcIlxuICBjZGtUcmFwRm9jdXNcbiAgW2Nka1RyYXBGb2N1c0F1dG9DYXB0dXJlXT1cInRydWVcIlxuPlxuICA8ZGl2IGNsYXNzPVwiby1tb2RhbFwiPlxuICAgIDxkaXYgY2xhc3M9XCJvLW1vZGFsX190b3BcIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJvLW1vZGFsX190b3BfX3RpdGxlXCI+XG4gICAgICAgIDxoMiBjbGFzcz1cImEtaDJcIiBpZD1cImRpYWxvZ190aXRsZVwiPlxuICAgICAgICAgIHt7IGRhdGEudGl0bGUgfCBpMThuIH19XG4gICAgICAgIDwvaDI+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJvLW1vZGFsX190b3BfX2Nsb3NlXCI+XG4gICAgICAgIDxidXR0b24gY2xhc3M9XCJhLWJ0biBhLWJ0bi0taWNvbi1vbmx5XCIgKGNsaWNrKT1cImNsb3NlRGlhbG9nKClcIiAjY3Jvc3M+XG4gICAgICAgICAgPHByeS1pY29uIGljb25Tdmc9XCJjbG9zZVwiIFtoZWlnaHRdPVwiMzVcIiBbd2lkdGhdPVwiMzVcIj48L3ByeS1pY29uPlxuICAgICAgICAgIDxzcGFuIGNsYXNzPVwidS12aXN1YWxseS1oaWRkZW5cIj57eyAnQHByeS50b29sYm94LmNsb3NlJyB8IGkxOG4gfX08L3NwYW4+XG4gICAgICAgIDwvYnV0dG9uPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gICAgPGRpdj5cbiAgICAgIDxwICpuZ0lmPVwiZGF0YT8ubWVzc2FnZSBhcyBtZXNzYWdlXCIgY2xhc3M9XCJhLXBcIj57eyBtZXNzYWdlIHwgaTE4biB9fTwvcD5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2IGNsYXNzPVwibS1idG4tZ3JvdXBcIj5cbiAgICAgIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IGFjdGlvbiBvZiBkYXRhLmFjdGlvbnNcIiAjYnV0dG9uQWN0aW9uPlxuICAgICAgICA8YnV0dG9uXG4gICAgICAgICAgKGNsaWNrKT1cIm9uQ2xpY2soYWN0aW9uKVwiXG4gICAgICAgICAgY2xhc3M9XCJhLWJ0blwiXG4gICAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgICAgW2NsYXNzLmEtYnRuLS1wcmltYXJ5XT1cImFjdGlvbi5jb2xvciA9PT0gJ3ByaW1hcnknIHx8IGFjdGlvbi5jb2xvciA9PT0gdW5kZWZpbmVkXCJcbiAgICAgICAgICBbY2xhc3MuYS1idG4tLXNlY29uZGFyeV09XCJhY3Rpb24uY29sb3IgPT09ICdzZWNvbmRhcnknXCJcbiAgICAgICAgICBbY2xhc3MuYS1idG4tLXRlcnRpYXJ5XT1cImFjdGlvbi5jb2xvciA9PT0gJ3RlcnRpYXJ5J1wiXG4gICAgICAgICAgW2NsYXNzLmEtYnRuLS1naG9zdF09XCJhY3Rpb24uY29sb3IgPT09ICdnaG9zdCdcIlxuICAgICAgICAgIFtuZ0NsYXNzXT1cInsgJ2EtYnRuLS1pY29uLXRleHQnOiBhY3Rpb24uaWNvbiB9XCJcbiAgICAgICAgPlxuICAgICAgICAgIDxwcnktaWNvbiAqbmdJZj1cImFjdGlvbi5pY29uXCIgW2ljb25TdmddPVwiYWN0aW9uLmljb25cIj48L3ByeS1pY29uPlxuICAgICAgICAgIHt7IGFjdGlvbi5sYWJlbCB8IGkxOG4gfX1cbiAgICAgICAgPC9idXR0b24+XG4gICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8L2Rpdj5cbiAgPC9kaXY+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -6,18 +6,19 @@ import { PryIconModule } from '../icon/icon.module';
|
|
|
6
6
|
import { PryDialogConfirmComponent } from './dialog-confirm.component';
|
|
7
7
|
import { PryOverlayDirective } from './overlay.directive';
|
|
8
8
|
import { PryTooltipDirective } from './tooltip.directive';
|
|
9
|
+
import { A11yModule } from '@angular/cdk/a11y';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
10
11
|
export class PryOverlayModule {
|
|
11
12
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryOverlayModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
12
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.6", ngImport: i0, type: PryOverlayModule, declarations: [PryTooltipDirective, PryOverlayDirective, PryDialogConfirmComponent], imports: [CommonModule, OverlayModule, PryIconModule, PryI18nModule], exports: [PryTooltipDirective, PryOverlayDirective, PryDialogConfirmComponent] }); }
|
|
13
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryOverlayModule, imports: [CommonModule, OverlayModule, PryIconModule, PryI18nModule] }); }
|
|
13
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.6", ngImport: i0, type: PryOverlayModule, declarations: [PryTooltipDirective, PryOverlayDirective, PryDialogConfirmComponent], imports: [CommonModule, OverlayModule, PryIconModule, PryI18nModule, A11yModule], exports: [PryTooltipDirective, PryOverlayDirective, PryDialogConfirmComponent] }); }
|
|
14
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryOverlayModule, imports: [CommonModule, OverlayModule, PryIconModule, PryI18nModule, A11yModule] }); }
|
|
14
15
|
}
|
|
15
16
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: PryOverlayModule, decorators: [{
|
|
16
17
|
type: NgModule,
|
|
17
18
|
args: [{
|
|
18
19
|
declarations: [PryTooltipDirective, PryOverlayDirective, PryDialogConfirmComponent],
|
|
19
20
|
exports: [PryTooltipDirective, PryOverlayDirective, PryDialogConfirmComponent],
|
|
20
|
-
imports: [CommonModule, OverlayModule, PryIconModule, PryI18nModule]
|
|
21
|
+
imports: [CommonModule, OverlayModule, PryIconModule, PryI18nModule, A11yModule]
|
|
21
22
|
}]
|
|
22
23
|
}] });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3ZlcmxheS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2Rhc2hib2FyZC9saWIvY29yZS9jb21wb25lbnRzL292ZXJsYXkvb3ZlcmxheS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDcEQsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDdkUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDMUQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDMUQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLG1CQUFtQixDQUFDOztBQU8vQyxNQUFNLE9BQU8sZ0JBQWdCOzhHQUFoQixnQkFBZ0I7K0dBQWhCLGdCQUFnQixpQkFKWixtQkFBbUIsRUFBRSxtQkFBbUIsRUFBRSx5QkFBeUIsYUFFeEUsWUFBWSxFQUFFLGFBQWEsRUFBRSxhQUFhLEVBQUUsYUFBYSxFQUFFLFVBQVUsYUFEckUsbUJBQW1CLEVBQUUsbUJBQW1CLEVBQUUseUJBQXlCOytHQUdsRSxnQkFBZ0IsWUFGakIsWUFBWSxFQUFFLGFBQWEsRUFBRSxhQUFhLEVBQUUsYUFBYSxFQUFFLFVBQVU7OzJGQUVwRSxnQkFBZ0I7a0JBTDVCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsbUJBQW1CLEVBQUUsbUJBQW1CLEVBQUUseUJBQXlCLENBQUM7b0JBQ25GLE9BQU8sRUFBRSxDQUFDLG1CQUFtQixFQUFFLG1CQUFtQixFQUFFLHlCQUF5QixDQUFDO29CQUM5RSxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsYUFBYSxFQUFFLGFBQWEsRUFBRSxhQUFhLEVBQUUsVUFBVSxDQUFDO2lCQUNqRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE92ZXJsYXlNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFByeUkxOG5Nb2R1bGUgfSBmcm9tICcuLi8uLi9pMThuL2kxOG4ubW9kdWxlJztcbmltcG9ydCB7IFByeUljb25Nb2R1bGUgfSBmcm9tICcuLi9pY29uL2ljb24ubW9kdWxlJztcbmltcG9ydCB7IFByeURpYWxvZ0NvbmZpcm1Db21wb25lbnQgfSBmcm9tICcuL2RpYWxvZy1jb25maXJtLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBQcnlPdmVybGF5RGlyZWN0aXZlIH0gZnJvbSAnLi9vdmVybGF5LmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBQcnlUb29sdGlwRGlyZWN0aXZlIH0gZnJvbSAnLi90b29sdGlwLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBBMTF5TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2ExMXknO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtQcnlUb29sdGlwRGlyZWN0aXZlLCBQcnlPdmVybGF5RGlyZWN0aXZlLCBQcnlEaWFsb2dDb25maXJtQ29tcG9uZW50XSxcbiAgZXhwb3J0czogW1ByeVRvb2x0aXBEaXJlY3RpdmUsIFByeU92ZXJsYXlEaXJlY3RpdmUsIFByeURpYWxvZ0NvbmZpcm1Db21wb25lbnRdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBPdmVybGF5TW9kdWxlLCBQcnlJY29uTW9kdWxlLCBQcnlJMThuTW9kdWxlLCBBMTF5TW9kdWxlXVxufSlcbmV4cG9ydCBjbGFzcyBQcnlPdmVybGF5TW9kdWxlIHt9XG4iXX0=
|