@provoly/dashboard 1.3.5 → 1.3.6

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.
@@ -33,6 +33,8 @@ export class DatasourceSelectorComponent extends SubscriptionnerDirective {
33
33
  this.store.select(DataSourceSelectors.getDataSourcesSorted),
34
34
  this.selectedIds$
35
35
  ]).pipe(map(([datasources, selectedIds]) => DatasourceUtils.getAllDatasourcesWithUnknowns(datasources, selectedIds).filter((ds) => selectedIds.includes(ds.id))));
36
+ }
37
+ ngOnInit() {
36
38
  this.subscriptions.add(this.selectedIds$.subscribe((selectedIds) => {
37
39
  this.itemsChanged.emit(selectedIds);
38
40
  this.detectChanges();
@@ -80,4 +82,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
80
82
  }], itemsChanged: [{
81
83
  type: Output
82
84
  }] } });
83
- //# 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 { ChangeDetectorRef, Component, EventEmitter, Input, Output } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport { BehaviorSubject, combineLatest, map, Observable, Subject } 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';\nimport { delay } from 'rxjs/operators';\n\n@Component({\n  selector: 'pry-datasource-selector',\n  templateUrl: 'datasource-selector.component.html'\n})\nexport class DatasourceSelectorComponent extends SubscriptionnerDirective {\n  manifest$ = new BehaviorSubject<WidgetManifest | null>(null);\n  selectedDatasources$: Observable<DataSource[]>;\n\n  selectedIds$ = new BehaviorSubject<string[]>([]);\n  searchOrCategoryChanged$ = new Subject<void>();\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(\n    private store: Store,\n    private cdr: ChangeDetectorRef\n  ) {\n    super();\n\n    this.selectedDatasources$ = combineLatest([\n      this.store.select(DataSourceSelectors.getDataSourcesSorted),\n      this.selectedIds$\n    ]).pipe(\n      map(([datasources, selectedIds]) =>\n        DatasourceUtils.getAllDatasourcesWithUnknowns(datasources, selectedIds).filter((ds) =>\n          selectedIds.includes(ds.id)\n        )\n      )\n    );\n    this.subscriptions.add(\n      this.selectedIds$.subscribe((selectedIds) => {\n        this.itemsChanged.emit(selectedIds);\n        this.detectChanges();\n      })\n    );\n    this.subscriptions.add(\n      this.searchOrCategoryChanged$.pipe(delay(50)).subscribe(() => {\n        this.detectChanges();\n      })\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    this.detectChanges();\n  }\n\n  updateDatasourceList(ids: string[]) {\n    this.selectedIds$.next(ids);\n    this.detectChanges();\n  }\n\n  detectChanges() {\n    this.cdr.detectChanges();\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    (searchOrCategoryChanged)=\"searchOrCategoryChanged$.next()\"\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"]}
85
+ //# 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 { ChangeDetectorRef, Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport { BehaviorSubject, combineLatest, map, Observable, Subject } 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';\nimport { delay } from 'rxjs/operators';\n\n@Component({\n  selector: 'pry-datasource-selector',\n  templateUrl: 'datasource-selector.component.html'\n})\nexport class DatasourceSelectorComponent extends SubscriptionnerDirective implements OnInit {\n  manifest$ = new BehaviorSubject<WidgetManifest | null>(null);\n  selectedDatasources$: Observable<DataSource[]>;\n\n  selectedIds$ = new BehaviorSubject<string[]>([]);\n  searchOrCategoryChanged$ = new Subject<void>();\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(\n    private store: Store,\n    private cdr: ChangeDetectorRef\n  ) {\n    super();\n\n    this.selectedDatasources$ = combineLatest([\n      this.store.select(DataSourceSelectors.getDataSourcesSorted),\n      this.selectedIds$\n    ]).pipe(\n      map(([datasources, selectedIds]) =>\n        DatasourceUtils.getAllDatasourcesWithUnknowns(datasources, selectedIds).filter((ds) =>\n          selectedIds.includes(ds.id)\n        )\n      )\n    );\n  }\n\n  ngOnInit() {\n    this.subscriptions.add(\n      this.selectedIds$.subscribe((selectedIds) => {\n        this.itemsChanged.emit(selectedIds);\n        this.detectChanges();\n      })\n    );\n    this.subscriptions.add(\n      this.searchOrCategoryChanged$.pipe(delay(50)).subscribe(() => {\n        this.detectChanges();\n      })\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    this.detectChanges();\n  }\n\n  updateDatasourceList(ids: string[]) {\n    this.selectedIds$.next(ids);\n    this.detectChanges();\n  }\n\n  detectChanges() {\n    this.cdr.detectChanges();\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    (searchOrCategoryChanged)=\"searchOrCategoryChanged$.next()\"\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"]}