@provoly/dashboard 0.23.1 → 0.23.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.d.ts +10 -2
- package/admin/i18n/en.translations.d.ts +5 -0
- package/admin/i18n/fr.translations.d.ts +4 -0
- package/admin/store/admin.effects.d.ts +7 -1
- package/esm2022/admin/components/admin-dataset/admin-select-dataset/admin-select-dataset.component.mjs +26 -10
- package/esm2022/admin/i18n/en.translations.mjs +7 -2
- package/esm2022/admin/i18n/fr.translations.mjs +7 -3
- package/esm2022/admin/store/admin.effects.mjs +17 -5
- package/esm2022/lib/core/components/share/share.model.mjs +1 -1
- package/esm2022/lib/core/i18n/en.translations.mjs +7 -2
- package/esm2022/lib/core/i18n/fr.translations.mjs +7 -2
- package/esm2022/lib/core/store/data-source/data-source.actions.mjs +2 -1
- package/esm2022/lib/core/store/data-source/data-source.effects.mjs +2 -8
- package/esm2022/lib/core/store/data-source/data-source.reducer.mjs +4 -1
- package/esm2022/lib/core/store/data-source/data-source.selectors.mjs +3 -1
- package/esm2022/lib/core/store/data-source/data-source.service.mjs +1 -1
- package/esm2022/lib/dashboard/store/dashboard.effects.mjs +32 -9
- package/esm2022/lib/dashboard/store/manifest.service.mjs +14 -12
- package/fesm2022/provoly-dashboard-admin.mjs +49 -13
- package/fesm2022/provoly-dashboard-admin.mjs.map +1 -1
- package/fesm2022/provoly-dashboard.mjs +62 -28
- package/fesm2022/provoly-dashboard.mjs.map +1 -1
- package/lib/core/components/share/share.model.d.ts +6 -0
- package/lib/core/i18n/en.translations.d.ts +5 -0
- package/lib/core/i18n/fr.translations.d.ts +5 -0
- package/lib/core/store/data-source/data-source.actions.d.ts +8 -3
- package/lib/core/store/data-source/data-source.effects.d.ts +3 -8
- package/lib/core/store/data-source/data-source.reducer.d.ts +2 -0
- package/lib/core/store/data-source/data-source.selectors.d.ts +1 -0
- package/lib/core/store/data-source/data-source.service.d.ts +2 -1
- package/lib/dashboard/store/dashboard.effects.d.ts +2 -1
- package/lib/dashboard/store/manifest.service.d.ts +2 -1
- package/package.json +36 -36
- package/styles/components/_o-widget.scss +1 -0
- package/styles-theme/components-theme/_a-btn.theme.scss +1 -1
- package/styles-theme/components-theme/_a-checkbox.theme.scss +5 -0
- package/styles-theme/components-theme/_a-form-field.theme.scss +5 -0
|
@@ -49,17 +49,19 @@ export class ManifestService {
|
|
|
49
49
|
.pipe(mergeMap((url) => this.httpClient.get(encodeURI(`${url}/users/me/dashboards/id/${id}/manifest`))));
|
|
50
50
|
}
|
|
51
51
|
save(name, manifest, id, description, image, cover, metadata, groups) {
|
|
52
|
-
return this.store.select(ConfigSelectors.refUrl).pipe(mergeMap((url) =>
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
52
|
+
return this.store.select(ConfigSelectors.refUrl).pipe(mergeMap((url) => {
|
|
53
|
+
return this.httpClient.post(encodeURI(`${url}/users/me/dashboards`), {
|
|
54
|
+
id,
|
|
55
|
+
name,
|
|
56
|
+
description,
|
|
57
|
+
manifest,
|
|
58
|
+
image,
|
|
59
|
+
cover,
|
|
60
|
+
metadata,
|
|
61
|
+
datasource: ManifestUtils.getDatasourcesUsedByManifest(manifest).map((ds) => ds.datasetId),
|
|
62
|
+
groups
|
|
63
|
+
});
|
|
64
|
+
}));
|
|
63
65
|
}
|
|
64
66
|
delete(id) {
|
|
65
67
|
return this.store
|
|
@@ -100,4 +102,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
100
102
|
providedIn: 'root'
|
|
101
103
|
}]
|
|
102
104
|
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: i2.Store }, { type: i3.PrySnackbarService }, { type: i4.PryI18nService }] });
|
|
103
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"manifest.service.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/lib/dashboard/store/manifest.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport { mergeMap, Observable, of } from 'rxjs';\nimport { catchError, map, withLatestFrom } from 'rxjs/operators';\nimport { PrySnackbarService } from '../../core/components/snackbar/snackbar.service';\nimport { PryI18nService } from '../../core/i18n/i18n.service';\nimport { GlobalManifest, ManifestDescription } from '../../core/model/manifest.interface';\nimport { ConfigSelectors } from '../../core/store/config/config.selectors';\nimport { ManifestUtils } from './manifest-utils.class';\nimport { DashboardSelectors } from './dashboard.selectors';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ManifestService {\n  constructor(\n    private httpClient: HttpClient,\n    private store: Store<any>,\n    private snackBar: PrySnackbarService,\n    private translateService: PryI18nService\n  ) {}\n\n  list(): Observable<ManifestDescription[]> {\n    return this.store.select(ConfigSelectors.refUrl).pipe(\n      mergeMap((url) => this.httpClient.get<ManifestDescription[]>(encodeURI(`${url}/users/me/dashboards`))),\n      catchError((error) => {\n        if (error.error instanceof Error) {\n          // A client-side or network error occurred\n          console.error('A frontend error occurred:', error.error.message);\n          this.snackBar.open({\n            type: 'error',\n            message: this.translateService.instant('@pry.manifest.get.errorFront', { msg: error.error.message })\n          });\n        } else {\n          // The backend returned an unsuccessful response code.\n          if (error.code !== 200) {\n            console.error(`Backend returned code ${error.status}, body was: ${JSON.stringify(error.error)}`);\n          }\n          if (error.code >= 400) {\n            this.snackBar.open({\n              type: 'error',\n              message: this.translateService.instant('@pry.manifest.get.errorBack', {\n                code: error.status\n              })\n            });\n          }\n        }\n        return of([]);\n      })\n    );\n  }\n\n  get(id: string): Observable<GlobalManifest> {\n    return this.store\n      .select(ConfigSelectors.refUrl)\n      .pipe(\n        mergeMap((url) =>\n          this.httpClient.get<GlobalManifest>(encodeURI(`${url}/users/me/dashboards/id/${id}/manifest`))\n        )\n      );\n  }\n\n  save(\n    name: string,\n    manifest: GlobalManifest,\n    id: string,\n    description?: string,\n    image?: string,\n    cover?: boolean,\n    metadata?: { metadataDefId: string; value: string }[],\n    groups?: string[]\n  ): Observable<{ id: string; name: string; manifest: GlobalManifest }> {\n    return this.store.select(ConfigSelectors.refUrl).pipe(\n      mergeMap((url) =>\n        this.httpClient.post<{ id: string; description: string; name: string; manifest: GlobalManifest }>(\n          encodeURI(`${url}/users/me/dashboards`),\n          {\n            id,\n            name,\n            description,\n            manifest,\n            image,\n            cover,\n            metadata,\n            datasource: ManifestUtils.getDatasourcesUsedByManifest(manifest).map((ds) => ds.datasetId),\n            groups\n          }\n        )\n      )\n    );\n  }\n\n  delete(id: string): Observable<void> {\n    return this.store\n      .select(ConfigSelectors.refUrl)\n      .pipe(mergeMap((url) => this.httpClient.delete<void>(encodeURI(`${url}/users/me/dashboards/id/${id}`))));\n  }\n\n  default(id: string): Observable<boolean> {\n    return this.store.select(ConfigSelectors.refUrl).pipe(\n      withLatestFrom(this.store.select(DashboardSelectors.manifestsList)),\n      mergeMap(([url, manifests]) => {\n        const actual = manifests.find((manifest: { id: string }) => manifest.id === id);\n        if (!!actual) {\n          return this.httpClient\n            .put<ArrayBuffer>(encodeURI(`${url}/users/me/dashboards/id/${id}/default`), {})\n            .pipe(map(() => true));\n        } else {\n          return this.httpClient\n            .delete<ArrayBuffer>(encodeURI(`${url}/users/me/dashboards/default`), {})\n            .pipe(map(() => false));\n        }\n      })\n    );\n  }\n\n  addMetadata(presentationId: string, metadataId: string, value: string): Observable<void> {\n    return this.store\n      .select(ConfigSelectors.refUrl)\n      .pipe(\n        mergeMap((url) =>\n          this.httpClient.put<void>(\n            encodeURI(`${url}/users/me/dashboards/id/${presentationId}/metadata/id/${metadataId}`),\n            { value }\n          )\n        )\n      );\n  }\n\n  deleteMetadata(presentationId: string, metadataId: string): Observable<void> {\n    return this.store\n      .select(ConfigSelectors.refUrl)\n      .pipe(\n        mergeMap((url) =>\n          this.httpClient.delete<void>(\n            encodeURI(`${url}/users/me/dashboards/id/${presentationId}/metadata/id/${metadataId}`)\n          )\n        )\n      );\n  }\n}\n"]}
|
|
105
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"manifest.service.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/lib/dashboard/store/manifest.service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,OAAO,EAAE,QAAQ,EAAc,EAAE,EAAE,MAAM,MAAM,CAAC;AAChD,OAAO,EAAE,UAAU,EAAE,GAAG,EAAE,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAIjE,OAAO,EAAE,eAAe,EAAE,MAAM,0CAA0C,CAAC;AAC3E,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;;;;;;AAM3D,MAAM,OAAO,eAAe;IAC1B,YACU,UAAsB,EACtB,KAAiB,EACjB,QAA4B,EAC5B,gBAAgC;QAHhC,eAAU,GAAV,UAAU,CAAY;QACtB,UAAK,GAAL,KAAK,CAAY;QACjB,aAAQ,GAAR,QAAQ,CAAoB;QAC5B,qBAAgB,GAAhB,gBAAgB,CAAgB;IACvC,CAAC;IAEJ,IAAI;QACF,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,IAAI,CACnD,QAAQ,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAwB,SAAS,CAAC,GAAG,GAAG,sBAAsB,CAAC,CAAC,CAAC,EACtG,UAAU,CAAC,CAAC,KAAK,EAAE,EAAE;YACnB,IAAI,KAAK,CAAC,KAAK,YAAY,KAAK,EAAE,CAAC;gBACjC,0CAA0C;gBAC1C,OAAO,CAAC,KAAK,CAAC,4BAA4B,EAAE,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;gBACjE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;oBACjB,IAAI,EAAE,OAAO;oBACb,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,8BAA8B,EAAE,EAAE,GAAG,EAAE,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;iBACrG,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,sDAAsD;gBACtD,IAAI,KAAK,CAAC,IAAI,KAAK,GAAG,EAAE,CAAC;oBACvB,OAAO,CAAC,KAAK,CAAC,yBAAyB,KAAK,CAAC,MAAM,eAAe,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;gBACnG,CAAC;gBACD,IAAI,KAAK,CAAC,IAAI,IAAI,GAAG,EAAE,CAAC;oBACtB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;wBACjB,IAAI,EAAE,OAAO;wBACb,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,6BAA6B,EAAE;4BACpE,IAAI,EAAE,KAAK,CAAC,MAAM;yBACnB,CAAC;qBACH,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;YACD,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;QAChB,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,GAAG,CAAC,EAAU;QACZ,OAAO,IAAI,CAAC,KAAK;aACd,MAAM,CAAC,eAAe,CAAC,MAAM,CAAC;aAC9B,IAAI,CACH,QAAQ,CAAC,CAAC,GAAG,EAAE,EAAE,CACf,IAAI,CAAC,UAAU,CAAC,GAAG,CAAiB,SAAS,CAAC,GAAG,GAAG,2BAA2B,EAAE,WAAW,CAAC,CAAC,CAC/F,CACF,CAAC;IACN,CAAC;IAED,IAAI,CACF,IAAY,EACZ,QAAwB,EACxB,EAAU,EACV,WAAoB,EACpB,KAAc,EACd,KAAe,EACf,QAAqD,EACrD,MAAiB;QAEjB,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,IAAI,CACnD,QAAQ,CAAC,CAAC,GAAG,EAAE,EAAE;YACf,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAQzB,SAAS,CAAC,GAAG,GAAG,sBAAsB,CAAC,EAAE;gBACzC,EAAE;gBACF,IAAI;gBACJ,WAAW;gBACX,QAAQ;gBACR,KAAK;gBACL,KAAK;gBACL,QAAQ;gBACR,UAAU,EAAE,aAAa,CAAC,4BAA4B,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC;gBAC1F,MAAM;aACP,CAAC,CAAC;QACL,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,EAAU;QACf,OAAO,IAAI,CAAC,KAAK;aACd,MAAM,CAAC,eAAe,CAAC,MAAM,CAAC;aAC9B,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAO,SAAS,CAAC,GAAG,GAAG,2BAA2B,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAC7G,CAAC;IAED,OAAO,CAAC,EAAU;QAChB,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,IAAI,CACnD,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,kBAAkB,CAAC,aAAa,CAAC,CAAC,EACnE,QAAQ,CAAC,CAAC,CAAC,GAAG,EAAE,SAAS,CAAC,EAAE,EAAE;YAC5B,MAAM,MAAM,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC,QAAwB,EAAE,EAAE,CAAC,QAAQ,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;YAChF,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC;gBACb,OAAO,IAAI,CAAC,UAAU;qBACnB,GAAG,CAAc,SAAS,CAAC,GAAG,GAAG,2BAA2B,EAAE,UAAU,CAAC,EAAE,EAAE,CAAC;qBAC9E,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;YAC3B,CAAC;iBAAM,CAAC;gBACN,OAAO,IAAI,CAAC,UAAU;qBACnB,MAAM,CAAc,SAAS,CAAC,GAAG,GAAG,8BAA8B,CAAC,EAAE,EAAE,CAAC;qBACxE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;YAC5B,CAAC;QACH,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,WAAW,CAAC,cAAsB,EAAE,UAAkB,EAAE,KAAa;QACnE,OAAO,IAAI,CAAC,KAAK;aACd,MAAM,CAAC,eAAe,CAAC,MAAM,CAAC;aAC9B,IAAI,CACH,QAAQ,CAAC,CAAC,GAAG,EAAE,EAAE,CACf,IAAI,CAAC,UAAU,CAAC,GAAG,CACjB,SAAS,CAAC,GAAG,GAAG,2BAA2B,cAAc,gBAAgB,UAAU,EAAE,CAAC,EACtF,EAAE,KAAK,EAAE,CACV,CACF,CACF,CAAC;IACN,CAAC;IAED,cAAc,CAAC,cAAsB,EAAE,UAAkB;QACvD,OAAO,IAAI,CAAC,KAAK;aACd,MAAM,CAAC,eAAe,CAAC,MAAM,CAAC;aAC9B,IAAI,CACH,QAAQ,CAAC,CAAC,GAAG,EAAE,EAAE,CACf,IAAI,CAAC,UAAU,CAAC,MAAM,CACpB,SAAS,CAAC,GAAG,GAAG,2BAA2B,cAAc,gBAAgB,UAAU,EAAE,CAAC,CACvF,CACF,CACF,CAAC;IACN,CAAC;8GAlIU,eAAe;kHAAf,eAAe,cAFd,MAAM;;2FAEP,eAAe;kBAH3B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Injectable } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport { mergeMap, Observable, of } from 'rxjs';\nimport { catchError, map, withLatestFrom } from 'rxjs/operators';\nimport { PrySnackbarService } from '../../core/components/snackbar/snackbar.service';\nimport { PryI18nService } from '../../core/i18n/i18n.service';\nimport { GlobalManifest, ManifestDescription } from '../../core/model/manifest.interface';\nimport { ConfigSelectors } from '../../core/store/config/config.selectors';\nimport { ManifestUtils } from './manifest-utils.class';\nimport { DashboardSelectors } from './dashboard.selectors';\nimport { ShareConflict } from '../../core/components/share/share.model';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class ManifestService {\n  constructor(\n    private httpClient: HttpClient,\n    private store: Store<any>,\n    private snackBar: PrySnackbarService,\n    private translateService: PryI18nService\n  ) {}\n\n  list(): Observable<ManifestDescription[]> {\n    return this.store.select(ConfigSelectors.refUrl).pipe(\n      mergeMap((url) => this.httpClient.get<ManifestDescription[]>(encodeURI(`${url}/users/me/dashboards`))),\n      catchError((error) => {\n        if (error.error instanceof Error) {\n          // A client-side or network error occurred\n          console.error('A frontend error occurred:', error.error.message);\n          this.snackBar.open({\n            type: 'error',\n            message: this.translateService.instant('@pry.manifest.get.errorFront', { msg: error.error.message })\n          });\n        } else {\n          // The backend returned an unsuccessful response code.\n          if (error.code !== 200) {\n            console.error(`Backend returned code ${error.status}, body was: ${JSON.stringify(error.error)}`);\n          }\n          if (error.code >= 400) {\n            this.snackBar.open({\n              type: 'error',\n              message: this.translateService.instant('@pry.manifest.get.errorBack', {\n                code: error.status\n              })\n            });\n          }\n        }\n        return of([]);\n      })\n    );\n  }\n\n  get(id: string): Observable<GlobalManifest> {\n    return this.store\n      .select(ConfigSelectors.refUrl)\n      .pipe(\n        mergeMap((url) =>\n          this.httpClient.get<GlobalManifest>(encodeURI(`${url}/users/me/dashboards/id/${id}/manifest`))\n        )\n      );\n  }\n\n  save(\n    name: string,\n    manifest: GlobalManifest,\n    id: string,\n    description?: string,\n    image?: string,\n    cover?: boolean,\n    metadata?: { metadataDefId: string; value: string }[],\n    groups?: string[]\n  ): Observable<{ id: string; name: string; manifest: GlobalManifest } | ShareConflict> {\n    return this.store.select(ConfigSelectors.refUrl).pipe(\n      mergeMap((url) => {\n        return this.httpClient.post<\n          | {\n              id: string;\n              description: string;\n              name: string;\n              manifest: GlobalManifest;\n            }\n          | ShareConflict\n        >(encodeURI(`${url}/users/me/dashboards`), {\n          id,\n          name,\n          description,\n          manifest,\n          image,\n          cover,\n          metadata,\n          datasource: ManifestUtils.getDatasourcesUsedByManifest(manifest).map((ds) => ds.datasetId),\n          groups\n        });\n      })\n    );\n  }\n\n  delete(id: string): Observable<void> {\n    return this.store\n      .select(ConfigSelectors.refUrl)\n      .pipe(mergeMap((url) => this.httpClient.delete<void>(encodeURI(`${url}/users/me/dashboards/id/${id}`))));\n  }\n\n  default(id: string): Observable<boolean> {\n    return this.store.select(ConfigSelectors.refUrl).pipe(\n      withLatestFrom(this.store.select(DashboardSelectors.manifestsList)),\n      mergeMap(([url, manifests]) => {\n        const actual = manifests.find((manifest: { id: string }) => manifest.id === id);\n        if (!!actual) {\n          return this.httpClient\n            .put<ArrayBuffer>(encodeURI(`${url}/users/me/dashboards/id/${id}/default`), {})\n            .pipe(map(() => true));\n        } else {\n          return this.httpClient\n            .delete<ArrayBuffer>(encodeURI(`${url}/users/me/dashboards/default`), {})\n            .pipe(map(() => false));\n        }\n      })\n    );\n  }\n\n  addMetadata(presentationId: string, metadataId: string, value: string): Observable<void> {\n    return this.store\n      .select(ConfigSelectors.refUrl)\n      .pipe(\n        mergeMap((url) =>\n          this.httpClient.put<void>(\n            encodeURI(`${url}/users/me/dashboards/id/${presentationId}/metadata/id/${metadataId}`),\n            { value }\n          )\n        )\n      );\n  }\n\n  deleteMetadata(presentationId: string, metadataId: string): Observable<void> {\n    return this.store\n      .select(ConfigSelectors.refUrl)\n      .pipe(\n        mergeMap((url) =>\n          this.httpClient.delete<void>(\n            encodeURI(`${url}/users/me/dashboards/id/${presentationId}/metadata/id/${metadataId}`)\n          )\n        )\n      );\n  }\n}\n"]}
|
|
@@ -13,14 +13,14 @@ import { concatLatestFrom, createEffect, ofType, EffectsModule } from '@ngrx/eff
|
|
|
13
13
|
import * as i1 from '@ngrx/store';
|
|
14
14
|
import { createAction, props, createReducer, on, createFeatureSelector, createSelector, StoreModule } from '@ngrx/store';
|
|
15
15
|
import * as i4 from '@provoly/dashboard';
|
|
16
|
-
import { ClassSelectors, FieldSelectors, FieldType, ClassActions, FieldActions, SubscriptionnerDirective, ConfigSelectors, ConfigActions, DEFAULT_ICON_URL, IconPosition, compareOperationFunctions, ItemUtils, FIELD_OPTIONS, CategoryActions, CategorySelectors, DEFAULT_CATEGORY_UUID, DataSourceActions, DataSourceSelectors, PryDatasetType, ENV_OPTIONS, GeometricFieldTypes, META_OPTIONS, RelationTypesSelectors, RelationTypesActions, BaseMenuComponent, BaseLayoutComponent, PRY_ACCESS_GUARD, PryDialogConfirmComponent, PrySortModule, PryIconModule, PryModalModule, PryI18nModule, PryCoreModule, PrySelectModule, PryToggleModule, PryOverlayModule, PryShareModule } from '@provoly/dashboard';
|
|
16
|
+
import { ClassSelectors, FieldSelectors, FieldType, ClassActions, FieldActions, SubscriptionnerDirective, ConfigSelectors, ConfigActions, DEFAULT_ICON_URL, IconPosition, compareOperationFunctions, ItemUtils, FIELD_OPTIONS, CategoryActions, CategorySelectors, DEFAULT_CATEGORY_UUID, DataSourceActions, DataSourceSelectors, PryDatasetType, ENV_OPTIONS, GeometricFieldTypes, DashboardSelectors, META_OPTIONS, RelationTypesSelectors, RelationTypesActions, BaseMenuComponent, BaseLayoutComponent, PRY_ACCESS_GUARD, PryDialogConfirmComponent, PrySortModule, PryIconModule, PryModalModule, PryI18nModule, PryCoreModule, PrySelectModule, PryToggleModule, PryOverlayModule, PryShareModule } from '@provoly/dashboard';
|
|
17
17
|
import * as i5$1 from '@provoly/dashboard/components/checkbox';
|
|
18
18
|
import { PryCheckboxModule } from '@provoly/dashboard/components/checkbox';
|
|
19
19
|
import * as i6 from '@provoly/dashboard/components/metadata-editor';
|
|
20
20
|
import { MetadataSelectors, MetadataActions, PryExpandPanelModule } from '@provoly/dashboard/components/metadata-editor';
|
|
21
21
|
import * as i2 from '@angular/router';
|
|
22
22
|
import { RouterModule } from '@angular/router';
|
|
23
|
-
import { switchMap, mergeMap, combineLatest, of, map, filter, BehaviorSubject, combineLatestWith, Subscription, distinctUntilChanged as distinctUntilChanged$1, debounceTime, startWith, Subject, zip, takeUntil, catchError,
|
|
23
|
+
import { switchMap, mergeMap, combineLatest, of, map, filter, BehaviorSubject, combineLatestWith, Subscription, distinctUntilChanged as distinctUntilChanged$1, debounceTime, startWith, Subject, zip, withLatestFrom, takeUntil, catchError, tap } from 'rxjs';
|
|
24
24
|
import { v4 } from 'uuid';
|
|
25
25
|
import equal from 'fast-deep-equal/es6';
|
|
26
26
|
import { distinctUntilChanged, map as map$1, filter as filter$1, mergeMap as mergeMap$1, catchError as catchError$1 } from 'rxjs/operators';
|
|
@@ -2766,11 +2766,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
2766
2766
|
|
|
2767
2767
|
class AdminSelectDatasetComponent extends SubscriptionnerDirective {
|
|
2768
2768
|
static { this.id = 'AdminSelectDatasetComponent'; }
|
|
2769
|
-
constructor(store, router, route) {
|
|
2769
|
+
constructor(store, router, route, i18n) {
|
|
2770
2770
|
super();
|
|
2771
2771
|
this.store = store;
|
|
2772
2772
|
this.router = router;
|
|
2773
2773
|
this.route = route;
|
|
2774
|
+
this.i18n = i18n;
|
|
2774
2775
|
this.sub = new Subscription();
|
|
2775
2776
|
this.currentTypeTranslation = '';
|
|
2776
2777
|
this.accessGroups = [];
|
|
@@ -2779,6 +2780,16 @@ class AdminSelectDatasetComponent extends SubscriptionnerDirective {
|
|
|
2779
2780
|
this.datasetMetadata$ = this.store.select(DataSourceSelectors.selectedDatasetMetadata);
|
|
2780
2781
|
this.associations$ = this.store.select(AdminSelectors.selectedAssociation);
|
|
2781
2782
|
this.editable$ = this.store.select(MetadataSelectors.editable);
|
|
2783
|
+
this.missingGroups$ = this.store.select(DataSourceSelectors.selectedDatasetMissingGroups).pipe(withLatestFrom(this.store.select(DashboardSelectors.manifestsList)), map(([conflict, manifests]) => {
|
|
2784
|
+
const result = {};
|
|
2785
|
+
Object.keys(conflict ?? {}).forEach((entityId) => {
|
|
2786
|
+
result[entityId] = {
|
|
2787
|
+
groups: conflict?.[entityId] ?? [],
|
|
2788
|
+
entityName: manifests.find((m) => m.id === entityId)?.name ?? entityId
|
|
2789
|
+
};
|
|
2790
|
+
});
|
|
2791
|
+
return Object.keys(result).length > 0 ? result : undefined;
|
|
2792
|
+
}));
|
|
2782
2793
|
}
|
|
2783
2794
|
ngOnInit() {
|
|
2784
2795
|
this.subscriptions.add(this.selectedDataset$.subscribe((dataset) => {
|
|
@@ -2853,13 +2864,18 @@ class AdminSelectDatasetComponent extends SubscriptionnerDirective {
|
|
|
2853
2864
|
share(dataset) {
|
|
2854
2865
|
this.store.dispatch(DataSourceActions.dataset.update({ dataset: { ...dataset, groups: this.accessGroups }, route: '' }));
|
|
2855
2866
|
}
|
|
2856
|
-
|
|
2857
|
-
|
|
2867
|
+
getGroupLabel(groupName) {
|
|
2868
|
+
const i18nBase = '@pry.components.chipsSelector.share.groups.';
|
|
2869
|
+
const label = this.i18n.instant(i18nBase + groupName);
|
|
2870
|
+
return label.startsWith(i18nBase) ? groupName : label;
|
|
2871
|
+
}
|
|
2872
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: AdminSelectDatasetComponent, deps: [{ token: i1.Store }, { token: i2.Router }, { token: i2.ActivatedRoute }, { token: i4.PryI18nService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
2873
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: AdminSelectDatasetComponent, selector: "pry-admin-select-dataset", usesInheritance: true, ngImport: i0, template: "<div\n *ngIf=\"selectedDataset$ | async as dataset\"\n [id]=\"'panel-dataset-' + dataset.id\"\n [attr.aria-labelledby]=\"'button-dataset-' + dataset.id\"\n class=\"o-panel o-pry-admin-dataset-select\"\n>\n <div class=\"o-panel__header\">\n <button type=\"button\" class=\"a-btn a-btn--icon-only\" (click)=\"closePanel()\">\n <span class=\"u-visually-hidden\">{{ '@pry.action.closePanel' | i18n }}</span>\n <pry-icon iconSvg=\"close\"></pry-icon>\n </button>\n\n <h3 class=\"a-h3\">\n {{ '@pry.admin.dataset.details' | i18n }}\n </h3>\n </div>\n\n <pry-tab-group translationStringBase=\"@pry.admin.\">\n <pry-tab [templateRef]=\"datasetMetadata\" name=\"metadata.title\"></pry-tab>\n <pry-tab [templateRef]=\"datasetAssociations\" name=\"classes.associations\"></pry-tab>\n <pry-tab *ngIf=\"dataset.owner\" [templateRef]=\"shareDataset\" name=\"share\"></pry-tab>\n </pry-tab-group>\n\n <ng-template #datasetMetadata>\n <pry-metadata-editor\n [targetId]=\"(selectedDataset$ | async)?.id ?? ''\"\n [isModification]=\"(editable$ | async) ?? false\"\n [metadata]=\"(datasetMetadata$ | async) ?? []\"\n (removeMeta)=\"removeMetadata($event)\"\n (addMeta)=\"addDatasetMetadata($event)\"\n [type]=\"'meta'\"\n ></pry-metadata-editor>\n </ng-template>\n\n <ng-template #datasetAssociations>\n <div *ngIf=\"associations$ | async as associations\" class=\"o-tabs__panels__item__content\">\n <h4 class=\"a-h4\">{{ '@pry.admin.classes.associations' | i18n }}</h4>\n <pry-association [associations]=\"associations\"></pry-association>\n </div>\n </ng-template>\n\n <ng-template #shareDataset>\n <div class=\"o-pry-admin-dataset-select__share\">\n <pry-group-share [ngModel]=\"dataset.groups\" (ngModelChange)=\"accessGroups = $event\"></pry-group-share>\n <button type=\"submit\" class=\"a-btn a-btn--primary u-self-end\" #submit (click)=\"share(dataset)\">\n {{ '@pry.admin.validate' | i18n }}\n </button>\n @if(missingGroups$ | async; as missingGroups) {\n <div class=\"u-display-flex -column\">\n <span>{{ '@pry.admin.dataset.conflict' | i18n }}</span>\n @for(missing of missingGroups | keyvalue; track missing.key) {\n <div>\n {{ '@pry.admin.dataset.entities.dashboard' | i18n }} <strong>{{ missing.value.entityName }}</strong>\n <div class=\"u-display-flex\">\n @for(group of missing.value.groups; track group) {\n <span class=\"a-chip\">{{ getGroupLabel(group) }}</span>\n }\n </div>\n </div>\n }\n </div>\n }\n </div>\n </ng-template>\n</div>\n", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.TabGroupComponent, selector: "pry-tab-group", inputs: ["translationStringBase"] }, { kind: "component", type: i4.TabComponent, selector: "pry-tab", inputs: ["name", "templateRef", "index"] }, { kind: "component", type: i4.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "directive", type: i3$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.PryMetadataEditorComponent, selector: "pry-metadata-editor", inputs: ["isModification", "targetId", "type", "metadata"], outputs: ["addMeta", "removeMeta"] }, { kind: "component", type: i4.PryGroupShareComponent, selector: "pry-group-share" }, { kind: "component", type: PryAssociationComponent, selector: "pry-association", inputs: ["associations"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.KeyValuePipe, name: "keyvalue" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] }); }
|
|
2858
2874
|
}
|
|
2859
2875
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: AdminSelectDatasetComponent, decorators: [{
|
|
2860
2876
|
type: Component,
|
|
2861
|
-
args: [{ selector: 'pry-admin-select-dataset', template: "<div\n *ngIf=\"selectedDataset$ | async as dataset\"\n [id]=\"'panel-dataset-' + dataset.id\"\n [attr.aria-labelledby]=\"'button-dataset-' + dataset.id\"\n class=\"o-panel o-pry-admin-dataset-select\"\n>\n <div class=\"o-panel__header\">\n <button type=\"button\" class=\"a-btn a-btn--icon-only\" (click)=\"closePanel()\">\n <span class=\"u-visually-hidden\">{{ '@pry.action.closePanel' | i18n }}</span>\n <pry-icon iconSvg=\"close\"></pry-icon>\n </button>\n\n <h3 class=\"a-h3\">\n {{ '@pry.admin.dataset.details' | i18n }}\n </h3>\n </div>\n\n <pry-tab-group translationStringBase=\"@pry.admin.\">\n <pry-tab [templateRef]=\"datasetMetadata\" name=\"metadata.title\"></pry-tab>\n <pry-tab [templateRef]=\"datasetAssociations\" name=\"classes.associations\"></pry-tab>\n <pry-tab *ngIf=\"dataset.owner\" [templateRef]=\"shareDataset\" name=\"share\"></pry-tab>\n </pry-tab-group>\n\n <ng-template #datasetMetadata>\n <pry-metadata-editor\n [targetId]=\"(selectedDataset$ | async)?.id ?? ''\"\n [isModification]=\"(editable$ | async) ?? false\"\n [metadata]=\"(datasetMetadata$ | async) ?? []\"\n (removeMeta)=\"removeMetadata($event)\"\n (addMeta)=\"addDatasetMetadata($event)\"\n [type]=\"'meta'\"\n ></pry-metadata-editor>\n </ng-template>\n\n <ng-template #datasetAssociations>\n <div *ngIf=\"associations$ | async as associations\" class=\"o-tabs__panels__item__content\">\n <h4 class=\"a-h4\">{{ '@pry.admin.classes.associations' | i18n }}</h4>\n <pry-association [associations]=\"associations\"></pry-association>\n </div>\n </ng-template>\n\n <ng-template #shareDataset>\n <div class=\"o-pry-admin-dataset-select__share\">\n <pry-group-share [ngModel]=\"dataset.groups\" (ngModelChange)=\"accessGroups = $event\"></pry-group-share>\n <button type=\"submit\" class=\"a-btn a-btn--primary u-self-end\" #submit (click)=\"share(dataset)\">\n {{ '@pry.admin.validate' | i18n }}\n </button>\n </div>\n </ng-template>\n</div>\n" }]
|
|
2862
|
-
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.Router }, { type: i2.ActivatedRoute }] });
|
|
2877
|
+
args: [{ selector: 'pry-admin-select-dataset', template: "<div\n *ngIf=\"selectedDataset$ | async as dataset\"\n [id]=\"'panel-dataset-' + dataset.id\"\n [attr.aria-labelledby]=\"'button-dataset-' + dataset.id\"\n class=\"o-panel o-pry-admin-dataset-select\"\n>\n <div class=\"o-panel__header\">\n <button type=\"button\" class=\"a-btn a-btn--icon-only\" (click)=\"closePanel()\">\n <span class=\"u-visually-hidden\">{{ '@pry.action.closePanel' | i18n }}</span>\n <pry-icon iconSvg=\"close\"></pry-icon>\n </button>\n\n <h3 class=\"a-h3\">\n {{ '@pry.admin.dataset.details' | i18n }}\n </h3>\n </div>\n\n <pry-tab-group translationStringBase=\"@pry.admin.\">\n <pry-tab [templateRef]=\"datasetMetadata\" name=\"metadata.title\"></pry-tab>\n <pry-tab [templateRef]=\"datasetAssociations\" name=\"classes.associations\"></pry-tab>\n <pry-tab *ngIf=\"dataset.owner\" [templateRef]=\"shareDataset\" name=\"share\"></pry-tab>\n </pry-tab-group>\n\n <ng-template #datasetMetadata>\n <pry-metadata-editor\n [targetId]=\"(selectedDataset$ | async)?.id ?? ''\"\n [isModification]=\"(editable$ | async) ?? false\"\n [metadata]=\"(datasetMetadata$ | async) ?? []\"\n (removeMeta)=\"removeMetadata($event)\"\n (addMeta)=\"addDatasetMetadata($event)\"\n [type]=\"'meta'\"\n ></pry-metadata-editor>\n </ng-template>\n\n <ng-template #datasetAssociations>\n <div *ngIf=\"associations$ | async as associations\" class=\"o-tabs__panels__item__content\">\n <h4 class=\"a-h4\">{{ '@pry.admin.classes.associations' | i18n }}</h4>\n <pry-association [associations]=\"associations\"></pry-association>\n </div>\n </ng-template>\n\n <ng-template #shareDataset>\n <div class=\"o-pry-admin-dataset-select__share\">\n <pry-group-share [ngModel]=\"dataset.groups\" (ngModelChange)=\"accessGroups = $event\"></pry-group-share>\n <button type=\"submit\" class=\"a-btn a-btn--primary u-self-end\" #submit (click)=\"share(dataset)\">\n {{ '@pry.admin.validate' | i18n }}\n </button>\n @if(missingGroups$ | async; as missingGroups) {\n <div class=\"u-display-flex -column\">\n <span>{{ '@pry.admin.dataset.conflict' | i18n }}</span>\n @for(missing of missingGroups | keyvalue; track missing.key) {\n <div>\n {{ '@pry.admin.dataset.entities.dashboard' | i18n }} <strong>{{ missing.value.entityName }}</strong>\n <div class=\"u-display-flex\">\n @for(group of missing.value.groups; track group) {\n <span class=\"a-chip\">{{ getGroupLabel(group) }}</span>\n }\n </div>\n </div>\n }\n </div>\n }\n </div>\n </ng-template>\n</div>\n" }]
|
|
2878
|
+
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.Router }, { type: i2.ActivatedRoute }, { type: i4.PryI18nService }] });
|
|
2863
2879
|
|
|
2864
2880
|
class AdminEnvironmentSelectComponent {
|
|
2865
2881
|
static { this.id = 'AdminEnvironmentSelectComponent'; }
|
|
@@ -5946,6 +5962,7 @@ const enTranslations = {
|
|
|
5946
5962
|
dataset: {
|
|
5947
5963
|
delete: 'All versions and associated data will be deleted. Restitutions and presentations using this dataset will no longer display the corresponding data. Do you confirm the deletion?',
|
|
5948
5964
|
title: 'Dataset',
|
|
5965
|
+
details: 'Dataset details',
|
|
5949
5966
|
id: 'Id',
|
|
5950
5967
|
name: 'Name',
|
|
5951
5968
|
oClass: 'Business model',
|
|
@@ -5959,7 +5976,11 @@ const enTranslations = {
|
|
|
5959
5976
|
},
|
|
5960
5977
|
OPEN: 'Open',
|
|
5961
5978
|
CLOSED: 'Closed',
|
|
5962
|
-
MODIFIABLE: 'Modifiable'
|
|
5979
|
+
MODIFIABLE: 'Modifiable',
|
|
5980
|
+
conflict: 'Careful, the following dashboards are shared to groups which can no longer access this datasource:',
|
|
5981
|
+
entities: {
|
|
5982
|
+
dashboard: 'Dashboard'
|
|
5983
|
+
}
|
|
5963
5984
|
},
|
|
5964
5985
|
'abac-rules': {
|
|
5965
5986
|
delete: 'Delete',
|
|
@@ -6329,7 +6350,11 @@ const frTranslations = {
|
|
|
6329
6350
|
},
|
|
6330
6351
|
OPEN: 'Ouvert',
|
|
6331
6352
|
CLOSED: 'Fermé',
|
|
6332
|
-
MODIFIABLE: 'Modifiable'
|
|
6353
|
+
MODIFIABLE: 'Modifiable',
|
|
6354
|
+
conflict: "Attention les tableaux de bord suivant sont partagés à des groupes qui n'auront plus accès aux données :",
|
|
6355
|
+
entities: {
|
|
6356
|
+
dashboard: 'Tableaux de bord'
|
|
6357
|
+
}
|
|
6333
6358
|
},
|
|
6334
6359
|
'abac-rules': {
|
|
6335
6360
|
delete: 'Supprimer',
|
|
@@ -6532,7 +6557,7 @@ const frTranslations = {
|
|
|
6532
6557
|
label: 'Base de stockage',
|
|
6533
6558
|
description: {
|
|
6534
6559
|
POSTGIS: "Ce stockage est conseillé en cas de stockage de données géographique complexes ou dans des systèmes de coordonnées différents de WGS 84. Il est recommandé de ne stocker dans cette base que des modèles métier dont la volumétrie de données estimée (en terme de nombre d'items) n'est pas trop élevée.",
|
|
6535
|
-
ELASTIC:
|
|
6560
|
+
ELASTIC: "Ce stockage est conseillé en cas de forte volumétrie de données prévue pour ce modèle métier (grand nombre d'items). Si vous souhaitez stocker des données géographiques dans ce modèle, des formes simples sont conseillées et le système de coordonnées de référence utilisé doit être WGS 84. Ce système de stockage offre une scalabilité horizontale"
|
|
6536
6561
|
},
|
|
6537
6562
|
options: {
|
|
6538
6563
|
POSTGIS: 'PostGIS',
|
|
@@ -6551,10 +6576,11 @@ const frTranslations = {
|
|
|
6551
6576
|
};
|
|
6552
6577
|
|
|
6553
6578
|
class AdminEffects {
|
|
6554
|
-
constructor(actions$, service, router) {
|
|
6579
|
+
constructor(actions$, service, router, dsService) {
|
|
6555
6580
|
this.actions$ = actions$;
|
|
6556
6581
|
this.service = service;
|
|
6557
6582
|
this.router = router;
|
|
6583
|
+
this.dsService = dsService;
|
|
6558
6584
|
this.routeTo$ = createEffect(() => this.actions$.pipe(ofType(AdminActions.routeTo, DataSourceActions.dataset.created, DataSourceActions.dataset.updated), mergeMap((action) => {
|
|
6559
6585
|
this.router.navigate([action.path], { queryParams: action.params });
|
|
6560
6586
|
return action.path === this.router.url ? [] : [AdminActions.resetActions()];
|
|
@@ -6606,13 +6632,23 @@ class AdminEffects {
|
|
|
6606
6632
|
this.fetchFieldAssociations$ = createEffect(() => this.actions$.pipe(ofType(AdminActions.fetchFieldAssociations), mergeMap((action) => this.service.getFieldAssociations(action.id).pipe(map((association) => AdminActions.fetchAssociationsSuccess({ association })), catchError((error) => [AdminActions.fetchAssociationsFailure({ error: error })])))));
|
|
6607
6633
|
this.fetchDatasetAssociations$ = createEffect(() => this.actions$.pipe(ofType(AdminActions.fetchDatasetAssociations), mergeMap((action) => this.service.getDatasetAssociations(action.id).pipe(map((association) => AdminActions.fetchAssociationsSuccess({ association })), catchError((error) => [AdminActions.fetchAssociationsFailure({ error: error })])))));
|
|
6608
6634
|
this.fetchAttributeAssociations$ = createEffect(() => this.actions$.pipe(ofType(AdminActions.fetchAttributeAssociations), mergeMap((action) => this.service.getAttributeAssociations(action.id).pipe(map((association) => AdminActions.fetchAssociationsSuccess({ association })), catchError((error) => [AdminActions.fetchAssociationsFailure({ error: error })])))));
|
|
6635
|
+
// TODO move this effect into an admin-datasource store (provoly-dashboard#586)
|
|
6636
|
+
this.updateDataset$ = createEffect(() => this.actions$.pipe(ofType(DataSourceActions.dataset.update), switchMap((action) => this.dsService.updateDataset(action.dataset).pipe(mergeMap((conflict) => {
|
|
6637
|
+
let actions = [
|
|
6638
|
+
DataSourceActions.dataset.setMissingGroups({ missingGroups: conflict?.missingGroupsByEntity }),
|
|
6639
|
+
DataSourceActions.dataset.loadDataset()
|
|
6640
|
+
];
|
|
6641
|
+
if (action.route)
|
|
6642
|
+
actions.push(DataSourceActions.dataset.unselectDataset(), AdminActions.routeTo({ path: action.route }));
|
|
6643
|
+
return actions;
|
|
6644
|
+
}))), catchError((error) => [DataSourceActions.dataset.failure({ error })])));
|
|
6609
6645
|
}
|
|
6610
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: AdminEffects, deps: [{ token: i1$2.Actions }, { token: AdminService }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
6646
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: AdminEffects, deps: [{ token: i1$2.Actions }, { token: AdminService }, { token: i2.Router }, { token: i4.DataSourceService }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
6611
6647
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: AdminEffects }); }
|
|
6612
6648
|
}
|
|
6613
6649
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: AdminEffects, decorators: [{
|
|
6614
6650
|
type: Injectable
|
|
6615
|
-
}], ctorParameters: () => [{ type: i1$2.Actions }, { type: AdminService }, { type: i2.Router }] });
|
|
6651
|
+
}], ctorParameters: () => [{ type: i1$2.Actions }, { type: AdminService }, { type: i2.Router }, { type: i4.DataSourceService }] });
|
|
6616
6652
|
|
|
6617
6653
|
class PryAdminModule {
|
|
6618
6654
|
constructor(pryTranslateService) {
|