@provoly/dashboard 1.2.9 → 1.2.11

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.
Files changed (113) hide show
  1. package/admin/admin.module.d.ts +2 -3
  2. package/dataset/components/dataset.component.d.ts +3 -11
  3. package/dataset/dataset.module.d.ts +7 -9
  4. package/dataset/public-api.d.ts +0 -1
  5. package/dataset/style/_o-pry-dataset.scss +3 -72
  6. package/esm2022/admin/admin.module.mjs +1 -5
  7. package/esm2022/dataset/components/dataset-detail/dataset-detail.component.mjs +3 -4
  8. package/esm2022/dataset/components/dataset.component.mjs +8 -33
  9. package/esm2022/dataset/dataset.module.mjs +9 -13
  10. package/esm2022/dataset/public-api.mjs +1 -2
  11. package/esm2022/dataset/style/css.component.mjs +3 -3
  12. package/esm2022/lib/core/components/chips-selector/chips-selector.component.mjs +7 -27
  13. package/esm2022/lib/core/components/chips-selector/chips-selector.module.mjs +21 -0
  14. package/esm2022/lib/core/components/select/select-a11y.service.mjs +5 -4
  15. package/esm2022/lib/core/components/select/select.component.mjs +8 -5
  16. package/esm2022/lib/core/components/select-image/select-image.component.mjs +1 -1
  17. package/esm2022/lib/core/components/share/group-share/group-share.component.mjs +3 -3
  18. package/esm2022/lib/core/components/share/share.module.mjs +8 -12
  19. package/esm2022/lib/core/components/share/share.utils.mjs +4 -4
  20. package/esm2022/lib/core/core.module.mjs +4 -8
  21. package/esm2022/lib/core/i18n/en.translations.mjs +10 -10
  22. package/esm2022/lib/core/i18n/fr.translations.mjs +10 -10
  23. package/esm2022/lib/core/pipes/get-secured-image/get-secured-image.pipe.mjs +21 -0
  24. package/esm2022/lib/core/pipes/since-date/since-date.module.mjs +18 -0
  25. package/esm2022/lib/core/pipes/since-date/since-date.pipe.mjs +55 -0
  26. package/esm2022/lib/core/pipes/translate-id/translate-id.pipe.mjs +108 -0
  27. package/esm2022/lib/core/pipes/translate-item-to-symbol/translate-item-to-symbol.pipe.mjs +21 -0
  28. package/esm2022/lib/core/public-api.mjs +7 -4
  29. package/esm2022/lib/core/store/data-source/datasource-utils.mjs +22 -1
  30. package/esm2022/lib/dashboard/components/widgets/data-widget.component.mjs +2 -2
  31. package/esm2022/lib/dashboard/components/widgets/datasource-selector/datasource-card/datasource-card.component.mjs +60 -0
  32. package/esm2022/lib/dashboard/components/widgets/datasource-selector/datasource-list/datasource-list.component.mjs +95 -0
  33. package/esm2022/lib/dashboard/components/widgets/datasource-selector/datasource-selector.component.mjs +53 -48
  34. package/esm2022/lib/dashboard/components/widgets/header/widget-header.component.mjs +6 -7
  35. package/esm2022/lib/dashboard/components/widgets/public-api.mjs +3 -1
  36. package/esm2022/lib/dashboard/dashboard.module.mjs +19 -7
  37. package/esm2022/lib/dashboard/store/dashboard.effects.mjs +73 -3
  38. package/esm2022/lib/dashboard/store/dashboard.reducers.mjs +2 -45
  39. package/esm2022/lib/dashboard/tooltip/components/default/default.tooltip.component.mjs +2 -2
  40. package/esm2022/pipeline/components/pipeline-details/pipeline-details.component.mjs +2 -3
  41. package/esm2022/pipeline/components/pipeline-list/pipeline-list.component.mjs +2 -3
  42. package/esm2022/pipeline/pipeline.module.mjs +8 -9
  43. package/esm2022/presentation/components/presentation.component.mjs +2 -3
  44. package/esm2022/presentation/presentation.module.mjs +8 -9
  45. package/esm2022/restitution/components/restitution/restitution.component.mjs +4 -4
  46. package/esm2022/restitution/components/restitution-catalog/restitution-catalog.component.mjs +2 -3
  47. package/esm2022/restitution/restitution.module.mjs +2 -3
  48. package/esm2022/restitution/style/css.component.mjs +2 -2
  49. package/esm2022/widgets/widget-map/component/widget-map.component.mjs +2 -2
  50. package/fesm2022/provoly-dashboard-admin.mjs +0 -4
  51. package/fesm2022/provoly-dashboard-admin.mjs.map +1 -1
  52. package/fesm2022/provoly-dashboard-dataset.mjs +30 -87
  53. package/fesm2022/provoly-dashboard-dataset.mjs.map +1 -1
  54. package/fesm2022/provoly-dashboard-pipeline.mjs +17 -19
  55. package/fesm2022/provoly-dashboard-pipeline.mjs.map +1 -1
  56. package/fesm2022/provoly-dashboard-presentation.mjs +8 -10
  57. package/fesm2022/provoly-dashboard-presentation.mjs.map +1 -1
  58. package/fesm2022/provoly-dashboard-restitution.mjs +7 -9
  59. package/fesm2022/provoly-dashboard-restitution.mjs.map +1 -1
  60. package/fesm2022/provoly-dashboard-widgets-widget-map.mjs +1 -1
  61. package/fesm2022/provoly-dashboard-widgets-widget-map.mjs.map +1 -1
  62. package/fesm2022/provoly-dashboard.mjs +3535 -3296
  63. package/fesm2022/provoly-dashboard.mjs.map +1 -1
  64. package/lib/core/components/chips-selector/chips-selector.component.d.ts +1 -6
  65. package/lib/core/components/chips-selector/chips-selector.module.d.ts +11 -0
  66. package/lib/core/components/select/select-a11y.service.d.ts +1 -1
  67. package/lib/core/components/select/select.component.d.ts +2 -1
  68. package/lib/core/components/share/share.module.d.ts +3 -4
  69. package/lib/core/core.module.d.ts +26 -27
  70. package/lib/core/i18n/en.translations.d.ts +9 -9
  71. package/lib/core/i18n/fr.translations.d.ts +9 -9
  72. package/{components/sinceDate/sinceDate.module.d.ts → lib/core/pipes/since-date/since-date.module.d.ts} +3 -2
  73. package/{components/sinceDate/sinceDate.pipe.d.ts → lib/core/pipes/since-date/since-date.pipe.d.ts} +4 -4
  74. package/lib/core/{components → pipes}/translate-id/translate-id.pipe.d.ts +0 -2
  75. package/lib/core/public-api.d.ts +6 -3
  76. package/lib/core/store/data-source/datasource-utils.d.ts +4 -1
  77. package/lib/dashboard/components/widgets/datasource-selector/datasource-card/datasource-card.component.d.ts +24 -0
  78. package/lib/dashboard/components/widgets/datasource-selector/datasource-list/datasource-list.component.d.ts +35 -0
  79. package/lib/dashboard/components/widgets/datasource-selector/datasource-selector.component.d.ts +19 -11
  80. package/lib/dashboard/components/widgets/header/widget-header.component.d.ts +1 -1
  81. package/lib/dashboard/components/widgets/public-api.d.ts +2 -0
  82. package/lib/dashboard/dashboard.module.d.ts +18 -15
  83. package/lib/dashboard/store/dashboard.effects.d.ts +8 -0
  84. package/package.json +37 -43
  85. package/pipeline/pipeline.module.d.ts +3 -4
  86. package/presentation/presentation.module.d.ts +7 -8
  87. package/restitution/components/restitution/restitution.component.d.ts +1 -1
  88. package/restitution/restitution.module.d.ts +1 -2
  89. package/restitution/style/_o-restitution.scss +4 -0
  90. package/styles/components/_a-chip.scss +44 -0
  91. package/styles/components/_o-datasource-selector.scss +192 -0
  92. package/styles/components/_o-widget.scss +1 -1
  93. package/styles/main.scss +1 -0
  94. package/styles-theme/main-theme.scss +0 -3
  95. package/components/sinceDate/index.d.ts +0 -5
  96. package/components/sinceDate/public-api.d.ts +0 -2
  97. package/dataset/components/dataset-card/dataset-card.component.d.ts +0 -18
  98. package/dataset/style/_o-pry-dataset-card.scss +0 -93
  99. package/esm2022/components/sinceDate/provoly-dashboard-components-sinceDate.mjs +0 -5
  100. package/esm2022/components/sinceDate/public-api.mjs +0 -3
  101. package/esm2022/components/sinceDate/sinceDate.module.mjs +0 -16
  102. package/esm2022/components/sinceDate/sinceDate.pipe.mjs +0 -55
  103. package/esm2022/dataset/components/dataset-card/dataset-card.component.mjs +0 -41
  104. package/esm2022/lib/core/components/get-secured-image/get-secured-image.pipe.mjs +0 -21
  105. package/esm2022/lib/core/components/translate-id/translate-id.pipe.mjs +0 -114
  106. package/esm2022/lib/core/components/translate-item-to-symbol/translate-item-to-symbol.pipe.mjs +0 -23
  107. package/fesm2022/provoly-dashboard-components-sinceDate.mjs +0 -75
  108. package/fesm2022/provoly-dashboard-components-sinceDate.mjs.map +0 -1
  109. package/styles-theme/components-theme/_a-chip.theme.scss +0 -32
  110. package/styles-theme/components-theme/_o-pry-dataset-card.theme.scss +0 -26
  111. package/styles-theme/components-theme/_o-pry-dataset.theme.scss +0 -4
  112. /package/lib/core/{components → pipes}/get-secured-image/get-secured-image.pipe.d.ts +0 -0
  113. /package/lib/core/{components → pipes}/translate-item-to-symbol/translate-item-to-symbol.pipe.d.ts +0 -0
@@ -1,11 +1,11 @@
1
1
  import { Component, Input } from '@angular/core';
2
2
  import equal from 'fast-deep-equal/es6';
