@provoly/dashboard 1.2.9 → 1.2.10
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/admin.module.d.ts +2 -3
- package/dataset/components/dataset.component.d.ts +3 -11
- package/dataset/dataset.module.d.ts +7 -9
- package/dataset/public-api.d.ts +0 -1
- package/dataset/style/_o-pry-dataset.scss +3 -72
- package/esm2022/admin/admin.module.mjs +1 -5
- package/esm2022/dataset/components/dataset-detail/dataset-detail.component.mjs +3 -4
- package/esm2022/dataset/components/dataset.component.mjs +8 -33
- package/esm2022/dataset/dataset.module.mjs +9 -13
- package/esm2022/dataset/public-api.mjs +1 -2
- package/esm2022/dataset/style/css.component.mjs +3 -3
- package/esm2022/lib/core/components/chips-selector/chips-selector.component.mjs +7 -27
- package/esm2022/lib/core/components/chips-selector/chips-selector.module.mjs +21 -0
- package/esm2022/lib/core/components/select-image/select-image.component.mjs +1 -1
- package/esm2022/lib/core/components/share/group-share/group-share.component.mjs +3 -3
- package/esm2022/lib/core/components/share/share.module.mjs +8 -12
- package/esm2022/lib/core/core.module.mjs +4 -8
- package/esm2022/lib/core/i18n/en.translations.mjs +8 -8
- package/esm2022/lib/core/i18n/fr.translations.mjs +9 -9
- package/esm2022/lib/core/pipes/get-secured-image/get-secured-image.pipe.mjs +21 -0
- package/esm2022/lib/core/pipes/since-date/since-date.module.mjs +18 -0
- package/esm2022/lib/core/pipes/since-date/since-date.pipe.mjs +55 -0
- package/esm2022/lib/core/pipes/translate-id/translate-id.pipe.mjs +108 -0
- package/esm2022/lib/core/pipes/translate-item-to-symbol/translate-item-to-symbol.pipe.mjs +23 -0
- package/esm2022/lib/core/public-api.mjs +7 -4
- package/esm2022/lib/core/store/data-source/datasource-utils.mjs +22 -1
- package/esm2022/lib/dashboard/components/widgets/data-widget.component.mjs +2 -2
- package/esm2022/lib/dashboard/components/widgets/datasource-selector/datasource-card/datasource-card.component.mjs +60 -0
- package/esm2022/lib/dashboard/components/widgets/datasource-selector/datasource-list/datasource-list.component.mjs +95 -0
- package/esm2022/lib/dashboard/components/widgets/datasource-selector/datasource-selector.component.mjs +53 -48
- package/esm2022/lib/dashboard/components/widgets/header/widget-header.component.mjs +6 -7
- package/esm2022/lib/dashboard/components/widgets/public-api.mjs +3 -1
- package/esm2022/lib/dashboard/dashboard.module.mjs +19 -7
- package/esm2022/lib/dashboard/tooltip/components/default/default.tooltip.component.mjs +2 -2
- package/esm2022/pipeline/components/pipeline-details/pipeline-details.component.mjs +2 -3
- package/esm2022/pipeline/components/pipeline-list/pipeline-list.component.mjs +2 -3
- package/esm2022/pipeline/pipeline.module.mjs +8 -9
- package/esm2022/presentation/components/presentation.component.mjs +2 -3
- package/esm2022/presentation/presentation.module.mjs +8 -9
- package/esm2022/restitution/components/restitution/restitution.component.mjs +4 -4
- package/esm2022/restitution/components/restitution-catalog/restitution-catalog.component.mjs +2 -3
- package/esm2022/restitution/restitution.module.mjs +2 -3
- package/esm2022/restitution/style/css.component.mjs +2 -2
- package/fesm2022/provoly-dashboard-admin.mjs +0 -4
- package/fesm2022/provoly-dashboard-admin.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-dataset.mjs +30 -87
- package/fesm2022/provoly-dashboard-dataset.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-pipeline.mjs +17 -19
- package/fesm2022/provoly-dashboard-pipeline.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-presentation.mjs +8 -10
- package/fesm2022/provoly-dashboard-presentation.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-restitution.mjs +7 -9
- package/fesm2022/provoly-dashboard-restitution.mjs.map +1 -1
- package/fesm2022/provoly-dashboard.mjs +3475 -3265
- package/fesm2022/provoly-dashboard.mjs.map +1 -1
- package/lib/core/components/chips-selector/chips-selector.component.d.ts +1 -6
- package/lib/core/components/chips-selector/chips-selector.module.d.ts +11 -0
- package/lib/core/components/share/share.module.d.ts +3 -4
- package/lib/core/core.module.d.ts +26 -27
- package/lib/core/i18n/en.translations.d.ts +7 -7
- package/lib/core/i18n/fr.translations.d.ts +7 -7
- package/{components/sinceDate/sinceDate.module.d.ts → lib/core/pipes/since-date/since-date.module.d.ts} +3 -2
- package/{components/sinceDate/sinceDate.pipe.d.ts → lib/core/pipes/since-date/since-date.pipe.d.ts} +4 -4
- package/lib/core/{components → pipes}/translate-id/translate-id.pipe.d.ts +0 -2
- package/lib/core/public-api.d.ts +6 -3
- package/lib/core/store/data-source/datasource-utils.d.ts +4 -1
- package/lib/dashboard/components/widgets/datasource-selector/datasource-card/datasource-card.component.d.ts +24 -0
- package/lib/dashboard/components/widgets/datasource-selector/datasource-list/datasource-list.component.d.ts +35 -0
- package/lib/dashboard/components/widgets/datasource-selector/datasource-selector.component.d.ts +19 -11
- package/lib/dashboard/components/widgets/header/widget-header.component.d.ts +1 -1
- package/lib/dashboard/components/widgets/public-api.d.ts +2 -0
- package/lib/dashboard/dashboard.module.d.ts +18 -15
- package/package.json +43 -49
- package/pipeline/pipeline.module.d.ts +3 -4
- package/presentation/presentation.module.d.ts +7 -8
- package/restitution/components/restitution/restitution.component.d.ts +1 -1
- package/restitution/restitution.module.d.ts +1 -2
- package/restitution/style/_o-restitution.scss +4 -0
- package/styles/components/_a-chip.scss +44 -0
- package/styles/components/_o-datasource-selector.scss +192 -0
- package/styles/components/_o-widget.scss +1 -1
- package/styles/main.scss +1 -0
- package/styles-theme/main-theme.scss +0 -3
- package/components/sinceDate/index.d.ts +0 -5
- package/components/sinceDate/public-api.d.ts +0 -2
- package/dataset/components/dataset-card/dataset-card.component.d.ts +0 -18
- package/dataset/style/_o-pry-dataset-card.scss +0 -93
- package/esm2022/components/sinceDate/provoly-dashboard-components-sinceDate.mjs +0 -5
- package/esm2022/components/sinceDate/public-api.mjs +0 -3
- package/esm2022/components/sinceDate/sinceDate.module.mjs +0 -16
- package/esm2022/components/sinceDate/sinceDate.pipe.mjs +0 -55
- package/esm2022/dataset/components/dataset-card/dataset-card.component.mjs +0 -41
- package/esm2022/lib/core/components/get-secured-image/get-secured-image.pipe.mjs +0 -21
- package/esm2022/lib/core/components/translate-id/translate-id.pipe.mjs +0 -114
- package/esm2022/lib/core/components/translate-item-to-symbol/translate-item-to-symbol.pipe.mjs +0 -23
- package/fesm2022/provoly-dashboard-components-sinceDate.mjs +0 -75
- package/fesm2022/provoly-dashboard-components-sinceDate.mjs.map +0 -1
- package/styles-theme/components-theme/_a-chip.theme.scss +0 -32
- package/styles-theme/components-theme/_o-pry-dataset-card.theme.scss +0 -26
- package/styles-theme/components-theme/_o-pry-dataset.theme.scss +0 -4
- /package/lib/core/{components → pipes}/get-secured-image/get-secured-image.pipe.d.ts +0 -0
- /package/lib/core/{components → pipes}/translate-item-to-symbol/translate-item-to-symbol.pipe.d.ts +0 -0
|
@@ -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 {
|
|
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 "
|
|
9
|
-
import * as i3 from "
|
|
10
|
-
import * as i4 from "
|
|
11
|
-
import * as i5 from "../../../../core/
|
|
12
|
-
|
|
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
|
|
21
|
-
super(
|
|
17
|
+
constructor(store) {
|
|
18
|
+
super();
|
|
22
19
|
this.store = store;
|
|
23
|
-
this._usedItems$ = new BehaviorSubject([]);
|
|
24
20
|
this.manifest$ = new BehaviorSubject(null);
|
|
25
|
-
this.
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
this.
|
|
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
|
-
|
|
55
|
-
|
|
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-
|
|
60
|
-
}], ctorParameters: () => [{ type: i1.Store }
|
|
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":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvE,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,GAAG,EAAc,MAAM,MAAM,CAAC;AAGvE,OAAO,EAAE,wBAAwB,EAAE,MAAM,iCAAiC,CAAC;AAC3E,OAAO,EAAE,eAAe,EAAE,MAAM,qDAAqD,CAAC;AACtF,OAAO,EAAE,mBAAmB,EAAE,MAAM,0DAA0D,CAAC;;;;;;;AAM/F,MAAM,OAAO,2BAA4B,SAAQ,wBAAwB;IASvE,IAAa,QAAQ,CAAC,QAA+B;QACnD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC9B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC,CAAC;IACnF,CAAC;IAQD,YAAoB,KAAY;QAC9B,KAAK,EAAE,CAAC;QADU,UAAK,GAAL,KAAK,CAAO;QAlBhC,cAAS,GAAG,IAAI,eAAe,CAAwB,IAAI,CAAC,CAAC;QAG7D,iBAAY,GAAG,IAAI,eAAe,CAAW,EAAE,CAAC,CAAC;QAExC,gBAAW,GAAG,IAAI,CAAC;QACnB,cAAS,GAAG,IAAI,CAAC;QAMhB,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QACjC,YAAO,GAAG,IAAI,YAAY,EAAE,CAAC;QAC7B,WAAM,GAAG,IAAI,YAAY,EAAE,CAAC;QAC5B,cAAS,GAAG,IAAI,YAAY,EAAE,CAAC;QAC/B,iBAAY,GAAG,IAAI,YAAY,EAAY,CAAC;QAKpD,IAAI,CAAC,YAAY,GAAG,aAAa,CAAC;YAChC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,mBAAmB,CAAC,oBAAoB,CAAC;YAC3D,IAAI,CAAC,YAAY;SAClB,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,WAAW,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,6BAA6B,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC,CAC7G,CAAC;QAEF,IAAI,CAAC,oBAAoB,GAAG,aAAa,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CACpF,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,QAAQ,CAAC,EAAE,EAAE,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CACvF,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,IAAgB;QACpB,OAAO,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACrC,CAAC;IAED,eAAe,CAAC,EAAU;QACxB,IAAI,CAAC,YAAY,CAAC,IAAI,CACpB,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC;YAClC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC;YACjD,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,EAAE,CAAC,CACrC,CAAC;IACJ,CAAC;IAED,oBAAoB,CAAC,GAAa;QAChC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC5B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC9B,CAAC;8GAlDU,2BAA2B;kGAA3B,2BAA2B,iTCbxC,u7DAiDA;;2FDpCa,2BAA2B;kBAJvC,SAAS;+BACE,yBAAyB;0EAU1B,WAAW;sBAAnB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACO,QAAQ;sBAApB,KAAK;gBAKI,WAAW;sBAApB,MAAM;gBACG,OAAO;sBAAhB,MAAM;gBACG,MAAM;sBAAf,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBACG,YAAY;sBAArB,MAAM","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"]}
|