@provoly/dashboard 0.22.5 → 0.22.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +0 -2
- package/admin/components/admin-classes/admin-classes-customize/tooltip/admin-classes-customize-tooltip.component.d.ts +8 -4
- package/esm2022/admin/components/admin-classes/admin-classes-customize/admin-classes-customize.component.mjs +7 -6
- package/esm2022/admin/components/admin-classes/admin-classes-customize/tooltip/admin-classes-customize-tooltip.component.mjs +44 -30
- package/esm2022/admin/components/admin-menu/admin-menu.component.mjs +3 -3
- package/esm2022/lib/core/components/about/about.component.mjs +3 -3
- package/esm2022/lib/core/components/base-menu/base-menu.component.mjs +3 -3
- package/esm2022/lib/core/components/select/select.component.mjs +5 -4
- package/esm2022/lib/core/components/select/select.module.mjs +5 -4
- package/esm2022/lib/core/components/select-image/select-image.component.mjs +2 -2
- package/esm2022/lib/core/i18n/fr.translations.mjs +2 -2
- package/esm2022/lib/dashboard/components/widgets/header/widget-header.component.mjs +2 -2
- package/esm2022/lib/dashboard/components/widgets/widget-instanciator/widget-factory.service.mjs +16 -1
- package/esm2022/lib/dashboard/item-utils.mjs +2 -2
- package/esm2022/lib/dashboard/store/dashboard.selectors.mjs +1 -4
- package/esm2022/lib/dashboard/store/refresh.service.mjs +14 -9
- package/esm2022/presentation/components/presentation.component.mjs +3 -3
- package/esm2022/presentation/style/css.component.mjs +2 -2
- package/esm2022/restitution/components/restitution-catalog/restitution-catalog.component.mjs +3 -3
- package/esm2022/restitution/style/css.component.mjs +2 -2
- package/esm2022/toolbox/components/automate-refresh/automate-refresh.component.mjs +12 -9
- package/esm2022/toolbox/components/refresh-datasets/refresh-datasets.component.mjs +19 -17
- package/esm2022/toolbox/components/toolbox.component.mjs +7 -4
- package/esm2022/widgets/widget-aggregated-chart/component/widget-aggregated-chart.component.mjs +3 -3
- package/esm2022/widgets/widget-aggregated-chart/style/css.component.mjs +2 -2
- package/esm2022/widgets/widget-graph/component/widget-graph.component.mjs +4 -5
- package/esm2022/widgets/widget-graph/style/css.component.mjs +2 -2
- package/esm2022/widgets/widget-map/component/widget-map.component.mjs +3 -3
- package/fesm2022/provoly-dashboard-admin.mjs +49 -34
- package/fesm2022/provoly-dashboard-admin.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-presentation.mjs +4 -4
- package/fesm2022/provoly-dashboard-presentation.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-restitution.mjs +4 -4
- package/fesm2022/provoly-dashboard-restitution.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-toolbox.mjs +29 -21
- package/fesm2022/provoly-dashboard-toolbox.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-aggregated-chart.mjs +4 -4
- package/fesm2022/provoly-dashboard-widgets-widget-aggregated-chart.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-graph.mjs +5 -6
- package/fesm2022/provoly-dashboard-widgets-widget-graph.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-map.mjs +2 -2
- package/fesm2022/provoly-dashboard-widgets-widget-map.mjs.map +1 -1
- package/fesm2022/provoly-dashboard.mjs +56 -39
- package/fesm2022/provoly-dashboard.mjs.map +1 -1
- package/lib/core/components/select/select.module.d.ts +2 -1
- package/lib/dashboard/components/widgets/header/widget-header.component.d.ts +1 -1
- package/lib/dashboard/components/widgets/widget-instanciator/widget-factory.service.d.ts +8 -1
- package/lib/dashboard/store/dashboard.selectors.d.ts +0 -13
- package/lib/dashboard/store/refresh.service.d.ts +3 -1
- package/package.json +7 -7
- package/presentation/style/_o-pry-presentation.scss +0 -3
- package/styles/components/_a-chip.scss +6 -0
- package/styles/components/_a-pry-select.scss +13 -0
- package/styles/components/_a-range-slider.scss +4 -5
- package/styles/components/_m-nav-links.scss +2 -7
- package/styles/components/_o-widget.scss +6 -0
- package/styles-theme/abstracts-theme/variables/_variables-colors.scss +4 -3
- package/styles-theme/base-theme/_typography.theme.scss +5 -2
- package/styles-theme/components-theme/_a-btn.theme.scss +3 -7
- package/styles-theme/components-theme/_a-label.theme.scss +1 -0
- package/styles-theme/components-theme/_a-pry-select.theme.scss +4 -6
- package/styles-theme/components-theme/_a-range-slider.theme.scss +16 -16
- package/styles-theme/components-theme/_a-table.theme.scss +2 -2
- package/styles-theme/components-theme/_m-btn-sorttable.theme.scss +3 -3
- package/styles-theme/components-theme/_m-nav-links.theme.scss +18 -0
- package/styles-theme/components-theme/_o-pry-presentation.theme.scss +9 -0
- package/styles-theme/components-theme/_o-tabs.theme.scss +1 -1
- package/styles-theme/layout-theme/_o-base-layout.theme.scss +1 -0
- package/styles-theme/main-theme.scss +1 -0
- package/toolbox/components/automate-refresh/automate-refresh.component.d.ts +3 -1
- package/toolbox/components/refresh-datasets/refresh-datasets.component.d.ts +3 -2
- package/widgets/widget-aggregated-chart/style/_o-widget-chart.scss +3 -0
- package/widgets/widget-graph/component/widget-graph.component.d.ts +0 -1
- package/widgets/widget-graph/style/_o-widget-graph.scss +14 -0
package/README.md
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ComponentRef, EventEmitter, Injector, OnDestroy, ViewContainerRef } from '@angular/core';
|
|
2
2
|
import { Store } from '@ngrx/store';
|
|
3
|
-
import { Attribute, BaseTooltipComponent, Class, PryI18nService, SubscriptionnerDirective, TooltipFactoryService, TooltipOfClass } from '@provoly/dashboard';
|
|
3
|
+
import { Attribute, BaseTooltipComponent, Class, Field, PryI18nService, SubscriptionnerDirective, TooltipFactoryService, TooltipOfClass } from '@provoly/dashboard';
|
|
4
4
|
import { Observable } from 'rxjs';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export declare class AdminClassesCustomizeTooltipComponent extends SubscriptionnerDirective implements OnDestroy {
|
|
@@ -15,17 +15,20 @@ export declare class AdminClassesCustomizeTooltipComponent extends Subscriptionn
|
|
|
15
15
|
label: string;
|
|
16
16
|
}[]>;
|
|
17
17
|
advancedTooltip: boolean;
|
|
18
|
-
possibleAttributes: Attribute[];
|
|
19
18
|
possibleNonAttributesFields: Attribute[];
|
|
20
19
|
backPressed: EventEmitter<void>;
|
|
21
|
-
private _currentClass
|
|
22
|
-
private fields;
|
|
20
|
+
private _currentClass$;
|
|
23
21
|
strOptions: string;
|
|
24
22
|
tmpComponent?: ComponentRef<BaseTooltipComponent>;
|
|
25
23
|
defs: {
|
|
26
24
|
[p: string]: TooltipOfClass;
|
|
27
25
|
};
|
|
28
26
|
noTooltip: boolean;
|
|
27
|
+
classes$: Observable<Class[]>;
|
|
28
|
+
fields$: Observable<Field[]>;
|
|
29
|
+
attributesOfClass$: Observable<Attribute[]>;
|
|
30
|
+
mockData: any;
|
|
31
|
+
attributes: Attribute[];
|
|
29
32
|
set currentClass(clazz: Class | null | undefined);
|
|
30
33
|
get currentClass(): Class;
|
|
31
34
|
constructor(tooltipFactoryService: TooltipFactoryService, injector: Injector, translateService: PryI18nService, store: Store);
|
|
@@ -35,6 +38,7 @@ export declare class AdminClassesCustomizeTooltipComponent extends Subscriptionn
|
|
|
35
38
|
updateTemplate(): void;
|
|
36
39
|
goBack(): void;
|
|
37
40
|
changeAttributes($event: any): void;
|
|
41
|
+
private removeUnknown;
|
|
38
42
|
static ɵfac: i0.ɵɵFactoryDeclaration<AdminClassesCustomizeTooltipComponent, never>;
|
|
39
43
|
static ɵcmp: i0.ɵɵComponentDeclaration<AdminClassesCustomizeTooltipComponent, "pry-admin-classes-customize-tooltip", never, { "currentClass": { "alias": "currentClass"; "required": false; }; }, { "backPressed": "backPressed"; }, never, never, false, never>;
|
|
40
44
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';
|
|
2
2
|
import { Component } from '@angular/core';
|
|
3
|
-
import { ClassActions, ClassSelectors, ConfigActions, ConfigSelectors, FieldSelectors, ItemUtils, SubscriptionnerDirective } from '@provoly/dashboard';
|
|
3
|
+
import { ClassActions, ClassSelectors, ConfigActions, ConfigSelectors, FieldActions, FieldSelectors, ItemUtils, SubscriptionnerDirective } from '@provoly/dashboard';
|
|
4
4
|
import { combineLatest, combineLatestWith, map, of, switchMap } from 'rxjs';
|
|
5
5
|
import { AdminClassActions } from '../store/admin-class.actions';
|
|
6
6
|
import { AdminClassSelectors } from '../store/admin-class.selectors';
|
|
@@ -27,6 +27,7 @@ export class AdminClassesCustomizeComponent extends SubscriptionnerDirective {
|
|
|
27
27
|
this.maxTilesAttributes = 5;
|
|
28
28
|
this.subscriptions.add(this.route.params.subscribe((params) => this.store.dispatch(AdminClassActions.selectClass({ clazz: { id: params['id'] } }))));
|
|
29
29
|
this.store.dispatch(ClassActions.load());
|
|
30
|
+
this.store.dispatch(FieldActions.load());
|
|
30
31
|
this.store.dispatch(ConfigActions.loadCustomization());
|
|
31
32
|
this.fields$ = this.store.select(FieldSelectors.fields);
|
|
32
33
|
this.currentClass$ = combineLatest([
|
|
@@ -38,15 +39,15 @@ export class AdminClassesCustomizeComponent extends SubscriptionnerDirective {
|
|
|
38
39
|
this.subscriptions.add(this.currentPropertiesConfig$.pipe(combineLatestWith(this.currentClass$)).subscribe(([attrs, clazz]) => {
|
|
39
40
|
this.defaultAttributes = JSON.parse(JSON.stringify(attrs));
|
|
40
41
|
this.otherAttributes = (clazz ?? { attributes: [] }).attributes
|
|
41
|
-
.filter((attr) => !attrs.includes(attr.
|
|
42
|
-
.map((attr) => attr.
|
|
42
|
+
.filter((attr) => !attrs.includes(attr.name))
|
|
43
|
+
.map((attr) => attr.name);
|
|
43
44
|
}));
|
|
44
45
|
this.currentTilePropertiesConfig$ = this.store.select(ConfigSelectors.tileAttributesDefinitions).pipe(combineLatestWith(this.currentClass$, this.fields$), map(([defs, clazz, fields]) => ItemUtils.getAttributesDefinitionForClass((clazz ?? { attributes: [] }), defs, fields)), map((attrs) => attrs.filter((_, i) => i < this.maxTilesAttributes)));
|
|
45
46
|
this.subscriptions.add(this.currentTilePropertiesConfig$.pipe(combineLatestWith(this.currentClass$)).subscribe(([attrs, clazz]) => {
|
|
46
47
|
this.defaultTileAttributes = JSON.parse(JSON.stringify(attrs));
|
|
47
48
|
this.otherTileAttributes = (clazz ?? { attributes: [] }).attributes
|
|
48
|
-
.filter((attr) => !attrs.includes(attr.
|
|
49
|
-
.map((attr) => attr.
|
|
49
|
+
.filter((attr) => !attrs.includes(attr.name))
|
|
50
|
+
.map((attr) => attr.name);
|
|
50
51
|
}));
|
|
51
52
|
this.subscriptions.add(this.store.select(ConfigSelectors.maxAttributesInTiles).subscribe((max) => {
|
|
52
53
|
this.maxTilesAttributes = max;
|
|
@@ -88,4 +89,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
88
89
|
type: Component,
|
|
89
90
|
args: [{ selector: 'pry-admin-classes-customize', template: "<div class=\"o-pry-admin-classes-customize\">\n <h1 class=\"a-h1\" id=\"tab-custom\">{{ '@pry.admin.customize.title' | i18n }}</h1>\n\n <pry-tab-group translationStringBase=\"@pry.admin.\">\n <pry-tab [templateRef]=\"customizeTemplate\" name=\"customize.template\"></pry-tab>\n <pry-tab [templateRef]=\"customizeTable\" name=\"customize.table\"></pry-tab>\n <pry-tab [templateRef]=\"customizeSymbol\" name=\"classes.rules\"></pry-tab>\n <pry-tab [templateRef]=\"customizeTile\" name=\"customize.tile\"></pry-tab>\n </pry-tab-group>\n\n <ng-template #customizeTemplate>\n <pry-admin-classes-customize-tooltip\n (backPressed)=\"goBack()\"\n [currentClass]=\"currentClass$ | async\"\n ></pry-admin-classes-customize-tooltip>\n </ng-template>\n <ng-template #customizeTable>\n <div class=\"container\">\n <h2>{{ '@pry.admin.customize.tableAttrs' | i18n }}</h2>\n <div\n cdkDropList\n #defaultList=\"cdkDropList\"\n [cdkDropListData]=\"defaultAttributes\"\n [cdkDropListConnectedTo]=\"[notDefaultList]\"\n class=\"list\"\n (cdkDropListDropped)=\"drop($event)\"\n >\n <div class=\"item\" *ngFor=\"let item of defaultAttributes\" cdkDrag>{{ item }}</div>\n </div>\n </div>\n\n <div class=\"container\">\n <h2>{{ '@pry.admin.customize.noTableAttrs' | i18n }}</h2>\n <div\n cdkDropList\n #notDefaultList=\"cdkDropList\"\n [cdkDropListData]=\"otherAttributes\"\n [cdkDropListConnectedTo]=\"[defaultList]\"\n class=\"list\"\n (cdkDropListDropped)=\"drop($event)\"\n >\n <div class=\"item\" *ngFor=\"let item of otherAttributes\" cdkDrag>{{ item }}</div>\n </div>\n </div>\n\n <div class=\"m-btn-group -width-lg\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--secondary\"\n (click)=\"goBack()\"\n [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n ></button>\n <button class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTableAttrs()\">\n {{ '@pry.admin.customize.updateTable' | i18n }}\n </button>\n </div>\n </ng-template>\n <ng-template #customizeSymbol>\n <pry-admin-classes-customize-symbol\n (backPressed)=\"goBack()\"\n [currentClass]=\"currentClass$ | async\"\n ></pry-admin-classes-customize-symbol>\n </ng-template>\n <ng-template #customizeTile>\n <div class=\"container\">\n <h2>{{ '@pry.admin.customize.tile' | i18n }}</h2>\n <div\n cdkDropList\n #defaultTilesList=\"cdkDropList\"\n [cdkDropListData]=\"defaultTileAttributes\"\n [cdkDropListConnectedTo]=\"[notDefaultTilesList]\"\n class=\"list\"\n (cdkDropListDropped)=\"drop($event)\"\n >\n <div class=\"item\" *ngFor=\"let item of defaultTileAttributes\" cdkDrag>{{ item }}</div>\n </div>\n </div>\n\n <div class=\"container\">\n <h2>{{ '@pry.admin.customize.noTileAttrs' | i18n }}</h2>\n <div\n cdkDropList\n #notDefaultTilesList=\"cdkDropList\"\n [cdkDropListData]=\"otherTileAttributes\"\n [cdkDropListConnectedTo]=\"[defaultTilesList]\"\n class=\"list\"\n (cdkDropListDropped)=\"drop($event)\"\n >\n <div class=\"item\" *ngFor=\"let item of otherTileAttributes\" cdkDrag>{{ item }}</div>\n </div>\n </div>\n\n <div>\n <ng-container *ngIf=\"!isTileConfValid()\">\n <p>{{ '@pry.admin.customize.tileHint' | i18n : { max: maxTilesAttributes } }}</p>\n </ng-container>\n </div>\n\n <div class=\"m-btn-group -width-lg\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--secondary\"\n (click)=\"goBack()\"\n [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n ></button>\n <button class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTileAttrs()\" [disabled]=\"!isTileConfValid()\">\n {{ '@pry.admin.customize.updateTile' | i18n }}\n </button>\n </div>\n </ng-template>\n</div>\n" }]
|
|
90
91
|
}], ctorParameters: function () { return [{ type: i1.Store }, { type: i2.Router }, { type: i2.ActivatedRoute }]; } });
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-classes-customize.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-customize/admin-classes-customize.component.ts","../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-customize/admin-classes-customize.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';\nimport { Component, OnDestroy } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  Class,\n  ClassActions,\n  ClassSelectors,\n  ConfigActions,\n  ConfigSelectors,\n  Field,\n  FieldSelectors,\n  ItemUtils,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { combineLatest, combineLatestWith, map, Observable, of, switchMap } from 'rxjs';\nimport { AdminClassActions } from '../store/admin-class.actions';\nimport { AdminClassSelectors } from '../store/admin-class.selectors';\n\n@Component({\n  selector: 'pry-admin-classes-customize',\n  templateUrl: './admin-classes-customize.component.html'\n})\nexport class AdminClassesCustomizeComponent extends SubscriptionnerDirective implements OnDestroy {\n  currentClass$: Observable<Class | undefined>;\n  currentClass: Class = {} as Class;\n  defaultAttributes: string[] = [];\n  otherAttributes: string[] = [];\n  currentPropertiesConfig$: Observable<string[]>;\n  currentTilePropertiesConfig$: Observable<string[]>;\n  classes$: Observable<Class[]> = of([]);\n  defaultTileAttributes: string[] = [];\n  otherTileAttributes: string[] = [];\n  maxTilesAttributes = 5;\n  fields$: Observable<Field[]>;\n\n  constructor(private store: Store<any>, private router: Router, private route: ActivatedRoute) {\n    super();\n    this.subscriptions.add(\n      this.route.params.subscribe((params) =>\n        this.store.dispatch(AdminClassActions.selectClass({ clazz: { id: params['id'] } as Class }))\n      )\n    );\n    this.store.dispatch(ClassActions.load());\n    this.store.dispatch(ConfigActions.loadCustomization());\n    this.fields$ = this.store.select(FieldSelectors.fields);\n    this.currentClass$ = combineLatest([\n      this.store.select(AdminClassSelectors.selectedClass),\n      this.store.select(ClassSelectors.classes)\n    ]).pipe(switchMap(([clazz, _]) => this.store.select(ClassSelectors.classById(clazz?.id ?? ''))));\n    this.subscriptions.add(this.currentClass$.subscribe((clazz) => (this.currentClass = clazz ?? ({} as Class))));\n    this.currentPropertiesConfig$ = this.store.select(ConfigSelectors.tableDefaultAttributesDefinitions).pipe(\n      combineLatestWith(this.currentClass$, this.fields$),\n      map(([defs, clazz, fields]) =>\n        ItemUtils.getAttributesDefinitionForClass((clazz ?? { attributes: [] }) as Class, defs, fields)\n      )\n    );\n    this.subscriptions.add(\n      this.currentPropertiesConfig$.pipe(combineLatestWith(this.currentClass$)).subscribe(([attrs, clazz]) => {\n        this.defaultAttributes = JSON.parse(JSON.stringify(attrs));\n        this.otherAttributes = (clazz ?? { attributes: [] }).attributes\n          .filter((attr) => !attrs.includes(attr.technicalName))\n          .map((attr) => attr.technicalName);\n      })\n    );\n    this.currentTilePropertiesConfig$ = this.store.select(ConfigSelectors.tileAttributesDefinitions).pipe(\n      combineLatestWith(this.currentClass$, this.fields$),\n      map(([defs, clazz, fields]) =>\n        ItemUtils.getAttributesDefinitionForClass((clazz ?? { attributes: [] }) as Class, defs, fields)\n      ),\n      map((attrs) => attrs.filter((_, i) => i < this.maxTilesAttributes))\n    );\n    this.subscriptions.add(\n      this.currentTilePropertiesConfig$.pipe(combineLatestWith(this.currentClass$)).subscribe(([attrs, clazz]) => {\n        this.defaultTileAttributes = JSON.parse(JSON.stringify(attrs));\n        this.otherTileAttributes = (clazz ?? { attributes: [] }).attributes\n          .filter((attr) => !attrs.includes(attr.technicalName))\n          .map((attr) => attr.technicalName);\n      })\n    );\n    this.subscriptions.add(\n      this.store.select(ConfigSelectors.maxAttributesInTiles).subscribe((max) => {\n        this.maxTilesAttributes = max;\n      })\n    );\n  }\n\n  goBack() {\n    const path = this.router.createUrlTree(['../..'], { relativeTo: this.route });\n    this.store.dispatch(AdminClassActions.back({ path: path.toString() }));\n  }\n\n  drop(event: CdkDragDrop<string[]>) {\n    if (event.previousContainer === event.container) {\n      moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);\n    } else {\n      transferArrayItem(event.previousContainer.data, event.container.data, event.previousIndex, event.currentIndex);\n    }\n    const toSort = event.previousContainer.id === 'cdk-drop-list-1' ? event.previousContainer : event.container;\n    toSort.data.sort((a, b) => a.toLowerCase().localeCompare(b.toLowerCase()));\n  }\n\n  updateTableAttrs() {\n    this.store.dispatch(\n      ConfigActions.saveTableDefaultAttributes({\n        definitions: { [this.currentClass.id]: this.defaultAttributes.sort() }\n      })\n    );\n    this.goBack();\n  }\n\n  updateTileAttrs() {\n    this.store.dispatch(\n      ConfigActions.saveTileAttributes({\n        definitions: { [this.currentClass.id]: this.defaultTileAttributes }\n      })\n    );\n    this.goBack();\n  }\n\n  isTileConfValid() {\n    return this.defaultTileAttributes.length > 0 && this.defaultTileAttributes.length <= this.maxTilesAttributes;\n  }\n}\n","<div class=\"o-pry-admin-classes-customize\">\n  <h1 class=\"a-h1\" id=\"tab-custom\">{{ '@pry.admin.customize.title' | i18n }}</h1>\n\n  <pry-tab-group translationStringBase=\"@pry.admin.\">\n    <pry-tab [templateRef]=\"customizeTemplate\" name=\"customize.template\"></pry-tab>\n    <pry-tab [templateRef]=\"customizeTable\" name=\"customize.table\"></pry-tab>\n    <pry-tab [templateRef]=\"customizeSymbol\" name=\"classes.rules\"></pry-tab>\n    <pry-tab [templateRef]=\"customizeTile\" name=\"customize.tile\"></pry-tab>\n  </pry-tab-group>\n\n  <ng-template #customizeTemplate>\n    <pry-admin-classes-customize-tooltip\n      (backPressed)=\"goBack()\"\n      [currentClass]=\"currentClass$ | async\"\n    ></pry-admin-classes-customize-tooltip>\n  </ng-template>\n  <ng-template #customizeTable>\n    <div class=\"container\">\n      <h2>{{ '@pry.admin.customize.tableAttrs' | i18n }}</h2>\n      <div\n        cdkDropList\n        #defaultList=\"cdkDropList\"\n        [cdkDropListData]=\"defaultAttributes\"\n        [cdkDropListConnectedTo]=\"[notDefaultList]\"\n        class=\"list\"\n        (cdkDropListDropped)=\"drop($event)\"\n      >\n        <div class=\"item\" *ngFor=\"let item of defaultAttributes\" cdkDrag>{{ item }}</div>\n      </div>\n    </div>\n\n    <div class=\"container\">\n      <h2>{{ '@pry.admin.customize.noTableAttrs' | i18n }}</h2>\n      <div\n        cdkDropList\n        #notDefaultList=\"cdkDropList\"\n        [cdkDropListData]=\"otherAttributes\"\n        [cdkDropListConnectedTo]=\"[defaultList]\"\n        class=\"list\"\n        (cdkDropListDropped)=\"drop($event)\"\n      >\n        <div class=\"item\" *ngFor=\"let item of otherAttributes\" cdkDrag>{{ item }}</div>\n      </div>\n    </div>\n\n    <div class=\"m-btn-group -width-lg\">\n      <button\n        type=\"button\"\n        class=\"a-btn a-btn--secondary\"\n        (click)=\"goBack()\"\n        [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n      ></button>\n      <button class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTableAttrs()\">\n        {{ '@pry.admin.customize.updateTable' | i18n }}\n      </button>\n    </div>\n  </ng-template>\n  <ng-template #customizeSymbol>\n    <pry-admin-classes-customize-symbol\n      (backPressed)=\"goBack()\"\n      [currentClass]=\"currentClass$ | async\"\n    ></pry-admin-classes-customize-symbol>\n  </ng-template>\n  <ng-template #customizeTile>\n    <div class=\"container\">\n      <h2>{{ '@pry.admin.customize.tile' | i18n }}</h2>\n      <div\n        cdkDropList\n        #defaultTilesList=\"cdkDropList\"\n        [cdkDropListData]=\"defaultTileAttributes\"\n        [cdkDropListConnectedTo]=\"[notDefaultTilesList]\"\n        class=\"list\"\n        (cdkDropListDropped)=\"drop($event)\"\n      >\n        <div class=\"item\" *ngFor=\"let item of defaultTileAttributes\" cdkDrag>{{ item }}</div>\n      </div>\n    </div>\n\n    <div class=\"container\">\n      <h2>{{ '@pry.admin.customize.noTileAttrs' | i18n }}</h2>\n      <div\n        cdkDropList\n        #notDefaultTilesList=\"cdkDropList\"\n        [cdkDropListData]=\"otherTileAttributes\"\n        [cdkDropListConnectedTo]=\"[defaultTilesList]\"\n        class=\"list\"\n        (cdkDropListDropped)=\"drop($event)\"\n      >\n        <div class=\"item\" *ngFor=\"let item of otherTileAttributes\" cdkDrag>{{ item }}</div>\n      </div>\n    </div>\n\n    <div>\n      <ng-container *ngIf=\"!isTileConfValid()\">\n        <p>{{ '@pry.admin.customize.tileHint' | i18n : { max: maxTilesAttributes } }}</p>\n      </ng-container>\n    </div>\n\n    <div class=\"m-btn-group -width-lg\">\n      <button\n        type=\"button\"\n        class=\"a-btn a-btn--secondary\"\n        (click)=\"goBack()\"\n        [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n      ></button>\n      <button class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTileAttrs()\" [disabled]=\"!isTileConfValid()\">\n        {{ '@pry.admin.customize.updateTile' | i18n }}\n      </button>\n    </div>\n  </ng-template>\n</div>\n"]}
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-classes-customize.component.js","sourceRoot":"","sources":["../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-customize/admin-classes-customize.component.ts","../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-customize/admin-classes-customize.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';\nimport { Component, OnDestroy } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  Class,\n  ClassActions,\n  ClassSelectors,\n  ConfigActions,\n  ConfigSelectors,\n  Field,\n  FieldActions,\n  FieldSelectors,\n  ItemUtils,\n  SubscriptionnerDirective\n} from '@provoly/dashboard';\nimport { combineLatest, combineLatestWith, map, Observable, of, switchMap } from 'rxjs';\nimport { AdminClassActions } from '../store/admin-class.actions';\nimport { AdminClassSelectors } from '../store/admin-class.selectors';\n\n@Component({\n  selector: 'pry-admin-classes-customize',\n  templateUrl: './admin-classes-customize.component.html'\n})\nexport class AdminClassesCustomizeComponent extends SubscriptionnerDirective implements OnDestroy {\n  currentClass$: Observable<Class | undefined>;\n  currentClass: Class = {} as Class;\n  defaultAttributes: string[] = [];\n  otherAttributes: string[] = [];\n  currentPropertiesConfig$: Observable<string[]>;\n  currentTilePropertiesConfig$: Observable<string[]>;\n  classes$: Observable<Class[]> = of([]);\n  defaultTileAttributes: string[] = [];\n  otherTileAttributes: string[] = [];\n  maxTilesAttributes = 5;\n  fields$: Observable<Field[]>;\n\n  constructor(private store: Store<any>, private router: Router, private route: ActivatedRoute) {\n    super();\n    this.subscriptions.add(\n      this.route.params.subscribe((params) =>\n        this.store.dispatch(AdminClassActions.selectClass({ clazz: { id: params['id'] } as Class }))\n      )\n    );\n    this.store.dispatch(ClassActions.load());\n    this.store.dispatch(FieldActions.load());\n    this.store.dispatch(ConfigActions.loadCustomization());\n    this.fields$ = this.store.select(FieldSelectors.fields);\n    this.currentClass$ = combineLatest([\n      this.store.select(AdminClassSelectors.selectedClass),\n      this.store.select(ClassSelectors.classes)\n    ]).pipe(switchMap(([clazz, _]) => this.store.select(ClassSelectors.classById(clazz?.id ?? ''))));\n    this.subscriptions.add(this.currentClass$.subscribe((clazz) => (this.currentClass = clazz ?? ({} as Class))));\n    this.currentPropertiesConfig$ = this.store.select(ConfigSelectors.tableDefaultAttributesDefinitions).pipe(\n      combineLatestWith(this.currentClass$, this.fields$),\n      map(([defs, clazz, fields]) =>\n        ItemUtils.getAttributesDefinitionForClass((clazz ?? { attributes: [] }) as Class, defs, fields)\n      )\n    );\n    this.subscriptions.add(\n      this.currentPropertiesConfig$.pipe(combineLatestWith(this.currentClass$)).subscribe(([attrs, clazz]) => {\n        this.defaultAttributes = JSON.parse(JSON.stringify(attrs));\n        this.otherAttributes = (clazz ?? { attributes: [] }).attributes\n          .filter((attr) => !attrs.includes(attr.name))\n          .map((attr) => attr.name);\n      })\n    );\n    this.currentTilePropertiesConfig$ = this.store.select(ConfigSelectors.tileAttributesDefinitions).pipe(\n      combineLatestWith(this.currentClass$, this.fields$),\n      map(([defs, clazz, fields]) =>\n        ItemUtils.getAttributesDefinitionForClass((clazz ?? { attributes: [] }) as Class, defs, fields)\n      ),\n      map((attrs) => attrs.filter((_, i) => i < this.maxTilesAttributes))\n    );\n    this.subscriptions.add(\n      this.currentTilePropertiesConfig$.pipe(combineLatestWith(this.currentClass$)).subscribe(([attrs, clazz]) => {\n        this.defaultTileAttributes = JSON.parse(JSON.stringify(attrs));\n        this.otherTileAttributes = (clazz ?? { attributes: [] }).attributes\n          .filter((attr) => !attrs.includes(attr.name))\n          .map((attr) => attr.name);\n      })\n    );\n    this.subscriptions.add(\n      this.store.select(ConfigSelectors.maxAttributesInTiles).subscribe((max) => {\n        this.maxTilesAttributes = max;\n      })\n    );\n  }\n\n  goBack() {\n    const path = this.router.createUrlTree(['../..'], { relativeTo: this.route });\n    this.store.dispatch(AdminClassActions.back({ path: path.toString() }));\n  }\n\n  drop(event: CdkDragDrop<string[]>) {\n    if (event.previousContainer === event.container) {\n      moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);\n    } else {\n      transferArrayItem(event.previousContainer.data, event.container.data, event.previousIndex, event.currentIndex);\n    }\n    const toSort = event.previousContainer.id === 'cdk-drop-list-1' ? event.previousContainer : event.container;\n    toSort.data.sort((a, b) => a.toLowerCase().localeCompare(b.toLowerCase()));\n  }\n\n  updateTableAttrs() {\n    this.store.dispatch(\n      ConfigActions.saveTableDefaultAttributes({\n        definitions: { [this.currentClass.id]: this.defaultAttributes.sort() }\n      })\n    );\n    this.goBack();\n  }\n\n  updateTileAttrs() {\n    this.store.dispatch(\n      ConfigActions.saveTileAttributes({\n        definitions: { [this.currentClass.id]: this.defaultTileAttributes }\n      })\n    );\n    this.goBack();\n  }\n\n  isTileConfValid() {\n    return this.defaultTileAttributes.length > 0 && this.defaultTileAttributes.length <= this.maxTilesAttributes;\n  }\n}\n","<div class=\"o-pry-admin-classes-customize\">\n  <h1 class=\"a-h1\" id=\"tab-custom\">{{ '@pry.admin.customize.title' | i18n }}</h1>\n\n  <pry-tab-group translationStringBase=\"@pry.admin.\">\n    <pry-tab [templateRef]=\"customizeTemplate\" name=\"customize.template\"></pry-tab>\n    <pry-tab [templateRef]=\"customizeTable\" name=\"customize.table\"></pry-tab>\n    <pry-tab [templateRef]=\"customizeSymbol\" name=\"classes.rules\"></pry-tab>\n    <pry-tab [templateRef]=\"customizeTile\" name=\"customize.tile\"></pry-tab>\n  </pry-tab-group>\n\n  <ng-template #customizeTemplate>\n    <pry-admin-classes-customize-tooltip\n      (backPressed)=\"goBack()\"\n      [currentClass]=\"currentClass$ | async\"\n    ></pry-admin-classes-customize-tooltip>\n  </ng-template>\n  <ng-template #customizeTable>\n    <div class=\"container\">\n      <h2>{{ '@pry.admin.customize.tableAttrs' | i18n }}</h2>\n      <div\n        cdkDropList\n        #defaultList=\"cdkDropList\"\n        [cdkDropListData]=\"defaultAttributes\"\n        [cdkDropListConnectedTo]=\"[notDefaultList]\"\n        class=\"list\"\n        (cdkDropListDropped)=\"drop($event)\"\n      >\n        <div class=\"item\" *ngFor=\"let item of defaultAttributes\" cdkDrag>{{ item }}</div>\n      </div>\n    </div>\n\n    <div class=\"container\">\n      <h2>{{ '@pry.admin.customize.noTableAttrs' | i18n }}</h2>\n      <div\n        cdkDropList\n        #notDefaultList=\"cdkDropList\"\n        [cdkDropListData]=\"otherAttributes\"\n        [cdkDropListConnectedTo]=\"[defaultList]\"\n        class=\"list\"\n        (cdkDropListDropped)=\"drop($event)\"\n      >\n        <div class=\"item\" *ngFor=\"let item of otherAttributes\" cdkDrag>{{ item }}</div>\n      </div>\n    </div>\n\n    <div class=\"m-btn-group -width-lg\">\n      <button\n        type=\"button\"\n        class=\"a-btn a-btn--secondary\"\n        (click)=\"goBack()\"\n        [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n      ></button>\n      <button class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTableAttrs()\">\n        {{ '@pry.admin.customize.updateTable' | i18n }}\n      </button>\n    </div>\n  </ng-template>\n  <ng-template #customizeSymbol>\n    <pry-admin-classes-customize-symbol\n      (backPressed)=\"goBack()\"\n      [currentClass]=\"currentClass$ | async\"\n    ></pry-admin-classes-customize-symbol>\n  </ng-template>\n  <ng-template #customizeTile>\n    <div class=\"container\">\n      <h2>{{ '@pry.admin.customize.tile' | i18n }}</h2>\n      <div\n        cdkDropList\n        #defaultTilesList=\"cdkDropList\"\n        [cdkDropListData]=\"defaultTileAttributes\"\n        [cdkDropListConnectedTo]=\"[notDefaultTilesList]\"\n        class=\"list\"\n        (cdkDropListDropped)=\"drop($event)\"\n      >\n        <div class=\"item\" *ngFor=\"let item of defaultTileAttributes\" cdkDrag>{{ item }}</div>\n      </div>\n    </div>\n\n    <div class=\"container\">\n      <h2>{{ '@pry.admin.customize.noTileAttrs' | i18n }}</h2>\n      <div\n        cdkDropList\n        #notDefaultTilesList=\"cdkDropList\"\n        [cdkDropListData]=\"otherTileAttributes\"\n        [cdkDropListConnectedTo]=\"[defaultTilesList]\"\n        class=\"list\"\n        (cdkDropListDropped)=\"drop($event)\"\n      >\n        <div class=\"item\" *ngFor=\"let item of otherTileAttributes\" cdkDrag>{{ item }}</div>\n      </div>\n    </div>\n\n    <div>\n      <ng-container *ngIf=\"!isTileConfValid()\">\n        <p>{{ '@pry.admin.customize.tileHint' | i18n : { max: maxTilesAttributes } }}</p>\n      </ng-container>\n    </div>\n\n    <div class=\"m-btn-group -width-lg\">\n      <button\n        type=\"button\"\n        class=\"a-btn a-btn--secondary\"\n        (click)=\"goBack()\"\n        [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n      ></button>\n      <button class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTileAttrs()\" [disabled]=\"!isTileConfValid()\">\n        {{ '@pry.admin.customize.updateTile' | i18n }}\n      </button>\n    </div>\n  </ng-template>\n</div>\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output, ViewChild, ViewContainerRef } from '@angular/core';
|
|
2
|
-
import { ConfigActions, ConfigSelectors, SubscriptionnerDirective } from '@provoly/dashboard';
|
|
3
|
-
import { map } from 'rxjs';
|
|
2
|
+
import { ClassSelectors, ConfigActions, ConfigSelectors, FieldSelectors, SubscriptionnerDirective } from '@provoly/dashboard';
|
|
3
|
+
import { BehaviorSubject, combineLatest, map } from 'rxjs';
|
|
4
4
|
import { v4 } from 'uuid';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@provoly/dashboard";
|
|
@@ -10,15 +10,11 @@ import * as i4 from "@angular/forms";
|
|
|
10
10
|
import * as i5 from "@provoly/dashboard/components/checkbox";
|
|
11
11
|
export class AdminClassesCustomizeTooltipComponent extends SubscriptionnerDirective {
|
|
12
12
|
set currentClass(clazz) {
|
|
13
|
-
this._currentClass
|
|
14
|
-
this.
|
|
15
|
-
this.possibleAttributes = this.possibleNonAttributesFields
|
|
16
|
-
.concat(this.fields)
|
|
17
|
-
.sort((f1, f2) => f1.name.localeCompare(f2.name));
|
|
18
|
-
this.currentClassConfig = JSON.parse(JSON.stringify(this.defs[this.currentClass.id] ?? { type: 'default' }));
|
|
13
|
+
this._currentClass$.next(clazz ?? {});
|
|
14
|
+
this.currentClassConfig = this.removeUnknown(JSON.parse(JSON.stringify(this.defs[this.currentClass.id] ?? { type: 'default' })));
|
|
19
15
|
}
|
|
20
16
|
get currentClass() {
|
|
21
|
-
return this._currentClass;
|
|
17
|
+
return this._currentClass$.value;
|
|
22
18
|
}
|
|
23
19
|
constructor(tooltipFactoryService, injector, translateService, store) {
|
|
24
20
|
super();
|
|
@@ -28,7 +24,6 @@ export class AdminClassesCustomizeTooltipComponent extends SubscriptionnerDirect
|
|
|
28
24
|
this.store = store;
|
|
29
25
|
this.currentClassConfig = { type: 'default' };
|
|
30
26
|
this.advancedTooltip = false;
|
|
31
|
-
this.possibleAttributes = [];
|
|
32
27
|
this.possibleNonAttributesFields = [
|
|
33
28
|
{
|
|
34
29
|
name: 'id',
|
|
@@ -40,11 +35,11 @@ export class AdminClassesCustomizeTooltipComponent extends SubscriptionnerDirect
|
|
|
40
35
|
}
|
|
41
36
|
];
|
|
42
37
|
this.backPressed = new EventEmitter();
|
|
43
|
-
this._currentClass = {};
|
|
44
|
-
this.fields = [];
|
|
38
|
+
this._currentClass$ = new BehaviorSubject({});
|
|
45
39
|
this.strOptions = '';
|
|
46
40
|
this.defs = {};
|
|
47
41
|
this.noTooltip = false;
|
|
42
|
+
this.attributes = [];
|
|
48
43
|
this.possibleTooltipTypes$ = this.tooltipFactoryService.types$.pipe(map((types) => types.map((type) => ({
|
|
49
44
|
value: type,
|
|
50
45
|
label: this.translateService.instant('@pry.tooltip.' + type)
|
|
@@ -53,11 +48,31 @@ export class AdminClassesCustomizeTooltipComponent extends SubscriptionnerDirect
|
|
|
53
48
|
this.defs = defs;
|
|
54
49
|
this.currentClassConfig = JSON.parse(JSON.stringify(defs[this.currentClass.id] ?? { type: 'default' }));
|
|
55
50
|
}));
|
|
51
|
+
this.classes$ = this.store.select(ClassSelectors.classes);
|
|
52
|
+
this.fields$ = this.store.select(FieldSelectors.fields);
|
|
53
|
+
this.attributesOfClass$ = combineLatest([this._currentClass$, this.classes$]).pipe(map(([clazz, classes]) => classes.find((cl) => cl.id === clazz.id)?.attributes ?? []), map((attrs) => [...attrs, ...this.possibleNonAttributesFields].sort((f1, f2) => f1.name.localeCompare(f2.name))));
|
|
54
|
+
this.subscriptions.add(this.attributesOfClass$.subscribe((attrs) => {
|
|
55
|
+
this.attributes = attrs;
|
|
56
|
+
this.mockData = attrs
|
|
57
|
+
.map((attr) => ({
|
|
58
|
+
[attr.technicalName]: {
|
|
59
|
+
type: 'VALUE',
|
|
60
|
+
value: '«' + this.translateService.instant('@pry.admin.customize.exemple', { expr: attr.technicalName }) + '»',
|
|
61
|
+
visible: true
|
|
62
|
+
}
|
|
63
|
+
}))
|
|
64
|
+
.reduce((p, c) => ({ ...p, attributes: { ...p.attributes, ...c } }), {
|
|
65
|
+
oClass: this.currentClass.id,
|
|
66
|
+
id: v4(),
|
|
67
|
+
label: '«' + this.translateService.instant('@pry.admin.customize.exemple', { expr: 'label' }) + '»',
|
|
68
|
+
attributes: {}
|
|
69
|
+
});
|
|
70
|
+
}));
|
|
56
71
|
}
|
|
57
72
|
tooltipTypeChanged($event) {
|
|
58
73
|
this.currentClassConfig.type = $event;
|
|
59
74
|
if (this.currentClassConfig.type === 'attribute') {
|
|
60
|
-
this.currentClassConfig.options = { attributes: this.
|
|
75
|
+
this.currentClassConfig.options = { attributes: this.attributes.map((attr) => attr.id) };
|
|
61
76
|
}
|
|
62
77
|
else {
|
|
63
78
|
this.currentClassConfig.options = {};
|
|
@@ -78,20 +93,7 @@ export class AdminClassesCustomizeTooltipComponent extends SubscriptionnerDirect
|
|
|
78
93
|
component$.subscribe((component) => {
|
|
79
94
|
this.noTooltip = !component;
|
|
80
95
|
if (component) {
|
|
81
|
-
component.instance.data.item = this.
|
|
82
|
-
.map((attr) => ({
|
|
83
|
-
[attr.technicalName]: {
|
|
84
|
-
type: 'VALUE',
|
|
85
|
-
value: '«' + this.translateService.instant('@pry.admin.customize.exemple', { expr: attr.technicalName }) + '»',
|
|
86
|
-
visible: true
|
|
87
|
-
}
|
|
88
|
-
}))
|
|
89
|
-
.reduce((p, c) => ({ ...p, attributes: { ...p.attributes, ...c } }), {
|
|
90
|
-
oClass: this.currentClass.id,
|
|
91
|
-
id: v4(),
|
|
92
|
-
label: '«' + this.translateService.instant('@pry.admin.customize.exemple', { expr: 'label' }) + '»',
|
|
93
|
-
attributes: {}
|
|
94
|
-
});
|
|
96
|
+
component.instance.data.item = this.mockData;
|
|
95
97
|
this.tmpComponent = component;
|
|
96
98
|
component.instance.context = this.currentClassConfig.options;
|
|
97
99
|
}
|
|
@@ -110,12 +112,24 @@ export class AdminClassesCustomizeTooltipComponent extends SubscriptionnerDirect
|
|
|
110
112
|
this.currentClassConfig.options.attributes = $event;
|
|
111
113
|
setTimeout(() => this.updateExample(), 100);
|
|
112
114
|
}
|
|
115
|
+
removeUnknown(config) {
|
|
116
|
+
if (config.type === 'attribute') {
|
|
117
|
+
const toRemove = [];
|
|
118
|
+
config.options.attributes.forEach((attr) => {
|
|
119
|
+
if (!this.attributes.map((attr) => attr.id).includes(attr)) {
|
|
120
|
+
toRemove.push(attr);
|
|
121
|
+
}
|
|
122
|
+
});
|
|
123
|
+
config.options.attributes = config.options.attributes.filter((attr) => !toRemove.includes(attr));
|
|
124
|
+
}
|
|
125
|
+
return config;
|
|
126
|
+
}
|
|
113
127
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AdminClassesCustomizeTooltipComponent, deps: [{ token: i1.TooltipFactoryService }, { token: i0.Injector }, { token: i1.PryI18nService }, { token: i2.Store }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
114
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AdminClassesCustomizeTooltipComponent, selector: "pry-admin-classes-customize-tooltip", inputs: { currentClass: "currentClass" }, outputs: { backPressed: "backPressed" }, viewQueries: [{ propertyName: "example", first: true, predicate: ["example"], descendants: true, read: ViewContainerRef }], usesInheritance: true, ngImport: i0, template: "<div>\n <div class=\"m-form-label-field -width-xl\">\n <label class=\"a-label\" for=\"tooltip_type\">{{ '@pry.admin.customize.type' | i18n }}</label>\n <pry-select\n id=\"tooltip_type\"\n (ngModelChange)=\"tooltipTypeChanged($event)\"\n [ngModel]=\"currentClassConfig.type\"\n [items]=\"possibleTooltipTypes$ | async\"\n bindValue=\"value\"\n bindLabel=\"label\"\n ></pry-select>\n </div>\n\n <div>\n <pry-checkbox [(ngModel)]=\"advancedTooltip\">{{ '@pry.admin.customize.advanced' | i18n }}</pry-checkbox>\n </div>\n\n <div class=\"m-form-label-field -width-xl\" *ngIf=\"!advancedTooltip && currentClassConfig.type === 'attribute'\">\n <label class=\"a-label\" for=\"customize_simplified\">{{ '@pry.admin.customize.simplified' | i18n }}</label>\n <pry-select\n id=\"customize_simplified\"\n (ngModelChange)=\"changeAttributes($event)\"\n [ngModel]=\"currentClassConfig.options.attributes\"\n [items]=\"
|
|
128
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AdminClassesCustomizeTooltipComponent, selector: "pry-admin-classes-customize-tooltip", inputs: { currentClass: "currentClass" }, outputs: { backPressed: "backPressed" }, viewQueries: [{ propertyName: "example", first: true, predicate: ["example"], descendants: true, read: ViewContainerRef }], usesInheritance: true, ngImport: i0, template: "<div>\n <div class=\"m-form-label-field -width-xl\">\n <label class=\"a-label\" for=\"tooltip_type\">{{ '@pry.admin.customize.type' | i18n }}</label>\n <pry-select\n id=\"tooltip_type\"\n (ngModelChange)=\"tooltipTypeChanged($event)\"\n [ngModel]=\"currentClassConfig.type\"\n [items]=\"possibleTooltipTypes$ | async\"\n bindValue=\"value\"\n bindLabel=\"label\"\n ></pry-select>\n </div>\n\n <div>\n <pry-checkbox [(ngModel)]=\"advancedTooltip\">{{ '@pry.admin.customize.advanced' | i18n }}</pry-checkbox>\n </div>\n\n <div class=\"m-form-label-field -width-xl\" *ngIf=\"!advancedTooltip && currentClassConfig.type === 'attribute'\">\n <label class=\"a-label\" for=\"customize_simplified\">{{ '@pry.admin.customize.simplified' | i18n }}</label>\n <pry-select\n id=\"customize_simplified\"\n (ngModelChange)=\"changeAttributes($event)\"\n [ngModel]=\"currentClassConfig.options.attributes\"\n [items]=\"attributesOfClass$ | async\"\n [multiple]=\"true\"\n [closeOnSelect]=\"false\"\n bindLabel=\"name\"\n bindValue=\"id\"\n ></pry-select>\n </div>\n\n <ng-container *ngIf=\"advancedTooltip\">\n <textarea\n cols=\"100\"\n rows=\"15\"\n class=\"a-form-field\"\n [(ngModel)]=\"strOptions\"\n (focusout)=\"optionsChanged()\"\n ></textarea>\n </ng-container>\n</div>\n\n<div class=\"m-tooltip m-tooltip--example\" [class.-hidden]=\"noTooltip\">\n <div #example></div>\n</div>\n\n<div class=\"m-btn-group -width-md\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--secondary\"\n (click)=\"goBack()\"\n [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n ></button>\n <button class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTemplate()\">\n {{ '@pry.admin.customize.update' | i18n }}\n </button>\n</div>\n", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.PryCheckboxComponent, selector: "pry-checkbox", inputs: ["circle"] }, { kind: "component", type: i1.PrySelectComponent, selector: "pry-select", inputs: ["items", "clearable", "multiple", "closeOnSelect", "placeholder", "isForm", "required", "name", "readonly", "autocomplete", "bindValue", "bindLabel", "iconSize", "bindIcon", "template", "i18nPrefix", "bindClasses", "loading", "elementRef"], outputs: ["searched", "cleared"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.I18nPipe, name: "i18n" }] }); }
|
|
115
129
|
}
|
|
116
130
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AdminClassesCustomizeTooltipComponent, decorators: [{
|
|
117
131
|
type: Component,
|
|
118
|
-
args: [{ selector: 'pry-admin-classes-customize-tooltip', template: "<div>\n <div class=\"m-form-label-field -width-xl\">\n <label class=\"a-label\" for=\"tooltip_type\">{{ '@pry.admin.customize.type' | i18n }}</label>\n <pry-select\n id=\"tooltip_type\"\n (ngModelChange)=\"tooltipTypeChanged($event)\"\n [ngModel]=\"currentClassConfig.type\"\n [items]=\"possibleTooltipTypes$ | async\"\n bindValue=\"value\"\n bindLabel=\"label\"\n ></pry-select>\n </div>\n\n <div>\n <pry-checkbox [(ngModel)]=\"advancedTooltip\">{{ '@pry.admin.customize.advanced' | i18n }}</pry-checkbox>\n </div>\n\n <div class=\"m-form-label-field -width-xl\" *ngIf=\"!advancedTooltip && currentClassConfig.type === 'attribute'\">\n <label class=\"a-label\" for=\"customize_simplified\">{{ '@pry.admin.customize.simplified' | i18n }}</label>\n <pry-select\n id=\"customize_simplified\"\n (ngModelChange)=\"changeAttributes($event)\"\n [ngModel]=\"currentClassConfig.options.attributes\"\n [items]=\"
|
|
132
|
+
args: [{ selector: 'pry-admin-classes-customize-tooltip', template: "<div>\n <div class=\"m-form-label-field -width-xl\">\n <label class=\"a-label\" for=\"tooltip_type\">{{ '@pry.admin.customize.type' | i18n }}</label>\n <pry-select\n id=\"tooltip_type\"\n (ngModelChange)=\"tooltipTypeChanged($event)\"\n [ngModel]=\"currentClassConfig.type\"\n [items]=\"possibleTooltipTypes$ | async\"\n bindValue=\"value\"\n bindLabel=\"label\"\n ></pry-select>\n </div>\n\n <div>\n <pry-checkbox [(ngModel)]=\"advancedTooltip\">{{ '@pry.admin.customize.advanced' | i18n }}</pry-checkbox>\n </div>\n\n <div class=\"m-form-label-field -width-xl\" *ngIf=\"!advancedTooltip && currentClassConfig.type === 'attribute'\">\n <label class=\"a-label\" for=\"customize_simplified\">{{ '@pry.admin.customize.simplified' | i18n }}</label>\n <pry-select\n id=\"customize_simplified\"\n (ngModelChange)=\"changeAttributes($event)\"\n [ngModel]=\"currentClassConfig.options.attributes\"\n [items]=\"attributesOfClass$ | async\"\n [multiple]=\"true\"\n [closeOnSelect]=\"false\"\n bindLabel=\"name\"\n bindValue=\"id\"\n ></pry-select>\n </div>\n\n <ng-container *ngIf=\"advancedTooltip\">\n <textarea\n cols=\"100\"\n rows=\"15\"\n class=\"a-form-field\"\n [(ngModel)]=\"strOptions\"\n (focusout)=\"optionsChanged()\"\n ></textarea>\n </ng-container>\n</div>\n\n<div class=\"m-tooltip m-tooltip--example\" [class.-hidden]=\"noTooltip\">\n <div #example></div>\n</div>\n\n<div class=\"m-btn-group -width-md\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--secondary\"\n (click)=\"goBack()\"\n [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n ></button>\n <button class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTemplate()\">\n {{ '@pry.admin.customize.update' | i18n }}\n </button>\n</div>\n" }]
|
|
119
133
|
}], ctorParameters: function () { return [{ type: i1.TooltipFactoryService }, { type: i0.Injector }, { type: i1.PryI18nService }, { type: i2.Store }]; }, propDecorators: { example: [{
|
|
120
134
|
type: ViewChild,
|
|
121
135
|
args: ['example', { read: ViewContainerRef }]
|
|
@@ -124,4 +138,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
124
138
|
}], currentClass: [{
|
|
125
139
|
type: Input
|
|
126
140
|
}] } });
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-classes-customize-tooltip.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-customize/tooltip/admin-classes-customize-tooltip.component.ts","../../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-customize/tooltip/admin-classes-customize-tooltip.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ComponentRef,\n  EventEmitter,\n  Injector,\n  Input,\n  OnDestroy,\n  Output,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport {\n  Attribute,\n  AttributeSimpleValue,\n  BaseTooltipComponent,\n  Class,\n  ConfigActions,\n  ConfigSelectors,\n  Item,\n  PryI18nService,\n  SubscriptionnerDirective,\n  TooltipFactoryService,\n  TooltipOfClass\n} from '@provoly/dashboard';\nimport { map, Observable } from 'rxjs';\nimport { v4 } from 'uuid';\n\n@Component({\n  selector: 'pry-admin-classes-customize-tooltip',\n  templateUrl: './admin-classes-customize-tooltip.component.html'\n})\nexport class AdminClassesCustomizeTooltipComponent extends SubscriptionnerDirective implements OnDestroy {\n  @ViewChild('example', { read: ViewContainerRef }) example!: ViewContainerRef;\n  currentClassConfig: TooltipOfClass = { type: 'default' };\n  possibleTooltipTypes$: Observable<{ value: string; label: string }[]>;\n  advancedTooltip: boolean = false;\n  possibleAttributes: Attribute[] = [];\n  possibleNonAttributesFields = [\n    {\n      name: 'id',\n      id: 'id'\n    },\n    {\n      name: 'oClass',\n      id: 'oClass'\n    }\n  ] as Attribute[];\n  @Output() backPressed = new EventEmitter<void>();\n  private _currentClass: Class = {} as Class;\n  private fields: Attribute[] = [];\n  strOptions: string = '';\n  tmpComponent?: ComponentRef<BaseTooltipComponent>;\n  defs: { [p: string]: TooltipOfClass } = {};\n  noTooltip: boolean = false;\n\n  @Input() set currentClass(clazz: Class | null | undefined) {\n    this._currentClass = clazz ?? ({} as Class);\n    this.fields = (clazz ?? { attributes: [] }).attributes ?? [];\n    this.possibleAttributes = this.possibleNonAttributesFields\n      .concat(this.fields)\n      .sort((f1, f2) => f1.name.localeCompare(f2.name));\n    this.currentClassConfig = JSON.parse(JSON.stringify(this.defs[this.currentClass.id] ?? { type: 'default' }));\n  }\n\n  get currentClass(): Class {\n    return this._currentClass;\n  }\n\n  constructor(\n    private tooltipFactoryService: TooltipFactoryService,\n    private injector: Injector,\n    private translateService: PryI18nService,\n    private store: Store\n  ) {\n    super();\n    this.possibleTooltipTypes$ = this.tooltipFactoryService.types$.pipe(\n      map((types) =>\n        types.map((type) => ({\n          value: type,\n          label: this.translateService.instant('@pry.tooltip.' + type)\n        }))\n      )\n    );\n    this.subscriptions.add(\n      this.store.select(ConfigSelectors.tooltipDefinitions).subscribe((defs) => {\n        this.defs = defs;\n        this.currentClassConfig = JSON.parse(JSON.stringify(defs[this.currentClass.id] ?? { type: 'default' }));\n      })\n    );\n  }\n\n  tooltipTypeChanged($event: any) {\n    this.currentClassConfig.type = $event;\n    if (this.currentClassConfig.type === 'attribute') {\n      this.currentClassConfig.options = { attributes: this.possibleAttributes.map((attr) => attr.id) };\n    } else {\n      this.currentClassConfig.options = {};\n    }\n    this.strOptions = JSON.stringify(this.currentClassConfig.options);\n    this.updateExample();\n  }\n\n  optionsChanged() {\n    this.currentClassConfig.options = JSON.parse(this.strOptions);\n    if (this.tmpComponent) {\n      this.tmpComponent.instance.context = this.currentClassConfig.options;\n    }\n    this.updateExample();\n  }\n\n  updateExample() {\n    this.example?.clear();\n    const component$ = this.tooltipFactoryService.generateTooltip(\n      this.currentClassConfig.type,\n      this.injector,\n      this.example\n    );\n    component$.subscribe((component) => {\n      this.noTooltip = !component;\n      if (component) {\n        component.instance.data.item = this.fields\n          .map((attr) => ({\n            [attr.technicalName]: {\n              type: 'VALUE',\n              value:\n                '«' + this.translateService.instant('@pry.admin.customize.exemple', { expr: attr.technicalName }) + '»',\n              visible: true\n            } as AttributeSimpleValue\n          }))\n          .reduce((p, c) => ({ ...p, attributes: { ...p.attributes, ...c } }), {\n            oClass: this.currentClass.id,\n            id: v4(),\n            label: '«' + this.translateService.instant('@pry.admin.customize.exemple', { expr: 'label' }) + '»',\n            attributes: {} as { [key: string]: AttributeSimpleValue }\n          } as Item);\n\n        this.tmpComponent = component;\n\n        component.instance.context = this.currentClassConfig.options;\n      }\n    });\n  }\n\n  updateTemplate() {\n    this.store.dispatch(\n      ConfigActions.saveTooltip({\n        definitions: { [this.currentClass.id]: this.currentClassConfig }\n      })\n    );\n    this.goBack();\n  }\n\n  goBack() {\n    this.backPressed.emit();\n  }\n\n  changeAttributes($event: any) {\n    this.currentClassConfig.options.attributes = $event;\n    setTimeout(() => this.updateExample(), 100);\n  }\n}\n","<div>\n  <div class=\"m-form-label-field -width-xl\">\n    <label class=\"a-label\" for=\"tooltip_type\">{{ '@pry.admin.customize.type' | i18n }}</label>\n    <pry-select\n      id=\"tooltip_type\"\n      (ngModelChange)=\"tooltipTypeChanged($event)\"\n      [ngModel]=\"currentClassConfig.type\"\n      [items]=\"possibleTooltipTypes$ | async\"\n      bindValue=\"value\"\n      bindLabel=\"label\"\n    ></pry-select>\n  </div>\n\n  <div>\n    <pry-checkbox [(ngModel)]=\"advancedTooltip\">{{ '@pry.admin.customize.advanced' | i18n }}</pry-checkbox>\n  </div>\n\n  <div class=\"m-form-label-field -width-xl\" *ngIf=\"!advancedTooltip && currentClassConfig.type === 'attribute'\">\n    <label class=\"a-label\" for=\"customize_simplified\">{{ '@pry.admin.customize.simplified' | i18n }}</label>\n    <pry-select\n      id=\"customize_simplified\"\n      (ngModelChange)=\"changeAttributes($event)\"\n      [ngModel]=\"currentClassConfig.options.attributes\"\n      [items]=\"possibleAttributes\"\n      [multiple]=\"true\"\n      [closeOnSelect]=\"false\"\n      bindLabel=\"name\"\n      bindValue=\"id\"\n    ></pry-select>\n  </div>\n\n  <ng-container *ngIf=\"advancedTooltip\">\n    <textarea\n      cols=\"100\"\n      rows=\"15\"\n      class=\"a-form-field\"\n      [(ngModel)]=\"strOptions\"\n      (focusout)=\"optionsChanged()\"\n    ></textarea>\n  </ng-container>\n</div>\n\n<div class=\"m-tooltip m-tooltip--example\" [class.-hidden]=\"noTooltip\">\n  <div #example></div>\n</div>\n\n<div class=\"m-btn-group -width-md\">\n  <button\n    type=\"button\"\n    class=\"a-btn a-btn--secondary\"\n    (click)=\"goBack()\"\n    [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n  ></button>\n  <button class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTemplate()\">\n    {{ '@pry.admin.customize.update' | i18n }}\n  </button>\n</div>\n"]}
|
|
141
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"admin-classes-customize-tooltip.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-customize/tooltip/admin-classes-customize-tooltip.component.ts","../../../../../../../../../projects/provoly/dashboard/admin/components/admin-classes/admin-classes-customize/tooltip/admin-classes-customize-tooltip.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ComponentRef,\n  EventEmitter,\n  Injector,\n  Input,\n  OnDestroy,\n  Output,\n  ViewChild,\n  ViewContainerRef\n} from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport {\n  Attribute,\n  AttributeSimpleValue,\n  BaseTooltipComponent,\n  Class,\n  ClassSelectors,\n  ConfigActions,\n  ConfigSelectors,\n  Field,\n  FieldSelectors,\n  Item,\n  PryI18nService,\n  SubscriptionnerDirective,\n  TooltipFactoryService,\n  TooltipOfClass\n} from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, map, Observable } from 'rxjs';\nimport { v4 } from 'uuid';\n\n@Component({\n  selector: 'pry-admin-classes-customize-tooltip',\n  templateUrl: './admin-classes-customize-tooltip.component.html'\n})\nexport class AdminClassesCustomizeTooltipComponent extends SubscriptionnerDirective implements OnDestroy {\n  @ViewChild('example', { read: ViewContainerRef }) example!: ViewContainerRef;\n  currentClassConfig: TooltipOfClass = { type: 'default' };\n  possibleTooltipTypes$: Observable<{ value: string; label: string }[]>;\n  advancedTooltip: boolean = false;\n  possibleNonAttributesFields = [\n    {\n      name: 'id',\n      id: 'id'\n    },\n    {\n      name: 'oClass',\n      id: 'oClass'\n    }\n  ] as Attribute[];\n  @Output() backPressed = new EventEmitter<void>();\n  private _currentClass$ = new BehaviorSubject<Class>({} as Class);\n  strOptions: string = '';\n  tmpComponent?: ComponentRef<BaseTooltipComponent>;\n  defs: { [p: string]: TooltipOfClass } = {};\n  noTooltip: boolean = false;\n  classes$: Observable<Class[]>;\n  fields$: Observable<Field[]>;\n  attributesOfClass$: Observable<Attribute[]>;\n  mockData: any;\n  attributes: Attribute[] = [];\n\n  @Input() set currentClass(clazz: Class | null | undefined) {\n    this._currentClass$.next(clazz ?? ({} as Class));\n    this.currentClassConfig = this.removeUnknown(\n      JSON.parse(JSON.stringify(this.defs[this.currentClass.id] ?? { type: 'default' }))\n    );\n  }\n\n  get currentClass(): Class {\n    return this._currentClass$.value;\n  }\n\n  constructor(\n    private tooltipFactoryService: TooltipFactoryService,\n    private injector: Injector,\n    private translateService: PryI18nService,\n    private store: Store\n  ) {\n    super();\n    this.possibleTooltipTypes$ = this.tooltipFactoryService.types$.pipe(\n      map((types) =>\n        types.map((type) => ({\n          value: type,\n          label: this.translateService.instant('@pry.tooltip.' + type)\n        }))\n      )\n    );\n    this.subscriptions.add(\n      this.store.select(ConfigSelectors.tooltipDefinitions).subscribe((defs) => {\n        this.defs = defs;\n        this.currentClassConfig = JSON.parse(JSON.stringify(defs[this.currentClass.id] ?? { type: 'default' }));\n      })\n    );\n    this.classes$ = this.store.select(ClassSelectors.classes);\n    this.fields$ = this.store.select(FieldSelectors.fields);\n    this.attributesOfClass$ = combineLatest([this._currentClass$, this.classes$]).pipe(\n      map(([clazz, classes]) => classes.find((cl) => cl.id === clazz.id)?.attributes ?? []),\n      map((attrs) => [...attrs, ...this.possibleNonAttributesFields].sort((f1, f2) => f1.name.localeCompare(f2.name)))\n    );\n    this.subscriptions.add(\n      this.attributesOfClass$.subscribe((attrs) => {\n        this.attributes = attrs;\n        this.mockData = attrs\n          .map((attr) => ({\n            [attr.technicalName]: {\n              type: 'VALUE',\n              value:\n                '«' + this.translateService.instant('@pry.admin.customize.exemple', { expr: attr.technicalName }) + '»',\n              visible: true\n            } as AttributeSimpleValue\n          }))\n          .reduce((p, c) => ({ ...p, attributes: { ...p.attributes, ...c } }), {\n            oClass: this.currentClass.id,\n            id: v4(),\n            label: '«' + this.translateService.instant('@pry.admin.customize.exemple', { expr: 'label' }) + '»',\n            attributes: {} as { [key: string]: AttributeSimpleValue }\n          } as Item);\n      })\n    );\n  }\n\n  tooltipTypeChanged($event: any) {\n    this.currentClassConfig.type = $event;\n    if (this.currentClassConfig.type === 'attribute') {\n      this.currentClassConfig.options = { attributes: this.attributes.map((attr) => attr.id) };\n    } else {\n      this.currentClassConfig.options = {};\n    }\n    this.strOptions = JSON.stringify(this.currentClassConfig.options);\n    this.updateExample();\n  }\n\n  optionsChanged() {\n    this.currentClassConfig.options = JSON.parse(this.strOptions);\n    if (this.tmpComponent) {\n      this.tmpComponent.instance.context = this.currentClassConfig.options;\n    }\n    this.updateExample();\n  }\n\n  updateExample() {\n    this.example?.clear();\n    const component$ = this.tooltipFactoryService.generateTooltip(\n      this.currentClassConfig.type,\n      this.injector,\n      this.example\n    );\n    component$.subscribe((component) => {\n      this.noTooltip = !component;\n      if (component) {\n        component.instance.data.item = this.mockData;\n\n        this.tmpComponent = component;\n\n        component.instance.context = this.currentClassConfig.options;\n      }\n    });\n  }\n\n  updateTemplate() {\n    this.store.dispatch(\n      ConfigActions.saveTooltip({\n        definitions: { [this.currentClass.id]: this.currentClassConfig }\n      })\n    );\n    this.goBack();\n  }\n\n  goBack() {\n    this.backPressed.emit();\n  }\n\n  changeAttributes($event: any) {\n    this.currentClassConfig.options.attributes = $event;\n    setTimeout(() => this.updateExample(), 100);\n  }\n\n  private removeUnknown(config: TooltipOfClass): TooltipOfClass {\n    if (config.type === 'attribute') {\n      const toRemove: string[] = [];\n      config.options.attributes.forEach((attr: string) => {\n        if (!this.attributes.map((attr) => attr.id).includes(attr)) {\n          toRemove.push(attr);\n        }\n      });\n      config.options.attributes = config.options.attributes.filter((attr: string) => !toRemove.includes(attr));\n    }\n    return config;\n  }\n}\n","<div>\n  <div class=\"m-form-label-field -width-xl\">\n    <label class=\"a-label\" for=\"tooltip_type\">{{ '@pry.admin.customize.type' | i18n }}</label>\n    <pry-select\n      id=\"tooltip_type\"\n      (ngModelChange)=\"tooltipTypeChanged($event)\"\n      [ngModel]=\"currentClassConfig.type\"\n      [items]=\"possibleTooltipTypes$ | async\"\n      bindValue=\"value\"\n      bindLabel=\"label\"\n    ></pry-select>\n  </div>\n\n  <div>\n    <pry-checkbox [(ngModel)]=\"advancedTooltip\">{{ '@pry.admin.customize.advanced' | i18n }}</pry-checkbox>\n  </div>\n\n  <div class=\"m-form-label-field -width-xl\" *ngIf=\"!advancedTooltip && currentClassConfig.type === 'attribute'\">\n    <label class=\"a-label\" for=\"customize_simplified\">{{ '@pry.admin.customize.simplified' | i18n }}</label>\n    <pry-select\n      id=\"customize_simplified\"\n      (ngModelChange)=\"changeAttributes($event)\"\n      [ngModel]=\"currentClassConfig.options.attributes\"\n      [items]=\"attributesOfClass$ | async\"\n      [multiple]=\"true\"\n      [closeOnSelect]=\"false\"\n      bindLabel=\"name\"\n      bindValue=\"id\"\n    ></pry-select>\n  </div>\n\n  <ng-container *ngIf=\"advancedTooltip\">\n    <textarea\n      cols=\"100\"\n      rows=\"15\"\n      class=\"a-form-field\"\n      [(ngModel)]=\"strOptions\"\n      (focusout)=\"optionsChanged()\"\n    ></textarea>\n  </ng-container>\n</div>\n\n<div class=\"m-tooltip m-tooltip--example\" [class.-hidden]=\"noTooltip\">\n  <div #example></div>\n</div>\n\n<div class=\"m-btn-group -width-md\">\n  <button\n    type=\"button\"\n    class=\"a-btn a-btn--secondary\"\n    (click)=\"goBack()\"\n    [innerHTML]=\"'@pry.admin.cancel' | i18n\"\n  ></button>\n  <button class=\"a-btn a-btn--primary\" type=\"submit\" (click)=\"updateTemplate()\">\n    {{ '@pry.admin.customize.update' | i18n }}\n  </button>\n</div>\n"]}
|
|
@@ -29,10 +29,10 @@ export class AdminMenuComponent extends BaseMenuComponent {
|
|
|
29
29
|
this.store.dispatch(AdminActions.highlightMenu({ menu }));
|
|
30
30
|
}
|
|
31
31
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AdminMenuComponent, deps: [{ token: i1.Store }, { token: i2.Router }, { token: i2.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
32
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AdminMenuComponent, selector: "pry-admin-menu", usesInheritance: true, ngImport: i0, template: "<nav class=\"m-nav-links\">\n <ng-container *ngFor=\"let sub of subMenu$ | async\">\n <ul class=\"m-nav-links__list\">\n <ng-container *ngFor=\"let menu of sub.subMenus\">\n <li\n *pryAccess=\"{ module: menu.module, page: menu.page, subMenu: menu.subMenu }\"\n class=\"m-nav-links__list__item\"\n >\n <a [routerLink]=\"menu.menu\" class=\"a-btn
|
|
32
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AdminMenuComponent, selector: "pry-admin-menu", usesInheritance: true, ngImport: i0, template: "<nav class=\"m-nav-links\">\n <ng-container *ngFor=\"let sub of subMenu$ | async\">\n <ul class=\"m-nav-links__list\">\n <ng-container *ngFor=\"let menu of sub.subMenus\">\n <li\n *pryAccess=\"{ module: menu.module, page: menu.page, subMenu: menu.subMenu }\"\n class=\"m-nav-links__list__item\"\n >\n <a [routerLink]=\"menu.menu\" class=\"a-btn -width-full\" [routerLinkActive]=\"'is-active'\">\n {{ baseMenuTranslation + menu.menu | i18n }}\n </a>\n </li>\n </ng-container>\n </ul>\n </ng-container>\n</nav>\n", dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.PryAccessDirective, selector: "[pryAccess]", inputs: ["pryAccess"] }, { kind: "directive", type: i2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i2.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] }); }
|
|
33
33
|
}
|
|
34
34
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AdminMenuComponent, decorators: [{
|
|
35
35
|
type: Component,
|
|
36
|
-
args: [{ selector: 'pry-admin-menu', template: "<nav class=\"m-nav-links\">\n <ng-container *ngFor=\"let sub of subMenu$ | async\">\n <ul class=\"m-nav-links__list\">\n <ng-container *ngFor=\"let menu of sub.subMenus\">\n <li\n *pryAccess=\"{ module: menu.module, page: menu.page, subMenu: menu.subMenu }\"\n class=\"m-nav-links__list__item\"\n >\n <a [routerLink]=\"menu.menu\" class=\"a-btn
|
|
36
|
+
args: [{ selector: 'pry-admin-menu', template: "<nav class=\"m-nav-links\">\n <ng-container *ngFor=\"let sub of subMenu$ | async\">\n <ul class=\"m-nav-links__list\">\n <ng-container *ngFor=\"let menu of sub.subMenus\">\n <li\n *pryAccess=\"{ module: menu.module, page: menu.page, subMenu: menu.subMenu }\"\n class=\"m-nav-links__list__item\"\n >\n <a [routerLink]=\"menu.menu\" class=\"a-btn -width-full\" [routerLinkActive]=\"'is-active'\">\n {{ baseMenuTranslation + menu.menu | i18n }}\n </a>\n </li>\n </ng-container>\n </ul>\n </ng-container>\n</nav>\n" }]
|
|
37
37
|
}], ctorParameters: function () { return [{ type: i1.Store }, { type: i2.Router }, { type: i2.ActivatedRoute }]; } });
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRtaW4tbWVudS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2Rhc2hib2FyZC9hZG1pbi9jb21wb25lbnRzL2FkbWluLW1lbnUvYWRtaW4tbWVudS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2Rhc2hib2FyZC9saWIvY29yZS9jb21wb25lbnRzL2Jhc2UtbWVudS9iYXNlLW1lbnUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUcxQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUN0RCxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ3pELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQzs7Ozs7O0FBTTdELE1BQU0sT0FBTyxrQkFBbUIsU0FBUSxpQkFBaUI7SUFHdkQsWUFDRSxLQUFpQixFQUNULE1BQWMsRUFDZCxLQUFxQjtRQUU3QixLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFITCxXQUFNLEdBQU4sTUFBTSxDQUFRO1FBQ2QsVUFBSyxHQUFMLEtBQUssQ0FBZ0I7UUFHN0IsSUFBSSxDQUFDLG1CQUFtQixHQUFHLG1CQUFtQixDQUFDO1FBQy9DLElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3BHLENBQUM7SUFFUSxJQUFJO1FBQ1gsSUFBSSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDdEQsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLGNBQWMsQ0FBQyxlQUFlLENBQUMsQ0FBQztRQUMxRSxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksZUFBZSxDQUFxQixTQUFTLENBQUMsQ0FBQztRQUNqRSxJQUFJLENBQUMsUUFBUSxHQUFHLGFBQWEsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLGNBQWMsQ0FBQyxRQUFRLENBQUMsRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQzNGLEdBQUcsQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksS0FBSyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FDdkYsQ0FBQztJQUNKLENBQUM7SUFFUSxNQUFNLENBQUMsSUFBWTtRQUMxQixNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFLEVBQUUsVUFBVSxFQUFFLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDO1FBQzNFLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDeEYsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsWUFBWSxDQUFDLGFBQWEsQ0FBQyxFQUFFLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztJQUM1RCxDQUFDOytHQTFCVSxrQkFBa0I7bUdBQWxCLGtCQUFrQiw2RUNiL0Isc2xCQWdCQTs7NEZESGEsa0JBQWtCO2tCQUo5QixTQUFTOytCQUNFLGdCQUFnQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQWN0aXZhdGVkUm91dGUsIFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQgeyBTdG9yZSB9IGZyb20gJ0BuZ3J4L3N0b3JlJztcbmltcG9ydCB7IEJhc2VNZW51Q29tcG9uZW50IH0gZnJvbSAnQHByb3ZvbHkvZGFzaGJvYXJkJztcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgY29tYmluZUxhdGVzdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgbWFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuaW1wb3J0IHsgQWRtaW5BY3Rpb25zIH0gZnJvbSAnLi4vLi4vc3RvcmUvYWRtaW4uYWN0aW9ucyc7XG5pbXBvcnQgeyBBZG1pblNlbGVjdG9ycyB9IGZyb20gJy4uLy4uL3N0b3JlL2FkbWluLnNlbGVjdG9ycyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ByeS1hZG1pbi1tZW51JyxcbiAgdGVtcGxhdGVVcmw6ICcuLi8uLi8uLi9saWIvY29yZS9jb21wb25lbnRzL2Jhc2UtbWVudS9iYXNlLW1lbnUuY29tcG9uZW50Lmh0bWwnXG59KVxuZXhwb3J0IGNsYXNzIEFkbWluTWVudUNvbXBvbmVudCBleHRlbmRzIEJhc2VNZW51Q29tcG9uZW50IHtcbiAgcHJpdmF0ZSBsaW1pdCQ/OiBCZWhhdmlvclN1YmplY3Q8c3RyaW5nIHwgdW5kZWZpbmVkPjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBzdG9yZTogU3RvcmU8YW55PixcbiAgICBwcml2YXRlIHJvdXRlcjogUm91dGVyLFxuICAgIHByaXZhdGUgcm91dGU6IEFjdGl2YXRlZFJvdXRlXG4gICkge1xuICAgIHN1cGVyKHN0b3JlKTtcbiAgICB0aGlzLmJhc2VNZW51VHJhbnNsYXRpb24gPSAnQHByeS5hZG1pbi5tZW51cy4nO1xuICAgIHRoaXMuc3Vic2NyaXB0aW9ucy5hZGQodGhpcy5yb3V0ZS5kYXRhLnN1YnNjcmliZSgoZGF0YSkgPT4gdGhpcy5saW1pdCQ/Lm5leHQoZGF0YVsnbGltaXRNZW51J10pKSk7XG4gIH1cblxuICBvdmVycmlkZSBpbml0KCkge1xuICAgIHRoaXMubWVudXMkID0gdGhpcy5zdG9yZS5zZWxlY3QoQWRtaW5TZWxlY3RvcnMubWVudXMpO1xuICAgIHRoaXMuaGlnaGxpZ2h0ZWRNZW51JCA9IHRoaXMuc3RvcmUuc2VsZWN0KEFkbWluU2VsZWN0b3JzLmhpZ2hsaWdodGVkTWVudSk7XG4gICAgdGhpcy5saW1pdCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PHN0cmluZyB8IHVuZGVmaW5lZD4odW5kZWZpbmVkKTtcbiAgICB0aGlzLnN1Yk1lbnUkID0gY29tYmluZUxhdGVzdChbdGhpcy5zdG9yZS5zZWxlY3QoQWRtaW5TZWxlY3RvcnMuc3ViTWVudXMpLCB0aGlzLmxpbWl0JF0pLnBpcGUoXG4gICAgICBtYXAoKFttZW51cywgbGltaXRdKSA9PiAobGltaXQgPyBtZW51cy5maWx0ZXIoKG1lbnUpID0+IG1lbnUubmFtZSA9PT0gbGltaXQpIDogbWVudXMpKVxuICAgICk7XG4gIH1cblxuICBvdmVycmlkZSBzZWxlY3QobWVudTogc3RyaW5nKTogdm9pZCB7XG4gICAgY29uc3QgcGF0aCA9IHRoaXMucm91dGVyLmNyZWF0ZVVybFRyZWUoW21lbnVdLCB7IHJlbGF0aXZlVG86IHRoaXMucm91dGUgfSk7XG4gICAgdGhpcy5zdG9yZS5kaXNwYXRjaChBZG1pbkFjdGlvbnMucm91dGVUbyh7IHBhdGg6IHBhdGgudG9TdHJpbmcoKSwgcGFyYW1zOiB1bmRlZmluZWQgfSkpO1xuICAgIHRoaXMuc3RvcmUuZGlzcGF0Y2goQWRtaW5BY3Rpb25zLmhpZ2hsaWdodE1lbnUoeyBtZW51IH0pKTtcbiAgfVxufVxuIiwiPG5hdiBjbGFzcz1cIm0tbmF2LWxpbmtzXCI+XG4gIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IHN1YiBvZiBzdWJNZW51JCB8IGFzeW5jXCI+XG4gICAgPHVsIGNsYXNzPVwibS1uYXYtbGlua3NfX2xpc3RcIj5cbiAgICAgIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IG1lbnUgb2Ygc3ViLnN1Yk1lbnVzXCI+XG4gICAgICAgIDxsaVxuICAgICAgICAgICpwcnlBY2Nlc3M9XCJ7IG1vZHVsZTogbWVudS5tb2R1bGUsIHBhZ2U6IG1lbnUucGFnZSwgc3ViTWVudTogbWVudS5zdWJNZW51IH1cIlxuICAgICAgICAgIGNsYXNzPVwibS1uYXYtbGlua3NfX2xpc3RfX2l0ZW1cIlxuICAgICAgICA+XG4gICAgICAgICAgPGEgW3JvdXRlckxpbmtdPVwibWVudS5tZW51XCIgY2xhc3M9XCJhLWJ0biAtd2lkdGgtZnVsbFwiIFtyb3V0ZXJMaW5rQWN0aXZlXT1cIidpcy1hY3RpdmUnXCI+XG4gICAgICAgICAgICB7eyBiYXNlTWVudVRyYW5zbGF0aW9uICsgbWVudS5tZW51IHwgaTE4biB9fVxuICAgICAgICAgIDwvYT5cbiAgICAgICAgPC9saT5cbiAgICAgIDwvbmctY29udGFpbmVyPlxuICAgIDwvdWw+XG4gIDwvbmctY29udGFpbmVyPlxuPC9uYXY+XG4iXX0=
|
|
@@ -31,12 +31,12 @@ export class PryAboutComponent {
|
|
|
31
31
|
return !!value && (!!backVersion.chartVersion || !!frontVersion.libVersion);
|
|
32
32
|
}
|
|
33
33
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PryAboutComponent, deps: [{ token: i1.Store }, { token: i2.PryI18nService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
34
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: PryAboutComponent, selector: "pry-about", inputs: { tooltipPosition: "tooltipPosition" }, ngImport: i0, template: "<div class=\"o-about\">\n <div class=\"m-info-icon\">\n <span>i</span>\n </div>\n <div class=\"o-about__tooltip -position-{{ tooltipPosition }}\">\n <ng-container *ngFor=\"let version of (version$ | async) ?? {} | keyvalue\">\n <div class=\"o-about__line\">\n {{ '@pry.about.' + version.key | i18n }}\n <p class=\"a-chip -md\" [class.-not-found]=\"!hasVersion(version.value)\">\n {{ displayVersion(version.value) }}\n </p>\n </div>\n </ng-container>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.KeyValuePipe, name: "keyvalue" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] }); }
|
|
34
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: PryAboutComponent, selector: "pry-about", inputs: { tooltipPosition: "tooltipPosition" }, ngImport: i0, template: "<div class=\"o-about\">\n <div class=\"m-info-icon\">\n <span>i</span>\n </div>\n <div class=\"o-about__tooltip -position-{{ tooltipPosition }}\">\n <ng-container *ngFor=\"let version of (version$ | async) ?? {} | keyvalue\">\n <div class=\"o-about__line\">\n {{ '@pry.about.' + version.key | i18n }}\n <p class=\"a-chip -md -no-wrap\" [class.-not-found]=\"!hasVersion(version.value)\">\n {{ displayVersion(version.value) }}\n </p>\n </div>\n </ng-container>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.KeyValuePipe, name: "keyvalue" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }] }); }
|
|
35
35
|
}
|
|
36
36
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PryAboutComponent, decorators: [{
|
|
37
37
|
type: Component,
|
|
38
|
-
args: [{ selector: 'pry-about', template: "<div class=\"o-about\">\n <div class=\"m-info-icon\">\n <span>i</span>\n </div>\n <div class=\"o-about__tooltip -position-{{ tooltipPosition }}\">\n <ng-container *ngFor=\"let version of (version$ | async) ?? {} | keyvalue\">\n <div class=\"o-about__line\">\n {{ '@pry.about.' + version.key | i18n }}\n <p class=\"a-chip -md\" [class.-not-found]=\"!hasVersion(version.value)\">\n {{ displayVersion(version.value) }}\n </p>\n </div>\n </ng-container>\n </div>\n</div>\n" }]
|
|
38
|
+
args: [{ selector: 'pry-about', template: "<div class=\"o-about\">\n <div class=\"m-info-icon\">\n <span>i</span>\n </div>\n <div class=\"o-about__tooltip -position-{{ tooltipPosition }}\">\n <ng-container *ngFor=\"let version of (version$ | async) ?? {} | keyvalue\">\n <div class=\"o-about__line\">\n {{ '@pry.about.' + version.key | i18n }}\n <p class=\"a-chip -md -no-wrap\" [class.-not-found]=\"!hasVersion(version.value)\">\n {{ displayVersion(version.value) }}\n </p>\n </div>\n </ng-container>\n </div>\n</div>\n" }]
|
|
39
39
|
}], ctorParameters: function () { return [{ type: i1.Store }, { type: i2.PryI18nService }]; }, propDecorators: { tooltipPosition: [{
|
|
40
40
|
type: Input
|
|
41
41
|
}] } });
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJvdXQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJvdm9seS9kYXNoYm9hcmQvbGliL2NvcmUvY29tcG9uZW50cy9hYm91dC9hYm91dC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2Rhc2hib2FyZC9saWIvY29yZS9jb21wb25lbnRzL2Fib3V0L2Fib3V0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBSWpELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUNBQXFDLENBQUM7Ozs7OztBQU90RSxNQUFNLE9BQU8saUJBQWlCO0lBVzVCLFlBQW9CLEtBQVksRUFBVSxXQUEyQjtRQUFqRCxVQUFLLEdBQUwsS0FBSyxDQUFPO1FBQVUsZ0JBQVcsR0FBWCxXQUFXLENBQWdCO1FBVjVELG9CQUFlLEdBUUgsUUFBUSxDQUFDO1FBRzVCLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxZQUFZLEVBQUUsQ0FBQyxDQUFDO1FBQ2xELElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsZUFBZSxDQUFDLGNBQWMsQ0FBQyxDQUFDO0lBQ3BFLENBQUM7SUFFRCxjQUFjLENBQUMsS0FBdUM7UUFDcEQsTUFBTSxXQUFXLEdBQUcsS0FBdUIsQ0FBQztRQUM1QyxJQUFJLENBQUMsQ0FBQyxXQUFXLENBQUMsa0JBQWtCLEVBQUU7WUFDcEMsT0FBTyxHQUFHLFdBQVcsQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1NBQzVDO1FBQ0QsTUFBTSxZQUFZLEdBQUcsS0FBd0IsQ0FBQztRQUM5QyxJQUFJLENBQUMsQ0FBQyxZQUFZLENBQUMsVUFBVSxFQUFFO1lBQzdCLE9BQU8sWUFBWSxDQUFDLFVBQVUsQ0FBQztTQUNoQztRQUNELE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsc0JBQXNCLENBQUMsQ0FBQztJQUMxRCxDQUFDO0lBRUQsVUFBVSxDQUFDLEtBQXVDO1FBQ2hELE1BQU0sV0FBVyxHQUFHLEtBQXVCLENBQUM7UUFDNUMsTUFBTSxZQUFZLEdBQUcsS0FBd0IsQ0FBQztRQUM5QyxPQUFPLENBQUMsQ0FBQyxLQUFLLElBQUksQ0FBQyxDQUFDLENBQUMsV0FBVyxDQUFDLFlBQVksSUFBSSxDQUFDLENBQUMsWUFBWSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBQzlFLENBQUM7K0dBaENVLGlCQUFpQjttR0FBakIsaUJBQWlCLGlHQ1o5QixvaEJBZUE7OzRGREhhLGlCQUFpQjtrQkFKN0IsU0FBUzsrQkFDRSxXQUFXO3lIQUlaLGVBQWU7c0JBQXZCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTdG9yZSB9IGZyb20gJ0BuZ3J4L3N0b3JlJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IFByeUkxOG5TZXJ2aWNlIH0gZnJvbSAnLi4vLi4vaTE4bi9pMThuLnNlcnZpY2UnO1xuaW1wb3J0IHsgQ29uZmlnQWN0aW9ucyB9IGZyb20gJy4uLy4uL3N0b3JlL2NvbmZpZy9jb25maWcuYWN0aW9ucyc7XG5pbXBvcnQgeyBDb25maWdTZWxlY3RvcnMgfSBmcm9tICcuLi8uLi9zdG9yZS9jb25maWcvY29uZmlnLnNlbGVjdG9ycyc7XG5pbXBvcnQgeyBCYWNrZW5kVmVyc2lvbiwgRnJvbnRlbmRWZXJzaW9uLCBWZXJzaW9ucyB9IGZyb20gJy4uLy4uL3N0b3JlL2NvbmZpZy92ZXJzaW9ucy5pbnRlcmZhY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdwcnktYWJvdXQnLFxuICB0ZW1wbGF0ZVVybDogJ2Fib3V0LmNvbXBvbmVudC5odG1sJ1xufSlcbmV4cG9ydCBjbGFzcyBQcnlBYm91dENvbXBvbmVudCB7XG4gIEBJbnB1dCgpIHRvb2x0aXBQb3NpdGlvbjpcbiAgICB8ICd0b3AnXG4gICAgfCAnYm90dG9tJ1xuICAgIHwgJ2xlZnQnXG4gICAgfCAncmlnaHQnXG4gICAgfCAndG9wLWxlZnQnXG4gICAgfCAndG9wLXJpZ2h0J1xuICAgIHwgJ2JvdHRvbS1sZWZ0J1xuICAgIHwgJ2JvdHRvbS1yaWdodCcgPSAnYm90dG9tJztcbiAgdmVyc2lvbiQ6IE9ic2VydmFibGU8VmVyc2lvbnMgfCBudWxsPjtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzdG9yZTogU3RvcmUsIHByaXZhdGUgaTE4blNlcnZpY2U6IFByeUkxOG5TZXJ2aWNlKSB7XG4gICAgdGhpcy5zdG9yZS5kaXNwYXRjaChDb25maWdBY3Rpb25zLmxvYWRWZXJzaW9ucygpKTtcbiAgICB0aGlzLnZlcnNpb24kID0gdGhpcy5zdG9yZS5zZWxlY3QoQ29uZmlnU2VsZWN0b3JzLnNlbGVjdFZlcnNpb25zKTtcbiAgfVxuXG4gIGRpc3BsYXlWZXJzaW9uKHZhbHVlOiBCYWNrZW5kVmVyc2lvbiB8IEZyb250ZW5kVmVyc2lvbikge1xuICAgIGNvbnN0IGJhY2tWZXJzaW9uID0gdmFsdWUgYXMgQmFja2VuZFZlcnNpb247XG4gICAgaWYgKCEhYmFja1ZlcnNpb24uYXBwbGljYXRpb25WZXJzaW9uKSB7XG4gICAgICByZXR1cm4gYCR7YmFja1ZlcnNpb24uYXBwbGljYXRpb25WZXJzaW9ufWA7XG4gICAgfVxuICAgIGNvbnN0IGZyb250VmVyc2lvbiA9IHZhbHVlIGFzIEZyb250ZW5kVmVyc2lvbjtcbiAgICBpZiAoISFmcm9udFZlcnNpb24ubGliVmVyc2lvbikge1xuICAgICAgcmV0dXJuIGZyb250VmVyc2lvbi5saWJWZXJzaW9uO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcy5pMThuU2VydmljZS5pbnN0YW50KCdAcHJ5LmFib3V0Lm5vVmVyc2lvbicpO1xuICB9XG5cbiAgaGFzVmVyc2lvbih2YWx1ZTogQmFja2VuZFZlcnNpb24gfCBGcm9udGVuZFZlcnNpb24pIHtcbiAgICBjb25zdCBiYWNrVmVyc2lvbiA9IHZhbHVlIGFzIEJhY2tlbmRWZXJzaW9uO1xuICAgIGNvbnN0IGZyb250VmVyc2lvbiA9IHZhbHVlIGFzIEZyb250ZW5kVmVyc2lvbjtcbiAgICByZXR1cm4gISF2YWx1ZSAmJiAoISFiYWNrVmVyc2lvbi5jaGFydFZlcnNpb24gfHwgISFmcm9udFZlcnNpb24ubGliVmVyc2lvbik7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJvLWFib3V0XCI+XG4gIDxkaXYgY2xhc3M9XCJtLWluZm8taWNvblwiPlxuICAgIDxzcGFuPmk8L3NwYW4+XG4gIDwvZGl2PlxuICA8ZGl2IGNsYXNzPVwiby1hYm91dF9fdG9vbHRpcCAtcG9zaXRpb24te3sgdG9vbHRpcFBvc2l0aW9uIH19XCI+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgdmVyc2lvbiBvZiAodmVyc2lvbiQgfCBhc3luYykgPz8ge30gfCBrZXl2YWx1ZVwiPlxuICAgICAgPGRpdiBjbGFzcz1cIm8tYWJvdXRfX2xpbmVcIj5cbiAgICAgICAge3sgJ0BwcnkuYWJvdXQuJyArIHZlcnNpb24ua2V5IHwgaTE4biB9fVxuICAgICAgICA8cCBjbGFzcz1cImEtY2hpcCAtbWQgLW5vLXdyYXBcIiBbY2xhc3MuLW5vdC1mb3VuZF09XCIhaGFzVmVyc2lvbih2ZXJzaW9uLnZhbHVlKVwiPlxuICAgICAgICAgIHt7IGRpc3BsYXlWZXJzaW9uKHZlcnNpb24udmFsdWUpIH19XG4gICAgICAgIDwvcD5cbiAgICAgIDwvZGl2PlxuICAgIDwvbmctY29udGFpbmVyPlxuICA8L2Rpdj5cbjwvZGl2PlxuIl19
|
|
@@ -20,10 +20,10 @@ export class BaseMenuComponent extends SubscriptionnerDirective {
|
|
|
20
20
|
console.error('Must override init function');
|
|
21
21
|
}
|
|
22
22
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BaseMenuComponent, deps: [{ token: i1.Store }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
23
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: BaseMenuComponent, selector: "pry-base-menu", usesInheritance: true, ngImport: i0, template: "<nav class=\"m-nav-links\">\n <ng-container *ngFor=\"let sub of subMenu$ | async\">\n <ul class=\"m-nav-links__list\">\n <ng-container *ngFor=\"let menu of sub.subMenus\">\n <li\n *pryAccess=\"{ module: menu.module, page: menu.page, subMenu: menu.subMenu }\"\n class=\"m-nav-links__list__item\"\n >\n <a [routerLink]=\"menu.menu\" class=\"a-btn
|
|
23
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: BaseMenuComponent, selector: "pry-base-menu", usesInheritance: true, ngImport: i0, template: "<nav class=\"m-nav-links\">\n <ng-container *ngFor=\"let sub of subMenu$ | async\">\n <ul class=\"m-nav-links__list\">\n <ng-container *ngFor=\"let menu of sub.subMenus\">\n <li\n *pryAccess=\"{ module: menu.module, page: menu.page, subMenu: menu.subMenu }\"\n class=\"m-nav-links__list__item\"\n >\n <a [routerLink]=\"menu.menu\" class=\"a-btn -width-full\" [routerLinkActive]=\"'is-active'\">\n {{ baseMenuTranslation + menu.menu | i18n }}\n </a>\n </li>\n </ng-container>\n </ul>\n </ng-container>\n</nav>\n", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i3.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "directive", type: i4.PryAccessDirective, selector: "[pryAccess]", inputs: ["pryAccess"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i5.I18nPipe, name: "i18n" }] }); }
|
|
24
24
|
}
|
|
25
25
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BaseMenuComponent, decorators: [{
|
|
26
26
|
type: Component,
|
|
27
|
-
args: [{ selector: 'pry-base-menu', template: "<nav class=\"m-nav-links\">\n <ng-container *ngFor=\"let sub of subMenu$ | async\">\n <ul class=\"m-nav-links__list\">\n <ng-container *ngFor=\"let menu of sub.subMenus\">\n <li\n *pryAccess=\"{ module: menu.module, page: menu.page, subMenu: menu.subMenu }\"\n class=\"m-nav-links__list__item\"\n >\n <a [routerLink]=\"menu.menu\" class=\"a-btn
|
|
27
|
+
args: [{ selector: 'pry-base-menu', template: "<nav class=\"m-nav-links\">\n <ng-container *ngFor=\"let sub of subMenu$ | async\">\n <ul class=\"m-nav-links__list\">\n <ng-container *ngFor=\"let menu of sub.subMenus\">\n <li\n *pryAccess=\"{ module: menu.module, page: menu.page, subMenu: menu.subMenu }\"\n class=\"m-nav-links__list__item\"\n >\n <a [routerLink]=\"menu.menu\" class=\"a-btn -width-full\" [routerLinkActive]=\"'is-active'\">\n {{ baseMenuTranslation + menu.menu | i18n }}\n </a>\n </li>\n </ng-container>\n </ul>\n </ng-container>\n</nav>\n" }]
|
|
28
28
|
}], ctorParameters: function () { return [{ type: i1.Store }]; } });
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1tZW51LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Byb3ZvbHkvZGFzaGJvYXJkL2xpYi9jb3JlL2NvbXBvbmVudHMvYmFzZS1tZW51L2Jhc2UtbWVudS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2Rhc2hib2FyZC9saWIvY29yZS9jb21wb25lbnRzL2Jhc2UtbWVudS9iYXNlLW1lbnUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUcxQyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx5REFBeUQsQ0FBQzs7Ozs7OztBQW1CbkcsTUFBTSxPQUFPLGlCQUFrQixTQUFRLHdCQUF3QjtJQU03RCxZQUFzQixLQUFpQjtRQUNyQyxLQUFLLEVBQUUsQ0FBQztRQURZLFVBQUssR0FBTCxLQUFLLENBQVk7UUFMdkMsd0JBQW1CLEdBQUcsRUFBRSxDQUFDO1FBT3ZCLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNkLENBQUM7SUFFRCxNQUFNLENBQUMsSUFBWTtRQUNqQixPQUFPLENBQUMsS0FBSyxDQUFDLCtCQUErQixDQUFDLENBQUM7SUFDakQsQ0FBQztJQUVELElBQUk7UUFDRixPQUFPLENBQUMsS0FBSyxDQUFDLDZCQUE2QixDQUFDLENBQUM7SUFDL0MsQ0FBQzsrR0FqQlUsaUJBQWlCO21HQUFqQixpQkFBaUIsNEVDdEI5QixzbEJBZ0JBOzs0RkRNYSxpQkFBaUI7a0JBSjdCLFNBQVM7K0JBQ0UsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3RvcmUgfSBmcm9tICdAbmdyeC9zdG9yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyBTdWJzY3JpcHRpb25uZXJEaXJlY3RpdmUgfSBmcm9tICcuLi8uLi8uLi9kYXNoYm9hcmQvY29tcG9uZW50cy9zdWJzY3JpcHRpb25uZXIuZGlyZWN0aXZlJztcblxuZXhwb3J0IGludGVyZmFjZSBCYXNlTWVudUl0ZW0ge1xuICBtZW51OiBzdHJpbmc7XG4gIG1vZHVsZT86IHN0cmluZztcbiAgcGFnZT86IHN0cmluZztcbiAgc3ViTWVudT86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTdWJNZW51IHtcbiAgbmFtZT86IHN0cmluZztcbiAgaWNvbjogc3RyaW5nO1xuICBzdWJNZW51czogQmFzZU1lbnVJdGVtW107XG59XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ByeS1iYXNlLW1lbnUnLFxuICB0ZW1wbGF0ZVVybDogJy4vYmFzZS1tZW51LmNvbXBvbmVudC5odG1sJ1xufSlcbmV4cG9ydCBjbGFzcyBCYXNlTWVudUNvbXBvbmVudCBleHRlbmRzIFN1YnNjcmlwdGlvbm5lckRpcmVjdGl2ZSB7XG4gIGJhc2VNZW51VHJhbnNsYXRpb24gPSAnJztcbiAgbWVudXMkPzogT2JzZXJ2YWJsZTxCYXNlTWVudUl0ZW1bXT47XG4gIHN1Yk1lbnUkPzogT2JzZXJ2YWJsZTxTdWJNZW51W10+O1xuICBoaWdobGlnaHRlZE1lbnUkPzogT2JzZXJ2YWJsZTxzdHJpbmc+O1xuXG4gIGNvbnN0cnVjdG9yKHByb3RlY3RlZCBzdG9yZTogU3RvcmU8YW55Pikge1xuICAgIHN1cGVyKCk7XG4gICAgdGhpcy5pbml0KCk7XG4gIH1cblxuICBzZWxlY3QobWVudTogc3RyaW5nKTogdm9pZCB7XG4gICAgY29uc29sZS5lcnJvcignTXVzdCBvdmVycmlkZSBzZWxlY3QgZnVuY3Rpb24nKTtcbiAgfVxuXG4gIGluaXQoKTogdm9pZCB7XG4gICAgY29uc29sZS5lcnJvcignTXVzdCBvdmVycmlkZSBpbml0IGZ1bmN0aW9uJyk7XG4gIH1cbn1cbiIsIjxuYXYgY2xhc3M9XCJtLW5hdi1saW5rc1wiPlxuICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBzdWIgb2Ygc3ViTWVudSQgfCBhc3luY1wiPlxuICAgIDx1bCBjbGFzcz1cIm0tbmF2LWxpbmtzX19saXN0XCI+XG4gICAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBtZW51IG9mIHN1Yi5zdWJNZW51c1wiPlxuICAgICAgICA8bGlcbiAgICAgICAgICAqcHJ5QWNjZXNzPVwieyBtb2R1bGU6IG1lbnUubW9kdWxlLCBwYWdlOiBtZW51LnBhZ2UsIHN1Yk1lbnU6IG1lbnUuc3ViTWVudSB9XCJcbiAgICAgICAgICBjbGFzcz1cIm0tbmF2LWxpbmtzX19saXN0X19pdGVtXCJcbiAgICAgICAgPlxuICAgICAgICAgIDxhIFtyb3V0ZXJMaW5rXT1cIm1lbnUubWVudVwiIGNsYXNzPVwiYS1idG4gLXdpZHRoLWZ1bGxcIiBbcm91dGVyTGlua0FjdGl2ZV09XCInaXMtYWN0aXZlJ1wiPlxuICAgICAgICAgICAge3sgYmFzZU1lbnVUcmFuc2xhdGlvbiArIG1lbnUubWVudSB8IGkxOG4gfX1cbiAgICAgICAgICA8L2E+XG4gICAgICAgIDwvbGk+XG4gICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8L3VsPlxuICA8L25nLWNvbnRhaW5lcj5cbjwvbmF2PlxuIl19
|