3
3
  import { BehaviorSubject, combineLatest, distinctUntilChanged, filter, map, Subject } from 'rxjs';
4
- import { UNKNOWN_DATASOURCE } from '../../../core/components/translate-id/translate-id.pipe';
5
4
  import { DataSourceSelectors } from '../../../core/store/data-source/data-source.selectors';
6
5
  import { ResultsetUtils } from '../../resultset-utils';
7
6
  import { DashboardSelectors } from '../../store/dashboard.selectors';
8
7
  import { BaseWidgetComponent } from './base-widget.component';
8
+ import { UNKNOWN_DATASOURCE } from '../../../core/store/data-source/datasource-utils';
9
9
  import * as i0 from "@angular/core";
10
10
  import * as i1 from "@ngrx/store";
11
11
  export class DataWidgetComponent extends BaseWidgetComponent {
@@ -58,4 +58,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
58
58
  }], staticResultSet: [{
59
59
  type: Input
60
60
  }] } });
61
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-widget.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/dashboard/lib/dashboard/components/widgets/data-widget.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport equal from 'fast-deep-equal/es6';\nimport { BehaviorSubject, combineLatest, distinctUntilChanged, filter, map, Observable, Subject } from 'rxjs';\nimport { UNKNOWN_DATASOURCE } from '../../../core/components/translate-id/translate-id.pipe';\nimport { Item } from '../../../core/model/item.interface';\nimport { ResultSet } from '../../../core/model/result-set.interface';\nimport { DataSource } from '../../../core/store/data-source/data-source.model';\nimport { DataSourceSelectors } from '../../../core/store/data-source/data-source.selectors';\nimport { ResultsetUtils } from '../../resultset-utils';\nimport { DashboardSelectors } from '../../store/dashboard.selectors';\nimport { BaseWidgetComponent } from './base-widget.component';\n\n@Component({ selector: 'pry-data-widget', template: '' })\nexport class DataWidgetComponent extends BaseWidgetComponent {\n  resultSet$: Observable<ResultSet>;\n  staticResultSet$ = new BehaviorSubject<ResultSet | null>(null);\n  datasourceIds$: Observable<string[]>;\n  allItems$: Observable<Item[]>;\n  usedDatasources$: Observable<DataSource[]>;\n\n  @Input() openData$: Observable<void> | Subject<void> = new Subject<void>();\n  @Input() set staticResultSet(resultSet: ResultSet) {\n    this.staticResultSet$.next(resultSet);\n  }\n\n  constructor(store: Store<any>, el: ElementRef) {\n    super(store, el);\n    this.datasourceIds$ = this.manifest$.pipe(\n      map(\n        (manifest) =>\n          (Array.isArray(manifest.datasource) ? manifest.datasource : [manifest.datasource]).filter(\n            (id) => !!id\n          ) as string[]\n      )\n    );\n    this.usedDatasources$ = combineLatest([\n      this.datasourceIds$,\n      this.store.select(DataSourceSelectors.getDataSources)\n    ]).pipe(\n      map(\n        ([ids, datasources]) =>\n          ids\n            .map((id) => datasources.find((ds) => ds.id === id) ?? id)\n            .map((nq) => (typeof nq !== 'string' ? nq : UNKNOWN_DATASOURCE(nq))) as DataSource[]\n      )\n    );\n    this.resultSet$ = this.initResultSet$();\n\n    this.allItems$ = this.resultSet$.pipe(\n      filter((resultSet) => !!resultSet),\n      map(\n        (resultSet) =>\n          Object.keys(resultSet?.items)\n            .map((classId) => resultSet.items[classId])\n            .reduce((prev, curr) => [...prev, ...curr], []) as Item[]\n      )\n    );\n  }\n\n  initResultSet$() {\n    return combineLatest([\n      this.store.select(DashboardSelectors.resultSets),\n      this.datasourceIds$,\n      this.staticResultSet$\n    ]).pipe(\n      map(([resultSets, resultSetNamesArray, staticResultSet]) => {\n        if (!!staticResultSet) {\n          return staticResultSet;\n        }\n        const resultSetArray = resultSetNamesArray\n          .map((rsName) => resultSets[rsName ?? ''])\n          .filter((rsName) => !!rsName);\n        return resultSetArray.reduce((rs1, rs2) => ResultsetUtils.mergeResultSets(rs1, rs2), {\n          items: {},\n          relations: [],\n          merged: resultSetArray.length\n        });\n      }),\n      distinctUntilChanged((p, v) => equal(p, v))\n    );\n  }\n}\n"]}
61
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-widget.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/dashboard/lib/dashboard/components/widgets/data-widget.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport equal from 'fast-deep-equal/es6';\nimport { BehaviorSubject, combineLatest, distinctUntilChanged, filter, map, Observable, Subject } from 'rxjs';\nimport { Item } from '../../../core/model/item.interface';\nimport { ResultSet } from '../../../core/model/result-set.interface';\nimport { DataSource } from '../../../core/store/data-source/data-source.model';\nimport { DataSourceSelectors } from '../../../core/store/data-source/data-source.selectors';\nimport { ResultsetUtils } from '../../resultset-utils';\nimport { DashboardSelectors } from '../../store/dashboard.selectors';\nimport { BaseWidgetComponent } from './base-widget.component';\nimport { UNKNOWN_DATASOURCE } from '../../../core/store/data-source/datasource-utils';\n\n@Component({ selector: 'pry-data-widget', template: '' })\nexport class DataWidgetComponent extends BaseWidgetComponent {\n  resultSet$: Observable<ResultSet>;\n  staticResultSet$ = new BehaviorSubject<ResultSet | null>(null);\n  datasourceIds$: Observable<string[]>;\n  allItems$: Observable<Item[]>;\n  usedDatasources$: Observable<DataSource[]>;\n\n  @Input() openData$: Observable<void> | Subject<void> = new Subject<void>();\n  @Input() set staticResultSet(resultSet: ResultSet) {\n    this.staticResultSet$.next(resultSet);\n  }\n\n  constructor(store: Store<any>, el: ElementRef) {\n    super(store, el);\n    this.datasourceIds$ = this.manifest$.pipe(\n      map(\n        (manifest) =>\n          (Array.isArray(manifest.datasource) ? manifest.datasource : [manifest.datasource]).filter(\n            (id) => !!id\n          ) as string[]\n      )\n    );\n    this.usedDatasources$ = combineLatest([\n      this.datasourceIds$,\n      this.store.select(DataSourceSelectors.getDataSources)\n    ]).pipe(\n      map(\n        ([ids, datasources]) =>\n          ids\n            .map((id) => datasources.find((ds) => ds.id === id) ?? id)\n            .map((nq) => (typeof nq !== 'string' ? nq : UNKNOWN_DATASOURCE(nq))) as DataSource[]\n      )\n    );\n    this.resultSet$ = this.initResultSet$();\n\n    this.allItems$ = this.resultSet$.pipe(\n      filter((resultSet) => !!resultSet),\n      map(\n        (resultSet) =>\n          Object.keys(resultSet?.items)\n            .map((classId) => resultSet.items[classId])\n            .reduce((prev, curr) => [...prev, ...curr], []) as Item[]\n      )\n    );\n  }\n\n  initResultSet$() {\n    return combineLatest([\n      this.store.select(DashboardSelectors.resultSets),\n      this.datasourceIds$,\n      this.staticResultSet$\n    ]).pipe(\n      map(([resultSets, resultSetNamesArray, staticResultSet]) => {\n        if (!!staticResultSet) {\n          return staticResultSet;\n        }\n        const resultSetArray = resultSetNamesArray\n          .map((rsName) => resultSets[rsName ?? ''])\n          .filter((rsName) => !!rsName);\n        return resultSetArray.reduce((rs1, rs2) => ResultsetUtils.mergeResultSets(rs1, rs2), {\n          items: {},\n          relations: [],\n          merged: resultSetArray.length\n        });\n      }),\n      distinctUntilChanged((p, v) => equal(p, v))\n    );\n  }\n}\n"]}
@@ -0,0 +1,60 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { DataSourceSelectors } from '../../../../../core/store/data-source/data-source.selectors';
3
+ import { map } from 'rxjs';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@ngrx/store";
6
+ import * as i2 from "@angular/forms";
7
+ import * as i3 from "../../../../../core/components/icon/icon.component";
8
+ import * as i4 from "../../../../../core/components/ellipsis.directive";
9
+ import * as i5 from "@provoly/dashboard/components/checkbox";
10
+ import * as i6 from "@angular/common";
11
+ import * as i7 from "../../../../../core/pipes/translate-id/translate-id.pipe";
12
+ import * as i8 from "../../../../../core/i18n/i18n.pipe";
13
+ import * as i9 from "../../../../../core/pipes/since-date/since-date.pipe";
14
+ export class PryDatasourceCardComponent {
15
+ constructor(store) {
16
+ this.store = store;
17
+ this.showFooter = false;
18
+ this.isSelectable = false;
19
+ this.isSelected = false;
20
+ this.clicked = new EventEmitter();
21
+ }
22
+ ngAfterContentInit() {
23
+ this.datasetVersions$ = this.store
24
+ .select(DataSourceSelectors.matchingDatasetVersions(this.datasource.id))
25
+ .pipe(map((res) => [...res].sort((a, b) => b.version - a.version)));
26
+ this.activeVersion$ = this.datasetVersions$.pipe(map((versions) => versions.sort((v1, v2) => v2.version - v1.version).find((version) => version.state === 'ACTIVE')?.lastModified));
27
+ }
28
+ truncateDescription(description, maxLength) {
29
+ if (description && description.length > maxLength) {
30
+ return description.slice(0, maxLength) + '...';
31
+ }
32
+ return description;
33
+ }
34
+ onClick() {
35
+ if (this.isSelectable) {
36
+ this.isSelected = !this.isSelected;
37
+ this.clicked.emit({ isSelected: this.isSelected, datasource: this.datasource });
38
+ }
39
+ else {
40
+ this.clicked.emit({ isSelected: false, datasource: this.datasource });
41
+ }
42
+ }
43
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: PryDatasourceCardComponent, deps: [{ token: i1.Store }], target: i0.ɵɵFactoryTarget.Component }); }
44
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: PryDatasourceCardComponent, selector: "pry-datasource-card", inputs: { datasource: "datasource", showFooter: "showFooter", isSelectable: "isSelectable", isSelected: "isSelected" }, outputs: { clicked: "clicked" }, ngImport: i0, template: "<div\n class=\"o-datasource-card\"\n [class.-no-footer]=\"!showFooter\"\n [class.-is-selectable]=\"isSelectable\"\n (click)=\"onClick()\"\n>\n <div class=\"o-datasource-card__header\">\n <img\n alt=\"\"\n [height]=\"25\"\n [width]=\"25\"\n [src]=\"datasource.id | translateId: { type: 'datasource', output: 'icon' } | async\"\n />\n <div class=\"o-datasource-card__title\" ellipsis textElementSelector=\".a-h4\">\n <h4 class=\"a-h4\">{{ datasource.name }}</h4>\n </div>\n @if (isSelectable) {\n <pry-checkbox\n (click)=\"$event.preventDefault()\"\n class=\"o-datasource-card__checkbox\"\n [ngModel]=\"isSelected\"\n ></pry-checkbox>\n }\n </div>\n <div class=\"o-datasource-card__content u-display-flex -column -gap-10\">\n @if (datasource.description) {\n <div class=\"o-datasource-card__description\" ellipsis textElementSelector=\".description\">\n <div class=\"description\">{{ truncateDescription(datasource.description, 100) }}</div>\n </div>\n } @else {\n <div class=\"o-datasource-card__description -italic\">{{ '@pry.dataset.noDescription' | i18n }}</div>\n }\n\n <span class=\"o-datasource-card__date\">\n @if (activeVersion$ | async) {\n {{ '@pry.dataset.since_day' | i18n }} {{ (activeVersion$ | async)! | sinceDate }}\n } @else {\n <span class=\"-italic\">{{ '@pry.dataset.noActiveVersion' | i18n }}</span>\n }\n </span>\n @if (datasource.sourceType === 'dataset' && datasource.categories && datasource.categories.length > 0) {\n <div class=\"o-datasource-card__categories u-display-flex -wrap\">\n @for (category of datasource.categories; track category.id) {\n <span class=\"a-chip -md\">{{ category.name }}</span>\n }\n </div>\n }\n </div>\n\n @if (showFooter) {\n <div class=\"o-datasource-card__footer\">\n <button class=\"a-btn\">\n {{ '@pry.dataset.consult' | i18n }}\n <pry-icon [width]=\"20\" [height]=\"20\" iconSvg=\"arrow_right\"></pry-icon>\n </button>\n </div>\n }\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "directive", type: i4.EllipsisDirective, selector: "[ellipsis]", inputs: ["textElementSelector"] }, { kind: "component", type: i5.PryCheckboxComponent, selector: "pry-checkbox", inputs: ["circle"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.TranslateIdPipe, name: "translateId" }, { kind: "pipe", type: i8.I18nPipe, name: "i18n" }, { kind: "pipe", type: i9.SinceDatePipe, name: "sinceDate" }] }); }
45
+ }
46
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: PryDatasourceCardComponent, decorators: [{
47
+ type: Component,
48
+ args: [{ selector: 'pry-datasource-card', template: "<div\n class=\"o-datasource-card\"\n [class.-no-footer]=\"!showFooter\"\n [class.-is-selectable]=\"isSelectable\"\n (click)=\"onClick()\"\n>\n <div class=\"o-datasource-card__header\">\n <img\n alt=\"\"\n [height]=\"25\"\n [width]=\"25\"\n [src]=\"datasource.id | translateId: { type: 'datasource', output: 'icon' } | async\"\n />\n <div class=\"o-datasource-card__title\" ellipsis textElementSelector=\".a-h4\">\n <h4 class=\"a-h4\">{{ datasource.name }}</h4>\n </div>\n @if (isSelectable) {\n <pry-checkbox\n (click)=\"$event.preventDefault()\"\n class=\"o-datasource-card__checkbox\"\n [ngModel]=\"isSelected\"\n ></pry-checkbox>\n }\n </div>\n <div class=\"o-datasource-card__content u-display-flex -column -gap-10\">\n @if (datasource.description) {\n <div class=\"o-datasource-card__description\" ellipsis textElementSelector=\".description\">\n <div class=\"description\">{{ truncateDescription(datasource.description, 100) }}</div>\n </div>\n } @else {\n <div class=\"o-datasource-card__description -italic\">{{ '@pry.dataset.noDescription' | i18n }}</div>\n }\n\n <span class=\"o-datasource-card__date\">\n @if (activeVersion$ | async) {\n {{ '@pry.dataset.since_day' | i18n }} {{ (activeVersion$ | async)! | sinceDate }}\n } @else {\n <span class=\"-italic\">{{ '@pry.dataset.noActiveVersion' | i18n }}</span>\n }\n </span>\n @if (datasource.sourceType === 'dataset' && datasource.categories && datasource.categories.length > 0) {\n <div class=\"o-datasource-card__categories u-display-flex -wrap\">\n @for (category of datasource.categories; track category.id) {\n <span class=\"a-chip -md\">{{ category.name }}</span>\n }\n </div>\n }\n </div>\n\n @if (showFooter) {\n <div class=\"o-datasource-card__footer\">\n <button class=\"a-btn\">\n {{ '@pry.dataset.consult' | i18n }}\n <pry-icon [width]=\"20\" [height]=\"20\" iconSvg=\"arrow_right\"></pry-icon>\n </button>\n </div>\n }\n</div>\n" }]
49
+ }], ctorParameters: () => [{ type: i1.Store }], propDecorators: { datasource: [{
50
+ type: Input
51
+ }], showFooter: [{
52
+ type: Input
53
+ }], isSelectable: [{
54
+ type: Input
55
+ }], isSelected: [{
56
+ type: Input
57
+ }], clicked: [{
58
+ type: Output
59
+ }] } });
60
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datasource-card.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/provoly/dashboard/lib/dashboard/components/widgets/datasource-selector/datasource-card/datasource-card.component.ts","../../../../../../../../../../projects/provoly/dashboard/lib/dashboard/components/widgets/datasource-selector/datasource-card/datasource-card.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAoB,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEzF,OAAO,EAAE,mBAAmB,EAAE,MAAM,6DAA6D,CAAC;AAElG,OAAO,EAAE,GAAG,EAAc,MAAM,MAAM,CAAC;;;;;;;;;;;AAOvC,MAAM,OAAO,0BAA0B;IAWrC,YAAoB,KAAY;QAAZ,UAAK,GAAL,KAAK,CAAO;QATvB,eAAU,GAAY,KAAK,CAAC;QAC5B,iBAAY,GAAY,KAAK,CAAC;QAC9B,eAAU,GAAY,KAAK,CAAC;QAE3B,YAAO,GAAG,IAAI,YAAY,EAAoD,CAAC;IAKtD,CAAC;IAEpC,kBAAkB;QAChB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,KAAK;aAC/B,MAAM,CAAC,mBAAmB,CAAC,uBAAuB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;aACvE,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QACtE,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAC9C,GAAG,CACD,CAAC,QAAQ,EAAE,EAAE,CACX,QAAQ,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,OAAO,GAAG,EAAE,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,KAAK,QAAQ,CAAC,EAAE,YAAY,CACjH,CACF,CAAC;IACJ,CAAC;IAED,mBAAmB,CAAC,WAA+B,EAAE,SAAiB;QACpE,IAAI,WAAW,IAAI,WAAW,CAAC,MAAM,GAAG,SAAS,EAAE,CAAC;YAClD,OAAO,WAAW,CAAC,KAAK,CAAC,CAAC,EAAE,SAAS,CAAC,GAAG,KAAK,CAAC;QACjD,CAAC;QACD,OAAe,WAAW,CAAC;IAC7B,CAAC;IAED,OAAO;QACL,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACtB,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC;YACnC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;QAClF,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,KAAK,EAAE,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;QACxE,CAAC;IACH,CAAC;8GAvCU,0BAA0B;kGAA1B,0BAA0B,oNCXvC,0kEA0DA;;2FD/Ca,0BAA0B;kBAJtC,SAAS;+BACE,qBAAqB;0EAItB,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAEI,OAAO;sBAAhB,MAAM","sourcesContent":["import { AfterContentInit, Component, EventEmitter, Input, Output } from '@angular/core';\nimport { DataSource, DatasetVersion } from '../../../../../core/store/data-source/data-source.model';\nimport { DataSourceSelectors } from '../../../../../core/store/data-source/data-source.selectors';\n\nimport { map, Observable } from 'rxjs';\nimport { Store } from '@ngrx/store';\n\n@Component({\n  selector: 'pry-datasource-card',\n  templateUrl: './datasource-card.component.html'\n})\nexport class PryDatasourceCardComponent implements AfterContentInit {\n  @Input() datasource!: DataSource;\n  @Input() showFooter: boolean = false;\n  @Input() isSelectable: boolean = false;\n  @Input() isSelected: boolean = false;\n\n  @Output() clicked = new EventEmitter<{ datasource: DataSource; isSelected: boolean; }>();\n\n  datasetVersions$!: Observable<DatasetVersion[]>;\n  activeVersion$!: Observable<string | undefined>;\n\n  constructor(private store: Store) {}\n\n  ngAfterContentInit() {\n    this.datasetVersions$ = this.store\n      .select(DataSourceSelectors.matchingDatasetVersions(this.datasource.id))\n      .pipe(map((res) => [...res].sort((a, b) => b.version - a.version)));\n    this.activeVersion$ = this.datasetVersions$.pipe(\n      map(\n        (versions) =>\n          versions.sort((v1, v2) => v2.version - v1.version).find((version) => version.state === 'ACTIVE')?.lastModified\n      )\n    );\n  }\n\n  truncateDescription(description: string | undefined, maxLength: number): string {\n    if (description && description.length > maxLength) {\n      return description.slice(0, maxLength) + '...';\n    }\n    return <string>description;\n  }\n\n  onClick() {\n    if (this.isSelectable) {\n      this.isSelected = !this.isSelected;\n      this.clicked.emit({ isSelected: this.isSelected, datasource: this.datasource });\n    } else {\n      this.clicked.emit({ isSelected: false, datasource: this.datasource });\n    }\n  }\n}\n","<div\n  class=\"o-datasource-card\"\n  [class.-no-footer]=\"!showFooter\"\n  [class.-is-selectable]=\"isSelectable\"\n  (click)=\"onClick()\"\n>\n  <div class=\"o-datasource-card__header\">\n    <img\n      alt=\"\"\n      [height]=\"25\"\n      [width]=\"25\"\n      [src]=\"datasource.id | translateId: { type: 'datasource', output: 'icon' } | async\"\n    />\n    <div class=\"o-datasource-card__title\" ellipsis textElementSelector=\".a-h4\">\n      <h4 class=\"a-h4\">{{ datasource.name }}</h4>\n    </div>\n    @if (isSelectable) {\n      <pry-checkbox\n        (click)=\"$event.preventDefault()\"\n        class=\"o-datasource-card__checkbox\"\n        [ngModel]=\"isSelected\"\n      ></pry-checkbox>\n    }\n  </div>\n  <div class=\"o-datasource-card__content u-display-flex -column -gap-10\">\n    @if (datasource.description) {\n      <div class=\"o-datasource-card__description\" ellipsis textElementSelector=\".description\">\n        <div class=\"description\">{{ truncateDescription(datasource.description, 100) }}</div>\n      </div>\n    } @else {\n      <div class=\"o-datasource-card__description -italic\">{{ '@pry.dataset.noDescription' | i18n }}</div>\n    }\n\n    <span class=\"o-datasource-card__date\">\n      @if (activeVersion$ | async) {\n        {{ '@pry.dataset.since_day' | i18n }} {{ (activeVersion$ | async)! | sinceDate }}\n      } @else {\n        <span class=\"-italic\">{{ '@pry.dataset.noActiveVersion' | i18n }}</span>\n      }\n    </span>\n    @if (datasource.sourceType === 'dataset' && datasource.categories && datasource.categories.length > 0) {\n      <div class=\"o-datasource-card__categories u-display-flex -wrap\">\n        @for (category of datasource.categories; track category.id) {\n          <span class=\"a-chip -md\">{{ category.name }}</span>\n        }\n      </div>\n    }\n  </div>\n\n  @if (showFooter) {\n    <div class=\"o-datasource-card__footer\">\n      <button class=\"a-btn\">\n        {{ '@pry.dataset.consult' | i18n }}\n        <pry-icon [width]=\"20\" [height]=\"20\" iconSvg=\"arrow_right\"></pry-icon>\n      </button>\n    </div>\n  }\n</div>\n"]}
@@ -0,0 +1,95 @@
1
+ import { BehaviorSubject, combineLatest, map } from 'rxjs';
2
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
3
+ import { DataSourceActions } from '../../../../../core/store/data-source/data-source.actions';
4
+ import { DataSourceSelectors } from '../../../../../core/store/data-source/data-source.selectors';
5
+ import { DashboardActions } from '../../../../store/dashboard.actions';
6
+ import { SubscriptionnerDirective } from '../../../subscriptionner.directive';
7
+ import { DatasourceUtils } from '../../../../../core/store/data-source/datasource-utils';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@ngrx/store";
10
+ import * as i2 from "@angular/forms";
11
+ import * as i3 from "../../../../../core/components/select/select.component";
12
+ import * as i4 from "../../../../../core/components/icon/icon.component";
13
+ import * as i5 from "../datasource-card/datasource-card.component";
14
+ import * as i6 from "@angular/common";
15
+ import * as i7 from "../../../../../core/i18n/i18n.pipe";
16
+ export class PryDatasourceListComponent extends SubscriptionnerDirective {
17
+ set mode(mode) {
18
+ this._mode$.next(mode);
19
+ }
20
+ ;
21
+ set selectedDatasources(datasourceIds) {
22
+ this.selectedDatasources$.next(datasourceIds);
23
+ }
24
+ constructor(store) {
25
+ super();
26
+ this.store = store;
27
+ this.search$ = new BehaviorSubject('');
28
+ this.selectedCategories = [];
29
+ this.selectedCategories$ = new BehaviorSubject([]);
30
+ this.selectedDatasources$ = new BehaviorSubject([]);
31
+ this._mode$ = new BehaviorSubject('list');
32
+ this.consultedDataset = new EventEmitter();
33
+ this.datasourceSelected = new EventEmitter();
34
+ this.store.dispatch(DataSourceActions.load());
35
+ this.datasources$ = combineLatest([
36
+ this.store.select(DataSourceSelectors.getDataSourcesSorted),
37
+ this.selectedDatasources$
38
+ ]).pipe(map(([datasources, selectedDatasources]) => DatasourceUtils.getAllDatasourcesWithUnknowns(datasources, selectedDatasources)));
39
+ this.datasets$ = this.store.select(DataSourceSelectors.datasets);
40
+ this.store.dispatch(DashboardActions.fetchManifestsList());
41
+ this.store.dispatch(DataSourceActions.dataset.getCategories());
42
+ this.categories$ = this.store.select(DataSourceSelectors.categories);
43
+ this.store.dispatch(DataSourceActions.dataset.listVersions());
44
+ }
45
+ ngOnInit() {
46
+ this.filteredDatasources$ = combineLatest([
47
+ this._mode$,
48
+ this.search$,
49
+ this.selectedCategories$,
50
+ this.selectedDatasources$,
51
+ this.datasources$,
52
+ this.datasets$
53
+ ]).pipe(map(([mode, query, selectedCategories, selectedDs, datasources, datasets]) => mode === 'list' ? this.search(datasets, query, selectedCategories)
54
+ : this.search(datasources, query, selectedCategories)
55
+ .map((dataset) => ({ ...dataset, isSelected: selectedDs.includes(dataset.id) }))
56
+ .sort((a, b) => Number(b.isSelected) - Number(a.isSelected))));
57
+ }
58
+ search(datasets, search, categories) {
59
+ return datasets
60
+ .filter((dataset) => (search.length === 0 || dataset.name.toLowerCase().includes(search.toLowerCase())) &&
61
+ (categories.length === 0 || this.doesDatasourceMatchCategoryFilter(dataset, categories)))
62
+ .sort((a, b) => a.name.localeCompare(b.name));
63
+ }
64
+ doesDatasourceMatchCategoryFilter(datasource, selectedCategories) {
65
+ return datasource.sourceType === 'dataset' && datasource.categories
66
+ ? selectedCategories.reduce((acc, selectedCat) => acc && datasource.categories.map((cat) => cat.id).includes(selectedCat.id), true)
67
+ : false;
68
+ }
69
+ onDatasourceClick({ isSelected, datasource }) {
70
+ if (this._mode$.value === 'list') {
71
+ this.consultedDataset.emit(datasource);
72
+ }
73
+ else {
74
+ this.selectedDatasources$.next(isSelected
75
+ ? [...this.selectedDatasources$.value, datasource.id]
76
+ : this.selectedDatasources$.value.filter((id) => id !== datasource.id));
77
+ this.datasourceSelected.emit(this.selectedDatasources$.value);
78
+ }
79
+ }
80
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: PryDatasourceListComponent, deps: [{ token: i1.Store }], target: i0.ɵɵFactoryTarget.Component }); }
81
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: PryDatasourceListComponent, selector: "pry-datasource-list", inputs: { mode: "mode", selectedDatasources: "selectedDatasources" }, outputs: { consultedDataset: "consultedDataset", datasourceSelected: "datasourceSelected" }, usesInheritance: true, ngImport: i0, template: "<div class=\"o-datasource-list__header u-display-flex\">\n <div class=\"o-datasource-list__search m-form-label-field\">\n <label class=\"a-label\" id=\"catalog-search-label\" for=\"catalog-search\">{{ '@pry.dataset.search' | i18n }}</label>\n <input\n id=\"catalog-search\"\n type=\"text\"\n class=\"a-form-field\"\n [placeholder]=\"'@pry.dataset.searchPlaceholder' | i18n\"\n [ngModel]=\"search$ | async\"\n (ngModelChange)=\"this.search$.next($event)\"\n />\n <pry-icon class=\"search-icon\" iconSvg=\"search\" [width]=\"20\" [height]=\"20\"></pry-icon>\n </div>\n <div class=\"o-datasource-list__categories m-form-label-field\">\n <label class=\"a-label\" id=\"tags-label\" for=\"catalog-category-search\">{{ '@pry.dataset.filter' | i18n }}</label>\n <pry-select\n id=\"catalog-category-search\"\n [ngModel]=\"selectedCategories\"\n (ngModelChange)=\"this.selectedCategories$.next($event)\"\n [items]=\"categories$ | async\"\n bindLabel=\"name\"\n aria-labelledby=\"tags-label\"\n [multiple]=\"true\"\n [closeOnSelect]=\"false\"\n [placeholder]=\"'@pry.dataset.filterPlaceholder' | i18n\"\n ></pry-select>\n </div>\n</div>\n<div class=\"o-datasource-list__content\">\n @if ((_mode$ | async) === 'list') {\n @for (datasource of filteredDatasources$ | async; track datasource.id) {\n <pry-datasource-card\n [datasource]=\"datasource\"\n [isSelectable]=\"false\"\n [showFooter]=\"true\"\n (clicked)=\"onDatasourceClick($event)\"\n ></pry-datasource-card>\n }\n } @else if ((_mode$ | async) === 'selector') {\n @for (datasource of filteredDatasources$ | async; track datasource.id) {\n <pry-datasource-card\n [datasource]=\"datasource\"\n [isSelectable]=\"true\"\n [showFooter]=\"false\"\n (clicked)=\"onDatasourceClick($event)\"\n [isSelected]=\"datasource.isSelected ?? false\"\n ></pry-datasource-card>\n }\n }\n</div>\n", dependencies: [{ kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.PrySelectComponent, selector: "pry-select", inputs: ["items", "clearable", "multiple", "closeOnSelect", "placeholder", "isForm", "required", "name", "readonly", "autocomplete", "alwaysShowAutosuggestedValues", "externalAutocompleteService", "bindValue", "bindLabel", "iconSize", "bindIcon", "template", "i18nPrefix", "bindClasses", "loading", "elementRef"], outputs: ["searched", "cleared", "clicked"] }, { kind: "component", type: i4.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "component", type: i5.PryDatasourceCardComponent, selector: "pry-datasource-card", inputs: ["datasource", "showFooter", "isSelectable", "isSelected"], outputs: ["clicked"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i7.I18nPipe, name: "i18n" }] }); }
82
+ }
83
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: PryDatasourceListComponent, decorators: [{
84
+ type: Component,
85
+ args: [{ selector: 'pry-datasource-list', template: "<div class=\"o-datasource-list__header u-display-flex\">\n <div class=\"o-datasource-list__search m-form-label-field\">\n <label class=\"a-label\" id=\"catalog-search-label\" for=\"catalog-search\">{{ '@pry.dataset.search' | i18n }}</label>\n <input\n id=\"catalog-search\"\n type=\"text\"\n class=\"a-form-field\"\n [placeholder]=\"'@pry.dataset.searchPlaceholder' | i18n\"\n [ngModel]=\"search$ | async\"\n (ngModelChange)=\"this.search$.next($event)\"\n />\n <pry-icon class=\"search-icon\" iconSvg=\"search\" [width]=\"20\" [height]=\"20\"></pry-icon>\n </div>\n <div class=\"o-datasource-list__categories m-form-label-field\">\n <label class=\"a-label\" id=\"tags-label\" for=\"catalog-category-search\">{{ '@pry.dataset.filter' | i18n }}</label>\n <pry-select\n id=\"catalog-category-search\"\n [ngModel]=\"selectedCategories\"\n (ngModelChange)=\"this.selectedCategories$.next($event)\"\n [items]=\"categories$ | async\"\n bindLabel=\"name\"\n aria-labelledby=\"tags-label\"\n [multiple]=\"true\"\n [closeOnSelect]=\"false\"\n [placeholder]=\"'@pry.dataset.filterPlaceholder' | i18n\"\n ></pry-select>\n </div>\n</div>\n<div class=\"o-datasource-list__content\">\n @if ((_mode$ | async) === 'list') {\n @for (datasource of filteredDatasources$ | async; track datasource.id) {\n <pry-datasource-card\n [datasource]=\"datasource\"\n [isSelectable]=\"false\"\n [showFooter]=\"true\"\n (clicked)=\"onDatasourceClick($event)\"\n ></pry-datasource-card>\n }\n } @else if ((_mode$ | async) === 'selector') {\n @for (datasource of filteredDatasources$ | async; track datasource.id) {\n <pry-datasource-card\n [datasource]=\"datasource\"\n [isSelectable]=\"true\"\n [showFooter]=\"false\"\n (clicked)=\"onDatasourceClick($event)\"\n [isSelected]=\"datasource.isSelected ?? false\"\n ></pry-datasource-card>\n }\n }\n</div>\n" }]
86
+ }], ctorParameters: () => [{ type: i1.Store }], propDecorators: { mode: [{
87
+ type: Input
88
+ }], selectedDatasources: [{
89
+ type: Input
90
+ }], consultedDataset: [{
91
+ type: Output
92
+ }], datasourceSelected: [{
93
+ type: Output
94
+ }] } });
95
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datasource-list.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/provoly/dashboard/lib/dashboard/components/widgets/datasource-selector/datasource-list/datasource-list.component.ts","../../../../../../../../../../projects/provoly/dashboard/lib/dashboard/components/widgets/datasource-selector/datasource-list/datasource-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { BehaviorSubject, combineLatest, map, Observable, Subject, switchMap } from 'rxjs';\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport { Dataset, DataSource } from '../../../../../core/store/data-source/data-source.model';\nimport { DataSourceActions } from '../../../../../core/store/data-source/data-source.actions';\nimport { DataSourceSelectors } from '../../../../../core/store/data-source/data-source.selectors';\nimport { Category } from '../../../../../core/store/category/category.interface';\nimport { DashboardActions } from '../../../../store/dashboard.actions';\nimport { SubscriptionnerDirective } from '../../../subscriptionner.directive';\nimport { DatasourceUtils } from '../../../../../core/store/data-source/datasource-utils';\n\n@Component({\n  selector: 'pry-datasource-list',\n  templateUrl: './datasource-list.component.html'\n})\nexport class PryDatasourceListComponent extends SubscriptionnerDirective implements OnInit {\n  datasources$: Observable<DataSource[]>;\n  datasets$: Observable<Dataset[]>;\n  search$ = new BehaviorSubject('');\n  categories$: Observable<Category[]>;\n  selectedCategories = [];\n  selectedCategories$ = new BehaviorSubject<Category[]>([]);\n  filteredDatasources$!: Observable<(DataSource & { isSelected?: boolean })[]>;\n  selectedDatasources$ = new BehaviorSubject<string[]>([]);\n  _mode$ = new BehaviorSubject<string>('list');\n\n  @Input() set mode(mode: 'list' | 'selector') {\n    this._mode$.next(mode);\n  };\n  @Input() set selectedDatasources(datasourceIds: string[]) {\n    this.selectedDatasources$.next(datasourceIds);\n  }\n\n  @Output() consultedDataset = new EventEmitter<Dataset>();\n  @Output() datasourceSelected = new EventEmitter<string[]>();\n\n  constructor(protected store: Store<any>) {\n    super();\n    this.store.dispatch(DataSourceActions.load());\n    this.datasources$ = combineLatest([\n      this.store.select(DataSourceSelectors.getDataSourcesSorted),\n      this.selectedDatasources$\n    ]).pipe(\n      map(([datasources, selectedDatasources]) =>\n        DatasourceUtils.getAllDatasourcesWithUnknowns(datasources, selectedDatasources)\n      )\n    );\n    this.datasets$ = this.store.select(DataSourceSelectors.datasets);\n    this.store.dispatch(DashboardActions.fetchManifestsList());\n\n    this.store.dispatch(DataSourceActions.dataset.getCategories());\n    this.categories$ = this.store.select(DataSourceSelectors.categories);\n    this.store.dispatch(DataSourceActions.dataset.listVersions());\n  }\n\n  ngOnInit() {\n    this.filteredDatasources$ = combineLatest([\n      this._mode$,\n      this.search$,\n      this.selectedCategories$,\n      this.selectedDatasources$,\n      this.datasources$,\n      this.datasets$\n    ]).pipe(\n      map(([mode, query, selectedCategories, selectedDs, datasources, datasets]) =>\n        mode === 'list' ? this.search(datasets, query, selectedCategories)\n        : this.search(datasources, query, selectedCategories)\n          .map((dataset) => ({ ...dataset, isSelected: selectedDs.includes(dataset.id) }))\n          .sort((a, b) => Number(b.isSelected) - Number(a.isSelected))\n        )\n    );\n  }\n\n  search(datasets: DataSource[], search: string, categories: Category[]): DataSource[] {\n    return datasets\n      .filter(\n        (dataset) =>\n          (search.length === 0 || dataset.name.toLowerCase().includes(search.toLowerCase())) &&\n          (categories.length === 0 || this.doesDatasourceMatchCategoryFilter(dataset, categories))\n      )\n      .sort((a, b) => a.name.localeCompare(b.name));\n  }\n\n  doesDatasourceMatchCategoryFilter(datasource: DataSource, selectedCategories: Category[]): boolean {\n    return datasource.sourceType === 'dataset' && datasource.categories\n      ? selectedCategories.reduce(\n          (acc, selectedCat) => acc && datasource.categories!.map((cat) => cat.id).includes(selectedCat.id),\n          true\n        )\n      : false;\n  }\n\n  onDatasourceClick({ isSelected, datasource }: { isSelected: boolean; datasource: DataSource }) {\n    if (this._mode$.value === 'list') {\n      this.consultedDataset.emit(datasource as Dataset);\n    } else {\n      this.selectedDatasources$.next(\n        isSelected\n          ? [...this.selectedDatasources$.value, datasource.id]\n          : this.selectedDatasources$.value.filter((id) => id !== datasource.id)\n      );\n      this.datasourceSelected.emit(this.selectedDatasources$.value);\n    }\n  }\n}\n","<div class=\"o-datasource-list__header u-display-flex\">\n  <div class=\"o-datasource-list__search m-form-label-field\">\n    <label class=\"a-label\" id=\"catalog-search-label\" for=\"catalog-search\">{{ '@pry.dataset.search' | i18n }}</label>\n    <input\n      id=\"catalog-search\"\n      type=\"text\"\n      class=\"a-form-field\"\n      [placeholder]=\"'@pry.dataset.searchPlaceholder' | i18n\"\n      [ngModel]=\"search$ | async\"\n      (ngModelChange)=\"this.search$.next($event)\"\n    />\n    <pry-icon class=\"search-icon\" iconSvg=\"search\" [width]=\"20\" [height]=\"20\"></pry-icon>\n  </div>\n  <div class=\"o-datasource-list__categories m-form-label-field\">\n    <label class=\"a-label\" id=\"tags-label\" for=\"catalog-category-search\">{{ '@pry.dataset.filter' | i18n }}</label>\n    <pry-select\n      id=\"catalog-category-search\"\n      [ngModel]=\"selectedCategories\"\n      (ngModelChange)=\"this.selectedCategories$.next($event)\"\n      [items]=\"categories$ | async\"\n      bindLabel=\"name\"\n      aria-labelledby=\"tags-label\"\n      [multiple]=\"true\"\n      [closeOnSelect]=\"false\"\n      [placeholder]=\"'@pry.dataset.filterPlaceholder' | i18n\"\n    ></pry-select>\n  </div>\n</div>\n<div class=\"o-datasource-list__content\">\n  @if ((_mode$ | async) === 'list') {\n    @for (datasource of filteredDatasources$ | async; track datasource.id) {\n      <pry-datasource-card\n        [datasource]=\"datasource\"\n        [isSelectable]=\"false\"\n        [showFooter]=\"true\"\n        (clicked)=\"onDatasourceClick($event)\"\n      ></pry-datasource-card>\n    }\n  } @else if ((_mode$ | async) === 'selector') {\n    @for (datasource of filteredDatasources$ | async; track datasource.id) {\n      <pry-datasource-card\n        [datasource]=\"datasource\"\n        [isSelectable]=\"true\"\n        [showFooter]=\"false\"\n        (clicked)=\"onDatasourceClick($event)\"\n        [isSelected]=\"datasource.isSelected ?? false\"\n      ></pry-datasource-card>\n    }\n  }\n</div>\n"]}
@@ -1,65 +1,70 @@
1
- import { Component, Input } from '@angular/core';
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
2
  import { BehaviorSubject, combineLatest, map } from 'rxjs';
