@provoly/dashboard 1.4.44 → 1.4.45
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/presentation/components/add-edit-presentation/add-edit-presentation.component.mjs +47 -49
- package/esm2022/toolbox/components/edit-presentation/edit-presentation.component.mjs +1 -1
- package/esm2022/toolbox/components/save-view/save-view.component.mjs +1 -1
- package/esm2022/toolbox/shared/presentation-form/presentation-form.component.mjs +6 -3
- package/esm2022/toolbox/toolbox.module.mjs +7 -4
- package/fesm2022/provoly-dashboard-presentation.mjs +53 -55
- package/fesm2022/provoly-dashboard-presentation.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-toolbox.mjs +13 -7
- package/fesm2022/provoly-dashboard-toolbox.mjs.map +1 -1
- package/package.json +1 -1
- package/presentation/components/add-edit-presentation/add-edit-presentation.component.d.ts +7 -6
- package/toolbox/shared/presentation-form/presentation-form.component.d.ts +2 -1
- package/toolbox/toolbox.module.d.ts +1 -1
package/esm2022/presentation/components/add-edit-presentation/add-edit-presentation.component.mjs
CHANGED
|
@@ -1,34 +1,36 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Optional, Output } from '@angular/core';
|
|
2
2
|
import { DashboardActions, DashboardGridLayout, DashboardSelectors, SubscriptionnerDirective, ViewMode, WidgetPlacementUtils } from '@provoly/dashboard';
|
|
3
|
-
import { BehaviorSubject, combineLatest } from 'rxjs';
|
|
3
|
+
import { BehaviorSubject, catchError, combineLatest, throwError } from 'rxjs';
|
|
4
4
|
import { MetadataSelectors } from '@provoly/dashboard/components/metadata-editor';
|
|
5
5
|
import { v4 as uuidv4 } from 'uuid';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
import * as i1 from "@ngrx/store";
|
|
8
|
-
import * as i2 from "@
|
|
9
|
-
import * as i3 from "@
|
|
10
|
-
import * as i4 from "@provoly/dashboard/
|
|
11
|
-
import * as i5 from "@provoly/dashboard";
|
|
8
|
+
import * as i2 from "@provoly/dashboard";
|
|
9
|
+
import * as i3 from "@angular/router";
|
|
10
|
+
import * as i4 from "@provoly/dashboard/toolbox";
|
|
11
|
+
import * as i5 from "@provoly/dashboard/components/metadata-editor";
|
|
12
12
|
import * as i6 from "@angular/common";
|
|
13
13
|
export class PryAddEditPresentationComponent extends SubscriptionnerDirective {
|
|
14
14
|
set selectedPresentation(presentation) {
|
|
15
15
|
this.selectedPresentation$.next(presentation);
|
|
16
16
|
}
|
|
17
|
-
constructor(store, router) {
|
|
17
|
+
constructor(store, manifestService, router) {
|
|
18
18
|
super();
|
|
19
19
|
this.store = store;
|
|
20
|
+
this.manifestService = manifestService;
|
|
20
21
|
this.router = router;
|
|
21
22
|
this.selectedPresentation$ = new BehaviorSubject(undefined);
|
|
22
23
|
this.chosenLayout = DashboardGridLayout.FULL;
|
|
23
24
|
this.metadataThemeId = '';
|
|
24
25
|
this.isFormValid = false;
|
|
26
|
+
this.errorDuplicatingText = null;
|
|
25
27
|
this.edition = false;
|
|
26
28
|
this.themePrefix = null;
|
|
27
29
|
this.editionStartUrl = '/';
|
|
28
30
|
this.mode = 'meta';
|
|
29
31
|
this.goBack = new EventEmitter();
|
|
30
32
|
this.staticManifest$ = this.store.select(DashboardSelectors.staticManifest);
|
|
31
|
-
this.subscriptions.add(this.staticManifest$.subscribe(manifest => this.staticManifest = manifest));
|
|
33
|
+
this.subscriptions.add(this.staticManifest$.subscribe((manifest) => (this.staticManifest = manifest)));
|
|
32
34
|
this.subscriptions.add(combineLatest([this.staticManifest$, this.store.select(DashboardSelectors.gridLayout)]).subscribe(([staticManifest, gridLayout]) => {
|
|
33
35
|
this.chosenLayout =
|
|
34
36
|
this.edition && staticManifest.windows[0]?.grid?.layout !== undefined
|
|
@@ -43,52 +45,48 @@ export class PryAddEditPresentationComponent extends SubscriptionnerDirective {
|
|
|
43
45
|
}
|
|
44
46
|
}));
|
|
45
47
|
}
|
|
46
|
-
|
|
48
|
+
saveOrUpdateDashboard() {
|
|
47
49
|
const presentation = {
|
|
48
50
|
...this.selectedPresentation$.value,
|
|
49
51
|
id: this.selectedPresentation$.value?.id || uuidv4(),
|
|
50
52
|
...this.formValue,
|
|
51
53
|
metadata: this.metadata()
|
|
52
54
|
};
|
|
53
|
-
this.
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
55
|
+
this.errorDuplicatingText = null;
|
|
56
|
+
this.manifestService
|
|
57
|
+
.save(presentation.name, this.edition ? this.staticManifest : this.getNewManifest(), presentation.id, presentation.description, presentation.image, presentation.metadata?.map((metadata) => ({
|
|
58
|
+
metadataDefId: metadata.metadataDef.id,
|
|
59
|
+
value: metadata.value
|
|
60
|
+
})), presentation.accessRightsByGroup, presentation.additionalInformation)
|
|
61
|
+
.pipe(catchError((error) => {
|
|
62
|
+
this.errorDuplicatingText = '@chh.message.failure.alreadyExisting';
|
|
63
|
+
return throwError(error);
|
|
64
|
+
}))
|
|
65
|
+
.subscribe(() => {
|
|
66
|
+
const presentation = {
|
|
67
|
+
...this.selectedPresentation$.value,
|
|
68
|
+
...this.formValue,
|
|
69
|
+
metadata: this.metadata()
|
|
70
|
+
};
|
|
71
|
+
if (!this.edition) {
|
|
72
|
+
this.store.dispatch(DashboardActions.selectPresentation({
|
|
73
|
+
presentation,
|
|
74
|
+
viewMode: ViewMode.CREATION
|
|
75
|
+
}));
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
this.store.dispatch(DashboardActions.loadPresentation({
|
|
79
|
+
presentation,
|
|
80
|
+
viewMode: ViewMode.EDITION
|
|
81
|
+
}));
|
|
82
|
+
}
|
|
83
|
+
this.router?.navigateByUrl(this.editionStartUrl);
|
|
84
|
+
});
|
|
69
85
|
}
|
|
70
|
-
|
|
86
|
+
saveDashboard() {
|
|
71
87
|
if (this.isFormValid) {
|
|
72
|
-
this.
|
|
73
|
-
}
|
|
74
|
-
const presentation = {
|
|
75
|
-
...this.selectedPresentation$.value,
|
|
76
|
-
...this.formValue,
|
|
77
|
-
metadata: this.metadata()
|
|
78
|
-
};
|
|
79
|
-
if (!this.edition) {
|
|
80
|
-
this.store.dispatch(DashboardActions.selectPresentation({
|
|
81
|
-
presentation,
|
|
82
|
-
viewMode: ViewMode.CREATION
|
|
83
|
-
}));
|
|
84
|
-
}
|
|
85
|
-
else {
|
|
86
|
-
this.store.dispatch(DashboardActions.loadPresentation({
|
|
87
|
-
presentation,
|
|
88
|
-
viewMode: ViewMode.EDITION
|
|
89
|
-
}));
|
|
88
|
+
this.saveOrUpdateDashboard();
|
|
90
89
|
}
|
|
91
|
-
this.router?.navigateByUrl(this.editionStartUrl);
|
|
92
90
|
}
|
|
93
91
|
addMetadata(metadata) {
|
|
94
92
|
this.store.dispatch(DashboardActions.addManifestMetadata({
|
|
@@ -132,13 +130,13 @@ export class PryAddEditPresentationComponent extends SubscriptionnerDirective {
|
|
|
132
130
|
]
|
|
133
131
|
};
|
|
134
132
|
}
|
|
135
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: PryAddEditPresentationComponent, deps: [{ token: i1.Store }, { token: i2.Router, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
136
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: PryAddEditPresentationComponent, selector: "pry-add-edit-presentation", inputs: { selectedPresentation: "selectedPresentation", edition: "edition", themePrefix: "themePrefix", editionStartUrl: "editionStartUrl", mode: "mode" }, outputs: { goBack: "goBack" }, usesInheritance: true, ngImport: i0, template: "<div class=\"o-manifest-layout\">\n <div class=\"o-manifest-layout__toolbox -justify-space-between -align-center\">\n <button class=\"a-btn a-btn--secondary\" type=\"button\" (click)=\"close()\">\n {{ '@pry.toolbox.manifest.close' | i18n }}\n </button>\n <button class=\"a-btn a-btn--primary\" type=\"button\" (click)=\"
|
|
133
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: PryAddEditPresentationComponent, deps: [{ token: i1.Store }, { token: i2.ManifestService }, { token: i3.Router, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
134
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: PryAddEditPresentationComponent, selector: "pry-add-edit-presentation", inputs: { selectedPresentation: "selectedPresentation", edition: "edition", themePrefix: "themePrefix", editionStartUrl: "editionStartUrl", mode: "mode" }, outputs: { goBack: "goBack" }, usesInheritance: true, ngImport: i0, template: "<div class=\"o-manifest-layout\">\n <div class=\"o-manifest-layout__toolbox -justify-space-between -align-center\">\n <button class=\"a-btn a-btn--secondary\" type=\"button\" (click)=\"close()\">\n {{ '@pry.toolbox.manifest.close' | i18n }}\n </button>\n <button class=\"a-btn a-btn--primary\" type=\"button\" (click)=\"saveDashboard()\" [disabled]=\"!isFormValid\">\n {{ '@pry.toolbox.manifest.check' | i18n }}\n </button>\n </div>\n <div class=\"o-manifest-layout__content--presentation\">\n <h2 class=\"a-h2\">{{ '@pry.presentation.add' + '.pageTitle' | i18n }}</h2>\n <div class=\"o-presentation-form-wrapper\">\n <div class=\"u-display-flex -column\">\n <pry-presentation-form\n mode=\"theme\"\n [selectedPresentation]=\"(selectedPresentation$ | async) ?? undefined\"\n (formValue)=\"formValue = $event\"\n (isFormValid)=\"isFormValid = $event\"\n [mode]=\"mode\"\n [errorDuplicatingText]=\"errorDuplicatingText\"\n [themePrefix]=\"themePrefix\"\n ></pry-presentation-form>\n <div class=\"m-form-label-field -width-full m-form-label-field--inline\">\n <label class=\"a-label\">{{ '@pry.presentation.form.grid' | i18n }}</label>\n <span class=\"a-label\">{{ '@pry.toolbox.layout.' + this.chosenLayout | i18n }}</span>\n @if (!edition) {\n <pry-select-grid-layout></pry-select-grid-layout>\n }\n </div>\n </div>\n @if (mode === 'meta') {\n @if (selectedPresentation$ | async; as selectedPresentation) {\n <div class=\"o-presentation__metadata-editor\">\n <pry-metadata-editor\n [targetId]=\"selectedPresentation.id\"\n [isModification]=\"true\"\n [metadata]=\"selectedPresentation.metadata ?? []\"\n (removeMeta)=\"removeMetadata($event)\"\n (addMeta)=\"addMetadata($event)\"\n [type]=\"'meta'\"\n ></pry-metadata-editor>\n </div>\n }\n }\n </div>\n <button\n class=\"a-btn a-btn--primary\"\n (click)=\"saveDashboard()\"\n [disabled]=\"!isFormValid\"\n >\n {{ '@pry.presentation.configuration' | i18n }}\n </button>\n </div>\n</div>\n", dependencies: [{ kind: "component", type: i4.SelectGridLayoutComponent, selector: "pry-select-grid-layout" }, { kind: "component", type: i4.PresentationFormComponent, selector: "pry-presentation-form", inputs: ["mode", "themePrefix", "errorDuplicatingText", "selectedPresentation"], outputs: ["formValue", "isFormValid"] }, { kind: "component", type: i5.PryMetadataEditorComponent, selector: "pry-metadata-editor", inputs: ["isModification", "targetId", "type", "metadata"], outputs: ["addMeta", "removeMeta"] }, { kind: "pipe", type: i2.I18nPipe, name: "i18n" }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }] }); }
|
|
137
135
|
}
|
|
138
136
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: PryAddEditPresentationComponent, decorators: [{
|
|
139
137
|
type: Component,
|
|
140
|
-
args: [{ selector: 'pry-add-edit-presentation', template: "<div class=\"o-manifest-layout\">\n <div class=\"o-manifest-layout__toolbox -justify-space-between -align-center\">\n <button class=\"a-btn a-btn--secondary\" type=\"button\" (click)=\"close()\">\n {{ '@pry.toolbox.manifest.close' | i18n }}\n </button>\n <button class=\"a-btn a-btn--primary\" type=\"button\" (click)=\"
|
|
141
|
-
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.Router, decorators: [{
|
|
138
|
+
args: [{ selector: 'pry-add-edit-presentation', template: "<div class=\"o-manifest-layout\">\n <div class=\"o-manifest-layout__toolbox -justify-space-between -align-center\">\n <button class=\"a-btn a-btn--secondary\" type=\"button\" (click)=\"close()\">\n {{ '@pry.toolbox.manifest.close' | i18n }}\n </button>\n <button class=\"a-btn a-btn--primary\" type=\"button\" (click)=\"saveDashboard()\" [disabled]=\"!isFormValid\">\n {{ '@pry.toolbox.manifest.check' | i18n }}\n </button>\n </div>\n <div class=\"o-manifest-layout__content--presentation\">\n <h2 class=\"a-h2\">{{ '@pry.presentation.add' + '.pageTitle' | i18n }}</h2>\n <div class=\"o-presentation-form-wrapper\">\n <div class=\"u-display-flex -column\">\n <pry-presentation-form\n mode=\"theme\"\n [selectedPresentation]=\"(selectedPresentation$ | async) ?? undefined\"\n (formValue)=\"formValue = $event\"\n (isFormValid)=\"isFormValid = $event\"\n [mode]=\"mode\"\n [errorDuplicatingText]=\"errorDuplicatingText\"\n [themePrefix]=\"themePrefix\"\n ></pry-presentation-form>\n <div class=\"m-form-label-field -width-full m-form-label-field--inline\">\n <label class=\"a-label\">{{ '@pry.presentation.form.grid' | i18n }}</label>\n <span class=\"a-label\">{{ '@pry.toolbox.layout.' + this.chosenLayout | i18n }}</span>\n @if (!edition) {\n <pry-select-grid-layout></pry-select-grid-layout>\n }\n </div>\n </div>\n @if (mode === 'meta') {\n @if (selectedPresentation$ | async; as selectedPresentation) {\n <div class=\"o-presentation__metadata-editor\">\n <pry-metadata-editor\n [targetId]=\"selectedPresentation.id\"\n [isModification]=\"true\"\n [metadata]=\"selectedPresentation.metadata ?? []\"\n (removeMeta)=\"removeMetadata($event)\"\n (addMeta)=\"addMetadata($event)\"\n [type]=\"'meta'\"\n ></pry-metadata-editor>\n </div>\n }\n }\n </div>\n <button\n class=\"a-btn a-btn--primary\"\n (click)=\"saveDashboard()\"\n [disabled]=\"!isFormValid\"\n >\n {{ '@pry.presentation.configuration' | i18n }}\n </button>\n </div>\n</div>\n" }]
|
|
139
|
+
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.ManifestService }, { type: i3.Router, decorators: [{
|
|
142
140
|
type: Optional
|
|
143
141
|
}] }], propDecorators: { selectedPresentation: [{
|
|
144
142
|
type: Input
|
|
@@ -153,4 +151,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImpor
|
|
|
153
151
|
}], goBack: [{
|
|
154
152
|
type: Output
|
|
155
153
|
}] } });
|
|
156
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-edit-presentation.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/presentation/components/add-edit-presentation/add-edit-presentation.component.ts","../../../../../../../projects/provoly/dashboard/presentation/components/add-edit-presentation/add-edit-presentation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Optional, Output } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  DashboardActions,\n  DashboardGridLayout,\n  DashboardSelectors,\n  GlobalManifest,\n  IMetadata,\n  ManifestDescription,\n  MetadataValue,\n  SubscriptionnerDirective,\n  ViewMode,\n  WidgetPlacementUtils\n} from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, Observable, take } from 'rxjs';\nimport { MetadataSelectors, MetaEventType } from '@provoly/dashboard/components/metadata-editor';\nimport { v4 as uuidv4 } from 'uuid';\nimport { PresentationFormValue } from '@provoly/dashboard/toolbox';\n\n@Component({\n  selector: 'pry-add-edit-presentation',\n  templateUrl: './add-edit-presentation.component.html'\n})\nexport class PryAddEditPresentationComponent extends SubscriptionnerDirective {\n  staticManifest$: Observable<GlobalManifest>;\n  staticManifest?: GlobalManifest;\n  selectedPresentation$ = new BehaviorSubject<ManifestDescription | undefined>(undefined);\n  chosenLayout: string = DashboardGridLayout.FULL;\n  metadataDefs: IMetadata[] | undefined;\n  metadataThemeId: string = '';\n  formValue?: Partial<PresentationFormValue>;\n  isFormValid = false;\n\n  @Input() set selectedPresentation(presentation: ManifestDescription | undefined) {\n    this.selectedPresentation$.next(presentation);\n  }\n  @Input() edition: boolean = false;\n  @Input() themePrefix: string | null = null;\n  @Input() editionStartUrl: string = '/';\n  @Input() mode: 'theme' | 'meta' = 'meta';\n\n  @Output() goBack = new EventEmitter<void>();\n\n  constructor(\n    protected store: Store,\n    @Optional() protected router: Router\n  ) {\n    super();\n    this.staticManifest$ = this.store.select(DashboardSelectors.staticManifest);\n    this.subscriptions.add(this.staticManifest$.subscribe(manifest => this.staticManifest = manifest));\n    this.subscriptions.add(\n      combineLatest([this.staticManifest$, this.store.select(DashboardSelectors.gridLayout)]).subscribe(\n        ([staticManifest, gridLayout]) => {\n          this.chosenLayout =\n            this.edition && staticManifest.windows[0]?.grid?.layout !== undefined\n              ? staticManifest.windows[0]?.grid?.layout\n              : gridLayout;\n        }\n      )\n    );\n    this.subscriptions.add(\n      this.store.select(MetadataSelectors.metadata).subscribe((metadata) => {\n        this.metadataDefs = metadata;\n        const metadataTheme = metadata?.find((meta) => meta.name === '_theme');\n        if (metadataTheme) {\n          this.metadataThemeId = metadataTheme?.id ?? '';\n        }\n      })\n    );\n  }\n\n  dispatchSave(): ManifestDescription {\n    const presentation = {\n      ...this.selectedPresentation$.value!,\n      id: this.selectedPresentation$.value?.id || uuidv4(),\n      ...this.formValue,\n      metadata: this.metadata()\n    };\n\n    this.store.dispatch(\n      DashboardActions.saveManifest({\n        ...presentation,\n        metadata: presentation.metadata?.map((metadata: MetadataValue) => ({\n          metadataDefId: metadata.metadataDef.id,\n          value: metadata.value\n        })),\n        manifest: this.edition ? this.staticManifest : this.getNewManifest()\n      })\n    );\n    return presentation;\n  }\n\n  save() {\n    const presentation = this.dispatchSave();\n    this.store.dispatch(\n      DashboardActions.selectPresentation({\n        presentation,\n        viewMode: ViewMode.EDITION\n      })\n    );\n  }\n\n  configureDashboard(selectedPresentation: ManifestDescription) {\n    if (this.isFormValid) {\n      this.dispatchSave();\n    }\n\n    const presentation = {\n      ...this.selectedPresentation$.value!,\n      ...this.formValue,\n      metadata: this.metadata()\n    };\n\n    if (!this.edition) {\n      this.store.dispatch(\n        DashboardActions.selectPresentation({\n          presentation,\n          viewMode: ViewMode.CREATION\n        })\n      );\n    } else {\n      this.store.dispatch(\n        DashboardActions.loadPresentation({\n          presentation,\n          viewMode: ViewMode.EDITION\n        })\n      );\n    }\n    this.router?.navigateByUrl(this.editionStartUrl);\n  }\n\n  addMetadata(metadata: MetaEventType) {\n    this.store.dispatch(\n      DashboardActions.addManifestMetadata({\n        presentationId: this.selectedPresentation$.value?.id!,\n        metadataId: metadata.metadataId,\n        value: metadata.value ?? ''\n      })\n    );\n  }\n\n  removeMetadata(metadata: MetaEventType) {\n    this.store.dispatch(\n      DashboardActions.deleteManifestMetadata({\n        presentationId: this.selectedPresentation$.value?.id!,\n        metadataId: metadata.metadataId\n      })\n    );\n  }\n\n  close() {\n    this.goBack.emit();\n  }\n\n  metadata(): MetadataValue[] {\n    return this.mode === 'theme'\n      ? !this.formValue?.theme || this.formValue?.theme === ''\n        ? []\n        : [\n            {\n              metadataDef: this.metadataDefs!.find((metadata) => metadata.id === this.metadataThemeId)!,\n              value: this.formValue.theme ?? ''\n            }\n          ]\n      : this.selectedPresentation$.value?.metadata ?? [];\n  }\n\n  getNewManifest(): GlobalManifest {\n    return {\n      windows: [\n        {\n          widgets: [],\n          grid: {\n            layout: this.chosenLayout,\n            columns: WidgetPlacementUtils.getLayout(this.chosenLayout)?.columns,\n            rows: WidgetPlacementUtils.getLayout(this.chosenLayout)?.rows\n          }\n        }\n      ]\n    };\n  }\n}\n","<div class=\"o-manifest-layout\">\n  <div class=\"o-manifest-layout__toolbox -justify-space-between -align-center\">\n    <button class=\"a-btn a-btn--secondary\" type=\"button\" (click)=\"close()\">\n      {{ '@pry.toolbox.manifest.close' | i18n }}\n    </button>\n    <button class=\"a-btn a-btn--primary\" type=\"button\" (click)=\"save()\" [disabled]=\"!isFormValid\">\n      {{ '@pry.toolbox.manifest.check' | i18n }}\n    </button>\n  </div>\n  <div class=\"o-manifest-layout__content--presentation\">\n    <h2 class=\"a-h2\">{{ '@pry.presentation.add' + '.pageTitle' | i18n }}</h2>\n    <div class=\"o-presentation-form-wrapper\">\n      <div class=\"u-display-flex -column\">\n        <pry-presentation-form\n          mode=\"theme\"\n          [selectedPresentation]=\"(selectedPresentation$ | async) ?? undefined\"\n          (formValue)=\"formValue = $event\"\n          (isFormValid)=\"isFormValid = $event\"\n          [mode]=\"mode\"\n          [themePrefix]=\"themePrefix\"\n        ></pry-presentation-form>\n        <div class=\"m-form-label-field -width-full m-form-label-field--inline\">\n          <label class=\"a-label\">{{ '@pry.presentation.form.grid' | i18n }}</label>\n          <span class=\"a-label\">{{ '@pry.toolbox.layout.' + this.chosenLayout | i18n }}</span>\n          @if (!edition) {\n            <pry-select-grid-layout></pry-select-grid-layout>\n          }\n        </div>\n      </div>\n      @if (mode === 'meta') {\n        @if (selectedPresentation$ | async; as selectedPresentation) {\n          <div class=\"o-presentation__metadata-editor\">\n            <pry-metadata-editor\n              [targetId]=\"selectedPresentation.id\"\n              [isModification]=\"true\"\n              [metadata]=\"selectedPresentation.metadata ?? []\"\n              (removeMeta)=\"removeMetadata($event)\"\n              (addMeta)=\"addMetadata($event)\"\n              [type]=\"'meta'\"\n            ></pry-metadata-editor>\n          </div>\n        }\n      }\n    </div>\n    <button\n      class=\"a-btn a-btn--primary\"\n      (click)=\"configureDashboard(selectedPresentation$.value!)\"\n      [disabled]=\"!isFormValid\"\n      >\n      {{ '@pry.presentation.configuration' | i18n }}\n    </button>\n  </div>\n</div>\n"]}
|
|
154
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-edit-presentation.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/presentation/components/add-edit-presentation/add-edit-presentation.component.ts","../../../../../../../projects/provoly/dashboard/presentation/components/add-edit-presentation/add-edit-presentation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Optional, Output } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  DashboardActions,\n  DashboardGridLayout,\n  DashboardSelectors,\n  GlobalManifest,\n  IMetadata,\n  ManifestDescription,\n  ManifestService,\n  MetadataValue,\n  SubscriptionnerDirective,\n  ViewMode,\n  WidgetPlacementUtils\n} from '@provoly/dashboard';\nimport {BehaviorSubject, catchError, combineLatest, Observable, throwError} from 'rxjs';\nimport { MetadataSelectors, MetaEventType } from '@provoly/dashboard/components/metadata-editor';\nimport { v4 as uuidv4 } from 'uuid';\nimport { PresentationFormValue } from '@provoly/dashboard/toolbox';\n\n@Component({\n  selector: 'pry-add-edit-presentation',\n  templateUrl: './add-edit-presentation.component.html'\n})\nexport class PryAddEditPresentationComponent extends SubscriptionnerDirective {\n  staticManifest$: Observable<GlobalManifest>;\n  staticManifest?: GlobalManifest;\n  selectedPresentation$ = new BehaviorSubject<ManifestDescription | undefined>(undefined);\n  chosenLayout: string = DashboardGridLayout.FULL;\n  metadataDefs: IMetadata[] | undefined;\n  metadataThemeId: string = '';\n  formValue?: Partial<PresentationFormValue>;\n  isFormValid = false;\n  errorDuplicatingText: string | null = null;\n\n  @Input() set selectedPresentation(presentation: ManifestDescription | undefined) {\n    this.selectedPresentation$.next(presentation);\n  }\n  @Input() edition: boolean = false;\n  @Input() themePrefix: string | null = null;\n  @Input() editionStartUrl: string = '/';\n  @Input() mode: 'theme' | 'meta' = 'meta';\n\n  @Output() goBack = new EventEmitter<void>();\n\n  constructor(\n    protected store: Store,\n    private manifestService: ManifestService,\n    @Optional() protected router: Router\n  ) {\n    super();\n    this.staticManifest$ = this.store.select(DashboardSelectors.staticManifest);\n    this.subscriptions.add(this.staticManifest$.subscribe((manifest) => (this.staticManifest = manifest)));\n    this.subscriptions.add(\n      combineLatest([this.staticManifest$, this.store.select(DashboardSelectors.gridLayout)]).subscribe(\n        ([staticManifest, gridLayout]) => {\n          this.chosenLayout =\n            this.edition && staticManifest.windows[0]?.grid?.layout !== undefined\n              ? staticManifest.windows[0]?.grid?.layout\n              : gridLayout;\n        }\n      )\n    );\n    this.subscriptions.add(\n      this.store.select(MetadataSelectors.metadata).subscribe((metadata) => {\n        this.metadataDefs = metadata;\n        const metadataTheme = metadata?.find((meta) => meta.name === '_theme');\n        if (metadataTheme) {\n          this.metadataThemeId = metadataTheme?.id ?? '';\n        }\n      })\n    );\n  }\n\n  saveOrUpdateDashboard() {\n    const presentation = {\n      ...this.selectedPresentation$.value!,\n      id: this.selectedPresentation$.value?.id || uuidv4(),\n      ...this.formValue,\n      metadata: this.metadata()\n    };\n    this.errorDuplicatingText = null;\n    this.manifestService\n      .save(\n        presentation.name,\n        this.edition ? (this.staticManifest as GlobalManifest) : this.getNewManifest(),\n        presentation.id,\n        presentation.description,\n        presentation.image,\n        presentation.metadata?.map((metadata: MetadataValue) => ({\n          metadataDefId: metadata.metadataDef.id,\n          value: metadata.value\n        })),\n        presentation.accessRightsByGroup,\n        presentation.additionalInformation\n      )\n      .pipe(\n        catchError((error) => {\n          this.errorDuplicatingText = '@chh.message.failure.alreadyExisting';\n          return throwError(error);\n        })\n      )\n      .subscribe(() => {\n        const presentation = {\n          ...this.selectedPresentation$.value!,\n          ...this.formValue,\n          metadata: this.metadata()\n        };\n\n        if (!this.edition) {\n          this.store.dispatch(\n            DashboardActions.selectPresentation({\n              presentation,\n              viewMode: ViewMode.CREATION\n            })\n          );\n        } else {\n          this.store.dispatch(\n            DashboardActions.loadPresentation({\n              presentation,\n              viewMode: ViewMode.EDITION\n            })\n          );\n        }\n        this.router?.navigateByUrl(this.editionStartUrl);\n      });\n  }\n\n  saveDashboard() {\n    if (this.isFormValid) {\n      this.saveOrUpdateDashboard();\n    }\n  }\n\n  addMetadata(metadata: MetaEventType) {\n    this.store.dispatch(\n      DashboardActions.addManifestMetadata({\n        presentationId: this.selectedPresentation$.value?.id!,\n        metadataId: metadata.metadataId,\n        value: metadata.value ?? ''\n      })\n    );\n  }\n\n  removeMetadata(metadata: MetaEventType) {\n    this.store.dispatch(\n      DashboardActions.deleteManifestMetadata({\n        presentationId: this.selectedPresentation$.value?.id!,\n        metadataId: metadata.metadataId\n      })\n    );\n  }\n\n  close() {\n    this.goBack.emit();\n  }\n\n  metadata(): MetadataValue[] {\n    return this.mode === 'theme'\n      ? !this.formValue?.theme || this.formValue?.theme === ''\n        ? []\n        : [\n            {\n              metadataDef: this.metadataDefs!.find((metadata) => metadata.id === this.metadataThemeId)!,\n              value: this.formValue.theme ?? ''\n            }\n          ]\n      : this.selectedPresentation$.value?.metadata ?? [];\n  }\n\n  getNewManifest(): GlobalManifest {\n    return {\n      windows: [\n        {\n          widgets: [],\n          grid: {\n            layout: this.chosenLayout,\n            columns: WidgetPlacementUtils.getLayout(this.chosenLayout)?.columns,\n            rows: WidgetPlacementUtils.getLayout(this.chosenLayout)?.rows\n          }\n        }\n      ]\n    };\n  }\n}\n","<div class=\"o-manifest-layout\">\n  <div class=\"o-manifest-layout__toolbox -justify-space-between -align-center\">\n    <button class=\"a-btn a-btn--secondary\" type=\"button\" (click)=\"close()\">\n      {{ '@pry.toolbox.manifest.close' | i18n }}\n    </button>\n    <button class=\"a-btn a-btn--primary\" type=\"button\" (click)=\"saveDashboard()\" [disabled]=\"!isFormValid\">\n      {{ '@pry.toolbox.manifest.check' | i18n }}\n    </button>\n  </div>\n  <div class=\"o-manifest-layout__content--presentation\">\n    <h2 class=\"a-h2\">{{ '@pry.presentation.add' + '.pageTitle' | i18n }}</h2>\n    <div class=\"o-presentation-form-wrapper\">\n      <div class=\"u-display-flex -column\">\n        <pry-presentation-form\n          mode=\"theme\"\n          [selectedPresentation]=\"(selectedPresentation$ | async) ?? undefined\"\n          (formValue)=\"formValue = $event\"\n          (isFormValid)=\"isFormValid = $event\"\n          [mode]=\"mode\"\n          [errorDuplicatingText]=\"errorDuplicatingText\"\n          [themePrefix]=\"themePrefix\"\n        ></pry-presentation-form>\n        <div class=\"m-form-label-field -width-full m-form-label-field--inline\">\n          <label class=\"a-label\">{{ '@pry.presentation.form.grid' | i18n }}</label>\n          <span class=\"a-label\">{{ '@pry.toolbox.layout.' + this.chosenLayout | i18n }}</span>\n          @if (!edition) {\n            <pry-select-grid-layout></pry-select-grid-layout>\n          }\n        </div>\n      </div>\n      @if (mode === 'meta') {\n        @if (selectedPresentation$ | async; as selectedPresentation) {\n          <div class=\"o-presentation__metadata-editor\">\n            <pry-metadata-editor\n              [targetId]=\"selectedPresentation.id\"\n              [isModification]=\"true\"\n              [metadata]=\"selectedPresentation.metadata ?? []\"\n              (removeMeta)=\"removeMetadata($event)\"\n              (addMeta)=\"addMetadata($event)\"\n              [type]=\"'meta'\"\n            ></pry-metadata-editor>\n          </div>\n        }\n      }\n    </div>\n    <button\n      class=\"a-btn a-btn--primary\"\n      (click)=\"saveDashboard()\"\n      [disabled]=\"!isFormValid\"\n      >\n      {{ '@pry.presentation.configuration' | i18n }}\n    </button>\n  </div>\n</div>\n"]}
|
|
@@ -47,7 +47,7 @@ export class EditPresentationComponent extends ToolboxActionComponent {
|
|
|
47
47
|
}));
|
|
48
48
|
}
|
|
49
49
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: EditPresentationComponent, deps: [{ token: i1.Store }, { token: PRY_ACCESS_TOKEN, optional: true }, { token: i2.Overlay }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
50
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: EditPresentationComponent, selector: "pry-edit-details", viewQueries: [{ propertyName: "template", first: true, predicate: ["template"], descendants: true, read: TemplateRef }], usesInheritance: true, ngImport: i0, template: "@if (canModify$ | async) {\n <button type=\"button\" class=\"a-btn a-btn--secondary\" (click)=\"openModal()\">\n @if (displayLabels) {\n {{ '@pry.toolbox.editPresentation' | i18n }}\n }\n </button>\n}\n\n<ng-template #template>\n <div\n class=\"o-modal\"\n (click)=\"$event.stopPropagation()\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"dialog_title\"\n id=\"grid-layout\"\n (keydown.escape)=\"closeModal()\"\n cdkTrapFocus\n [cdkTrapFocusAutoCapture]=\"true\"\n >\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.editPresentation' | i18n }}</h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" (click)=\"closeModal()\">\n <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n </button>\n </div>\n </div>\n <pry-presentation-form\n [selectedPresentation]=\"(currentManifest$ | async) ?? undefined\"\n (formValue)=\"formValue = $event\"\n (isFormValid)=\"isFormValid = $event\"\n ></pry-presentation-form>\n <div class=\"m-btn-group -space-evenly\">\n <button (click)=\"closeModal()\" class=\"a-btn a-btn--secondary\">\n {{ '@pry.toolbox.manifest.close' | i18n }}\n </button>\n <button (click)=\"save()\" [disabled]=\"!isFormValid\" class=\"a-btn a-btn--primary\">\n {{ '@pry.toolbox.manifest.validated' | i18n }}\n </button>\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "component", type: i3.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "directive", type: i4.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { kind: "component", type: i5.PresentationFormComponent, selector: "pry-presentation-form", inputs: ["mode", "themePrefix", "selectedPresentation"], outputs: ["formValue", "isFormValid"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.I18nPipe, name: "i18n" }] }); }
|
|
50
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: EditPresentationComponent, selector: "pry-edit-details", viewQueries: [{ propertyName: "template", first: true, predicate: ["template"], descendants: true, read: TemplateRef }], usesInheritance: true, ngImport: i0, template: "@if (canModify$ | async) {\n <button type=\"button\" class=\"a-btn a-btn--secondary\" (click)=\"openModal()\">\n @if (displayLabels) {\n {{ '@pry.toolbox.editPresentation' | i18n }}\n }\n </button>\n}\n\n<ng-template #template>\n <div\n class=\"o-modal\"\n (click)=\"$event.stopPropagation()\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"dialog_title\"\n id=\"grid-layout\"\n (keydown.escape)=\"closeModal()\"\n cdkTrapFocus\n [cdkTrapFocusAutoCapture]=\"true\"\n >\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.editPresentation' | i18n }}</h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" (click)=\"closeModal()\">\n <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n </button>\n </div>\n </div>\n <pry-presentation-form\n [selectedPresentation]=\"(currentManifest$ | async) ?? undefined\"\n (formValue)=\"formValue = $event\"\n (isFormValid)=\"isFormValid = $event\"\n ></pry-presentation-form>\n <div class=\"m-btn-group -space-evenly\">\n <button (click)=\"closeModal()\" class=\"a-btn a-btn--secondary\">\n {{ '@pry.toolbox.manifest.close' | i18n }}\n </button>\n <button (click)=\"save()\" [disabled]=\"!isFormValid\" class=\"a-btn a-btn--primary\">\n {{ '@pry.toolbox.manifest.validated' | i18n }}\n </button>\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "component", type: i3.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "directive", type: i4.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { kind: "component", type: i5.PresentationFormComponent, selector: "pry-presentation-form", inputs: ["mode", "themePrefix", "errorDuplicatingText", "selectedPresentation"], outputs: ["formValue", "isFormValid"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.I18nPipe, name: "i18n" }] }); }
|
|
51
51
|
}
|
|
52
52
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: EditPresentationComponent, decorators: [{
|
|
53
53
|
type: Component,
|
|
@@ -166,7 +166,7 @@ export class SaveViewComponent extends ToolboxActionComponent {
|
|
|
166
166
|
}
|
|
167
167
|
}
|
|
168
168
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: SaveViewComponent, deps: [{ token: i1.Store }, { token: PRY_ACCESS_TOKEN, optional: true }, { token: i2.Overlay }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
169
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: SaveViewComponent, selector: "pry-save-view", inputs: { mode: "mode" }, viewQueries: [{ propertyName: "saveAs", first: true, predicate: ["saveAs"], descendants: true }, { propertyName: "directiveSave", first: true, predicate: ["directiveSave"], descendants: true }, { propertyName: "firstFocusdirective", first: true, predicate: ["firstFocusdirective"], descendants: true }, { propertyName: "cross", first: true, predicate: ["cross"], descendants: true }, { propertyName: "confirm", first: true, predicate: ["confirm"], descendants: true }, { propertyName: "cancel", first: true, predicate: ["cancel"], descendants: true }, { propertyName: "templateSaveAs", first: true, predicate: ["templateSaveAs"], descendants: true, read: TemplateRef }, { propertyName: "templateDirectSaveType", first: true, predicate: ["templateDirectSaveType"], descendants: true, read: TemplateRef }], usesInheritance: true, ngImport: i0, template: "<ng-container *pryAccess=\"{ module: 'dashboard', page: 'toolbox', action: 'save' }\">\n @if (mode === 'directSave') {\n <div [attr.aria-expanded]=\"saveTypeOpened\" aria-controls=\"directiveSave\" aria-describedby=\"infoTooltip_directSave\">\n @if (canModify$ | async) {\n <button\n type=\"button\"\n #directiveSave\n class=\"a-btn a-btn--primary\"\n (click)=\"directSave()\"\n [disabled]=\"!(isCurrentPresentationModified$ | async)\"\n >\n @if (displayLabels) {\n {{\n '@pry.toolbox.save' | i18n: { nbPages: '(' + nbPages + ')' }\n }}\n }\n </button>\n }\n </div>\n }\n @if (mode === 'saveAs') {\n <div\n class=\"save-manifest-container\"\n [attr.aria-expanded]=\"saveAsOpened\"\n aria-controls=\"saveModal\"\n aria-describedby=\"infoTooltip_saveAs\"\n >\n <button type=\"button\" #saveAs class=\"a-btn a-btn--secondary\" (click)=\"toggleSaveAs()\" aria-haspopup=\"dialog\">\n @if (displayLabels) {\n {{\n '@pry.toolbox.rename' | i18n: { nbPages: '(' + nbPages + ')' }\n }}\n }\n </button>\n </div>\n }\n</ng-container>\n<ng-template #templateSaveAs>\n <div\n class=\"o-modal\"\n (click)=\"$event.stopPropagation()\"\n id=\"saveModal\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"dialog_saveModal\"\n (keydown.escape)=\"closeModals()\"\n >\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.rename' | i18n }}</h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" #cross (keydown.shift.tab)=\"focusValidation()\" (click)=\"toggleSaveAs()\">\n <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n </button>\n </div>\n </div>\n <pry-stepper #stepper>\n <pry-step>\n <h4 class=\"m-stepper-item__title\" *stepTitle>{{ '@pry.presentation.add.info' | i18n }}</h4>\n <pry-presentation-form\n [selectedPresentation]=\"currentManifest\"\n (formValue)=\"formValue = $event\"\n (isFormValid)=\"isFormValid = $event\"\n ></pry-presentation-form>\n <div class=\"m-btn-group\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--secondary\"\n #cancel\n (click)=\"toggleSaveAs()\"\n (keydown.tab)=\"disableNextStep()\"\n >\n {{ '@pry.toolbox.manifest.close' | i18n }}\n </button>\n <button\n type=\"submit\"\n class=\"a-btn a-btn--primary\"\n (click)=\"stepper.next()\"\n [disabled]=\"!isFormValid\"\n (keydown.tab)=\"focusCrossElement()\"\n >\n {{ '@pry.action.next' | i18n }}\n </button>\n </div>\n </pry-step>\n <pry-step>\n <h4 class=\"m-stepper-item__title\" *stepTitle>{{ '@pry.restitution.share' | i18n }}</h4>\n <pry-access-rights-share\n [(ngModel)]=\"accessRightsByGroup\"\n (ngModelChange)=\"changeAccessRights($event)\"\n [manifestDescription]=\"currentManifest\"\n ></pry-access-rights-share>\n <div class=\"m-btn-group\">\n <button type=\"button\" class=\"a-btn a-btn--secondary\" (click)=\"stepper.prev()\">\n {{ '@pry.action.back' | i18n }}\n </button>\n <button\n type=\"submit\"\n class=\"a-btn a-btn--primary\"\n #confirm\n (click)=\"save()\"\n (keydown.tab)=\"focusCrossElement()\"\n >\n {{ '@pry.restitution.share' | i18n }}\n </button>\n </div>\n </pry-step>\n </pry-stepper>\n </div>\n</ng-template>\n\n<ng-template #templateDirectSaveType>\n <div\n class=\"o-modal\"\n (click)=\"$event.stopPropagation()\"\n id=\"directiveSave\"\n role=\"dialog\"\n aria-labelledby=\"dialog_title\"\n (keydown.escape)=\"closeModals()\"\n >\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\" id=\"dialog_title_\">{{ '@pry.toolbox.save' | i18n }}</h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" #firstFocusdirective (click)=\"toggleDirectSaveType()\">\n <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n </button>\n </div>\n </div>\n <div>\n <h3>{{ '@pry.snack.pagesChanged' | i18n }}</h3>\n </div>\n <div class=\"m-btn-group\">\n <button class=\"a-btn a-btn--primary\" (click)=\"save()\">\n {{ '@pry.toolbox.save' | i18n }}\n </button>\n <button class=\"a-btn a-btn--primary\" (click)=\"rename()\">\n {{ '@pry.toolbox.rename' | i18n }}\n </button>\n <button class=\"a-btn a-btn--primary\" (click)=\"restore()\" (keydown.tab)=\"closeModals()\">\n {{ '@pry.toolbox.restore' | i18n }}\n </button>\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.PryAccessDirective, selector: "[pryAccess]", inputs: ["pryAccess"] }, { kind: "component", type: i4.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "component", type: i5.PryStepperComponent, selector: "pry-stepper", inputs: ["isConsultMode"], outputs: ["lastStepCompleted", "activeIndexChange"] }, { kind: "component", type: i5.PryStepComponent, selector: "pry-step", inputs: ["setActiveState"] }, { kind: "directive", type: i5.PryStepTitleDirective, selector: "[stepTitle]" }, { kind: "component", type: i4.PryAccessRightsShareComponent, selector: "pry-access-rights-share", inputs: ["manifestDescription", "allowedGroups"] }, { kind: "component", type: i6.PresentationFormComponent, selector: "pry-presentation-form", inputs: ["mode", "themePrefix", "selectedPresentation"], outputs: ["formValue", "isFormValid"] }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] }); }
|
|
169
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: SaveViewComponent, selector: "pry-save-view", inputs: { mode: "mode" }, viewQueries: [{ propertyName: "saveAs", first: true, predicate: ["saveAs"], descendants: true }, { propertyName: "directiveSave", first: true, predicate: ["directiveSave"], descendants: true }, { propertyName: "firstFocusdirective", first: true, predicate: ["firstFocusdirective"], descendants: true }, { propertyName: "cross", first: true, predicate: ["cross"], descendants: true }, { propertyName: "confirm", first: true, predicate: ["confirm"], descendants: true }, { propertyName: "cancel", first: true, predicate: ["cancel"], descendants: true }, { propertyName: "templateSaveAs", first: true, predicate: ["templateSaveAs"], descendants: true, read: TemplateRef }, { propertyName: "templateDirectSaveType", first: true, predicate: ["templateDirectSaveType"], descendants: true, read: TemplateRef }], usesInheritance: true, ngImport: i0, template: "<ng-container *pryAccess=\"{ module: 'dashboard', page: 'toolbox', action: 'save' }\">\n @if (mode === 'directSave') {\n <div [attr.aria-expanded]=\"saveTypeOpened\" aria-controls=\"directiveSave\" aria-describedby=\"infoTooltip_directSave\">\n @if (canModify$ | async) {\n <button\n type=\"button\"\n #directiveSave\n class=\"a-btn a-btn--primary\"\n (click)=\"directSave()\"\n [disabled]=\"!(isCurrentPresentationModified$ | async)\"\n >\n @if (displayLabels) {\n {{\n '@pry.toolbox.save' | i18n: { nbPages: '(' + nbPages + ')' }\n }}\n }\n </button>\n }\n </div>\n }\n @if (mode === 'saveAs') {\n <div\n class=\"save-manifest-container\"\n [attr.aria-expanded]=\"saveAsOpened\"\n aria-controls=\"saveModal\"\n aria-describedby=\"infoTooltip_saveAs\"\n >\n <button type=\"button\" #saveAs class=\"a-btn a-btn--secondary\" (click)=\"toggleSaveAs()\" aria-haspopup=\"dialog\">\n @if (displayLabels) {\n {{\n '@pry.toolbox.rename' | i18n: { nbPages: '(' + nbPages + ')' }\n }}\n }\n </button>\n </div>\n }\n</ng-container>\n<ng-template #templateSaveAs>\n <div\n class=\"o-modal\"\n (click)=\"$event.stopPropagation()\"\n id=\"saveModal\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"dialog_saveModal\"\n (keydown.escape)=\"closeModals()\"\n >\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.rename' | i18n }}</h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" #cross (keydown.shift.tab)=\"focusValidation()\" (click)=\"toggleSaveAs()\">\n <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n </button>\n </div>\n </div>\n <pry-stepper #stepper>\n <pry-step>\n <h4 class=\"m-stepper-item__title\" *stepTitle>{{ '@pry.presentation.add.info' | i18n }}</h4>\n <pry-presentation-form\n [selectedPresentation]=\"currentManifest\"\n (formValue)=\"formValue = $event\"\n (isFormValid)=\"isFormValid = $event\"\n ></pry-presentation-form>\n <div class=\"m-btn-group\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--secondary\"\n #cancel\n (click)=\"toggleSaveAs()\"\n (keydown.tab)=\"disableNextStep()\"\n >\n {{ '@pry.toolbox.manifest.close' | i18n }}\n </button>\n <button\n type=\"submit\"\n class=\"a-btn a-btn--primary\"\n (click)=\"stepper.next()\"\n [disabled]=\"!isFormValid\"\n (keydown.tab)=\"focusCrossElement()\"\n >\n {{ '@pry.action.next' | i18n }}\n </button>\n </div>\n </pry-step>\n <pry-step>\n <h4 class=\"m-stepper-item__title\" *stepTitle>{{ '@pry.restitution.share' | i18n }}</h4>\n <pry-access-rights-share\n [(ngModel)]=\"accessRightsByGroup\"\n (ngModelChange)=\"changeAccessRights($event)\"\n [manifestDescription]=\"currentManifest\"\n ></pry-access-rights-share>\n <div class=\"m-btn-group\">\n <button type=\"button\" class=\"a-btn a-btn--secondary\" (click)=\"stepper.prev()\">\n {{ '@pry.action.back' | i18n }}\n </button>\n <button\n type=\"submit\"\n class=\"a-btn a-btn--primary\"\n #confirm\n (click)=\"save()\"\n (keydown.tab)=\"focusCrossElement()\"\n >\n {{ '@pry.restitution.share' | i18n }}\n </button>\n </div>\n </pry-step>\n </pry-stepper>\n </div>\n</ng-template>\n\n<ng-template #templateDirectSaveType>\n <div\n class=\"o-modal\"\n (click)=\"$event.stopPropagation()\"\n id=\"directiveSave\"\n role=\"dialog\"\n aria-labelledby=\"dialog_title\"\n (keydown.escape)=\"closeModals()\"\n >\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\" id=\"dialog_title_\">{{ '@pry.toolbox.save' | i18n }}</h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" #firstFocusdirective (click)=\"toggleDirectSaveType()\">\n <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n </button>\n </div>\n </div>\n <div>\n <h3>{{ '@pry.snack.pagesChanged' | i18n }}</h3>\n </div>\n <div class=\"m-btn-group\">\n <button class=\"a-btn a-btn--primary\" (click)=\"save()\">\n {{ '@pry.toolbox.save' | i18n }}\n </button>\n <button class=\"a-btn a-btn--primary\" (click)=\"rename()\">\n {{ '@pry.toolbox.rename' | i18n }}\n </button>\n <button class=\"a-btn a-btn--primary\" (click)=\"restore()\" (keydown.tab)=\"closeModals()\">\n {{ '@pry.toolbox.restore' | i18n }}\n </button>\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.PryAccessDirective, selector: "[pryAccess]", inputs: ["pryAccess"] }, { kind: "component", type: i4.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "component", type: i5.PryStepperComponent, selector: "pry-stepper", inputs: ["isConsultMode"], outputs: ["lastStepCompleted", "activeIndexChange"] }, { kind: "component", type: i5.PryStepComponent, selector: "pry-step", inputs: ["setActiveState"] }, { kind: "directive", type: i5.PryStepTitleDirective, selector: "[stepTitle]" }, { kind: "component", type: i4.PryAccessRightsShareComponent, selector: "pry-access-rights-share", inputs: ["manifestDescription", "allowedGroups"] }, { kind: "component", type: i6.PresentationFormComponent, selector: "pry-presentation-form", inputs: ["mode", "themePrefix", "errorDuplicatingText", "selectedPresentation"], outputs: ["formValue", "isFormValid"] }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] }); }
|
|
170
170
|
}
|
|
171
171
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: SaveViewComponent, decorators: [{
|
|
172
172
|
type: Component,
|
|
@@ -30,6 +30,7 @@ export class PresentationFormComponent extends SubscriptionnerDirective {
|
|
|
30
30
|
this.possibleThemes = [];
|
|
31
31
|
this.mode = 'meta';
|
|
32
32
|
this.themePrefix = null;
|
|
33
|
+
this.errorDuplicatingText = null;
|
|
33
34
|
this.selectedPresentation$ = new BehaviorSubject(undefined);
|
|
34
35
|
this.formValue = new BehaviorSubject(undefined);
|
|
35
36
|
this.isFormValid = new BehaviorSubject(false);
|
|
@@ -88,15 +89,17 @@ export class PresentationFormComponent extends SubscriptionnerDirective {
|
|
|
88
89
|
this.formValue.next(this.getFormValue());
|
|
89
90
|
}
|
|
90
91
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: PresentationFormComponent, deps: [{ token: i1.Store }, { token: i2.PryI18nService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
91
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: PresentationFormComponent, selector: "pry-presentation-form", inputs: { mode: "mode", themePrefix: "themePrefix", selectedPresentation: "selectedPresentation" }, outputs: { formValue: "formValue", isFormValid: "isFormValid" }, viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<form [formGroup]=\"form\" class=\"o-presentation-form\">\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_name\"\n >{{ '@pry.presentation.form.name.title' | i18n }}<span class=\"required\">*</span></label\n >\n <input\n type=\"text\"\n id=\"presentation_name\"\n formControlName=\"name\"\n placeholder=\"{{ '@pry.presentation.form.name.placeholder' | i18n }}\"\n class=\"a-form-field\"\n maxlength=\"50\"\n required\n #input\n />\n @if (name.touched && name.errors?.['required']) {\n <label for=\"presentation_name\" class=\"a-label a-label--help -error\">\n {{ '@pry.presentation.required' | i18n }}\n </label>\n }\n @if (name.touched && name.errors?.['maxlength']) {\n <label for=\"presentation_name\" class=\"a-label a-label--help -error\">\n {{ '@pry.presentation.maxLength' | i18n: { len: '50' } }}\n </label>\n }\n </div>\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_description\">{{\n '@pry.presentation.form.description.title' | i18n\n }}</label>\n <textarea\n formControlName=\"description\"\n id=\"presentation_description\"\n name=\"description\"\n cols=\"30\"\n rows=\"5\"\n maxlength=\"200\"\n placeholder=\"{{ '@pry.presentation.form.description.placeholder' | i18n }}\"\n class=\"a-form-field\"\n ></textarea>\n @if (description.touched && description.errors?.['maxlength']) {\n <label for=\"presentation_description\" class=\"a-label a-label--help -error\">\n {{ '@pry.presentation.maxLength' | i18n: { len: '200' } }}\n </label>\n }\n </div>\n @if (mode === 'theme') {\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_theme\"\n >{{ '@pry.presentation.form.theme' | i18n }}<span class=\"required\">*</span></label\n >\n <pry-select\n id=\"presentation_theme\"\n [items]=\"possibleThemes\"\n formControlName=\"theme\"\n [clearable]=\"true\"\n [i18nPrefix]=\"themePrefix\"\n ></pry-select>\n </div>\n }\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_image\">{{ '@pry.presentation.form.image' | i18n }}</label>\n <div class=\"o-file-input\">\n <pry-select-image\n id=\"presentation_image\"\n (changed)=\"onImageChanged($event)\"\n [iconUrl]=\"image\"\n [mode]=\"type\"\n ></pry-select-image>\n </div>\n </div>\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_image\">{{ '@pry.toolbox.about' | i18n }}</label>\n <pry-text-editor formControlName=\"additionalInformation\"></pry-text-editor>\n </div>\n</form>\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.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "component", type: i2.PrySelectImageComponent, selector: "pry-select-image", inputs: ["iconUrl", "size", "mode"], outputs: ["toggled", "changed"] }, { kind: "component", type: i2.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: "component", type: i4.PryTextEditorComponent, selector: "pry-text-editor", inputs: ["tabView"] }, { 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: "pipe", type: i2.I18nPipe, name: "i18n" }] }); }
|
|
92
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.7", type: PresentationFormComponent, selector: "pry-presentation-form", inputs: { mode: "mode", themePrefix: "themePrefix", errorDuplicatingText: "errorDuplicatingText", selectedPresentation: "selectedPresentation" }, outputs: { formValue: "formValue", isFormValid: "isFormValid" }, viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<form [formGroup]=\"form\" class=\"o-presentation-form\">\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_name\"\n >{{ '@pry.presentation.form.name.title' | i18n }}<span class=\"required\">*</span></label\n >\n <input\n type=\"text\"\n id=\"presentation_name\"\n formControlName=\"name\"\n placeholder=\"{{ '@pry.presentation.form.name.placeholder' | i18n }}\"\n class=\"a-form-field\"\n maxlength=\"50\"\n required\n #input\n />\n @if (name.touched && name.errors?.['required']) {\n <label for=\"presentation_name\" class=\"a-label a-label--help -error\">\n {{ '@pry.presentation.required' | i18n }}\n </label>\n }\n @if (name.touched && name.errors?.['maxlength']) {\n <label for=\"presentation_name\" class=\"a-label a-label--help -error\">\n {{ '@pry.presentation.maxLength' | i18n: { len: '50' } }}\n </label>\n }\n @if (errorDuplicatingText) {\n <div class=\"error-duplicating\">\n <label class=\"a-form-field -error\">{{ errorDuplicatingText | i18n }}</label>\n </div>\n }\n </div>\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_description\">{{\n '@pry.presentation.form.description.title' | i18n\n }}</label>\n <textarea\n formControlName=\"description\"\n id=\"presentation_description\"\n name=\"description\"\n cols=\"30\"\n rows=\"5\"\n maxlength=\"200\"\n placeholder=\"{{ '@pry.presentation.form.description.placeholder' | i18n }}\"\n class=\"a-form-field\"\n ></textarea>\n @if (description.touched && description.errors?.['maxlength']) {\n <label for=\"presentation_description\" class=\"a-label a-label--help -error\">\n {{ '@pry.presentation.maxLength' | i18n: { len: '200' } }}\n </label>\n }\n </div>\n @if (mode === 'theme') {\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_theme\"\n >{{ '@pry.presentation.form.theme' | i18n }}<span class=\"required\">*</span></label\n >\n <pry-select\n id=\"presentation_theme\"\n [items]=\"possibleThemes\"\n formControlName=\"theme\"\n [clearable]=\"true\"\n [i18nPrefix]=\"themePrefix\"\n ></pry-select>\n </div>\n }\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_image\">{{ '@pry.presentation.form.image' | i18n }}</label>\n <div class=\"o-file-input\">\n <pry-select-image\n id=\"presentation_image\"\n (changed)=\"onImageChanged($event)\"\n [iconUrl]=\"image\"\n [mode]=\"type\"\n ></pry-select-image>\n </div>\n </div>\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_image\">{{ '@pry.toolbox.about' | i18n }}</label>\n <pry-text-editor formControlName=\"additionalInformation\"></pry-text-editor>\n </div>\n</form>\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.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "component", type: i2.PrySelectImageComponent, selector: "pry-select-image", inputs: ["iconUrl", "size", "mode"], outputs: ["toggled", "changed"] }, { kind: "component", type: i2.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: "component", type: i4.PryTextEditorComponent, selector: "pry-text-editor", inputs: ["tabView"] }, { 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: "pipe", type: i2.I18nPipe, name: "i18n" }] }); }
|
|
92
93
|
}
|
|
93
94
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: PresentationFormComponent, decorators: [{
|
|
94
95
|
type: Component,
|
|
95
|
-
args: [{ selector: 'pry-presentation-form', template: "<form [formGroup]=\"form\" class=\"o-presentation-form\">\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_name\"\n >{{ '@pry.presentation.form.name.title' | i18n }}<span class=\"required\">*</span></label\n >\n <input\n type=\"text\"\n id=\"presentation_name\"\n formControlName=\"name\"\n placeholder=\"{{ '@pry.presentation.form.name.placeholder' | i18n }}\"\n class=\"a-form-field\"\n maxlength=\"50\"\n required\n #input\n />\n @if (name.touched && name.errors?.['required']) {\n <label for=\"presentation_name\" class=\"a-label a-label--help -error\">\n {{ '@pry.presentation.required' | i18n }}\n </label>\n }\n @if (name.touched && name.errors?.['maxlength']) {\n <label for=\"presentation_name\" class=\"a-label a-label--help -error\">\n {{ '@pry.presentation.maxLength' | i18n: { len: '50' } }}\n </label>\n }\n </div>\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_description\">{{\n '@pry.presentation.form.description.title' | i18n\n }}</label>\n <textarea\n formControlName=\"description\"\n id=\"presentation_description\"\n name=\"description\"\n cols=\"30\"\n rows=\"5\"\n maxlength=\"200\"\n placeholder=\"{{ '@pry.presentation.form.description.placeholder' | i18n }}\"\n class=\"a-form-field\"\n ></textarea>\n @if (description.touched && description.errors?.['maxlength']) {\n <label for=\"presentation_description\" class=\"a-label a-label--help -error\">\n {{ '@pry.presentation.maxLength' | i18n: { len: '200' } }}\n </label>\n }\n </div>\n @if (mode === 'theme') {\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_theme\"\n >{{ '@pry.presentation.form.theme' | i18n }}<span class=\"required\">*</span></label\n >\n <pry-select\n id=\"presentation_theme\"\n [items]=\"possibleThemes\"\n formControlName=\"theme\"\n [clearable]=\"true\"\n [i18nPrefix]=\"themePrefix\"\n ></pry-select>\n </div>\n }\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_image\">{{ '@pry.presentation.form.image' | i18n }}</label>\n <div class=\"o-file-input\">\n <pry-select-image\n id=\"presentation_image\"\n (changed)=\"onImageChanged($event)\"\n [iconUrl]=\"image\"\n [mode]=\"type\"\n ></pry-select-image>\n </div>\n </div>\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_image\">{{ '@pry.toolbox.about' | i18n }}</label>\n <pry-text-editor formControlName=\"additionalInformation\"></pry-text-editor>\n </div>\n</form>\n" }]
|
|
96
|
+
args: [{ selector: 'pry-presentation-form', template: "<form [formGroup]=\"form\" class=\"o-presentation-form\">\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_name\"\n >{{ '@pry.presentation.form.name.title' | i18n }}<span class=\"required\">*</span></label\n >\n <input\n type=\"text\"\n id=\"presentation_name\"\n formControlName=\"name\"\n placeholder=\"{{ '@pry.presentation.form.name.placeholder' | i18n }}\"\n class=\"a-form-field\"\n maxlength=\"50\"\n required\n #input\n />\n @if (name.touched && name.errors?.['required']) {\n <label for=\"presentation_name\" class=\"a-label a-label--help -error\">\n {{ '@pry.presentation.required' | i18n }}\n </label>\n }\n @if (name.touched && name.errors?.['maxlength']) {\n <label for=\"presentation_name\" class=\"a-label a-label--help -error\">\n {{ '@pry.presentation.maxLength' | i18n: { len: '50' } }}\n </label>\n }\n @if (errorDuplicatingText) {\n <div class=\"error-duplicating\">\n <label class=\"a-form-field -error\">{{ errorDuplicatingText | i18n }}</label>\n </div>\n }\n </div>\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_description\">{{\n '@pry.presentation.form.description.title' | i18n\n }}</label>\n <textarea\n formControlName=\"description\"\n id=\"presentation_description\"\n name=\"description\"\n cols=\"30\"\n rows=\"5\"\n maxlength=\"200\"\n placeholder=\"{{ '@pry.presentation.form.description.placeholder' | i18n }}\"\n class=\"a-form-field\"\n ></textarea>\n @if (description.touched && description.errors?.['maxlength']) {\n <label for=\"presentation_description\" class=\"a-label a-label--help -error\">\n {{ '@pry.presentation.maxLength' | i18n: { len: '200' } }}\n </label>\n }\n </div>\n @if (mode === 'theme') {\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_theme\"\n >{{ '@pry.presentation.form.theme' | i18n }}<span class=\"required\">*</span></label\n >\n <pry-select\n id=\"presentation_theme\"\n [items]=\"possibleThemes\"\n formControlName=\"theme\"\n [clearable]=\"true\"\n [i18nPrefix]=\"themePrefix\"\n ></pry-select>\n </div>\n }\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_image\">{{ '@pry.presentation.form.image' | i18n }}</label>\n <div class=\"o-file-input\">\n <pry-select-image\n id=\"presentation_image\"\n (changed)=\"onImageChanged($event)\"\n [iconUrl]=\"image\"\n [mode]=\"type\"\n ></pry-select-image>\n </div>\n </div>\n <div class=\"m-form-label-field -width-full\">\n <label class=\"a-label\" for=\"presentation_image\">{{ '@pry.toolbox.about' | i18n }}</label>\n <pry-text-editor formControlName=\"additionalInformation\"></pry-text-editor>\n </div>\n</form>\n" }]
|
|
96
97
|
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.PryI18nService }], propDecorators: { mode: [{
|
|
97
98
|
type: Input
|
|
98
99
|
}], themePrefix: [{
|
|
99
100
|
type: Input
|
|
101
|
+
}], errorDuplicatingText: [{
|
|
102
|
+
type: Input
|
|
100
103
|
}], input: [{
|
|
101
104
|
type: ViewChild,
|
|
102
105
|
args: ['input']
|
|
@@ -107,4 +110,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImpor
|
|
|
107
110
|
}], isFormValid: [{
|
|
108
111
|
type: Output
|
|
109
112
|
}] } });
|
|
110
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"presentation-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/toolbox/shared/presentation-form/presentation-form.component.ts","../../../../../../../projects/provoly/dashboard/toolbox/shared/presentation-form/presentation-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, FormControl, FormGroup, Validators } from '@angular/forms';\nimport {\n  DEFAULT_DASHBOARD_ICON_URL,\n  LibraryTypes,\n  ManifestDescription,\n  PryI18nService,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { AfterViewInit, Component, ElementRef, Input, OnInit, Output, ViewChild } from '@angular/core';\nimport { BehaviorSubject } from 'rxjs';\nimport { MetadataActions, MetadataSelectors } from '@provoly/dashboard/components/metadata-editor';\nimport { Store } from '@ngrx/store';\n\nexport interface PresentationForm {\n  name: FormControl<string | undefined>;\n  description: FormControl<string | undefined | null>;\n  theme: FormControl<string | undefined | null>;\n  additionalInformation: FormControl<string | undefined | null>;\n}\n\nexport interface PresentationFormValue {\n  name: string;\n  description?: string;\n  theme?: string;\n  additionalInformation?: string;\n  image: string;\n}\n\n@Component({\n  selector: 'pry-presentation-form',\n  templateUrl: './presentation-form.component.html'\n})\nexport class PresentationFormComponent extends SubscriptionnerDirective implements OnInit, AfterViewInit {\n  form = new FormGroup<PresentationForm>({\n    name: new FormControl(undefined, {\n      validators: [Validators.required, Validators.maxLength(50)],\n      nonNullable: true\n    }),\n    description: new FormControl(undefined, [Validators.maxLength(200)]),\n    theme: new FormControl(undefined),\n    additionalInformation: new FormControl(undefined)\n  });\n\n  image: string = DEFAULT_DASHBOARD_ICON_URL;\n  type: LibraryTypes = LibraryTypes.ILLUSTRATION;\n  possibleThemes: string[] = [];\n\n  @Input() mode: 'theme' | 'meta' = 'meta';\n  @Input() themePrefix: string | null = null;\n  @ViewChild('input') input!: ElementRef;\n\n  selectedPresentation$ = new BehaviorSubject<ManifestDescription | undefined>(undefined);\n\n  @Input() set selectedPresentation(presentation: ManifestDescription | undefined) {\n    this.selectedPresentation$.next(presentation);\n  }\n\n  @Output() formValue = new BehaviorSubject<Partial<PresentationFormValue> | undefined>(undefined);\n  @Output() isFormValid = new BehaviorSubject<boolean>(false);\n\n  constructor(\n    protected store: Store,\n    private i18nService: PryI18nService\n  ) {\n    super();\n    this.store.dispatch(MetadataActions.loadMetadata());\n\n    this.subscriptions.add(\n      this.store.select(MetadataSelectors.metadata).subscribe((metadata) => {\n        this.possibleThemes = [...(metadata?.find((meta) => meta.name === '_theme')?.allowedValues ?? [])];\n        this.possibleThemes.sort((themeA, themeB) =>\n          this.i18nService\n            .instant((this.themePrefix ?? '') + themeA)\n            .localeCompare(this.i18nService.instant((this.themePrefix ?? '') + themeB))\n        );\n      })\n    );\n\n    this.subscriptions.add(\n      this.form.valueChanges.subscribe(() => {\n        this.isFormValid.next(this.form.valid);\n        this.formValue.next(this.getFormValue());\n      })\n    );\n  }\n\n  ngOnInit(): void {\n    this.image = this.selectedPresentation$.value?.image ?? DEFAULT_DASHBOARD_ICON_URL;\n    this.subscriptions.add(\n      this.selectedPresentation$.subscribe((presentation) => {\n        const theme = presentation?.metadata?.find((metadata) => metadata.metadataDef.name === '_theme')?.value;\n        if (!!theme) this.form.patchValue({ theme });\n      })\n    );\n    setTimeout(() => {\n      this.input?.nativeElement.focus();\n    }, 10);\n  }\n\n  ngAfterViewInit() {\n    setTimeout(() => {\n      if (this.selectedPresentation$.value) this.form.patchValue(this.selectedPresentation$.value);\n    });\n  }\n\n  get name(): AbstractControl<string | undefined> {\n    return this.form.controls['name'];\n  }\n\n  get description(): AbstractControl<string | undefined | null> {\n    return this.form.controls['description'];\n  }\n\n  get theme(): AbstractControl<string | undefined | null> {\n    return this.form.controls['theme'];\n  }\n\n  get additionalInformation(): AbstractControl<string | undefined | null> {\n    return this.form.controls['additionalInformation'];\n  }\n\n  getFormValue(): Partial<PresentationFormValue> {\n    return {\n      name: this.name.value,\n      description: this.description.value === null ? undefined : this.description.value,\n      theme: this.theme.value === null ? undefined : this.theme.value,\n      additionalInformation: this.additionalInformation.value === null ? undefined : this.additionalInformation.value,\n      image: this.image\n    };\n  }\n\n  onImageChanged($event: string) {\n    this.image = $event;\n    this.formValue.next(this.getFormValue());\n  }\n}\n","<form [formGroup]=\"form\" class=\"o-presentation-form\">\n  <div class=\"m-form-label-field -width-full\">\n    <label class=\"a-label\" for=\"presentation_name\"\n      >{{ '@pry.presentation.form.name.title' | i18n }}<span class=\"required\">*</span></label\n    >\n    <input\n      type=\"text\"\n      id=\"presentation_name\"\n      formControlName=\"name\"\n      placeholder=\"{{ '@pry.presentation.form.name.placeholder' | i18n }}\"\n      class=\"a-form-field\"\n      maxlength=\"50\"\n      required\n      #input\n    />\n    @if (name.touched && name.errors?.['required']) {\n      <label for=\"presentation_name\" class=\"a-label a-label--help -error\">\n        {{ '@pry.presentation.required' | i18n }}\n      </label>\n    }\n    @if (name.touched && name.errors?.['maxlength']) {\n      <label for=\"presentation_name\" class=\"a-label a-label--help -error\">\n        {{ '@pry.presentation.maxLength' | i18n: { len: '50' } }}\n      </label>\n    }\n  </div>\n  <div class=\"m-form-label-field -width-full\">\n    <label class=\"a-label\" for=\"presentation_description\">{{\n      '@pry.presentation.form.description.title' | i18n\n    }}</label>\n    <textarea\n      formControlName=\"description\"\n      id=\"presentation_description\"\n      name=\"description\"\n      cols=\"30\"\n      rows=\"5\"\n      maxlength=\"200\"\n      placeholder=\"{{ '@pry.presentation.form.description.placeholder' | i18n }}\"\n      class=\"a-form-field\"\n    ></textarea>\n    @if (description.touched && description.errors?.['maxlength']) {\n      <label for=\"presentation_description\" class=\"a-label a-label--help -error\">\n        {{ '@pry.presentation.maxLength' | i18n: { len: '200' } }}\n      </label>\n    }\n  </div>\n  @if (mode === 'theme') {\n    <div class=\"m-form-label-field -width-full\">\n      <label class=\"a-label\" for=\"presentation_theme\"\n        >{{ '@pry.presentation.form.theme' | i18n }}<span class=\"required\">*</span></label\n      >\n      <pry-select\n        id=\"presentation_theme\"\n        [items]=\"possibleThemes\"\n        formControlName=\"theme\"\n        [clearable]=\"true\"\n        [i18nPrefix]=\"themePrefix\"\n      ></pry-select>\n    </div>\n  }\n  <div class=\"m-form-label-field -width-full\">\n    <label class=\"a-label\" for=\"presentation_image\">{{ '@pry.presentation.form.image' | i18n }}</label>\n    <div class=\"o-file-input\">\n      <pry-select-image\n        id=\"presentation_image\"\n        (changed)=\"onImageChanged($event)\"\n        [iconUrl]=\"image\"\n        [mode]=\"type\"\n      ></pry-select-image>\n    </div>\n  </div>\n  <div class=\"m-form-label-field -width-full\">\n    <label class=\"a-label\" for=\"presentation_image\">{{ '@pry.toolbox.about' | i18n }}</label>\n    <pry-text-editor formControlName=\"additionalInformation\"></pry-text-editor>\n  </div>\n</form>\n"]}
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"presentation-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/toolbox/shared/presentation-form/presentation-form.component.ts","../../../../../../../projects/provoly/dashboard/toolbox/shared/presentation-form/presentation-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, FormControl, FormGroup, Validators } from '@angular/forms';\nimport {\n  DEFAULT_DASHBOARD_ICON_URL,\n  LibraryTypes,\n  ManifestDescription,\n  PryI18nService,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { AfterViewInit, Component, ElementRef, Input, OnInit, Output, ViewChild } from '@angular/core';\nimport { BehaviorSubject } from 'rxjs';\nimport { MetadataActions, MetadataSelectors } from '@provoly/dashboard/components/metadata-editor';\nimport { Store } from '@ngrx/store';\n\nexport interface PresentationForm {\n  name: FormControl<string | undefined>;\n  description: FormControl<string | undefined | null>;\n  theme: FormControl<string | undefined | null>;\n  additionalInformation: FormControl<string | undefined | null>;\n}\n\nexport interface PresentationFormValue {\n  name: string;\n  description?: string;\n  theme?: string;\n  additionalInformation?: string;\n  image: string;\n}\n\n@Component({\n  selector: 'pry-presentation-form',\n  templateUrl: './presentation-form.component.html'\n})\nexport class PresentationFormComponent extends SubscriptionnerDirective implements OnInit, AfterViewInit {\n  form = new FormGroup<PresentationForm>({\n    name: new FormControl(undefined, {\n      validators: [Validators.required, Validators.maxLength(50)],\n      nonNullable: true\n    }),\n    description: new FormControl(undefined, [Validators.maxLength(200)]),\n    theme: new FormControl(undefined),\n    additionalInformation: new FormControl(undefined)\n  });\n\n  image: string = DEFAULT_DASHBOARD_ICON_URL;\n  type: LibraryTypes = LibraryTypes.ILLUSTRATION;\n  possibleThemes: string[] = [];\n\n  @Input() mode: 'theme' | 'meta' = 'meta';\n  @Input() themePrefix: string | null = null;\n  @Input() errorDuplicatingText: string | null = null;\n  @ViewChild('input') input!: ElementRef;\n\n  selectedPresentation$ = new BehaviorSubject<ManifestDescription | undefined>(undefined);\n\n  @Input() set selectedPresentation(presentation: ManifestDescription | undefined) {\n    this.selectedPresentation$.next(presentation);\n  }\n\n  @Output() formValue = new BehaviorSubject<Partial<PresentationFormValue> | undefined>(undefined);\n  @Output() isFormValid = new BehaviorSubject<boolean>(false);\n\n  constructor(\n    protected store: Store,\n    private i18nService: PryI18nService\n  ) {\n    super();\n    this.store.dispatch(MetadataActions.loadMetadata());\n\n    this.subscriptions.add(\n      this.store.select(MetadataSelectors.metadata).subscribe((metadata) => {\n        this.possibleThemes = [...(metadata?.find((meta) => meta.name === '_theme')?.allowedValues ?? [])];\n        this.possibleThemes.sort((themeA, themeB) =>\n          this.i18nService\n            .instant((this.themePrefix ?? '') + themeA)\n            .localeCompare(this.i18nService.instant((this.themePrefix ?? '') + themeB))\n        );\n      })\n    );\n\n    this.subscriptions.add(\n      this.form.valueChanges.subscribe(() => {\n        this.isFormValid.next(this.form.valid);\n        this.formValue.next(this.getFormValue());\n      })\n    );\n  }\n\n  ngOnInit(): void {\n    this.image = this.selectedPresentation$.value?.image ?? DEFAULT_DASHBOARD_ICON_URL;\n    this.subscriptions.add(\n      this.selectedPresentation$.subscribe((presentation) => {\n        const theme = presentation?.metadata?.find((metadata) => metadata.metadataDef.name === '_theme')?.value;\n        if (!!theme) this.form.patchValue({ theme });\n      })\n    );\n    setTimeout(() => {\n      this.input?.nativeElement.focus();\n    }, 10);\n  }\n\n  ngAfterViewInit() {\n    setTimeout(() => {\n      if (this.selectedPresentation$.value) this.form.patchValue(this.selectedPresentation$.value);\n    });\n  }\n\n  get name(): AbstractControl<string | undefined> {\n    return this.form.controls['name'];\n  }\n\n  get description(): AbstractControl<string | undefined | null> {\n    return this.form.controls['description'];\n  }\n\n  get theme(): AbstractControl<string | undefined | null> {\n    return this.form.controls['theme'];\n  }\n\n  get additionalInformation(): AbstractControl<string | undefined | null> {\n    return this.form.controls['additionalInformation'];\n  }\n\n  getFormValue(): Partial<PresentationFormValue> {\n    return {\n      name: this.name.value,\n      description: this.description.value === null ? undefined : this.description.value,\n      theme: this.theme.value === null ? undefined : this.theme.value,\n      additionalInformation: this.additionalInformation.value === null ? undefined : this.additionalInformation.value,\n      image: this.image\n    };\n  }\n\n  onImageChanged($event: string) {\n    this.image = $event;\n    this.formValue.next(this.getFormValue());\n  }\n}\n","<form [formGroup]=\"form\" class=\"o-presentation-form\">\n  <div class=\"m-form-label-field -width-full\">\n    <label class=\"a-label\" for=\"presentation_name\"\n      >{{ '@pry.presentation.form.name.title' | i18n }}<span class=\"required\">*</span></label\n    >\n    <input\n      type=\"text\"\n      id=\"presentation_name\"\n      formControlName=\"name\"\n      placeholder=\"{{ '@pry.presentation.form.name.placeholder' | i18n }}\"\n      class=\"a-form-field\"\n      maxlength=\"50\"\n      required\n      #input\n    />\n    @if (name.touched && name.errors?.['required']) {\n      <label for=\"presentation_name\" class=\"a-label a-label--help -error\">\n        {{ '@pry.presentation.required' | i18n }}\n      </label>\n    }\n    @if (name.touched && name.errors?.['maxlength']) {\n      <label for=\"presentation_name\" class=\"a-label a-label--help -error\">\n        {{ '@pry.presentation.maxLength' | i18n: { len: '50' } }}\n      </label>\n    }\n    @if (errorDuplicatingText) {\n      <div class=\"error-duplicating\">\n        <label class=\"a-form-field -error\">{{ errorDuplicatingText | i18n }}</label>\n      </div>\n    }\n  </div>\n  <div class=\"m-form-label-field -width-full\">\n    <label class=\"a-label\" for=\"presentation_description\">{{\n      '@pry.presentation.form.description.title' | i18n\n    }}</label>\n    <textarea\n      formControlName=\"description\"\n      id=\"presentation_description\"\n      name=\"description\"\n      cols=\"30\"\n      rows=\"5\"\n      maxlength=\"200\"\n      placeholder=\"{{ '@pry.presentation.form.description.placeholder' | i18n }}\"\n      class=\"a-form-field\"\n    ></textarea>\n    @if (description.touched && description.errors?.['maxlength']) {\n      <label for=\"presentation_description\" class=\"a-label a-label--help -error\">\n        {{ '@pry.presentation.maxLength' | i18n: { len: '200' } }}\n      </label>\n    }\n  </div>\n  @if (mode === 'theme') {\n    <div class=\"m-form-label-field -width-full\">\n      <label class=\"a-label\" for=\"presentation_theme\"\n        >{{ '@pry.presentation.form.theme' | i18n }}<span class=\"required\">*</span></label\n      >\n      <pry-select\n        id=\"presentation_theme\"\n        [items]=\"possibleThemes\"\n        formControlName=\"theme\"\n        [clearable]=\"true\"\n        [i18nPrefix]=\"themePrefix\"\n      ></pry-select>\n    </div>\n  }\n  <div class=\"m-form-label-field -width-full\">\n    <label class=\"a-label\" for=\"presentation_image\">{{ '@pry.presentation.form.image' | i18n }}</label>\n    <div class=\"o-file-input\">\n      <pry-select-image\n        id=\"presentation_image\"\n        (changed)=\"onImageChanged($event)\"\n        [iconUrl]=\"image\"\n        [mode]=\"type\"\n      ></pry-select-image>\n    </div>\n  </div>\n  <div class=\"m-form-label-field -width-full\">\n    <label class=\"a-label\" for=\"presentation_image\">{{ '@pry.toolbox.about' | i18n }}</label>\n    <pry-text-editor formControlName=\"additionalInformation\"></pry-text-editor>\n  </div>\n</form>\n"]}
|
|
@@ -93,7 +93,8 @@ export class PryToolboxModule {
|
|
|
93
93
|
CdkDragHandle,
|
|
94
94
|
A11yModule,
|
|
95
95
|
PryTextEditorModule,
|
|
96
|
-
ReactiveFormsModule
|
|
96
|
+
ReactiveFormsModule,
|
|
97
|
+
PryI18nModule], exports: [ToolboxActionComponent,
|
|
97
98
|
ToolboxActionInstanciatorComponent,
|
|
98
99
|
ClearViewComponent,
|
|
99
100
|
DragWidgetsComponent,
|
|
@@ -129,7 +130,8 @@ export class PryToolboxModule {
|
|
|
129
130
|
PryI18nModule,
|
|
130
131
|
A11yModule,
|
|
131
132
|
PryTextEditorModule,
|
|
132
|
-
ReactiveFormsModule
|
|
133
|
+
ReactiveFormsModule,
|
|
134
|
+
PryI18nModule] }); }
|
|
133
135
|
}
|
|
134
136
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: PryToolboxModule, decorators: [{
|
|
135
137
|
type: NgModule,
|
|
@@ -154,9 +156,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImpor
|
|
|
154
156
|
CdkDragHandle,
|
|
155
157
|
A11yModule,
|
|
156
158
|
PryTextEditorModule,
|
|
157
|
-
ReactiveFormsModule
|
|
159
|
+
ReactiveFormsModule,
|
|
160
|
+
PryI18nModule
|
|
158
161
|
],
|
|
159
162
|
exports: [...components]
|
|
160
163
|
}]
|
|
161
164
|
}] });
|
|
162
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
165
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toolbox.module.js","sourceRoot":"","sources":["../../../../../projects/provoly/dashboard/toolbox/toolbox.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkDrag, CdkDragHandle, CdkDropList } from '@angular/cdk/drag-drop';\nimport { OverlayModule } from '@angular/cdk/overlay';\nimport { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport {\n  PryCoreModule,\n  PryDashboardModule,\n  PryI18nModule,\n  PryIconModule,\n  PryOverlayModule,\n  PrySelectModule,\n  PryShareModule,\n  PryToggleModule\n} from '@provoly/dashboard';\nimport { PryCheckboxModule } from '@provoly/dashboard/components/checkbox';\nimport { PryStepperModule } from '@provoly/dashboard/components/stepper';\nimport { ClearViewComponent } from './components/clear-view/clear-view.component';\nimport { DragWidgetsComponent } from './components/drag-widgets/drag-widgets.component';\nimport { EditModeToggleComponent } from './components/edit-mode-toggle/edit-mode-toggle.component';\nimport { PryFilterSettingsComponent } from './components/filter-settings/filter-settings.component';\nimport { LaunchTabComponent } from './components/launch-tab/launch-tab.component';\nimport { NamedQueryComponent } from './components/named-query/named-query.component';\nimport { SaveViewComponent } from './components/save-view/save-view.component';\nimport { SelectGridLayoutComponent } from './components/select-grid-layout/select-grid-layout.component';\nimport { ToolboxComponent } from './components/toolbox.component';\nimport { PrySelectGridLayoutCssComponent } from './style/css.component';\nimport { RefreshDatasetsComponent } from './components/refresh-datasets/refresh-datasets.component';\nimport { AutomateRefreshComponent } from './components/automate-refresh/automate-refresh.component';\nimport { A11yModule } from '@angular/cdk/a11y';\nimport { SwitchToEditContentComponent } from './components/switch-to-edit-content/switch-to-edit-content.component';\nimport { ShareComponent } from './components/share/share.component';\nimport { DeleteComponent } from './components/delete/delete.component';\nimport { DashboardDetailsComponent } from './components/dashboard-details/dashboard-details.component';\nimport { EditModeActionComponent } from './components/edit-mode-action/edit-mode-action.component';\nimport { PryTextEditorModule } from '@provoly/dashboard/components/text-editor';\nimport { EditPresentationComponent } from './components/edit-presentation/edit-presentation.component';\nimport { PresentationFormComponent } from './shared/presentation-form/presentation-form.component';\nimport { ToolboxActionInstanciatorComponent } from './shared/toolbox-action-instanciator/toolbox-action-instanciator.component';\nimport { ToolboxActionComponent } from './shared/toolbox-action/toolbox-action.component';\n\nconst components = [\n  ToolboxActionComponent,\n  ToolboxActionInstanciatorComponent,\n  ClearViewComponent,\n  DragWidgetsComponent,\n  EditModeToggleComponent,\n  LaunchTabComponent,\n  NamedQueryComponent,\n  SaveViewComponent,\n  SelectGridLayoutComponent,\n  ToolboxComponent,\n  PrySelectGridLayoutCssComponent,\n  PryFilterSettingsComponent,\n  RefreshDatasetsComponent,\n  AutomateRefreshComponent,\n  SwitchToEditContentComponent,\n  ShareComponent,\n  DeleteComponent,\n  DashboardDetailsComponent,\n  EditModeActionComponent,\n  EditPresentationComponent,\n  PresentationFormComponent\n];\n\n@NgModule({\n  declarations: [...components],\n    imports: [\n        CommonModule,\n        FormsModule,\n        OverlayModule,\n        PryOverlayModule,\n        PryCoreModule,\n        PryDashboardModule,\n        PrySelectModule,\n        PryIconModule,\n        PryCheckboxModule,\n        PryToggleModule,\n        PryStepperModule,\n        PryShareModule,\n        PryI18nModule,\n        CdkDropList,\n        CdkDrag,\n        CdkDragHandle,\n        A11yModule,\n        PryTextEditorModule,\n        ReactiveFormsModule,\n        PryI18nModule\n    ],\n  exports: [...components]\n})\nexport class PryToolboxModule {}\n"]}
|