barsa-tiles 2.2.1 → 2.2.3
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/barsa-tiles.mjs +5 -0
- package/esm2022/lib/action-item/action-item.component.mjs +17 -0
- package/esm2022/lib/action-links.pipe.mjs +17 -0
- package/esm2022/lib/actions-link/actions-link.component.mjs +49 -0
- package/esm2022/lib/app-finder/app-finder.component.mjs +52 -0
- package/esm2022/lib/app-finder-app-list/app-finder-app-list.component.mjs +39 -0
- package/esm2022/lib/app-finder-group/app-finder-group.component.mjs +41 -0
- package/esm2022/lib/app-finder.service.mjs +121 -0
- package/esm2022/lib/barsa-pin-app/barsa-pin-app.component.mjs +34 -0
- package/esm2022/lib/barsa-shellbar/barsa-shellbar.component.mjs +183 -0
- package/esm2022/lib/barsa-tile-group-page/barsa-tile-group-page.component.mjs +71 -0
- package/esm2022/lib/barsa-tile-sidebar-page/barsa-tile-sidebar-page.component.mjs +45 -0
- package/esm2022/lib/barsa-tiles-routing.module.mjs +58 -0
- package/esm2022/lib/barsa-tiles.module.mjs +278 -0
- package/esm2022/lib/change-app-tile/change-app-tile.component.mjs +46 -0
- package/esm2022/lib/create-app-group/create-app-group.component.mjs +43 -0
- package/esm2022/lib/directives/emptylist.directive.mjs +37 -0
- package/esm2022/lib/feed-tile/feed-tile.component.mjs +31 -0
- package/esm2022/lib/footer-edit-tile/footer-edit-tile.component.mjs +13 -0
- package/esm2022/lib/footer-tile/footer-tile.component.mjs +22 -0
- package/esm2022/lib/form-app-finder/form-app-finder.component.mjs +95 -0
- package/esm2022/lib/form-tile/form-tile.component.mjs +34 -0
- package/esm2022/lib/logo-tile/logo-tile.component.mjs +23 -0
- package/esm2022/lib/micro-tile-chart-area/micro-tile-chart-area.component.mjs +40 -0
- package/esm2022/lib/micro-tile-chart-bar/micro-tile-chart-bar.component.mjs +16 -0
- package/esm2022/lib/micro-tile-chart-bullet/micro-tile-chart-bullet.component.mjs +26 -0
- package/esm2022/lib/micro-tile-chart-circular/micro-tile-chart-circular.component.mjs +20 -0
- package/esm2022/lib/micro-tile-chart-comparison/micro-tile-chart-comparison.component.mjs +31 -0
- package/esm2022/lib/micro-tile-chart-line/micro-tile-chart-line.component.mjs +32 -0
- package/esm2022/lib/micro-tile-chart-stackbar/micro-tile-chart-stackbar.component.mjs +27 -0
- package/esm2022/lib/models/app-tile-footer-section.mjs +2 -0
- package/esm2022/lib/models/app-tile-footer.mjs +2 -0
- package/esm2022/lib/models/app-tile-group-pin.mjs +2 -0
- package/esm2022/lib/models/base-bt-tile-component.mjs +27 -0
- package/esm2022/lib/models/base-tile-component.mjs +59 -0
- package/esm2022/lib/models/base-tile-setting.mjs +2 -0
- package/esm2022/lib/models/feed-tile-setting.mjs +2 -0
- package/esm2022/lib/models/index.mjs +14 -0
- package/esm2022/lib/models/logo-tile-setting.mjs +2 -0
- package/esm2022/lib/models/micro-tile-chart-bullet-setting.mjs +2 -0
- package/esm2022/lib/models/news-tile-setting.mjs +2 -0
- package/esm2022/lib/models/numeric-tile-setting.mjs +2 -0
- package/esm2022/lib/models/profile-tile-setting.mjs +2 -0
- package/esm2022/lib/models/tile-setting.mjs +2 -0
- package/esm2022/lib/models/user-portal-settings.mjs +2 -0
- package/esm2022/lib/news-tile/news-tile.component.mjs +53 -0
- package/esm2022/lib/notification-group/notification-group.component.mjs +111 -0
- package/esm2022/lib/notification-group-header/notification-group-header.component.mjs +38 -0
- package/esm2022/lib/numeric-tile/numeric-tile.component.mjs +64 -0
- package/esm2022/lib/pin-tile/pin-tile.component.mjs +110 -0
- package/esm2022/lib/pipes/group-tiles.pipe.mjs +32 -0
- package/esm2022/lib/pipes/home-group.pipe.mjs +18 -0
- package/esm2022/lib/pipes/tile-home-filter.pipe.mjs +29 -0
- package/esm2022/lib/pipes/tile-prop.pipe.mjs +51 -0
- package/esm2022/lib/popover-app-finder/filter-apps-grouped.pipe.mjs +36 -0
- package/esm2022/lib/popover-app-finder/popover-app-finder.component.mjs +102 -0
- package/esm2022/lib/profile-tile/profile-tile.component.mjs +34 -0
- package/esm2022/lib/shellbar/shellbar.component.mjs +237 -0
- package/esm2022/lib/simple-tile/simple-tile.component.mjs +27 -0
- package/esm2022/lib/tile/tile.component.mjs +95 -0
- package/esm2022/lib/tile-renderer.directive.mjs +83 -0
- package/esm2022/lib/tile-size.directive.mjs +31 -0
- package/esm2022/lib/tile-style.directive.mjs +30 -0
- package/esm2022/lib/tiles-viewer/tiles-viewer.component.mjs +188 -0
- package/esm2022/lib/tiles-viewer-container/tiles-viewer-container.component.mjs +173 -0
- package/esm2022/lib/tiles-viewer-group/tiles-viewer-group.component.mjs +89 -0
- package/esm2022/lib/tiles-viewer.service.mjs +130 -0
- package/esm2022/lib/tiles.service.mjs +614 -0
- package/esm2022/public-api.mjs +49 -0
- package/package.json +3 -1
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import { BaseComponent, BarsaApi } from 'barsa-novin-ray-core';
|
|
3
|
+
import { CreateAppGroupComponent } from '../create-app-group/create-app-group.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@fundamental-ngx/core";
|
|
6
|
+
import * as i2 from "barsa-novin-ray-core";
|
|
7
|
+
import * as i3 from "@angular/forms";
|
|
8
|
+
import * as i4 from "@fundamental-ngx/core/bar";
|
|
9
|
+
import * as i5 from "@fundamental-ngx/core/checkbox";
|
|
10
|
+
import * as i6 from "@fundamental-ngx/core/icon";
|
|
11
|
+
import * as i7 from "@fundamental-ngx/core/list";
|
|
12
|
+
import * as i8 from "@fundamental-ngx/core/dialog";
|
|
13
|
+
import * as i9 from "@fundamental-ngx/cdk/utils";
|
|
14
|
+
import * as i10 from "@fundamental-ngx/core/title";
|
|
15
|
+
export class PinTileComponent extends BaseComponent {
|
|
16
|
+
constructor(_dialogService, _dialogRef, bbbPipe) {
|
|
17
|
+
super();
|
|
18
|
+
this._dialogService = _dialogService;
|
|
19
|
+
this._dialogRef = _dialogRef;
|
|
20
|
+
this.bbbPipe = bbbPipe;
|
|
21
|
+
this.newGroupText = BarsaApi.LoginFormData.IsRtl
|
|
22
|
+
? this.bbbPipe.transform('Groups') + ' ' + this.bbbPipe.transform('New')
|
|
23
|
+
: this.bbbPipe.transform('New') + ' ' + this.bbbPipe.transform('Groups');
|
|
24
|
+
this.app = _dialogRef.data.app;
|
|
25
|
+
this.appTileGroups = _dialogRef.data.appTileGroups;
|
|
26
|
+
this.pinnedAppInTileGroups = _dialogRef.data.pinnedAppInTileGroups;
|
|
27
|
+
}
|
|
28
|
+
ngOnInit() {
|
|
29
|
+
this._setLoading(true);
|
|
30
|
+
const tileGroupsId = this.pinnedAppInTileGroups[this.app.Id];
|
|
31
|
+
this.appTileGroups.forEach((appGroup) => {
|
|
32
|
+
this._setDefaultPinTile(appGroup, tileGroupsId);
|
|
33
|
+
});
|
|
34
|
+
this._setLoading(false);
|
|
35
|
+
}
|
|
36
|
+
onAccept() {
|
|
37
|
+
const appTileGroupsPin = [];
|
|
38
|
+
this.appTileGroups.forEach((group) => {
|
|
39
|
+
this._getChangedPinTileGroups(group, appTileGroupsPin);
|
|
40
|
+
});
|
|
41
|
+
this._close({ appTileGroupsPin, app: this.app });
|
|
42
|
+
}
|
|
43
|
+
onClose() {
|
|
44
|
+
this._close();
|
|
45
|
+
}
|
|
46
|
+
onNewGroup() {
|
|
47
|
+
this.newGroupDialogRef = this._dialogService.open(CreateAppGroupComponent, {
|
|
48
|
+
data: { title: this.newGroupText },
|
|
49
|
+
verticalPadding: true,
|
|
50
|
+
mobile: this.mobile,
|
|
51
|
+
responsivePadding: true
|
|
52
|
+
});
|
|
53
|
+
this.newGroupDialogRef.afterClosed.subscribe(() => {
|
|
54
|
+
// if (result) {
|
|
55
|
+
// this.dialogRef.loading(true);
|
|
56
|
+
// this.tilesService
|
|
57
|
+
// .createAppGroup(result)
|
|
58
|
+
// .pipe(
|
|
59
|
+
// takeUntil(this._onDestroy$),
|
|
60
|
+
// finalize(() => {
|
|
61
|
+
// this.dialogRef.loading(false);
|
|
62
|
+
// })
|
|
63
|
+
// )
|
|
64
|
+
// .subscribe();
|
|
65
|
+
// }
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
_setLoading(loading) {
|
|
69
|
+
this._dialogRef.loading(loading);
|
|
70
|
+
}
|
|
71
|
+
_setDefaultPinTile(appTileGroup, tileGroupsId) {
|
|
72
|
+
appTileGroup.$PinTile = appTileGroup.$DefaultPinTile =
|
|
73
|
+
tileGroupsId.includes(appTileGroup.Id) || tileGroupsId.includes(appTileGroup.UserAppTileGroupSetting?.Id);
|
|
74
|
+
appTileGroup.$Children?.forEach((subGroup) => {
|
|
75
|
+
this._setDefaultPinTile(subGroup, tileGroupsId);
|
|
76
|
+
});
|
|
77
|
+
appTileGroup.$Disabledpin = false;
|
|
78
|
+
}
|
|
79
|
+
_getChangedPinTileGroups(appTileGroup, appTileGroupsPin) {
|
|
80
|
+
if (appTileGroup.$PinTile && !appTileGroup.$DefaultPinTile) {
|
|
81
|
+
// Add
|
|
82
|
+
appTileGroupsPin.push({ appTileGroup, visible: true });
|
|
83
|
+
}
|
|
84
|
+
else if (appTileGroup.$PinTile === false && appTileGroup.$DefaultPinTile) {
|
|
85
|
+
// Remove
|
|
86
|
+
appTileGroupsPin.push({ appTileGroup, visible: false });
|
|
87
|
+
}
|
|
88
|
+
appTileGroup.$Children?.forEach((subGroup) => {
|
|
89
|
+
this._getChangedPinTileGroups(subGroup, appTileGroupsPin);
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
_close(result) {
|
|
93
|
+
this._dialogRef.close(result);
|
|
94
|
+
}
|
|
95
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PinTileComponent, deps: [{ token: i1.DialogService }, { token: i1.DialogRef }, { token: i2.BbbTranslatePipe }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
96
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: PinTileComponent, selector: "bt-pin-tile", inputs: { app: "app", appTileGroups: "appTileGroups", mobile: "mobile", pin: "pin" }, usesInheritance: true, ngImport: i0, template: "<fd-dialog>\r\n <fd-dialog-header>\r\n <h1 fd-title>{{ 'AddToList' | bbbTranslate }}</h1>\r\n </fd-dialog-header>\r\n <fd-dialog-body>\r\n <ul fd-list [navigationIndicator]=\"true\" style=\"margin-bottom: 1rem\">\r\n <li fd-list-item [navigationIndicator]=\"true\" (click)=\"onNewGroup()\">\r\n <fd-icon glyph=\"add\"></fd-icon><span fd-list-title>{{ newGroupText }}</span>\r\n </li>\r\n @for (appTileGroup of appTileGroups; track appTileGroup) { @if (!appTileGroup.$Disabledpin) {\r\n <li fd-list-item [selected]=\"appTileGroup.$PinTile\">\r\n <fd-checkbox [(ngModel)]=\"appTileGroup.$PinTile\"></fd-checkbox>\r\n <span fd-list-title>{{ appTileGroup.navigatorTitle || appTileGroup.Title }}</span>\r\n </li>\r\n } @for (subGroup of appTileGroup.$Children; track subGroup) { @if (!subGroup.$Disabledpin) {\r\n <li fd-list-item [selected]=\"subGroup.$PinTile\">\r\n <fd-checkbox [(ngModel)]=\"subGroup.$PinTile\"></fd-checkbox>\r\n <span fd-list-title>{{ subGroup.navigatorTitle || subGroup.Title }}</span>\r\n </li>\r\n } } }\r\n </ul>\r\n </fd-dialog-body>\r\n\r\n <fd-dialog-footer>\r\n <ng-template fdkTemplate=\"footer\">\r\n <div fd-bar-left></div>\r\n <div fd-bar-right>\r\n <fd-button-bar fdkInitialFocus fdType=\"emphasized\" [label]=\"'OK' | bbbTranslate\" (click)=\"onAccept()\">\r\n </fd-button-bar>\r\n <fd-button-bar\r\n fdkInitialFocus\r\n fdType=\"transparent\"\r\n [label]=\"'Cancel' | bbbTranslate\"\r\n (click)=\"onClose()\"\r\n >\r\n </fd-button-bar>\r\n </div>\r\n </ng-template>\r\n </fd-dialog-footer>\r\n</fd-dialog>\r\n", styles: [":host ::ng-deep .cdk-drag{cursor:default!important}:host *{cursor:default!important}li{cursor:pointer}fd-dialog-body,fd-dialog-footer,fd-dialog-header{cursor:default}fd-icon{padding:0 5px}\n"], dependencies: [{ kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.BarLeftDirective, selector: "[fd-bar-left]" }, { kind: "directive", type: i4.BarRightDirective, selector: "[fd-bar-right]" }, { kind: "component", type: i4.ButtonBarComponent, selector: "fd-button-bar", inputs: ["fullWidth", "fdType", "title", "ariaLabelledby", "id"] }, { kind: "component", type: i5.CheckboxComponent, selector: "fd-checkbox", inputs: ["wrapLabel", "valignLabel", "ariaLabel", "role", "value", "ariaLabelledBy", "ariaDescribedBy", "title", "inputId", "state", "name", "label", "disabled", "readonly", "tristate", "tristateSelectable", "labelClass", "required", "displayOnly", "values", "standalone"], outputs: ["focusChange"] }, { kind: "component", type: i6.IconComponent, selector: "fd-icon", inputs: ["glyph", "font", "color", "background", "class", "ariaLabel", "ariaHidden"] }, { kind: "component", type: i7.ListComponent, selector: "[fd-list], [fdList]", inputs: ["dropdownMode", "multiInputMode", "mobileMode", "hasMessage", "noBorder", "navigationIndicator", "selection", "keyboardSupport", "byline", "unreadIndicator", "role"], outputs: ["focusEscapeList"] }, { kind: "component", type: i7.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "noData", "action", "interactive", "growing", "counter", "unread", "byline", "ariaRole", "id"], outputs: ["keyDown"] }, { kind: "directive", type: i7.ListTitleDirective, selector: "[fd-list-title], [fdListTitle]", inputs: ["wrap"] }, { kind: "component", type: i8.DialogComponent, selector: "fd-dialog", inputs: ["class", "dialogRef", "dialogConfig"] }, { kind: "component", type: i8.DialogBodyComponent, selector: "fd-dialog-body", inputs: ["disablePaddings"] }, { kind: "component", type: i8.DialogFooterComponent, selector: "fd-dialog-footer" }, { kind: "component", type: i8.DialogHeaderComponent, selector: "fd-dialog-header" }, { kind: "directive", type: i9.TemplateDirective, selector: "[fdkTemplate]", inputs: ["fdkTemplate"] }, { kind: "component", type: i10.TitleComponent, selector: "[fd-title], [fdTitle]", inputs: ["headerSize", "wrap"], exportAs: ["fd-title"] }, { kind: "directive", type: i9.InitialFocusDirective, selector: "[fdkInitialFocus]", inputs: ["fdkInitialFocus", "enabled", "focusLastElement"] }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
97
|
+
}
|
|
98
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PinTileComponent, decorators: [{
|
|
99
|
+
type: Component,
|
|
100
|
+
args: [{ selector: 'bt-pin-tile', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<fd-dialog>\r\n <fd-dialog-header>\r\n <h1 fd-title>{{ 'AddToList' | bbbTranslate }}</h1>\r\n </fd-dialog-header>\r\n <fd-dialog-body>\r\n <ul fd-list [navigationIndicator]=\"true\" style=\"margin-bottom: 1rem\">\r\n <li fd-list-item [navigationIndicator]=\"true\" (click)=\"onNewGroup()\">\r\n <fd-icon glyph=\"add\"></fd-icon><span fd-list-title>{{ newGroupText }}</span>\r\n </li>\r\n @for (appTileGroup of appTileGroups; track appTileGroup) { @if (!appTileGroup.$Disabledpin) {\r\n <li fd-list-item [selected]=\"appTileGroup.$PinTile\">\r\n <fd-checkbox [(ngModel)]=\"appTileGroup.$PinTile\"></fd-checkbox>\r\n <span fd-list-title>{{ appTileGroup.navigatorTitle || appTileGroup.Title }}</span>\r\n </li>\r\n } @for (subGroup of appTileGroup.$Children; track subGroup) { @if (!subGroup.$Disabledpin) {\r\n <li fd-list-item [selected]=\"subGroup.$PinTile\">\r\n <fd-checkbox [(ngModel)]=\"subGroup.$PinTile\"></fd-checkbox>\r\n <span fd-list-title>{{ subGroup.navigatorTitle || subGroup.Title }}</span>\r\n </li>\r\n } } }\r\n </ul>\r\n </fd-dialog-body>\r\n\r\n <fd-dialog-footer>\r\n <ng-template fdkTemplate=\"footer\">\r\n <div fd-bar-left></div>\r\n <div fd-bar-right>\r\n <fd-button-bar fdkInitialFocus fdType=\"emphasized\" [label]=\"'OK' | bbbTranslate\" (click)=\"onAccept()\">\r\n </fd-button-bar>\r\n <fd-button-bar\r\n fdkInitialFocus\r\n fdType=\"transparent\"\r\n [label]=\"'Cancel' | bbbTranslate\"\r\n (click)=\"onClose()\"\r\n >\r\n </fd-button-bar>\r\n </div>\r\n </ng-template>\r\n </fd-dialog-footer>\r\n</fd-dialog>\r\n", styles: [":host ::ng-deep .cdk-drag{cursor:default!important}:host *{cursor:default!important}li{cursor:pointer}fd-dialog-body,fd-dialog-footer,fd-dialog-header{cursor:default}fd-icon{padding:0 5px}\n"] }]
|
|
101
|
+
}], ctorParameters: () => [{ type: i1.DialogService }, { type: i1.DialogRef }, { type: i2.BbbTranslatePipe }], propDecorators: { app: [{
|
|
102
|
+
type: Input
|
|
103
|
+
}], appTileGroups: [{
|
|
104
|
+
type: Input
|
|
105
|
+
}], mobile: [{
|
|
106
|
+
type: Input
|
|
107
|
+
}], pin: [{
|
|
108
|
+
type: Input
|
|
109
|
+
}] } });
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pin-tile.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-tiles/src/lib/pin-tile/pin-tile.component.ts","../../../../../projects/barsa-tiles/src/lib/pin-tile/pin-tile.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Input, OnInit } from '@angular/core';\r\nimport { DialogRef, DialogService } from '@fundamental-ngx/core';\r\n\r\nimport { BaseComponent, BarsaApi, MetaobjectDataModel, BbbTranslatePipe } from 'barsa-novin-ray-core';\r\n\r\nimport { CreateAppGroupComponent } from '../create-app-group/create-app-group.component';\r\nimport { AppTileGroupPin } from '../models';\r\n\r\n@Component({\r\n    selector: 'bt-pin-tile',\r\n    templateUrl: './pin-tile.component.html',\r\n    styleUrls: ['./pin-tile.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: false\r\n})\r\nexport class PinTileComponent extends BaseComponent implements OnInit {\r\n    @Input() app: MetaobjectDataModel;\r\n    @Input() appTileGroups: MetaobjectDataModel[];\r\n\r\n    @Input() mobile: boolean;\r\n    @Input() pin: boolean;\r\n    newGroupDialogRef: DialogRef;\r\n    newGroupText = BarsaApi.LoginFormData.IsRtl\r\n        ? this.bbbPipe.transform('Groups') + ' ' + this.bbbPipe.transform('New')\r\n        : this.bbbPipe.transform('New') + ' ' + this.bbbPipe.transform('Groups');\r\n    pinnedAppInTileGroups: {\r\n        [key: string]: string[];\r\n    };\r\n    constructor(public _dialogService: DialogService, public _dialogRef: DialogRef, private bbbPipe: BbbTranslatePipe) {\r\n        super();\r\n        this.app = _dialogRef.data.app;\r\n        this.appTileGroups = _dialogRef.data.appTileGroups;\r\n        this.pinnedAppInTileGroups = _dialogRef.data.pinnedAppInTileGroups;\r\n    }\r\n    ngOnInit(): void {\r\n        this._setLoading(true);\r\n        const tileGroupsId = this.pinnedAppInTileGroups[this.app.Id];\r\n        this.appTileGroups.forEach((appGroup) => {\r\n            this._setDefaultPinTile(appGroup, tileGroupsId);\r\n        });\r\n        this._setLoading(false);\r\n    }\r\n    onAccept(): void {\r\n        const appTileGroupsPin: AppTileGroupPin[] = [];\r\n        this.appTileGroups.forEach((group) => {\r\n            this._getChangedPinTileGroups(group, appTileGroupsPin);\r\n        });\r\n        this._close({ appTileGroupsPin, app: this.app });\r\n    }\r\n\r\n    onClose(): void {\r\n        this._close();\r\n    }\r\n\r\n    onNewGroup(): void {\r\n        this.newGroupDialogRef = this._dialogService.open(CreateAppGroupComponent, {\r\n            data: { title: this.newGroupText },\r\n            verticalPadding: true,\r\n            mobile: this.mobile,\r\n            responsivePadding: true\r\n        });\r\n\r\n        this.newGroupDialogRef.afterClosed.subscribe(() => {\r\n            // if (result) {\r\n            //   this.dialogRef.loading(true);\r\n            //   this.tilesService\r\n            //     .createAppGroup(result)\r\n            //     .pipe(\r\n            //       takeUntil(this._onDestroy$),\r\n            //       finalize(() => {\r\n            //         this.dialogRef.loading(false);\r\n            //       })\r\n            //     )\r\n            //     .subscribe();\r\n            // }\r\n        });\r\n    }\r\n    _setLoading(loading): void {\r\n        this._dialogRef.loading(loading);\r\n    }\r\n    _setDefaultPinTile(appTileGroup: MetaobjectDataModel, tileGroupsId: string[]): void {\r\n        appTileGroup.$PinTile = appTileGroup.$DefaultPinTile =\r\n            tileGroupsId.includes(appTileGroup.Id) || tileGroupsId.includes(appTileGroup.UserAppTileGroupSetting?.Id);\r\n        appTileGroup.$Children?.forEach((subGroup) => {\r\n            this._setDefaultPinTile(subGroup, tileGroupsId);\r\n        });\r\n        appTileGroup.$Disabledpin = false;\r\n    }\r\n    _getChangedPinTileGroups(appTileGroup: MetaobjectDataModel, appTileGroupsPin: AppTileGroupPin[]): void {\r\n        if (appTileGroup.$PinTile && !appTileGroup.$DefaultPinTile) {\r\n            // Add\r\n            appTileGroupsPin.push({ appTileGroup, visible: true });\r\n        } else if (appTileGroup.$PinTile === false && appTileGroup.$DefaultPinTile) {\r\n            // Remove\r\n            appTileGroupsPin.push({ appTileGroup, visible: false });\r\n        }\r\n        appTileGroup.$Children?.forEach((subGroup) => {\r\n            this._getChangedPinTileGroups(subGroup, appTileGroupsPin);\r\n        });\r\n    }\r\n    _close(result?): void {\r\n        this._dialogRef.close(result);\r\n    }\r\n}\r\n","<fd-dialog>\r\n    <fd-dialog-header>\r\n        <h1 fd-title>{{ 'AddToList' | bbbTranslate }}</h1>\r\n    </fd-dialog-header>\r\n    <fd-dialog-body>\r\n        <ul fd-list [navigationIndicator]=\"true\" style=\"margin-bottom: 1rem\">\r\n            <li fd-list-item [navigationIndicator]=\"true\" (click)=\"onNewGroup()\">\r\n                <fd-icon glyph=\"add\"></fd-icon><span fd-list-title>{{ newGroupText }}</span>\r\n            </li>\r\n            @for (appTileGroup of appTileGroups; track appTileGroup) { @if (!appTileGroup.$Disabledpin) {\r\n            <li fd-list-item [selected]=\"appTileGroup.$PinTile\">\r\n                <fd-checkbox [(ngModel)]=\"appTileGroup.$PinTile\"></fd-checkbox>\r\n                <span fd-list-title>{{ appTileGroup.navigatorTitle || appTileGroup.Title }}</span>\r\n            </li>\r\n            } @for (subGroup of appTileGroup.$Children; track subGroup) { @if (!subGroup.$Disabledpin) {\r\n            <li fd-list-item [selected]=\"subGroup.$PinTile\">\r\n                <fd-checkbox [(ngModel)]=\"subGroup.$PinTile\"></fd-checkbox>\r\n                <span fd-list-title>{{ subGroup.navigatorTitle || subGroup.Title }}</span>\r\n            </li>\r\n            } } }\r\n        </ul>\r\n    </fd-dialog-body>\r\n\r\n    <fd-dialog-footer>\r\n        <ng-template fdkTemplate=\"footer\">\r\n            <div fd-bar-left></div>\r\n            <div fd-bar-right>\r\n                <fd-button-bar fdkInitialFocus fdType=\"emphasized\" [label]=\"'OK' | bbbTranslate\" (click)=\"onAccept()\">\r\n                </fd-button-bar>\r\n                <fd-button-bar\r\n                    fdkInitialFocus\r\n                    fdType=\"transparent\"\r\n                    [label]=\"'Cancel' | bbbTranslate\"\r\n                    (click)=\"onClose()\"\r\n                >\r\n                </fd-button-bar>\r\n            </div>\r\n        </ng-template>\r\n    </fd-dialog-footer>\r\n</fd-dialog>\r\n"]}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import { forkJoin, of } from 'rxjs';
|
|
3
|
+
import { map, shareReplay } from 'rxjs/operators';
|
|
4
|
+
import { BarsaApi } from 'barsa-novin-ray-core';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class GroupTilesPipe {
|
|
7
|
+
transform(appGroup) {
|
|
8
|
+
const predefineTiles = appGroup.AppTiles;
|
|
9
|
+
if (predefineTiles?.length === 0) {
|
|
10
|
+
return of([]);
|
|
11
|
+
}
|
|
12
|
+
const predefine$ = of(predefineTiles);
|
|
13
|
+
const userDefine$ = of(appGroup.UserAppTileGroupSetting?.UserAppTilesSetting?.MoDataList);
|
|
14
|
+
return forkJoin([predefine$, userDefine$]).pipe(map(([s1, s2]) => [...s1, ...s2]), map((arrTiles) => {
|
|
15
|
+
const tempTiles = arrTiles.filter((c) => c.Visible).sort((a, b) => (a.OrderItem > b.OrderItem ? 1 : 0));
|
|
16
|
+
const group = { ...appGroup };
|
|
17
|
+
group.Title = BarsaApi.Common.Util.TryGetValue(group, 'UserAppTileGroupSetting.Title', group.Title);
|
|
18
|
+
group.OrderItem = BarsaApi.Common.Util.TryGetValue(group, 'UserAppTileGroupSetting.OrderItem', group.OrderItem);
|
|
19
|
+
return tempTiles;
|
|
20
|
+
}), shareReplay(1));
|
|
21
|
+
}
|
|
22
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: GroupTilesPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
23
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: GroupTilesPipe, name: "groupTiles" }); }
|
|
24
|
+
}
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: GroupTilesPipe, decorators: [{
|
|
26
|
+
type: Pipe,
|
|
27
|
+
args: [{
|
|
28
|
+
name: 'groupTiles',
|
|
29
|
+
standalone: false
|
|
30
|
+
}]
|
|
31
|
+
}] });
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JvdXAtdGlsZXMucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLXRpbGVzL3NyYy9saWIvcGlwZXMvZ3JvdXAtdGlsZXMucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUNwRCxPQUFPLEVBQUUsUUFBUSxFQUFjLEVBQUUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNoRCxPQUFPLEVBQUUsR0FBRyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRWxELE9BQU8sRUFBRSxRQUFRLEVBQXVCLE1BQU0sc0JBQXNCLENBQUM7O0FBVXJFLE1BQU0sT0FBTyxjQUFjO0lBQ3ZCLFNBQVMsQ0FBQyxRQUE2QjtRQUNuQyxNQUFNLGNBQWMsR0FBRyxRQUFRLENBQUMsUUFBUSxDQUFDO1FBQ3pDLElBQUksY0FBYyxFQUFFLE1BQU0sS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUMvQixPQUFPLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUNsQixDQUFDO1FBQ0QsTUFBTSxVQUFVLEdBQUcsRUFBRSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQ3RDLE1BQU0sV0FBVyxHQUFHLEVBQUUsQ0FBQyxRQUFRLENBQUMsdUJBQXVCLEVBQUUsbUJBQW1CLEVBQUUsVUFBVSxDQUFDLENBQUM7UUFFMUYsT0FBTyxRQUFRLENBQUMsQ0FBQyxVQUFVLEVBQUUsV0FBVyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQzNDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsRUFDakMsR0FBRyxDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUU7WUFDYixNQUFNLFNBQVMsR0FBRyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxHQUFHLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUN4RyxNQUFNLEtBQUssR0FBRyxFQUFFLEdBQUcsUUFBUSxFQUFFLENBQUM7WUFDOUIsS0FBSyxDQUFDLEtBQUssR0FBRyxRQUFRLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxFQUFFLCtCQUErQixFQUFFLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUNwRyxLQUFLLENBQUMsU0FBUyxHQUFHLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FDOUMsS0FBSyxFQUNMLG1DQUFtQyxFQUNuQyxLQUFLLENBQUMsU0FBUyxDQUNsQixDQUFDO1lBRUYsT0FBTyxTQUFTLENBQUM7UUFDckIsQ0FBQyxDQUFDLEVBQ0YsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUNqQixDQUFDO0lBQ04sQ0FBQzsrR0F6QlEsY0FBYzs2R0FBZCxjQUFjOzs0RkFBZCxjQUFjO2tCQUoxQixJQUFJO21CQUFDO29CQUNGLElBQUksRUFBRSxZQUFZO29CQUNsQixVQUFVLEVBQUUsS0FBSztpQkFDcEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IGZvcmtKb2luLCBPYnNlcnZhYmxlLCBvZiB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBtYXAsIHNoYXJlUmVwbGF5IH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xyXG5cclxuaW1wb3J0IHsgQmFyc2FBcGksIE1ldGFvYmplY3REYXRhTW9kZWwgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcblxyXG5pbnRlcmZhY2UgQXBwVGlsZU1vZGVsIGV4dGVuZHMgTWV0YW9iamVjdERhdGFNb2RlbCB7XHJcbiAgICBDb21wb25lbnQ6IE1ldGFvYmplY3REYXRhTW9kZWw7XHJcbiAgICBTZWxlY3Rvcjogc3RyaW5nO1xyXG59XHJcbkBQaXBlKHtcclxuICAgIG5hbWU6ICdncm91cFRpbGVzJyxcclxuICAgIHN0YW5kYWxvbmU6IGZhbHNlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBHcm91cFRpbGVzUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xyXG4gICAgdHJhbnNmb3JtKGFwcEdyb3VwOiBNZXRhb2JqZWN0RGF0YU1vZGVsKTogT2JzZXJ2YWJsZTxBcHBUaWxlTW9kZWxbXT4ge1xyXG4gICAgICAgIGNvbnN0IHByZWRlZmluZVRpbGVzID0gYXBwR3JvdXAuQXBwVGlsZXM7XHJcbiAgICAgICAgaWYgKHByZWRlZmluZVRpbGVzPy5sZW5ndGggPT09IDApIHtcclxuICAgICAgICAgICAgcmV0dXJuIG9mKFtdKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgY29uc3QgcHJlZGVmaW5lJCA9IG9mKHByZWRlZmluZVRpbGVzKTtcclxuICAgICAgICBjb25zdCB1c2VyRGVmaW5lJCA9IG9mKGFwcEdyb3VwLlVzZXJBcHBUaWxlR3JvdXBTZXR0aW5nPy5Vc2VyQXBwVGlsZXNTZXR0aW5nPy5Nb0RhdGFMaXN0KTtcclxuXHJcbiAgICAgICAgcmV0dXJuIGZvcmtKb2luKFtwcmVkZWZpbmUkLCB1c2VyRGVmaW5lJF0pLnBpcGUoXHJcbiAgICAgICAgICAgIG1hcCgoW3MxLCBzMl0pID0+IFsuLi5zMSwgLi4uczJdKSxcclxuICAgICAgICAgICAgbWFwKChhcnJUaWxlcykgPT4ge1xyXG4gICAgICAgICAgICAgICAgY29uc3QgdGVtcFRpbGVzID0gYXJyVGlsZXMuZmlsdGVyKChjKSA9PiBjLlZpc2libGUpLnNvcnQoKGEsIGIpID0+IChhLk9yZGVySXRlbSA+IGIuT3JkZXJJdGVtID8gMSA6IDApKTtcclxuICAgICAgICAgICAgICAgIGNvbnN0IGdyb3VwID0geyAuLi5hcHBHcm91cCB9O1xyXG4gICAgICAgICAgICAgICAgZ3JvdXAuVGl0bGUgPSBCYXJzYUFwaS5Db21tb24uVXRpbC5UcnlHZXRWYWx1ZShncm91cCwgJ1VzZXJBcHBUaWxlR3JvdXBTZXR0aW5nLlRpdGxlJywgZ3JvdXAuVGl0bGUpO1xyXG4gICAgICAgICAgICAgICAgZ3JvdXAuT3JkZXJJdGVtID0gQmFyc2FBcGkuQ29tbW9uLlV0aWwuVHJ5R2V0VmFsdWUoXHJcbiAgICAgICAgICAgICAgICAgICAgZ3JvdXAsXHJcbiAgICAgICAgICAgICAgICAgICAgJ1VzZXJBcHBUaWxlR3JvdXBTZXR0aW5nLk9yZGVySXRlbScsXHJcbiAgICAgICAgICAgICAgICAgICAgZ3JvdXAuT3JkZXJJdGVtXHJcbiAgICAgICAgICAgICAgICApO1xyXG5cclxuICAgICAgICAgICAgICAgIHJldHVybiB0ZW1wVGlsZXM7XHJcbiAgICAgICAgICAgIH0pLFxyXG4gICAgICAgICAgICBzaGFyZVJlcGxheSgxKVxyXG4gICAgICAgICk7XHJcbiAgICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class HomeGroupPipe {
|
|
4
|
+
constructor() { }
|
|
5
|
+
transform(appGroups) {
|
|
6
|
+
return appGroups.filter((c) => c.navigatorTiles && c.navigatorTiles.length > 0);
|
|
7
|
+
}
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: HomeGroupPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
9
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: HomeGroupPipe, name: "homeGroup" }); }
|
|
10
|
+
}
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: HomeGroupPipe, decorators: [{
|
|
12
|
+
type: Pipe,
|
|
13
|
+
args: [{
|
|
14
|
+
name: 'homeGroup',
|
|
15
|
+
standalone: false
|
|
16
|
+
}]
|
|
17
|
+
}], ctorParameters: () => [] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaG9tZS1ncm91cC5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtdGlsZXMvc3JjL2xpYi9waXBlcy9ob21lLWdyb3VwLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBT3BELE1BQU0sT0FBTyxhQUFhO0lBQ3RCLGdCQUFlLENBQUM7SUFDaEIsU0FBUyxDQUFDLFNBQWdDO1FBQ3RDLE9BQU8sU0FBUyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLGNBQWMsSUFBSSxDQUFDLENBQUMsY0FBYyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQztJQUNwRixDQUFDOytHQUpRLGFBQWE7NkdBQWIsYUFBYTs7NEZBQWIsYUFBYTtrQkFKekIsSUFBSTttQkFBQztvQkFDRixJQUFJLEVBQUUsV0FBVztvQkFDakIsVUFBVSxFQUFFLEtBQUs7aUJBQ3BCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBNZXRhb2JqZWN0RGF0YU1vZGVsIH0gZnJvbSAnYmFyc2Etbm92aW4tcmF5LWNvcmUnO1xyXG5cclxuQFBpcGUoe1xyXG4gICAgbmFtZTogJ2hvbWVHcm91cCcsXHJcbiAgICBzdGFuZGFsb25lOiBmYWxzZVxyXG59KVxyXG5leHBvcnQgY2xhc3MgSG9tZUdyb3VwUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xyXG4gICAgY29uc3RydWN0b3IoKSB7fVxyXG4gICAgdHJhbnNmb3JtKGFwcEdyb3VwczogTWV0YW9iamVjdERhdGFNb2RlbFtdKTogTWV0YW9iamVjdERhdGFNb2RlbFtdIHtcclxuICAgICAgICByZXR1cm4gYXBwR3JvdXBzLmZpbHRlcigoYykgPT4gYy5uYXZpZ2F0b3JUaWxlcyAmJiBjLm5hdmlnYXRvclRpbGVzLmxlbmd0aCA+IDApO1xyXG4gICAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import { BarsaApi } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class TileHomeFilterPipe {
|
|
5
|
+
transform(collection) {
|
|
6
|
+
return collection.filter((val) => this.matchFilter(val));
|
|
7
|
+
}
|
|
8
|
+
matchFilter(value) {
|
|
9
|
+
const match = Object.keys(value.Data).some((key) => {
|
|
10
|
+
if (key.startsWith('$')) {
|
|
11
|
+
return false;
|
|
12
|
+
}
|
|
13
|
+
if (key.startsWith('c')) {
|
|
14
|
+
return BarsaApi.Common.Util.TryGetValue(value, 'Data.' + key);
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
return match;
|
|
18
|
+
}
|
|
19
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TileHomeFilterPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
20
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: TileHomeFilterPipe, name: "tileHomeFilter" }); }
|
|
21
|
+
}
|
|
22
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TileHomeFilterPipe, decorators: [{
|
|
23
|
+
type: Pipe,
|
|
24
|
+
args: [{
|
|
25
|
+
name: 'tileHomeFilter',
|
|
26
|
+
standalone: false
|
|
27
|
+
}]
|
|
28
|
+
}] });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlsZS1ob21lLWZpbHRlci5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtdGlsZXMvc3JjL2xpYi9waXBlcy90aWxlLWhvbWUtZmlsdGVyLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7QUFFcEQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLHNCQUFzQixDQUFDOztBQU1oRCxNQUFNLE9BQU8sa0JBQWtCO0lBQzNCLFNBQVMsQ0FBQyxVQUFpQjtRQUN2QixPQUFPLFVBQVUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztJQUM3RCxDQUFDO0lBQ0QsV0FBVyxDQUFDLEtBQUs7UUFDYixNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTtZQUMvQyxJQUFJLEdBQUcsQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztnQkFDdEIsT0FBTyxLQUFLLENBQUM7WUFDakIsQ0FBQztZQUNELElBQUksR0FBRyxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDO2dCQUN0QixPQUFPLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLEVBQUUsT0FBTyxHQUFHLEdBQUcsQ0FBQyxDQUFDO1lBQ2xFLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztRQUNILE9BQU8sS0FBSyxDQUFDO0lBQ2pCLENBQUM7K0dBZFEsa0JBQWtCOzZHQUFsQixrQkFBa0I7OzRGQUFsQixrQkFBa0I7a0JBSjlCLElBQUk7bUJBQUM7b0JBQ0YsSUFBSSxFQUFFLGdCQUFnQjtvQkFDdEIsVUFBVSxFQUFFLEtBQUs7aUJBQ3BCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHsgQmFyc2FBcGkgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcblxyXG5AUGlwZSh7XHJcbiAgICBuYW1lOiAndGlsZUhvbWVGaWx0ZXInLFxyXG4gICAgc3RhbmRhbG9uZTogZmFsc2VcclxufSlcclxuZXhwb3J0IGNsYXNzIFRpbGVIb21lRmlsdGVyUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xyXG4gICAgdHJhbnNmb3JtKGNvbGxlY3Rpb246IGFueVtdKTogYW55W10ge1xyXG4gICAgICAgIHJldHVybiBjb2xsZWN0aW9uLmZpbHRlcigodmFsKSA9PiB0aGlzLm1hdGNoRmlsdGVyKHZhbCkpO1xyXG4gICAgfVxyXG4gICAgbWF0Y2hGaWx0ZXIodmFsdWUpOiBib29sZWFuIHtcclxuICAgICAgICBjb25zdCBtYXRjaCA9IE9iamVjdC5rZXlzKHZhbHVlLkRhdGEpLnNvbWUoKGtleSkgPT4ge1xyXG4gICAgICAgICAgICBpZiAoa2V5LnN0YXJ0c1dpdGgoJyQnKSkge1xyXG4gICAgICAgICAgICAgICAgcmV0dXJuIGZhbHNlO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIGlmIChrZXkuc3RhcnRzV2l0aCgnYycpKSB7XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gQmFyc2FBcGkuQ29tbW9uLlV0aWwuVHJ5R2V0VmFsdWUodmFsdWUsICdEYXRhLicgKyBrZXkpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfSk7XHJcbiAgICAgICAgcmV0dXJuIG1hdGNoO1xyXG4gICAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import { BarsaApi } from 'barsa-novin-ray-core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class TilePropPipe {
|
|
5
|
+
transform(data, prop, parameters) {
|
|
6
|
+
if (data) {
|
|
7
|
+
if (prop === 'Title') {
|
|
8
|
+
let val = data.TileTitle;
|
|
9
|
+
if (!val) {
|
|
10
|
+
val = BarsaApi.Common.Util.TryGetValue(data, 'Component.Settings.TileSetting.Title', '');
|
|
11
|
+
}
|
|
12
|
+
if (!val) {
|
|
13
|
+
val = BarsaApi.Common.Util.TryGetValue(data, 'Title', '');
|
|
14
|
+
}
|
|
15
|
+
return val;
|
|
16
|
+
}
|
|
17
|
+
if (prop === 'Subtitle') {
|
|
18
|
+
let val = data.Subtitle;
|
|
19
|
+
if (!val) {
|
|
20
|
+
val = BarsaApi.Common.Util.TryGetValue(data, 'Component.Settings.TileSetting.Subtitle', '');
|
|
21
|
+
}
|
|
22
|
+
if (!val) {
|
|
23
|
+
val = BarsaApi.Common.Util.TryGetValue(data, 'Subtitle', '');
|
|
24
|
+
}
|
|
25
|
+
return val;
|
|
26
|
+
}
|
|
27
|
+
if (prop === 'DynamicCommand') {
|
|
28
|
+
return data['DynamicCommand'];
|
|
29
|
+
}
|
|
30
|
+
if (data.Component && data.Component.Settings) {
|
|
31
|
+
const val = data.Component.Settings.TileSetting[prop];
|
|
32
|
+
if (typeof val === 'undefined') {
|
|
33
|
+
return data.Component.Settings[prop];
|
|
34
|
+
}
|
|
35
|
+
return val;
|
|
36
|
+
}
|
|
37
|
+
return '';
|
|
38
|
+
}
|
|
39
|
+
return parameters ? parameters.TileSetting[prop] : '';
|
|
40
|
+
}
|
|
41
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TilePropPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
42
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: TilePropPipe, name: "tileProp" }); }
|
|
43
|
+
}
|
|
44
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TilePropPipe, decorators: [{
|
|
45
|
+
type: Pipe,
|
|
46
|
+
args: [{
|
|
47
|
+
name: 'tileProp',
|
|
48
|
+
standalone: false
|
|
49
|
+
}]
|
|
50
|
+
}] });
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGlsZS1wcm9wLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS10aWxlcy9zcmMvbGliL3BpcGVzL3RpbGUtcHJvcC5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBQ3BELE9BQU8sRUFBdUIsUUFBUSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7O0FBTXJFLE1BQU0sT0FBTyxZQUFZO0lBQ3JCLFNBQVMsQ0FBQyxJQUFTLEVBQUUsSUFBWSxFQUFFLFVBQWdDO1FBQy9ELElBQUksSUFBSSxFQUFFLENBQUM7WUFDUCxJQUFJLElBQUksS0FBSyxPQUFPLEVBQUUsQ0FBQztnQkFDbkIsSUFBSSxHQUFHLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQztnQkFDekIsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDO29CQUNQLEdBQUcsR0FBRyxRQUFRLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxFQUFFLHNDQUFzQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO2dCQUM3RixDQUFDO2dCQUNELElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztvQkFDUCxHQUFHLEdBQUcsUUFBUSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksRUFBRSxPQUFPLEVBQUUsRUFBRSxDQUFDLENBQUM7Z0JBQzlELENBQUM7Z0JBQ0QsT0FBTyxHQUFHLENBQUM7WUFDZixDQUFDO1lBQ0QsSUFBSSxJQUFJLEtBQUssVUFBVSxFQUFFLENBQUM7Z0JBQ3RCLElBQUksR0FBRyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUM7Z0JBQ3hCLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztvQkFDUCxHQUFHLEdBQUcsUUFBUSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksRUFBRSx5Q0FBeUMsRUFBRSxFQUFFLENBQUMsQ0FBQztnQkFDaEcsQ0FBQztnQkFDRCxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUM7b0JBQ1AsR0FBRyxHQUFHLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsVUFBVSxFQUFFLEVBQUUsQ0FBQyxDQUFDO2dCQUNqRSxDQUFDO2dCQUNELE9BQU8sR0FBRyxDQUFDO1lBQ2YsQ0FBQztZQUNELElBQUksSUFBSSxLQUFLLGdCQUFnQixFQUFFLENBQUM7Z0JBQzVCLE9BQU8sSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7WUFDbEMsQ0FBQztZQUNELElBQUksSUFBSSxDQUFDLFNBQVMsSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsRUFBRSxDQUFDO2dCQUM1QyxNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQ3RELElBQUksT0FBTyxHQUFHLEtBQUssV0FBVyxFQUFFLENBQUM7b0JBQzdCLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQ3pDLENBQUM7Z0JBQ0QsT0FBTyxHQUFHLENBQUM7WUFDZixDQUFDO1lBQ0QsT0FBTyxFQUFFLENBQUM7UUFDZCxDQUFDO1FBQ0QsT0FBTyxVQUFVLENBQUMsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztJQUMxRCxDQUFDOytHQXBDUSxZQUFZOzZHQUFaLFlBQVk7OzRGQUFaLFlBQVk7a0JBSnhCLElBQUk7bUJBQUM7b0JBQ0YsSUFBSSxFQUFFLFVBQVU7b0JBQ2hCLFVBQVUsRUFBRSxLQUFLO2lCQUNwQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTWV0YW9iamVjdERhdGFNb2RlbCwgQmFyc2FBcGkgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcblxyXG5AUGlwZSh7XHJcbiAgICBuYW1lOiAndGlsZVByb3AnLFxyXG4gICAgc3RhbmRhbG9uZTogZmFsc2VcclxufSlcclxuZXhwb3J0IGNsYXNzIFRpbGVQcm9wUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xyXG4gICAgdHJhbnNmb3JtKGRhdGE6IGFueSwgcHJvcDogc3RyaW5nLCBwYXJhbWV0ZXJzPzogTWV0YW9iamVjdERhdGFNb2RlbCk6IHN0cmluZyB8IGFueSB7XHJcbiAgICAgICAgaWYgKGRhdGEpIHtcclxuICAgICAgICAgICAgaWYgKHByb3AgPT09ICdUaXRsZScpIHtcclxuICAgICAgICAgICAgICAgIGxldCB2YWwgPSBkYXRhLlRpbGVUaXRsZTtcclxuICAgICAgICAgICAgICAgIGlmICghdmFsKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgdmFsID0gQmFyc2FBcGkuQ29tbW9uLlV0aWwuVHJ5R2V0VmFsdWUoZGF0YSwgJ0NvbXBvbmVudC5TZXR0aW5ncy5UaWxlU2V0dGluZy5UaXRsZScsICcnKTtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgIGlmICghdmFsKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgdmFsID0gQmFyc2FBcGkuQ29tbW9uLlV0aWwuVHJ5R2V0VmFsdWUoZGF0YSwgJ1RpdGxlJywgJycpO1xyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgcmV0dXJuIHZhbDtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICBpZiAocHJvcCA9PT0gJ1N1YnRpdGxlJykge1xyXG4gICAgICAgICAgICAgICAgbGV0IHZhbCA9IGRhdGEuU3VidGl0bGU7XHJcbiAgICAgICAgICAgICAgICBpZiAoIXZhbCkge1xyXG4gICAgICAgICAgICAgICAgICAgIHZhbCA9IEJhcnNhQXBpLkNvbW1vbi5VdGlsLlRyeUdldFZhbHVlKGRhdGEsICdDb21wb25lbnQuU2V0dGluZ3MuVGlsZVNldHRpbmcuU3VidGl0bGUnLCAnJyk7XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICBpZiAoIXZhbCkge1xyXG4gICAgICAgICAgICAgICAgICAgIHZhbCA9IEJhcnNhQXBpLkNvbW1vbi5VdGlsLlRyeUdldFZhbHVlKGRhdGEsICdTdWJ0aXRsZScsICcnKTtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgIHJldHVybiB2YWw7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgaWYgKHByb3AgPT09ICdEeW5hbWljQ29tbWFuZCcpIHtcclxuICAgICAgICAgICAgICAgIHJldHVybiBkYXRhWydEeW5hbWljQ29tbWFuZCddO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIGlmIChkYXRhLkNvbXBvbmVudCAmJiBkYXRhLkNvbXBvbmVudC5TZXR0aW5ncykge1xyXG4gICAgICAgICAgICAgICAgY29uc3QgdmFsID0gZGF0YS5Db21wb25lbnQuU2V0dGluZ3MuVGlsZVNldHRpbmdbcHJvcF07XHJcbiAgICAgICAgICAgICAgICBpZiAodHlwZW9mIHZhbCA9PT0gJ3VuZGVmaW5lZCcpIHtcclxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gZGF0YS5Db21wb25lbnQuU2V0dGluZ3NbcHJvcF07XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gdmFsO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIHJldHVybiAnJztcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHBhcmFtZXRlcnMgPyBwYXJhbWV0ZXJzLlRpbGVTZXR0aW5nW3Byb3BdIDogJyc7XHJcbiAgICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class FilterAppsGroupedPipe {
|
|
4
|
+
transform(value, term) {
|
|
5
|
+
return value?.filter((cat) => !!cat.Apps.filter((app) => app.$Caption.includes(term ?? ''))?.length);
|
|
6
|
+
}
|
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterAppsGroupedPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
8
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: FilterAppsGroupedPipe, isStandalone: true, name: "filterAppsGrouped", pure: false }); }
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterAppsGroupedPipe, decorators: [{
|
|
11
|
+
type: Pipe,
|
|
12
|
+
args: [{
|
|
13
|
+
name: 'filterAppsGrouped',
|
|
14
|
+
standalone: true,
|
|
15
|
+
pure: false
|
|
16
|
+
}]
|
|
17
|
+
}] });
|
|
18
|
+
export class FilterAppsPipe {
|
|
19
|
+
transform(value, term) {
|
|
20
|
+
if (!Array.isArray(value) || !term) {
|
|
21
|
+
return value;
|
|
22
|
+
}
|
|
23
|
+
return value?.filter((app) => app.$Caption.includes(term));
|
|
24
|
+
}
|
|
25
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterAppsPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
26
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: FilterAppsPipe, isStandalone: true, name: "filterApps", pure: false }); }
|
|
27
|
+
}
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FilterAppsPipe, decorators: [{
|
|
29
|
+
type: Pipe,
|
|
30
|
+
args: [{
|
|
31
|
+
name: 'filterApps',
|
|
32
|
+
standalone: true,
|
|
33
|
+
pure: false
|
|
34
|
+
}]
|
|
35
|
+
}] });
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWFwcHMtZ3JvdXBlZC5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2EtdGlsZXMvc3JjL2xpYi9wb3BvdmVyLWFwcC1maW5kZXIvZmlsdGVyLWFwcHMtZ3JvdXBlZC5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDOztBQVFwRCxNQUFNLE9BQU8scUJBQXFCO0lBQzlCLFNBQVMsQ0FBQyxLQUErQyxFQUFFLElBQVk7UUFDbkUsT0FBTyxLQUFLLEVBQUUsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLElBQUksSUFBSSxFQUFFLENBQUMsQ0FBQyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ3pHLENBQUM7K0dBSFEscUJBQXFCOzZHQUFyQixxQkFBcUI7OzRGQUFyQixxQkFBcUI7a0JBTGpDLElBQUk7bUJBQUM7b0JBQ0YsSUFBSSxFQUFFLG1CQUFtQjtvQkFDekIsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLElBQUksRUFBRSxLQUFLO2lCQUNkOztBQVlELE1BQU0sT0FBTyxjQUFjO0lBQ3ZCLFNBQVMsQ0FBQyxLQUErQyxFQUFFLElBQVk7UUFDbkUsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNqQyxPQUFPLEtBQUssQ0FBQztRQUNqQixDQUFDO1FBQ0QsT0FBTyxLQUFLLEVBQUUsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO0lBQy9ELENBQUM7K0dBTlEsY0FBYzs2R0FBZCxjQUFjOzs0RkFBZCxjQUFjO2tCQUwxQixJQUFJO21CQUFDO29CQUNGLElBQUksRUFBRSxZQUFZO29CQUNsQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsSUFBSSxFQUFFLEtBQUs7aUJBQ2QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE1ldGFvYmplY3REYXRhTW9kZWwgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcblxyXG5AUGlwZSh7XHJcbiAgICBuYW1lOiAnZmlsdGVyQXBwc0dyb3VwZWQnLFxyXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICAgIHB1cmU6IGZhbHNlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBGaWx0ZXJBcHBzR3JvdXBlZFBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcclxuICAgIHRyYW5zZm9ybSh2YWx1ZTogTWV0YW9iamVjdERhdGFNb2RlbFtdIHwgdW5kZWZpbmVkIHwgbnVsbCwgdGVybTogc3RyaW5nKTogTWV0YW9iamVjdERhdGFNb2RlbFtdIHwgdW5kZWZpbmVkIHwgbnVsbCB7XHJcbiAgICAgICAgcmV0dXJuIHZhbHVlPy5maWx0ZXIoKGNhdCkgPT4gISFjYXQuQXBwcy5maWx0ZXIoKGFwcCkgPT4gYXBwLiRDYXB0aW9uLmluY2x1ZGVzKHRlcm0gPz8gJycpKT8ubGVuZ3RoKTtcclxuICAgIH1cclxufVxyXG5cclxuQFBpcGUoe1xyXG4gICAgbmFtZTogJ2ZpbHRlckFwcHMnLFxyXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICAgIHB1cmU6IGZhbHNlXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBGaWx0ZXJBcHBzUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xyXG4gICAgdHJhbnNmb3JtKHZhbHVlOiBNZXRhb2JqZWN0RGF0YU1vZGVsW10gfCB1bmRlZmluZWQgfCBudWxsLCB0ZXJtOiBzdHJpbmcpOiBNZXRhb2JqZWN0RGF0YU1vZGVsW10gfCB1bmRlZmluZWQgfCBudWxsIHtcclxuICAgICAgICBpZiAoIUFycmF5LmlzQXJyYXkodmFsdWUpIHx8ICF0ZXJtKSB7XHJcbiAgICAgICAgICAgIHJldHVybiB2YWx1ZTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIHZhbHVlPy5maWx0ZXIoKGFwcCkgPT4gYXBwLiRDYXB0aW9uLmluY2x1ZGVzKHRlcm0pKTtcclxuICAgIH1cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Output } from '@angular/core';
|
|
2
|
+
import { map, takeUntil } from 'rxjs/operators';
|
|
3
|
+
import { BaseComponent } from 'barsa-novin-ray-core';
|
|
4
|
+
import { PinTileComponent } from '../pin-tile/pin-tile.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@fundamental-ngx/core";
|
|
7
|
+
import * as i2 from "../app-finder.service";
|
|
8
|
+
export class PopoverAppFinderComponent extends BaseComponent {
|
|
9
|
+
constructor(_cdr, _dialogService, _appFinderService, _el, _contentDensityService) {
|
|
10
|
+
super();
|
|
11
|
+
this._cdr = _cdr;
|
|
12
|
+
this._dialogService = _dialogService;
|
|
13
|
+
this._appFinderService = _appFinderService;
|
|
14
|
+
this._el = _el;
|
|
15
|
+
this.closeMenu = new EventEmitter();
|
|
16
|
+
this.isAllSelected = true;
|
|
17
|
+
this.contentDensity$ = _contentDensityService.contentDensity.asObservable();
|
|
18
|
+
this.appGroups$ = this._appFinderService.appGroups$.pipe(map((appGroups) => {
|
|
19
|
+
appGroups.forEach((cat) => {
|
|
20
|
+
this._appFinderService.loadAppsByAppGroup(appGroups, cat);
|
|
21
|
+
});
|
|
22
|
+
return appGroups;
|
|
23
|
+
}));
|
|
24
|
+
this.selectedAppGroup$ = this._appFinderService.selectedAppGroup$;
|
|
25
|
+
this.selectedAppGroupId$ = this._appFinderService.selectedAppGroupId$;
|
|
26
|
+
this.deviceSize$ = this._appFinderService.deviceSize$;
|
|
27
|
+
this.pinnedAppInAppTileGroups$ = this._appFinderService.pinnedAppInAppTileGroups$;
|
|
28
|
+
this.mobile$ = this.deviceSize$.pipe(map((c) => c === 's'));
|
|
29
|
+
}
|
|
30
|
+
ngOnInit() {
|
|
31
|
+
super.ngOnInit();
|
|
32
|
+
this.contentHeight = 'calc(' + this._el.nativeElement.offsetHeight + 'px - 2.75rem)';
|
|
33
|
+
this.sideContentSize$ = this.deviceSize$.pipe(takeUntil(this._onDestroy$), map((deviceSize) => {
|
|
34
|
+
switch (deviceSize) {
|
|
35
|
+
case 's':
|
|
36
|
+
return 'sm';
|
|
37
|
+
case 'm':
|
|
38
|
+
return 'md';
|
|
39
|
+
case 'l':
|
|
40
|
+
return 'lg';
|
|
41
|
+
case 'xl':
|
|
42
|
+
return 'xl';
|
|
43
|
+
default:
|
|
44
|
+
return 'l';
|
|
45
|
+
}
|
|
46
|
+
}));
|
|
47
|
+
}
|
|
48
|
+
onSelectedAppGroupChange(appGroupId) {
|
|
49
|
+
this._changeGroup(appGroupId);
|
|
50
|
+
}
|
|
51
|
+
onPinClick(app) {
|
|
52
|
+
const pinnedAppInTileGroups = this._appFinderService.loadPinnedAppInTileGroups(app);
|
|
53
|
+
const appTileGroups = this._appFinderService.appTileGroups;
|
|
54
|
+
const deviceSize = this._appFinderService.deviceSize;
|
|
55
|
+
const mobile = deviceSize === 's';
|
|
56
|
+
this._dialogService
|
|
57
|
+
.open(PinTileComponent, {
|
|
58
|
+
data: { app, pinnedAppInTileGroups, appTileGroups },
|
|
59
|
+
minWidth: '350px',
|
|
60
|
+
minHeight: '420px',
|
|
61
|
+
draggable: false,
|
|
62
|
+
mobile,
|
|
63
|
+
resizable: false,
|
|
64
|
+
verticalPadding: false,
|
|
65
|
+
backdropClickCloseable: false
|
|
66
|
+
})
|
|
67
|
+
.afterClosed.subscribe((result) => {
|
|
68
|
+
this._appTileGroupsPinChange(result);
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
onRefresh() { }
|
|
72
|
+
async _appTileGroupsPinChange(result) {
|
|
73
|
+
try {
|
|
74
|
+
// Will try to ask for permission
|
|
75
|
+
this._appFinderService.pinTileChanged(result.appTileGroupsPin, result.app, () => {
|
|
76
|
+
this._cdr.detectChanges();
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
catch (err) {
|
|
80
|
+
// show msg error
|
|
81
|
+
}
|
|
82
|
+
finally {
|
|
83
|
+
// show toast successful
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
_changeGroup(appGroupId) {
|
|
87
|
+
this.isAllSelected = false;
|
|
88
|
+
this._appFinderService.selectAppGroup(appGroupId);
|
|
89
|
+
this._cdr.detectChanges();
|
|
90
|
+
}
|
|
91
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PopoverAppFinderComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.DialogService }, { token: i2.AppFinderService }, { token: i0.ElementRef }, { token: i1.ContentDensityService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
92
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: PopoverAppFinderComponent, selector: "bt-popover-app-finder", outputs: { closeMenu: "closeMenu" }, host: { classAttribute: "!tw-min-h-min" }, usesInheritance: true, ngImport: i0, template: "<!-- \r\n<div>\r\n <div class=\"!tw-px-4 !tw-pt-2\" fd-form-item>\r\n <fd-input-group\r\n glyph=\"decline\"\r\n glyphAriaLabel=\"Clear\"\r\n placeholder=\"\u062C\u0633\u062A\u062C\u0648\"\r\n [button]=\"true\"\r\n [disabled]=\"false\"\r\n [(ngModel)]=\"searchTerm\"\r\n (addOnButtonClicked)=\"searchTerm = ''\"\r\n >\r\n </fd-input-group>\r\n </div>\r\n @for (cat of appGroups$ | async | filterAppsGrouped:searchTerm; track cat.Id) {\r\n <fd-panel\r\n fdCompact\r\n expandAriaLabel=\"Panel Expand\"\r\n expandAriaLabelledBy=\"panel-compact-1\"\r\n [expanded]=\"!!searchTerm?.length\"\r\n >\r\n <h5 fd-panel-title id=\"panel-compact-1\">{{ cat.Title }}</h5>\r\n <div fd-panel-content ariaLabel=\"Panel Content\" id=\"panel-content-3\" class=\"!p-0\">\r\n <ul fd-list [noBorder]=\"false\">\r\n @for (app of cat.Apps | filterApps:searchTerm; track app.Id) {\r\n <li fd-list-item>\r\n <a fd-list-link [navigated]=\"true\" [dynCommand]=\"app.DynamicCommand\" (click)=\"closeMenu.emit()\">\r\n <i fd-list-icon glyph=\"history\"></i>\r\n <span fd-list-title>{{ app.Title }}</span>\r\n <span fd-list-secondary>\r\n @if(pinnedAppInAppTileGroups$ | async; as pinnedAppInAppTileGroups) {\r\n <button\r\n ariaLabel=\"Bookmark\"\r\n fdType=\"transparent\"\r\n title=\"Bookmark\"\r\n fd-button\r\n [glyph]=\"'pushpin-off'\"\r\n [fdType]=\"\r\n pinnedAppInAppTileGroups[app.Id]\r\n ? pinnedAppInAppTileGroups[app.Id].length\r\n ? 'emphasized'\r\n : 'transparent'\r\n : app.$HasPinned\r\n ? 'emphasized'\r\n : 'transparent'\r\n \"\r\n (click)=\"$event.stopPropagation(); onPinClick(app)\"\r\n ></button>\r\n }\r\n </span>\r\n </a>\r\n </li>\r\n }\r\n </ul>\r\n </div>\r\n </fd-panel>\r\n }\r\n</div> -->\r\n", styles: [":host{display:block;min-height:100vh}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
93
|
+
}
|
|
94
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PopoverAppFinderComponent, decorators: [{
|
|
95
|
+
type: Component,
|
|
96
|
+
args: [{ selector: 'bt-popover-app-finder', changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
97
|
+
class: '!tw-min-h-min'
|
|
98
|
+
}, standalone: false, template: "<!-- \r\n<div>\r\n <div class=\"!tw-px-4 !tw-pt-2\" fd-form-item>\r\n <fd-input-group\r\n glyph=\"decline\"\r\n glyphAriaLabel=\"Clear\"\r\n placeholder=\"\u062C\u0633\u062A\u062C\u0648\"\r\n [button]=\"true\"\r\n [disabled]=\"false\"\r\n [(ngModel)]=\"searchTerm\"\r\n (addOnButtonClicked)=\"searchTerm = ''\"\r\n >\r\n </fd-input-group>\r\n </div>\r\n @for (cat of appGroups$ | async | filterAppsGrouped:searchTerm; track cat.Id) {\r\n <fd-panel\r\n fdCompact\r\n expandAriaLabel=\"Panel Expand\"\r\n expandAriaLabelledBy=\"panel-compact-1\"\r\n [expanded]=\"!!searchTerm?.length\"\r\n >\r\n <h5 fd-panel-title id=\"panel-compact-1\">{{ cat.Title }}</h5>\r\n <div fd-panel-content ariaLabel=\"Panel Content\" id=\"panel-content-3\" class=\"!p-0\">\r\n <ul fd-list [noBorder]=\"false\">\r\n @for (app of cat.Apps | filterApps:searchTerm; track app.Id) {\r\n <li fd-list-item>\r\n <a fd-list-link [navigated]=\"true\" [dynCommand]=\"app.DynamicCommand\" (click)=\"closeMenu.emit()\">\r\n <i fd-list-icon glyph=\"history\"></i>\r\n <span fd-list-title>{{ app.Title }}</span>\r\n <span fd-list-secondary>\r\n @if(pinnedAppInAppTileGroups$ | async; as pinnedAppInAppTileGroups) {\r\n <button\r\n ariaLabel=\"Bookmark\"\r\n fdType=\"transparent\"\r\n title=\"Bookmark\"\r\n fd-button\r\n [glyph]=\"'pushpin-off'\"\r\n [fdType]=\"\r\n pinnedAppInAppTileGroups[app.Id]\r\n ? pinnedAppInAppTileGroups[app.Id].length\r\n ? 'emphasized'\r\n : 'transparent'\r\n : app.$HasPinned\r\n ? 'emphasized'\r\n : 'transparent'\r\n \"\r\n (click)=\"$event.stopPropagation(); onPinClick(app)\"\r\n ></button>\r\n }\r\n </span>\r\n </a>\r\n </li>\r\n }\r\n </ul>\r\n </div>\r\n </fd-panel>\r\n }\r\n</div> -->\r\n", styles: [":host{display:block;min-height:100vh}\n"] }]
|
|
99
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.DialogService }, { type: i2.AppFinderService }, { type: i0.ElementRef }, { type: i1.ContentDensityService }], propDecorators: { closeMenu: [{
|
|
100
|
+
type: Output
|
|
101
|
+
}] } });
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover-app-finder.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-tiles/src/lib/popover-app-finder/popover-app-finder.component.ts","../../../../../projects/barsa-tiles/src/lib/popover-app-finder/popover-app-finder.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    ElementRef,\r\n    EventEmitter,\r\n    OnInit,\r\n    Output\r\n} from '@angular/core';\r\nimport { Observable } from 'rxjs';\r\nimport { map, takeUntil } from 'rxjs/operators';\r\nimport { ContentDensity, ContentDensityService, DialogService } from '@fundamental-ngx/core';\r\n\r\nimport { BaseComponent, MetaobjectDataModel, AbbrevationDeviceSize } from 'barsa-novin-ray-core';\r\nimport { AppFinderService } from '../app-finder.service';\r\nimport { AppTileGroupPin } from '../models';\r\nimport { PinTileComponent } from '../pin-tile/pin-tile.component';\r\n\r\n@Component({\r\n    selector: 'bt-popover-app-finder',\r\n    templateUrl: './popover-app-finder.component.html',\r\n    styleUrls: ['./popover-app-finder.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    host: {\r\n        class: '!tw-min-h-min'\r\n    },\r\n    standalone: false\r\n})\r\nexport class PopoverAppFinderComponent extends BaseComponent implements OnInit {\r\n    @Output() closeMenu = new EventEmitter<void>();\r\n    selectedGroups: MetaobjectDataModel[];\r\n    isAllSelected = true;\r\n    appGroups$: Observable<MetaobjectDataModel[] | undefined>;\r\n    appTileGroups$: Observable<MetaobjectDataModel[]>;\r\n    searchTerm: string;\r\n    deviceSize$: Observable<AbbrevationDeviceSize>;\r\n    sideContentSize$: Observable<string>;\r\n    contentDensity$: Observable<ContentDensity>;\r\n    selectedAppGroup$: Observable<MetaobjectDataModel | undefined>;\r\n    selectedAppGroupId$: Observable<string>;\r\n    mobile$: Observable<boolean>;\r\n    contentHeight: string;\r\n    pinnedAppInAppTileGroups$: Observable<Record<string, string[]>>;\r\n\r\n    constructor(\r\n        private _cdr: ChangeDetectorRef,\r\n        private _dialogService: DialogService,\r\n        private _appFinderService: AppFinderService,\r\n        private _el: ElementRef,\r\n        _contentDensityService: ContentDensityService\r\n    ) {\r\n        super();\r\n        this.contentDensity$ = _contentDensityService.contentDensity.asObservable();\r\n        this.appGroups$ = this._appFinderService.appGroups$.pipe(\r\n            map((appGroups) => {\r\n                appGroups.forEach((cat) => {\r\n                    this._appFinderService.loadAppsByAppGroup(appGroups, cat);\r\n                });\r\n                return appGroups;\r\n            })\r\n        );\r\n        this.selectedAppGroup$ = this._appFinderService.selectedAppGroup$;\r\n        this.selectedAppGroupId$ = this._appFinderService.selectedAppGroupId$;\r\n        this.deviceSize$ = this._appFinderService.deviceSize$;\r\n        this.pinnedAppInAppTileGroups$ = this._appFinderService.pinnedAppInAppTileGroups$;\r\n        this.mobile$ = this.deviceSize$.pipe(map((c) => c === 's'));\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n\r\n        this.contentHeight = 'calc(' + this._el.nativeElement.offsetHeight + 'px - 2.75rem)';\r\n\r\n        this.sideContentSize$ = this.deviceSize$.pipe(\r\n            takeUntil(this._onDestroy$),\r\n            map((deviceSize) => {\r\n                switch (deviceSize) {\r\n                    case 's':\r\n                        return 'sm';\r\n                    case 'm':\r\n                        return 'md';\r\n                    case 'l':\r\n                        return 'lg';\r\n                    case 'xl':\r\n                        return 'xl';\r\n                    default:\r\n                        return 'l';\r\n                }\r\n            })\r\n        );\r\n    }\r\n\r\n    onSelectedAppGroupChange(appGroupId: string): void {\r\n        this._changeGroup(appGroupId);\r\n    }\r\n\r\n    onPinClick(app: MetaobjectDataModel): void {\r\n        const pinnedAppInTileGroups = this._appFinderService.loadPinnedAppInTileGroups(app);\r\n        const appTileGroups = this._appFinderService.appTileGroups;\r\n        const deviceSize = this._appFinderService.deviceSize;\r\n        const mobile = deviceSize === 's';\r\n        this._dialogService\r\n            .open(PinTileComponent, {\r\n                data: { app, pinnedAppInTileGroups, appTileGroups },\r\n                minWidth: '350px',\r\n                minHeight: '420px',\r\n                draggable: false,\r\n                mobile,\r\n                resizable: false,\r\n                verticalPadding: false,\r\n                backdropClickCloseable: false\r\n            })\r\n            .afterClosed.subscribe((result) => {\r\n                this._appTileGroupsPinChange(result);\r\n            });\r\n    }\r\n    onRefresh(): void {}\r\n    async _appTileGroupsPinChange(result: {\r\n        appTileGroupsPin: AppTileGroupPin[];\r\n        app: MetaobjectDataModel;\r\n    }): Promise<void> {\r\n        try {\r\n            // Will try to ask for permission\r\n            this._appFinderService.pinTileChanged(result.appTileGroupsPin, result.app, () => {\r\n                this._cdr.detectChanges();\r\n            });\r\n        } catch (err) {\r\n            // show msg error\r\n        } finally {\r\n            // show toast successful\r\n        }\r\n    }\r\n    private _changeGroup(appGroupId: string): void {\r\n        this.isAllSelected = false;\r\n        this._appFinderService.selectAppGroup(appGroupId);\r\n        this._cdr.detectChanges();\r\n    }\r\n}\r\n","<!-- \r\n<div>\r\n    <div class=\"!tw-px-4 !tw-pt-2\" fd-form-item>\r\n        <fd-input-group\r\n            glyph=\"decline\"\r\n            glyphAriaLabel=\"Clear\"\r\n            placeholder=\"جستجو\"\r\n            [button]=\"true\"\r\n            [disabled]=\"false\"\r\n            [(ngModel)]=\"searchTerm\"\r\n            (addOnButtonClicked)=\"searchTerm = ''\"\r\n        >\r\n        </fd-input-group>\r\n    </div>\r\n    @for (cat of appGroups$ | async | filterAppsGrouped:searchTerm; track cat.Id) {\r\n    <fd-panel\r\n        fdCompact\r\n        expandAriaLabel=\"Panel Expand\"\r\n        expandAriaLabelledBy=\"panel-compact-1\"\r\n        [expanded]=\"!!searchTerm?.length\"\r\n    >\r\n        <h5 fd-panel-title id=\"panel-compact-1\">{{ cat.Title }}</h5>\r\n        <div fd-panel-content ariaLabel=\"Panel Content\" id=\"panel-content-3\" class=\"!p-0\">\r\n            <ul fd-list [noBorder]=\"false\">\r\n                @for (app of cat.Apps | filterApps:searchTerm; track app.Id) {\r\n                <li fd-list-item>\r\n                    <a fd-list-link [navigated]=\"true\" [dynCommand]=\"app.DynamicCommand\" (click)=\"closeMenu.emit()\">\r\n                        <i fd-list-icon glyph=\"history\"></i>\r\n                        <span fd-list-title>{{ app.Title }}</span>\r\n                        <span fd-list-secondary>\r\n                            @if(pinnedAppInAppTileGroups$ | async; as pinnedAppInAppTileGroups) {\r\n                            <button\r\n                                ariaLabel=\"Bookmark\"\r\n                                fdType=\"transparent\"\r\n                                title=\"Bookmark\"\r\n                                fd-button\r\n                                [glyph]=\"'pushpin-off'\"\r\n                                [fdType]=\"\r\n                                    pinnedAppInAppTileGroups[app.Id]\r\n                                        ? pinnedAppInAppTileGroups[app.Id].length\r\n                                            ? 'emphasized'\r\n                                            : 'transparent'\r\n                                        : app.$HasPinned\r\n                                        ? 'emphasized'\r\n                                        : 'transparent'\r\n                                \"\r\n                                (click)=\"$event.stopPropagation(); onPinClick(app)\"\r\n                            ></button>\r\n                            }\r\n                        </span>\r\n                    </a>\r\n                </li>\r\n                }\r\n            </ul>\r\n        </div>\r\n    </fd-panel>\r\n    }\r\n</div> -->\r\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { BaseBtTileComponent } from '../models';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@fundamental-ngx/core/icon";
|
|
5
|
+
import * as i2 from "@fundamental-ngx/core/tile";
|
|
6
|
+
import * as i3 from "../tile/tile.component";
|
|
7
|
+
import * as i4 from "barsa-novin-ray-core";
|
|
8
|
+
import * as i5 from "barsa-sap-ui";
|
|
9
|
+
import * as i6 from "../pipes/tile-prop.pipe";
|
|
10
|
+
export class ProfileTileComponent extends BaseBtTileComponent {
|
|
11
|
+
get fileId() {
|
|
12
|
+
let fileId = this.settings?.Image?.FileId;
|
|
13
|
+
if (!fileId) {
|
|
14
|
+
fileId = this.settings?.CalcImage;
|
|
15
|
+
}
|
|
16
|
+
return fileId;
|
|
17
|
+
}
|
|
18
|
+
ngOnInit() {
|
|
19
|
+
super.ngOnInit();
|
|
20
|
+
this.icon = this.settings?.Icon;
|
|
21
|
+
this.fileId2 = this.fileId;
|
|
22
|
+
this.calcImage = this.settings?.CalcImage;
|
|
23
|
+
if (this.calcImage && this.calcImage.toLowerCase().startsWith('ih')) {
|
|
24
|
+
this.iconCalc = this.calcImage;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ProfileTileComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
28
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ProfileTileComponent, selector: "bt-profile-tile", usesInheritance: true, ngImport: i0, template: "<bt-tile\r\n [data]=\"data\"\r\n [type]=\"'launch'\"\r\n [edit]=\"edit\"\r\n [backColor]=\"backColor\"\r\n [setToStorage]=\"setToStorage\"\r\n [listMode]=\"listMode\"\r\n [deviceSize]=\"deviceSize\"\r\n [navigateBackOnClick]=\"navigateBackOnClick\"\r\n [title]=\"data | tileProp: 'Title':parameters\"\r\n [subtitle]=\"data | tileProp: 'Subtitle':parameters\"\r\n [dynamicCommand]=\"data | tileProp: 'DynamicCommand':parameters\"\r\n [isDouble]=\"data | tileProp: 'IsDouble':parameters\"\r\n [footer]=\"data | tileProp: 'Footer':parameters\"\r\n (hideClick)=\"hideClick.emit()\"\r\n (renameClick)=\"renameClick.emit()\"\r\n (click)=\"onTileClick()\"\r\n>\r\n <div fd-tile-content>\r\n @if (fileId2 || calcImage) {\r\n <span\r\n class=\"profile\"\r\n fd-tile-profile-img\r\n [backgroundImage]=\"calcImage || (fileId2 | picFieldSrc: 'GetPictureFromFileInfo':null)\"\r\n ></span>\r\n } @else if(icon){\r\n <fd-icon [font]=\"icon | sapFont\" fd-tile-profile-img style=\"font-size: 2rem\" [glyph]=\"icon\"></fd-icon>\r\n } @else {\r\n <fd-icon font=\"SAP-icons-TNT\" fd-tile-profile-img style=\"font-size: 2rem\" glyph=\"user\"></fd-icon>\r\n }\r\n </div>\r\n</bt-tile>\r\n", styles: [".profile{background-size:contain;background-repeat:no-repeat}\n"], dependencies: [{ kind: "component", type: i1.IconComponent, selector: "fd-icon", inputs: ["glyph", "font", "color", "background", "class", "ariaLabel", "ariaHidden"] }, { kind: "directive", type: i2.TileContentDirective, selector: "[fdTileContent], [fd-tile-content]", inputs: ["twoColumn"] }, { kind: "directive", type: i2.TileProfileImgDirective, selector: "[fdTileProfileImg], [fd-tile-profile-img]", inputs: ["id", "ariaLabel", "ariaLabelledby", "backgroundImage"] }, { kind: "component", type: i3.TileComponent, selector: "bt-tile", inputs: ["type", "footerTemplate", "footer", "disableClick", "title", "icon", "subtitle", "isDouble", "edit", "backColor", "dynamicCommand", "hideHeader", "setToStorage", "listMode", "navigateBackOnClick"] }, { kind: "pipe", type: i4.PictureFieldSourcePipe, name: "picFieldSrc" }, { kind: "pipe", type: i5.SapFontPipe, name: "sapFont" }, { kind: "pipe", type: i6.TilePropPipe, name: "tileProp" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
29
|
+
}
|
|
30
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ProfileTileComponent, decorators: [{
|
|
31
|
+
type: Component,
|
|
32
|
+
args: [{ selector: 'bt-profile-tile', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<bt-tile\r\n [data]=\"data\"\r\n [type]=\"'launch'\"\r\n [edit]=\"edit\"\r\n [backColor]=\"backColor\"\r\n [setToStorage]=\"setToStorage\"\r\n [listMode]=\"listMode\"\r\n [deviceSize]=\"deviceSize\"\r\n [navigateBackOnClick]=\"navigateBackOnClick\"\r\n [title]=\"data | tileProp: 'Title':parameters\"\r\n [subtitle]=\"data | tileProp: 'Subtitle':parameters\"\r\n [dynamicCommand]=\"data | tileProp: 'DynamicCommand':parameters\"\r\n [isDouble]=\"data | tileProp: 'IsDouble':parameters\"\r\n [footer]=\"data | tileProp: 'Footer':parameters\"\r\n (hideClick)=\"hideClick.emit()\"\r\n (renameClick)=\"renameClick.emit()\"\r\n (click)=\"onTileClick()\"\r\n>\r\n <div fd-tile-content>\r\n @if (fileId2 || calcImage) {\r\n <span\r\n class=\"profile\"\r\n fd-tile-profile-img\r\n [backgroundImage]=\"calcImage || (fileId2 | picFieldSrc: 'GetPictureFromFileInfo':null)\"\r\n ></span>\r\n } @else if(icon){\r\n <fd-icon [font]=\"icon | sapFont\" fd-tile-profile-img style=\"font-size: 2rem\" [glyph]=\"icon\"></fd-icon>\r\n } @else {\r\n <fd-icon font=\"SAP-icons-TNT\" fd-tile-profile-img style=\"font-size: 2rem\" glyph=\"user\"></fd-icon>\r\n }\r\n </div>\r\n</bt-tile>\r\n", styles: [".profile{background-size:contain;background-repeat:no-repeat}\n"] }]
|
|
33
|
+
}] });
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZmlsZS10aWxlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLXRpbGVzL3NyYy9saWIvcHJvZmlsZS10aWxlL3Byb2ZpbGUtdGlsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9iYXJzYS10aWxlcy9zcmMvbGliL3Byb2ZpbGUtdGlsZS9wcm9maWxlLXRpbGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVuRSxPQUFPLEVBQUUsbUJBQW1CLEVBQXNCLE1BQU0sV0FBVyxDQUFDOzs7Ozs7OztBQVNwRSxNQUFNLE9BQU8sb0JBQXFCLFNBQVEsbUJBQXVDO0lBTzdFLElBQUksTUFBTTtRQUNOLElBQUksTUFBTSxHQUFHLElBQUksQ0FBQyxRQUFRLEVBQUUsS0FBSyxFQUFFLE1BQU0sQ0FBQztRQUMxQyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDVixNQUFNLEdBQUcsSUFBSSxDQUFDLFFBQVEsRUFBRSxTQUFTLENBQUM7UUFDdEMsQ0FBQztRQUNELE9BQU8sTUFBTSxDQUFDO0lBQ2xCLENBQUM7SUFDRCxRQUFRO1FBQ0osS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLFFBQVEsRUFBRSxJQUFJLENBQUM7UUFDaEMsSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDO1FBQzNCLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLFFBQVEsRUFBRSxTQUFTLENBQUM7UUFDMUMsSUFBSSxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsV0FBVyxFQUFFLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7WUFDbEUsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO1FBQ25DLENBQUM7SUFDTCxDQUFDOytHQXRCUSxvQkFBb0I7bUdBQXBCLG9CQUFvQiw4RUNYakMsZ3lDQWdDQTs7NEZEckJhLG9CQUFvQjtrQkFQaEMsU0FBUzsrQkFDSSxpQkFBaUIsbUJBR1YsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuaW1wb3J0IHsgQmFzZUJ0VGlsZUNvbXBvbmVudCwgUHJvZmlsZVRpbGVTZXR0aW5nIH0gZnJvbSAnLi4vbW9kZWxzJztcclxuaW1wb3J0IHsgRmlsZVBpY3R1cmVJbmZvTW9kZWwgfSBmcm9tICdiYXJzYS1ub3Zpbi1yYXktY29yZSc7XHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdidC1wcm9maWxlLXRpbGUnLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL3Byb2ZpbGUtdGlsZS5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZVVybHM6IFsnLi9wcm9maWxlLXRpbGUuY29tcG9uZW50LnNjc3MnXSxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gICAgc3RhbmRhbG9uZTogZmFsc2VcclxufSlcclxuZXhwb3J0IGNsYXNzIFByb2ZpbGVUaWxlQ29tcG9uZW50IGV4dGVuZHMgQmFzZUJ0VGlsZUNvbXBvbmVudDxQcm9maWxlVGlsZVNldHRpbmc+IHtcclxuICAgIGljb246IHN0cmluZztcclxuICAgIGljb25DYWxjOiBzdHJpbmc7XHJcbiAgICBpY29uQ29sb3I6IHN0cmluZztcclxuICAgIGNhbGNJbWFnZTogc3RyaW5nO1xyXG4gICAgaW1hZ2U6IEZpbGVQaWN0dXJlSW5mb01vZGVsO1xyXG4gICAgZmlsZUlkMjogc3RyaW5nO1xyXG4gICAgZ2V0IGZpbGVJZCgpOiBzdHJpbmcge1xyXG4gICAgICAgIGxldCBmaWxlSWQgPSB0aGlzLnNldHRpbmdzPy5JbWFnZT8uRmlsZUlkO1xyXG4gICAgICAgIGlmICghZmlsZUlkKSB7XHJcbiAgICAgICAgICAgIGZpbGVJZCA9IHRoaXMuc2V0dGluZ3M/LkNhbGNJbWFnZTtcclxuICAgICAgICB9XHJcbiAgICAgICAgcmV0dXJuIGZpbGVJZDtcclxuICAgIH1cclxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XHJcbiAgICAgICAgdGhpcy5pY29uID0gdGhpcy5zZXR0aW5ncz8uSWNvbjtcclxuICAgICAgICB0aGlzLmZpbGVJZDIgPSB0aGlzLmZpbGVJZDtcclxuICAgICAgICB0aGlzLmNhbGNJbWFnZSA9IHRoaXMuc2V0dGluZ3M/LkNhbGNJbWFnZTtcclxuICAgICAgICBpZiAodGhpcy5jYWxjSW1hZ2UgJiYgdGhpcy5jYWxjSW1hZ2UudG9Mb3dlckNhc2UoKS5zdGFydHNXaXRoKCdpaCcpKSB7XHJcbiAgICAgICAgICAgIHRoaXMuaWNvbkNhbGMgPSB0aGlzLmNhbGNJbWFnZTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbn1cclxuIiwiPGJ0LXRpbGVcclxuICAgIFtkYXRhXT1cImRhdGFcIlxyXG4gICAgW3R5cGVdPVwiJ2xhdW5jaCdcIlxyXG4gICAgW2VkaXRdPVwiZWRpdFwiXHJcbiAgICBbYmFja0NvbG9yXT1cImJhY2tDb2xvclwiXHJcbiAgICBbc2V0VG9TdG9yYWdlXT1cInNldFRvU3RvcmFnZVwiXHJcbiAgICBbbGlzdE1vZGVdPVwibGlzdE1vZGVcIlxyXG4gICAgW2RldmljZVNpemVdPVwiZGV2aWNlU2l6ZVwiXHJcbiAgICBbbmF2aWdhdGVCYWNrT25DbGlja109XCJuYXZpZ2F0ZUJhY2tPbkNsaWNrXCJcclxuICAgIFt0aXRsZV09XCJkYXRhIHwgdGlsZVByb3A6ICdUaXRsZSc6cGFyYW1ldGVyc1wiXHJcbiAgICBbc3VidGl0bGVdPVwiZGF0YSB8IHRpbGVQcm9wOiAnU3VidGl0bGUnOnBhcmFtZXRlcnNcIlxyXG4gICAgW2R5bmFtaWNDb21tYW5kXT1cImRhdGEgfCB0aWxlUHJvcDogJ0R5bmFtaWNDb21tYW5kJzpwYXJhbWV0ZXJzXCJcclxuICAgIFtpc0RvdWJsZV09XCJkYXRhIHwgdGlsZVByb3A6ICdJc0RvdWJsZSc6cGFyYW1ldGVyc1wiXHJcbiAgICBbZm9vdGVyXT1cImRhdGEgfCB0aWxlUHJvcDogJ0Zvb3Rlcic6cGFyYW1ldGVyc1wiXHJcbiAgICAoaGlkZUNsaWNrKT1cImhpZGVDbGljay5lbWl0KClcIlxyXG4gICAgKHJlbmFtZUNsaWNrKT1cInJlbmFtZUNsaWNrLmVtaXQoKVwiXHJcbiAgICAoY2xpY2spPVwib25UaWxlQ2xpY2soKVwiXHJcbj5cclxuICAgIDxkaXYgZmQtdGlsZS1jb250ZW50PlxyXG4gICAgICAgIEBpZiAoZmlsZUlkMiB8fCBjYWxjSW1hZ2UpIHtcclxuICAgICAgICA8c3BhblxyXG4gICAgICAgICAgICBjbGFzcz1cInByb2ZpbGVcIlxyXG4gICAgICAgICAgICBmZC10aWxlLXByb2ZpbGUtaW1nXHJcbiAgICAgICAgICAgIFtiYWNrZ3JvdW5kSW1hZ2VdPVwiY2FsY0ltYWdlIHx8IChmaWxlSWQyIHwgcGljRmllbGRTcmM6ICdHZXRQaWN0dXJlRnJvbUZpbGVJbmZvJzpudWxsKVwiXHJcbiAgICAgICAgPjwvc3Bhbj5cclxuICAgICAgICB9IEBlbHNlIGlmKGljb24pe1xyXG4gICAgICAgIDxmZC1pY29uIFtmb250XT1cImljb24gfCBzYXBGb250XCIgZmQtdGlsZS1wcm9maWxlLWltZyBzdHlsZT1cImZvbnQtc2l6ZTogMnJlbVwiIFtnbHlwaF09XCJpY29uXCI+PC9mZC1pY29uPlxyXG4gICAgICAgIH0gQGVsc2Uge1xyXG4gICAgICAgIDxmZC1pY29uIGZvbnQ9XCJTQVAtaWNvbnMtVE5UXCIgZmQtdGlsZS1wcm9maWxlLWltZyBzdHlsZT1cImZvbnQtc2l6ZTogMnJlbVwiIGdseXBoPVwidXNlclwiPjwvZmQtaWNvbj5cclxuICAgICAgICB9XHJcbiAgICA8L2Rpdj5cclxuPC9idC10aWxlPlxyXG4iXX0=
|