3
- import { UNKNOWN_DATASOURCE } from '../../../../core/components/translate-id/translate-id.pipe';
3
+ import { SubscriptionnerDirective } from '../../subscriptionner.directive';
4
+ import { DatasourceUtils } from '../../../../core/store/data-source/datasource-utils';
4
5
  import { DataSourceSelectors } from '../../../../core/store/data-source/data-source.selectors';
5
- import { ChipsSelectorComponent } from '../../../../core/components/chips-selector/chips-selector.component';
6
6
  import * as i0 from "@angular/core";
7
7
  import * as i1 from "@ngrx/store";
8
- import * as i2 from "../../../../core/i18n/i18n.service";
9
- import * as i3 from "@angular/common";
10
- import * as i4 from "@angular/forms";
11
- import * as i5 from "../../../../core/components/icon/icon.component";
12
- import * as i6 from "../../../../core/i18n/i18n.pipe";
13
- export class DatasourceSelectorComponent extends ChipsSelectorComponent {
14
- set usedItems(items) {
15
- this._usedItems$.next(items);
16
- }
8
+ import * as i2 from "@angular/common";
9
+ import * as i3 from "../../../../core/components/icon/icon.component";
10
+ import * as i4 from "./datasource-list/datasource-list.component";
11
+ import * as i5 from "../../../../core/i18n/i18n.pipe";
12
+ export class DatasourceSelectorComponent extends SubscriptionnerDirective {
17
13
  set manifest(manifest) {
18
14
  this.manifest$.next(manifest);
15
+ this.selectedIds$.next(DatasourceUtils.getDatasourceArray(manifest?.datasource));
19
16
  }
20
- constructor(store, cdr, i18n) {
21
- super(cdr, i18n);
17
+ constructor(store) {
18
+ super();
22
19
  this.store = store;
23
- this._usedItems$ = new BehaviorSubject([]);
24
20
  this.manifest$ = new BehaviorSubject(null);
25
- this.subscriptions.add(combineLatest([this.manifest$, this.store.select(DataSourceSelectors.getDataSourcesSorted)])
26
- .pipe(map(([manifest, allNamedQueries]) => {
27
- let dss = [...allNamedQueries];
28
- if (!!manifest) {
29
- const manifestNamedQueries = Array.isArray(manifest.datasource)
30
- ? manifest.datasource
31
- : [manifest.datasource];
32
- manifestNamedQueries.forEach((manifestNamedQuery) => {
33
- const alreadyPresent = !!allNamedQueries.find((nq) => nq.id === manifestNamedQuery);
34
- if (!alreadyPresent) {
35
- dss.push(UNKNOWN_DATASOURCE(manifestNamedQuery ?? ''));
36
- }
37
- });
38
- }
39
- return dss;
40
- }))
41
- .subscribe((datasources) => {
42
- this.items$.next(datasources);
43
- }));
44
- this.usedDatasources$ = combineLatest([
45
- this._usedItems$,
46
- this.store.select(DataSourceSelectors.getDataSources)
47
- ]).pipe(map(([usedDatasources, datasources]) => usedDatasources
48
- .map((usedDatasource) => datasources.find((ds) => ds.id === usedDatasource.id) ?? usedDatasource)
49
- .map((nq) => (typeof nq !== 'string' ? nq : UNKNOWN_DATASOURCE(nq)))));
50
- this.subscriptions.add(this.usedDatasources$.subscribe((usedDatasources) => {
51
- this.usedItems$.next(usedDatasources);
52
- }));
21
+ this.selectedIds$ = new BehaviorSubject([]);
22
+ this.showButtons = true;
23
+ this.showTitle = true;
24
+ this.previousTab = new EventEmitter();
25
+ this.nextTab = new EventEmitter();
26
+ this.cancel = new EventEmitter();
27
+ this.validated = new EventEmitter();
28
+ this.itemsChanged = new EventEmitter();
29
+ this.datasources$ = combineLatest([
30
+ this.store.select(DataSourceSelectors.getDataSourcesSorted),
31
+ this.selectedIds$
32
+ ]).pipe(map(([datasources, selectedIds]) => DatasourceUtils.getAllDatasourcesWithUnknowns(datasources, selectedIds)));
33
+ this.selectedDatasources$ = combineLatest([this.datasources$, this.selectedIds$]).pipe(map(([datasources, selected]) => datasources.filter((ds) => selected.includes(ds.id))));
34
+ }
35
+ isGeo(item) {
36
+ return DatasourceUtils.isGeo(item);
37
+ }
38
+ toggleSelection(id) {
39
+ this.selectedIds$.next(this.selectedIds$.value.includes(id)
40
+ ? this.selectedIds$.value.filter((i) => i !== id)
41
+ : [...this.selectedIds$.value, id]);
53
42
  }
54
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DatasourceSelectorComponent, deps: [{ token: i1.Store }, { token: i0.ChangeDetectorRef }, { token: i2.PryI18nService }], target: i0.ɵɵFactoryTarget.Component }); }
55
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: DatasourceSelectorComponent, selector: "pry-datasource-selector", inputs: { usedItems: "usedItems", manifest: "manifest" }, usesInheritance: true, ngImport: i0, template: "<div class=\"o-chips-selector\" role=\"dialog\" aria-modal=\"true\" aria-labelledby=\"dialog_namedqueries\">\n <div *ngIf=\"showSearchbar\" class=\"o-widget__search\">\n <input\n id=\"catalog-search\"\n (keydown.shift.tab)=\"previousTab.emit()\"\n type=\"text\"\n class=\"a-form-field\"\n [placeholder]=\"'@pry.components.searchData' | i18n\"\n [ngModel]=\"search$ | async\"\n (ngModelChange)=\"search($event)\"\n />\n <pry-icon iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n </div>\n <div class=\"o-chips-selector__items\">\n <div *ngIf=\"((usedItems$ | async) ?? []).length > 0; else noItems\" class=\"o-chips-selector__used-items\">\n <h4 class=\"a-h4\">{{ translationStringBase + 'selection' | i18n }}</h4>\n <ul class=\"o-chips-selector__list\">\n <li *ngFor=\"let item of usedItems$ | async\" class=\"o-chips-selector__item\">\n <button class=\"a-chip -md o-chips-selector__chip\" (click)=\"toggleItemSelection(item)\" type=\"button\">\n <p>\n {{ getItemLabel(item) }}\n </p>\n <pry-icon *ngIf=\"isGeo(item)\" iconSvg=\"globe\" [width]=\"22\" [height]=\"22\"></pry-icon>\n <pry-icon [iconSvg]=\"'close'\" [width]=\"17\" [height]=\"17\"></pry-icon>\n </button>\n </li>\n </ul>\n </div>\n <ng-template #noItems>\n <span class=\"-no-items\">{{ translationStringBase + 'noItemSelected' | i18n }}</span>\n </ng-template>\n <div class=\"o-chips-selector__unused-items\">\n <h4 class=\"a-h4\">{{ translationStringBase + 'select' | i18n }}</h4>\n <ul class=\"o-chips-selector__list\">\n <li *ngFor=\"let item of unusedItems$ | async\" class=\"o-chips-selector__item\">\n <button class=\"a-chip a-chip--light -md o-chips-selector__chip\" (click)=\"toggleItemSelection(item)\">\n <span class=\"u-visually-hidden\">{{ translationStringBase + 'selectItem' | i18n }}</span>\n <p class=\"a-p\">{{ getItemLabel(item) }}</p>\n <pry-icon *ngIf=\"isGeo(item)\" iconSvg=\"globe\" [width]=\"22\" [height]=\"22\"></pry-icon>\n </button>\n </li>\n </ul>\n </div>\n </div>\n <div *ngIf=\"showActionButtons\" class=\"m-btn-group o-chips-selector__footer\">\n <button type=\"button\" (click)=\"cancel.emit()\" class=\"a-btn a-btn--secondary\">\n {{ '@pry.toolbox.manifest.close' | i18n }}\n </button>\n <button\n type=\"button\"\n (click)=\"validated.emit()\"\n #validate\n (keydown.tab)=\"nextTab.emit()\"\n class=\"a-btn a-btn--primary\"\n >\n {{ '@pry.toolbox.manifest.validated' | i18n }}\n </button>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i6.I18nPipe, name: "i18n" }] }); }
43
+ updateDatasourceList(ids) {
44
+ this.selectedIds$.next(ids);
45
+ this.itemsChanged.emit(ids);
46
+ }
47
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DatasourceSelectorComponent, deps: [{ token: i1.Store }], target: i0.ɵɵFactoryTarget.Component }); }
48
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: DatasourceSelectorComponent, selector: "pry-datasource-selector", inputs: { showButtons: "showButtons", showTitle: "showTitle", manifest: "manifest" }, outputs: { previousTab: "previousTab", nextTab: "nextTab", cancel: "cancel", validated: "validated", itemsChanged: "itemsChanged" }, usesInheritance: true, ngImport: i0, template: "<div class=\"o-datasource-selector u-display-flex -column\">\n @if (showTitle) {\n <h2 class=\"u-self-center\">{{ '@pry.components.datasourceSelector.select' | i18n }}</h2>\n }\n <div>\n <h3>\n {{ '@pry.components.datasourceSelector.selection' | i18n }} ({{ ((selectedDatasources$ | async) ?? []).length }})\n </h3>\n <div class=\"o-datasource-selector__chips u-display-flex -wrap -gap-10\">\n @if ((selectedDatasources$ | async)?.length === 0) {\n <span class=\"a-label -italic\">{{ '@pry.components.datasourceSelector.noItemSelected' | i18n }}</span>\n } @else {\n @for (datasource of selectedDatasources$ | async; track datasource.id) {\n <button\n class=\"a-chip a-chip--ghost -lg a-tooltip\"\n [attr.data-tooltip]=\"'@pry.components.datasourceSelector.unselectItem' | i18n\"\n type=\"button\"\n (click)=\"toggleSelection(datasource.id)\"\n >\n <pry-icon iconSvg=\"close\" [width]=\"15\" [height]=\"15\"></pry-icon>\n {{ datasource.name }}\n <pry-icon *ngIf=\"isGeo(datasource)\" iconSvg=\"globe\" [width]=\"18\" [height]=\"18\"></pry-icon>\n </button>\n }\n }\n </div>\n </div>\n <pry-datasource-list\n mode=\"selector\"\n [selectedDatasources]=\"(selectedIds$ | async) ?? []\"\n (datasourceSelected)=\"updateDatasourceList($event)\"\n ></pry-datasource-list>\n @if (showButtons) {\n <div class=\"m-btn-group o-datasource-selector__footer\">\n <button type=\"button\" (click)=\"cancel.emit()\" class=\"a-btn a-btn--secondary\">\n {{ '@pry.toolbox.manifest.close' | i18n }}\n </button>\n <button\n type=\"button\"\n (click)=\"validated.emit()\"\n #validate\n (keydown.tab)=\"nextTab.emit()\"\n class=\"a-btn a-btn--primary\"\n >\n {{ '@pry.toolbox.manifest.validated' | i18n }}\n </button>\n </div>\n }\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "component", type: i4.PryDatasourceListComponent, selector: "pry-datasource-list", inputs: ["mode", "selectedDatasources"], outputs: ["consultedDataset", "datasourceSelected"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.I18nPipe, name: "i18n" }] }); }
56
49
  }
