@provoly/dashboard 1.4.14 → 1.4.16
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/admin/components/admin-abac-rules/admin-abac-rules-form/admin-abac-rules-form.component.mjs +7 -7
- package/esm2022/admin/components/admin-abac-rules/admin-abac-rules.component.mjs +3 -3
- package/esm2022/admin/components/admin-abac-rules/components/attribute-condition/attribute-condition.component.mjs +7 -7
- package/esm2022/admin/components/admin-abac-rules/components/composed-condition/composed-condition.component.mjs +10 -10
- package/esm2022/admin/components/admin-abac-rules/components/metadata-condition/metadata-condition.component.mjs +6 -6
- package/esm2022/admin/components/admin-abac-rules/components/select-attribute/select-attribute.component.mjs +3 -3
- package/esm2022/admin/components/admin-abac-rules/components/select-metadata/select-metadata.component.mjs +3 -3
- package/esm2022/admin/components/admin-classes/admin-classes-customize/admin-classes-customize.component.mjs +10 -10
- package/esm2022/admin/components/admin-classes/admin-classes-customize/symbol/admin-classes-customize-symbol.component.mjs +10 -15
- package/esm2022/admin/components/admin-classes/admin-classes-customize/tooltip/admin-classes-customize-tooltip.component.mjs +8 -8
- package/esm2022/admin/components/admin-classes/admin-classes-edit/admin-classes-edit.component.mjs +5 -5
- package/esm2022/admin/components/admin-classes/admin-classes-form/admin-classes-form.component.mjs +5 -5
- package/esm2022/admin/components/admin-classes/admin-classes-select/admin-classes-select.component.mjs +6 -6
- package/esm2022/admin/components/admin-classes/admin-classes-view/admin-attributes-edit/admin-attributes-edit.component.mjs +5 -5
- package/esm2022/admin/components/admin-classes/admin-classes-view/admin-attributes-form/admin-attributes-form.component.mjs +3 -3
- package/esm2022/admin/components/admin-classes/admin-classes-view/admin-attributes-new/admin-attributes-new.component.mjs +5 -5
- package/esm2022/admin/components/admin-classes/admin-classes-view/admin-attributes-select/admin-attributes-select.component.mjs +6 -6
- package/esm2022/admin/components/admin-classes/admin-classes-view/admin-classes-view.component.mjs +3 -3
- package/esm2022/admin/components/admin-classes/admin-classes.component.mjs +5 -5
- package/esm2022/admin/components/admin-dataset/admin-dataset.component.mjs +6 -6
- package/esm2022/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.mjs +7 -7
- package/esm2022/admin/components/admin-environment/admin-environment-form/admin-environment-form.component.mjs +3 -3
- package/esm2022/admin/components/admin-environment/admin-environment-select/admin-environment-select.component.mjs +5 -5
- package/esm2022/admin/components/admin-environment/admin-environment-update/admin-environment-update.component.mjs +5 -5
- package/esm2022/admin/components/admin-environment/admin-environment.component.mjs +5 -5
- package/esm2022/admin/components/admin-fields/admin-fields-edit/admin-fields-edit.component.mjs +5 -5
- package/esm2022/admin/components/admin-fields/admin-fields-select/admin-fields-select.component.mjs +3 -3
- package/esm2022/admin/components/admin-layout/admin-layout.component.mjs +3 -3
- package/esm2022/admin/components/admin-links/admin-links-new/admin-links-new.component.mjs +5 -5
- package/esm2022/admin/components/admin-links/admin-links.component.mjs +5 -5
- package/esm2022/admin/components/admin-menu/admin-menu.component.mjs +5 -5
- package/esm2022/admin/components/admin-metadata/admin-edit-metadata/admin-edit-metadata.component.mjs +5 -5
- package/esm2022/admin/components/admin-metadata/admin-select-metadata/admin-select-metadata.component.mjs +5 -5
- package/esm2022/admin/components/admin-metadata/shared/form-metadata/form-metadata.component.mjs +4 -5
- package/esm2022/admin/components/admin-metadata/shared/list-metadata/pry-list-metadata.component.mjs +5 -6
- package/esm2022/admin/components/admin-metadata-rules/admin-metadata-rules.component.mjs +5 -5
- package/esm2022/admin/components/admin-metadata-rules/admin-select-metadata-rules/admin-select-metadata-rules.component.mjs +5 -5
- package/esm2022/admin/components/admin-metadata-rules/shared/admin-form-metadata-rules/admin-form-metadata-rules.component.mjs +4 -5
- package/esm2022/admin/components/admin-metadata-user/admin-user-edit-metadata/admin-user-edit-metadata.component.mjs +5 -5
- package/esm2022/admin/components/admin-metadata-user/admin-user-select-metadata/admin-user-select-metadata.component.mjs +5 -5
- package/esm2022/admin/components/admin-predicates/admin-predicates-form/admin-predicates-form.component.mjs +5 -5
- package/esm2022/admin/components/admin-predicates/admin-predicates-select/admin-predicates-select.component.mjs +5 -5
- package/esm2022/admin/components/admin-predicates/admin-predicates-update/admin-predicates-update.component.mjs +5 -5
- package/esm2022/admin/components/admin-predicates/admin-predicates.component.mjs +5 -5
- package/esm2022/admin/components/admin-relation-types/admin-relation-types-modal/admin-relation-types-modal.component.mjs +4 -5
- package/esm2022/admin/components/admin-relation-types/admin-relation-types-select/admin-relation-types-select.component.mjs +5 -5
- package/esm2022/admin/components/admin-relation-types/admin-relation-types.component.mjs +6 -6
- package/esm2022/admin/components/admin-user/admin-user-select/admin-user-select.component.mjs +6 -6
- package/esm2022/admin/components/admin-user/admin-user.component.mjs +5 -5
- package/esm2022/admin/components/association/association.component.mjs +4 -5
- package/esm2022/components/card/card.component.mjs +5 -6
- package/esm2022/components/metadata-editor/metadata-editor.component.mjs +6 -6
- package/esm2022/components/scheme-picker/scheme-picker.component.mjs +7 -7
- package/esm2022/components/stepper/stepper.component.mjs +3 -4
- package/esm2022/dataset/components/dataset-detail/dataset-detail.component.mjs +5 -5
- package/esm2022/dataset/components/dataset-version-form/dataset-version-form.component.mjs +6 -7
- package/esm2022/filters/date/date-filter.component.mjs +5 -6
- package/esm2022/filters/list/list-filter.component.mjs +6 -7
- package/esm2022/filters/number/number-filter.component.mjs +5 -6
- package/esm2022/filters/text/text-filter.component.mjs +5 -6
- package/esm2022/lib/core/components/about/about.component.mjs +3 -3
- package/esm2022/lib/core/components/accordion/accordion-item/accordion-item.component.mjs +7 -7
- package/esm2022/lib/core/components/base-menu/base-menu.component.mjs +6 -6
- package/esm2022/lib/core/components/base-toolbox/base-toolbox.component.mjs +6 -6
- package/esm2022/lib/core/components/base-toolbox-action/base-toolbox-action.component.mjs +6 -7
- package/esm2022/lib/core/components/date-picker/date-picker.component.mjs +4 -4
- package/esm2022/lib/core/components/date-picker/time-picker/loop-scroll-column/loop-scroll-column.component.mjs +3 -4
- package/esm2022/lib/core/components/date-picker/time-picker/time-picker.component.mjs +6 -6
- package/esm2022/lib/core/components/edit-input/edit-input.component.mjs +7 -8
- package/esm2022/lib/core/components/icon/icon.component.mjs +3 -3
- package/esm2022/lib/core/components/modal/modal.component.mjs +5 -6
- package/esm2022/lib/core/components/nq-color-selector/nq-color-selector.component.mjs +5 -5
- package/esm2022/lib/core/components/overlay/dialog-confirm.component.mjs +3 -3
- package/esm2022/lib/core/components/range/range.component.mjs +5 -6
- package/esm2022/lib/core/components/select/select.component.mjs +3 -3
- package/esm2022/lib/core/components/select-image/select-image.component.mjs +5 -5
- package/esm2022/lib/core/components/share/group-share/group-share.component.mjs +6 -6
- package/esm2022/lib/core/components/snackbar/snackbar/snackbar.component.mjs +3 -3
- package/esm2022/lib/core/components/status-modal/status-modal.component.mjs +5 -5
- package/esm2022/lib/core/components/tabs/tab-group.component.mjs +3 -3
- package/esm2022/lib/core/components/toggle/toggle.component.mjs +4 -4
- package/esm2022/lib/core/store/data-source/data-source.effects.mjs +9 -9
- package/esm2022/lib/core/store/search/search.effects.mjs +4 -2
- package/esm2022/lib/core/store/search/search.service.mjs +3 -7
- package/esm2022/lib/core/toolbox/toolbox-manifest.service.mjs +3 -3
- package/esm2022/lib/dashboard/action-bus/service/bus.service.mjs +2 -2
- package/esm2022/lib/dashboard/components/context-menu/context-menu.component.mjs +8 -8
- package/esm2022/lib/dashboard/components/dashboard.component.mjs +12 -12
- package/esm2022/lib/dashboard/components/manifests/manifests.component.mjs +5 -5
- package/esm2022/lib/dashboard/components/metadata/metadata.component.mjs +5 -6
- package/esm2022/lib/dashboard/components/vizualize-raw/vizualize-raw.component.mjs +3 -3
- package/esm2022/lib/dashboard/components/widgets/datasource-selector/datasource-selector.component.mjs +6 -6
- package/esm2022/lib/dashboard/components/widgets/header/widget-header.component.mjs +10 -10
- package/esm2022/lib/dashboard/components/widgets/widget-filler/widget-filler.component.mjs +2 -2
- package/esm2022/lib/dashboard/components/widgets/widget-placement/widget-placement.utils.mjs +2 -2
- package/esm2022/lib/dashboard/filter/components/filter-group/filter-group.component.mjs +7 -7
- package/esm2022/lib/dashboard/resultset-utils.mjs +7 -8
- package/esm2022/lib/dashboard/store/dashboard.effects.mjs +4 -4
- package/esm2022/lib/dashboard/store/dashboard.reducers.mjs +13 -24
- package/esm2022/lib/dashboard/tooltip/components/default/default.tooltip.component.mjs +3 -3
- package/esm2022/notification/components/notification/content/notification-content.component.mjs +3 -3
- package/esm2022/notification/components/notification/notification.component.mjs +5 -5
- package/esm2022/pipeline/components/pipeline-details/pipeline-details.component.mjs +7 -7
- package/esm2022/pipeline/components/pipeline-editor/graph-serializer.utils.mjs +2 -2
- package/esm2022/pipeline/components/pipeline-editor/pipeline-editor.component.mjs +5 -5
- package/esm2022/pipeline/components/pipeline-list/pipeline-list.component.mjs +9 -9
- package/esm2022/presentation/components/add-edit-presentation/add-edit-presentation.component.mjs +6 -6
- package/esm2022/presentation/components/presentation.component.mjs +6 -6
- package/esm2022/presentation/components/title-presentation/title-presentation.component.mjs +5 -5
- package/esm2022/restitution/components/restitution/restitution.component.mjs +3 -3
- package/esm2022/restitution/components/restitution-catalog/restitution-catalog.component.mjs +9 -9
- package/esm2022/restitution/components/restitution-list-item/restitution-list-item.component.mjs +3 -3
- package/esm2022/search/components/choose-widget/choose-widget.component.mjs +5 -5
- package/esm2022/search/components/edit-named-query/edit-named-query.component.mjs +9 -9
- package/esm2022/search/search-fulltext/search-fulltext/search-fulltext.component.mjs +3 -3
- package/esm2022/search/search-home/search-home.component.mjs +3 -3
- package/esm2022/search/search-mono-class/components/search-composed/search-composed.component.mjs +3 -3
- package/esm2022/search/search-mono-class/components/search-condition/search-condition.component.mjs +3 -3
- package/esm2022/search/search-mono-class/components/search-mono-class/search-mono-class.component.mjs +8 -8
- package/esm2022/search/search-mono-class/components/search-order/search-order.component.mjs +6 -6
- package/esm2022/search/search-mono-class/components/search-select-attribute/search-select-attribute.component.mjs +3 -3
- package/esm2022/search/search-multi-class/components/multi-class-condition/multi-class-condition.component.mjs +7 -7
- package/esm2022/search/search-multi-class/components/multi-class-field-selection/multi-class-field-selection.component.mjs +6 -6
- package/esm2022/search/search-multi-class/components/search-multi-class/search-multi-class.component.mjs +7 -7
- package/esm2022/search/search-tools/search-tools.component.mjs +13 -13
- package/esm2022/toolbox/components/named-query/named-query.component.mjs +5 -5
- package/esm2022/toolbox/components/save-view/save-view.component.mjs +10 -10
- package/esm2022/toolbox/components/select-grid-layout/select-grid-layout.component.mjs +8 -8
- package/esm2022/toolbox/shared/presentation-form/presentation-form.component.mjs +5 -6
- package/esm2022/tooltips/attribute/attribute-tooltip.component.mjs +3 -3
- package/esm2022/widgets/widget-aggregated-chart/component/widget-aggregated-chart.component.mjs +4 -4
- package/esm2022/widgets/widget-analytic/component/widget-analytic.component.mjs +2 -2
- package/esm2022/widgets/widget-chart/component/widget-chart.component.mjs +12 -12
- package/esm2022/widgets/widget-detail/component/widget-detail.component.mjs +13 -7
- package/esm2022/widgets/widget-graph/component/widget-graph.component.mjs +7 -7
- package/esm2022/widgets/widget-iframe/component/widget-iframe.component.mjs +7 -7
- package/esm2022/widgets/widget-iframe/messaging/iframe-messaging.service.mjs +2 -2
- package/esm2022/widgets/widget-map/component/widget-map.component.mjs +10 -10
- package/esm2022/widgets/widget-map/utils/widget-map.utils.mjs +2 -2
- package/esm2022/widgets/widget-table/component/widget-table.component.mjs +2 -2
- package/esm2022/widgets/widget-table/expand-value/expand-value.component.mjs +4 -5
- package/esm2022/widgets/widget-template/component/widget-template.component.mjs +7 -7
- package/esm2022/widgets/widget-tile/component/widget-tile.component.mjs +10 -10
- package/esm2022/widgets/widget-vega/component/widget-vega.component.mjs +9 -9
- package/fesm2022/provoly-dashboard-admin.mjs +171 -175
- package/fesm2022/provoly-dashboard-admin.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-components-card.mjs +4 -5
- package/fesm2022/provoly-dashboard-components-card.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-components-metadata-editor.mjs +4 -4
- package/fesm2022/provoly-dashboard-components-metadata-editor.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-components-scheme-picker.mjs +6 -6
- package/fesm2022/provoly-dashboard-components-scheme-picker.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-components-stepper.mjs +2 -3
- package/fesm2022/provoly-dashboard-components-stepper.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-dataset.mjs +14 -14
- package/fesm2022/provoly-dashboard-dataset.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-filters-date.mjs +4 -5
- package/fesm2022/provoly-dashboard-filters-date.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-filters-list.mjs +4 -5
- package/fesm2022/provoly-dashboard-filters-list.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-filters-number.mjs +4 -5
- package/fesm2022/provoly-dashboard-filters-number.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-filters-text.mjs +4 -5
- package/fesm2022/provoly-dashboard-filters-text.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-notification.mjs +4 -4
- package/fesm2022/provoly-dashboard-notification.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-pipeline.mjs +21 -21
- package/fesm2022/provoly-dashboard-pipeline.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-presentation.mjs +14 -14
- package/fesm2022/provoly-dashboard-presentation.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-restitution.mjs +6 -6
- package/fesm2022/provoly-dashboard-restitution.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-search.mjs +35 -35
- package/fesm2022/provoly-dashboard-search.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-toolbox.mjs +25 -25
- 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-aggregated-chart.mjs +3 -3
- package/fesm2022/provoly-dashboard-widgets-widget-aggregated-chart.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-analytic.mjs +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-analytic.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-chart.mjs +10 -10
- package/fesm2022/provoly-dashboard-widgets-widget-chart.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-detail.mjs +11 -5
- package/fesm2022/provoly-dashboard-widgets-widget-detail.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-graph.mjs +5 -5
- package/fesm2022/provoly-dashboard-widgets-widget-graph.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-iframe.mjs +8 -8
- package/fesm2022/provoly-dashboard-widgets-widget-iframe.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-map.mjs +9 -9
- package/fesm2022/provoly-dashboard-widgets-widget-map.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-table.mjs +6 -6
- package/fesm2022/provoly-dashboard-widgets-widget-table.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-template.mjs +7 -7
- package/fesm2022/provoly-dashboard-widgets-widget-template.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-tile.mjs +11 -11
- package/fesm2022/provoly-dashboard-widgets-widget-tile.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-vega.mjs +7 -7
- package/fesm2022/provoly-dashboard-widgets-widget-vega.mjs.map +1 -1
- package/fesm2022/provoly-dashboard.mjs +204 -219
- package/fesm2022/provoly-dashboard.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -7,9 +7,9 @@ import * as i0 from "@angular/core";
|
|
|
7
7
|
import * as i1 from "@ngrx/store";
|
|
8
8
|
import * as i2 from "@provoly/dashboard";
|
|
9
9
|
import * as i3 from "@angular/router";
|
|
10
|
-
import * as i4 from "@angular/
|
|
11
|
-
import * as i5 from "@
|
|
12
|
-
import * as i6 from "@
|
|
10
|
+
import * as i4 from "@angular/forms";
|
|
11
|
+
import * as i5 from "@provoly/dashboard/components/page-loader";
|
|
12
|
+
import * as i6 from "@angular/common";
|
|
13
13
|
export class AdminDatasetComponent {
|
|
14
14
|
constructor(store, translateService, router, route) {
|
|
15
15
|
this.store = store;
|
|
@@ -73,13 +73,13 @@ export class AdminDatasetComponent {
|
|
|
73
73
|
this.store.dispatch(AdminActions.selectComponentType({ componentType: 'AdminSelectDatasetComponent' }));
|
|
74
74
|
}
|
|
75
75
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: AdminDatasetComponent, deps: [{ token: i1.Store }, { token: i2.PryI18nService }, { token: i3.Router }, { token: i3.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
76
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: AdminDatasetComponent, selector: "pry-admin-dataset", viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }], ngImport: i0, template: "<div class=\"o-base-container u-display-flex -column\">\n <h1 class=\"a-h1\">{{ '@pry.admin.dataset.title' | i18n }}</h1>\n @if (loading$ | async; as loading) {\n <div class=\"a-page-loader -relative\" [style.display]=\"'flex'\">\n <pry-page-loader></pry-page-loader>\n <p>{{ '@pry.widget.target.loading' | i18n }}...</p>\n </div>\n } @else {\n @if (datasetList$ | async; as datasetList) {\n <table\n class=\"a-table\"\n prySortTable\n prySortActive=\"name\"\n prySortDirection=\"asc\"\n (prySortChange)=\"sortActive = $event.active; sortDirection = $event.direction\"\n
|
|
76
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: AdminDatasetComponent, selector: "pry-admin-dataset", viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }], ngImport: i0, template: "<div class=\"o-base-container u-display-flex -column\">\n <h1 class=\"a-h1\">{{ '@pry.admin.dataset.title' | i18n }}</h1>\n @if (loading$ | async; as loading) {\n <div class=\"a-page-loader -relative\" [style.display]=\"'flex'\">\n <pry-page-loader></pry-page-loader>\n <p>{{ '@pry.widget.target.loading' | i18n }}...</p>\n </div>\n } @else {\n @if (datasetList$ | async; as datasetList) {\n <table\n class=\"a-table\"\n prySortTable\n prySortActive=\"name\"\n prySortDirection=\"asc\"\n (prySortChange)=\"sortActive = $event.active; sortDirection = $event.direction\"\n >\n <caption>\n {{\n '@pry.admin.dataset.title' | i18n\n }},\n {{\n '@pry.action.sortableColumnHeader' | i18n\n }}\n </caption>\n <thead>\n <tr>\n <th></th>\n @for (conf of configHeader; track conf) {\n <th [prySortHeader]=\"conf.label\">{{ conf.label }}</th>\n }\n <th></th>\n </tr>\n </thead>\n <tbody>\n @for (dataset of datasetList | prySortData: sortActive : sortDirection; track dataset) {\n <tr\n (click)=\"selectDataset(dataset)\"\n [class.is-selected]=\"(selectedDataset$ | async) === dataset.id\"\n >\n <td class=\"view-details\">\n <button\n id=\"button-dataset- + {{ dataset.id }}\"\n type=\"button\"\n class=\"a-btn a-btn--icon-only\"\n title=\"{{ '@pry.action.viewDetails' | i18n }}\"\n [attr.aria-expanded]=\"(selectedDataset$ | async) === dataset.id\"\n aria-haspopup\n [attr.aria-controls]=\"'panel-dataset-' + dataset.id\"\n >\n <span class=\"u-visually-hidden\">{{ dataset.name }}, {{ '@pry.action.viewDetails' | i18n }}</span>\n <pry-icon iconSvg=\"eye\" [width]=\"15\" [height]=\"15\"></pry-icon>\n </button>\n </td>\n <td>{{ dataset.name }}</td>\n <td>{{ dataset.oClass | translateId: { type: 'class', output: 'name' } | async }}</td>\n <td>{{ '@pry.admin.dataset.' + dataset.type | i18n }}</td>\n <td>\n <pry-icon\n [iconSvg]=\"getShareLevel(dataset.groups).toLowerCase()\"\n class=\"a-tooltip -tooltip-no-wrap\"\n [attr.data-tooltip]=\"'@pry.share.iconLabel.' + getShareLevel(dataset.groups) | i18n\"\n data-tooltip-position=\"left\"\n [height]=\"17\"\n [width]=\"17\"\n ></pry-icon>\n </td>\n </tr>\n }\n </tbody>\n </table>\n }\n }\n</div>\n\n<pry-modal\n [titleModal]=\"'@pry.toolbox.rename' | i18n\"\n [validateLabel]=\"'@pry.toolbox.manifest.check' | i18n\"\n [validateAction]=\"validateAction\"\n [cancelLabel]=\"'@pry.toolbox.manifest.close' | i18n\"\n [cancelAction]=\"cancelAction\"\n [opened]=\"this.editOpened\"\n >\n <div class=\"field__input\">\n <span>{{ '@pry.toolbox.manifest.name' | i18n }}</span>\n <input\n type=\"text\"\n (keyup.enter)=\"validateName(input.value)\"\n [ngModel]=\"labelDatasetSelected\"\n (ngModelChange)=\"changeValue($event)\"\n #input\n />\n </div>\n</pry-modal>\n", dependencies: [{ kind: "component", type: i2.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { 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: i2.PrySortHeaderComponent, selector: "th[prySortHeader]", inputs: ["prySortHeader"], outputs: ["sortChange"] }, { kind: "directive", type: i2.PrySortHeaderDirective, selector: "[prySortHeader]" }, { kind: "directive", type: i2.PrySortTableDirective, selector: "[prySortTable]", inputs: ["prySortActive", "prySortDirection"], outputs: ["prySortChange"] }, { kind: "component", type: i2.PryModalComponent, selector: "pry-modal", inputs: ["titleModal", "opened", "validateLabel", "validateAction", "cancelLabel", "cancelAction"] }, { kind: "component", type: i5.PryPageLoaderComponent, selector: "pry-page-loader", inputs: ["image", "imageAltText"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i2.TranslateIdPipe, name: "translateId" }, { kind: "pipe", type: i2.PrySortDataPipe, name: "prySortData" }, { kind: "pipe", type: i2.I18nPipe, name: "i18n" }] }); }
|
|
77
77
|
}
|
|
78
78
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: AdminDatasetComponent, decorators: [{
|
|
79
79
|
type: Component,
|
|
80
|
-
args: [{ selector: 'pry-admin-dataset', template: "<div class=\"o-base-container u-display-flex -column\">\n <h1 class=\"a-h1\">{{ '@pry.admin.dataset.title' | i18n }}</h1>\n @if (loading$ | async; as loading) {\n <div class=\"a-page-loader -relative\" [style.display]=\"'flex'\">\n <pry-page-loader></pry-page-loader>\n <p>{{ '@pry.widget.target.loading' | i18n }}...</p>\n </div>\n } @else {\n @if (datasetList$ | async; as datasetList) {\n <table\n class=\"a-table\"\n prySortTable\n prySortActive=\"name\"\n prySortDirection=\"asc\"\n (prySortChange)=\"sortActive = $event.active; sortDirection = $event.direction\"\n
|
|
80
|
+
args: [{ selector: 'pry-admin-dataset', template: "<div class=\"o-base-container u-display-flex -column\">\n <h1 class=\"a-h1\">{{ '@pry.admin.dataset.title' | i18n }}</h1>\n @if (loading$ | async; as loading) {\n <div class=\"a-page-loader -relative\" [style.display]=\"'flex'\">\n <pry-page-loader></pry-page-loader>\n <p>{{ '@pry.widget.target.loading' | i18n }}...</p>\n </div>\n } @else {\n @if (datasetList$ | async; as datasetList) {\n <table\n class=\"a-table\"\n prySortTable\n prySortActive=\"name\"\n prySortDirection=\"asc\"\n (prySortChange)=\"sortActive = $event.active; sortDirection = $event.direction\"\n >\n <caption>\n {{\n '@pry.admin.dataset.title' | i18n\n }},\n {{\n '@pry.action.sortableColumnHeader' | i18n\n }}\n </caption>\n <thead>\n <tr>\n <th></th>\n @for (conf of configHeader; track conf) {\n <th [prySortHeader]=\"conf.label\">{{ conf.label }}</th>\n }\n <th></th>\n </tr>\n </thead>\n <tbody>\n @for (dataset of datasetList | prySortData: sortActive : sortDirection; track dataset) {\n <tr\n (click)=\"selectDataset(dataset)\"\n [class.is-selected]=\"(selectedDataset$ | async) === dataset.id\"\n >\n <td class=\"view-details\">\n <button\n id=\"button-dataset- + {{ dataset.id }}\"\n type=\"button\"\n class=\"a-btn a-btn--icon-only\"\n title=\"{{ '@pry.action.viewDetails' | i18n }}\"\n [attr.aria-expanded]=\"(selectedDataset$ | async) === dataset.id\"\n aria-haspopup\n [attr.aria-controls]=\"'panel-dataset-' + dataset.id\"\n >\n <span class=\"u-visually-hidden\">{{ dataset.name }}, {{ '@pry.action.viewDetails' | i18n }}</span>\n <pry-icon iconSvg=\"eye\" [width]=\"15\" [height]=\"15\"></pry-icon>\n </button>\n </td>\n <td>{{ dataset.name }}</td>\n <td>{{ dataset.oClass | translateId: { type: 'class', output: 'name' } | async }}</td>\n <td>{{ '@pry.admin.dataset.' + dataset.type | i18n }}</td>\n <td>\n <pry-icon\n [iconSvg]=\"getShareLevel(dataset.groups).toLowerCase()\"\n class=\"a-tooltip -tooltip-no-wrap\"\n [attr.data-tooltip]=\"'@pry.share.iconLabel.' + getShareLevel(dataset.groups) | i18n\"\n data-tooltip-position=\"left\"\n [height]=\"17\"\n [width]=\"17\"\n ></pry-icon>\n </td>\n </tr>\n }\n </tbody>\n </table>\n }\n }\n</div>\n\n<pry-modal\n [titleModal]=\"'@pry.toolbox.rename' | i18n\"\n [validateLabel]=\"'@pry.toolbox.manifest.check' | i18n\"\n [validateAction]=\"validateAction\"\n [cancelLabel]=\"'@pry.toolbox.manifest.close' | i18n\"\n [cancelAction]=\"cancelAction\"\n [opened]=\"this.editOpened\"\n >\n <div class=\"field__input\">\n <span>{{ '@pry.toolbox.manifest.name' | i18n }}</span>\n <input\n type=\"text\"\n (keyup.enter)=\"validateName(input.value)\"\n [ngModel]=\"labelDatasetSelected\"\n (ngModelChange)=\"changeValue($event)\"\n #input\n />\n </div>\n</pry-modal>\n" }]
|
|
81
81
|
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.PryI18nService }, { type: i3.Router }, { type: i3.ActivatedRoute }], propDecorators: { input: [{
|
|
82
82
|
type: ViewChild,
|
|
83
83
|
args: ['input']
|
|
84
84
|
}] } });
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-dataset.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/admin/components/admin-dataset/admin-dataset.component.ts","../../../../../../../projects/provoly/dashboard/admin/components/admin-dataset/admin-dataset.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, ViewChild } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  ClassActions,\n  ClassSelectors,\n  Dataset,\n  DataSourceActions,\n  DataSourceSelectors,\n  DataSourceState,\n  getShareLevel,\n  PryI18nService\n} from '@provoly/dashboard';\nimport { Observable } from 'rxjs';\nimport { AdminActions } from '../../store/admin.actions';\nimport { IConfigHeader } from '../admin-metadata/shared/list-metadata/pry-list-metadata.component';\nimport { AdminDatasetActions } from './store/admin-dataset.actions';\nimport { AdminDatasetSelectors } from './store/admin-dataset.selectors';\n\n@Component({\n  selector: 'pry-admin-dataset',\n  templateUrl: './admin-dataset.component.html'\n})\nexport class AdminDatasetComponent {\n  @ViewChild('input') input!: ElementRef;\n  datasetList$: Observable<Dataset[]>;\n  selectedDataset$: Observable<string | undefined>;\n  sortActive? = 'name';\n  sortDirection? = 'asc';\n  value: string = '';\n  configHeader: Array<IConfigHeader>;\n  labelDatasetSelected: string = '';\n  editOpened: boolean = false;\n  loading$: Observable<boolean>;\n\n  validateAction: () => void;\n  cancelAction: () => void;\n\n  constructor(\n    private store: Store<DataSourceState>,\n    private translateService: PryI18nService,\n    private router: Router,\n    private route: ActivatedRoute\n  ) {\n    this.loading$ = this.store.select(ClassSelectors.loading);\n    this.store.dispatch(DataSourceActions.dataset.loadDataset());\n    this.store.dispatch(ClassActions.load());\n    this.validateAction = () => this.validateName(this.labelDatasetSelected);\n    this.cancelAction = () => this.cancelEdition();\n    this.configHeader = [\n      { headerType: 'label', label: this.translateService.instant('@pry.admin.dataset.name') },\n      { headerType: 'label', label: this.translateService.instant('@pry.admin.dataset.oClass') },\n      { headerType: 'label', label: this.translateService.instant('@pry.admin.dataset.type') }\n    ];\n    this.datasetList$ = this.store.select(DataSourceSelectors.datasets);\n    this.selectedDataset$ = this.store.select(AdminDatasetSelectors.selectedDatasetId);\n    this.store.dispatch(AdminDatasetActions.unselectDataset());\n    const path = this.router.createUrlTree(['.', 'new'], { relativeTo: this.route });\n    this.store.dispatch(\n      AdminActions.mainActions({\n        actions: [\n          {\n            action: AdminDatasetActions.openNewDataset({ route: 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  cancelEdition(): void {\n    this.toggleEditionDataset();\n    this.store.dispatch(AdminDatasetActions.unselectDataset());\n  }\n\n  toggleEditionDataset(): void {\n    this.editOpened = !this.editOpened;\n    if (this.editOpened) {\n      setTimeout(() => {\n        this.input.nativeElement.focus();\n      }, 10);\n    }\n  }\n\n  validateName(newLabel: string): void {\n    this.toggleEditionDataset();\n  }\n\n  changeValue($event: any) {\n    this.labelDatasetSelected = $event;\n  }\n\n  selectDataset(dataset: Dataset) {\n    this.store.dispatch(AdminActions.fetchDatasetAssociations({ id: dataset.id }));\n    this.store.dispatch(AdminDatasetActions.selectDataset({ dataset }));\n    this.store.dispatch(AdminActions.selectComponentType({ componentType: 'AdminSelectDatasetComponent' }));\n  }\n\n  protected readonly getShareLevel = getShareLevel;\n}\n","<div class=\"o-base-container u-display-flex -column\">\n  <h1 class=\"a-h1\">{{ '@pry.admin.dataset.title' | i18n }}</h1>\n  @if (loading$ | async; as loading) {\n    <div class=\"a-page-loader -relative\" [style.display]=\"'flex'\">\n      <pry-page-loader></pry-page-loader>\n      <p>{{ '@pry.widget.target.loading' | i18n }}...</p>\n    </div>\n  } @else {\n    @if (datasetList$ | async; as datasetList) {\n      <table\n        class=\"a-table\"\n        prySortTable\n        prySortActive=\"name\"\n        prySortDirection=\"asc\"\n        (prySortChange)=\"sortActive = $event.active; sortDirection = $event.direction\"\n      >\n        <caption>\n          {{\n            '@pry.admin.dataset.title' | i18n\n          }},\n          {{\n            '@pry.action.sortableColumnHeader' | i18n\n          }}\n        </caption>\n        <thead>\n          <tr>\n            <th></th>\n            <th *ngFor=\"let conf of configHeader\" [prySortHeader]=\"conf.label\">{{ conf.label }}</th>\n            <th></th>\n          </tr>\n        </thead>\n        <tbody>\n          <tr\n            *ngFor=\"let dataset of datasetList | prySortData: sortActive : sortDirection\"\n            (click)=\"selectDataset(dataset)\"\n            [class.is-selected]=\"(selectedDataset$ | async) === dataset.id\"\n          >\n            <td class=\"view-details\">\n              <button\n                id=\"button-dataset- + {{ dataset.id }}\"\n                type=\"button\"\n                class=\"a-btn a-btn--icon-only\"\n                title=\"{{ '@pry.action.viewDetails' | i18n }}\"\n                [attr.aria-expanded]=\"(selectedDataset$ | async) === dataset.id\"\n                aria-haspopup\n                [attr.aria-controls]=\"'panel-dataset-' + dataset.id\"\n              >\n                <span class=\"u-visually-hidden\">{{ dataset.name }}, {{ '@pry.action.viewDetails' | i18n }}</span>\n                <pry-icon iconSvg=\"eye\" [width]=\"15\" [height]=\"15\"></pry-icon>\n              </button>\n            </td>\n            <td>{{ dataset.name }}</td>\n            <td>{{ dataset.oClass | translateId: { type: 'class', output: 'name' } | async }}</td>\n            <td>{{ '@pry.admin.dataset.' + dataset.type | i18n }}</td>\n            <td>\n              <pry-icon\n                [iconSvg]=\"getShareLevel(dataset.groups).toLowerCase()\"\n                class=\"a-tooltip -tooltip-no-wrap\"\n                [attr.data-tooltip]=\"'@pry.share.iconLabel.' + getShareLevel(dataset.groups) | i18n\"\n                data-tooltip-position=\"left\"\n                [height]=\"17\"\n                [width]=\"17\"\n              ></pry-icon>\n            </td>\n          </tr>\n        </tbody>\n      </table>\n    }\n  }\n</div>\n\n<pry-modal\n  [titleModal]=\"'@pry.toolbox.rename' | i18n\"\n  [validateLabel]=\"'@pry.toolbox.manifest.check' | i18n\"\n  [validateAction]=\"validateAction\"\n  [cancelLabel]=\"'@pry.toolbox.manifest.close' | i18n\"\n  [cancelAction]=\"cancelAction\"\n  [opened]=\"this.editOpened\"\n>\n  <div class=\"field__input\">\n    <span>{{ '@pry.toolbox.manifest.name' | i18n }}</span>\n    <input\n      type=\"text\"\n      (keyup.enter)=\"validateName(input.value)\"\n      [ngModel]=\"labelDatasetSelected\"\n      (ngModelChange)=\"changeValue($event)\"\n      #input\n    />\n  </div>\n</pry-modal>\n"]}
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-dataset.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/admin/components/admin-dataset/admin-dataset.component.ts","../../../../../../../projects/provoly/dashboard/admin/components/admin-dataset/admin-dataset.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, ViewChild } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  ClassActions,\n  ClassSelectors,\n  Dataset,\n  DataSourceActions,\n  DataSourceSelectors,\n  DataSourceState,\n  getShareLevel,\n  PryI18nService\n} from '@provoly/dashboard';\nimport { Observable } from 'rxjs';\nimport { AdminActions } from '../../store/admin.actions';\nimport { IConfigHeader } from '../admin-metadata/shared/list-metadata/pry-list-metadata.component';\nimport { AdminDatasetActions } from './store/admin-dataset.actions';\nimport { AdminDatasetSelectors } from './store/admin-dataset.selectors';\n\n@Component({\n  selector: 'pry-admin-dataset',\n  templateUrl: './admin-dataset.component.html'\n})\nexport class AdminDatasetComponent {\n  @ViewChild('input') input!: ElementRef;\n  datasetList$: Observable<Dataset[]>;\n  selectedDataset$: Observable<string | undefined>;\n  sortActive? = 'name';\n  sortDirection? = 'asc';\n  value: string = '';\n  configHeader: Array<IConfigHeader>;\n  labelDatasetSelected: string = '';\n  editOpened: boolean = false;\n  loading$: Observable<boolean>;\n\n  validateAction: () => void;\n  cancelAction: () => void;\n\n  constructor(\n    private store: Store<DataSourceState>,\n    private translateService: PryI18nService,\n    private router: Router,\n    private route: ActivatedRoute\n  ) {\n    this.loading$ = this.store.select(ClassSelectors.loading);\n    this.store.dispatch(DataSourceActions.dataset.loadDataset());\n    this.store.dispatch(ClassActions.load());\n    this.validateAction = () => this.validateName(this.labelDatasetSelected);\n    this.cancelAction = () => this.cancelEdition();\n    this.configHeader = [\n      { headerType: 'label', label: this.translateService.instant('@pry.admin.dataset.name') },\n      { headerType: 'label', label: this.translateService.instant('@pry.admin.dataset.oClass') },\n      { headerType: 'label', label: this.translateService.instant('@pry.admin.dataset.type') }\n    ];\n    this.datasetList$ = this.store.select(DataSourceSelectors.datasets);\n    this.selectedDataset$ = this.store.select(AdminDatasetSelectors.selectedDatasetId);\n    this.store.dispatch(AdminDatasetActions.unselectDataset());\n    const path = this.router.createUrlTree(['.', 'new'], { relativeTo: this.route });\n    this.store.dispatch(\n      AdminActions.mainActions({\n        actions: [\n          {\n            action: AdminDatasetActions.openNewDataset({ route: 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  cancelEdition(): void {\n    this.toggleEditionDataset();\n    this.store.dispatch(AdminDatasetActions.unselectDataset());\n  }\n\n  toggleEditionDataset(): void {\n    this.editOpened = !this.editOpened;\n    if (this.editOpened) {\n      setTimeout(() => {\n        this.input.nativeElement.focus();\n      }, 10);\n    }\n  }\n\n  validateName(newLabel: string): void {\n    this.toggleEditionDataset();\n  }\n\n  changeValue($event: any) {\n    this.labelDatasetSelected = $event;\n  }\n\n  selectDataset(dataset: Dataset) {\n    this.store.dispatch(AdminActions.fetchDatasetAssociations({ id: dataset.id }));\n    this.store.dispatch(AdminDatasetActions.selectDataset({ dataset }));\n    this.store.dispatch(AdminActions.selectComponentType({ componentType: 'AdminSelectDatasetComponent' }));\n  }\n\n  protected readonly getShareLevel = getShareLevel;\n}\n","<div class=\"o-base-container u-display-flex -column\">\n  <h1 class=\"a-h1\">{{ '@pry.admin.dataset.title' | i18n }}</h1>\n  @if (loading$ | async; as loading) {\n    <div class=\"a-page-loader -relative\" [style.display]=\"'flex'\">\n      <pry-page-loader></pry-page-loader>\n      <p>{{ '@pry.widget.target.loading' | i18n }}...</p>\n    </div>\n  } @else {\n    @if (datasetList$ | async; as datasetList) {\n      <table\n        class=\"a-table\"\n        prySortTable\n        prySortActive=\"name\"\n        prySortDirection=\"asc\"\n        (prySortChange)=\"sortActive = $event.active; sortDirection = $event.direction\"\n        >\n        <caption>\n          {{\n          '@pry.admin.dataset.title' | i18n\n          }},\n          {{\n          '@pry.action.sortableColumnHeader' | i18n\n          }}\n        </caption>\n        <thead>\n          <tr>\n            <th></th>\n            @for (conf of configHeader; track conf) {\n              <th [prySortHeader]=\"conf.label\">{{ conf.label }}</th>\n            }\n            <th></th>\n          </tr>\n        </thead>\n        <tbody>\n          @for (dataset of datasetList | prySortData: sortActive : sortDirection; track dataset) {\n            <tr\n              (click)=\"selectDataset(dataset)\"\n              [class.is-selected]=\"(selectedDataset$ | async) === dataset.id\"\n              >\n              <td class=\"view-details\">\n                <button\n                  id=\"button-dataset- + {{ dataset.id }}\"\n                  type=\"button\"\n                  class=\"a-btn a-btn--icon-only\"\n                  title=\"{{ '@pry.action.viewDetails' | i18n }}\"\n                  [attr.aria-expanded]=\"(selectedDataset$ | async) === dataset.id\"\n                  aria-haspopup\n                  [attr.aria-controls]=\"'panel-dataset-' + dataset.id\"\n                  >\n                  <span class=\"u-visually-hidden\">{{ dataset.name }}, {{ '@pry.action.viewDetails' | i18n }}</span>\n                  <pry-icon iconSvg=\"eye\" [width]=\"15\" [height]=\"15\"></pry-icon>\n                </button>\n              </td>\n              <td>{{ dataset.name }}</td>\n              <td>{{ dataset.oClass | translateId: { type: 'class', output: 'name' } | async }}</td>\n              <td>{{ '@pry.admin.dataset.' + dataset.type | i18n }}</td>\n              <td>\n                <pry-icon\n                  [iconSvg]=\"getShareLevel(dataset.groups).toLowerCase()\"\n                  class=\"a-tooltip -tooltip-no-wrap\"\n                  [attr.data-tooltip]=\"'@pry.share.iconLabel.' + getShareLevel(dataset.groups) | i18n\"\n                  data-tooltip-position=\"left\"\n                  [height]=\"17\"\n                  [width]=\"17\"\n                ></pry-icon>\n              </td>\n            </tr>\n          }\n        </tbody>\n      </table>\n    }\n  }\n</div>\n\n<pry-modal\n  [titleModal]=\"'@pry.toolbox.rename' | i18n\"\n  [validateLabel]=\"'@pry.toolbox.manifest.check' | i18n\"\n  [validateAction]=\"validateAction\"\n  [cancelLabel]=\"'@pry.toolbox.manifest.close' | i18n\"\n  [cancelAction]=\"cancelAction\"\n  [opened]=\"this.editOpened\"\n  >\n  <div class=\"field__input\">\n    <span>{{ '@pry.toolbox.manifest.name' | i18n }}</span>\n    <input\n      type=\"text\"\n      (keyup.enter)=\"validateName(input.value)\"\n      [ngModel]=\"labelDatasetSelected\"\n      (ngModelChange)=\"changeValue($event)\"\n      #input\n      />\n  </div>\n</pry-modal>\n"]}
|
|
@@ -11,10 +11,10 @@ import * as i0 from "@angular/core";
|
|
|
11
11
|
import * as i1 from "@ngrx/store";
|
|
12
12
|
import * as i2 from "@angular/router";
|
|
13
13
|
import * as i3 from "@provoly/dashboard";
|
|
14
|
-
import * as i4 from "@angular/
|
|
15
|
-
import * as i5 from "@
|
|
16
|
-
import * as i6 from "
|
|
17
|
-
import * as i7 from "
|
|
14
|
+
import * as i4 from "@angular/forms";
|
|
15
|
+
import * as i5 from "@provoly/dashboard/components/metadata-editor";
|
|
16
|
+
import * as i6 from "../../association/association.component";
|
|
17
|
+
import * as i7 from "@angular/common";
|
|
18
18
|
export class AdminSelectDatasetComponent extends SubscriptionnerDirective {
|
|
19
19
|
static { this.id = 'AdminSelectDatasetComponent'; }
|
|
20
20
|
constructor(store, router, route, i18n, cdr, access) {
|
|
@@ -152,15 +152,15 @@ export class AdminSelectDatasetComponent extends SubscriptionnerDirective {
|
|
|
152
152
|
return this.access ? this.access.canModifyDataset(dataset) : of(false);
|
|
153
153
|
}
|
|
154
154
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: AdminSelectDatasetComponent, deps: [{ token: i1.Store }, { token: i2.Router }, { token: i2.ActivatedRoute }, { token: i3.PryI18nService }, { token: i0.ChangeDetectorRef }, { token: PRY_ACCESS_TOKEN, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
155
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: AdminSelectDatasetComponent, selector: "pry-admin-select-dataset", usesInheritance: true, ngImport: i0, template: "
|
|
155
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: AdminSelectDatasetComponent, selector: "pry-admin-select-dataset", usesInheritance: true, ngImport: i0, template: "@if (selectedDataset$ | async; as dataset) {\n <div\n [id]=\"'panel-dataset-' + dataset.id\"\n [attr.aria-labelledby]=\"'button-dataset-' + dataset.id\"\n class=\"o-panel o-pry-admin-dataset-select\"\n >\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 <h3 class=\"a-h3\">\n {{ '@pry.admin.dataset.datasetDetails' | i18n }}\n </h3>\n </div>\n <pry-tab-group translationStringBase=\"@pry.admin.\">\n <pry-tab [templateRef]=\"datasetDetails\" name=\"dataset.details\"></pry-tab>\n <pry-tab [templateRef]=\"datasetMetadata\" name=\"metadata.title\"></pry-tab>\n <pry-tab [templateRef]=\"datasetAssociations\" name=\"classes.associations\"></pry-tab>\n @if (canModify$(dataset) | async) {\n <pry-tab [templateRef]=\"shareDataset\" name=\"share\"></pry-tab>\n }\n </pry-tab-group>\n <ng-template #datasetDetails>\n <div class=\"u-display-flex -column -gap-20\">\n <div>\n <h4 class=\"a-h4\">{{ '@pry.dataset.name' | i18n }}</h4>\n <span>{{ dataset.name }}</span>\n </div>\n <div>\n <h4 class=\"a-h4\">{{ '@pry.dataset.description' | i18n }}</h4>\n @if (dataset.description) {\n <span>{{ dataset.description }}</span>\n } @else {\n <span class=\"-italic\">{{ '@pry.dataset.noDescription' | i18n }}</span>\n }\n </div>\n <div>\n <h4 class=\"a-h4\">{{ '@pry.admin.customize.name' | i18n }}</h4>\n <span>{{ dataset.oClass | translateId: { type: 'class', output: 'name' } | async }}</span>\n </div>\n <div>\n <h4 class=\"a-h4\">{{ '@pry.admin.dataset.type' | i18n }}</h4>\n <span>{{ '@pry.admin.dataset.' + dataset.type | i18n }}</span>\n </div>\n <div>\n <h4 class=\"a-h4\">{{ '@pry.dataset.tags' | i18n }}</h4>\n @if (dataset.categories && dataset.categories.length > 0) {\n <div class=\"u-display-flex\">\n @for (category of dataset.categories; track category.id) {\n <span class=\"a-chip -md\">{{ category.name }}</span>\n }\n </div>\n } @else {\n <span class=\"-italic\">{{ '@pry.dataset.noTags' | i18n }}</span>\n }\n </div>\n </div>\n </ng-template>\n <ng-template #datasetMetadata>\n <pry-metadata-editor\n [targetId]=\"(selectedDataset$ | async)?.id ?? ''\"\n [isModification]=\"(editable$ | async) ?? false\"\n [metadata]=\"(datasetMetadata$ | async) ?? []\"\n (removeMeta)=\"removeMetadata($event)\"\n (addMeta)=\"addDatasetMetadata($event)\"\n [type]=\"'meta'\"\n ></pry-metadata-editor>\n </ng-template>\n <ng-template #datasetAssociations>\n @if (associations$ | async; as associations) {\n <div 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 }\n </ng-template>\n <ng-template #shareDataset>\n <div class=\"o-pry-admin-dataset-select__share\">\n <pry-group-share\n [ngModel]=\"dataset.groups\"\n (ngModelChange)=\"changeGroup($event)\"\n (radioValueChange)=\"updateGroups($event)\"\n ></pry-group-share>\n <button\n type=\"submit\"\n class=\"a-btn a-btn--primary u-self-end\"\n #submit\n (click)=\"share(dataset)\"\n [disabled]=\"disableShareButton$ | async\"\n >\n {{ '@pry.admin.validate' | i18n }}\n </button>\n @if (selectedDatasetMissingGroups$ | async) {\n <h4 class=\"a-h4\">{{ '@pry.admin.dataset.success' | i18n }}</h4>\n }\n @if (missingGroups$ | async; as missingGroups) {\n <div class=\"u-display-flex -column\">\n <span>{{ '@pry.admin.dataset.conflict' | i18n }}</span>\n @for (missing of missingGroups | keyvalue; track missing.key) {\n <div>\n {{ '@pry.admin.dataset.entities.dashboard' | i18n }} <strong>{{ missing.value.entityName }}</strong>\n <div class=\"u-display-flex\">\n @for (group of missing.value.groups; track group) {\n <span class=\"a-chip\">{{ getGroupLabel(group) }}</span>\n }\n </div>\n </div>\n }\n </div>\n }\n </div>\n </ng-template>\n </div>\n}\n", dependencies: [{ kind: "component", type: i3.TabGroupComponent, selector: "pry-tab-group", inputs: ["translationStringBase"], outputs: ["clickedTabIdx"] }, { kind: "component", type: i3.TabComponent, selector: "pry-tab", inputs: ["name", "templateRef", "index"] }, { kind: "component", type: i3.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { 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.PryMetadataEditorComponent, selector: "pry-metadata-editor", inputs: ["isModification", "targetId", "type", "metadata"], outputs: ["addMeta", "removeMeta"] }, { kind: "component", type: i3.PryGroupShareComponent, selector: "pry-group-share", inputs: ["disableRadios", "allowedGroups"], outputs: ["radioValueChange"] }, { kind: "component", type: i6.PryAssociationComponent, selector: "pry-association", inputs: ["associations"] }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.KeyValuePipe, name: "keyvalue" }, { kind: "pipe", type: i3.TranslateIdPipe, name: "translateId" }, { kind: "pipe", type: i3.I18nPipe, name: "i18n" }] }); }
|
|
156
156
|
}
|
|
157
157
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: AdminSelectDatasetComponent, decorators: [{
|
|
158
158
|
type: Component,
|
|
159
|
-
args: [{ selector: 'pry-admin-select-dataset', template: "
|
|
159
|
+
args: [{ selector: 'pry-admin-select-dataset', template: "@if (selectedDataset$ | async; as dataset) {\n <div\n [id]=\"'panel-dataset-' + dataset.id\"\n [attr.aria-labelledby]=\"'button-dataset-' + dataset.id\"\n class=\"o-panel o-pry-admin-dataset-select\"\n >\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 <h3 class=\"a-h3\">\n {{ '@pry.admin.dataset.datasetDetails' | i18n }}\n </h3>\n </div>\n <pry-tab-group translationStringBase=\"@pry.admin.\">\n <pry-tab [templateRef]=\"datasetDetails\" name=\"dataset.details\"></pry-tab>\n <pry-tab [templateRef]=\"datasetMetadata\" name=\"metadata.title\"></pry-tab>\n <pry-tab [templateRef]=\"datasetAssociations\" name=\"classes.associations\"></pry-tab>\n @if (canModify$(dataset) | async) {\n <pry-tab [templateRef]=\"shareDataset\" name=\"share\"></pry-tab>\n }\n </pry-tab-group>\n <ng-template #datasetDetails>\n <div class=\"u-display-flex -column -gap-20\">\n <div>\n <h4 class=\"a-h4\">{{ '@pry.dataset.name' | i18n }}</h4>\n <span>{{ dataset.name }}</span>\n </div>\n <div>\n <h4 class=\"a-h4\">{{ '@pry.dataset.description' | i18n }}</h4>\n @if (dataset.description) {\n <span>{{ dataset.description }}</span>\n } @else {\n <span class=\"-italic\">{{ '@pry.dataset.noDescription' | i18n }}</span>\n }\n </div>\n <div>\n <h4 class=\"a-h4\">{{ '@pry.admin.customize.name' | i18n }}</h4>\n <span>{{ dataset.oClass | translateId: { type: 'class', output: 'name' } | async }}</span>\n </div>\n <div>\n <h4 class=\"a-h4\">{{ '@pry.admin.dataset.type' | i18n }}</h4>\n <span>{{ '@pry.admin.dataset.' + dataset.type | i18n }}</span>\n </div>\n <div>\n <h4 class=\"a-h4\">{{ '@pry.dataset.tags' | i18n }}</h4>\n @if (dataset.categories && dataset.categories.length > 0) {\n <div class=\"u-display-flex\">\n @for (category of dataset.categories; track category.id) {\n <span class=\"a-chip -md\">{{ category.name }}</span>\n }\n </div>\n } @else {\n <span class=\"-italic\">{{ '@pry.dataset.noTags' | i18n }}</span>\n }\n </div>\n </div>\n </ng-template>\n <ng-template #datasetMetadata>\n <pry-metadata-editor\n [targetId]=\"(selectedDataset$ | async)?.id ?? ''\"\n [isModification]=\"(editable$ | async) ?? false\"\n [metadata]=\"(datasetMetadata$ | async) ?? []\"\n (removeMeta)=\"removeMetadata($event)\"\n (addMeta)=\"addDatasetMetadata($event)\"\n [type]=\"'meta'\"\n ></pry-metadata-editor>\n </ng-template>\n <ng-template #datasetAssociations>\n @if (associations$ | async; as associations) {\n <div 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 }\n </ng-template>\n <ng-template #shareDataset>\n <div class=\"o-pry-admin-dataset-select__share\">\n <pry-group-share\n [ngModel]=\"dataset.groups\"\n (ngModelChange)=\"changeGroup($event)\"\n (radioValueChange)=\"updateGroups($event)\"\n ></pry-group-share>\n <button\n type=\"submit\"\n class=\"a-btn a-btn--primary u-self-end\"\n #submit\n (click)=\"share(dataset)\"\n [disabled]=\"disableShareButton$ | async\"\n >\n {{ '@pry.admin.validate' | i18n }}\n </button>\n @if (selectedDatasetMissingGroups$ | async) {\n <h4 class=\"a-h4\">{{ '@pry.admin.dataset.success' | i18n }}</h4>\n }\n @if (missingGroups$ | async; as missingGroups) {\n <div class=\"u-display-flex -column\">\n <span>{{ '@pry.admin.dataset.conflict' | i18n }}</span>\n @for (missing of missingGroups | keyvalue; track missing.key) {\n <div>\n {{ '@pry.admin.dataset.entities.dashboard' | i18n }} <strong>{{ missing.value.entityName }}</strong>\n <div class=\"u-display-flex\">\n @for (group of missing.value.groups; track group) {\n <span class=\"a-chip\">{{ getGroupLabel(group) }}</span>\n }\n </div>\n </div>\n }\n </div>\n }\n </div>\n </ng-template>\n </div>\n}\n" }]
|
|
160
160
|
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.Router }, { type: i2.ActivatedRoute }, { type: i3.PryI18nService }, { type: i0.ChangeDetectorRef }, { type: i3.PryBaseAccess, decorators: [{
|
|
161
161
|
type: Optional
|
|
162
162
|
}, {
|
|
163
163
|
type: Inject,
|
|
164
164
|
args: [PRY_ACCESS_TOKEN]
|
|
165
165
|
}] }] });
|
|
166
|
-
//# 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 { ChangeDetectorRef, Component, Inject, OnDestroy, OnInit, Optional } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  Associations,\n  DashboardSelectors,\n  Dataset,\n  DataSourceSelectors,\n  MetadataValue,\n  MissingGroupsByEntity,\n  PRY_ACCESS_TOKEN,\n  PryBaseAccess,\n  PryI18nService,\n  PryShareMode,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { MetadataActions, MetadataSelectors, MetaEventType } from '@provoly/dashboard/components/metadata-editor';\nimport { BehaviorSubject, combineLatest, map, Observable, of, Subscription, withLatestFrom } from 'rxjs';\nimport { concatLatestFrom } from '@ngrx/operators';\nimport { AdminActions } from '../../../store/admin.actions';\nimport { AdminSelectors } from '../../../store/admin.selectors';\nimport { AdminDatasetActions } from '../store/admin-dataset.actions';\nimport { AdminDatasetSelectors } from '../store/admin-dataset.selectors';\n\ninterface MissingGroups {\n  [key: string]: { groups: string[]; entityName: string };\n}\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  selectedDataset$: Observable<Dataset | null>;\n  associations$: Observable<Associations | undefined>;\n  sub = new Subscription();\n  currentTypeTranslation = '';\n  datasetMetadata$: Observable<MetadataValue[]>;\n  editable$: Observable<boolean>;\n  accessGroups: string[] = [];\n  selectedDatasetMissingGroups$: Observable<MissingGroupsByEntity | undefined>;\n  missingGroups$: Observable<MissingGroups | undefined>;\n  shareRadioValue$ = new BehaviorSubject<PryShareMode | undefined>(undefined);\n  disableShareButton$ = new BehaviorSubject<boolean>(false);\n\n  constructor(\n    private store: Store<any>,\n    private router: Router,\n    private route: ActivatedRoute,\n    private i18n: PryI18nService,\n    private cdr: ChangeDetectorRef,\n    @Optional() @Inject(PRY_ACCESS_TOKEN) protected access: PryBaseAccess\n  ) {\n    super();\n    this.store.dispatch(MetadataActions.loadMetadata());\n    this.selectedDataset$ = this.store.select(AdminDatasetSelectors.selectedDataset);\n    this.datasetMetadata$ = this.store.select(AdminDatasetSelectors.selectedDatasetMetadata);\n    this.associations$ = this.store.select(AdminSelectors.selectedAssociation);\n    this.editable$ = this.store.select(MetadataSelectors.editable);\n    this.selectedDatasetMissingGroups$ = this.store.select(AdminDatasetSelectors.selectedDatasetMissingGroups);\n    this.missingGroups$ = this.selectedDatasetMissingGroups$.pipe(\n      withLatestFrom(this.store.select(DashboardSelectors.manifestsList)),\n      map(([conflict, manifests]) => {\n        const result: { [key: string]: { groups: string[]; entityName: string } } = {};\n        Object.keys(conflict ?? {}).forEach((entityId) => {\n          result[entityId] = {\n            groups: conflict?.[entityId] ?? [],\n            entityName: manifests.find((m) => m.id === entityId)?.name ?? entityId\n          };\n        });\n        return Object.keys(result).length > 0 ? result : undefined;\n      })\n    );\n  }\n\n  ngOnInit(): void {\n    this.subscriptions.add(\n      combineLatest([this.selectedDataset$, this.store.select(DataSourceSelectors.datasetVersions)])\n        .pipe(concatLatestFrom(([dataset, versions]) => (dataset ? this.canModify$(dataset) : of(false))))\n        .subscribe(([[dataset, versions], canModify]) => {\n          if (dataset) {\n            this.accessGroups = dataset.groups ?? [];\n            const editPath = this.router.createUrlTree(['.', 'dataset', 'edit', dataset.id], {\n              relativeTo: this.route\n            });\n            if (canModify) {\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: AdminDatasetActions.confirmDatasetDeletion({\n                        name: dataset.id,\n                        route: this.router.createUrlTree(['.', 'dataset'], { relativeTo: this.route }).toString(),\n                        addRoute: this.router\n                          .createUrlTree(['.', 'dataset', 'new'], { relativeTo: this.route })\n                          .toString()\n                      }),\n                      label: 'delete',\n                      icon: 'delete',\n                      moduleAccess: 'admin',\n                      pageAccess: 'dataset',\n                      actionAccess: 'write',\n                      disabled: versions.filter((v) => v.dataset.id === dataset.id).length > 0\n                    }\n                  ]\n                })\n              );\n            } else {\n              this.store.dispatch(\n                AdminActions.mainActions({\n                  actions: []\n                })\n              );\n            }\n          }\n        })\n    );\n  }\n\n  closePanel() {\n    const path = this.router.createUrlTree(['.', 'dataset', 'new'], { relativeTo: this.route });\n    this.store.dispatch(AdminDatasetActions.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  removeMetadata(metadata: MetaEventType) {\n    this.store.dispatch(\n      MetadataActions.deleteDatasetMetadata({ datasetId: metadata.id, metadataId: metadata.metadataId })\n    );\n  }\n\n  addDatasetMetadata(metadata: MetaEventType) {\n    this.store.dispatch(\n      MetadataActions.addDatasetMetadata({\n        datasetId: metadata.id,\n        metadataId: metadata.metadataId,\n        value: metadata.value\n      })\n    );\n  }\n\n  share(dataset: Dataset) {\n    this.store.dispatch(AdminDatasetActions.update({ dataset: { ...dataset, groups: this.accessGroups }, route: '' }));\n  }\n\n  getGroupLabel(groupName: string) {\n    const i18nBase = '@pry.components.chipsSelector.share.groups.';\n    const label = this.i18n.instant(i18nBase + groupName, undefined, false);\n    return label.startsWith(i18nBase) ? groupName : label;\n  }\n\n  changeGroup($event: string[]) {\n    this.accessGroups = $event;\n    this.updateDisableButtonValue();\n    this.store.dispatch(AdminDatasetActions.setMissingGroups({ missingGroups: undefined }));\n  }\n\n  updateGroups($event: PryShareMode) {\n    this.shareRadioValue$.next($event);\n    this.updateDisableButtonValue();\n  }\n\n  updateDisableButtonValue() {\n    if (this.shareRadioValue$.getValue() === PryShareMode.GROUPS && this.accessGroups.length === 0) {\n      this.disableShareButton$.next(true);\n    } else {\n      if (this.disableShareButton$.getValue()) {\n        this.disableShareButton$.next(false);\n      }\n    }\n    this.cdr.detectChanges();\n  }\n\n  canModify$(dataset: Dataset) {\n    return this.access ? this.access.canModifyDataset(dataset) : of(false);\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 o-pry-admin-dataset-select\"\n>\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 class=\"a-h3\">\n      {{ '@pry.admin.dataset.datasetDetails' | i18n }}\n    </h3>\n  </div>\n\n  <pry-tab-group translationStringBase=\"@pry.admin.\">\n    <pry-tab [templateRef]=\"datasetDetails\" name=\"dataset.details\"></pry-tab>\n    <pry-tab [templateRef]=\"datasetMetadata\" name=\"metadata.title\"></pry-tab>\n    <pry-tab [templateRef]=\"datasetAssociations\" name=\"classes.associations\"></pry-tab>\n    <pry-tab *ngIf=\"canModify$(dataset) | async\" [templateRef]=\"shareDataset\" name=\"share\"></pry-tab>\n  </pry-tab-group>\n\n  <ng-template #datasetDetails>\n    <div class=\"u-display-flex -column -gap-20\">\n      <div>\n        <h4 class=\"a-h4\">{{ '@pry.dataset.name' | i18n }}</h4>\n        <span>{{ dataset.name }}</span>\n      </div>\n      <div>\n        <h4 class=\"a-h4\">{{ '@pry.dataset.description' | i18n }}</h4>\n        @if (dataset.description) {\n          <span>{{ dataset.description }}</span>\n        } @else {\n          <span class=\"-italic\">{{ '@pry.dataset.noDescription' | i18n }}</span>\n        }\n      </div>\n      <div>\n        <h4 class=\"a-h4\">{{ '@pry.admin.customize.name' | i18n }}</h4>\n        <span>{{ dataset.oClass | translateId: { type: 'class', output: 'name' } | async }}</span>\n      </div>\n      <div>\n        <h4 class=\"a-h4\">{{ '@pry.admin.dataset.type' | i18n }}</h4>\n        <span>{{ '@pry.admin.dataset.' + dataset.type | i18n }}</span>\n      </div>\n      <div>\n        <h4 class=\"a-h4\">{{ '@pry.dataset.tags' | i18n }}</h4>\n        @if (dataset.categories && dataset.categories.length > 0) {\n          <div class=\"u-display-flex\">\n            @for (category of dataset.categories; track category.id) {\n              <span class=\"a-chip -md\">{{ category.name }}</span>\n            }\n          </div>\n        } @else {\n          <span class=\"-italic\">{{ '@pry.dataset.noTags' | i18n }}</span>\n        }\n      </div>\n    </div>\n  </ng-template>\n\n  <ng-template #datasetMetadata>\n    <pry-metadata-editor\n      [targetId]=\"(selectedDataset$ | async)?.id ?? ''\"\n      [isModification]=\"(editable$ | async) ?? false\"\n      [metadata]=\"(datasetMetadata$ | async) ?? []\"\n      (removeMeta)=\"removeMetadata($event)\"\n      (addMeta)=\"addDatasetMetadata($event)\"\n      [type]=\"'meta'\"\n    ></pry-metadata-editor>\n  </ng-template>\n\n  <ng-template #datasetAssociations>\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  </ng-template>\n\n  <ng-template #shareDataset>\n    <div class=\"o-pry-admin-dataset-select__share\">\n      <pry-group-share\n        [ngModel]=\"dataset.groups\"\n        (ngModelChange)=\"changeGroup($event)\"\n        (radioValueChange)=\"updateGroups($event)\"\n      ></pry-group-share>\n      <button\n        type=\"submit\"\n        class=\"a-btn a-btn--primary u-self-end\"\n        #submit\n        (click)=\"share(dataset)\"\n        [disabled]=\"disableShareButton$ | async\"\n      >\n        {{ '@pry.admin.validate' | i18n }}\n      </button>\n      @if (selectedDatasetMissingGroups$ | async) {\n        <h4 class=\"a-h4\">{{ '@pry.admin.dataset.success' | i18n }}</h4>\n      }\n      @if (missingGroups$ | async; as missingGroups) {\n        <div class=\"u-display-flex -column\">\n          <span>{{ '@pry.admin.dataset.conflict' | i18n }}</span>\n          @for (missing of missingGroups | keyvalue; track missing.key) {\n            <div>\n              {{ '@pry.admin.dataset.entities.dashboard' | i18n }} <strong>{{ missing.value.entityName }}</strong>\n              <div class=\"u-display-flex\">\n                @for (group of missing.value.groups; track group) {\n                  <span class=\"a-chip\">{{ getGroupLabel(group) }}</span>\n                }\n              </div>\n            </div>\n          }\n        </div>\n      }\n    </div>\n  </ng-template>\n</div>\n"]}
|
|
166
|
+
//# 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 { ChangeDetectorRef, Component, Inject, OnDestroy, OnInit, Optional } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  Associations,\n  DashboardSelectors,\n  Dataset,\n  DataSourceSelectors,\n  MetadataValue,\n  MissingGroupsByEntity,\n  PRY_ACCESS_TOKEN,\n  PryBaseAccess,\n  PryI18nService,\n  PryShareMode,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { MetadataActions, MetadataSelectors, MetaEventType } from '@provoly/dashboard/components/metadata-editor';\nimport { BehaviorSubject, combineLatest, map, Observable, of, Subscription, withLatestFrom } from 'rxjs';\nimport { concatLatestFrom } from '@ngrx/operators';\nimport { AdminActions } from '../../../store/admin.actions';\nimport { AdminSelectors } from '../../../store/admin.selectors';\nimport { AdminDatasetActions } from '../store/admin-dataset.actions';\nimport { AdminDatasetSelectors } from '../store/admin-dataset.selectors';\n\ninterface MissingGroups {\n  [key: string]: { groups: string[]; entityName: string };\n}\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  selectedDataset$: Observable<Dataset | null>;\n  associations$: Observable<Associations | undefined>;\n  sub = new Subscription();\n  currentTypeTranslation = '';\n  datasetMetadata$: Observable<MetadataValue[]>;\n  editable$: Observable<boolean>;\n  accessGroups: string[] = [];\n  selectedDatasetMissingGroups$: Observable<MissingGroupsByEntity | undefined>;\n  missingGroups$: Observable<MissingGroups | undefined>;\n  shareRadioValue$ = new BehaviorSubject<PryShareMode | undefined>(undefined);\n  disableShareButton$ = new BehaviorSubject<boolean>(false);\n\n  constructor(\n    private store: Store<any>,\n    private router: Router,\n    private route: ActivatedRoute,\n    private i18n: PryI18nService,\n    private cdr: ChangeDetectorRef,\n    @Optional() @Inject(PRY_ACCESS_TOKEN) protected access: PryBaseAccess\n  ) {\n    super();\n    this.store.dispatch(MetadataActions.loadMetadata());\n    this.selectedDataset$ = this.store.select(AdminDatasetSelectors.selectedDataset);\n    this.datasetMetadata$ = this.store.select(AdminDatasetSelectors.selectedDatasetMetadata);\n    this.associations$ = this.store.select(AdminSelectors.selectedAssociation);\n    this.editable$ = this.store.select(MetadataSelectors.editable);\n    this.selectedDatasetMissingGroups$ = this.store.select(AdminDatasetSelectors.selectedDatasetMissingGroups);\n    this.missingGroups$ = this.selectedDatasetMissingGroups$.pipe(\n      withLatestFrom(this.store.select(DashboardSelectors.manifestsList)),\n      map(([conflict, manifests]) => {\n        const result: { [key: string]: { groups: string[]; entityName: string } } = {};\n        Object.keys(conflict ?? {}).forEach((entityId) => {\n          result[entityId] = {\n            groups: conflict?.[entityId] ?? [],\n            entityName: manifests.find((m) => m.id === entityId)?.name ?? entityId\n          };\n        });\n        return Object.keys(result).length > 0 ? result : undefined;\n      })\n    );\n  }\n\n  ngOnInit(): void {\n    this.subscriptions.add(\n      combineLatest([this.selectedDataset$, this.store.select(DataSourceSelectors.datasetVersions)])\n        .pipe(concatLatestFrom(([dataset, versions]) => (dataset ? this.canModify$(dataset) : of(false))))\n        .subscribe(([[dataset, versions], canModify]) => {\n          if (dataset) {\n            this.accessGroups = dataset.groups ?? [];\n            const editPath = this.router.createUrlTree(['.', 'dataset', 'edit', dataset.id], {\n              relativeTo: this.route\n            });\n            if (canModify) {\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: AdminDatasetActions.confirmDatasetDeletion({\n                        name: dataset.id,\n                        route: this.router.createUrlTree(['.', 'dataset'], { relativeTo: this.route }).toString(),\n                        addRoute: this.router\n                          .createUrlTree(['.', 'dataset', 'new'], { relativeTo: this.route })\n                          .toString()\n                      }),\n                      label: 'delete',\n                      icon: 'delete',\n                      moduleAccess: 'admin',\n                      pageAccess: 'dataset',\n                      actionAccess: 'write',\n                      disabled: versions.filter((v) => v.dataset.id === dataset.id).length > 0\n                    }\n                  ]\n                })\n              );\n            } else {\n              this.store.dispatch(\n                AdminActions.mainActions({\n                  actions: []\n                })\n              );\n            }\n          }\n        })\n    );\n  }\n\n  closePanel() {\n    const path = this.router.createUrlTree(['.', 'dataset', 'new'], { relativeTo: this.route });\n    this.store.dispatch(AdminDatasetActions.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  removeMetadata(metadata: MetaEventType) {\n    this.store.dispatch(\n      MetadataActions.deleteDatasetMetadata({ datasetId: metadata.id, metadataId: metadata.metadataId })\n    );\n  }\n\n  addDatasetMetadata(metadata: MetaEventType) {\n    this.store.dispatch(\n      MetadataActions.addDatasetMetadata({\n        datasetId: metadata.id,\n        metadataId: metadata.metadataId,\n        value: metadata.value\n      })\n    );\n  }\n\n  share(dataset: Dataset) {\n    this.store.dispatch(AdminDatasetActions.update({ dataset: { ...dataset, groups: this.accessGroups }, route: '' }));\n  }\n\n  getGroupLabel(groupName: string) {\n    const i18nBase = '@pry.components.chipsSelector.share.groups.';\n    const label = this.i18n.instant(i18nBase + groupName, undefined, false);\n    return label.startsWith(i18nBase) ? groupName : label;\n  }\n\n  changeGroup($event: string[]) {\n    this.accessGroups = $event;\n    this.updateDisableButtonValue();\n    this.store.dispatch(AdminDatasetActions.setMissingGroups({ missingGroups: undefined }));\n  }\n\n  updateGroups($event: PryShareMode) {\n    this.shareRadioValue$.next($event);\n    this.updateDisableButtonValue();\n  }\n\n  updateDisableButtonValue() {\n    if (this.shareRadioValue$.getValue() === PryShareMode.GROUPS && this.accessGroups.length === 0) {\n      this.disableShareButton$.next(true);\n    } else {\n      if (this.disableShareButton$.getValue()) {\n        this.disableShareButton$.next(false);\n      }\n    }\n    this.cdr.detectChanges();\n  }\n\n  canModify$(dataset: Dataset) {\n    return this.access ? this.access.canModifyDataset(dataset) : of(false);\n  }\n}\n","@if (selectedDataset$ | async; as dataset) {\n  <div\n    [id]=\"'panel-dataset-' + dataset.id\"\n    [attr.aria-labelledby]=\"'button-dataset-' + dataset.id\"\n    class=\"o-panel o-pry-admin-dataset-select\"\n    >\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      <h3 class=\"a-h3\">\n        {{ '@pry.admin.dataset.datasetDetails' | i18n }}\n      </h3>\n    </div>\n    <pry-tab-group translationStringBase=\"@pry.admin.\">\n      <pry-tab [templateRef]=\"datasetDetails\" name=\"dataset.details\"></pry-tab>\n      <pry-tab [templateRef]=\"datasetMetadata\" name=\"metadata.title\"></pry-tab>\n      <pry-tab [templateRef]=\"datasetAssociations\" name=\"classes.associations\"></pry-tab>\n      @if (canModify$(dataset) | async) {\n        <pry-tab [templateRef]=\"shareDataset\" name=\"share\"></pry-tab>\n      }\n    </pry-tab-group>\n    <ng-template #datasetDetails>\n      <div class=\"u-display-flex -column -gap-20\">\n        <div>\n          <h4 class=\"a-h4\">{{ '@pry.dataset.name' | i18n }}</h4>\n          <span>{{ dataset.name }}</span>\n        </div>\n        <div>\n          <h4 class=\"a-h4\">{{ '@pry.dataset.description' | i18n }}</h4>\n          @if (dataset.description) {\n            <span>{{ dataset.description }}</span>\n          } @else {\n            <span class=\"-italic\">{{ '@pry.dataset.noDescription' | i18n }}</span>\n          }\n        </div>\n        <div>\n          <h4 class=\"a-h4\">{{ '@pry.admin.customize.name' | i18n }}</h4>\n          <span>{{ dataset.oClass | translateId: { type: 'class', output: 'name' } | async }}</span>\n        </div>\n        <div>\n          <h4 class=\"a-h4\">{{ '@pry.admin.dataset.type' | i18n }}</h4>\n          <span>{{ '@pry.admin.dataset.' + dataset.type | i18n }}</span>\n        </div>\n        <div>\n          <h4 class=\"a-h4\">{{ '@pry.dataset.tags' | i18n }}</h4>\n          @if (dataset.categories && dataset.categories.length > 0) {\n            <div class=\"u-display-flex\">\n              @for (category of dataset.categories; track category.id) {\n                <span class=\"a-chip -md\">{{ category.name }}</span>\n              }\n            </div>\n          } @else {\n            <span class=\"-italic\">{{ '@pry.dataset.noTags' | i18n }}</span>\n          }\n        </div>\n      </div>\n    </ng-template>\n    <ng-template #datasetMetadata>\n      <pry-metadata-editor\n        [targetId]=\"(selectedDataset$ | async)?.id ?? ''\"\n        [isModification]=\"(editable$ | async) ?? false\"\n        [metadata]=\"(datasetMetadata$ | async) ?? []\"\n        (removeMeta)=\"removeMetadata($event)\"\n        (addMeta)=\"addDatasetMetadata($event)\"\n        [type]=\"'meta'\"\n      ></pry-metadata-editor>\n    </ng-template>\n    <ng-template #datasetAssociations>\n      @if (associations$ | async; as associations) {\n        <div 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      }\n    </ng-template>\n    <ng-template #shareDataset>\n      <div class=\"o-pry-admin-dataset-select__share\">\n        <pry-group-share\n          [ngModel]=\"dataset.groups\"\n          (ngModelChange)=\"changeGroup($event)\"\n          (radioValueChange)=\"updateGroups($event)\"\n        ></pry-group-share>\n        <button\n          type=\"submit\"\n          class=\"a-btn a-btn--primary u-self-end\"\n          #submit\n          (click)=\"share(dataset)\"\n          [disabled]=\"disableShareButton$ | async\"\n          >\n          {{ '@pry.admin.validate' | i18n }}\n        </button>\n        @if (selectedDatasetMissingGroups$ | async) {\n          <h4 class=\"a-h4\">{{ '@pry.admin.dataset.success' | i18n }}</h4>\n        }\n        @if (missingGroups$ | async; as missingGroups) {\n          <div class=\"u-display-flex -column\">\n            <span>{{ '@pry.admin.dataset.conflict' | i18n }}</span>\n            @for (missing of missingGroups | keyvalue; track missing.key) {\n              <div>\n                {{ '@pry.admin.dataset.entities.dashboard' | i18n }} <strong>{{ missing.value.entityName }}</strong>\n                <div class=\"u-display-flex\">\n                  @for (group of missing.value.groups; track group) {\n                    <span class=\"a-chip\">{{ getGroupLabel(group) }}</span>\n                  }\n                </div>\n              </div>\n            }\n          </div>\n        }\n      </div>\n    </ng-template>\n  </div>\n}\n"]}
|
|
@@ -120,12 +120,12 @@ export class AdminEnvironmentFormComponent {
|
|
|
120
120
|
return path.toString();
|
|
121
121
|
}
|
|
122
122
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: AdminEnvironmentFormComponent, deps: [{ token: i1.Store }, { token: i2.Router }, { token: i2.ActivatedRoute }, { token: i3.UntypedFormBuilder }, { token: i4.DatePipe }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
123
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
123
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: AdminEnvironmentFormComponent, selector: "pry-admin-environment-form", inputs: { currentEnv: "currentEnv" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"o-base-container\">\n <form class=\"o-form\" [formGroup]=\"envForm\" (ngSubmit)=\"addEnvironment()\">\n <div class=\"m-form-label-field -width-sm\">\n <label for=\"environment_name\" id=\"name-label\" class=\"a-label\">\n {{ '@pry.admin.environment.name' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <input\n id=\"environment_name\"\n type=\"text\"\n class=\"a-form-field\"\n formControlName=\"name\"\n [required]=\"!_currentEnv\"\n [attr.aria-labelledby]=\"isSubmitted && envForm.get('name')?.invalid ? 'name-label name-error' : 'name-label'\"\n [attr.aria-invalid]=\"isSubmitted && envForm.get('name')?.invalid\"\n />\n @if (isSubmitted && envForm.get('name')?.invalid) {\n <label\n id=\"name-error\"\n for=\"environment_name\"\n class=\"a-label a-label--help -error\"\n >\n @if (envForm.get('name')?.hasError('same-name')) {\n <span>{{ '@pry.admin.exists' | i18n }}</span>\n }\n @if (envForm.get('name')?.hasError('required')) {\n <span>{{ '@pry.admin.required' | i18n }}</span>\n }\n @if (envForm.get('name')?.hasError('pattern')) {\n <span>{{ '@pry.admin.environment.formatName' | i18n }}</span>\n }\n </label>\n }\n </div>\n\n <div class=\"m-form-label-field -width-sm\">\n <label class=\"a-label\" for=\"environment-type\">{{ '@pry.admin.environment.type' | i18n }}</label>\n <pry-select\n id=\"environment-type\"\n formControlName=\"type\"\n [items]=\"envOptions\"\n bindValue=\"varType\"\n bindLabel=\"translation\"\n (ngModelChange)=\"onTypeChange($event)\"\n [isForm]=\"true\"\n ></pry-select>\n </div>\n\n <div class=\"m-form-label-field -width-sm\">\n @if (envForm.value.type === 'DATE') {\n <label class=\"a-label\" for=\"value_date\">\n {{ '@pry.admin.environment.value' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <input type=\"date\" id=\"value_date\" class=\"a-form-field\" formControlName=\"value\" required />\n @if (isSubmitted && envForm.get('value')?.invalid && envForm.get('value')?.hasError('required')) {\n <label\n id=\"value_date_error\"\n for=\"value_date\"\n class=\"a-label a-label--help -error\"\n >\n {{ '@pry.admin.required' | i18n }}\n </label>\n }\n } @else {\n <label id=\"value-label\" class=\"a-label\">{{ '@pry.admin.environment.value' | i18n }}</label>\n <input\n id=\"environment_value\"\n type=\"text\"\n class=\"a-form-field\"\n formControlName=\"value\"\n [attr.aria-labelledby]=\"\n isSubmitted && envForm.get('value')?.invalid ? 'value-label value-error' : 'value-label'\n \"\n [attr.aria-invalid]=\"isSubmitted && envForm.get('value')?.invalid\"\n required\n />\n @if (isSubmitted && envForm.get('value')?.invalid) {\n <label\n id=\"value-error\"\n for=\"environment_value\"\n class=\"a-label a-label--help -error\"\n >\n @if (envForm.get('value')?.hasError('required')) {\n <span>{{ '@pry.admin.required' | i18n }}</span>\n }\n @if (envForm.get('value')?.hasError('pattern')) {\n @if (envForm.value.type === 'DOUBLE') {\n <span>{{ '@pry.admin.environment.formatDouble' | i18n }}</span>\n }\n @if (envForm.value.type === 'INTEGER') {\n <span>{{ '@pry.admin.environment.formatInt' | i18n }}</span>\n }\n }\n </label>\n }\n }\n\n </div>\n\n <div class=\"m-btn-group -width-sm\">\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\n class=\"predicate-create a-btn a-btn--primary\"\n type=\"submit\"\n [innerHTML]=\"(_currentEnv ? '@pry.admin.edit' : '@pry.admin.create') | i18n\"\n ></button>\n </div>\n </form>\n</div>\n", dependencies: [{ kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i5.PrySelectComponent, selector: "pry-select", inputs: ["items", "clearable", "multiple", "closeOnSelect", "placeholder", "isForm", "required", "name", "autocomplete", "alwaysShowAutosuggestedValues", "externalAutocompleteService", "bindValue", "bindLabel", "iconSize", "bindIcon", "template", "i18nPrefix", "bindClasses", "loading", "elementRef"], outputs: ["searched", "cleared", "clicked", "pressedEnter"] }, { kind: "pipe", type: i5.I18nPipe, name: "i18n" }] }); }
|
|
124
124
|
}
|
|
125
125
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: AdminEnvironmentFormComponent, decorators: [{
|
|
126
126
|
type: Component,
|
|
127
|
-
args: [{ selector: 'pry-admin-environment-form', template: "<div class=\"o-base-container\">\n <form class=\"o-form\" [formGroup]=\"envForm\" (ngSubmit)=\"addEnvironment()\">\n <div class=\"m-form-label-field -width-sm\">\n <label for=\"environment_name\" id=\"name-label\" class=\"a-label\">\n {{ '@pry.admin.environment.name' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <input\n id=\"environment_name\"\n type=\"text\"\n class=\"a-form-field\"\n formControlName=\"name\"\n [required]=\"!_currentEnv\"\n [attr.aria-labelledby]=\"isSubmitted && envForm.get('name')?.invalid ? 'name-label name-error' : 'name-label'\"\n [attr.aria-invalid]=\"isSubmitted && envForm.get('name')?.invalid\"\n
|
|
127
|
+
args: [{ selector: 'pry-admin-environment-form', template: "<div class=\"o-base-container\">\n <form class=\"o-form\" [formGroup]=\"envForm\" (ngSubmit)=\"addEnvironment()\">\n <div class=\"m-form-label-field -width-sm\">\n <label for=\"environment_name\" id=\"name-label\" class=\"a-label\">\n {{ '@pry.admin.environment.name' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <input\n id=\"environment_name\"\n type=\"text\"\n class=\"a-form-field\"\n formControlName=\"name\"\n [required]=\"!_currentEnv\"\n [attr.aria-labelledby]=\"isSubmitted && envForm.get('name')?.invalid ? 'name-label name-error' : 'name-label'\"\n [attr.aria-invalid]=\"isSubmitted && envForm.get('name')?.invalid\"\n />\n @if (isSubmitted && envForm.get('name')?.invalid) {\n <label\n id=\"name-error\"\n for=\"environment_name\"\n class=\"a-label a-label--help -error\"\n >\n @if (envForm.get('name')?.hasError('same-name')) {\n <span>{{ '@pry.admin.exists' | i18n }}</span>\n }\n @if (envForm.get('name')?.hasError('required')) {\n <span>{{ '@pry.admin.required' | i18n }}</span>\n }\n @if (envForm.get('name')?.hasError('pattern')) {\n <span>{{ '@pry.admin.environment.formatName' | i18n }}</span>\n }\n </label>\n }\n </div>\n\n <div class=\"m-form-label-field -width-sm\">\n <label class=\"a-label\" for=\"environment-type\">{{ '@pry.admin.environment.type' | i18n }}</label>\n <pry-select\n id=\"environment-type\"\n formControlName=\"type\"\n [items]=\"envOptions\"\n bindValue=\"varType\"\n bindLabel=\"translation\"\n (ngModelChange)=\"onTypeChange($event)\"\n [isForm]=\"true\"\n ></pry-select>\n </div>\n\n <div class=\"m-form-label-field -width-sm\">\n @if (envForm.value.type === 'DATE') {\n <label class=\"a-label\" for=\"value_date\">\n {{ '@pry.admin.environment.value' | i18n }} *\n <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n </label>\n <input type=\"date\" id=\"value_date\" class=\"a-form-field\" formControlName=\"value\" required />\n @if (isSubmitted && envForm.get('value')?.invalid && envForm.get('value')?.hasError('required')) {\n <label\n id=\"value_date_error\"\n for=\"value_date\"\n class=\"a-label a-label--help -error\"\n >\n {{ '@pry.admin.required' | i18n }}\n </label>\n }\n } @else {\n <label id=\"value-label\" class=\"a-label\">{{ '@pry.admin.environment.value' | i18n }}</label>\n <input\n id=\"environment_value\"\n type=\"text\"\n class=\"a-form-field\"\n formControlName=\"value\"\n [attr.aria-labelledby]=\"\n isSubmitted && envForm.get('value')?.invalid ? 'value-label value-error' : 'value-label'\n \"\n [attr.aria-invalid]=\"isSubmitted && envForm.get('value')?.invalid\"\n required\n />\n @if (isSubmitted && envForm.get('value')?.invalid) {\n <label\n id=\"value-error\"\n for=\"environment_value\"\n class=\"a-label a-label--help -error\"\n >\n @if (envForm.get('value')?.hasError('required')) {\n <span>{{ '@pry.admin.required' | i18n }}</span>\n }\n @if (envForm.get('value')?.hasError('pattern')) {\n @if (envForm.value.type === 'DOUBLE') {\n <span>{{ '@pry.admin.environment.formatDouble' | i18n }}</span>\n }\n @if (envForm.value.type === 'INTEGER') {\n <span>{{ '@pry.admin.environment.formatInt' | i18n }}</span>\n }\n }\n </label>\n }\n }\n\n </div>\n\n <div class=\"m-btn-group -width-sm\">\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\n class=\"predicate-create a-btn a-btn--primary\"\n type=\"submit\"\n [innerHTML]=\"(_currentEnv ? '@pry.admin.edit' : '@pry.admin.create') | i18n\"\n ></button>\n </div>\n </form>\n</div>\n" }]
|
|
128
128
|
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.Router }, { type: i2.ActivatedRoute }, { type: i3.UntypedFormBuilder }, { type: i4.DatePipe }], propDecorators: { currentEnv: [{
|
|
129
129
|
type: Input
|
|
130
130
|
}] } });
|
|
131
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-environment-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/dashboard/admin/components/admin-environment/admin-environment-form/admin-environment-form.component.ts","../../../../../../../../projects/provoly/dashboard/admin/components/admin-environment/admin-environment-form/admin-environment-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe } from '@angular/common';\nimport { Component, Input, OnChanges, OnDestroy, OnInit, SimpleChanges } from '@angular/core';\nimport { UntypedFormBuilder, UntypedFormGroup, Validators } from '@angular/forms';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport { ENV_OPTIONS, Environment } from '@provoly/dashboard';\nimport { combineLatest, map, Observable, Subject, Subscription } from 'rxjs';\nimport { AdminActions } from '../../../store/admin.actions';\nimport { EnvironmentActions } from '../store/environment.actions';\nimport { EnvironmentSelectors } from '../store/environment.selectors';\n\n@Component({\n  selector: 'pry-admin-environment-form',\n  templateUrl: './admin-environment-form.component.html'\n})\nexport class AdminEnvironmentFormComponent implements OnInit, OnChanges, OnDestroy {\n  envNames$?: Observable<string[]>;\n  nameAlreadyExists$?: Observable<boolean>;\n  private currentEnv$ = new Subject<Environment>();\n  sub = new Subscription();\n\n  _currentEnv?: Environment;\n  envForm: UntypedFormGroup;\n  envOptions = ENV_OPTIONS;\n  currentTypeTranslation = '';\n  isSubmitted = false;\n\n  @Input() set currentEnv(val: Environment) {\n    this.currentEnv$.next(val);\n    this._currentEnv = val;\n  }\n\n  constructor(\n    private store: Store<any>,\n    private router: Router,\n    private route: ActivatedRoute,\n    private formBuilder: UntypedFormBuilder,\n    private datePipe: DatePipe\n  ) {\n    this.envForm = this.formBuilder.group({\n      name: ['', [Validators.required, Validators.pattern('^[a-zA-Z0-9_-]*$')]],\n      type: [this.envOptions[0].varType],\n      value: ['', [Validators.required, Validators.pattern('^[+-]?[0-9]*$')]]\n    });\n    this.sub.add(\n      this.currentEnv$.subscribe((ce) => {\n        this._currentEnv = ce;\n        const type = ENV_OPTIONS.find((el) => el.varType === ce?.type);\n        this.currentTypeTranslation = type ? type.translation : ENV_OPTIONS[0].translation;\n        if (!!this._currentEnv) {\n          this.envForm.controls['type'].disable({ onlySelf: true });\n        } else {\n          this.envForm.controls['type'].enable({ onlySelf: true });\n        }\n      })\n    );\n  }\n\n  ngOnInit(): void {\n    if (!this._currentEnv) {\n      this.store.dispatch(EnvironmentActions.loadEnvironments());\n      this.envNames$ = this.store\n        .select(EnvironmentSelectors.environments)\n        .pipe(map((envs: Environment[]) => envs.map((env: Environment) => env.name.toLowerCase())));\n\n      this.nameAlreadyExists$ = combineLatest([\n        this.envForm.get('name')?.valueChanges as Observable<string>,\n        this.envNames$\n      ]).pipe(map(([value, envNames]) => envNames.includes(value.toLowerCase())));\n      this.sub.add(\n        this.nameAlreadyExists$.subscribe((value) => {\n          if (value) {\n            this.envForm.controls['name'].setErrors({ 'same-name': true });\n          }\n          return value;\n        })\n      );\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this._currentEnv) {\n      this.envForm.patchValue({\n        name: this._currentEnv.name,\n        type: this._currentEnv.type,\n        value:\n          this._currentEnv.type === 'DATE'\n            ? this.datePipe.transform(this._currentEnv.value, 'yyyy-MM-dd')\n            : this._currentEnv.value\n      });\n      this.onTypeChange(this._currentEnv.type);\n      this.envForm.controls['name'].disable();\n    }\n  }\n\n  ngOnDestroy() {\n    this.sub.unsubscribe();\n  }\n\n  goBack() {\n    this.store.dispatch(AdminActions.routeTo({ path: this.getPath(), params: undefined }));\n  }\n\n  addEnvironment() {\n    this.isSubmitted = true;\n    if (this.envForm.valid) {\n      this.isSubmitted = false;\n      let newEnv = this.envForm.getRawValue();\n      if (newEnv.type === 'INTEGER') {\n        newEnv.value = parseInt(newEnv.value);\n      } else if (newEnv.type === 'DOUBLE') {\n        newEnv.value = parseFloat(newEnv.value);\n      } else if (newEnv.type === 'DATE') {\n        newEnv.value = this.datePipe.transform(newEnv.value, 'yyyy/MM/dd');\n      }\n      this.store.dispatch(EnvironmentActions.saveEnvironment({ env: newEnv, route: this.getPath() }));\n    }\n  }\n\n  onTypeChange(type: string) {\n    if (type === 'INTEGER') {\n      this.envForm.controls['value'].setValidators([Validators.required, Validators.pattern('^[+-]?[0-9]*$')]);\n    } else if (type === 'DOUBLE') {\n      this.envForm.controls['value'].setValidators([\n        Validators.required,\n        Validators.pattern('[+-]?([0-9]*[.])?[0-9]+')\n      ]);\n    } else {\n      this.envForm.controls['value'].setValidators([Validators.required]);\n    }\n  }\n\n  getPath() {\n    let path = this.router.createUrlTree(['..'], { relativeTo: this.route });\n    if (this._currentEnv) {\n      path = this.router.createUrlTree(['../..'], { relativeTo: this.route });\n    }\n    return path.toString();\n  }\n}\n","<div class=\"o-base-container\">\n  <form class=\"o-form\" [formGroup]=\"envForm\" (ngSubmit)=\"addEnvironment()\">\n    <div class=\"m-form-label-field -width-sm\">\n      <label for=\"environment_name\" id=\"name-label\" class=\"a-label\">\n        {{ '@pry.admin.environment.name' | i18n }} *\n        <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n      </label>\n      <input\n        id=\"environment_name\"\n        type=\"text\"\n        class=\"a-form-field\"\n        formControlName=\"name\"\n        [required]=\"!_currentEnv\"\n        [attr.aria-labelledby]=\"isSubmitted && envForm.get('name')?.invalid ? 'name-label name-error' : 'name-label'\"\n        [attr.aria-invalid]=\"isSubmitted && envForm.get('name')?.invalid\"\n      />\n      <label\n        *ngIf=\"isSubmitted && envForm.get('name')?.invalid\"\n        id=\"name-error\"\n        for=\"environment_name\"\n        class=\"a-label a-label--help -error\"\n      >\n        <span *ngIf=\"envForm.get('name')?.hasError('same-name')\">{{ '@pry.admin.exists' | i18n }}</span>\n        <span *ngIf=\"envForm.get('name')?.hasError('required')\">{{ '@pry.admin.required' | i18n }}</span>\n        <span *ngIf=\"envForm.get('name')?.hasError('pattern')\">{{ '@pry.admin.environment.formatName' | i18n }}</span>\n      </label>\n    </div>\n\n    <div class=\"m-form-label-field -width-sm\">\n      <label class=\"a-label\" for=\"environment-type\">{{ '@pry.admin.environment.type' | i18n }}</label>\n      <pry-select\n        id=\"environment-type\"\n        formControlName=\"type\"\n        [items]=\"envOptions\"\n        bindValue=\"varType\"\n        bindLabel=\"translation\"\n        (ngModelChange)=\"onTypeChange($event)\"\n        [isForm]=\"true\"\n      ></pry-select>\n    </div>\n\n    <div class=\"m-form-label-field -width-sm\">\n      <ng-container *ngIf=\"envForm.value.type === 'DATE'; else inputText\">\n        <label class=\"a-label\" for=\"value_date\">\n          {{ '@pry.admin.environment.value' | i18n }} *\n          <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n        </label>\n        <input type=\"date\" id=\"value_date\" class=\"a-form-field\" formControlName=\"value\" required />\n        <label\n          *ngIf=\"isSubmitted && envForm.get('value')?.invalid && envForm.get('value')?.hasError('required')\"\n          id=\"value_date_error\"\n          for=\"value_date\"\n          class=\"a-label a-label--help -error\"\n        >\n          {{ '@pry.admin.required' | i18n }}\n        </label>\n      </ng-container>\n\n      <ng-template #inputText>\n        <label id=\"value-label\" class=\"a-label\">{{ '@pry.admin.environment.value' | i18n }}</label>\n        <input\n          id=\"environment_value\"\n          type=\"text\"\n          class=\"a-form-field\"\n          formControlName=\"value\"\n          [attr.aria-labelledby]=\"\n            isSubmitted && envForm.get('value')?.invalid ? 'value-label value-error' : 'value-label'\n          \"\n          [attr.aria-invalid]=\"isSubmitted && envForm.get('value')?.invalid\"\n          required\n        />\n        <label\n          *ngIf=\"isSubmitted && envForm.get('value')?.invalid\"\n          id=\"value-error\"\n          for=\"environment_value\"\n          class=\"a-label a-label--help -error\"\n        >\n          <span *ngIf=\"envForm.get('value')?.hasError('required')\">{{ '@pry.admin.required' | i18n }}</span>\n          <ng-container *ngIf=\"envForm.get('value')?.hasError('pattern')\">\n            <span *ngIf=\"envForm.value.type === 'DOUBLE'\">{{ '@pry.admin.environment.formatDouble' | i18n }}</span>\n            <span *ngIf=\"envForm.value.type === 'INTEGER'\">{{ '@pry.admin.environment.formatInt' | i18n }}</span>\n          </ng-container>\n        </label>\n      </ng-template>\n    </div>\n\n    <div class=\"m-btn-group -width-sm\">\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\n        class=\"predicate-create a-btn a-btn--primary\"\n        type=\"submit\"\n        [innerHTML]=\"(_currentEnv ? '@pry.admin.edit' : '@pry.admin.create') | i18n\"\n      ></button>\n    </div>\n  </form>\n</div>\n"]}
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-environment-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/dashboard/admin/components/admin-environment/admin-environment-form/admin-environment-form.component.ts","../../../../../../../../projects/provoly/dashboard/admin/components/admin-environment/admin-environment-form/admin-environment-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe } from '@angular/common';\nimport { Component, Input, OnChanges, OnDestroy, OnInit, SimpleChanges } from '@angular/core';\nimport { UntypedFormBuilder, UntypedFormGroup, Validators } from '@angular/forms';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport { ENV_OPTIONS, Environment } from '@provoly/dashboard';\nimport { combineLatest, map, Observable, Subject, Subscription } from 'rxjs';\nimport { AdminActions } from '../../../store/admin.actions';\nimport { EnvironmentActions } from '../store/environment.actions';\nimport { EnvironmentSelectors } from '../store/environment.selectors';\n\n@Component({\n  selector: 'pry-admin-environment-form',\n  templateUrl: './admin-environment-form.component.html'\n})\nexport class AdminEnvironmentFormComponent implements OnInit, OnChanges, OnDestroy {\n  envNames$?: Observable<string[]>;\n  nameAlreadyExists$?: Observable<boolean>;\n  private currentEnv$ = new Subject<Environment>();\n  sub = new Subscription();\n\n  _currentEnv?: Environment;\n  envForm: UntypedFormGroup;\n  envOptions = ENV_OPTIONS;\n  currentTypeTranslation = '';\n  isSubmitted = false;\n\n  @Input() set currentEnv(val: Environment) {\n    this.currentEnv$.next(val);\n    this._currentEnv = val;\n  }\n\n  constructor(\n    private store: Store<any>,\n    private router: Router,\n    private route: ActivatedRoute,\n    private formBuilder: UntypedFormBuilder,\n    private datePipe: DatePipe\n  ) {\n    this.envForm = this.formBuilder.group({\n      name: ['', [Validators.required, Validators.pattern('^[a-zA-Z0-9_-]*$')]],\n      type: [this.envOptions[0].varType],\n      value: ['', [Validators.required, Validators.pattern('^[+-]?[0-9]*$')]]\n    });\n    this.sub.add(\n      this.currentEnv$.subscribe((ce) => {\n        this._currentEnv = ce;\n        const type = ENV_OPTIONS.find((el) => el.varType === ce?.type);\n        this.currentTypeTranslation = type ? type.translation : ENV_OPTIONS[0].translation;\n        if (!!this._currentEnv) {\n          this.envForm.controls['type'].disable({ onlySelf: true });\n        } else {\n          this.envForm.controls['type'].enable({ onlySelf: true });\n        }\n      })\n    );\n  }\n\n  ngOnInit(): void {\n    if (!this._currentEnv) {\n      this.store.dispatch(EnvironmentActions.loadEnvironments());\n      this.envNames$ = this.store\n        .select(EnvironmentSelectors.environments)\n        .pipe(map((envs: Environment[]) => envs.map((env: Environment) => env.name.toLowerCase())));\n\n      this.nameAlreadyExists$ = combineLatest([\n        this.envForm.get('name')?.valueChanges as Observable<string>,\n        this.envNames$\n      ]).pipe(map(([value, envNames]) => envNames.includes(value.toLowerCase())));\n      this.sub.add(\n        this.nameAlreadyExists$.subscribe((value) => {\n          if (value) {\n            this.envForm.controls['name'].setErrors({ 'same-name': true });\n          }\n          return value;\n        })\n      );\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this._currentEnv) {\n      this.envForm.patchValue({\n        name: this._currentEnv.name,\n        type: this._currentEnv.type,\n        value:\n          this._currentEnv.type === 'DATE'\n            ? this.datePipe.transform(this._currentEnv.value, 'yyyy-MM-dd')\n            : this._currentEnv.value\n      });\n      this.onTypeChange(this._currentEnv.type);\n      this.envForm.controls['name'].disable();\n    }\n  }\n\n  ngOnDestroy() {\n    this.sub.unsubscribe();\n  }\n\n  goBack() {\n    this.store.dispatch(AdminActions.routeTo({ path: this.getPath(), params: undefined }));\n  }\n\n  addEnvironment() {\n    this.isSubmitted = true;\n    if (this.envForm.valid) {\n      this.isSubmitted = false;\n      let newEnv = this.envForm.getRawValue();\n      if (newEnv.type === 'INTEGER') {\n        newEnv.value = parseInt(newEnv.value);\n      } else if (newEnv.type === 'DOUBLE') {\n        newEnv.value = parseFloat(newEnv.value);\n      } else if (newEnv.type === 'DATE') {\n        newEnv.value = this.datePipe.transform(newEnv.value, 'yyyy/MM/dd');\n      }\n      this.store.dispatch(EnvironmentActions.saveEnvironment({ env: newEnv, route: this.getPath() }));\n    }\n  }\n\n  onTypeChange(type: string) {\n    if (type === 'INTEGER') {\n      this.envForm.controls['value'].setValidators([Validators.required, Validators.pattern('^[+-]?[0-9]*$')]);\n    } else if (type === 'DOUBLE') {\n      this.envForm.controls['value'].setValidators([\n        Validators.required,\n        Validators.pattern('[+-]?([0-9]*[.])?[0-9]+')\n      ]);\n    } else {\n      this.envForm.controls['value'].setValidators([Validators.required]);\n    }\n  }\n\n  getPath() {\n    let path = this.router.createUrlTree(['..'], { relativeTo: this.route });\n    if (this._currentEnv) {\n      path = this.router.createUrlTree(['../..'], { relativeTo: this.route });\n    }\n    return path.toString();\n  }\n}\n","<div class=\"o-base-container\">\n  <form class=\"o-form\" [formGroup]=\"envForm\" (ngSubmit)=\"addEnvironment()\">\n    <div class=\"m-form-label-field -width-sm\">\n      <label for=\"environment_name\" id=\"name-label\" class=\"a-label\">\n        {{ '@pry.admin.environment.name' | i18n }} *\n        <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n      </label>\n      <input\n        id=\"environment_name\"\n        type=\"text\"\n        class=\"a-form-field\"\n        formControlName=\"name\"\n        [required]=\"!_currentEnv\"\n        [attr.aria-labelledby]=\"isSubmitted && envForm.get('name')?.invalid ? 'name-label name-error' : 'name-label'\"\n        [attr.aria-invalid]=\"isSubmitted && envForm.get('name')?.invalid\"\n        />\n      @if (isSubmitted && envForm.get('name')?.invalid) {\n        <label\n          id=\"name-error\"\n          for=\"environment_name\"\n          class=\"a-label a-label--help -error\"\n          >\n          @if (envForm.get('name')?.hasError('same-name')) {\n            <span>{{ '@pry.admin.exists' | i18n }}</span>\n          }\n          @if (envForm.get('name')?.hasError('required')) {\n            <span>{{ '@pry.admin.required' | i18n }}</span>\n          }\n          @if (envForm.get('name')?.hasError('pattern')) {\n            <span>{{ '@pry.admin.environment.formatName' | i18n }}</span>\n          }\n        </label>\n      }\n    </div>\n\n    <div class=\"m-form-label-field -width-sm\">\n      <label class=\"a-label\" for=\"environment-type\">{{ '@pry.admin.environment.type' | i18n }}</label>\n      <pry-select\n        id=\"environment-type\"\n        formControlName=\"type\"\n        [items]=\"envOptions\"\n        bindValue=\"varType\"\n        bindLabel=\"translation\"\n        (ngModelChange)=\"onTypeChange($event)\"\n        [isForm]=\"true\"\n      ></pry-select>\n    </div>\n\n    <div class=\"m-form-label-field -width-sm\">\n      @if (envForm.value.type === 'DATE') {\n        <label class=\"a-label\" for=\"value_date\">\n          {{ '@pry.admin.environment.value' | i18n }} *\n          <span class=\"u-visually-hidden\">({{ '@pry.admin.required' | i18n }})</span>\n        </label>\n        <input type=\"date\" id=\"value_date\" class=\"a-form-field\" formControlName=\"value\" required />\n        @if (isSubmitted && envForm.get('value')?.invalid && envForm.get('value')?.hasError('required')) {\n          <label\n            id=\"value_date_error\"\n            for=\"value_date\"\n            class=\"a-label a-label--help -error\"\n            >\n            {{ '@pry.admin.required' | i18n }}\n          </label>\n        }\n      } @else {\n        <label id=\"value-label\" class=\"a-label\">{{ '@pry.admin.environment.value' | i18n }}</label>\n        <input\n          id=\"environment_value\"\n          type=\"text\"\n          class=\"a-form-field\"\n          formControlName=\"value\"\n          [attr.aria-labelledby]=\"\n            isSubmitted && envForm.get('value')?.invalid ? 'value-label value-error' : 'value-label'\n          \"\n          [attr.aria-invalid]=\"isSubmitted && envForm.get('value')?.invalid\"\n          required\n          />\n        @if (isSubmitted && envForm.get('value')?.invalid) {\n          <label\n            id=\"value-error\"\n            for=\"environment_value\"\n            class=\"a-label a-label--help -error\"\n            >\n            @if (envForm.get('value')?.hasError('required')) {\n              <span>{{ '@pry.admin.required' | i18n }}</span>\n            }\n            @if (envForm.get('value')?.hasError('pattern')) {\n              @if (envForm.value.type === 'DOUBLE') {\n                <span>{{ '@pry.admin.environment.formatDouble' | i18n }}</span>\n              }\n              @if (envForm.value.type === 'INTEGER') {\n                <span>{{ '@pry.admin.environment.formatInt' | i18n }}</span>\n              }\n            }\n          </label>\n        }\n      }\n\n    </div>\n\n    <div class=\"m-btn-group -width-sm\">\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\n        class=\"predicate-create a-btn a-btn--primary\"\n        type=\"submit\"\n        [innerHTML]=\"(_currentEnv ? '@pry.admin.edit' : '@pry.admin.create') | i18n\"\n      ></button>\n    </div>\n  </form>\n</div>\n"]}
|