@provoly/dashboard 0.21.10 → 0.22.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/dataset/components/dataset-detail/dataset-detail.component.mjs +1 -1
- package/esm2022/lib/core/components/select/select-a11y.service.mjs +84 -0
- package/esm2022/lib/core/components/select/select.component.mjs +39 -22
- package/esm2022/lib/core/components/select/select.module.mjs +5 -4
- package/esm2022/lib/core/model/automatic-grid-layout-definition.interface.mjs +2 -0
- package/esm2022/lib/core/model/manifest.interface.mjs +1 -1
- package/esm2022/lib/core/model/public-api.mjs +2 -1
- package/esm2022/lib/dashboard/components/dashboard.component.mjs +17 -11
- package/esm2022/lib/dashboard/components/widgets/header/widget-header.component.mjs +2 -4
- package/esm2022/lib/dashboard/components/widgets/widget-placement/widget-placement.utils.mjs +79 -125
- package/esm2022/lib/dashboard/dashboard.module.mjs +5 -8
- package/esm2022/lib/dashboard/store/dashboard.actions.mjs +1 -1
- package/esm2022/lib/dashboard/store/dashboard.effects.mjs +3 -3
- package/esm2022/lib/dashboard/store/dashboard.reducers.mjs +7 -5
- package/esm2022/lib/dashboard/store/dashboard.selectors.mjs +3 -4
- package/esm2022/presentation/components/add-edit-presentation/add-edit-presentation.component.mjs +4 -4
- package/esm2022/presentation/components/presentation.component.mjs +5 -6
- package/esm2022/search/search-home/search-home.component.mjs +1 -1
- package/esm2022/toolbox/components/select-grid-layout/select-grid-layout.component.mjs +6 -12
- package/esm2022/toolbox/style/css.component.mjs +2 -2
- package/fesm2022/provoly-dashboard-dataset.mjs +1 -1
- package/fesm2022/provoly-dashboard-dataset.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-presentation.mjs +7 -8
- package/fesm2022/provoly-dashboard-presentation.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-search.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-toolbox.mjs +7 -13
- package/fesm2022/provoly-dashboard-toolbox.mjs.map +1 -1
- package/fesm2022/provoly-dashboard.mjs +411 -413
- package/fesm2022/provoly-dashboard.mjs.map +1 -1
- package/lib/core/components/select/select-a11y.service.d.ts +11 -0
- package/lib/core/components/select/select.component.d.ts +15 -4
- package/lib/core/components/select/select.module.d.ts +6 -5
- package/lib/core/model/automatic-grid-layout-definition.interface.d.ts +9 -0
- package/lib/core/model/manifest.interface.d.ts +2 -2
- package/lib/core/model/public-api.d.ts +1 -0
- package/lib/dashboard/components/dashboard.component.d.ts +4 -3
- package/lib/dashboard/components/widgets/header/widget-header.component.d.ts +2 -2
- package/lib/dashboard/components/widgets/widget-placement/widget-placement.utils.d.ts +14 -30
- package/lib/dashboard/dashboard.module.d.ts +2 -7
- package/lib/dashboard/store/dashboard.actions.d.ts +3 -3
- package/lib/dashboard/store/dashboard.selectors.d.ts +2 -2
- package/package.json +37 -37
- package/presentation/components/add-edit-presentation/add-edit-presentation.component.d.ts +2 -2
- package/search/search-home/search-home.component.d.ts +1 -1
- package/styles/components/_a-page-loader.scss +2 -4
- package/styles-theme/components-theme/_a-page-loader.theme.scss +9 -0
- package/styles-theme/components-theme/_a-pry-select.theme.scss +4 -0
- package/styles-theme/main-theme.scss +1 -0
- package/toolbox/components/select-grid-layout/select-grid-layout.component.d.ts +4 -8
- package/toolbox/style/_o-select-grid-layout.scss +6 -1
- package/esm2022/lib/dashboard/store/proxy.utils.mjs +0 -61
- package/lib/dashboard/store/proxy.utils.d.ts +0 -24
|
@@ -62,11 +62,11 @@ export class PryPresentationComponent extends SubscriptionnerDirective {
|
|
|
62
62
|
this.search$,
|
|
63
63
|
this.inputSearch$.pipe(startWith(''))
|
|
64
64
|
]).pipe(map(([presentations, search, inputSearch]) => presentations.filter((presentations) => {
|
|
65
|
-
const [name, description] = [presentations.name.toLowerCase(), presentations.description
|
|
65
|
+
const [name, description] = [presentations.name.toLowerCase(), presentations.description?.toLowerCase()];
|
|
66
66
|
const [searchQuery, inputSearchQuery] = [search?.toLowerCase(), inputSearch?.toLowerCase()];
|
|
67
67
|
return !!searchQuery || !!inputSearchQuery
|
|
68
|
-
? (!!searchQuery && (name.includes(searchQuery) || description
|
|
69
|
-
(!!inputSearchQuery && (name.includes(inputSearchQuery) || description
|
|
68
|
+
? (!!searchQuery && (name.includes(searchQuery) || description?.includes(searchQuery))) ||
|
|
69
|
+
(!!inputSearchQuery && (name.includes(inputSearchQuery) || description?.includes(inputSearchQuery)))
|
|
70
70
|
: true;
|
|
71
71
|
})));
|
|
72
72
|
this.subscriptions.add(this.store.select(DashboardSelectors.presentation).subscribe((presentation) => {
|
|
@@ -93,7 +93,6 @@ export class PryPresentationComponent extends SubscriptionnerDirective {
|
|
|
93
93
|
presentation: {
|
|
94
94
|
id: v4(),
|
|
95
95
|
name: '',
|
|
96
|
-
description: '',
|
|
97
96
|
groups: [],
|
|
98
97
|
owner: true
|
|
99
98
|
},
|
|
@@ -174,7 +173,7 @@ export class PryPresentationComponent extends SubscriptionnerDirective {
|
|
|
174
173
|
this.store.dispatch(DashboardActions.saveManifest({
|
|
175
174
|
id: presentation.id ?? '',
|
|
176
175
|
name: presentation.name ?? '',
|
|
177
|
-
description: presentation.description
|
|
176
|
+
description: presentation.description,
|
|
178
177
|
image: presentation.image ?? '',
|
|
179
178
|
groups: this.accessGroups
|
|
180
179
|
}));
|
|
@@ -244,4 +243,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
244
243
|
}], search: [{
|
|
245
244
|
type: Input
|
|
246
245
|
}] } });
|
|
247
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"presentation.component.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/presentation/components/presentation.component.ts","../../../../../../projects/provoly/dashboard/presentation/components/presentation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { Component, ElementRef, Input, NgZone, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  DashboardActions,\n  DashboardGridLayout,\n  DashboardManifest,\n  DashboardSelectors,\n  ManifestDescription,\n  PryTitleService,\n  SubscriptionnerDirective,\n  ViewMode\n} from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, map, Observable, startWith } from 'rxjs';\nimport { v4 } from 'uuid';\n\n@Component({\n  selector: 'pry-presentation',\n  templateUrl: './presentation.component.html'\n})\nexport class PryPresentationComponent extends SubscriptionnerDirective {\n  manifests$: Observable<ManifestDescription[]>;\n  selectedPresentation$ = new BehaviorSubject<ManifestDescription | null>(null);\n  presentation?: ManifestDescription;\n  staticManifest$?: Observable<DashboardManifest>;\n  selectedMode: ViewMode = ViewMode.CATALOG;\n  modalOpened = false;\n  @ViewChild('modalActions', { read: TemplateRef }) templateModalActions!: TemplateRef<any>;\n  @ViewChild('modal', { read: TemplateRef }) template!: TemplateRef<any>;\n  @ViewChild('openModal') openModal!: ElementRef<HTMLButtonElement>;\n  @ViewChild('confirm') confirm!: ElementRef<HTMLButtonElement>;\n  @ViewChild('submit') submit!: ElementRef<HTMLButtonElement>;\n  @ViewChild('cross') cross!: ElementRef<HTMLButtonElement>;\n  @ViewChild('crossVisibility') crossVisibility!: ElementRef<HTMLButtonElement>;\n  @ViewChild('visibilityModal') visibilityModal!: ElementRef;\n  overlayRef?: OverlayRef;\n  accessGroups: string[] = [];\n  @Input() editionStartUrl: string = '/';\n  @Input() consultStartUrl: string = '/';\n  @Input() meAsOwner?: string;\n  ViewMode = ViewMode;\n  search$ = new BehaviorSubject('');\n  filteredPresentations$: Observable<ManifestDescription[]>;\n  listOfManifests$ = new BehaviorSubject<ManifestDescription[] | null>(null);\n  @Input() mode: 'theme' | 'meta' = 'meta';\n\n  @Input() set listOfManifests(manifests: ManifestDescription[] | null) {\n    this.listOfManifests$.next(Array.isArray(manifests) ? manifests : null);\n  }\n\n  @Input() hideToolbox = false;\n  inputSearch$ = new BehaviorSubject('');\n  @Input() set search(query: string) {\n    this.inputSearch$.next(query);\n  }\n\n  constructor(\n    protected store: Store<any>,\n    protected overlay: Overlay,\n    protected viewContainerRef: ViewContainerRef,\n    protected router: Router,\n    protected titleService: PryTitleService,\n    protected activatedRoute: ActivatedRoute,\n    protected ngZone: NgZone\n  ) {\n    super();\n    this.subscriptions.add(\n      this.activatedRoute.queryParams.subscribe((params) => {\n        if (params['create']) {\n          this.creation();\n        }\n      })\n    );\n    this.store.dispatch(DashboardActions.fetchManifestsList());\n    this.manifests$ = combineLatest([\n      this.store\n        .select(DashboardSelectors.manifestsList)\n        .pipe(\n          map((manifestList) =>\n            [...manifestList].sort((a, b) =>\n              a.modificationDate ? b.modificationDate.localeCompare(a.modificationDate) : 1\n            )\n          )\n        ),\n      this.listOfManifests$\n    ]).pipe(map(([dynamics, statics]) => statics ?? dynamics));\n\n    this.staticManifest$ = this.store\n      .select(DashboardSelectors.staticManifest)\n      .pipe(map((staticM) => staticM.windows[0]));\n    this.filteredPresentations$ = combineLatest([\n      this.manifests$,\n      this.search$,\n      this.inputSearch$.pipe(startWith(''))\n    ]).pipe(\n      map(([presentations, search, inputSearch]) =>\n        presentations.filter((presentations) => {\n          const [name, description] = [presentations.name.toLowerCase(), presentations.description.toLowerCase()];\n          const [searchQuery, inputSearchQuery] = [search?.toLowerCase(), inputSearch?.toLowerCase()];\n          return !!searchQuery || !!inputSearchQuery\n            ? (!!searchQuery && (name.includes(searchQuery) || description.includes(searchQuery))) ||\n                (!!inputSearchQuery && (name.includes(inputSearchQuery) || description.includes(inputSearchQuery)))\n            : true;\n        })\n      )\n    );\n    this.subscriptions.add(\n      this.store.select(DashboardSelectors.presentation).subscribe((presentation) => {\n        this.selectedMode = presentation?.viewMode ?? this.ViewMode.CATALOG;\n        this.selectedPresentation$.next(presentation.current ?? null);\n      })\n    );\n    this.titleService.changeTitle('@pry.presentation.title');\n  }\n\n  closeRestitution() {\n    this.selectedPresentation$.next(null);\n    this.selectedMode = ViewMode.CATALOG;\n    this.store.dispatch(DashboardActions.selectPresentation({ presentation: undefined, viewMode: ViewMode.CATALOG }));\n  }\n\n  fetch(presentation: ManifestDescription) {\n    this.store.dispatch(DashboardActions.loadPresentation({ presentation, viewMode: ViewMode.CONSULT }));\n    this.ngZone.run(() => {\n      this.router?.navigateByUrl(this.consultStartUrl);\n    });\n  }\n\n  creation() {\n    this.selectedMode = ViewMode.CREATION;\n    this.store.dispatch(DashboardActions.updateManifest({ manifest: { windows: [] }, selectedIds: [] }));\n    const newPresentation = {\n      presentation: {\n        id: v4(),\n        name: '',\n        description: '',\n        groups: [] as string[],\n        owner: true\n      } as ManifestDescription,\n      viewMode: ViewMode.CREATION\n    };\n    this.store.dispatch(DashboardActions.selectPresentation(newPresentation));\n    this.store.dispatch(DashboardActions.setGridLayout({ layout: DashboardGridLayout.FULL }));\n    this.store.dispatch(DashboardActions.updateDisplayOptions({ mode: ViewMode.CREATION }));\n  }\n\n  edit(presentation: ManifestDescription) {\n    this.selectedMode = ViewMode.EDITION;\n    this.selectedPresentation$.next(presentation);\n    this.titleService.changeTitle(presentation.name);\n    this.store.dispatch(DashboardActions.selectPresentation({ presentation, viewMode: ViewMode.EDITION }));\n    this.store.dispatch(DashboardActions.fetchStaticManifest({ id: presentation.id }));\n    this.store.dispatch(DashboardActions.updateDisplayOptions({ mode: ViewMode.EDITION }));\n    this.overlayRef?.dispose();\n    this.overlayRef = undefined;\n  }\n\n  delete(id: string) {\n    this.store.dispatch(DashboardActions.confirmManifestDeletion({ id }));\n    this.toggleModalActions();\n  }\n\n  toggleModalActions(presentation?: ManifestDescription | null, moreButton?: HTMLButtonElement) {\n    if (!this.overlayRef && presentation) {\n      this.selectedPresentation$.next(presentation);\n      this.store.dispatch(DashboardActions.selectPresentation({ presentation, viewMode: ViewMode.CATALOG }));\n      this.store.dispatch(DashboardActions.loadManifest({ id: presentation.id }));\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['m-context-menu-wrapper'],\n          backdropClass: 'backdrop'\n        })\n      );\n      this.overlayRef.backdropClick().subscribe(() => this.toggleModalActions(presentation));\n      this.overlayRef.attach(new TemplatePortal(this.templateModalActions, this.viewContainerRef));\n      const contextMenu = document.querySelector('div.m-context-menu') as HTMLDivElement;\n      if (!!contextMenu && moreButton) {\n        const rect = moreButton.getBoundingClientRect();\n        contextMenu.style.minWidth = '185px'\n        contextMenu.style.left = (rect?.left ?? 0) - (contextMenu?.clientWidth ?? 0) + 23 + 'px';\n        contextMenu.style.top = (rect?.top ?? 0) + 30 + 'px';\n      }\n    } else {\n      this.overlayRef?.dispose();\n      this.overlayRef = undefined;\n      this.selectedPresentation$.next(null);\n    }\n  }\n\n  toggleModal(presentation?: ManifestDescription | null) {\n    this.modalOpened = !this.modalOpened;\n    if (this.modalOpened && presentation) {\n      this.toggleModalActions();\n      this.selectedPresentation$.next(presentation);\n      this.store.dispatch(DashboardActions.selectPresentation({ presentation, viewMode: ViewMode.CATALOG }));\n      /* we need to load manifest in order to be able to save it later */\n      this.store.dispatch(DashboardActions.loadManifest({ id: presentation.id }));\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['o-modal-wrapper'],\n          backdropClass: 'backdrop'\n        })\n      );\n      this.overlayRef.backdropClick().subscribe(() => this.toggleModal(presentation));\n      this.overlayRef.attach(new TemplatePortal(this.template, this.viewContainerRef));\n      setTimeout(() => {\n        const focus = this.visibilityModal.nativeElement.children[0].children[1].firstElementChild as HTMLButtonElement;\n        focus.focus();\n      }, 10);\n    } else {\n      this.overlayRef?.dispose();\n      this.selectedPresentation$.next(null);\n      this.overlayRef = undefined;\n    }\n  }\n\n  changeVisibility(presentation?: ManifestDescription) {\n    if (presentation) {\n      this.store.dispatch(\n        DashboardActions.saveManifest({\n          id: presentation.id ?? '',\n          name: presentation.name ?? '',\n          description: presentation.description ?? '',\n          image: presentation.image ?? '',\n          groups: this.accessGroups\n        })\n      );\n    }\n    this.toggleModal(presentation);\n  }\n\n  focusCrossElement() {\n    if (this.crossVisibility) {\n      this.crossVisibility?.nativeElement.focus();\n    }\n    this.cross?.nativeElement.focus();\n  }\n\n  focusValidation() {\n    if (this.confirm) {\n      this.confirm.nativeElement.focus();\n    }\n    this.submit.nativeElement.focus();\n  }\n\n  editContent(selectedPresentation: ManifestDescription) {\n    this.store.dispatch(\n      DashboardActions.loadPresentation({ presentation: selectedPresentation, viewMode: ViewMode.EDITION })\n    );\n    this.ngZone.run(() => {\n      this.router?.navigateByUrl(this.consultStartUrl);\n    });\n  }\n}\n","<pry-presentation-css></pry-presentation-css>\n<div class=\"o-manifest-layout\" [ngSwitch]=\"selectedMode\">\n  <ng-container *ngSwitchDefault>\n    <div class=\"o-manifest-layout__toolbox\" [class.-u-hidden]=\"hideToolbox\">\n      <button\n        class=\"a-btn a-btn--primary a-btn--icon-text a-tooltip -tooltip-no-wrap\"\n        [attr.data-tooltip]=\"'@pry.presentation.create' | i18n\"\n        data-tooltip-position=\"bottom\"\n        type=\"button\"\n        (click)=\"creation()\"\n        *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'create' }\"\n      >\n        {{ '@pry.context.create' | i18n }}\n      </button>\n      <div>\n        <div class=\"o-manifest-layout__toolbox__search\">\n          <label id=\"catalog-search-label\" for=\"catalog-search\" class=\"u-visually-hidden\">\n            <span>{{ '@pry.toolbox.catalog.filter.name' | i18n }}</span>\n          </label>\n          <input\n            id=\"catalog-search\"\n            type=\"text\"\n            class=\"a-form-field\"\n            [placeholder]=\"'@pry.presentation.search' | i18n\"\n            [ngModel]=\"search$ | async\"\n            (ngModelChange)=\"this.search$.next($event)\"\n          />\n          <pry-icon class=\"search-icon\" iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n        </div>\n      </div>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <h1 class=\"a-h1\">{{ '@pry.presentation.title' | i18n }}</h1>\n      <div class=\"o-presentation-wrapper\">\n        <ul class=\"o-presentation\">\n          <li\n            class=\"o-presentation__item\"\n            *ngFor=\"let presentation of filteredPresentations$ | async; let index = index\"\n          >\n            <div class=\"o-presentation__item__header\">\n              <ng-container *ngIf=\"presentation.groups.length === 0\">\n                <pry-icon\n                  iconSvg=\"private\"\n                  class=\"is-private a-tooltip -tooltip-no-wrap\"\n                  [attr.data-tooltip]=\"'@pry.presentation.private' | i18n\"\n                  [height]=\"17\"\n                  [width]=\"17\"\n                ></pry-icon>\n              </ng-container>\n              <div\n                class=\"a-tooltip -tooltip-no-wrap\"\n                (click)=\"fetch(presentation)\"\n                [attr.data-tooltip]=\"'@pry.presentation.view' | i18n\"\n              >\n                <div class=\"o-presentation__item__image\">\n                  <img\n                    alt=\"\"\n                    [class.is-full-width]=\"presentation.cover\"\n                    [src]=\"presentation.image | getSecuredImage | async\"\n                  />\n                </div>\n              </div>\n              <ng-container *ngIf=\"presentation.owner\">\n                <div class=\"more-button\" *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'share' }\">\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--more a-tooltip -tooltip-no-wrap\"\n                    [id]=\"'more-button-' + index\"\n                    [attr.data-tooltip]=\"'@pry.restitution.more' | i18n\"\n                    (click)=\"$event.stopPropagation(); toggleModalActions(presentation, button)\"\n                    #button\n                  >\n                    <pry-icon [height]=\"25\" [width]=\"25\" iconSvg=\"more_horiz\"></pry-icon>\n                  </button>\n                </div>\n              </ng-container>\n            </div>\n            <div class=\"o-presentation__item__txt\" (click)=\"fetch(presentation)\">\n              <div class=\"o-presentation__item__title-container\" ellipsis textElementSelector=\".a-h3\">\n                <h3 class=\"a-h3\">{{ presentation.name }}</h3>\n              </div>\n              <div class=\"o-presentation__item__description-container\" ellipsis textElementSelector=\".a-p\">\n                <div class=\"o-presentation__item__description a-p\">\n                  {{ presentation.description }}\n                </div>\n              </div>\n              <p class=\"a-p -date\">{{ presentation.modificationDate | sinceDate }}</p>\n            </div>\n            <div\n              class=\"o-presentation__item__footer a-tooltip -tooltip-no-wrap\"\n              (click)=\"fetch(presentation)\"\n              [attr.data-tooltip]=\"'@pry.presentation.view' | i18n\"\n            >\n              <button class=\"a-btn\">\n                {{ '@pry.presentation.consult' | i18n }}\n                <pry-icon [width]=\"20\" [height]=\"20\" iconSvg=\"arrow_right\"></pry-icon>\n              </button>\n            </div>\n          </li>\n        </ul>\n      </div>\n    </div>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"ViewMode.CREATION\">\n    <pry-add-edit-presentation\n      [selectedPresentation]=\"selectedPresentation$ | async\"\n      (goBack)=\"closeRestitution()\"\n      [editionStartUrl]=\"editionStartUrl\"\n      [edition]=\"false\"\n      [mode]=\"mode\"\n    ></pry-add-edit-presentation>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"ViewMode.EDITION\">\n    <pry-add-edit-presentation\n      [selectedPresentation]=\"selectedPresentation$ | async\"\n      (goBack)=\"closeRestitution()\"\n      [editionStartUrl]=\"editionStartUrl\"\n      [edition]=\"true\"\n      [mode]=\"mode\"\n    ></pry-add-edit-presentation>\n  </ng-container>\n</div>\n\n<ng-template #modal>\n  <div\n    class=\"o-modal\"\n    #visibilityModal\n    role=\"dialog\"\n    aria-modal=\"true\"\n    aria-labelledby=\"dialog change visibility\"\n    *ngIf=\"selectedPresentation$ | async as selectedPresentation\"\n  >\n    <div class=\"o-modal__top\">\n      <div class=\"o-modal__top__title\">\n        <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.share' | i18n }}</h2>\n      </div>\n      <div class=\"o-modal__top__close\">\n        <button\n          class=\"a-btn a-btn--icon-only\"\n          #crossVisibility\n          (keydown.shift.tab)=\"focusValidation()\"\n          (click)=\"toggleModal()\"\n        >\n          <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n          <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n        </button>\n      </div>\n    </div>\n    <pry-group-share [ngModel]=\"selectedPresentation.groups\" (ngModelChange)=\"accessGroups = $event\"></pry-group-share>\n    <div class=\"m-btn-group\">\n      <button type=\"button\" class=\"a-btn a-btn--secondary\" (click)=\"toggleModal()\">\n        {{ '@pry.toolbox.manifest.close' | i18n }}\n      </button>\n      <button\n        type=\"submit\"\n        class=\"a-btn a-btn--primary\"\n        #submit\n        (keydown.tab)=\"focusCrossElement()\"\n        (click)=\"changeVisibility(selectedPresentation)\"\n      >\n        {{ '@pry.toolbox.manifest.check' | i18n }}\n      </button>\n    </div>\n  </div>\n</ng-template>\n<ng-template #modalActions>\n  <div class=\"m-context-menu\">\n    <ul\n      class=\"m-context-menu__list\"\n      role=\"dialog\"\n      aria-modal=\"true\"\n      aria-labelledby=\"dialog presentation options\"\n      *ngIf=\"selectedPresentation$ | async as selectedPresentation\"\n    >\n      <li class=\"m-context-menu__list__item\">\n        <button\n          class=\"a-btn -link-like\"\n          (click)=\"edit(selectedPresentation)\"\n          [disabled]=\"!selectedPresentation.owner\"\n          *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'edit' }\"\n        >\n          {{ '@pry.presentation.edition' | i18n }}\n        </button>\n      </li>\n      <li class=\"m-context-menu__list__item\">\n        <button\n          class=\"a-btn -link-like\"\n          (click)=\"editContent(selectedPresentation)\"\n          [disabled]=\"!selectedPresentation.owner\"\n          *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'edit' }\"\n        >\n          {{ '@pry.presentation.editionContent' | i18n }}\n        </button>\n      </li>\n      <li class=\"m-context-menu__list__item\">\n        <button\n          (click)=\"toggleModal(selectedPresentation)\"\n          class=\"a-btn -link-like\"\n          aria-haspopup=\"dialog\"\n          [disabled]=\"!selectedPresentation.owner\"\n          *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'share' }\"\n        >\n          {{ '@pry.presentation.share' | i18n }}\n        </button>\n      </li>\n      <li class=\"m-context-menu__list__item\">\n        <button\n          class=\"a-btn -link-like\"\n          #openModal\n          (click)=\"delete(selectedPresentation.id)\"\n          [disabled]=\"!selectedPresentation.owner\"\n          *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'delete' }\"\n        >\n          {{ '@pry.presentation.delete' | i18n }}\n        </button>\n      </li>\n    </ul>\n  </div>\n</ng-template>\n"]}
|
|
246
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"presentation.component.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/presentation/components/presentation.component.ts","../../../../../../projects/provoly/dashboard/presentation/components/presentation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { Component, ElementRef, Input, NgZone, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  DashboardActions,\n  DashboardGridLayout,\n  DashboardManifest,\n  DashboardSelectors,\n  ManifestDescription,\n  PryTitleService,\n  SubscriptionnerDirective,\n  ViewMode\n} from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, map, Observable, startWith } from 'rxjs';\nimport { v4 } from 'uuid';\n\n@Component({\n  selector: 'pry-presentation',\n  templateUrl: './presentation.component.html'\n})\nexport class PryPresentationComponent extends SubscriptionnerDirective {\n  manifests$: Observable<ManifestDescription[]>;\n  selectedPresentation$ = new BehaviorSubject<ManifestDescription | null>(null);\n  presentation?: ManifestDescription;\n  staticManifest$?: Observable<DashboardManifest>;\n  selectedMode: ViewMode = ViewMode.CATALOG;\n  modalOpened = false;\n  @ViewChild('modalActions', { read: TemplateRef }) templateModalActions!: TemplateRef<any>;\n  @ViewChild('modal', { read: TemplateRef }) template!: TemplateRef<any>;\n  @ViewChild('openModal') openModal!: ElementRef<HTMLButtonElement>;\n  @ViewChild('confirm') confirm!: ElementRef<HTMLButtonElement>;\n  @ViewChild('submit') submit!: ElementRef<HTMLButtonElement>;\n  @ViewChild('cross') cross!: ElementRef<HTMLButtonElement>;\n  @ViewChild('crossVisibility') crossVisibility!: ElementRef<HTMLButtonElement>;\n  @ViewChild('visibilityModal') visibilityModal!: ElementRef;\n  overlayRef?: OverlayRef;\n  accessGroups: string[] = [];\n  @Input() editionStartUrl: string = '/';\n  @Input() consultStartUrl: string = '/';\n  @Input() meAsOwner?: string;\n  ViewMode = ViewMode;\n  search$ = new BehaviorSubject('');\n  filteredPresentations$: Observable<ManifestDescription[]>;\n  listOfManifests$ = new BehaviorSubject<ManifestDescription[] | null>(null);\n  @Input() mode: 'theme' | 'meta' = 'meta';\n\n  @Input() set listOfManifests(manifests: ManifestDescription[] | null) {\n    this.listOfManifests$.next(Array.isArray(manifests) ? manifests : null);\n  }\n\n  @Input() hideToolbox = false;\n  inputSearch$ = new BehaviorSubject('');\n  @Input() set search(query: string) {\n    this.inputSearch$.next(query);\n  }\n\n  constructor(\n    protected store: Store<any>,\n    protected overlay: Overlay,\n    protected viewContainerRef: ViewContainerRef,\n    protected router: Router,\n    protected titleService: PryTitleService,\n    protected activatedRoute: ActivatedRoute,\n    protected ngZone: NgZone\n  ) {\n    super();\n    this.subscriptions.add(\n      this.activatedRoute.queryParams.subscribe((params) => {\n        if (params['create']) {\n          this.creation();\n        }\n      })\n    );\n    this.store.dispatch(DashboardActions.fetchManifestsList());\n    this.manifests$ = combineLatest([\n      this.store\n        .select(DashboardSelectors.manifestsList)\n        .pipe(\n          map((manifestList) =>\n            [...manifestList].sort((a, b) =>\n              a.modificationDate ? b.modificationDate.localeCompare(a.modificationDate) : 1\n            )\n          )\n        ),\n      this.listOfManifests$\n    ]).pipe(map(([dynamics, statics]) => statics ?? dynamics));\n\n    this.staticManifest$ = this.store\n      .select(DashboardSelectors.staticManifest)\n      .pipe(map((staticM) => staticM.windows[0]));\n    this.filteredPresentations$ = combineLatest([\n      this.manifests$,\n      this.search$,\n      this.inputSearch$.pipe(startWith(''))\n    ]).pipe(\n      map(([presentations, search, inputSearch]) =>\n        presentations.filter((presentations) => {\n          const [name, description] = [presentations.name.toLowerCase(), presentations.description?.toLowerCase()];\n          const [searchQuery, inputSearchQuery] = [search?.toLowerCase(), inputSearch?.toLowerCase()];\n          return !!searchQuery || !!inputSearchQuery\n            ? (!!searchQuery && (name.includes(searchQuery) || description?.includes(searchQuery))) ||\n                (!!inputSearchQuery && (name.includes(inputSearchQuery) || description?.includes(inputSearchQuery)))\n            : true;\n        })\n      )\n    );\n    this.subscriptions.add(\n      this.store.select(DashboardSelectors.presentation).subscribe((presentation) => {\n        this.selectedMode = presentation?.viewMode ?? this.ViewMode.CATALOG;\n        this.selectedPresentation$.next(presentation.current ?? null);\n      })\n    );\n    this.titleService.changeTitle('@pry.presentation.title');\n  }\n\n  closeRestitution() {\n    this.selectedPresentation$.next(null);\n    this.selectedMode = ViewMode.CATALOG;\n    this.store.dispatch(DashboardActions.selectPresentation({ presentation: undefined, viewMode: ViewMode.CATALOG }));\n  }\n\n  fetch(presentation: ManifestDescription) {\n    this.store.dispatch(DashboardActions.loadPresentation({ presentation, viewMode: ViewMode.CONSULT }));\n    this.ngZone.run(() => {\n      this.router?.navigateByUrl(this.consultStartUrl);\n    });\n  }\n\n  creation() {\n    this.selectedMode = ViewMode.CREATION;\n    this.store.dispatch(DashboardActions.updateManifest({ manifest: { windows: [] }, selectedIds: [] }));\n    const newPresentation = {\n      presentation: {\n        id: v4(),\n        name: '',\n        groups: [] as string[],\n        owner: true\n      } as ManifestDescription,\n      viewMode: ViewMode.CREATION\n    };\n    this.store.dispatch(DashboardActions.selectPresentation(newPresentation));\n    this.store.dispatch(DashboardActions.setGridLayout({ layout: DashboardGridLayout.FULL }));\n    this.store.dispatch(DashboardActions.updateDisplayOptions({ mode: ViewMode.CREATION }));\n  }\n\n  edit(presentation: ManifestDescription) {\n    this.selectedMode = ViewMode.EDITION;\n    this.selectedPresentation$.next(presentation);\n    this.titleService.changeTitle(presentation.name);\n    this.store.dispatch(DashboardActions.selectPresentation({ presentation, viewMode: ViewMode.EDITION }));\n    this.store.dispatch(DashboardActions.fetchStaticManifest({ id: presentation.id }));\n    this.store.dispatch(DashboardActions.updateDisplayOptions({ mode: ViewMode.EDITION }));\n    this.overlayRef?.dispose();\n    this.overlayRef = undefined;\n  }\n\n  delete(id: string) {\n    this.store.dispatch(DashboardActions.confirmManifestDeletion({ id }));\n    this.toggleModalActions();\n  }\n\n  toggleModalActions(presentation?: ManifestDescription | null, moreButton?: HTMLButtonElement) {\n    if (!this.overlayRef && presentation) {\n      this.selectedPresentation$.next(presentation);\n      this.store.dispatch(DashboardActions.selectPresentation({ presentation, viewMode: ViewMode.CATALOG }));\n      this.store.dispatch(DashboardActions.loadManifest({ id: presentation.id }));\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['m-context-menu-wrapper'],\n          backdropClass: 'backdrop'\n        })\n      );\n      this.overlayRef.backdropClick().subscribe(() => this.toggleModalActions(presentation));\n      this.overlayRef.attach(new TemplatePortal(this.templateModalActions, this.viewContainerRef));\n      const contextMenu = document.querySelector('div.m-context-menu') as HTMLDivElement;\n      if (!!contextMenu && moreButton) {\n        const rect = moreButton.getBoundingClientRect();\n        contextMenu.style.minWidth = '185px';\n        contextMenu.style.left = (rect?.left ?? 0) - (contextMenu?.clientWidth ?? 0) + 23 + 'px';\n        contextMenu.style.top = (rect?.top ?? 0) + 30 + 'px';\n      }\n    } else {\n      this.overlayRef?.dispose();\n      this.overlayRef = undefined;\n      this.selectedPresentation$.next(null);\n    }\n  }\n\n  toggleModal(presentation?: ManifestDescription | null) {\n    this.modalOpened = !this.modalOpened;\n    if (this.modalOpened && presentation) {\n      this.toggleModalActions();\n      this.selectedPresentation$.next(presentation);\n      this.store.dispatch(DashboardActions.selectPresentation({ presentation, viewMode: ViewMode.CATALOG }));\n      /* we need to load manifest in order to be able to save it later */\n      this.store.dispatch(DashboardActions.loadManifest({ id: presentation.id }));\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['o-modal-wrapper'],\n          backdropClass: 'backdrop'\n        })\n      );\n      this.overlayRef.backdropClick().subscribe(() => this.toggleModal(presentation));\n      this.overlayRef.attach(new TemplatePortal(this.template, this.viewContainerRef));\n      setTimeout(() => {\n        const focus = this.visibilityModal.nativeElement.children[0].children[1].firstElementChild as HTMLButtonElement;\n        focus.focus();\n      }, 10);\n    } else {\n      this.overlayRef?.dispose();\n      this.selectedPresentation$.next(null);\n      this.overlayRef = undefined;\n    }\n  }\n\n  changeVisibility(presentation?: ManifestDescription) {\n    if (presentation) {\n      this.store.dispatch(\n        DashboardActions.saveManifest({\n          id: presentation.id ?? '',\n          name: presentation.name ?? '',\n          description: presentation.description,\n          image: presentation.image ?? '',\n          groups: this.accessGroups\n        })\n      );\n    }\n    this.toggleModal(presentation);\n  }\n\n  focusCrossElement() {\n    if (this.crossVisibility) {\n      this.crossVisibility?.nativeElement.focus();\n    }\n    this.cross?.nativeElement.focus();\n  }\n\n  focusValidation() {\n    if (this.confirm) {\n      this.confirm.nativeElement.focus();\n    }\n    this.submit.nativeElement.focus();\n  }\n\n  editContent(selectedPresentation: ManifestDescription) {\n    this.store.dispatch(\n      DashboardActions.loadPresentation({ presentation: selectedPresentation, viewMode: ViewMode.EDITION })\n    );\n    this.ngZone.run(() => {\n      this.router?.navigateByUrl(this.consultStartUrl);\n    });\n  }\n}\n","<pry-presentation-css></pry-presentation-css>\n<div class=\"o-manifest-layout\" [ngSwitch]=\"selectedMode\">\n  <ng-container *ngSwitchDefault>\n    <div class=\"o-manifest-layout__toolbox\" [class.-u-hidden]=\"hideToolbox\">\n      <button\n        class=\"a-btn a-btn--primary a-btn--icon-text a-tooltip -tooltip-no-wrap\"\n        [attr.data-tooltip]=\"'@pry.presentation.create' | i18n\"\n        data-tooltip-position=\"bottom\"\n        type=\"button\"\n        (click)=\"creation()\"\n        *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'create' }\"\n      >\n        {{ '@pry.context.create' | i18n }}\n      </button>\n      <div>\n        <div class=\"o-manifest-layout__toolbox__search\">\n          <label id=\"catalog-search-label\" for=\"catalog-search\" class=\"u-visually-hidden\">\n            <span>{{ '@pry.toolbox.catalog.filter.name' | i18n }}</span>\n          </label>\n          <input\n            id=\"catalog-search\"\n            type=\"text\"\n            class=\"a-form-field\"\n            [placeholder]=\"'@pry.presentation.search' | i18n\"\n            [ngModel]=\"search$ | async\"\n            (ngModelChange)=\"this.search$.next($event)\"\n          />\n          <pry-icon class=\"search-icon\" iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n        </div>\n      </div>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <h1 class=\"a-h1\">{{ '@pry.presentation.title' | i18n }}</h1>\n      <div class=\"o-presentation-wrapper\">\n        <ul class=\"o-presentation\">\n          <li\n            class=\"o-presentation__item\"\n            *ngFor=\"let presentation of filteredPresentations$ | async; let index = index\"\n          >\n            <div class=\"o-presentation__item__header\">\n              <ng-container *ngIf=\"presentation.groups.length === 0\">\n                <pry-icon\n                  iconSvg=\"private\"\n                  class=\"is-private a-tooltip -tooltip-no-wrap\"\n                  [attr.data-tooltip]=\"'@pry.presentation.private' | i18n\"\n                  [height]=\"17\"\n                  [width]=\"17\"\n                ></pry-icon>\n              </ng-container>\n              <div\n                class=\"a-tooltip -tooltip-no-wrap\"\n                (click)=\"fetch(presentation)\"\n                [attr.data-tooltip]=\"'@pry.presentation.view' | i18n\"\n              >\n                <div class=\"o-presentation__item__image\">\n                  <img\n                    alt=\"\"\n                    [class.is-full-width]=\"presentation.cover\"\n                    [src]=\"presentation.image | getSecuredImage | async\"\n                  />\n                </div>\n              </div>\n              <ng-container *ngIf=\"presentation.owner\">\n                <div class=\"more-button\" *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'share' }\">\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--more a-tooltip -tooltip-no-wrap\"\n                    [id]=\"'more-button-' + index\"\n                    [attr.data-tooltip]=\"'@pry.restitution.more' | i18n\"\n                    (click)=\"$event.stopPropagation(); toggleModalActions(presentation, button)\"\n                    #button\n                  >\n                    <pry-icon [height]=\"25\" [width]=\"25\" iconSvg=\"more_horiz\"></pry-icon>\n                  </button>\n                </div>\n              </ng-container>\n            </div>\n            <div class=\"o-presentation__item__txt\" (click)=\"fetch(presentation)\">\n              <div class=\"o-presentation__item__title-container\" ellipsis textElementSelector=\".a-h3\">\n                <h3 class=\"a-h3\">{{ presentation.name }}</h3>\n              </div>\n              <div class=\"o-presentation__item__description-container\" ellipsis textElementSelector=\".a-p\">\n                <div class=\"o-presentation__item__description a-p\">\n                  {{ presentation.description }}\n                </div>\n              </div>\n              <p class=\"a-p -date\">{{ presentation.modificationDate | sinceDate }}</p>\n            </div>\n            <div\n              class=\"o-presentation__item__footer a-tooltip -tooltip-no-wrap\"\n              (click)=\"fetch(presentation)\"\n              [attr.data-tooltip]=\"'@pry.presentation.view' | i18n\"\n            >\n              <button class=\"a-btn\">\n                {{ '@pry.presentation.consult' | i18n }}\n                <pry-icon [width]=\"20\" [height]=\"20\" iconSvg=\"arrow_right\"></pry-icon>\n              </button>\n            </div>\n          </li>\n        </ul>\n      </div>\n    </div>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"ViewMode.CREATION\">\n    <pry-add-edit-presentation\n      [selectedPresentation]=\"selectedPresentation$ | async\"\n      (goBack)=\"closeRestitution()\"\n      [editionStartUrl]=\"editionStartUrl\"\n      [edition]=\"false\"\n      [mode]=\"mode\"\n    ></pry-add-edit-presentation>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"ViewMode.EDITION\">\n    <pry-add-edit-presentation\n      [selectedPresentation]=\"selectedPresentation$ | async\"\n      (goBack)=\"closeRestitution()\"\n      [editionStartUrl]=\"editionStartUrl\"\n      [edition]=\"true\"\n      [mode]=\"mode\"\n    ></pry-add-edit-presentation>\n  </ng-container>\n</div>\n\n<ng-template #modal>\n  <div\n    class=\"o-modal\"\n    #visibilityModal\n    role=\"dialog\"\n    aria-modal=\"true\"\n    aria-labelledby=\"dialog change visibility\"\n    *ngIf=\"selectedPresentation$ | async as selectedPresentation\"\n  >\n    <div class=\"o-modal__top\">\n      <div class=\"o-modal__top__title\">\n        <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.share' | i18n }}</h2>\n      </div>\n      <div class=\"o-modal__top__close\">\n        <button\n          class=\"a-btn a-btn--icon-only\"\n          #crossVisibility\n          (keydown.shift.tab)=\"focusValidation()\"\n          (click)=\"toggleModal()\"\n        >\n          <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n          <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n        </button>\n      </div>\n    </div>\n    <pry-group-share [ngModel]=\"selectedPresentation.groups\" (ngModelChange)=\"accessGroups = $event\"></pry-group-share>\n    <div class=\"m-btn-group\">\n      <button type=\"button\" class=\"a-btn a-btn--secondary\" (click)=\"toggleModal()\">\n        {{ '@pry.toolbox.manifest.close' | i18n }}\n      </button>\n      <button\n        type=\"submit\"\n        class=\"a-btn a-btn--primary\"\n        #submit\n        (keydown.tab)=\"focusCrossElement()\"\n        (click)=\"changeVisibility(selectedPresentation)\"\n      >\n        {{ '@pry.toolbox.manifest.check' | i18n }}\n      </button>\n    </div>\n  </div>\n</ng-template>\n<ng-template #modalActions>\n  <div class=\"m-context-menu\">\n    <ul\n      class=\"m-context-menu__list\"\n      role=\"dialog\"\n      aria-modal=\"true\"\n      aria-labelledby=\"dialog presentation options\"\n      *ngIf=\"selectedPresentation$ | async as selectedPresentation\"\n    >\n      <li class=\"m-context-menu__list__item\">\n        <button\n          class=\"a-btn -link-like\"\n          (click)=\"edit(selectedPresentation)\"\n          [disabled]=\"!selectedPresentation.owner\"\n          *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'edit' }\"\n        >\n          {{ '@pry.presentation.edition' | i18n }}\n        </button>\n      </li>\n      <li class=\"m-context-menu__list__item\">\n        <button\n          class=\"a-btn -link-like\"\n          (click)=\"editContent(selectedPresentation)\"\n          [disabled]=\"!selectedPresentation.owner\"\n          *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'edit' }\"\n        >\n          {{ '@pry.presentation.editionContent' | i18n }}\n        </button>\n      </li>\n      <li class=\"m-context-menu__list__item\">\n        <button\n          (click)=\"toggleModal(selectedPresentation)\"\n          class=\"a-btn -link-like\"\n          aria-haspopup=\"dialog\"\n          [disabled]=\"!selectedPresentation.owner\"\n          *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'share' }\"\n        >\n          {{ '@pry.presentation.share' | i18n }}\n        </button>\n      </li>\n      <li class=\"m-context-menu__list__item\">\n        <button\n          class=\"a-btn -link-like\"\n          #openModal\n          (click)=\"delete(selectedPresentation.id)\"\n          [disabled]=\"!selectedPresentation.owner\"\n          *pryAccess=\"{ module: 'dashboard', page: 'manifest', action: 'delete' }\"\n        >\n          {{ '@pry.presentation.delete' | i18n }}\n        </button>\n      </li>\n    </ul>\n  </div>\n</ng-template>\n"]}
|
|
@@ -196,4 +196,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
196
196
|
}], changeSearchCriteria: [{
|
|
197
197
|
type: Output
|
|
198
198
|
}] } });
|
|
199
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-home.component.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/search/search-home/search-home.component.ts","../../../../../../projects/provoly/dashboard/search/search-home/search-home.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ConnectedPosition, Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport {\n  ConfigActions,\n  DashboardActions,\n  DashboardGridLayout,\n  DashboardSelectors,\n  DataSourceActions,\n  DataSourceSelectors,\n  DatasourceUtils,\n  defaultMenuStructure,\n  FullTextSearchPayload,\n  NamedQuery,\n  NamedQueryTypes,\n  PryDialogConfirmComponent,\n  PryDialogConfirmData,\n  PryDialogService,\n  SearchActions,\n  WidgetLayout\n} from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, combineLatestWith, filter, Observable, Subscription, take } from 'rxjs';\nimport { debounceTime, map } from 'rxjs/operators';\nimport { PrySaveQueryComponent } from '../components/save-query/save-query.component';\nimport { SearchFulltextChange } from '../search-fulltext/search-fulltext/search-fulltext.component';\n\n@Component({\n  selector: 'pry-search-home',\n  templateUrl: './search-home.component.html'\n})\nexport class PrySearchHomeComponent implements OnInit, OnDestroy {\n  @ViewChild('templateSpot', { read: TemplateRef }) templateSpot!: TemplateRef<any>;\n  @ViewChild('templateRefresh', { read: TemplateRef }) templateRefresh!: TemplateRef<any>;\n\n  @Input() searchFulltextTpl?: TemplateRef<any>;\n  @Input() isMoreList = false;\n\n  @Output() changeListView = new EventEmitter<boolean>();\n  @Output() changeSearchCriteria = new EventEmitter<boolean>();\n\n  namedQueryList$?: Observable<NamedQuery[]>;\n  private subscription: Subscription = new Subscription();\n\n  namedQueriesUses$!: Observable<{ [p: string]: { windowIndex: number; type: string; layout: WidgetLayout }[] }>;\n  spotting$ = new BehaviorSubject<string>('');\n  spottingWidget$!: Observable<{ windowIndex: number; type: string; layout: WidgetLayout }[]>;\n  refreshOptions = [0, 10, 30, 60];\n\n  icons = {\n    map: 'share_location',\n    table: 'table_chart',\n    chart: 'show_chart',\n    graph: 'graph'\n  } as { [key: string]: string };\n\n  loadOpened: string | undefined;\n\n  private overlayRef?: OverlayRef;\n\n  readonly connectedPosition: ConnectedPosition = {\n    originX: 'start',\n    originY: 'bottom',\n    overlayX: 'start',\n    overlayY: 'top'\n  };\n  structure = defaultMenuStructure.map((items) => ({\n    ...items,\n    sub: items.sub.filter((s) => s.type !== 'iframe' && s.type !== 'detail')\n  }));\n\n  refreshRates$!: Observable<{ [p: string]: number }>;\n  refreshId: string = '';\n  deleteError$?: Observable<any>;\n  layout$!: Observable<DashboardGridLayout>;\n  DashboardGridLayout = DashboardGridLayout;\n\n  constructor(\n    private store: Store,\n    private overlay: Overlay,\n    private viewContainerRef: ViewContainerRef,\n    private pryDialog: PryDialogService\n  ) {}\n\n  ngOnInit() {\n    this.store.dispatch(DataSourceActions.load());\n    this.namedQueryList$ = this.store.select(DataSourceSelectors.getNamedQuerySorted);\n    this.namedQueriesUses$ = this.store.select(DashboardSelectors.namedQueriesUses);\n    this.spottingWidget$ = combineLatest([this.namedQueriesUses$, this.spotting$]).pipe(\n      map(([uses, spotting]) => uses[spotting] ?? []),\n      map((uses) => uses.map((use) => ({ ...use, windowIndex: use.windowIndex + 1 })))\n    );\n    this.refreshRates$ = this.store.select(DashboardSelectors.refreshRates);\n    this.layout$ = this.store.select(DashboardSelectors.gridLayout);\n    this.deleteError$ = this.store.select(DataSourceSelectors.errors).pipe(debounceTime(100));\n  }\n\n  onSearchNamedQuery(id: string) {\n    this.store.dispatch(DashboardActions.updateWidgetInPresentation({ id, widgetType: 'table' }));\n  }\n\n  onFavorite(id: string, isFavorite: boolean | undefined) {\n    if (!isFavorite) {\n      this.store.dispatch(DataSourceActions.namedQuery.addFavorite({ id }));\n    } else {\n      this.store.dispatch(DataSourceActions.namedQuery.deleteFavorite({ id }));\n    }\n  }\n\n  onSpot(id: string, $event: MouseEvent) {\n    this.spotting$.next(id);\n\n    if (!this.overlayRef) {\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: false,\n          panelClass: ['spot-rs']\n        })\n      );\n      this.store.dispatch(ConfigActions.addingOverlay({ id: this.constructor.name }));\n      this.overlayRef.attach(new TemplatePortal(this.templateSpot, this.viewContainerRef));\n      const spotElement = document.querySelector('.spot-rs') as HTMLDivElement;\n      if (!!spotElement) {\n        spotElement.style.left = $event.clientX - 10 + 'px';\n        spotElement.style.top = $event.clientY - 10 + 'px';\n      }\n    }\n  }\n\n  hideSpot() {\n    this.overlayRef?.dispose();\n    this.store.dispatch(ConfigActions.closeOverlay({ id: this.constructor.name }));\n    this.overlayRef = undefined;\n  }\n\n  onEdit(namedQuery: NamedQuery) {\n    this.store.dispatch(DataSourceActions.namedQuery.edit({ currentEdit: namedQuery }));\n  }\n\n  onChangeListView(isMoreList: boolean) {\n    this.changeListView.emit(isMoreList);\n  }\n\n  onSearchCriteria() {\n    this.changeSearchCriteria.emit();\n  }\n\n  loadWidget(id: string, sub: { icon: string; label: string; type: string }) {\n    this.store.dispatch(DashboardActions.updateWidgetInPresentation({ id, widgetType: sub.type }));\n    this.loadOpened = undefined;\n  }\n\n  onDelete(nq: NamedQuery) {\n    const data: PryDialogConfirmData = {\n      title: '@pry.search.namedQuery.delete',\n      actions: [\n        { id: 0, label: '@pry.toolbox.manifest.close', color: 'ghost' },\n        { id: 1, label: '@pry.search.namedQuery.delete' }\n      ]\n    };\n    const dialog = this.pryDialog.open(PryDialogConfirmComponent, {\n      data\n    });\n    this.subscription.add(\n      dialog.closeValue.pipe(take(1)).subscribe((action) => {\n        this.store.dispatch(ConfigActions.closeOverlay({ id: 'PryDialogConfirmComponent' }));\n        if (action.id === 1) {\n          this.store.dispatch(DataSourceActions.namedQuery.delete({ id: nq.id ?? '' }));\n          this.subscription.add(\n            this.deleteError$\n              ?.pipe(\n                combineLatestWith(this.store.select(DataSourceSelectors.isLoading)),\n                filter(([, isLoading]) => !isLoading),\n                take(1)\n              )\n              .subscribe(([error]) => {\n                if (error?.status === 403) {\n                  const data: PryDialogConfirmData = {\n                    title: '@pry.manifest.deleteError',\n                    actions: [{ id: 1, label: '@pry.toolbox.close' }]\n                  };\n                  const errorDialog = this.pryDialog.open(PryDialogConfirmComponent, {\n                    data\n                  });\n                  this.subscription.add(\n                    errorDialog.closeValue.pipe(take(1)).subscribe(() => {\n                      this.store.dispatch(ConfigActions.closeOverlay({ id: 'PryDialogConfirmComponent' }));\n                    })\n                  );\n                }\n              })\n          );\n        }\n      })\n    );\n  }\n\n  onRename(nq: NamedQuery) {\n    this.store.dispatch(DataSourceActions.namedQuery.openRename());\n    this.store.dispatch(DataSourceActions.namedQuery.edit({ currentEdit: nq }));\n    const save = false;\n    const type = DatasourceUtils.getTypeFromPayload(nq.request);\n    const data =\n      type === NamedQueryTypes.FULL_TEXT\n        ? { save, type, payload: this.extractPayload(nq.request as FullTextSearchPayload) }\n        : { save, type };\n    this.pryDialog.open(PrySaveQueryComponent, { data });\n  }\n\n  private extractPayload(payload: FullTextSearchPayload): SearchFulltextChange {\n    const { fullSearch, oClasses } = payload;\n    return { value: fullSearch.value, classes: oClasses ?? [] };\n  }\n\n  onRefresh(id: string, $event: MouseEvent) {\n    this.refreshId = id;\n\n    if (!this.overlayRef) {\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['refresh-rs']\n        })\n      );\n      this.store.dispatch(ConfigActions.addingOverlay({ id: this.constructor.name }));\n      this.overlayRef.attach(new TemplatePortal(this.templateRefresh, this.viewContainerRef));\n      this.overlayRef.backdropClick().subscribe((_) => this.hideSpot());\n      const refreshElement = document.querySelector('.refresh-rs') as HTMLDivElement;\n      const refresh = document.querySelector('.refreshbt') as HTMLDivElement;\n      if (!!refreshElement) {\n        const rect = refresh.getBoundingClientRect();\n        refreshElement.style.left = rect.left + rect.width + 10 + 'px';\n        refreshElement.style.top = rect.top + 137 + 'px';\n      }\n    }\n  }\n\n  selectRefresh($event: number) {\n    this.store.dispatch(DashboardActions.setRefreshRate({ id: this.refreshId ?? '', rate: $event }));\n    this.hideSpot();\n  }\n\n  refresh(id: string) {\n    this.store.dispatch(\n      SearchActions.getDatasourceItems({ id, excludeGeo: false, from: 'PrySearchHomeComponent.refresh()' })\n    );\n  }\n\n  ngOnDestroy(): void {\n    this.subscription.unsubscribe();\n  }\n}\n","<pry-search-css></pry-search-css>\n<div class=\"o-pry-search-home__named-query\">\n  <ng-container *ngIf=\"namedQueryList$ | async as namedQuery\">\n    <ng-container *ngIf=\"namedQuery.length > 0; else noNamedQuery\">\n      <div class=\"o-pry-search-home__named-query__card\">\n        <pry-expand-panel [open]=\"true\">\n          <pry-expand-panel-title>{{ '@pry.search.home.title' | i18n }}</pry-expand-panel-title>\n\n          <pry-card *ngFor=\"let nq of namedQuery.length > 1 && !isMoreList ? namedQuery.slice(0, 2) : namedQuery\">\n            <pry-card-header [marker]=\"true\">\n              <pry-card-icon>\n                <pry-nq-color-selector [datasource]=\"nq\" [disabled]=\"true\"></pry-nq-color-selector>\n                <img\n                  [alt]=\"nq.id | translateId : { type: 'datasource', output: 'name' } | async\"\n                  [height]=\"22\"\n                  [width]=\"22\"\n                  [src]=\"nq.id | translateId : { type: 'datasource', output: 'icon' } | async\"\n                />\n              </pry-card-icon>\n\n              <pry-card-title>\n                <div class=\"o-pry-card-title__text\" aria-describedby=\"infoTooltip_searchHome\">\n                  <div class=\"a-p o-pry-card-title__text__title\">{{ nq.name }}</div>\n                  <div class=\"a-p o-pry-card-title__text__description\" *ngIf=\"nq.description\">{{ nq.description }}</div>\n                </div>\n                <ng-template #infoTooltip>\n                  <div class=\"m-tooltip\" role=\"tooltip\" id=\"infoTooltip_searchHome\">\n                    <span class=\"m-tooltip__text\">\n                      {{ nq.name }}\n                    </span>\n                    <span class=\"m-tooltip__description\" *ngIf=\"nq.description\">\n                      {{ nq.description }}\n                    </span>\n                  </div>\n                </ng-template>\n                <pry-icon\n                  class=\"o-pry-card-title__pin\"\n                  *ngIf=\"nq.favorite\"\n                  [width]=\"18\"\n                  [height]=\"18\"\n                  aria-label=\"favorite\"\n                  iconSvg=\"epingle\"\n                ></pry-icon>\n\n                <button\n                  [attr.data-tooltip]=\"'@pry.search.home.showAssociatedWidget' | i18n\"\n                  data-tooltip-position=\"bottom\"\n                  class=\"a-tooltip a-btn a-btn--secondary -size-sm -override-tooltip-position\"\n                  (click)=\"onSearchNamedQuery(nq.id)\"\n                  *ngIf=\"(layout$ | async) !== DashboardGridLayout.MANUAL\"\n                >\n                  {{ '@pry.search.namedQuery.display' | i18n }}\n                  <span class=\"u-visually-hidden\">{{ '@pry.search.home.associatedWidget' | i18n }}</span>\n                </button>\n              </pry-card-title>\n\n              <pry-card-menu>\n                <div class=\"o-pry-card-menu__nav\">\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--icon-text o-pry-card-menu__nav__item\"\n                    (click)=\"onFavorite(nq.id, nq.favorite)\"\n                  >\n                    <pry-icon iconSvg=\"epingle\"></pry-icon>\n                    {{ (nq.favorite ? '@pry.search.namedQuery.noFavorite' : '@pry.search.namedQuery.favorite') | i18n }}\n                  </button>\n                  <pry-card-menu (click)=\"refresh(nq.id)\" class=\"refreshbt\">\n                    <button type=\"button\" class=\"a-btn a-btn--icon-text o-pry-card-menu__nav__item\">\n                      <pry-icon iconSvg=\"synchro\"></pry-icon>\n                      {{ '@pry.search.namedQuery.refreshData' | i18n }}\n                    </button>\n                  </pry-card-menu>\n                  <pry-card-menu *ngIf=\"(layout$ | async) !== DashboardGridLayout.MANUAL\">\n                    <button\n                      type=\"button\"\n                      class=\"a-btn a-btn--icon-text o-pry-card-menu__nav__item\"\n                      (click)=\"loadOpened = nq.id; $event.stopPropagation()\"\n                      cdkOverlayOrigin\n                      #triggerLoad=\"cdkOverlayOrigin\"\n                    >\n                      <pry-icon iconSvg=\"file_download\"></pry-icon>\n                      {{ '@pry.search.namedQuery.display' | i18n }}\n                      <pry-icon\n                        iconSvg=\"fleche_haut\"\n                        [ngStyle]=\"{ transform: 'rotate(90deg)', marginLeft: 'auto' }\"\n                      ></pry-icon>\n                    </button>\n\n                    <ng-template\n                      cdkConnectedOverlay\n                      [cdkConnectedOverlayOrigin]=\"triggerLoad\"\n                      [cdkConnectedOverlayOpen]=\"loadOpened === nq.id\"\n                      [cdkConnectedOverlayHasBackdrop]=\"true\"\n                      [cdkConnectedOverlayPositions]=\"[connectedPosition]\"\n                      cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n                      (backdropClick)=\"loadOpened = undefined\"\n                    >\n                      <div class=\"o-draggable-menu -search-home\">\n                        <ul class=\"o-draggable-menu__list\">\n                          <ng-container *ngFor=\"let menu of structure\">\n                            <li class=\"o-draggable-menu__list__item\">\n                              <button class=\"a-btn\" aria-haspopup=\"true\" aria-expanded=\"false\">\n                                <pry-icon [iconSvg]=\"menu.icon\"></pry-icon>\n                                {{ menu.label | i18n }}\n                              </button>\n\n                              <ul class=\"o-draggable-menu__list__submenu\">\n                                <ng-container *ngFor=\"let sub of menu.sub\">\n                                  <li class=\"o-draggable-menu__list__submenu__item\">\n                                    <button class=\"a-btn\" (click)=\"loadWidget(nq.id, sub)\">\n                                      <pry-icon [iconSvg]=\"sub.icon\"></pry-icon>\n                                      {{ sub.label | i18n }}\n                                    </button>\n                                  </li>\n                                </ng-container>\n                              </ul>\n                            </li>\n                          </ng-container>\n                        </ul>\n                      </div>\n                    </ng-template>\n                  </pry-card-menu>\n\n                  <pry-card-menu class=\"o-pry-card-menu__nav__item\">\n                    <pry-nq-color-selector [ngStyle]=\"{ width: '100%' }\" [datasource]=\"nq\"></pry-nq-color-selector>\n                  </pry-card-menu>\n\n                  <pry-card-menu (click)=\"onSpot(nq.id, $event)\">\n                    <button type=\"button\" class=\"a-btn a-btn--icon-text o-pry-card-menu__nav__item\">\n                      <pry-icon iconSvg=\"mode_clic\"></pry-icon>\n                      {{ '@pry.search.namedQuery.spot' | i18n }}\n                      <pry-icon\n                        iconSvg=\"fleche_haut\"\n                        [ngStyle]=\"{ transform: 'rotate(90deg)', marginLeft: 'auto' }\"\n                      ></pry-icon>\n                    </button>\n                  </pry-card-menu>\n                  <pry-card-menu (click)=\"onRefresh(nq.id, $event)\">\n                    <button type=\"button\" class=\"a-btn a-btn--icon-text o-pry-card-menu__nav__item\">\n                      <pry-icon iconSvg=\"history-line\"></pry-icon>\n                      {{ '@pry.search.namedQuery.refresh.title' | i18n }}\n                      <pry-icon\n                        iconSvg=\"fleche_haut\"\n                        [ngStyle]=\"{ transform: 'rotate(90deg)', marginLeft: 'auto' }\"\n                      ></pry-icon>\n                    </button>\n                  </pry-card-menu>\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--icon-text o-pry-card-menu__nav__item\"\n                    (click)=\"onDelete(nq)\"\n                    *ngIf=\"nq.owner\"\n                  >\n                    <pry-icon iconSvg=\"delete\"></pry-icon>\n                    {{ '@pry.search.namedQuery.delete' | i18n }}\n                  </button>\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--icon-text o-pry-card-menu__nav__item\"\n                    (click)=\"onRename(nq)\"\n                    *ngIf=\"nq.owner\"\n                  >\n                    <pry-icon iconSvg=\"renamed\"></pry-icon>\n                    {{ '@pry.search.namedQuery.rename' | i18n }}\n                  </button>\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--icon-text o-pry-card-menu__nav__item\"\n                    (click)=\"onEdit(nq)\"\n                    (keydown.tab)=\"hideSpot()\"\n                  >\n                    <pry-icon iconSvg=\"edit\"></pry-icon>\n                    {{ '@pry.search.namedQuery.edit' | i18n }}\n                  </button>\n                </div>\n              </pry-card-menu>\n            </pry-card-header>\n          </pry-card>\n        </pry-expand-panel>\n      </div>\n      <button\n        class=\"a-btn -link-like\"\n        aria-pressed=\"false\"\n        id=\"btn_view_more\"\n        *ngIf=\"namedQuery.length > 2\"\n        (click)=\"onChangeListView(isMoreList)\"\n      >\n        {{ isMoreList ? ('@pry.search.namedQuery.seeLess' | i18n) : ('@pry.search.namedQuery.seeMore' | i18n) }}\n      </button>\n    </ng-container>\n\n    <ng-template #noNamedQuery>\n      <p class=\"search-home__container-search\">{{ '@pry.search.namedQuery.emptyNamedQuery' | i18n }}</p>\n    </ng-template>\n  </ng-container>\n</div>\n\n<div class=\"o-pry-search-home__search\">\n  <h3 class=\"a-h3\">{{ '@pry.search.home.ssTitle' | i18n }}</h3>\n  <ng-container *ngIf=\"searchFulltextTpl\">\n    <ng-container [ngTemplateOutlet]=\"searchFulltextTpl\"></ng-container>\n    <p class=\"a-p o-pry-search-home__search__or\">{{ '@pry.search.home.or' | i18n }}</p>\n  </ng-container>\n  <button class=\"a-btn a-btn--primary -width-full\" (click)=\"onSearchCriteria()\">\n    <pry-icon [width]=\"20\" [height]=\"20\" iconSvg=\"search-criteria\"></pry-icon>\n    {{ '@pry.search.home.searchByCriteria' | i18n }}\n    <pry-icon iconSvg=\"arrow_right\"></pry-icon>\n  </button>\n</div>\n\n<ng-template #templateSpot>\n  <div (mouseleave)=\"hideSpot()\">\n    {{\n      ((spottingWidget$ | async)?.length ?? 0 > 0\n        ? '@pry.search.namedQuery.spotTitle'\n        : '@pry.search.namedQuery.noSpot'\n      ) | i18n : { length: (spottingWidget$ | async)?.length }\n    }}\n    <div *ngFor=\"let use of spottingWidget$ | async\" class=\"spot-line\">\n      <pry-icon [width]=\"20\" [height]=\"20\" [iconSvg]=\"icons[use.type]\"></pry-icon>\n      {{ '@pry.search.namedQuery.type.' + use.type | i18n }} - {{ '@pry.search.namedQuery.use' | i18n : use }}\n    </div>\n  </div>\n</ng-template>\n\n<ng-template #templateRefresh>\n  <div>\n    <button\n      *ngFor=\"let option of refreshOptions\"\n      class=\"refresh-line a-btn a-btn--icon-text -size-sm\"\n      (click)=\"selectRefresh(option)\"\n    >\n      <pry-icon\n        [width]=\"20\"\n        [height]=\"20\"\n        iconSvg=\"check\"\n        *ngIf=\"(((refreshRates$ | async) ?? {})[refreshId] ?? 0) === option\"\n      ></pry-icon>\n      {{ '@pry.search.namedQuery.refresh.' + option | i18n }}\n    </button>\n  </div>\n</ng-template>\n"]}
|
|
199
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-home.component.js","sourceRoot":"","sources":["../../../../../../projects/provoly/dashboard/search/search-home/search-home.component.ts","../../../../../../projects/provoly/dashboard/search/search-home/search-home.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ConnectedPosition, Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport {\n  ConfigActions,\n  DashboardActions,\n  DashboardGridLayout,\n  DashboardSelectors,\n  DataSourceActions,\n  DataSourceSelectors,\n  DatasourceUtils,\n  defaultMenuStructure,\n  FullTextSearchPayload,\n  NamedQuery,\n  NamedQueryTypes,\n  PryDialogConfirmComponent,\n  PryDialogConfirmData,\n  PryDialogService,\n  SearchActions,\n  WidgetLayout\n} from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, combineLatestWith, filter, Observable, Subscription, take } from 'rxjs';\nimport { debounceTime, map } from 'rxjs/operators';\nimport { PrySaveQueryComponent } from '../components/save-query/save-query.component';\nimport { SearchFulltextChange } from '../search-fulltext/search-fulltext/search-fulltext.component';\n\n@Component({\n  selector: 'pry-search-home',\n  templateUrl: './search-home.component.html'\n})\nexport class PrySearchHomeComponent implements OnInit, OnDestroy {\n  @ViewChild('templateSpot', { read: TemplateRef }) templateSpot!: TemplateRef<any>;\n  @ViewChild('templateRefresh', { read: TemplateRef }) templateRefresh!: TemplateRef<any>;\n\n  @Input() searchFulltextTpl?: TemplateRef<any>;\n  @Input() isMoreList = false;\n\n  @Output() changeListView = new EventEmitter<boolean>();\n  @Output() changeSearchCriteria = new EventEmitter<boolean>();\n\n  namedQueryList$?: Observable<NamedQuery[]>;\n  private subscription: Subscription = new Subscription();\n\n  namedQueriesUses$!: Observable<{ [p: string]: { windowIndex: number; type: string; layout: WidgetLayout }[] }>;\n  spotting$ = new BehaviorSubject<string>('');\n  spottingWidget$!: Observable<{ windowIndex: number; type: string; layout: WidgetLayout }[]>;\n  refreshOptions = [0, 10, 30, 60];\n\n  icons = {\n    map: 'share_location',\n    table: 'table_chart',\n    chart: 'show_chart',\n    graph: 'graph'\n  } as { [key: string]: string };\n\n  loadOpened: string | undefined;\n\n  private overlayRef?: OverlayRef;\n\n  readonly connectedPosition: ConnectedPosition = {\n    originX: 'start',\n    originY: 'bottom',\n    overlayX: 'start',\n    overlayY: 'top'\n  };\n  structure = defaultMenuStructure.map((items) => ({\n    ...items,\n    sub: items.sub.filter((s) => s.type !== 'iframe' && s.type !== 'detail')\n  }));\n\n  refreshRates$!: Observable<{ [p: string]: number }>;\n  refreshId: string = '';\n  deleteError$?: Observable<any>;\n  layout$!: Observable<string>;\n  DashboardGridLayout = DashboardGridLayout;\n\n  constructor(\n    private store: Store,\n    private overlay: Overlay,\n    private viewContainerRef: ViewContainerRef,\n    private pryDialog: PryDialogService\n  ) {}\n\n  ngOnInit() {\n    this.store.dispatch(DataSourceActions.load());\n    this.namedQueryList$ = this.store.select(DataSourceSelectors.getNamedQuerySorted);\n    this.namedQueriesUses$ = this.store.select(DashboardSelectors.namedQueriesUses);\n    this.spottingWidget$ = combineLatest([this.namedQueriesUses$, this.spotting$]).pipe(\n      map(([uses, spotting]) => uses[spotting] ?? []),\n      map((uses) => uses.map((use) => ({ ...use, windowIndex: use.windowIndex + 1 })))\n    );\n    this.refreshRates$ = this.store.select(DashboardSelectors.refreshRates);\n    this.layout$ = this.store.select(DashboardSelectors.gridLayout);\n    this.deleteError$ = this.store.select(DataSourceSelectors.errors).pipe(debounceTime(100));\n  }\n\n  onSearchNamedQuery(id: string) {\n    this.store.dispatch(DashboardActions.updateWidgetInPresentation({ id, widgetType: 'table' }));\n  }\n\n  onFavorite(id: string, isFavorite: boolean | undefined) {\n    if (!isFavorite) {\n      this.store.dispatch(DataSourceActions.namedQuery.addFavorite({ id }));\n    } else {\n      this.store.dispatch(DataSourceActions.namedQuery.deleteFavorite({ id }));\n    }\n  }\n\n  onSpot(id: string, $event: MouseEvent) {\n    this.spotting$.next(id);\n\n    if (!this.overlayRef) {\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: false,\n          panelClass: ['spot-rs']\n        })\n      );\n      this.store.dispatch(ConfigActions.addingOverlay({ id: this.constructor.name }));\n      this.overlayRef.attach(new TemplatePortal(this.templateSpot, this.viewContainerRef));\n      const spotElement = document.querySelector('.spot-rs') as HTMLDivElement;\n      if (!!spotElement) {\n        spotElement.style.left = $event.clientX - 10 + 'px';\n        spotElement.style.top = $event.clientY - 10 + 'px';\n      }\n    }\n  }\n\n  hideSpot() {\n    this.overlayRef?.dispose();\n    this.store.dispatch(ConfigActions.closeOverlay({ id: this.constructor.name }));\n    this.overlayRef = undefined;\n  }\n\n  onEdit(namedQuery: NamedQuery) {\n    this.store.dispatch(DataSourceActions.namedQuery.edit({ currentEdit: namedQuery }));\n  }\n\n  onChangeListView(isMoreList: boolean) {\n    this.changeListView.emit(isMoreList);\n  }\n\n  onSearchCriteria() {\n    this.changeSearchCriteria.emit();\n  }\n\n  loadWidget(id: string, sub: { icon: string; label: string; type: string }) {\n    this.store.dispatch(DashboardActions.updateWidgetInPresentation({ id, widgetType: sub.type }));\n    this.loadOpened = undefined;\n  }\n\n  onDelete(nq: NamedQuery) {\n    const data: PryDialogConfirmData = {\n      title: '@pry.search.namedQuery.delete',\n      actions: [\n        { id: 0, label: '@pry.toolbox.manifest.close', color: 'ghost' },\n        { id: 1, label: '@pry.search.namedQuery.delete' }\n      ]\n    };\n    const dialog = this.pryDialog.open(PryDialogConfirmComponent, {\n      data\n    });\n    this.subscription.add(\n      dialog.closeValue.pipe(take(1)).subscribe((action) => {\n        this.store.dispatch(ConfigActions.closeOverlay({ id: 'PryDialogConfirmComponent' }));\n        if (action.id === 1) {\n          this.store.dispatch(DataSourceActions.namedQuery.delete({ id: nq.id ?? '' }));\n          this.subscription.add(\n            this.deleteError$\n              ?.pipe(\n                combineLatestWith(this.store.select(DataSourceSelectors.isLoading)),\n                filter(([, isLoading]) => !isLoading),\n                take(1)\n              )\n              .subscribe(([error]) => {\n                if (error?.status === 403) {\n                  const data: PryDialogConfirmData = {\n                    title: '@pry.manifest.deleteError',\n                    actions: [{ id: 1, label: '@pry.toolbox.close' }]\n                  };\n                  const errorDialog = this.pryDialog.open(PryDialogConfirmComponent, {\n                    data\n                  });\n                  this.subscription.add(\n                    errorDialog.closeValue.pipe(take(1)).subscribe(() => {\n                      this.store.dispatch(ConfigActions.closeOverlay({ id: 'PryDialogConfirmComponent' }));\n                    })\n                  );\n                }\n              })\n          );\n        }\n      })\n    );\n  }\n\n  onRename(nq: NamedQuery) {\n    this.store.dispatch(DataSourceActions.namedQuery.openRename());\n    this.store.dispatch(DataSourceActions.namedQuery.edit({ currentEdit: nq }));\n    const save = false;\n    const type = DatasourceUtils.getTypeFromPayload(nq.request);\n    const data =\n      type === NamedQueryTypes.FULL_TEXT\n        ? { save, type, payload: this.extractPayload(nq.request as FullTextSearchPayload) }\n        : { save, type };\n    this.pryDialog.open(PrySaveQueryComponent, { data });\n  }\n\n  private extractPayload(payload: FullTextSearchPayload): SearchFulltextChange {\n    const { fullSearch, oClasses } = payload;\n    return { value: fullSearch.value, classes: oClasses ?? [] };\n  }\n\n  onRefresh(id: string, $event: MouseEvent) {\n    this.refreshId = id;\n\n    if (!this.overlayRef) {\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['refresh-rs']\n        })\n      );\n      this.store.dispatch(ConfigActions.addingOverlay({ id: this.constructor.name }));\n      this.overlayRef.attach(new TemplatePortal(this.templateRefresh, this.viewContainerRef));\n      this.overlayRef.backdropClick().subscribe((_) => this.hideSpot());\n      const refreshElement = document.querySelector('.refresh-rs') as HTMLDivElement;\n      const refresh = document.querySelector('.refreshbt') as HTMLDivElement;\n      if (!!refreshElement) {\n        const rect = refresh.getBoundingClientRect();\n        refreshElement.style.left = rect.left + rect.width + 10 + 'px';\n        refreshElement.style.top = rect.top + 137 + 'px';\n      }\n    }\n  }\n\n  selectRefresh($event: number) {\n    this.store.dispatch(DashboardActions.setRefreshRate({ id: this.refreshId ?? '', rate: $event }));\n    this.hideSpot();\n  }\n\n  refresh(id: string) {\n    this.store.dispatch(\n      SearchActions.getDatasourceItems({ id, excludeGeo: false, from: 'PrySearchHomeComponent.refresh()' })\n    );\n  }\n\n  ngOnDestroy(): void {\n    this.subscription.unsubscribe();\n  }\n}\n","<pry-search-css></pry-search-css>\n<div class=\"o-pry-search-home__named-query\">\n  <ng-container *ngIf=\"namedQueryList$ | async as namedQuery\">\n    <ng-container *ngIf=\"namedQuery.length > 0; else noNamedQuery\">\n      <div class=\"o-pry-search-home__named-query__card\">\n        <pry-expand-panel [open]=\"true\">\n          <pry-expand-panel-title>{{ '@pry.search.home.title' | i18n }}</pry-expand-panel-title>\n\n          <pry-card *ngFor=\"let nq of namedQuery.length > 1 && !isMoreList ? namedQuery.slice(0, 2) : namedQuery\">\n            <pry-card-header [marker]=\"true\">\n              <pry-card-icon>\n                <pry-nq-color-selector [datasource]=\"nq\" [disabled]=\"true\"></pry-nq-color-selector>\n                <img\n                  [alt]=\"nq.id | translateId : { type: 'datasource', output: 'name' } | async\"\n                  [height]=\"22\"\n                  [width]=\"22\"\n                  [src]=\"nq.id | translateId : { type: 'datasource', output: 'icon' } | async\"\n                />\n              </pry-card-icon>\n\n              <pry-card-title>\n                <div class=\"o-pry-card-title__text\" aria-describedby=\"infoTooltip_searchHome\">\n                  <div class=\"a-p o-pry-card-title__text__title\">{{ nq.name }}</div>\n                  <div class=\"a-p o-pry-card-title__text__description\" *ngIf=\"nq.description\">{{ nq.description }}</div>\n                </div>\n                <ng-template #infoTooltip>\n                  <div class=\"m-tooltip\" role=\"tooltip\" id=\"infoTooltip_searchHome\">\n                    <span class=\"m-tooltip__text\">\n                      {{ nq.name }}\n                    </span>\n                    <span class=\"m-tooltip__description\" *ngIf=\"nq.description\">\n                      {{ nq.description }}\n                    </span>\n                  </div>\n                </ng-template>\n                <pry-icon\n                  class=\"o-pry-card-title__pin\"\n                  *ngIf=\"nq.favorite\"\n                  [width]=\"18\"\n                  [height]=\"18\"\n                  aria-label=\"favorite\"\n                  iconSvg=\"epingle\"\n                ></pry-icon>\n\n                <button\n                  [attr.data-tooltip]=\"'@pry.search.home.showAssociatedWidget' | i18n\"\n                  data-tooltip-position=\"bottom\"\n                  class=\"a-tooltip a-btn a-btn--secondary -size-sm -override-tooltip-position\"\n                  (click)=\"onSearchNamedQuery(nq.id)\"\n                  *ngIf=\"(layout$ | async) !== DashboardGridLayout.MANUAL\"\n                >\n                  {{ '@pry.search.namedQuery.display' | i18n }}\n                  <span class=\"u-visually-hidden\">{{ '@pry.search.home.associatedWidget' | i18n }}</span>\n                </button>\n              </pry-card-title>\n\n              <pry-card-menu>\n                <div class=\"o-pry-card-menu__nav\">\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--icon-text o-pry-card-menu__nav__item\"\n                    (click)=\"onFavorite(nq.id, nq.favorite)\"\n                  >\n                    <pry-icon iconSvg=\"epingle\"></pry-icon>\n                    {{ (nq.favorite ? '@pry.search.namedQuery.noFavorite' : '@pry.search.namedQuery.favorite') | i18n }}\n                  </button>\n                  <pry-card-menu (click)=\"refresh(nq.id)\" class=\"refreshbt\">\n                    <button type=\"button\" class=\"a-btn a-btn--icon-text o-pry-card-menu__nav__item\">\n                      <pry-icon iconSvg=\"synchro\"></pry-icon>\n                      {{ '@pry.search.namedQuery.refreshData' | i18n }}\n                    </button>\n                  </pry-card-menu>\n                  <pry-card-menu *ngIf=\"(layout$ | async) !== DashboardGridLayout.MANUAL\">\n                    <button\n                      type=\"button\"\n                      class=\"a-btn a-btn--icon-text o-pry-card-menu__nav__item\"\n                      (click)=\"loadOpened = nq.id; $event.stopPropagation()\"\n                      cdkOverlayOrigin\n                      #triggerLoad=\"cdkOverlayOrigin\"\n                    >\n                      <pry-icon iconSvg=\"file_download\"></pry-icon>\n                      {{ '@pry.search.namedQuery.display' | i18n }}\n                      <pry-icon\n                        iconSvg=\"fleche_haut\"\n                        [ngStyle]=\"{ transform: 'rotate(90deg)', marginLeft: 'auto' }\"\n                      ></pry-icon>\n                    </button>\n\n                    <ng-template\n                      cdkConnectedOverlay\n                      [cdkConnectedOverlayOrigin]=\"triggerLoad\"\n                      [cdkConnectedOverlayOpen]=\"loadOpened === nq.id\"\n                      [cdkConnectedOverlayHasBackdrop]=\"true\"\n                      [cdkConnectedOverlayPositions]=\"[connectedPosition]\"\n                      cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n                      (backdropClick)=\"loadOpened = undefined\"\n                    >\n                      <div class=\"o-draggable-menu -search-home\">\n                        <ul class=\"o-draggable-menu__list\">\n                          <ng-container *ngFor=\"let menu of structure\">\n                            <li class=\"o-draggable-menu__list__item\">\n                              <button class=\"a-btn\" aria-haspopup=\"true\" aria-expanded=\"false\">\n                                <pry-icon [iconSvg]=\"menu.icon\"></pry-icon>\n                                {{ menu.label | i18n }}\n                              </button>\n\n                              <ul class=\"o-draggable-menu__list__submenu\">\n                                <ng-container *ngFor=\"let sub of menu.sub\">\n                                  <li class=\"o-draggable-menu__list__submenu__item\">\n                                    <button class=\"a-btn\" (click)=\"loadWidget(nq.id, sub)\">\n                                      <pry-icon [iconSvg]=\"sub.icon\"></pry-icon>\n                                      {{ sub.label | i18n }}\n                                    </button>\n                                  </li>\n                                </ng-container>\n                              </ul>\n                            </li>\n                          </ng-container>\n                        </ul>\n                      </div>\n                    </ng-template>\n                  </pry-card-menu>\n\n                  <pry-card-menu class=\"o-pry-card-menu__nav__item\">\n                    <pry-nq-color-selector [ngStyle]=\"{ width: '100%' }\" [datasource]=\"nq\"></pry-nq-color-selector>\n                  </pry-card-menu>\n\n                  <pry-card-menu (click)=\"onSpot(nq.id, $event)\">\n                    <button type=\"button\" class=\"a-btn a-btn--icon-text o-pry-card-menu__nav__item\">\n                      <pry-icon iconSvg=\"mode_clic\"></pry-icon>\n                      {{ '@pry.search.namedQuery.spot' | i18n }}\n                      <pry-icon\n                        iconSvg=\"fleche_haut\"\n                        [ngStyle]=\"{ transform: 'rotate(90deg)', marginLeft: 'auto' }\"\n                      ></pry-icon>\n                    </button>\n                  </pry-card-menu>\n                  <pry-card-menu (click)=\"onRefresh(nq.id, $event)\">\n                    <button type=\"button\" class=\"a-btn a-btn--icon-text o-pry-card-menu__nav__item\">\n                      <pry-icon iconSvg=\"history-line\"></pry-icon>\n                      {{ '@pry.search.namedQuery.refresh.title' | i18n }}\n                      <pry-icon\n                        iconSvg=\"fleche_haut\"\n                        [ngStyle]=\"{ transform: 'rotate(90deg)', marginLeft: 'auto' }\"\n                      ></pry-icon>\n                    </button>\n                  </pry-card-menu>\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--icon-text o-pry-card-menu__nav__item\"\n                    (click)=\"onDelete(nq)\"\n                    *ngIf=\"nq.owner\"\n                  >\n                    <pry-icon iconSvg=\"delete\"></pry-icon>\n                    {{ '@pry.search.namedQuery.delete' | i18n }}\n                  </button>\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--icon-text o-pry-card-menu__nav__item\"\n                    (click)=\"onRename(nq)\"\n                    *ngIf=\"nq.owner\"\n                  >\n                    <pry-icon iconSvg=\"renamed\"></pry-icon>\n                    {{ '@pry.search.namedQuery.rename' | i18n }}\n                  </button>\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--icon-text o-pry-card-menu__nav__item\"\n                    (click)=\"onEdit(nq)\"\n                    (keydown.tab)=\"hideSpot()\"\n                  >\n                    <pry-icon iconSvg=\"edit\"></pry-icon>\n                    {{ '@pry.search.namedQuery.edit' | i18n }}\n                  </button>\n                </div>\n              </pry-card-menu>\n            </pry-card-header>\n          </pry-card>\n        </pry-expand-panel>\n      </div>\n      <button\n        class=\"a-btn -link-like\"\n        aria-pressed=\"false\"\n        id=\"btn_view_more\"\n        *ngIf=\"namedQuery.length > 2\"\n        (click)=\"onChangeListView(isMoreList)\"\n      >\n        {{ isMoreList ? ('@pry.search.namedQuery.seeLess' | i18n) : ('@pry.search.namedQuery.seeMore' | i18n) }}\n      </button>\n    </ng-container>\n\n    <ng-template #noNamedQuery>\n      <p class=\"search-home__container-search\">{{ '@pry.search.namedQuery.emptyNamedQuery' | i18n }}</p>\n    </ng-template>\n  </ng-container>\n</div>\n\n<div class=\"o-pry-search-home__search\">\n  <h3 class=\"a-h3\">{{ '@pry.search.home.ssTitle' | i18n }}</h3>\n  <ng-container *ngIf=\"searchFulltextTpl\">\n    <ng-container [ngTemplateOutlet]=\"searchFulltextTpl\"></ng-container>\n    <p class=\"a-p o-pry-search-home__search__or\">{{ '@pry.search.home.or' | i18n }}</p>\n  </ng-container>\n  <button class=\"a-btn a-btn--primary -width-full\" (click)=\"onSearchCriteria()\">\n    <pry-icon [width]=\"20\" [height]=\"20\" iconSvg=\"search-criteria\"></pry-icon>\n    {{ '@pry.search.home.searchByCriteria' | i18n }}\n    <pry-icon iconSvg=\"arrow_right\"></pry-icon>\n  </button>\n</div>\n\n<ng-template #templateSpot>\n  <div (mouseleave)=\"hideSpot()\">\n    {{\n      ((spottingWidget$ | async)?.length ?? 0 > 0\n        ? '@pry.search.namedQuery.spotTitle'\n        : '@pry.search.namedQuery.noSpot'\n      ) | i18n : { length: (spottingWidget$ | async)?.length }\n    }}\n    <div *ngFor=\"let use of spottingWidget$ | async\" class=\"spot-line\">\n      <pry-icon [width]=\"20\" [height]=\"20\" [iconSvg]=\"icons[use.type]\"></pry-icon>\n      {{ '@pry.search.namedQuery.type.' + use.type | i18n }} - {{ '@pry.search.namedQuery.use' | i18n : use }}\n    </div>\n  </div>\n</ng-template>\n\n<ng-template #templateRefresh>\n  <div>\n    <button\n      *ngFor=\"let option of refreshOptions\"\n      class=\"refresh-line a-btn a-btn--icon-text -size-sm\"\n      (click)=\"selectRefresh(option)\"\n    >\n      <pry-icon\n        [width]=\"20\"\n        [height]=\"20\"\n        iconSvg=\"check\"\n        *ngIf=\"(((refreshRates$ | async) ?? {})[refreshId] ?? 0) === option\"\n      ></pry-icon>\n      {{ '@pry.search.namedQuery.refresh.' + option | i18n }}\n    </button>\n  </div>\n</ng-template>\n"]}
|
|
@@ -20,15 +20,9 @@ export class SelectGridLayoutComponent extends ToolboxActionComponent {
|
|
|
20
20
|
this.canDispatch = false;
|
|
21
21
|
this.modalOpened = false;
|
|
22
22
|
this.subscriptions.add(this.store.select(DashboardSelectors.gridLayout).subscribe((layout) => (this.chosenLayout = layout)));
|
|
23
|
-
this.availableLayouts$ = this.store.select(DashboardSelectors.windowManifest).pipe(map((manifest) => WidgetPlacementUtils.
|
|
24
|
-
.
|
|
25
|
-
|
|
26
|
-
})
|
|
27
|
-
.map((layout) => ({
|
|
28
|
-
value: layout.key,
|
|
29
|
-
translation: '@pry.toolbox.layout.' + layout.key,
|
|
30
|
-
image: layout.image
|
|
31
|
-
}))));
|
|
23
|
+
this.availableLayouts$ = this.store.select(DashboardSelectors.windowManifest).pipe(map((manifest) => WidgetPlacementUtils.layouts.filter((layout) => {
|
|
24
|
+
return layout.places.length === 0 || layout.places.length >= (manifest.widgets ?? []).length;
|
|
25
|
+
})));
|
|
32
26
|
setTimeout(() => {
|
|
33
27
|
this.canDispatch = true;
|
|
34
28
|
}, 100);
|
|
@@ -78,11 +72,11 @@ export class SelectGridLayoutComponent extends ToolboxActionComponent {
|
|
|
78
72
|
this.toggleGridChoiceModal();
|
|
79
73
|
}
|
|
80
74
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SelectGridLayoutComponent, deps: [{ token: i1.Store }, { token: i2.Overlay }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
81
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SelectGridLayoutComponent, selector: "pry-select-grid-layout", viewQueries: [{ propertyName: "template", first: true, predicate: ["template"], descendants: true, read: TemplateRef }, { propertyName: "firstButton", first: true, predicate: ["firstButton"], descendants: true }, { propertyName: "openModal", first: true, predicate: ["openModal"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<pry-toolbox-css></pry-toolbox-css>\n<div [attr.aria-expanded]=\"modalOpened\" aria-controls=\"grid-layout\">\n <button type=\"button\" #openModal class=\"a-btn a-btn--secondary -size-md\" (click)=\"toggleGridChoiceModal()\">\n <ng-container *ngIf=\"displayLabels\">\n {{ '@pry.toolbox.chooseGrid' | i18n }}\n </ng-container>\n </button>\n</div>\n<ng-template #template>\n <div\n class=\"o-modal\"\n (click)=\"$event.stopPropagation()\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"dialog_title\"\n id=\"grid-layout\"\n (keydown.escape)=\"toggleGridChoiceModal()\"\n cdkTrapFocus\n [cdkTrapFocusAutoCapture]=\"true\"\n >\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.chooseGrid' | i18n }}</h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" (click)=\"toggleGridChoiceModal()\">\n <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n </button>\n </div>\n </div>\n <div class=\"o-select-grid-layout-wrapper\">\n <ul class=\"o-select-grid-layout\">\n <li *ngFor=\"let layout of availableLayouts$ | async\" class=\"o-select-grid-layout__item\">\n <button\n type=\"button\"\n #firstButton\n class=\"a-btn\"\n [attr.aria-pressed]=\"chosenLayout === layout.
|
|
75
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SelectGridLayoutComponent, selector: "pry-select-grid-layout", viewQueries: [{ propertyName: "template", first: true, predicate: ["template"], descendants: true, read: TemplateRef }, { propertyName: "firstButton", first: true, predicate: ["firstButton"], descendants: true }, { propertyName: "openModal", first: true, predicate: ["openModal"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<pry-toolbox-css></pry-toolbox-css>\n<div [attr.aria-expanded]=\"modalOpened\" aria-controls=\"grid-layout\">\n <button type=\"button\" #openModal class=\"a-btn a-btn--secondary -size-md\" (click)=\"toggleGridChoiceModal()\">\n <ng-container *ngIf=\"displayLabels\">\n {{ '@pry.toolbox.chooseGrid' | i18n }}\n </ng-container>\n </button>\n</div>\n<ng-template #template>\n <div\n class=\"o-modal\"\n (click)=\"$event.stopPropagation()\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"dialog_title\"\n id=\"grid-layout\"\n (keydown.escape)=\"toggleGridChoiceModal()\"\n cdkTrapFocus\n [cdkTrapFocusAutoCapture]=\"true\"\n >\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.chooseGrid' | i18n }}</h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" (click)=\"toggleGridChoiceModal()\">\n <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n </button>\n </div>\n </div>\n <div class=\"o-select-grid-layout-wrapper\">\n <ul class=\"o-select-grid-layout\">\n <li *ngFor=\"let layout of availableLayouts$ | async\" class=\"o-select-grid-layout__item\">\n <button\n type=\"button\"\n #firstButton\n class=\"a-btn\"\n [attr.aria-pressed]=\"chosenLayout === layout.type\"\n [class.selected]=\"chosenLayout === layout.type\"\n (click)=\"changeLayout(layout.type)\"\n >\n <div class=\"o-select-grid-layout__item__preview\">\n <pry-dashboard\n [staticDashboard]=\"{\n widgets: [],\n grid: { layout: layout.type, rows: layout.rows, columns: layout.columns, gap: 3 }\n }\"\n [breakpoint]=\"10\"\n [noBackground]=\"true\"\n ></pry-dashboard>\n </div>\n <p class=\"a-p\">\n <strong>{{ layout.label ?? '' | i18n }}</strong>\n </p>\n <p class=\"a-p\">\n {{ layout.description ?? '' | i18n }}\n </p>\n </button>\n </li>\n </ul>\n </div>\n <div class=\"m-btn-group -space-evenly\">\n <button (click)=\"toggleGridChoiceModal()\" class=\"a-btn a-btn--secondary\">\n {{ '@pry.toolbox.manifest.close' | i18n }}\n </button>\n <button (click)=\"validate()\" class=\"a-btn a-btn--primary\">\n {{ '@pry.toolbox.manifest.validated' | i18n }}\n </button>\n </div>\n </div>\n</ng-template>\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: "component", type: i4.DashboardComponent, selector: "pry-dashboard", inputs: ["staticDashboard", "CloseOnDragOut", "displayOptions", "noBackground", "breakpoint"], outputs: ["rowHeight", "rows"] }, { kind: "component", type: i4.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "directive", type: i5.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { kind: "component", type: i6.PrySelectGridLayoutCssComponent, selector: "pry-toolbox-css" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] }); }
|
|
82
76
|
}
|
|
83
77
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SelectGridLayoutComponent, decorators: [{
|
|
84
78
|
type: Component,
|
|
85
|
-
args: [{ selector: 'pry-select-grid-layout', template: "<pry-toolbox-css></pry-toolbox-css>\n<div [attr.aria-expanded]=\"modalOpened\" aria-controls=\"grid-layout\">\n <button type=\"button\" #openModal class=\"a-btn a-btn--secondary -size-md\" (click)=\"toggleGridChoiceModal()\">\n <ng-container *ngIf=\"displayLabels\">\n {{ '@pry.toolbox.chooseGrid' | i18n }}\n </ng-container>\n </button>\n</div>\n<ng-template #template>\n <div\n class=\"o-modal\"\n (click)=\"$event.stopPropagation()\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"dialog_title\"\n id=\"grid-layout\"\n (keydown.escape)=\"toggleGridChoiceModal()\"\n cdkTrapFocus\n [cdkTrapFocusAutoCapture]=\"true\"\n >\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.chooseGrid' | i18n }}</h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" (click)=\"toggleGridChoiceModal()\">\n <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n </button>\n </div>\n </div>\n <div class=\"o-select-grid-layout-wrapper\">\n <ul class=\"o-select-grid-layout\">\n <li *ngFor=\"let layout of availableLayouts$ | async\" class=\"o-select-grid-layout__item\">\n <button\n type=\"button\"\n #firstButton\n class=\"a-btn\"\n [attr.aria-pressed]=\"chosenLayout === layout.
|
|
79
|
+
args: [{ selector: 'pry-select-grid-layout', template: "<pry-toolbox-css></pry-toolbox-css>\n<div [attr.aria-expanded]=\"modalOpened\" aria-controls=\"grid-layout\">\n <button type=\"button\" #openModal class=\"a-btn a-btn--secondary -size-md\" (click)=\"toggleGridChoiceModal()\">\n <ng-container *ngIf=\"displayLabels\">\n {{ '@pry.toolbox.chooseGrid' | i18n }}\n </ng-container>\n </button>\n</div>\n<ng-template #template>\n <div\n class=\"o-modal\"\n (click)=\"$event.stopPropagation()\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"dialog_title\"\n id=\"grid-layout\"\n (keydown.escape)=\"toggleGridChoiceModal()\"\n cdkTrapFocus\n [cdkTrapFocusAutoCapture]=\"true\"\n >\n <div class=\"o-modal__top\">\n <div class=\"o-modal__top__title\">\n <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.chooseGrid' | i18n }}</h2>\n </div>\n <div class=\"o-modal__top__close\">\n <button class=\"a-btn a-btn--icon-only\" (click)=\"toggleGridChoiceModal()\">\n <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n </button>\n </div>\n </div>\n <div class=\"o-select-grid-layout-wrapper\">\n <ul class=\"o-select-grid-layout\">\n <li *ngFor=\"let layout of availableLayouts$ | async\" class=\"o-select-grid-layout__item\">\n <button\n type=\"button\"\n #firstButton\n class=\"a-btn\"\n [attr.aria-pressed]=\"chosenLayout === layout.type\"\n [class.selected]=\"chosenLayout === layout.type\"\n (click)=\"changeLayout(layout.type)\"\n >\n <div class=\"o-select-grid-layout__item__preview\">\n <pry-dashboard\n [staticDashboard]=\"{\n widgets: [],\n grid: { layout: layout.type, rows: layout.rows, columns: layout.columns, gap: 3 }\n }\"\n [breakpoint]=\"10\"\n [noBackground]=\"true\"\n ></pry-dashboard>\n </div>\n <p class=\"a-p\">\n <strong>{{ layout.label ?? '' | i18n }}</strong>\n </p>\n <p class=\"a-p\">\n {{ layout.description ?? '' | i18n }}\n </p>\n </button>\n </li>\n </ul>\n </div>\n <div class=\"m-btn-group -space-evenly\">\n <button (click)=\"toggleGridChoiceModal()\" class=\"a-btn a-btn--secondary\">\n {{ '@pry.toolbox.manifest.close' | i18n }}\n </button>\n <button (click)=\"validate()\" class=\"a-btn a-btn--primary\">\n {{ '@pry.toolbox.manifest.validated' | i18n }}\n </button>\n </div>\n </div>\n</ng-template>\n" }]
|
|
86
80
|
}], ctorParameters: function () { return [{ type: i1.Store }, { type: i2.Overlay }, { type: i0.ViewContainerRef }]; }, propDecorators: { template: [{
|
|
87
81
|
type: ViewChild,
|
|
88
82
|
args: ['template', { read: TemplateRef }]
|
|
@@ -93,4 +87,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
93
87
|
type: ViewChild,
|
|
94
88
|
args: ['openModal']
|
|
95
89
|
}] } });
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-grid-layout.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/toolbox/components/select-grid-layout/select-grid-layout.component.ts","../../../../../../../projects/provoly/dashboard/toolbox/components/select-grid-layout/select-grid-layout.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { Component, ElementRef, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport {\n  ConfigActions,\n  DashboardActions,\n  DashboardGridLayout,\n  DashboardSelectors,\n  WidgetPlacementUtils\n} from '@provoly/dashboard';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { ToolboxActionComponent } from '../toolbox-action/toolbox-action.component';\n\n@Component({\n  selector: 'pry-select-grid-layout',\n  templateUrl: './select-grid-layout.component.html'\n})\nexport class SelectGridLayoutComponent extends ToolboxActionComponent {\n  availableLayouts$: Observable<{ translation: any; value: any; image: string }[]>;\n  chosenLayout: DashboardGridLayout = DashboardGridLayout.MANUAL;\n  canDispatch = false;\n  @ViewChild('template', { read: TemplateRef }) template!: TemplateRef<any>;\n  @ViewChild('firstButton') firstButton!: ElementRef<HTMLButtonElement>;\n  @ViewChild('openModal') openModal!: ElementRef<HTMLButtonElement>;\n  modalOpened: boolean = false;\n  overlayRef?: OverlayRef;\n\n  constructor(store: Store, private overlay: Overlay, private viewContainerRef: ViewContainerRef) {\n    super(store);\n    this.subscriptions.add(\n      this.store.select(DashboardSelectors.gridLayout).subscribe((layout) => (this.chosenLayout = layout))\n    );\n    this.availableLayouts$ = this.store.select(DashboardSelectors.windowManifest).pipe(\n      map((manifest) =>\n        WidgetPlacementUtils.getLayouts()\n          .filter((layout) => {\n            return WidgetPlacementUtils.placesForLayout(layout.key) >= (manifest.widgets ?? []).length;\n          })\n          .map((layout) => ({\n            value: layout.key,\n            translation: '@pry.toolbox.layout.' + layout.key,\n            image: layout.image\n          }))\n      )\n    );\n\n    setTimeout(() => {\n      this.canDispatch = true;\n    }, 100);\n  }\n\n  changeLayout(layout: DashboardGridLayout) {\n    this.chosenLayout = layout;\n  }\n\n  toggleGridChoiceModal() {\n    this.modalOpened = !this.modalOpened;\n    if (this.modalOpened) {\n      this.openWithTemplate();\n    } else {\n      this.overlayRef?.dispose();\n      this.store.dispatch(ConfigActions.closeOverlay({ id: this.constructor.name }));\n      this.openModal.nativeElement.focus();\n    }\n  }\n\n  openWithTemplate() {\n    if (!this.overlayRef) {\n      this.modalOpened = !this.modalOpened;\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['o-modal-wrapper', 'o-select-grid-layout-modal-wrapper'],\n          backdropClass: 'backdrop'\n        })\n      );\n      this.store.dispatch(ConfigActions.addingOverlay({ id: this.constructor.name }));\n      this.overlayRef.backdropClick().subscribe((_) => this.toggleGridChoiceModal());\n      this.overlayRef.attach(new TemplatePortal(this.template, this.viewContainerRef));\n      setTimeout(() => {\n        this.firstButton.nativeElement.focus();\n      }, 10);\n    } else {\n      this.overlayRef.dispose();\n      this.overlayRef = undefined;\n      this.store.dispatch(ConfigActions.closeOverlay({ id: this.constructor.name }));\n      this.openModal.nativeElement.focus();\n      this.modalOpened = !this.modalOpened;\n      this.close();\n    }\n  }\n\n  validate() {\n    if (this.canDispatch) {\n      this.store.dispatch(DashboardActions.setGridLayout({ layout: this.chosenLayout }));\n    }\n    this.toggleGridChoiceModal();\n  }\n}\n","<pry-toolbox-css></pry-toolbox-css>\n<div [attr.aria-expanded]=\"modalOpened\" aria-controls=\"grid-layout\">\n  <button type=\"button\" #openModal class=\"a-btn a-btn--secondary -size-md\" (click)=\"toggleGridChoiceModal()\">\n    <ng-container *ngIf=\"displayLabels\">\n      {{ '@pry.toolbox.chooseGrid' | i18n }}\n    </ng-container>\n  </button>\n</div>\n<ng-template #template>\n  <div\n    class=\"o-modal\"\n    (click)=\"$event.stopPropagation()\"\n    role=\"dialog\"\n    aria-modal=\"true\"\n    aria-labelledby=\"dialog_title\"\n    id=\"grid-layout\"\n    (keydown.escape)=\"toggleGridChoiceModal()\"\n    cdkTrapFocus\n    [cdkTrapFocusAutoCapture]=\"true\"\n  >\n    <div class=\"o-modal__top\">\n      <div class=\"o-modal__top__title\">\n        <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.chooseGrid' | i18n }}</h2>\n      </div>\n      <div class=\"o-modal__top__close\">\n        <button class=\"a-btn a-btn--icon-only\" (click)=\"toggleGridChoiceModal()\">\n          <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n          <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n        </button>\n      </div>\n    </div>\n    <div class=\"o-select-grid-layout-wrapper\">\n      <ul class=\"o-select-grid-layout\">\n        <li *ngFor=\"let layout of availableLayouts$ | async\" class=\"o-select-grid-layout__item\">\n          <button\n            type=\"button\"\n            #firstButton\n            class=\"a-btn\"\n            [attr.aria-pressed]=\"chosenLayout === layout.value\"\n            [class.selected]=\"chosenLayout === layout.value\"\n            (click)=\"changeLayout(layout.value)\"\n          >\n            <div class=\"u-txt-center\">\n              <img [src]=\"layout.image\" />\n              <strong>{{ layout.translation | i18n }}</strong>\n            </div>\n            <p class=\"a-p\">\n              {{ layout.translation + '_detailled' | i18n }}\n            </p>\n          </button>\n        </li>\n      </ul>\n    </div>\n    <div class=\"m-btn-group -space-evenly\">\n      <button (click)=\"toggleGridChoiceModal()\" class=\"a-btn a-btn--secondary\">\n        {{ '@pry.toolbox.manifest.close' | i18n }}\n      </button>\n      <button (click)=\"validate()\" class=\"a-btn a-btn--primary\">\n        {{ '@pry.toolbox.manifest.validated' | i18n }}\n      </button>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-grid-layout.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/toolbox/components/select-grid-layout/select-grid-layout.component.ts","../../../../../../../projects/provoly/dashboard/toolbox/components/select-grid-layout/select-grid-layout.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { Component, ElementRef, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport {\n  AutomaticGridLayoutDefinition,\n  ConfigActions,\n  DashboardActions,\n  DashboardGridLayout,\n  DashboardSelectors,\n  WidgetPlacementUtils\n} from '@provoly/dashboard';\nimport { Observable } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { ToolboxActionComponent } from '../toolbox-action/toolbox-action.component';\n\n@Component({\n  selector: 'pry-select-grid-layout',\n  templateUrl: './select-grid-layout.component.html'\n})\nexport class SelectGridLayoutComponent extends ToolboxActionComponent {\n  availableLayouts$: Observable<AutomaticGridLayoutDefinition[]>;\n  chosenLayout: string = DashboardGridLayout.MANUAL;\n  canDispatch = false;\n  @ViewChild('template', { read: TemplateRef }) template!: TemplateRef<any>;\n  @ViewChild('firstButton') firstButton!: ElementRef<HTMLButtonElement>;\n  @ViewChild('openModal') openModal!: ElementRef<HTMLButtonElement>;\n  modalOpened: boolean = false;\n  overlayRef?: OverlayRef;\n\n  constructor(store: Store, private overlay: Overlay, private viewContainerRef: ViewContainerRef) {\n    super(store);\n    this.subscriptions.add(\n      this.store.select(DashboardSelectors.gridLayout).subscribe((layout) => (this.chosenLayout = layout))\n    );\n    this.availableLayouts$ = this.store.select(DashboardSelectors.windowManifest).pipe(\n      map((manifest) =>\n        WidgetPlacementUtils.layouts.filter((layout) => {\n          return layout.places.length === 0 || layout.places.length >= (manifest.widgets ?? []).length;\n        })\n      )\n    );\n\n    setTimeout(() => {\n      this.canDispatch = true;\n    }, 100);\n  }\n\n  changeLayout(layout: string) {\n    this.chosenLayout = layout;\n  }\n\n  toggleGridChoiceModal() {\n    this.modalOpened = !this.modalOpened;\n    if (this.modalOpened) {\n      this.openWithTemplate();\n    } else {\n      this.overlayRef?.dispose();\n      this.store.dispatch(ConfigActions.closeOverlay({ id: this.constructor.name }));\n      this.openModal.nativeElement.focus();\n    }\n  }\n\n  openWithTemplate() {\n    if (!this.overlayRef) {\n      this.modalOpened = !this.modalOpened;\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['o-modal-wrapper', 'o-select-grid-layout-modal-wrapper'],\n          backdropClass: 'backdrop'\n        })\n      );\n      this.store.dispatch(ConfigActions.addingOverlay({ id: this.constructor.name }));\n      this.overlayRef.backdropClick().subscribe((_) => this.toggleGridChoiceModal());\n      this.overlayRef.attach(new TemplatePortal(this.template, this.viewContainerRef));\n      setTimeout(() => {\n        this.firstButton.nativeElement.focus();\n      }, 10);\n    } else {\n      this.overlayRef.dispose();\n      this.overlayRef = undefined;\n      this.store.dispatch(ConfigActions.closeOverlay({ id: this.constructor.name }));\n      this.openModal.nativeElement.focus();\n      this.modalOpened = !this.modalOpened;\n      this.close();\n    }\n  }\n\n  validate() {\n    if (this.canDispatch) {\n      this.store.dispatch(DashboardActions.setGridLayout({ layout: this.chosenLayout }));\n    }\n    this.toggleGridChoiceModal();\n  }\n}\n","<pry-toolbox-css></pry-toolbox-css>\n<div [attr.aria-expanded]=\"modalOpened\" aria-controls=\"grid-layout\">\n  <button type=\"button\" #openModal class=\"a-btn a-btn--secondary -size-md\" (click)=\"toggleGridChoiceModal()\">\n    <ng-container *ngIf=\"displayLabels\">\n      {{ '@pry.toolbox.chooseGrid' | i18n }}\n    </ng-container>\n  </button>\n</div>\n<ng-template #template>\n  <div\n    class=\"o-modal\"\n    (click)=\"$event.stopPropagation()\"\n    role=\"dialog\"\n    aria-modal=\"true\"\n    aria-labelledby=\"dialog_title\"\n    id=\"grid-layout\"\n    (keydown.escape)=\"toggleGridChoiceModal()\"\n    cdkTrapFocus\n    [cdkTrapFocusAutoCapture]=\"true\"\n  >\n    <div class=\"o-modal__top\">\n      <div class=\"o-modal__top__title\">\n        <h2 class=\"a-h2\" id=\"dialog_title\">{{ '@pry.toolbox.chooseGrid' | i18n }}</h2>\n      </div>\n      <div class=\"o-modal__top__close\">\n        <button class=\"a-btn a-btn--icon-only\" (click)=\"toggleGridChoiceModal()\">\n          <pry-icon iconSvg=\"close\" [height]=\"35\" [width]=\"35\"></pry-icon>\n          <span class=\"u-visually-hidden\">{{ '@pry.toolbox.close' | i18n }}</span>\n        </button>\n      </div>\n    </div>\n    <div class=\"o-select-grid-layout-wrapper\">\n      <ul class=\"o-select-grid-layout\">\n        <li *ngFor=\"let layout of availableLayouts$ | async\" class=\"o-select-grid-layout__item\">\n          <button\n            type=\"button\"\n            #firstButton\n            class=\"a-btn\"\n            [attr.aria-pressed]=\"chosenLayout === layout.type\"\n            [class.selected]=\"chosenLayout === layout.type\"\n            (click)=\"changeLayout(layout.type)\"\n          >\n            <div class=\"o-select-grid-layout__item__preview\">\n              <pry-dashboard\n                [staticDashboard]=\"{\n                  widgets: [],\n                  grid: { layout: layout.type, rows: layout.rows, columns: layout.columns, gap: 3 }\n                }\"\n                [breakpoint]=\"10\"\n                [noBackground]=\"true\"\n              ></pry-dashboard>\n            </div>\n            <p class=\"a-p\">\n              <strong>{{ layout.label ?? '' | i18n }}</strong>\n            </p>\n            <p class=\"a-p\">\n              {{ layout.description ?? '' | i18n }}\n            </p>\n          </button>\n        </li>\n      </ul>\n    </div>\n    <div class=\"m-btn-group -space-evenly\">\n      <button (click)=\"toggleGridChoiceModal()\" class=\"a-btn a-btn--secondary\">\n        {{ '@pry.toolbox.manifest.close' | i18n }}\n      </button>\n      <button (click)=\"validate()\" class=\"a-btn a-btn--primary\">\n        {{ '@pry.toolbox.manifest.validated' | i18n }}\n      </button>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
@@ -2,10 +2,10 @@ import { Component, ViewEncapsulation } from '@angular/core';
|
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export class PrySelectGridLayoutCssComponent {
|
|
4
4
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PrySelectGridLayoutCssComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
5
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: PrySelectGridLayoutCssComponent, selector: "pry-toolbox-css", ngImport: i0, template: '', isInline: true, styles: [".o-select-grid-layout{margin:0;padding:0}.o-select-grid-layout li{list-style:none}.o-select-grid-layout-wrapper{overflow-y:auto;max-height:80%}.o-select-grid-layout-modal-wrapper{max-width:80%}.o-select-grid-layout{overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,auto));grid-gap:1.875rem;padding:.25rem .25rem 1.875rem}.o-select-grid-layout__item .a-btn{display:flex;flex-direction:column;align-items:center;justify-content:space-around;width:100%;height:
|
|
5
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: PrySelectGridLayoutCssComponent, selector: "pry-toolbox-css", ngImport: i0, template: '', isInline: true, styles: [".o-select-grid-layout{margin:0;padding:0}.o-select-grid-layout li{list-style:none}.o-select-grid-layout-wrapper{overflow-y:auto;max-height:80%}.o-select-grid-layout-modal-wrapper{max-width:80%}.o-select-grid-layout{overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,auto));grid-gap:1.875rem;padding:.25rem .25rem 1.875rem}.o-select-grid-layout__item .a-btn{display:flex;flex-direction:column;align-items:center;justify-content:space-around;width:100%;height:18.75rem;padding:.9375rem;border-radius:0;text-align:left}.o-select-grid-layout__item .a-btn:focus{outline:2px solid #35b99f}.o-select-grid-layout__item .a-btn:focus:not(:focus-visible){outline:0}.o-select-grid-layout__item .a-btn:focus-visible{outline:0;border-radius:.125rem;box-shadow:0 0 0 2px #fff,0 0 0 4px #35b99f}.o-select-grid-layout__item .a-btn strong{display:block}.o-select-grid-layout__item .a-btn .a-p{margin-bottom:0;font-size:13px}.o-select-grid-layout__item__preview{height:6.25rem;width:100%}\n", ".o-select-grid-layout-wrapper{overflow-y:auto;max-height:80%}.o-select-grid-layout-modal-wrapper{max-width:60%;padding:1.875rem 2.5rem}.backdrop{background-color:#0000004d}.o-filters{width:100%}.o-filters__header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1.875rem;border-bottom:1px solid #dfe5ec}.o-filters__header h2{padding:0}.o-filters__header .back-button{transform:rotate(180deg)}.o-filters__content{display:flex;flex-direction:column;padding-top:1.25rem}.o-filters__content>.a-btn{margin-top:1.25rem;align-self:center}.o-filters__filter td:first-child{min-width:20%;max-width:30%}.o-filters__filter td:nth-child(2){min-width:50%;max-width:60%}.o-filters__filter td:nth-child(3){width:8%}.o-filters__filter td:nth-child(4){width:8%}.o-filters__filter td:last-child{width:4%}.o-filters__filter.cdk-drag-preview{background-color:#fff}.o-filters__filter.cdk-drag-preview td{padding:.75rem .5rem}.o-filters__filter .cdk-drag-handle{pointer-events:auto}.o-filters__filter .cdk-drag-handle:hover{cursor:grab}.o-filters tr.o-filters__filter{cursor:default}.o-filters__no-filters{padding-bottom:1.875rem}\n", "@charset \"UTF-8\";.o-draggable-menu{width:-moz-fit-content;width:fit-content}.o-draggable-menu__list{display:flex;flex-direction:column}.o-draggable-menu__list__item .a-btn{border:none;color:#40b688;font-weight:500;margin-bottom:-.3125rem}.o-draggable-menu__list__item .a-btn:disabled{color:#40b688;opacity:.5}.o-draggable-menu__list__item .a-btn:before{content:\"\\2192\";font-size:1.25rem;padding-bottom:.625rem}.o-draggable-menu__list__item pry-toolbox-action-instanciator .a-tooltip[data-tooltip][data-tooltip-position=bottom]:after{top:calc(100% - 10px)}\n", ".refresh-rs>div{padding-left:0;padding-right:0}.refresh-rs button.refresh-line{border-radius:0;padding:0 .9375rem}.refresh-rs button.refresh-line:hover{font-weight:400;background-color:#0000001a}.refresh-rs button.refresh-line.-selected{background-color:#00000026}\n"], encapsulation: i0.ViewEncapsulation.None }); }
|
|
6
6
|
}
|
|
7
7
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PrySelectGridLayoutCssComponent, decorators: [{
|
|
8
8
|
type: Component,
|
|
9
|
-
args: [{ selector: 'pry-toolbox-css', template: '', encapsulation: ViewEncapsulation.None, styles: [".o-select-grid-layout{margin:0;padding:0}.o-select-grid-layout li{list-style:none}.o-select-grid-layout-wrapper{overflow-y:auto;max-height:80%}.o-select-grid-layout-modal-wrapper{max-width:80%}.o-select-grid-layout{overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,auto));grid-gap:1.875rem;padding:.25rem .25rem 1.875rem}.o-select-grid-layout__item .a-btn{display:flex;flex-direction:column;align-items:center;justify-content:space-around;width:100%;height:
|
|
9
|
+
args: [{ selector: 'pry-toolbox-css', template: '', encapsulation: ViewEncapsulation.None, styles: [".o-select-grid-layout{margin:0;padding:0}.o-select-grid-layout li{list-style:none}.o-select-grid-layout-wrapper{overflow-y:auto;max-height:80%}.o-select-grid-layout-modal-wrapper{max-width:80%}.o-select-grid-layout{overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,auto));grid-gap:1.875rem;padding:.25rem .25rem 1.875rem}.o-select-grid-layout__item .a-btn{display:flex;flex-direction:column;align-items:center;justify-content:space-around;width:100%;height:18.75rem;padding:.9375rem;border-radius:0;text-align:left}.o-select-grid-layout__item .a-btn:focus{outline:2px solid #35b99f}.o-select-grid-layout__item .a-btn:focus:not(:focus-visible){outline:0}.o-select-grid-layout__item .a-btn:focus-visible{outline:0;border-radius:.125rem;box-shadow:0 0 0 2px #fff,0 0 0 4px #35b99f}.o-select-grid-layout__item .a-btn strong{display:block}.o-select-grid-layout__item .a-btn .a-p{margin-bottom:0;font-size:13px}.o-select-grid-layout__item__preview{height:6.25rem;width:100%}\n", ".o-select-grid-layout-wrapper{overflow-y:auto;max-height:80%}.o-select-grid-layout-modal-wrapper{max-width:60%;padding:1.875rem 2.5rem}.backdrop{background-color:#0000004d}.o-filters{width:100%}.o-filters__header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1.875rem;border-bottom:1px solid #dfe5ec}.o-filters__header h2{padding:0}.o-filters__header .back-button{transform:rotate(180deg)}.o-filters__content{display:flex;flex-direction:column;padding-top:1.25rem}.o-filters__content>.a-btn{margin-top:1.25rem;align-self:center}.o-filters__filter td:first-child{min-width:20%;max-width:30%}.o-filters__filter td:nth-child(2){min-width:50%;max-width:60%}.o-filters__filter td:nth-child(3){width:8%}.o-filters__filter td:nth-child(4){width:8%}.o-filters__filter td:last-child{width:4%}.o-filters__filter.cdk-drag-preview{background-color:#fff}.o-filters__filter.cdk-drag-preview td{padding:.75rem .5rem}.o-filters__filter .cdk-drag-handle{pointer-events:auto}.o-filters__filter .cdk-drag-handle:hover{cursor:grab}.o-filters tr.o-filters__filter{cursor:default}.o-filters__no-filters{padding-bottom:1.875rem}\n", "@charset \"UTF-8\";.o-draggable-menu{width:-moz-fit-content;width:fit-content}.o-draggable-menu__list{display:flex;flex-direction:column}.o-draggable-menu__list__item .a-btn{border:none;color:#40b688;font-weight:500;margin-bottom:-.3125rem}.o-draggable-menu__list__item .a-btn:disabled{color:#40b688;opacity:.5}.o-draggable-menu__list__item .a-btn:before{content:\"\\2192\";font-size:1.25rem;padding-bottom:.625rem}.o-draggable-menu__list__item pry-toolbox-action-instanciator .a-tooltip[data-tooltip][data-tooltip-position=bottom]:after{top:calc(100% - 10px)}\n", ".refresh-rs>div{padding-left:0;padding-right:0}.refresh-rs button.refresh-line{border-radius:0;padding:0 .9375rem}.refresh-rs button.refresh-line:hover{font-weight:400;background-color:#0000001a}.refresh-rs button.refresh-line.-selected{background-color:#00000026}\n"] }]
|
|
10
10
|
}] });
|
|
11
11
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3NzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL3Rvb2xib3gvc3R5bGUvY3NzLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVE3RCxNQUFNLE9BQU8sK0JBQStCOytHQUEvQiwrQkFBK0I7bUdBQS9CLCtCQUErQix1REFKaEMsRUFBRTs7NEZBSUQsK0JBQStCO2tCQU4zQyxTQUFTOytCQUNFLGlCQUFpQixZQUNqQixFQUFFLGlCQUVHLGlCQUFpQixDQUFDLElBQUkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ByeS10b29sYm94LWNzcycsXG4gIHRlbXBsYXRlOiAnJyxcbiAgc3R5bGVVcmxzOiBbJ19vLXNlbGVjdC1ncmlkLWxheW91dC5zY3NzJywgJ19vLWZpbHRlci1zZXR0aW5ncy5zY3NzJywgJ19vLXRvb2xib3guc2NzcycsICdfby1hdXRvbWF0ZS1yZWZyZXNoLnNjc3MnXSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZVxufSlcbmV4cG9ydCBjbGFzcyBQcnlTZWxlY3RHcmlkTGF5b3V0Q3NzQ29tcG9uZW50IHt9XG4iXX0=
|