57
50
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: DatasourceSelectorComponent, decorators: [{
58
51
  type: Component,
59
- args: [{ selector: 'pry-datasource-selector', template: "<div class=\"o-chips-selector\" role=\"dialog\" aria-modal=\"true\" aria-labelledby=\"dialog_namedqueries\">\n <div *ngIf=\"showSearchbar\" class=\"o-widget__search\">\n <input\n id=\"catalog-search\"\n (keydown.shift.tab)=\"previousTab.emit()\"\n type=\"text\"\n class=\"a-form-field\"\n [placeholder]=\"'@pry.components.searchData' | i18n\"\n [ngModel]=\"search$ | async\"\n (ngModelChange)=\"search($event)\"\n />\n <pry-icon iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n </div>\n <div class=\"o-chips-selector__items\">\n <div *ngIf=\"((usedItems$ | async) ?? []).length > 0; else noItems\" class=\"o-chips-selector__used-items\">\n <h4 class=\"a-h4\">{{ translationStringBase + 'selection' | i18n }}</h4>\n <ul class=\"o-chips-selector__list\">\n <li *ngFor=\"let item of usedItems$ | async\" class=\"o-chips-selector__item\">\n <button class=\"a-chip -md o-chips-selector__chip\" (click)=\"toggleItemSelection(item)\" type=\"button\">\n <p>\n {{ getItemLabel(item) }}\n </p>\n <pry-icon *ngIf=\"isGeo(item)\" iconSvg=\"globe\" [width]=\"22\" [height]=\"22\"></pry-icon>\n <pry-icon [iconSvg]=\"'close'\" [width]=\"17\" [height]=\"17\"></pry-icon>\n </button>\n </li>\n </ul>\n </div>\n <ng-template #noItems>\n <span class=\"-no-items\">{{ translationStringBase + 'noItemSelected' | i18n }}</span>\n </ng-template>\n <div class=\"o-chips-selector__unused-items\">\n <h4 class=\"a-h4\">{{ translationStringBase + 'select' | i18n }}</h4>\n <ul class=\"o-chips-selector__list\">\n <li *ngFor=\"let item of unusedItems$ | async\" class=\"o-chips-selector__item\">\n <button class=\"a-chip a-chip--light -md o-chips-selector__chip\" (click)=\"toggleItemSelection(item)\">\n <span class=\"u-visually-hidden\">{{ translationStringBase + 'selectItem' | i18n }}</span>\n <p class=\"a-p\">{{ getItemLabel(item) }}</p>\n <pry-icon *ngIf=\"isGeo(item)\" iconSvg=\"globe\" [width]=\"22\" [height]=\"22\"></pry-icon>\n </button>\n </li>\n </ul>\n </div>\n </div>\n <div *ngIf=\"showActionButtons\" class=\"m-btn-group o-chips-selector__footer\">\n <button type=\"button\" (click)=\"cancel.emit()\" class=\"a-btn a-btn--secondary\">\n {{ '@pry.toolbox.manifest.close' | i18n }}\n </button>\n <button\n type=\"button\"\n (click)=\"validated.emit()\"\n #validate\n (keydown.tab)=\"nextTab.emit()\"\n class=\"a-btn a-btn--primary\"\n >\n {{ '@pry.toolbox.manifest.validated' | i18n }}\n </button>\n </div>\n</div>\n" }]
60
- }], ctorParameters: () => [{ type: i1.Store }, { type: i0.ChangeDetectorRef }, { type: i2.PryI18nService }], propDecorators: { usedItems: [{
52
+ args: [{ selector: 'pry-datasource-selector', template: "<div class=\"o-datasource-selector u-display-flex -column\">\n @if (showTitle) {\n <h2 class=\"u-self-center\">{{ '@pry.components.datasourceSelector.select' | i18n }}</h2>\n }\n <div>\n <h3>\n {{ '@pry.components.datasourceSelector.selection' | i18n }} ({{ ((selectedDatasources$ | async) ?? []).length }})\n </h3>\n <div class=\"o-datasource-selector__chips u-display-flex -wrap -gap-10\">\n @if ((selectedDatasources$ | async)?.length === 0) {\n <span class=\"a-label -italic\">{{ '@pry.components.datasourceSelector.noItemSelected' | i18n }}</span>\n } @else {\n @for (datasource of selectedDatasources$ | async; track datasource.id) {\n <button\n class=\"a-chip a-chip--ghost -lg a-tooltip\"\n [attr.data-tooltip]=\"'@pry.components.datasourceSelector.unselectItem' | i18n\"\n type=\"button\"\n (click)=\"toggleSelection(datasource.id)\"\n >\n <pry-icon iconSvg=\"close\" [width]=\"15\" [height]=\"15\"></pry-icon>\n {{ datasource.name }}\n <pry-icon *ngIf=\"isGeo(datasource)\" iconSvg=\"globe\" [width]=\"18\" [height]=\"18\"></pry-icon>\n </button>\n }\n }\n </div>\n </div>\n <pry-datasource-list\n mode=\"selector\"\n [selectedDatasources]=\"(selectedIds$ | async) ?? []\"\n (datasourceSelected)=\"updateDatasourceList($event)\"\n ></pry-datasource-list>\n @if (showButtons) {\n <div class=\"m-btn-group o-datasource-selector__footer\">\n <button type=\"button\" (click)=\"cancel.emit()\" class=\"a-btn a-btn--secondary\">\n {{ '@pry.toolbox.manifest.close' | i18n }}\n </button>\n <button\n type=\"button\"\n (click)=\"validated.emit()\"\n #validate\n (keydown.tab)=\"nextTab.emit()\"\n class=\"a-btn a-btn--primary\"\n >\n {{ '@pry.toolbox.manifest.validated' | i18n }}\n </button>\n </div>\n }\n</div>\n" }]
53
+ }], ctorParameters: () => [{ type: i1.Store }], propDecorators: { showButtons: [{
54
+ type: Input
55
+ }], showTitle: [{
61
56
  type: Input
62
57
  }], manifest: [{
63
58
  type: Input
59
+ }], previousTab: [{
60
+ type: Output
61
+ }], nextTab: [{
62
+ type: Output
63
+ }], cancel: [{
64
+ type: Output
65
+ }], validated: [{
66
+ type: Output
67
+ }], itemsChanged: [{
68
+ type: Output
64
69
  }] } });
