@provoly/dashboard 1.4.43 → 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/lib/dashboard/store/wms.service.mjs +2 -2
- package/esm2022/presentation/components/add-edit-presentation/add-edit-presentation.component.mjs +47 -49
- package/esm2022/presentation/i18n/fr.translations.mjs +2 -2
- package/esm2022/presentation/style/css.component.mjs +2 -2
- 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 +56 -58
- 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/fesm2022/provoly-dashboard.mjs +1 -1
- package/fesm2022/provoly-dashboard.mjs.map +1 -1
- package/package.json +1 -1
- package/presentation/components/add-edit-presentation/add-edit-presentation.component.d.ts +7 -6
- package/presentation/style/_o-pry-new-presentation.scss +5 -0
- package/toolbox/shared/presentation-form/presentation-form.component.d.ts +2 -1
- package/toolbox/toolbox.module.d.ts +1 -1
|
@@ -54,7 +54,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImpor
|
|
|
54
54
|
providedIn: 'root'
|
|
55
55
|
}]
|
|
56
56
|
}], ctorParameters: () => [{ type: i1.HttpClient }] });
|
|
57
|
-
const BBOX_ENHANCE_DISTANCE = 0.
|
|
57
|
+
const BBOX_ENHANCE_DISTANCE = 0.000001;
|
|
58
58
|
const wfsUrlBuilder = (wmsUrl, bbox, geomPropName, params) => {
|
|
59
59
|
const enhancedBbox = [
|
|
60
60
|
bbox[0] - BBOX_ENHANCE_DISTANCE,
|
|
@@ -91,4 +91,4 @@ const wfsUrlBuilder = (wmsUrl, bbox, geomPropName, params) => {
|
|
|
91
91
|
.filter((val) => !!val)
|
|
92
92
|
.join('&'));
|
|
93
93
|
};
|
|
94
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wms.service.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/lib/dashboard/store/wms.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient, HttpHeaders } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { catchError, map, Observable, of } from 'rxjs';\n\nexport type GetCapabilitiesResponse = { url: string; doc?: Document };\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class WmsService {\n  parser = new DOMParser();\n\n  constructor(private httpClient: HttpClient) {}\n\n  getCapabilities(url: string): Observable<GetCapabilitiesResponse | null> {\n    if (url) {\n      const layerUrlWithQmark = url.indexOf('?') === -1 ? url + '?' : url;\n      const layerUrlWithService =\n        layerUrlWithQmark.indexOf('&SERVICE=') === -1 ? layerUrlWithQmark + '&SERVICE=WMS' : layerUrlWithQmark;\n      const layerUrlWithVersion =\n        layerUrlWithService.indexOf('&VERSION=') === -1 ? layerUrlWithService + '&VERSION=1.3.0' : layerUrlWithService;\n\n      return this.httpClient\n        .get(`${layerUrlWithVersion}&REQUEST=GetCapabilities`, {\n          headers: new HttpHeaders({\n            Accept: 'text/html, application/xhtml+xml, */*',\n            'Content-Type': 'application/x-www-form-urlencoded'\n          }),\n          responseType: 'text'\n        })\n        .pipe(\n          map((response) => {\n            const doc = this.parser.parseFromString(response, 'application/xml');\n            const errorNode = doc.querySelector('parsererror');\n            if (errorNode) {\n              console.error(`Cannot getCapabilities for ${url}`);\n              return null;\n            } else {\n              return { url, doc };\n            }\n          }),\n          catchError(() => {\n            console.error(`Cannot getCapabilities for ${url}`);\n            return of(null);\n          })\n        );\n    }\n    return of(null);\n  }\n\n  getWmsFeatures(url: string): Observable<{ features: any[] }> {\n    return this.httpClient.get(url).pipe(map((json: any) => json));\n  }\n\n  getWfsFeatures(wmsUrl: string, bbox: number[], geomPropName: string): Observable<{ features: any[] }> {\n    const url = wfsUrlBuilder(wmsUrl, bbox, geomPropName);\n    return this.httpClient.get(url).pipe(map((json: any) => json));\n  }\n}\n\nconst BBOX_ENHANCE_DISTANCE = 0.0001;\nconst wfsUrlBuilder = (wmsUrl: string, bbox: number[], geomPropName: string, params?: string[]) => {\n  const enhancedBbox = [\n    bbox[0] - BBOX_ENHANCE_DISTANCE,\n    bbox[1] - BBOX_ENHANCE_DISTANCE,\n    bbox[2] + BBOX_ENHANCE_DISTANCE,\n    bbox[3] + BBOX_ENHANCE_DISTANCE\n  ];\n  const wfsFragments: { [key: string]: string | undefined } = {\n    service: 'WFS',\n    version: '2.0.0',\n    request: 'GetFeature',\n    outputFormat: 'application/json',\n    typeNames: undefined,\n    bbox: `${enhancedBbox.join(',')},EPSG:4326`,\n    srsName: undefined,\n    params: params ? `&${params.join('&')}` : ''\n  };\n  const base = wmsUrl.split('?')[0].replace('wms', 'wfs');\n  const wmsUrlFragments = wmsUrl.split('&');\n  wfsFragments['typeNames'] = wmsUrlFragments.find((param) => param.toUpperCase().includes('LAYERS'))?.split('=')[1];\n  wfsFragments['srsName'] = wmsUrlFragments.find((param) => param.toUpperCase().includes('CRS'))?.split('=')[1];\n\n  const cqlFilterFragment = wmsUrlFragments.find((param) => param.toUpperCase().includes('CQL_FILTER'));\n  if (cqlFilterFragment) {\n    const previousFragment = cqlFilterFragment.split('=')[1];\n    // cql_filter and bbox are mutually exclusive so we need to replace bbox with a cql filter on the bbox\n    wfsFragments['cql_filter'] =\n      previousFragment + ` AND BBOX(${geomPropName}, ${enhancedBbox.join(',')}, 'EPSG:4326')`;\n    wfsFragments['bbox'] = undefined;\n  }\n\n  return (\n    base +\n    '?' +\n    Object.entries(wfsFragments)\n      .map(([key, value]) => (value ? `${key}=${value}` : undefined))\n      .filter((val) => !!val)\n      .join('&')\n  );\n};\n"]}
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wms.service.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/lib/dashboard/store/wms.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient, HttpHeaders } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { catchError, map, Observable, of } from 'rxjs';\n\nexport type GetCapabilitiesResponse = { url: string; doc?: Document };\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class WmsService {\n  parser = new DOMParser();\n\n  constructor(private httpClient: HttpClient) {}\n\n  getCapabilities(url: string): Observable<GetCapabilitiesResponse | null> {\n    if (url) {\n      const layerUrlWithQmark = url.indexOf('?') === -1 ? url + '?' : url;\n      const layerUrlWithService =\n        layerUrlWithQmark.indexOf('&SERVICE=') === -1 ? layerUrlWithQmark + '&SERVICE=WMS' : layerUrlWithQmark;\n      const layerUrlWithVersion =\n        layerUrlWithService.indexOf('&VERSION=') === -1 ? layerUrlWithService + '&VERSION=1.3.0' : layerUrlWithService;\n\n      return this.httpClient\n        .get(`${layerUrlWithVersion}&REQUEST=GetCapabilities`, {\n          headers: new HttpHeaders({\n            Accept: 'text/html, application/xhtml+xml, */*',\n            'Content-Type': 'application/x-www-form-urlencoded'\n          }),\n          responseType: 'text'\n        })\n        .pipe(\n          map((response) => {\n            const doc = this.parser.parseFromString(response, 'application/xml');\n            const errorNode = doc.querySelector('parsererror');\n            if (errorNode) {\n              console.error(`Cannot getCapabilities for ${url}`);\n              return null;\n            } else {\n              return { url, doc };\n            }\n          }),\n          catchError(() => {\n            console.error(`Cannot getCapabilities for ${url}`);\n            return of(null);\n          })\n        );\n    }\n    return of(null);\n  }\n\n  getWmsFeatures(url: string): Observable<{ features: any[] }> {\n    return this.httpClient.get(url).pipe(map((json: any) => json));\n  }\n\n  getWfsFeatures(wmsUrl: string, bbox: number[], geomPropName: string): Observable<{ features: any[] }> {\n    const url = wfsUrlBuilder(wmsUrl, bbox, geomPropName);\n    return this.httpClient.get(url).pipe(map((json: any) => json));\n  }\n}\n\nconst BBOX_ENHANCE_DISTANCE = 0.000001;\nconst wfsUrlBuilder = (wmsUrl: string, bbox: number[], geomPropName: string, params?: string[]) => {\n  const enhancedBbox = [\n    bbox[0] - BBOX_ENHANCE_DISTANCE,\n    bbox[1] - BBOX_ENHANCE_DISTANCE,\n    bbox[2] + BBOX_ENHANCE_DISTANCE,\n    bbox[3] + BBOX_ENHANCE_DISTANCE\n  ];\n  const wfsFragments: { [key: string]: string | undefined } = {\n    service: 'WFS',\n    version: '2.0.0',\n    request: 'GetFeature',\n    outputFormat: 'application/json',\n    typeNames: undefined,\n    bbox: `${enhancedBbox.join(',')},EPSG:4326`,\n    srsName: undefined,\n    params: params ? `&${params.join('&')}` : ''\n  };\n  const base = wmsUrl.split('?')[0].replace('wms', 'wfs');\n  const wmsUrlFragments = wmsUrl.split('&');\n  wfsFragments['typeNames'] = wmsUrlFragments.find((param) => param.toUpperCase().includes('LAYERS'))?.split('=')[1];\n  wfsFragments['srsName'] = wmsUrlFragments.find((param) => param.toUpperCase().includes('CRS'))?.split('=')[1];\n\n  const cqlFilterFragment = wmsUrlFragments.find((param) => param.toUpperCase().includes('CQL_FILTER'));\n  if (cqlFilterFragment) {\n    const previousFragment = cqlFilterFragment.split('=')[1];\n    // cql_filter and bbox are mutually exclusive so we need to replace bbox with a cql filter on the bbox\n    wfsFragments['cql_filter'] =\n      previousFragment + ` AND BBOX(${geomPropName}, ${enhancedBbox.join(',')}, 'EPSG:4326')`;\n    wfsFragments['bbox'] = undefined;\n  }\n\n  return (\n    base +\n    '?' +\n    Object.entries(wfsFragments)\n      .map(([key, value]) => (value ? `${key}=${value}` : undefined))\n      .filter((val) => !!val)\n      .join('&')\n  );\n};\n"]}
|
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":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAGjF,OAAO,EACL,gBAAgB,EAChB,mBAAmB,EACnB,kBAAkB,EAMlB,wBAAwB,EACxB,QAAQ,EACR,oBAAoB,EACrB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAC,eAAe,EAAE,UAAU,EAAE,aAAa,EAAc,UAAU,EAAC,MAAM,MAAM,CAAC;AACxF,OAAO,EAAE,iBAAiB,EAAiB,MAAM,+CAA+C,CAAC;AACjG,OAAO,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,MAAM,CAAC;;;;;;;;AAOpC,MAAM,OAAO,+BAAgC,SAAQ,wBAAwB;IAW3E,IAAa,oBAAoB,CAAC,YAA6C;QAC7E,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAChD,CAAC;IAQD,YACY,KAAY,EACd,eAAgC,EAClB,MAAc;QAEpC,KAAK,EAAE,CAAC;QAJE,UAAK,GAAL,KAAK,CAAO;QACd,oBAAe,GAAf,eAAe,CAAiB;QAClB,WAAM,GAAN,MAAM,CAAQ;QArBtC,0BAAqB,GAAG,IAAI,eAAe,CAAkC,SAAS,CAAC,CAAC;QACxF,iBAAY,GAAW,mBAAmB,CAAC,IAAI,CAAC;QAEhD,oBAAe,GAAW,EAAE,CAAC;QAE7B,gBAAW,GAAG,KAAK,CAAC;QACpB,yBAAoB,GAAkB,IAAI,CAAC;QAKlC,YAAO,GAAY,KAAK,CAAC;QACzB,gBAAW,GAAkB,IAAI,CAAC;QAClC,oBAAe,GAAW,GAAG,CAAC;QAC9B,SAAI,GAAqB,MAAM,CAAC;QAE/B,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAC;QAQ1C,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,kBAAkB,CAAC,cAAc,CAAC,CAAC;QAC5E,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QACvG,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,aAAa,CAAC,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,SAAS,CAC/F,CAAC,CAAC,cAAc,EAAE,UAAU,CAAC,EAAE,EAAE;YAC/B,IAAI,CAAC,YAAY;gBACf,IAAI,CAAC,OAAO,IAAI,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,KAAK,SAAS;oBACnE,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM;oBACzC,CAAC,CAAC,UAAU,CAAC;QACnB,CAAC,CACF,CACF,CAAC;QACF,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;YACnE,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC;YAC7B,MAAM,aAAa,GAAG,QAAQ,EAAE,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;YACvE,IAAI,aAAa,EAAE,CAAC;gBAClB,IAAI,CAAC,eAAe,GAAG,aAAa,EAAE,EAAE,IAAI,EAAE,CAAC;YACjD,CAAC;QACH,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,qBAAqB;QACnB,MAAM,YAAY,GAAG;YACnB,GAAG,IAAI,CAAC,qBAAqB,CAAC,KAAM;YACpC,EAAE,EAAE,IAAI,CAAC,qBAAqB,CAAC,KAAK,EAAE,EAAE,IAAI,MAAM,EAAE;YACpD,GAAG,IAAI,CAAC,SAAS;YACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE;SAC1B,CAAC;QACF,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;QACjC,IAAI,CAAC,eAAe;aACjB,IAAI,CACH,YAAY,CAAC,IAAI,EACjB,IAAI,CAAC,OAAO,CAAC,CAAC,CAAE,IAAI,CAAC,cAAiC,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,EAAE,EAC9E,YAAY,CAAC,EAAE,EACf,YAAY,CAAC,WAAW,EACxB,YAAY,CAAC,KAAK,EAClB,YAAY,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,QAAuB,EAAE,EAAE,CAAC,CAAC;YACvD,aAAa,EAAE,QAAQ,CAAC,WAAW,CAAC,EAAE;YACtC,KAAK,EAAE,QAAQ,CAAC,KAAK;SACtB,CAAC,CAAC,EACH,YAAY,CAAC,mBAAmB,EAChC,YAAY,CAAC,qBAAqB,CACnC;aACA,IAAI,CACH,UAAU,CAAC,CAAC,KAAK,EAAE,EAAE;YACnB,IAAI,CAAC,oBAAoB,GAAG,sCAAsC,CAAC;YACnE,OAAO,UAAU,CAAC,KAAK,CAAC,CAAC;QAC3B,CAAC,CAAC,CACH;aACA,SAAS,CAAC,GAAG,EAAE;YACd,MAAM,YAAY,GAAG;gBACnB,GAAG,IAAI,CAAC,qBAAqB,CAAC,KAAM;gBACpC,GAAG,IAAI,CAAC,SAAS;gBACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE;aAC1B,CAAC;YAEF,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;gBAClB,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,gBAAgB,CAAC,kBAAkB,CAAC;oBAClC,YAAY;oBACZ,QAAQ,EAAE,QAAQ,CAAC,QAAQ;iBAC5B,CAAC,CACH,CAAC;YACJ,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,gBAAgB,CAAC,gBAAgB,CAAC;oBAChC,YAAY;oBACZ,QAAQ,EAAE,QAAQ,CAAC,OAAO;iBAC3B,CAAC,CACH,CAAC;YACJ,CAAC;YACD,IAAI,CAAC,MAAM,EAAE,aAAa,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QACnD,CAAC,CAAC,CAAC;IACP,CAAC;IAED,aAAa;QACX,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,IAAI,CAAC,qBAAqB,EAAE,CAAC;QAC/B,CAAC;IACH,CAAC;IAED,WAAW,CAAC,QAAuB;QACjC,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,gBAAgB,CAAC,mBAAmB,CAAC;YACnC,cAAc,EAAE,IAAI,CAAC,qBAAqB,CAAC,KAAK,EAAE,EAAG;YACrD,UAAU,EAAE,QAAQ,CAAC,UAAU;YAC/B,KAAK,EAAE,QAAQ,CAAC,KAAK,IAAI,EAAE;SAC5B,CAAC,CACH,CAAC;IACJ,CAAC;IAED,cAAc,CAAC,QAAuB;QACpC,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,gBAAgB,CAAC,sBAAsB,CAAC;YACtC,cAAc,EAAE,IAAI,CAAC,qBAAqB,CAAC,KAAK,EAAE,EAAG;YACrD,UAAU,EAAE,QAAQ,CAAC,UAAU;SAChC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,KAAK;QACH,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IACrB,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,IAAI,KAAK,OAAO;YAC1B,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,IAAI,IAAI,CAAC,SAAS,EAAE,KAAK,KAAK,EAAE;gBACtD,CAAC,CAAC,EAAE;gBACJ,CAAC,CAAC;oBACE;wBACE,WAAW,EAAE,IAAI,CAAC,YAAa,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,EAAE,KAAK,IAAI,CAAC,eAAe,CAAE;wBACzF,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,EAAE;qBAClC;iBACF;YACL,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,KAAK,EAAE,QAAQ,IAAI,EAAE,CAAC;IACvD,CAAC;IAED,cAAc;QACZ,OAAO;YACL,OAAO,EAAE;gBACP;oBACE,OAAO,EAAE,EAAE;oBACX,IAAI,EAAE;wBACJ,MAAM,EAAE,IAAI,CAAC,YAAY;wBACzB,OAAO,EAAE,oBAAoB,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,OAAO;wBACnE,IAAI,EAAE,oBAAoB,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,IAAI;qBAC9D;iBACF;aACF;SACF,CAAC;IACJ,CAAC;8GA/JU,+BAA+B;kGAA/B,+BAA+B,mRCzB5C,uvEAsDA;;2FD7Ba,+BAA+B;kBAJ3C,SAAS;+BACE,2BAA2B;;0BA2BlC,QAAQ;yCAbE,oBAAoB;sBAAhC,KAAK;gBAGG,OAAO;sBAAf,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAEI,MAAM;sBAAf,MAAM","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"]}
|
|
@@ -31,7 +31,7 @@ export const frTranslations = {
|
|
|
31
31
|
erase: 'Supprimer le tableau de bord',
|
|
32
32
|
change: 'Modifier le tableau de bord',
|
|
33
33
|
create: 'Créer un tableau de bord',
|
|
34
|
-
configuration: '
|
|
34
|
+
configuration: 'Enregistrer',
|
|
35
35
|
required: 'Ce champ est requis',
|
|
36
36
|
maxLength: 'Nombre de caractères autorisés : {{len}}',
|
|
37
37
|
edition: 'Modifier',
|
|
@@ -44,4 +44,4 @@ export const frTranslations = {
|
|
|
44
44
|
}
|
|
45
45
|
}
|
|
46
46
|
};
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnIudHJhbnNsYXRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvcHJlc2VudGF0aW9uL2kxOG4vZnIudHJhbnNsYXRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUM1QixNQUFNLEVBQUU7UUFDTixZQUFZLEVBQUU7WUFDWixHQUFHLEVBQUU7Z0JBQ0gsU0FBUyxFQUFFLDhDQUE4QztnQkFDekQsSUFBSSxFQUFFLGNBQWM7Z0JBQ3BCLE1BQU0sRUFBRSxhQUFhO2FBQ3RCO1lBQ0QsSUFBSSxFQUFFO2dCQUNKLFNBQVMsRUFBRSwyQ0FBMkM7Z0JBQ3RELE1BQU0sRUFBRSxnQ0FBZ0M7YUFDekM7WUFDRCxJQUFJLEVBQUU7Z0JBQ0osSUFBSSxFQUFFLE9BQU87Z0JBQ2IsV0FBVyxFQUFFLGFBQWE7Z0JBQzFCLEtBQUssRUFBRSxzQkFBc0I7Z0JBQzdCLFFBQVEsRUFBRSxtQkFBbUI7Z0JBQzdCLEVBQUUsRUFBRSxJQUFJO2dCQUNSLFVBQVUsRUFBRSxZQUFZO2dCQUN4QixhQUFhLEVBQUUsMEJBQTBCO2dCQUN6QyxJQUFJLEVBQUUsbUJBQW1CO2dCQUN6QixLQUFLLEVBQUUsWUFBWTthQUNwQjtZQUNELE1BQU0sRUFBRSx1QkFBdUI7WUFDL0IsS0FBSyxFQUFFLFVBQVU7WUFDakIsT0FBTyxFQUFFLDRCQUE0QjtZQUNyQyxPQUFPLEVBQUUsV0FBVztZQUNwQixJQUFJLEVBQUUsOEJBQThCO1lBQ3BDLE9BQU8sRUFBRSxxQkFBcUI7WUFDOUIsUUFBUSxFQUFFLDRCQUE0QjtZQUN0QyxLQUFLLEVBQUUsOEJBQThCO1lBQ3JDLE1BQU0sRUFBRSw2QkFBNkI7WUFDckMsTUFBTSxFQUFFLDBCQUEwQjtZQUNsQyxhQUFhLEVBQUUsYUFBYTtZQUM1QixRQUFRLEVBQUUscUJBQXFCO1lBQy9CLFNBQVMsRUFBRSwwQ0FBMEM7WUFDckQsT0FBTyxFQUFFLFVBQVU7WUFDbkIsY0FBYyxFQUFFLHlCQUF5QjtZQUN6QyxNQUFNLEVBQUUsV0FBVztZQUNuQixhQUFhLEVBQUUsc0JBQXNCO1lBQ3JDLE1BQU0sRUFBRSxZQUFZO1lBQ3BCLEtBQUssRUFBRSwrQkFBK0I7WUFDdEMsSUFBSSxFQUFFLFNBQVM7U0FDaEI7S0FDRjtDQUNGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgZnJUcmFuc2xhdGlvbnMgPSB7XG4gICdAcHJ5Jzoge1xuICAgIHByZXNlbnRhdGlvbjoge1xuICAgICAgYWRkOiB7XG4gICAgICAgIHBhZ2VUaXRsZTogJ1JlbnNlaWduZXIgbGEgZGVzY3JpcHRpb24gZHUgdGFibGVhdSBkZSBib3JkJyxcbiAgICAgICAgaW5mbzogJ0luZm9ybWF0aW9ucycsXG4gICAgICAgIHN1Ym1pdDogJ0VucmVnaXN0cmVyJ1xuICAgICAgfSxcbiAgICAgIGVkaXQ6IHtcbiAgICAgICAgcGFnZVRpdGxlOiAnQ2hhbmdlciBsYSBkZXNjcmlwdGlvbiBkdSB0YWJsZWF1IGRlIGJvcmQnLFxuICAgICAgICBzdWJtaXQ6ICdTYXV2ZWdhcmRlciBsZSB0YWJsZWF1IGRlIGJvcmQnXG4gICAgICB9LFxuICAgICAgZm9ybToge1xuICAgICAgICBuYW1lOiAnVGl0cmUnLFxuICAgICAgICBkZXNjcmlwdGlvbjogJ0Rlc2NyaXB0aW9uJyxcbiAgICAgICAgaW1hZ2U6ICdJbWFnZSBk4oCZaWxsdXN0cmF0aW9uJyxcbiAgICAgICAgZHJhZ0Ryb3A6ICdHbGlzc2VyIC0gRMOpcG9zZXInLFxuICAgICAgICBvcjogJ291JyxcbiAgICAgICAgY2F0ZWdvcmllczogJ0NhdMOpZ29yaWVzJyxcbiAgICAgICAgY2F0ZWdvcnlJbnB1dDogJ1NhaXNpciBsYS9sZXMgY2F0w6lnb3JpZXMnLFxuICAgICAgICBncmlkOiAnR3JpbGxlIGFjdHVlbGxlOiAnLFxuICAgICAgICB0aGVtZTogJ1Row6ltYXRpcXVlJ1xuICAgICAgfSxcbiAgICAgIG5vRGF0YTogJ0F1Y3VuIHRhYmxlYXUgZGUgYm9yZCcsXG4gICAgICBzaGFyZTogJ1BhcnRhZ2VyJyxcbiAgICAgIG9wdGlvbnM6ICdPcHRpb25zIGR1IHRhYmxlYXUgZGUgYm9yZCcsXG4gICAgICBjb25zdWx0OiAnQ29uc3VsdGVyJyxcbiAgICAgIHZpZXc6ICdDb25zdWx0ZXIgbGUgdGFibGVhdSBkZSBib3JkJyxcbiAgICAgIHByaXZhdGU6ICdQcsOpc2VudGF0aW9uIHByaXbDqWUnLFxuICAgICAgaG9tZVZpZXc6IFwiQWZmaWNoZXIgZW4gcGFnZSBkJ2FjY3VlaWxcIixcbiAgICAgIGVyYXNlOiAnU3VwcHJpbWVyIGxlIHRhYmxlYXUgZGUgYm9yZCcsXG4gICAgICBjaGFuZ2U6ICdNb2RpZmllciBsZSB0YWJsZWF1IGRlIGJvcmQnLFxuICAgICAgY3JlYXRlOiAnQ3LDqWVyIHVuIHRhYmxlYXUgZGUgYm9yZCcsXG4gICAgICBjb25maWd1cmF0aW9uOiAnRW5yZWdpc3RyZXInLFxuICAgICAgcmVxdWlyZWQ6ICdDZSBjaGFtcCBlc3QgcmVxdWlzJyxcbiAgICAgIG1heExlbmd0aDogJ05vbWJyZSBkZSBjYXJhY3TDqHJlcyBhdXRvcmlzw6lzIDoge3tsZW59fScsXG4gICAgICBlZGl0aW9uOiAnTW9kaWZpZXInLFxuICAgICAgZWRpdGlvbkNvbnRlbnQ6ICdNb2RpZmllciBsYSBjb21wb3NpdGlvbicsXG4gICAgICBkZWxldGU6ICdTdXBwcmltZXInLFxuICAgICAgYmFja1RvQ2F0YWxvZzogJ1JldmVuaXIgYXUgY2F0YWxvZ3VlJyxcbiAgICAgIHNlYXJjaDogJ1JlY2hlcmNoZXInLFxuICAgICAgdGl0bGU6ICdDYXRhbG9ndWUgZGUgdGFibGVhdXggZGUgYm9yZCcsXG4gICAgICBtb3JlOiAnT3B0aW9ucydcbiAgICB9XG4gIH1cbn07XG4iXX0=
|
|
@@ -2,10 +2,10 @@ import { Component, ViewEncapsulation } from '@angular/core';
|
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export class PryPresentationCssComponent {
|
|
4
4
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: PryPresentationCssComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
5
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: PryPresentationCssComponent, selector: "pry-presentation-css", ngImport: i0, template: '', isInline: true, styles: ["pry-add-edit-presentation{height:100%}.o-manifest-layout__content--presentation{width:100%;display:flex;flex-direction:column;padding:20px;text-align:left}.o-manifest-layout__content--presentation .a-h1{line-height:38px;font-size:28px;text-align:left}.o-manifest-layout__content--presentation .a-btn{margin:0 auto}.o-manifest-layout__toolbox{gap:.9375rem}.o-presentation-form-wrapper{display:flex;padding-bottom:.3125rem;gap:3rem}.o-presentation-form-wrapper>:first-child{flex:2 auto}.o-presentation-form-wrapper>:only-child{max-width:43.75rem}.o-presentation__metadata-editor{flex-basis:50%}.o-presentation-form{display:flex;flex-direction:column;align-items:center}.o-presentation-form .a-presentation-form-input{padding:.25rem .75rem;margin-bottom:.75rem}.o-presentation-form .o-file-input{border:1px dashed black;display:flex;flex-direction:column;align-items:center;width:100%;padding:.625rem 0;gap:15px}.o-presentation-form pry-select{width:100%}.o-presentation-form .a-btn[type=submit]{margin-top:20px}.o-presentation-form .o-text-editor__content{min-height:6.25rem}.o-presentation-form .o-text-editor__content textarea{height:6.25rem}\n", ".o-presentation{margin:0;padding:0}.o-presentation li{list-style:none}.o-manifest-layout__toolbox{justify-content:space-between}.o-manifest-layout__toolbox.-u-hidden{display:none}.o-manifest-layout__content{height:100%;overflow:auto}.o-manifest-layout__content .pointer{cursor:pointer}.pry-viewingpresentation{display:flex;overflow-y:scroll}.pry-viewingpresentation .o-manifest-layout__content,.pry-viewingpresentation .o-dashboard-widget{grid-area:middle;flex:100% 1 1}.no-data-dashboard{text-align:center}.o-presentation{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:1.875rem;padding:.25rem .25rem 1.25rem;overflow-y:auto}.o-presentation .a-h3{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.o-presentation__item{display:flex;flex-direction:column;align-items:stretch}.o-presentation__item:hover{cursor:pointer}.o-presentation__item:hover .o-presentation__item__footer pry-icon{visibility:visible;opacity:1}.o-presentation__item__image{cursor:pointer;overflow:hidden;height:6.875rem;display:flex;align-items:center;justify-content:center}.o-presentation__item__image img{width:100px}.o-presentation__item__image .is-full-width{width:100%;height:100%;object-fit:cover}.o-presentation__item__header{position:relative;display:flex;align-items:flex-start;justify-content:center;height:6.875rem}.o-presentation__item__header pry-icon.is-private{position:absolute;top:.625rem;left:.625rem;z-index:1}.o-presentation__item__header .a-tooltip{width:100%}.o-presentation__item__txt{flex-grow:1;padding:.625rem .9375rem;display:flex;flex-direction:column;justify-content:space-between}.o-presentation__item__txt .a-h3{padding-bottom:.3125rem}.o-presentation__item__txt .a-p.-date{padding-top:.625rem;margin-bottom:0}.o-presentation__item__txt .a-chip.-theme.-u-hidden{display:none}.o-presentation__item__title-container.a-tooltip[data-tooltip]:after{top:calc(100% - 15px)}.o-presentation__item__description-container{position:relative;width:100%;display:flex;align-content:center;min-height:1.25rem}.o-presentation__item__description-container.a-tooltip[data-tooltip]:after{width:100%}.o-presentation__item__description{width:100%;max-height:2.5rem}.o-presentation__item__footer{display:flex;align-content:center;justify-content:center;font-size:.875rem;line-height:1.125rem;padding:.1875rem 0;max-height:2.3125rem}.o-presentation__item__footer .a-btn{margin-left:1.25rem}.o-presentation__item__footer pry-icon{visibility:hidden;opacity:0;transition:visibility .1s linear,opacity .1s linear;margin-left:.1875rem}.o-presentation-consult{width:100%;padding:.9375rem}.more-button{position:absolute;top:.375rem;right:.625rem}.more-button .a-btn{padding:.125rem 0;border-radius:50%}.m-context-menu{position:absolute}\n"], encapsulation: i0.ViewEncapsulation.None }); }
|
|
5
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: PryPresentationCssComponent, selector: "pry-presentation-css", ngImport: i0, template: '', isInline: true, styles: ["pry-add-edit-presentation{height:100%}.o-manifest-layout__content--presentation{width:100%;display:flex;flex-direction:column;padding:20px;text-align:left}.o-manifest-layout__content--presentation .a-h1{line-height:38px;font-size:28px;text-align:left}.o-manifest-layout__content--presentation .a-btn{margin:0 auto}.o-manifest-layout__toolbox{gap:.9375rem}.o-presentation-form-wrapper{display:flex;padding-bottom:.3125rem;gap:3rem}.o-presentation-form-wrapper>:first-child{flex:2 auto}.o-presentation-form-wrapper>:only-child{max-width:43.75rem}.o-presentation__metadata-editor{flex-basis:50%}.o-presentation-form{display:flex;flex-direction:column;align-items:center}.o-presentation-form .a-form-field::placeholder{color:#859db6;font-style:italic}.o-presentation-form .a-presentation-form-input{padding:.25rem .75rem;margin-bottom:.75rem}.o-presentation-form .o-file-input{border:1px dashed black;display:flex;flex-direction:column;align-items:center;width:100%;padding:.625rem 0;gap:15px}.o-presentation-form pry-select{width:100%}.o-presentation-form .a-btn[type=submit]{margin-top:20px}.o-presentation-form .o-text-editor__content{min-height:6.25rem}.o-presentation-form .o-text-editor__content textarea{height:6.25rem}\n", ".o-presentation{margin:0;padding:0}.o-presentation li{list-style:none}.o-manifest-layout__toolbox{justify-content:space-between}.o-manifest-layout__toolbox.-u-hidden{display:none}.o-manifest-layout__content{height:100%;overflow:auto}.o-manifest-layout__content .pointer{cursor:pointer}.pry-viewingpresentation{display:flex;overflow-y:scroll}.pry-viewingpresentation .o-manifest-layout__content,.pry-viewingpresentation .o-dashboard-widget{grid-area:middle;flex:100% 1 1}.no-data-dashboard{text-align:center}.o-presentation{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:1.875rem;padding:.25rem .25rem 1.25rem;overflow-y:auto}.o-presentation .a-h3{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.o-presentation__item{display:flex;flex-direction:column;align-items:stretch}.o-presentation__item:hover{cursor:pointer}.o-presentation__item:hover .o-presentation__item__footer pry-icon{visibility:visible;opacity:1}.o-presentation__item__image{cursor:pointer;overflow:hidden;height:6.875rem;display:flex;align-items:center;justify-content:center}.o-presentation__item__image img{width:100px}.o-presentation__item__image .is-full-width{width:100%;height:100%;object-fit:cover}.o-presentation__item__header{position:relative;display:flex;align-items:flex-start;justify-content:center;height:6.875rem}.o-presentation__item__header pry-icon.is-private{position:absolute;top:.625rem;left:.625rem;z-index:1}.o-presentation__item__header .a-tooltip{width:100%}.o-presentation__item__txt{flex-grow:1;padding:.625rem .9375rem;display:flex;flex-direction:column;justify-content:space-between}.o-presentation__item__txt .a-h3{padding-bottom:.3125rem}.o-presentation__item__txt .a-p.-date{padding-top:.625rem;margin-bottom:0}.o-presentation__item__txt .a-chip.-theme.-u-hidden{display:none}.o-presentation__item__title-container.a-tooltip[data-tooltip]:after{top:calc(100% - 15px)}.o-presentation__item__description-container{position:relative;width:100%;display:flex;align-content:center;min-height:1.25rem}.o-presentation__item__description-container.a-tooltip[data-tooltip]:after{width:100%}.o-presentation__item__description{width:100%;max-height:2.5rem}.o-presentation__item__footer{display:flex;align-content:center;justify-content:center;font-size:.875rem;line-height:1.125rem;padding:.1875rem 0;max-height:2.3125rem}.o-presentation__item__footer .a-btn{margin-left:1.25rem}.o-presentation__item__footer pry-icon{visibility:hidden;opacity:0;transition:visibility .1s linear,opacity .1s linear;margin-left:.1875rem}.o-presentation-consult{width:100%;padding:.9375rem}.more-button{position:absolute;top:.375rem;right:.625rem}.more-button .a-btn{padding:.125rem 0;border-radius:50%}.m-context-menu{position:absolute}\n"], encapsulation: i0.ViewEncapsulation.None }); }
|
|
6
6
|
}
|
|
7
7
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: PryPresentationCssComponent, decorators: [{
|
|
8
8
|
type: Component,
|
|
9
|
-
args: [{ selector: 'pry-presentation-css', template: '', encapsulation: ViewEncapsulation.None, styles: ["pry-add-edit-presentation{height:100%}.o-manifest-layout__content--presentation{width:100%;display:flex;flex-direction:column;padding:20px;text-align:left}.o-manifest-layout__content--presentation .a-h1{line-height:38px;font-size:28px;text-align:left}.o-manifest-layout__content--presentation .a-btn{margin:0 auto}.o-manifest-layout__toolbox{gap:.9375rem}.o-presentation-form-wrapper{display:flex;padding-bottom:.3125rem;gap:3rem}.o-presentation-form-wrapper>:first-child{flex:2 auto}.o-presentation-form-wrapper>:only-child{max-width:43.75rem}.o-presentation__metadata-editor{flex-basis:50%}.o-presentation-form{display:flex;flex-direction:column;align-items:center}.o-presentation-form .a-presentation-form-input{padding:.25rem .75rem;margin-bottom:.75rem}.o-presentation-form .o-file-input{border:1px dashed black;display:flex;flex-direction:column;align-items:center;width:100%;padding:.625rem 0;gap:15px}.o-presentation-form pry-select{width:100%}.o-presentation-form .a-btn[type=submit]{margin-top:20px}.o-presentation-form .o-text-editor__content{min-height:6.25rem}.o-presentation-form .o-text-editor__content textarea{height:6.25rem}\n", ".o-presentation{margin:0;padding:0}.o-presentation li{list-style:none}.o-manifest-layout__toolbox{justify-content:space-between}.o-manifest-layout__toolbox.-u-hidden{display:none}.o-manifest-layout__content{height:100%;overflow:auto}.o-manifest-layout__content .pointer{cursor:pointer}.pry-viewingpresentation{display:flex;overflow-y:scroll}.pry-viewingpresentation .o-manifest-layout__content,.pry-viewingpresentation .o-dashboard-widget{grid-area:middle;flex:100% 1 1}.no-data-dashboard{text-align:center}.o-presentation{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:1.875rem;padding:.25rem .25rem 1.25rem;overflow-y:auto}.o-presentation .a-h3{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.o-presentation__item{display:flex;flex-direction:column;align-items:stretch}.o-presentation__item:hover{cursor:pointer}.o-presentation__item:hover .o-presentation__item__footer pry-icon{visibility:visible;opacity:1}.o-presentation__item__image{cursor:pointer;overflow:hidden;height:6.875rem;display:flex;align-items:center;justify-content:center}.o-presentation__item__image img{width:100px}.o-presentation__item__image .is-full-width{width:100%;height:100%;object-fit:cover}.o-presentation__item__header{position:relative;display:flex;align-items:flex-start;justify-content:center;height:6.875rem}.o-presentation__item__header pry-icon.is-private{position:absolute;top:.625rem;left:.625rem;z-index:1}.o-presentation__item__header .a-tooltip{width:100%}.o-presentation__item__txt{flex-grow:1;padding:.625rem .9375rem;display:flex;flex-direction:column;justify-content:space-between}.o-presentation__item__txt .a-h3{padding-bottom:.3125rem}.o-presentation__item__txt .a-p.-date{padding-top:.625rem;margin-bottom:0}.o-presentation__item__txt .a-chip.-theme.-u-hidden{display:none}.o-presentation__item__title-container.a-tooltip[data-tooltip]:after{top:calc(100% - 15px)}.o-presentation__item__description-container{position:relative;width:100%;display:flex;align-content:center;min-height:1.25rem}.o-presentation__item__description-container.a-tooltip[data-tooltip]:after{width:100%}.o-presentation__item__description{width:100%;max-height:2.5rem}.o-presentation__item__footer{display:flex;align-content:center;justify-content:center;font-size:.875rem;line-height:1.125rem;padding:.1875rem 0;max-height:2.3125rem}.o-presentation__item__footer .a-btn{margin-left:1.25rem}.o-presentation__item__footer pry-icon{visibility:hidden;opacity:0;transition:visibility .1s linear,opacity .1s linear;margin-left:.1875rem}.o-presentation-consult{width:100%;padding:.9375rem}.more-button{position:absolute;top:.375rem;right:.625rem}.more-button .a-btn{padding:.125rem 0;border-radius:50%}.m-context-menu{position:absolute}\n"] }]
|
|
9
|
+
args: [{ selector: 'pry-presentation-css', template: '', encapsulation: ViewEncapsulation.None, styles: ["pry-add-edit-presentation{height:100%}.o-manifest-layout__content--presentation{width:100%;display:flex;flex-direction:column;padding:20px;text-align:left}.o-manifest-layout__content--presentation .a-h1{line-height:38px;font-size:28px;text-align:left}.o-manifest-layout__content--presentation .a-btn{margin:0 auto}.o-manifest-layout__toolbox{gap:.9375rem}.o-presentation-form-wrapper{display:flex;padding-bottom:.3125rem;gap:3rem}.o-presentation-form-wrapper>:first-child{flex:2 auto}.o-presentation-form-wrapper>:only-child{max-width:43.75rem}.o-presentation__metadata-editor{flex-basis:50%}.o-presentation-form{display:flex;flex-direction:column;align-items:center}.o-presentation-form .a-form-field::placeholder{color:#859db6;font-style:italic}.o-presentation-form .a-presentation-form-input{padding:.25rem .75rem;margin-bottom:.75rem}.o-presentation-form .o-file-input{border:1px dashed black;display:flex;flex-direction:column;align-items:center;width:100%;padding:.625rem 0;gap:15px}.o-presentation-form pry-select{width:100%}.o-presentation-form .a-btn[type=submit]{margin-top:20px}.o-presentation-form .o-text-editor__content{min-height:6.25rem}.o-presentation-form .o-text-editor__content textarea{height:6.25rem}\n", ".o-presentation{margin:0;padding:0}.o-presentation li{list-style:none}.o-manifest-layout__toolbox{justify-content:space-between}.o-manifest-layout__toolbox.-u-hidden{display:none}.o-manifest-layout__content{height:100%;overflow:auto}.o-manifest-layout__content .pointer{cursor:pointer}.pry-viewingpresentation{display:flex;overflow-y:scroll}.pry-viewingpresentation .o-manifest-layout__content,.pry-viewingpresentation .o-dashboard-widget{grid-area:middle;flex:100% 1 1}.no-data-dashboard{text-align:center}.o-presentation{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:1.875rem;padding:.25rem .25rem 1.25rem;overflow-y:auto}.o-presentation .a-h3{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.o-presentation__item{display:flex;flex-direction:column;align-items:stretch}.o-presentation__item:hover{cursor:pointer}.o-presentation__item:hover .o-presentation__item__footer pry-icon{visibility:visible;opacity:1}.o-presentation__item__image{cursor:pointer;overflow:hidden;height:6.875rem;display:flex;align-items:center;justify-content:center}.o-presentation__item__image img{width:100px}.o-presentation__item__image .is-full-width{width:100%;height:100%;object-fit:cover}.o-presentation__item__header{position:relative;display:flex;align-items:flex-start;justify-content:center;height:6.875rem}.o-presentation__item__header pry-icon.is-private{position:absolute;top:.625rem;left:.625rem;z-index:1}.o-presentation__item__header .a-tooltip{width:100%}.o-presentation__item__txt{flex-grow:1;padding:.625rem .9375rem;display:flex;flex-direction:column;justify-content:space-between}.o-presentation__item__txt .a-h3{padding-bottom:.3125rem}.o-presentation__item__txt .a-p.-date{padding-top:.625rem;margin-bottom:0}.o-presentation__item__txt .a-chip.-theme.-u-hidden{display:none}.o-presentation__item__title-container.a-tooltip[data-tooltip]:after{top:calc(100% - 15px)}.o-presentation__item__description-container{position:relative;width:100%;display:flex;align-content:center;min-height:1.25rem}.o-presentation__item__description-container.a-tooltip[data-tooltip]:after{width:100%}.o-presentation__item__description{width:100%;max-height:2.5rem}.o-presentation__item__footer{display:flex;align-content:center;justify-content:center;font-size:.875rem;line-height:1.125rem;padding:.1875rem 0;max-height:2.3125rem}.o-presentation__item__footer .a-btn{margin-left:1.25rem}.o-presentation__item__footer pry-icon{visibility:hidden;opacity:0;transition:visibility .1s linear,opacity .1s linear;margin-left:.1875rem}.o-presentation-consult{width:100%;padding:.9375rem}.more-button{position:absolute;top:.375rem;right:.625rem}.more-button .a-btn{padding:.125rem 0;border-radius:50%}.m-context-menu{position:absolute}\n"] }]
|
|
10
10
|
}] });
|
|
11
11
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3NzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL3ByZXNlbnRhdGlvbi9zdHlsZS9jc3MuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBUTdELE1BQU0sT0FBTywyQkFBMkI7OEdBQTNCLDJCQUEyQjtrR0FBM0IsMkJBQTJCLDREQUo1QixFQUFFOzsyRkFJRCwyQkFBMkI7a0JBTnZDLFNBQVM7K0JBQ0Usc0JBQXNCLFlBQ3RCLEVBQUUsaUJBRUcsaUJBQWlCLENBQUMsSUFBSSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncHJ5LXByZXNlbnRhdGlvbi1jc3MnLFxuICB0ZW1wbGF0ZTogJycsXG4gIHN0eWxlVXJsczogWycuL19vLXByeS1uZXctcHJlc2VudGF0aW9uLnNjc3MnLCAnLi9fby1wcnktcHJlc2VudGF0aW9uLnNjc3MnXSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZVxufSlcbmV4cG9ydCBjbGFzcyBQcnlQcmVzZW50YXRpb25Dc3NDb21wb25lbnQge31cbiJdfQ==
|
|
@@ -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,
|