65
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datasource-selector.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/provoly/dashboard/lib/dashboard/components/widgets/datasource-selector/datasource-selector.component.ts","../../../../../../../../../projects/provoly/dashboard/lib/core/components/chips-selector/chips-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, Input } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport { BehaviorSubject, combineLatest, map, Observable } from 'rxjs';\nimport { UNKNOWN_DATASOURCE } from '../../../../core/components/translate-id/translate-id.pipe';\nimport { NamedQuery } from '../../../../core/store/data-source/data-source.model';\nimport { DataSourceSelectors } from '../../../../core/store/data-source/data-source.selectors';\nimport { ChipsSelectorComponent } from '../../../../core/components/chips-selector/chips-selector.component';\nimport { WidgetManifest } from '../../../../core/model/manifest.interface';\nimport { SubscriptionnerDirective } from '../../subscriptionner.directive';\nimport { PryI18nService } from '../../../../core/i18n/i18n.service';\n\n@Component({\n  selector: 'pry-datasource-selector',\n  templateUrl: '../../../../core/components/chips-selector/chips-selector.component.html'\n})\nexport class DatasourceSelectorComponent extends ChipsSelectorComponent implements SubscriptionnerDirective {\n  _usedItems$ = new BehaviorSubject([] as any[]);\n  usedDatasources$: Observable<NamedQuery[]>;\n\n  @Input() override set usedItems(items: any[]) {\n    this._usedItems$.next(items);\n  }\n\n  @Input() set manifest(manifest: WidgetManifest | null) {\n    this.manifest$.next(manifest);\n  }\n\n  manifest$ = new BehaviorSubject<WidgetManifest | null>(null);\n\n  constructor(private store: Store, cdr: ChangeDetectorRef, i18n: PryI18nService) {\n    super(cdr, i18n);\n    this.subscriptions.add(\n      combineLatest([this.manifest$, this.store.select(DataSourceSelectors.getDataSourcesSorted)])\n        .pipe(\n          map(([manifest, allNamedQueries]) => {\n            let dss = [...allNamedQueries];\n            if (!!manifest) {\n              const manifestNamedQueries = Array.isArray(manifest.datasource)\n                ? manifest.datasource\n                : [manifest.datasource];\n              manifestNamedQueries.forEach((manifestNamedQuery) => {\n                const alreadyPresent = !!allNamedQueries.find((nq) => nq.id === manifestNamedQuery);\n                if (!alreadyPresent) {\n                  dss.push(UNKNOWN_DATASOURCE(manifestNamedQuery ?? ''));\n                }\n              });\n            }\n            return dss;\n          })\n        )\n        .subscribe((datasources) => {\n          this.items$.next(datasources);\n        })\n    );\n\n    this.usedDatasources$ = combineLatest([\n      this._usedItems$,\n      this.store.select(DataSourceSelectors.getDataSources)\n    ]).pipe(\n      map(\n        ([usedDatasources, datasources]) =>\n          usedDatasources\n            .map((usedDatasource) => datasources.find((ds) => ds.id === usedDatasource.id) ?? usedDatasource)\n            .map((nq) => (typeof nq !== 'string' ? nq : UNKNOWN_DATASOURCE(nq))) as NamedQuery[]\n      )\n    );\n\n    this.subscriptions.add(\n      this.usedDatasources$.subscribe((usedDatasources) => {\n        this.usedItems$.next(usedDatasources);\n      })\n    );\n  }\n}\n","<div class=\"o-chips-selector\" role=\"dialog\" aria-modal=\"true\" aria-labelledby=\"dialog_namedqueries\">\n  <div *ngIf=\"showSearchbar\" class=\"o-widget__search\">\n    <input\n      id=\"catalog-search\"\n      (keydown.shift.tab)=\"previousTab.emit()\"\n      type=\"text\"\n      class=\"a-form-field\"\n      [placeholder]=\"'@pry.components.searchData' | i18n\"\n      [ngModel]=\"search$ | async\"\n      (ngModelChange)=\"search($event)\"\n    />\n    <pry-icon iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n  </div>\n  <div class=\"o-chips-selector__items\">\n    <div *ngIf=\"((usedItems$ | async) ?? []).length > 0; else noItems\" class=\"o-chips-selector__used-items\">\n      <h4 class=\"a-h4\">{{ translationStringBase + 'selection' | i18n }}</h4>\n      <ul class=\"o-chips-selector__list\">\n        <li *ngFor=\"let item of usedItems$ | async\" class=\"o-chips-selector__item\">\n          <button class=\"a-chip -md o-chips-selector__chip\" (click)=\"toggleItemSelection(item)\" type=\"button\">\n            <p>\n              {{ getItemLabel(item) }}\n            </p>\n            <pry-icon *ngIf=\"isGeo(item)\" iconSvg=\"globe\" [width]=\"22\" [height]=\"22\"></pry-icon>\n            <pry-icon [iconSvg]=\"'close'\" [width]=\"17\" [height]=\"17\"></pry-icon>\n          </button>\n        </li>\n      </ul>\n    </div>\n    <ng-template #noItems>\n      <span class=\"-no-items\">{{ translationStringBase + 'noItemSelected' | i18n }}</span>\n    </ng-template>\n    <div class=\"o-chips-selector__unused-items\">\n      <h4 class=\"a-h4\">{{ translationStringBase + 'select' | i18n }}</h4>\n      <ul class=\"o-chips-selector__list\">\n        <li *ngFor=\"let item of unusedItems$ | async\" class=\"o-chips-selector__item\">\n          <button class=\"a-chip a-chip--light -md o-chips-selector__chip\" (click)=\"toggleItemSelection(item)\">\n            <span class=\"u-visually-hidden\">{{ translationStringBase + 'selectItem' | i18n }}</span>\n            <p class=\"a-p\">{{ getItemLabel(item) }}</p>\n            <pry-icon *ngIf=\"isGeo(item)\" iconSvg=\"globe\" [width]=\"22\" [height]=\"22\"></pry-icon>\n          </button>\n        </li>\n      </ul>\n    </div>\n  </div>\n  <div *ngIf=\"showActionButtons\" class=\"m-btn-group o-chips-selector__footer\">\n    <button type=\"button\" (click)=\"cancel.emit()\" class=\"a-btn a-btn--secondary\">\n      {{ '@pry.toolbox.manifest.close' | i18n }}\n    </button>\n    <button\n      type=\"button\"\n      (click)=\"validated.emit()\"\n      #validate\n      (keydown.tab)=\"nextTab.emit()\"\n      class=\"a-btn a-btn--primary\"\n    >\n      {{ '@pry.toolbox.manifest.validated' | i18n }}\n    </button>\n  </div>\n</div>\n"]}
70
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datasource-selector.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/provoly/dashboard/lib/dashboard/components/widgets/datasource-selector/datasource-selector.component.ts","../../../../../../../../../projects/provoly/dashboard/lib/dashboard/components/widgets/datasource-selector/datasource-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport { BehaviorSubject, combineLatest, map, Observable } from 'rxjs';\nimport { DataSource } from '../../../../core/store/data-source/data-source.model';\nimport { WidgetManifest } from '../../../../core/model/manifest.interface';\nimport { SubscriptionnerDirective } from '../../subscriptionner.directive';\nimport { DatasourceUtils } from '../../../../core/store/data-source/datasource-utils';\nimport { DataSourceSelectors } from '../../../../core/store/data-source/data-source.selectors';\n\n@Component({\n  selector: 'pry-datasource-selector',\n  templateUrl: 'datasource-selector.component.html'\n})\nexport class DatasourceSelectorComponent extends SubscriptionnerDirective {\n  datasources$: Observable<DataSource[]>;\n  manifest$ = new BehaviorSubject<WidgetManifest | null>(null);\n  selectedDatasources$: Observable<DataSource[]>;\n\n  selectedIds$ = new BehaviorSubject<string[]>([]);\n\n  @Input() showButtons = true;\n  @Input() showTitle = true;\n  @Input() set manifest(manifest: WidgetManifest | null) {\n    this.manifest$.next(manifest);\n    this.selectedIds$.next(DatasourceUtils.getDatasourceArray(manifest?.datasource));\n  }\n\n  @Output() previousTab = new EventEmitter();\n  @Output() nextTab = new EventEmitter();\n  @Output() cancel = new EventEmitter();\n  @Output() validated = new EventEmitter();\n  @Output() itemsChanged = new EventEmitter<string[]>();\n\n  constructor(private store: Store) {\n    super();\n\n    this.datasources$ = combineLatest([\n      this.store.select(DataSourceSelectors.getDataSourcesSorted),\n      this.selectedIds$\n    ]).pipe(\n      map(([datasources, selectedIds]) => DatasourceUtils.getAllDatasourcesWithUnknowns(datasources, selectedIds))\n    );\n\n    this.selectedDatasources$ = combineLatest([this.datasources$, this.selectedIds$]).pipe(\n      map(([datasources, selected]) => datasources.filter((ds) => selected.includes(ds.id)))\n    );\n  }\n\n  isGeo(item: DataSource) {\n    return DatasourceUtils.isGeo(item);\n  }\n\n  toggleSelection(id: string) {\n    this.selectedIds$.next(\n      this.selectedIds$.value.includes(id)\n        ? this.selectedIds$.value.filter((i) => i !== id)\n        : [...this.selectedIds$.value, id]\n    );\n  }\n\n  updateDatasourceList(ids: string[]) {\n    this.selectedIds$.next(ids);\n    this.itemsChanged.emit(ids);\n  }\n}\n","<div class=\"o-datasource-selector u-display-flex -column\">\n  @if (showTitle) {\n    <h2 class=\"u-self-center\">{{ '@pry.components.datasourceSelector.select' | i18n }}</h2>\n  }\n  <div>\n    <h3>\n      {{ '@pry.components.datasourceSelector.selection' | i18n }} ({{ ((selectedDatasources$ | async) ?? []).length }})\n    </h3>\n    <div class=\"o-datasource-selector__chips u-display-flex -wrap -gap-10\">\n      @if ((selectedDatasources$ | async)?.length === 0) {\n        <span class=\"a-label -italic\">{{ '@pry.components.datasourceSelector.noItemSelected' | i18n }}</span>\n      } @else {\n        @for (datasource of selectedDatasources$ | async; track datasource.id) {\n          <button\n            class=\"a-chip a-chip--ghost -lg a-tooltip\"\n            [attr.data-tooltip]=\"'@pry.components.datasourceSelector.unselectItem' | i18n\"\n            type=\"button\"\n            (click)=\"toggleSelection(datasource.id)\"\n          >\n            <pry-icon iconSvg=\"close\" [width]=\"15\" [height]=\"15\"></pry-icon>\n            {{ datasource.name }}\n            <pry-icon *ngIf=\"isGeo(datasource)\" iconSvg=\"globe\" [width]=\"18\" [height]=\"18\"></pry-icon>\n          </button>\n        }\n      }\n    </div>\n  </div>\n  <pry-datasource-list\n    mode=\"selector\"\n    [selectedDatasources]=\"(selectedIds$ | async) ?? []\"\n    (datasourceSelected)=\"updateDatasourceList($event)\"\n  ></pry-datasource-list>\n  @if (showButtons) {\n    <div class=\"m-btn-group o-datasource-selector__footer\">\n      <button type=\"button\" (click)=\"cancel.emit()\" class=\"a-btn a-btn--secondary\">\n        {{ '@pry.toolbox.manifest.close' | i18n }}\n      </button>\n      <button\n        type=\"button\"\n        (click)=\"validated.emit()\"\n        #validate\n        (keydown.tab)=\"nextTab.emit()\"\n        class=\"a-btn a-btn--primary\"\n      >\n        {{ '@pry.toolbox.manifest.validated' | i18n }}\n      </button>\n    </div>\n  }\n</div>\n"]}