bpm-core 0.0.2 → 0.0.4
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/lib/app/app.component.mjs +62 -0
- package/esm2022/lib/components/app-component-sections/index.mjs +2 -1
- package/esm2022/lib/components/app-component-sections/layout/header/header.component.mjs +103 -0
- package/esm2022/lib/components/app-component-sections/layout/layout.component.mjs +101 -0
- package/esm2022/lib/components/app-component-sections/layout/side-nav/side-nav.component.mjs +158 -0
- package/esm2022/lib/services/core.service.ts.mjs +346 -0
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/bpm-core.mjs +1919 -1170
- package/fesm2022/bpm-core.mjs.map +1 -1
- package/lib/app/app.component.d.ts +20 -0
- package/lib/components/app-component-sections/index.d.ts +1 -0
- package/lib/components/app-component-sections/layout/header/header.component.d.ts +34 -0
- package/lib/components/app-component-sections/layout/layout.component.d.ts +27 -0
- package/lib/components/app-component-sections/layout/side-nav/side-nav.component.d.ts +28 -0
- package/lib/components/shared-components/dialogs/submit-dialog/submit-dialog.component.d.ts +1 -1
- package/lib/services/core.service.ts.d.ts +27 -0
- package/package.json +2 -2
- package/public-api.d.ts +1 -0
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { Component, Inject } from '@angular/core';
|
|
2
|
+
import { LayoutComponent } from "../components/app-component-sections/layout/layout.component";
|
|
3
|
+
import { DOCUMENT } from "@angular/common";
|
|
4
|
+
import { Form, Messages } from "../interfaces";
|
|
5
|
+
import * as constants from "../constants";
|
|
6
|
+
import loadFormHooks from "../hooks/load-form";
|
|
7
|
+
import { ServiceHeaderComponent, WorkflowSectionComponent } from "../components/app-component-sections";
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@angular/router";
|
|
10
|
+
import * as i2 from "../services";
|
|
11
|
+
import * as i3 from "../services/core.service.ts";
|
|
12
|
+
export class AppComponent {
|
|
13
|
+
document;
|
|
14
|
+
router;
|
|
15
|
+
sidenavService;
|
|
16
|
+
coreService;
|
|
17
|
+
loading = {
|
|
18
|
+
form: false
|
|
19
|
+
};
|
|
20
|
+
form;
|
|
21
|
+
formTitle = 'Test';
|
|
22
|
+
constructor(document, router, sidenavService, coreService) {
|
|
23
|
+
this.document = document;
|
|
24
|
+
this.router = router;
|
|
25
|
+
this.sidenavService = sidenavService;
|
|
26
|
+
this.coreService = coreService;
|
|
27
|
+
this.loading['form'] = true;
|
|
28
|
+
this.coreService.loadForm().then((form) => {
|
|
29
|
+
this.loading['form'] = false;
|
|
30
|
+
if (form instanceof Form) {
|
|
31
|
+
this.form = form;
|
|
32
|
+
}
|
|
33
|
+
else if (form instanceof Messages) {
|
|
34
|
+
this.errorResponse(form);
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
errorResponse(form) {
|
|
39
|
+
if (!this.form) {
|
|
40
|
+
this.form = new Form(constants.NO_VALUE, constants.NO_VALUE, constants.NO_VALUE, constants.NO_VALUE, constants.NO_VALUE, constants.NO_VALUE, form);
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
this.form.messages = form;
|
|
44
|
+
this.form = loadFormHooks.afterTranspilePayload(this.form);
|
|
45
|
+
}
|
|
46
|
+
window.scrollTo(0, 0);
|
|
47
|
+
}
|
|
48
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AppComponent, deps: [{ token: DOCUMENT }, { token: i1.Router }, { token: i2.SidenavService }, { token: i3.CoreService }], target: i0.ɵɵFactoryTarget.Component });
|
|
49
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: AppComponent, isStandalone: true, selector: "lib-app", ngImport: i0, template: "<core-layout>\r\n @if (!loading['form']) {\r\n <core-service-header\r\n [isLoading]=\"false\"\r\n [formTitle]=\"formTitle\"\r\n [form]=\"form\">\r\n </core-service-header>\r\n <app-workflow-section\r\n workflow\r\n [form]=\"form\"\r\n [sections]=\"form?.sections\">\r\n </app-workflow-section>\r\n } @else {\r\n <core-service-header header [formTitle]=\"formTitle\" [isLoading]=\"true\">\r\n </core-service-header>\r\n }\r\n</core-layout>\r\n", styles: [""], dependencies: [{ kind: "component", type: LayoutComponent, selector: "core-layout", inputs: ["form", "formTitle", "isLoading", "serviceBrief"] }, { kind: "component", type: ServiceHeaderComponent, selector: "core-service-header", inputs: ["form", "showHistory", "isLoading", "showApprovalHistory", "approvalHistory", "creationDate", "formTitle", "section", "serviceBrief"] }, { kind: "component", type: WorkflowSectionComponent, selector: "app-workflow-section", inputs: ["sections", "isReadOnly", "isLoading", "form", "contentClass", "sectionsController", "segmentDynamicLoaderService", "sectionFormComponent", "sectionName"], outputs: ["sectionSubmitted"] }] });
|
|
50
|
+
}
|
|
51
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AppComponent, decorators: [{
|
|
52
|
+
type: Component,
|
|
53
|
+
args: [{ selector: 'lib-app', standalone: true, imports: [
|
|
54
|
+
LayoutComponent,
|
|
55
|
+
ServiceHeaderComponent,
|
|
56
|
+
WorkflowSectionComponent
|
|
57
|
+
], template: "<core-layout>\r\n @if (!loading['form']) {\r\n <core-service-header\r\n [isLoading]=\"false\"\r\n [formTitle]=\"formTitle\"\r\n [form]=\"form\">\r\n </core-service-header>\r\n <app-workflow-section\r\n workflow\r\n [form]=\"form\"\r\n [sections]=\"form?.sections\">\r\n </app-workflow-section>\r\n } @else {\r\n <core-service-header header [formTitle]=\"formTitle\" [isLoading]=\"true\">\r\n </core-service-header>\r\n }\r\n</core-layout>\r\n" }]
|
|
58
|
+
}], ctorParameters: () => [{ type: Document, decorators: [{
|
|
59
|
+
type: Inject,
|
|
60
|
+
args: [DOCUMENT]
|
|
61
|
+
}] }, { type: i1.Router }, { type: i2.SidenavService }, { type: i3.CoreService }] });
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2JwbS1jb3JlL3NyYy9saWIvYXBwL2FwcC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9icG0tY29yZS9zcmMvbGliL2FwcC9hcHAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDaEQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLDhEQUE4RCxDQUFDO0FBQzdGLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUl6QyxPQUFPLEVBQUMsSUFBSSxFQUFFLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUM3QyxPQUFPLEtBQUssU0FBUyxNQUFNLGNBQWMsQ0FBQztBQUMxQyxPQUFPLGFBQWEsTUFBTSxvQkFBb0IsQ0FBQztBQUMvQyxPQUFPLEVBQUMsc0JBQXNCLEVBQUUsd0JBQXdCLEVBQUMsTUFBTSxzQ0FBc0MsQ0FBQzs7Ozs7QUFldEcsTUFBTSxPQUFPLFlBQVk7SUFRYztJQUNsQjtJQUNBO0lBQ1Q7SUFWVixPQUFPLEdBQUc7UUFDUixJQUFJLEVBQUUsS0FBSztLQUNaLENBQUE7SUFDRCxJQUFJLENBQU07SUFDVixTQUFTLEdBQVcsTUFBTSxDQUFDO0lBRTNCLFlBQ3FDLFFBQWtCLEVBQ3BDLE1BQWMsRUFDZCxjQUE4QixFQUN2QyxXQUF3QjtRQUhHLGFBQVEsR0FBUixRQUFRLENBQVU7UUFDcEMsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUNkLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtRQUN2QyxnQkFBVyxHQUFYLFdBQVcsQ0FBYTtRQUVoQyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FBQTtRQUMzQixJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLElBQVMsRUFBRSxFQUFFO1lBQzNDLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLEdBQUcsS0FBSyxDQUFBO1lBQzVCLElBQUksSUFBSSxZQUFZLElBQUksRUFBRSxDQUFDO2dCQUN6QixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztZQUNuQixDQUFDO2lCQUFNLElBQUksSUFBSSxZQUFZLFFBQVEsRUFBRSxDQUFDO2dCQUNwQyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFBO1lBQzFCLENBQUM7UUFDSCxDQUFDLENBQ0YsQ0FBQztJQUNKLENBQUM7SUFFRCxhQUFhLENBQUMsSUFBUztRQUNyQixJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1lBQ2YsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLElBQUksQ0FDbEIsU0FBUyxDQUFDLFFBQVEsRUFDbEIsU0FBUyxDQUFDLFFBQVEsRUFDbEIsU0FBUyxDQUFDLFFBQVEsRUFDbEIsU0FBUyxDQUFDLFFBQVEsRUFDbEIsU0FBUyxDQUFDLFFBQVEsRUFDbEIsU0FBUyxDQUFDLFFBQVEsRUFDbEIsSUFBSSxDQUNMLENBQUM7UUFDSixDQUFDO2FBQU0sQ0FBQztZQUNOLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztZQUMxQixJQUFJLENBQUMsSUFBSSxHQUFHLGFBQWEsQ0FBQyxxQkFBcUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDN0QsQ0FBQztRQUNELE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQ3hCLENBQUM7dUdBekNVLFlBQVksa0JBUWIsUUFBUTsyRkFSUCxZQUFZLG1FQ3hCekIsK2VBaUJBLDBEREVJLGVBQWUsb0hBQ2Ysc0JBQXNCLGdOQUN0Qix3QkFBd0I7OzJGQUdmLFlBQVk7a0JBWHhCLFNBQVM7K0JBQ0UsU0FBUyxjQUNQLElBQUksV0FHUDt3QkFDUCxlQUFlO3dCQUNmLHNCQUFzQjt3QkFDdEIsd0JBQXdCO3FCQUN6Qjs7MEJBVUUsTUFBTTsyQkFBQyxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIEluamVjdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7TGF5b3V0Q29tcG9uZW50fSBmcm9tIFwiLi4vY29tcG9uZW50cy9hcHAtY29tcG9uZW50LXNlY3Rpb25zL2xheW91dC9sYXlvdXQuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7RE9DVU1FTlR9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHtSb3V0ZXJ9IGZyb20gXCJAYW5ndWxhci9yb3V0ZXJcIjtcclxuaW1wb3J0IHtTaWRlbmF2U2VydmljZX0gZnJvbSBcIi4uL3NlcnZpY2VzXCI7XHJcbmltcG9ydCB7Q29yZVNlcnZpY2V9IGZyb20gXCIuLi9zZXJ2aWNlcy9jb3JlLnNlcnZpY2UudHNcIjtcclxuaW1wb3J0IHtGb3JtLCBNZXNzYWdlc30gZnJvbSBcIi4uL2ludGVyZmFjZXNcIjtcclxuaW1wb3J0ICogYXMgY29uc3RhbnRzIGZyb20gXCIuLi9jb25zdGFudHNcIjtcclxuaW1wb3J0IGxvYWRGb3JtSG9va3MgZnJvbSBcIi4uL2hvb2tzL2xvYWQtZm9ybVwiO1xyXG5pbXBvcnQge1NlcnZpY2VIZWFkZXJDb21wb25lbnQsIFdvcmtmbG93U2VjdGlvbkNvbXBvbmVudH0gZnJvbSBcIi4uL2NvbXBvbmVudHMvYXBwLWNvbXBvbmVudC1zZWN0aW9uc1wiO1xyXG5pbXBvcnQge01ZX0xJQl9DT05GSUdfVE9LRU59IGZyb20gXCIuLi8uLi9wdWJsaWMtYXBpXCI7XHJcbmltcG9ydCB7ZW52aXJvbm1lbnR9IGZyb20gXCIuLi9lbnZpcm9ubWVudHMvZW52aXJvbm1lbnQubG9jYWxcIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbGliLWFwcCcsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICB0ZW1wbGF0ZVVybDogJy4vYXBwLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4vYXBwLmNvbXBvbmVudC5jc3MnLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIExheW91dENvbXBvbmVudCxcclxuICAgIFNlcnZpY2VIZWFkZXJDb21wb25lbnQsXHJcbiAgICBXb3JrZmxvd1NlY3Rpb25Db21wb25lbnRcclxuICBdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQXBwQ29tcG9uZW50IHtcclxuICBsb2FkaW5nID0ge1xyXG4gICAgZm9ybTogZmFsc2VcclxuICB9XHJcbiAgZm9ybTogRm9ybVxyXG4gIGZvcm1UaXRsZTogc3RyaW5nID0gJ1Rlc3QnO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIEBJbmplY3QoRE9DVU1FTlQpIHByaXZhdGUgcmVhZG9ubHkgZG9jdW1lbnQ6IERvY3VtZW50LFxyXG4gICAgcHJpdmF0ZSByZWFkb25seSByb3V0ZXI6IFJvdXRlcixcclxuICAgIHByaXZhdGUgcmVhZG9ubHkgc2lkZW5hdlNlcnZpY2U6IFNpZGVuYXZTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBjb3JlU2VydmljZTogQ29yZVNlcnZpY2VcclxuICApIHtcclxuICAgIHRoaXMubG9hZGluZ1snZm9ybSddID0gdHJ1ZVxyXG4gICAgdGhpcy5jb3JlU2VydmljZS5sb2FkRm9ybSgpLnRoZW4oKGZvcm06IGFueSkgPT4ge1xyXG4gICAgICAgIHRoaXMubG9hZGluZ1snZm9ybSddID0gZmFsc2VcclxuICAgICAgICBpZiAoZm9ybSBpbnN0YW5jZW9mIEZvcm0pIHtcclxuICAgICAgICAgIHRoaXMuZm9ybSA9IGZvcm07XHJcbiAgICAgICAgfSBlbHNlIGlmIChmb3JtIGluc3RhbmNlb2YgTWVzc2FnZXMpIHtcclxuICAgICAgICAgIHRoaXMuZXJyb3JSZXNwb25zZShmb3JtKVxyXG4gICAgICAgIH1cclxuICAgICAgfVxyXG4gICAgKTtcclxuICB9XHJcblxyXG4gIGVycm9yUmVzcG9uc2UoZm9ybTogYW55KSB7XHJcbiAgICBpZiAoIXRoaXMuZm9ybSkge1xyXG4gICAgICB0aGlzLmZvcm0gPSBuZXcgRm9ybShcclxuICAgICAgICBjb25zdGFudHMuTk9fVkFMVUUsXHJcbiAgICAgICAgY29uc3RhbnRzLk5PX1ZBTFVFLFxyXG4gICAgICAgIGNvbnN0YW50cy5OT19WQUxVRSxcclxuICAgICAgICBjb25zdGFudHMuTk9fVkFMVUUsXHJcbiAgICAgICAgY29uc3RhbnRzLk5PX1ZBTFVFLFxyXG4gICAgICAgIGNvbnN0YW50cy5OT19WQUxVRSxcclxuICAgICAgICBmb3JtXHJcbiAgICAgICk7XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICB0aGlzLmZvcm0ubWVzc2FnZXMgPSBmb3JtO1xyXG4gICAgICB0aGlzLmZvcm0gPSBsb2FkRm9ybUhvb2tzLmFmdGVyVHJhbnNwaWxlUGF5bG9hZCh0aGlzLmZvcm0pO1xyXG4gICAgfVxyXG4gICAgd2luZG93LnNjcm9sbFRvKDAsIDApO1xyXG4gIH1cclxufVxyXG4iLCI8Y29yZS1sYXlvdXQ+XHJcbiAgQGlmICghbG9hZGluZ1snZm9ybSddKSB7XHJcbiAgICA8Y29yZS1zZXJ2aWNlLWhlYWRlclxyXG4gICAgICBbaXNMb2FkaW5nXT1cImZhbHNlXCJcclxuICAgICAgW2Zvcm1UaXRsZV09XCJmb3JtVGl0bGVcIlxyXG4gICAgICBbZm9ybV09XCJmb3JtXCI+XHJcbiAgICA8L2NvcmUtc2VydmljZS1oZWFkZXI+XHJcbiAgICA8YXBwLXdvcmtmbG93LXNlY3Rpb25cclxuICAgICAgd29ya2Zsb3dcclxuICAgICAgW2Zvcm1dPVwiZm9ybVwiXHJcbiAgICAgIFtzZWN0aW9uc109XCJmb3JtPy5zZWN0aW9uc1wiPlxyXG4gICAgPC9hcHAtd29ya2Zsb3ctc2VjdGlvbj5cclxuICB9IEBlbHNlIHtcclxuICAgIDxjb3JlLXNlcnZpY2UtaGVhZGVyIGhlYWRlciBbZm9ybVRpdGxlXT1cImZvcm1UaXRsZVwiIFtpc0xvYWRpbmddPVwidHJ1ZVwiPlxyXG4gICAgPC9jb3JlLXNlcnZpY2UtaGVhZGVyPlxyXG4gIH1cclxuPC9jb3JlLWxheW91dD5cclxuIl19
|
|
@@ -6,4 +6,5 @@ export * from './main-request-details/main-request-details.component';
|
|
|
6
6
|
export * from './feedback-section/feedback-section.component';
|
|
7
7
|
export * from './profile-section/profile-section.component';
|
|
8
8
|
export * from './comment-section/comment-section.component';
|
|
9
|
-
|
|
9
|
+
export * from './layout/layout.component';
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9icG0tY29yZS9zcmMvbGliL2NvbXBvbmVudHMvYXBwLWNvbXBvbmVudC1zZWN0aW9ucy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJDQUEyQyxDQUFBO0FBQ3pELGNBQWMsMkJBQTJCLENBQUE7QUFDekMsY0FBYywrQ0FBK0MsQ0FBQTtBQUM3RCxjQUFjLHVDQUF1QyxDQUFBO0FBQ3JELGNBQWMsdURBQXVELENBQUM7QUFDdEUsY0FBYywrQ0FBK0MsQ0FBQTtBQUM3RCxjQUFjLDZDQUE2QyxDQUFBO0FBQzNELGNBQWMsNkNBQTZDLENBQUE7QUFDM0QsY0FBYywyQkFBMkIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc2VydmljZS1oZWFkZXIvc2VydmljZS1oZWFkZXIuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL3N0YXR1cy9zdGF0dXMuY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL3dvcmtmbG93LXNlY3Rpb24vd29ya2Zsb3ctc2VjdGlvbi5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vZm9ybS1zZWN0aW9uL2Zvcm0tc2VjdGlvbi5jb21wb25lbnQnXHJcbmV4cG9ydCAqIGZyb20gJy4vbWFpbi1yZXF1ZXN0LWRldGFpbHMvbWFpbi1yZXF1ZXN0LWRldGFpbHMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9mZWVkYmFjay1zZWN0aW9uL2ZlZWRiYWNrLXNlY3Rpb24uY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL3Byb2ZpbGUtc2VjdGlvbi9wcm9maWxlLXNlY3Rpb24uY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2NvbW1lbnQtc2VjdGlvbi9jb21tZW50LXNlY3Rpb24uY29tcG9uZW50J1xyXG5leHBvcnQgKiBmcm9tICcuL2xheW91dC9sYXlvdXQuY29tcG9uZW50J1xyXG4iXX0=
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA, Inject, PLATFORM_ID } from '@angular/core';
|
|
3
|
+
import { FormControl, ReactiveFormsModule } from '@angular/forms';
|
|
4
|
+
import { MatMenuModule } from '@angular/material/menu';
|
|
5
|
+
import { MatToolbarModule } from '@angular/material/toolbar';
|
|
6
|
+
import { RouterModule } from '@angular/router';
|
|
7
|
+
import * as Constants from '../../../../constants';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "../../../../services";
|
|
10
|
+
import * as i2 from "../../../../services/core.service.ts";
|
|
11
|
+
import * as i3 from "@angular/router";
|
|
12
|
+
import * as i4 from "@angular/common";
|
|
13
|
+
import * as i5 from "@angular/material/menu";
|
|
14
|
+
import * as i6 from "@angular/material/toolbar";
|
|
15
|
+
export class HeaderComponent {
|
|
16
|
+
translate;
|
|
17
|
+
sidenavService;
|
|
18
|
+
coreService;
|
|
19
|
+
router;
|
|
20
|
+
platformId;
|
|
21
|
+
search = new FormControl('');
|
|
22
|
+
sidenavSubscription;
|
|
23
|
+
isSidenavOpened = false;
|
|
24
|
+
device = '';
|
|
25
|
+
isMobile;
|
|
26
|
+
userData;
|
|
27
|
+
userName;
|
|
28
|
+
constructor(translate, sidenavService, coreService, router, platformId) {
|
|
29
|
+
this.translate = translate;
|
|
30
|
+
this.sidenavService = sidenavService;
|
|
31
|
+
this.coreService = coreService;
|
|
32
|
+
this.router = router;
|
|
33
|
+
this.platformId = platformId;
|
|
34
|
+
this.device = navigator.userAgent;
|
|
35
|
+
if (this.isMobile) {
|
|
36
|
+
document.documentElement.classList.add('inside-mobile-app');
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
setLanguage() {
|
|
40
|
+
const targetLang = this.translate.getLanguage() === 'en' ? 'ar' : 'en';
|
|
41
|
+
let url = location.origin + `/${targetLang}/group/i-gate/asset-management`;
|
|
42
|
+
window.open(url, '_self');
|
|
43
|
+
}
|
|
44
|
+
logout() {
|
|
45
|
+
let logoutUrl = Constants.LOGOUT_URL;
|
|
46
|
+
localStorage.removeItem('token');
|
|
47
|
+
localStorage.removeItem('userName');
|
|
48
|
+
localStorage.removeItem('user');
|
|
49
|
+
const userSelectedLanguage = localStorage.getItem('language') ?? 'en';
|
|
50
|
+
sessionStorage.clear();
|
|
51
|
+
localStorage.setItem('language', userSelectedLanguage);
|
|
52
|
+
window.open(logoutUrl, '_self');
|
|
53
|
+
}
|
|
54
|
+
ngOnInit() {
|
|
55
|
+
this.sidenavSubscription = this.sidenavService.sideNavOpened.subscribe((val) => {
|
|
56
|
+
this.isSidenavOpened = val;
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
ngAfterViewInit() {
|
|
60
|
+
setTimeout(() => {
|
|
61
|
+
console.log('xx', this.coreService.loggedInUserData);
|
|
62
|
+
}, 1000);
|
|
63
|
+
}
|
|
64
|
+
toggleSideNav() {
|
|
65
|
+
document.documentElement.classList.toggle('main-sidenav-opened');
|
|
66
|
+
this.sidenavService.sideNavOpened.next(!this.isSidenavOpened);
|
|
67
|
+
}
|
|
68
|
+
openDemandRequest() {
|
|
69
|
+
// this.sidenavService.publish('open', DemandRequestComponent, 'end', 'over');
|
|
70
|
+
}
|
|
71
|
+
openTicket() {
|
|
72
|
+
// this.sidenavService.publish('open', OpenTicketComponent, 'end', 'over');
|
|
73
|
+
}
|
|
74
|
+
openEService() {
|
|
75
|
+
// this.sidenavService.publish('open', VhrComponent, 'end', 'over');
|
|
76
|
+
}
|
|
77
|
+
// goToAdmin() {
|
|
78
|
+
// this.router.navigate(['/admin']);
|
|
79
|
+
// }
|
|
80
|
+
openApp(url) {
|
|
81
|
+
window.open(url, '_blank')?.focus();
|
|
82
|
+
}
|
|
83
|
+
ngOnDestroy() {
|
|
84
|
+
// this.sidenavSubscription.unsubscribe()
|
|
85
|
+
}
|
|
86
|
+
location = location;
|
|
87
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: HeaderComponent, deps: [{ token: i1.CoreI18nService }, { token: i1.SidenavService }, { token: i2.CoreService }, { token: i3.Router }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component });
|
|
88
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: HeaderComponent, isStandalone: true, selector: "app-header", ngImport: i0, template: "<ng-container *ngIf=\"!isMobile\">\r\n <mat-toolbar\r\n class=\"align-items-center justify-content-between gap-3 border-bottom\"\r\n >\r\n <div class=\"d-flex align-items-center gap-3\">\r\n <ds-button\r\n shape=\"flat\"\r\n icon\r\n color=\"light-gray\"\r\n square\r\n (click)=\"toggleSideNav()\"\r\n >\r\n <ds-icon icon=\"burger-menu-1\" class=\"fs-24 fc-dark-gray\"></ds-icon>\r\n </ds-button>\r\n\r\n <a [href]=\"location.origin\">\r\n <figure class=\"m-0 d-flex\">\r\n <img class=\"main-logo\" src=\"assets/images/hub.svg\" alt=\"\" />\r\n </figure>\r\n </a>\r\n </div>\r\n\r\n <div class=\"d-flex align-items-center gap-3\">\r\n <ds-button\r\n shape=\"flat\"\r\n color=\"light-gray\"\r\n class=\"user-menu-btn\"\r\n [matMenuTriggerFor]=\"userMenu\"\r\n >\r\n <ds-avatar\r\n image=\"/group/i-gate/wm-bpm/forms/-/proxy/portrait?email={{userData?.email}}\"\r\n onerror=\"this.onerror=null;this.src='assets/images/user2.jpg'\"\r\n slot=\"prefix\"\r\n class=\"avatar\"\r\n >\r\n </ds-avatar>\r\n\r\n <span class=\"fs-14 fw-medium fc-black\">\r\n {{ userData?.firstName }} {{ userData?.lastName }}\r\n </span>\r\n\r\n <ds-icon\r\n slot=\"suffix\"\r\n icon=\"arrow\"\r\n class=\"fc-dark-gray fs-16\"\r\n ></ds-icon>\r\n </ds-button>\r\n </div>\r\n </mat-toolbar>\r\n\r\n <!-- User Menu -->\r\n <mat-menu #userMenu=\"matMenu\" class=\"user-menu\">\r\n <div mat-menu-item>\r\n <span class=\"fs-14\">{{ translate.translate('welcome') }}, </span>\r\n <br />\r\n <span class=\"fs-14 fw-medium line-height-1\">{{ userData?.firstName }}</span>\r\n </div>\r\n <button mat-menu-item (click)=\"setLanguage()\">\r\n <div class=\"d-flex align-items-center gap-2\">\r\n <ds-icon icon=\"globe\" class=\"fs-25 fc-purple\"></ds-icon>\r\n <span class=\"fs-14 fw-medium fc-black\">{{\r\n translate.translate('otherLang')\r\n }}</span>\r\n </div>\r\n </button>\r\n <button mat-menu-item (click)=\"logout()\">\r\n <div class=\"d-flex align-items-center gap-2\">\r\n <ds-icon icon=\"logout\" class=\"fs-25 fc-red\"></ds-icon>\r\n <span class=\"fs-14 fw-medium fc-black\">{{\r\n translate.translate('logout')\r\n }}</span>\r\n </div>\r\n </button>\r\n </mat-menu>\r\n</ng-container>\r\n", styles: [".test-user-agent{position:fixed;top:90px;width:100%;z-index:99999;color:#fff}ds-button[square].burger-menu::part(base){--btn-padding: 10px;margin-bottom:-1px;width:37px;height:37px;--default-size: 37px}[dir=rtl] :host ds-button::part(overlay){inset:0}mat-toolbar{background-color:var(--main-toolbar-bc);height:var(--main-toolbar-height);position:fixed;top:0;z-index:var(--main-toolbar-zIndex);border-bottom:1px solid var(--light-gray)!important}mat-toolbar .logo img{min-width:100px}@media (max-width: 991px){.user-menu-btn::part(base){border:0px;padding:0;--default-size: 40px}.user-menu-btn::part(overlay){border-radius:50%}.user-menu-btn::part(label),.user-menu-btn::part(suffix){display:none}}:host::ng-deep .avatar{min-width:24px;width:24px;height:24px;background-color:transparent}:host::ng-deep ds-button.add::part(base){--btn-bg-color: var(--coral)}@media (max-width: 991px){:host::ng-deep .avatar{min-width:40px;width:40px;height:40px}:host::ng-deep .avatar .avatar--x-small{--default-size: 40px}}.linkS{position:fixed;z-index:2;bottom:100px;right:20px}.dashboard-menu-icon{display:inline-flex;align-items:center;justify-content:center;min-width:56px;width:56px;height:56px;border-radius:50%;background-color:var(--coral);margin-bottom:10px}::ng-deep .inside-mobile-app{--main-toolbar-height: 0px}::ng-deep ds-button.transparent::part(base){--btn-bg-color: transparent;--btn-border-color: transparent;--btn-overlay-color: transparent}::ng-deep .mat-divider-vertical{border-right-color:var(--black)}.mat-divider{--mat-divider-width: 1px;--mat-divider-color: var(--dark-gray)}.header-search{width:500px}@media (max-width: 1130px){.header-search{width:200px}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: RouterModule }, { kind: "ngmodule", type: MatMenuModule }, { kind: "component", type: i5.MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "component", type: i5.MatMenuItem, selector: "[mat-menu-item]", inputs: ["role", "disabled", "disableRipple"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i5.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }, { kind: "ngmodule", type: MatToolbarModule }, { kind: "component", type: i6.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }] });
|
|
89
|
+
}
|
|
90
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: HeaderComponent, decorators: [{
|
|
91
|
+
type: Component,
|
|
92
|
+
args: [{ selector: 'app-header', standalone: true, imports: [
|
|
93
|
+
CommonModule,
|
|
94
|
+
ReactiveFormsModule,
|
|
95
|
+
RouterModule,
|
|
96
|
+
MatMenuModule,
|
|
97
|
+
MatToolbarModule
|
|
98
|
+
], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "<ng-container *ngIf=\"!isMobile\">\r\n <mat-toolbar\r\n class=\"align-items-center justify-content-between gap-3 border-bottom\"\r\n >\r\n <div class=\"d-flex align-items-center gap-3\">\r\n <ds-button\r\n shape=\"flat\"\r\n icon\r\n color=\"light-gray\"\r\n square\r\n (click)=\"toggleSideNav()\"\r\n >\r\n <ds-icon icon=\"burger-menu-1\" class=\"fs-24 fc-dark-gray\"></ds-icon>\r\n </ds-button>\r\n\r\n <a [href]=\"location.origin\">\r\n <figure class=\"m-0 d-flex\">\r\n <img class=\"main-logo\" src=\"assets/images/hub.svg\" alt=\"\" />\r\n </figure>\r\n </a>\r\n </div>\r\n\r\n <div class=\"d-flex align-items-center gap-3\">\r\n <ds-button\r\n shape=\"flat\"\r\n color=\"light-gray\"\r\n class=\"user-menu-btn\"\r\n [matMenuTriggerFor]=\"userMenu\"\r\n >\r\n <ds-avatar\r\n image=\"/group/i-gate/wm-bpm/forms/-/proxy/portrait?email={{userData?.email}}\"\r\n onerror=\"this.onerror=null;this.src='assets/images/user2.jpg'\"\r\n slot=\"prefix\"\r\n class=\"avatar\"\r\n >\r\n </ds-avatar>\r\n\r\n <span class=\"fs-14 fw-medium fc-black\">\r\n {{ userData?.firstName }} {{ userData?.lastName }}\r\n </span>\r\n\r\n <ds-icon\r\n slot=\"suffix\"\r\n icon=\"arrow\"\r\n class=\"fc-dark-gray fs-16\"\r\n ></ds-icon>\r\n </ds-button>\r\n </div>\r\n </mat-toolbar>\r\n\r\n <!-- User Menu -->\r\n <mat-menu #userMenu=\"matMenu\" class=\"user-menu\">\r\n <div mat-menu-item>\r\n <span class=\"fs-14\">{{ translate.translate('welcome') }}, </span>\r\n <br />\r\n <span class=\"fs-14 fw-medium line-height-1\">{{ userData?.firstName }}</span>\r\n </div>\r\n <button mat-menu-item (click)=\"setLanguage()\">\r\n <div class=\"d-flex align-items-center gap-2\">\r\n <ds-icon icon=\"globe\" class=\"fs-25 fc-purple\"></ds-icon>\r\n <span class=\"fs-14 fw-medium fc-black\">{{\r\n translate.translate('otherLang')\r\n }}</span>\r\n </div>\r\n </button>\r\n <button mat-menu-item (click)=\"logout()\">\r\n <div class=\"d-flex align-items-center gap-2\">\r\n <ds-icon icon=\"logout\" class=\"fs-25 fc-red\"></ds-icon>\r\n <span class=\"fs-14 fw-medium fc-black\">{{\r\n translate.translate('logout')\r\n }}</span>\r\n </div>\r\n </button>\r\n </mat-menu>\r\n</ng-container>\r\n", styles: [".test-user-agent{position:fixed;top:90px;width:100%;z-index:99999;color:#fff}ds-button[square].burger-menu::part(base){--btn-padding: 10px;margin-bottom:-1px;width:37px;height:37px;--default-size: 37px}[dir=rtl] :host ds-button::part(overlay){inset:0}mat-toolbar{background-color:var(--main-toolbar-bc);height:var(--main-toolbar-height);position:fixed;top:0;z-index:var(--main-toolbar-zIndex);border-bottom:1px solid var(--light-gray)!important}mat-toolbar .logo img{min-width:100px}@media (max-width: 991px){.user-menu-btn::part(base){border:0px;padding:0;--default-size: 40px}.user-menu-btn::part(overlay){border-radius:50%}.user-menu-btn::part(label),.user-menu-btn::part(suffix){display:none}}:host::ng-deep .avatar{min-width:24px;width:24px;height:24px;background-color:transparent}:host::ng-deep ds-button.add::part(base){--btn-bg-color: var(--coral)}@media (max-width: 991px){:host::ng-deep .avatar{min-width:40px;width:40px;height:40px}:host::ng-deep .avatar .avatar--x-small{--default-size: 40px}}.linkS{position:fixed;z-index:2;bottom:100px;right:20px}.dashboard-menu-icon{display:inline-flex;align-items:center;justify-content:center;min-width:56px;width:56px;height:56px;border-radius:50%;background-color:var(--coral);margin-bottom:10px}::ng-deep .inside-mobile-app{--main-toolbar-height: 0px}::ng-deep ds-button.transparent::part(base){--btn-bg-color: transparent;--btn-border-color: transparent;--btn-overlay-color: transparent}::ng-deep .mat-divider-vertical{border-right-color:var(--black)}.mat-divider{--mat-divider-width: 1px;--mat-divider-color: var(--dark-gray)}.header-search{width:500px}@media (max-width: 1130px){.header-search{width:200px}}\n"] }]
|
|
99
|
+
}], ctorParameters: () => [{ type: i1.CoreI18nService }, { type: i1.SidenavService }, { type: i2.CoreService }, { type: i3.Router }, { type: undefined, decorators: [{
|
|
100
|
+
type: Inject,
|
|
101
|
+
args: [PLATFORM_ID]
|
|
102
|
+
}] }] });
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/layout/header/header.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/layout/header/header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {CommonModule} from '@angular/common';\r\nimport {Component, CUSTOM_ELEMENTS_SCHEMA, Inject, PLATFORM_ID} from '@angular/core';\r\nimport {FormControl, ReactiveFormsModule} from '@angular/forms';\r\nimport {MatMenuModule} from '@angular/material/menu';\r\nimport {MatToolbarModule} from '@angular/material/toolbar';\r\nimport {Router, RouterModule} from '@angular/router';\r\nimport {Subscription} from 'rxjs';\r\nimport {CoreI18nService, SidenavService} from '../../../../services';\r\nimport * as Constants from '../../../../constants';\r\nimport {CoreService} from \"../../../../services/core.service.ts\";\r\n\r\n\r\n@Component({\r\n  selector: 'app-header',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    ReactiveFormsModule,\r\n    RouterModule,\r\n    MatMenuModule,\r\n    MatToolbarModule\r\n  ],\r\n  templateUrl: './header.component.html',\r\n  styleUrls: ['./header.component.scss'],\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA]\r\n})\r\nexport class HeaderComponent {\r\n  search = new FormControl('');\r\n  sidenavSubscription!: Subscription;\r\n  isSidenavOpened = false;\r\n  device = '';\r\n  isMobile!: boolean;\r\n  userData: any;\r\n  userName: any;\r\n\r\n  constructor(\r\n    public readonly translate: CoreI18nService,\r\n    private sidenavService: SidenavService,\r\n    private coreService: CoreService,\r\n    private router: Router,\r\n    @Inject(PLATFORM_ID) private platformId: any\r\n  ) {\r\n    this.device = navigator.userAgent;\r\n\r\n    if (this.isMobile) {\r\n      document.documentElement.classList.add('inside-mobile-app');\r\n    }\r\n  }\r\n\r\n\r\n  setLanguage(): void {\r\n    const targetLang = this.translate.getLanguage() === 'en' ? 'ar' : 'en';\r\n    let url = location.origin + `/${targetLang}/group/i-gate/asset-management`;\r\n    window.open(url, '_self');\r\n  }\r\n\r\n  logout() {\r\n    let logoutUrl = Constants.LOGOUT_URL;\r\n    localStorage.removeItem('token');\r\n    localStorage.removeItem('userName');\r\n    localStorage.removeItem('user');\r\n    const userSelectedLanguage = localStorage.getItem('language') ?? 'en';\r\n    sessionStorage.clear();\r\n    localStorage.setItem('language', userSelectedLanguage);\r\n    window.open(logoutUrl, '_self');\r\n  }\r\n\r\n\r\n  ngOnInit(): void {\r\n    this.sidenavSubscription = this.sidenavService.sideNavOpened.subscribe((val) => {\r\n      this.isSidenavOpened = val;\r\n    });\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    setTimeout(() => {\r\n      console.log('xx', this.coreService.loggedInUserData)\r\n    }, 1000);\r\n  }\r\n\r\n\r\n  toggleSideNav() {\r\n    document.documentElement.classList.toggle('main-sidenav-opened');\r\n    this.sidenavService.sideNavOpened.next(!this.isSidenavOpened);\r\n  }\r\n\r\n\r\n  openDemandRequest() {\r\n    // this.sidenavService.publish('open', DemandRequestComponent, 'end', 'over');\r\n  }\r\n\r\n  openTicket() {\r\n    // this.sidenavService.publish('open', OpenTicketComponent, 'end', 'over');\r\n  }\r\n\r\n  openEService() {\r\n    // this.sidenavService.publish('open', VhrComponent, 'end', 'over');\r\n  }\r\n\r\n  // goToAdmin() {\r\n  //   this.router.navigate(['/admin']);\r\n  // }\r\n\r\n\r\n  openApp(url: string) {\r\n    window.open(url, '_blank')?.focus();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    // this.sidenavSubscription.unsubscribe()\r\n  }\r\n\r\n  protected readonly location = location;\r\n}\r\n","<ng-container *ngIf=\"!isMobile\">\r\n  <mat-toolbar\r\n    class=\"align-items-center justify-content-between gap-3 border-bottom\"\r\n  >\r\n    <div class=\"d-flex align-items-center gap-3\">\r\n      <ds-button\r\n        shape=\"flat\"\r\n        icon\r\n        color=\"light-gray\"\r\n        square\r\n        (click)=\"toggleSideNav()\"\r\n      >\r\n        <ds-icon icon=\"burger-menu-1\" class=\"fs-24 fc-dark-gray\"></ds-icon>\r\n      </ds-button>\r\n\r\n      <a [href]=\"location.origin\">\r\n        <figure class=\"m-0 d-flex\">\r\n          <img class=\"main-logo\" src=\"assets/images/hub.svg\" alt=\"\" />\r\n        </figure>\r\n      </a>\r\n    </div>\r\n\r\n    <div class=\"d-flex align-items-center gap-3\">\r\n      <ds-button\r\n        shape=\"flat\"\r\n        color=\"light-gray\"\r\n        class=\"user-menu-btn\"\r\n        [matMenuTriggerFor]=\"userMenu\"\r\n      >\r\n        <ds-avatar\r\n          image=\"/group/i-gate/wm-bpm/forms/-/proxy/portrait?email={{userData?.email}}\"\r\n          onerror=\"this.onerror=null;this.src='assets/images/user2.jpg'\"\r\n          slot=\"prefix\"\r\n          class=\"avatar\"\r\n        >\r\n        </ds-avatar>\r\n\r\n        <span class=\"fs-14 fw-medium fc-black\">\r\n          {{ userData?.firstName }} {{ userData?.lastName }}\r\n        </span>\r\n\r\n        <ds-icon\r\n          slot=\"suffix\"\r\n          icon=\"arrow\"\r\n          class=\"fc-dark-gray fs-16\"\r\n        ></ds-icon>\r\n      </ds-button>\r\n    </div>\r\n  </mat-toolbar>\r\n\r\n  <!-- User Menu -->\r\n  <mat-menu #userMenu=\"matMenu\" class=\"user-menu\">\r\n    <div mat-menu-item>\r\n      <span class=\"fs-14\">{{ translate.translate('welcome') }}, </span>\r\n      <br />\r\n      <span class=\"fs-14 fw-medium line-height-1\">{{ userData?.firstName }}</span>\r\n    </div>\r\n    <button mat-menu-item (click)=\"setLanguage()\">\r\n      <div class=\"d-flex align-items-center gap-2\">\r\n        <ds-icon icon=\"globe\" class=\"fs-25 fc-purple\"></ds-icon>\r\n        <span class=\"fs-14 fw-medium fc-black\">{{\r\n            translate.translate('otherLang')\r\n          }}</span>\r\n      </div>\r\n    </button>\r\n    <button mat-menu-item (click)=\"logout()\">\r\n      <div class=\"d-flex align-items-center gap-2\">\r\n        <ds-icon icon=\"logout\" class=\"fs-25 fc-red\"></ds-icon>\r\n        <span class=\"fs-14 fw-medium fc-black\">{{\r\n            translate.translate('logout')\r\n          }}</span>\r\n      </div>\r\n    </button>\r\n  </mat-menu>\r\n</ng-container>\r\n"]}
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
import { DOCUMENT, NgClass, NgComponentOutlet, NgIf } from '@angular/common';
|
|
2
|
+
import { Component, Inject, Input, ViewChild } from "@angular/core";
|
|
3
|
+
import { MatSidenavModule } from '@angular/material/sidenav';
|
|
4
|
+
import { RouterOutlet } from "@angular/router";
|
|
5
|
+
import { HeaderComponent } from "./header/header.component";
|
|
6
|
+
import { SideNavComponent } from "./side-nav/side-nav.component";
|
|
7
|
+
import { WorkflowSectionComponent } from "../workflow-section/workflow-section.component";
|
|
8
|
+
import { ServiceHeaderComponent } from "../service-header/service-header.component";
|
|
9
|
+
import { CoreService } from "../../../services/core.service.ts";
|
|
10
|
+
import { MY_LIB_CONFIG_TOKEN } from "../../../../public-api";
|
|
11
|
+
import { environment } from "../../../environments/environment.local";
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
import * as i1 from "@angular/router";
|
|
14
|
+
import * as i2 from "../../../services";
|
|
15
|
+
import * as i3 from "@angular/material/sidenav";
|
|
16
|
+
export class LayoutComponent {
|
|
17
|
+
document;
|
|
18
|
+
router;
|
|
19
|
+
sidenavService;
|
|
20
|
+
sidenav;
|
|
21
|
+
sideContent;
|
|
22
|
+
sidenavSubscription;
|
|
23
|
+
form;
|
|
24
|
+
formTitle;
|
|
25
|
+
isLoading = false;
|
|
26
|
+
serviceBrief = [];
|
|
27
|
+
constructor(document, router, sidenavService) {
|
|
28
|
+
this.document = document;
|
|
29
|
+
this.router = router;
|
|
30
|
+
this.sidenavService = sidenavService;
|
|
31
|
+
}
|
|
32
|
+
ngOnInit() {
|
|
33
|
+
this.sidenavSubscription = this.sidenavService.subject.subscribe((value) => {
|
|
34
|
+
this.sideContent = value.componentName;
|
|
35
|
+
this.sidenav.mode = value.mode;
|
|
36
|
+
this.sidenav.position = value.position;
|
|
37
|
+
if (value.eventName === "open") {
|
|
38
|
+
this.openSideNav();
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
this.closeSideNav();
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
ngOnDestroy() {
|
|
46
|
+
if (this.sidenavSubscription) {
|
|
47
|
+
this.sidenavSubscription.unsubscribe();
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
onClose() {
|
|
51
|
+
this.document.body.classList.remove("NoScroll");
|
|
52
|
+
this.document.documentElement.classList.remove("NoScroll");
|
|
53
|
+
}
|
|
54
|
+
backdropClick() {
|
|
55
|
+
this.sidenav.close().then(r => { });
|
|
56
|
+
this.sidenavService.closeSidenav();
|
|
57
|
+
this.document.body.classList.remove("NoScroll");
|
|
58
|
+
this.document.documentElement.classList.remove("NoScroll");
|
|
59
|
+
}
|
|
60
|
+
openSideNav() {
|
|
61
|
+
this.sidenav.open().then(r => { });
|
|
62
|
+
this.document.body.classList.add("NoScroll");
|
|
63
|
+
this.document.documentElement.classList.add("NoScroll");
|
|
64
|
+
}
|
|
65
|
+
closeSideNav() {
|
|
66
|
+
this.sidenav.close().then(r => { });
|
|
67
|
+
}
|
|
68
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: LayoutComponent, deps: [{ token: DOCUMENT }, { token: i1.Router }, { token: i2.SidenavService }], target: i0.ɵɵFactoryTarget.Component });
|
|
69
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: LayoutComponent, isStandalone: true, selector: "core-layout", inputs: { form: "form", formTitle: "formTitle", isLoading: "isLoading", serviceBrief: "serviceBrief" }, providers: [
|
|
70
|
+
CoreService,
|
|
71
|
+
{
|
|
72
|
+
provide: MY_LIB_CONFIG_TOKEN,
|
|
73
|
+
useValue: environment
|
|
74
|
+
}
|
|
75
|
+
], viewQueries: [{ propertyName: "sidenav", first: true, predicate: ["sidenav"], descendants: true, static: true }], ngImport: i0, template: "<app-header></app-header>\r\n<section class=\"d-flex\">\r\n <app-side-nav></app-side-nav>\r\n <mat-sidenav-container\r\n class=\"flex-grow-1\"\r\n [hasBackdrop]=\"true\"\r\n (backdropClick)=\"backdropClick()\"\r\n >\r\n <mat-sidenav\r\n #sidenav\r\n autoFocus=\"false\"\r\n fixedInViewport\r\n [position]=\"'end'\"\r\n (closedStart)=\"onClose()\"\r\n >\r\n <ng-container *ngComponentOutlet=\"sideContent\">\r\n <app-side-nav></app-side-nav>\r\n </ng-container>\r\n </mat-sidenav>\r\n <mat-sidenav-content>\r\n <main\r\n class=\"hadPadding service-wrapper\"\r\n [ngClass]=\"form?.header?.status?.key == 'NEW' ? 'hub-container-mini' : 'hub-container'\">\r\n\r\n <ng-content ></ng-content>\r\n <ng-content select=\"[workflow]\"></ng-content>\r\n\r\n </main>\r\n </mat-sidenav-content>\r\n </mat-sidenav-container>\r\n</section>\r\n", styles: [":host ::ng-deep .mat-drawer-container{overflow:visible;margin-top:var(--main-toolbar-height);min-height:calc(100vh - var(--main-toolbar-height));background-color:var(--body-bg)!important;z-index:initial!important;min-width:calc(100% - var(--main-aside-width));width:calc(100% - var(--main-aside-width))}:host ::ng-deep .mat-drawer-container .mat-drawer-content{display:flex;flex-direction:column;overflow:visible}.hup-wrapper :host ::ng-deep .mat-drawer-container .mat-drawer-content{min-height:auto}:host ::ng-deep footer{bottom:-65px}.mat-drawer{border-radius:10px!important;margin:1rem;box-shadow:0 8px 16px 7px rgba(var(--rgb-black),.06);background-color:var(--white)}@media (max-width: 767px){.mat-drawer{padding:0;border-radius:0;margin:0;width:100%}}.customize-btn{min-width:166px}.zer-pt{padding-top:0!important}\n"], dependencies: [{ kind: "component", type: HeaderComponent, selector: "app-header" }, { kind: "component", type: SideNavComponent, selector: "app-side-nav", inputs: ["isOpened"] }, { kind: "ngmodule", type: MatSidenavModule }, { kind: "component", type: i3.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { kind: "component", type: i3.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { kind: "component", type: i3.MatSidenavContent, selector: "mat-sidenav-content" }, { kind: "directive", type: NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
|
|
76
|
+
}
|
|
77
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: LayoutComponent, decorators: [{
|
|
78
|
+
type: Component,
|
|
79
|
+
args: [{ selector: "core-layout", standalone: true, imports: [HeaderComponent, SideNavComponent, MatSidenavModule, RouterOutlet, NgComponentOutlet, WorkflowSectionComponent, ServiceHeaderComponent, NgClass, NgIf], providers: [
|
|
80
|
+
CoreService,
|
|
81
|
+
{
|
|
82
|
+
provide: MY_LIB_CONFIG_TOKEN,
|
|
83
|
+
useValue: environment
|
|
84
|
+
}
|
|
85
|
+
], template: "<app-header></app-header>\r\n<section class=\"d-flex\">\r\n <app-side-nav></app-side-nav>\r\n <mat-sidenav-container\r\n class=\"flex-grow-1\"\r\n [hasBackdrop]=\"true\"\r\n (backdropClick)=\"backdropClick()\"\r\n >\r\n <mat-sidenav\r\n #sidenav\r\n autoFocus=\"false\"\r\n fixedInViewport\r\n [position]=\"'end'\"\r\n (closedStart)=\"onClose()\"\r\n >\r\n <ng-container *ngComponentOutlet=\"sideContent\">\r\n <app-side-nav></app-side-nav>\r\n </ng-container>\r\n </mat-sidenav>\r\n <mat-sidenav-content>\r\n <main\r\n class=\"hadPadding service-wrapper\"\r\n [ngClass]=\"form?.header?.status?.key == 'NEW' ? 'hub-container-mini' : 'hub-container'\">\r\n\r\n <ng-content ></ng-content>\r\n <ng-content select=\"[workflow]\"></ng-content>\r\n\r\n </main>\r\n </mat-sidenav-content>\r\n </mat-sidenav-container>\r\n</section>\r\n", styles: [":host ::ng-deep .mat-drawer-container{overflow:visible;margin-top:var(--main-toolbar-height);min-height:calc(100vh - var(--main-toolbar-height));background-color:var(--body-bg)!important;z-index:initial!important;min-width:calc(100% - var(--main-aside-width));width:calc(100% - var(--main-aside-width))}:host ::ng-deep .mat-drawer-container .mat-drawer-content{display:flex;flex-direction:column;overflow:visible}.hup-wrapper :host ::ng-deep .mat-drawer-container .mat-drawer-content{min-height:auto}:host ::ng-deep footer{bottom:-65px}.mat-drawer{border-radius:10px!important;margin:1rem;box-shadow:0 8px 16px 7px rgba(var(--rgb-black),.06);background-color:var(--white)}@media (max-width: 767px){.mat-drawer{padding:0;border-radius:0;margin:0;width:100%}}.customize-btn{min-width:166px}.zer-pt{padding-top:0!important}\n"] }]
|
|
86
|
+
}], ctorParameters: () => [{ type: Document, decorators: [{
|
|
87
|
+
type: Inject,
|
|
88
|
+
args: [DOCUMENT]
|
|
89
|
+
}] }, { type: i1.Router }, { type: i2.SidenavService }], propDecorators: { sidenav: [{
|
|
90
|
+
type: ViewChild,
|
|
91
|
+
args: ["sidenav", { static: true }]
|
|
92
|
+
}], form: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], formTitle: [{
|
|
95
|
+
type: Input
|
|
96
|
+
}], isLoading: [{
|
|
97
|
+
type: Input
|
|
98
|
+
}], serviceBrief: [{
|
|
99
|
+
type: Input
|
|
100
|
+
}] } });
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layout.component.js","sourceRoot":"","sources":["../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/layout/layout.component.ts","../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/layout/layout.component.html"],"names":[],"mappings":"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","sourcesContent":["import {DOCUMENT, NgClass, NgComponentOutlet, NgIf} from '@angular/common'\r\nimport {Component, Inject, Input, OnDestroy, OnInit, ViewChild} from \"@angular/core\";\r\nimport {MatSidenav, MatSidenavModule} from '@angular/material/sidenav'\r\nimport {Router, RouterOutlet} from \"@angular/router\";\r\nimport {Subscription} from \"rxjs\";\r\nimport {SidenavService} from \"../../../services\";\r\nimport {HeaderComponent} from \"./header/header.component\";\r\nimport {SideNavComponent} from \"./side-nav/side-nav.component\";\r\nimport {WorkflowSectionComponent} from \"../workflow-section/workflow-section.component\";\r\nimport {Form} from \"../../../interfaces\";\r\nimport {ServiceHeaderComponent} from \"../service-header/service-header.component\";\r\nimport {CoreService} from \"../../../services/core.service.ts\";\r\nimport {MY_LIB_CONFIG_TOKEN} from \"../../../../public-api\";\r\nimport {environment} from \"../../../environments/environment.local\";\r\n\r\n@Component({\r\n  selector: \"core-layout\",\r\n  standalone: true,\r\n  imports: [HeaderComponent, SideNavComponent, MatSidenavModule, RouterOutlet, NgComponentOutlet, WorkflowSectionComponent, ServiceHeaderComponent, NgClass, NgIf],\r\n  templateUrl: \"./layout.component.html\",\r\n  styleUrl: \"./layout.component.scss\",\r\n  providers: [\r\n    CoreService,\r\n    {\r\n      provide: MY_LIB_CONFIG_TOKEN,\r\n      useValue: environment\r\n    }\r\n  ]\r\n})\r\nexport class LayoutComponent implements OnInit, OnDestroy {\r\n  @ViewChild(\"sidenav\", {static: true}) public sidenav!: MatSidenav;\r\n  sideContent: any;\r\n  private sidenavSubscription!: Subscription;\r\n  @Input() form: Form\r\n  @Input() formTitle: string\r\n  @Input() isLoading = false;\r\n  @Input() serviceBrief: any[] = [];\r\n\r\n\r\n  constructor(\r\n    @Inject(DOCUMENT) private readonly document: Document,\r\n    private readonly router: Router,\r\n    private readonly sidenavService: SidenavService,\r\n  ) {}\r\n\r\n\r\n  ngOnInit(): void {\r\n    this.sidenavSubscription = this.sidenavService.subject.subscribe(\r\n      (value: any) => {\r\n        this.sideContent = value.componentName;\r\n        this.sidenav.mode = value.mode;\r\n        this.sidenav.position = value.position;\r\n        if (value.eventName === \"open\") {\r\n          this.openSideNav();\r\n        } else {\r\n          this.closeSideNav();\r\n        }\r\n      }\r\n    );\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.sidenavSubscription) {\r\n      this.sidenavSubscription.unsubscribe();\r\n    }\r\n  }\r\n\r\n  onClose() {\r\n    this.document.body.classList.remove(\"NoScroll\");\r\n    this.document.documentElement.classList.remove(\"NoScroll\");\r\n  }\r\n\r\n  backdropClick() {\r\n    this.sidenav.close().then(r => {});\r\n    this.sidenavService.closeSidenav();\r\n    this.document.body.classList.remove(\"NoScroll\");\r\n    this.document.documentElement.classList.remove(\"NoScroll\");\r\n  }\r\n\r\n  private openSideNav() {\r\n    this.sidenav.open().then(r => {});\r\n    this.document.body.classList.add(\"NoScroll\");\r\n    this.document.documentElement.classList.add(\"NoScroll\");\r\n  }\r\n\r\n  private closeSideNav() {\r\n    this.sidenav.close().then(r => {});\r\n  }\r\n}\r\n","<app-header></app-header>\r\n<section class=\"d-flex\">\r\n  <app-side-nav></app-side-nav>\r\n  <mat-sidenav-container\r\n    class=\"flex-grow-1\"\r\n    [hasBackdrop]=\"true\"\r\n    (backdropClick)=\"backdropClick()\"\r\n  >\r\n    <mat-sidenav\r\n      #sidenav\r\n      autoFocus=\"false\"\r\n      fixedInViewport\r\n      [position]=\"'end'\"\r\n      (closedStart)=\"onClose()\"\r\n    >\r\n      <ng-container *ngComponentOutlet=\"sideContent\">\r\n        <app-side-nav></app-side-nav>\r\n      </ng-container>\r\n    </mat-sidenav>\r\n    <mat-sidenav-content>\r\n      <main\r\n        class=\"hadPadding service-wrapper\"\r\n        [ngClass]=\"form?.header?.status?.key == 'NEW' ? 'hub-container-mini' : 'hub-container'\">\r\n\r\n        <ng-content ></ng-content>\r\n        <ng-content select=\"[workflow]\"></ng-content>\r\n\r\n      </main>\r\n    </mat-sidenav-content>\r\n  </mat-sidenav-container>\r\n</section>\r\n"]}
|
|
@@ -0,0 +1,158 @@
|
|
|
1
|
+
import { Component, CUSTOM_ELEMENTS_SCHEMA, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { RouterLink, RouterLinkActive } from '@angular/router';
|
|
3
|
+
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
4
|
+
import { MatMenu, MatMenuTrigger } from '@angular/material/menu';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../../../services";
|
|
7
|
+
import * as i2 from "@angular/router";
|
|
8
|
+
import * as i3 from "@angular/material/tooltip";
|
|
9
|
+
export class SideNavComponent {
|
|
10
|
+
sidenavService;
|
|
11
|
+
router;
|
|
12
|
+
isOpened = false;
|
|
13
|
+
lang = '';
|
|
14
|
+
Menu = [
|
|
15
|
+
{
|
|
16
|
+
name: 'Home',
|
|
17
|
+
routerLink: '/group/hub/home1',
|
|
18
|
+
icon: 'home-o',
|
|
19
|
+
matmenu: false,
|
|
20
|
+
List: []
|
|
21
|
+
},
|
|
22
|
+
{
|
|
23
|
+
name: 'Inbox',
|
|
24
|
+
routerLink: '/group/hub/inbox',
|
|
25
|
+
icon: 'mail-o',
|
|
26
|
+
matmenu: false,
|
|
27
|
+
List: []
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
name: 'Dobox',
|
|
31
|
+
routerLink: '/group/hub/dobox',
|
|
32
|
+
icon: 'chick-sqaure',
|
|
33
|
+
matmenu: false,
|
|
34
|
+
List: []
|
|
35
|
+
},
|
|
36
|
+
{
|
|
37
|
+
name: 'Chat',
|
|
38
|
+
routerLink: '/group/hub/chat',
|
|
39
|
+
icon: 'chat-circle-2',
|
|
40
|
+
matmenu: false,
|
|
41
|
+
List: []
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
name: 'Mail',
|
|
45
|
+
routerLink: '/group/hub/mail',
|
|
46
|
+
icon: 'mail-f',
|
|
47
|
+
matmenu: false,
|
|
48
|
+
List: []
|
|
49
|
+
},
|
|
50
|
+
{
|
|
51
|
+
name: 'Meetings',
|
|
52
|
+
routerLink: '/group/hub/meetings',
|
|
53
|
+
icon: 'calendar',
|
|
54
|
+
matmenu: false,
|
|
55
|
+
List: []
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
name: 'Offers',
|
|
59
|
+
routerLink: '/group/hub/hub-offers',
|
|
60
|
+
icon: 'voucher',
|
|
61
|
+
matmenu: false,
|
|
62
|
+
List: []
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
name: 'stc today',
|
|
66
|
+
routerLink: '/group/hub/stc-profile',
|
|
67
|
+
icon: 'stc-profile-o',
|
|
68
|
+
matmenu: false,
|
|
69
|
+
List: []
|
|
70
|
+
},
|
|
71
|
+
{
|
|
72
|
+
name: 'Articles',
|
|
73
|
+
routerLink: '/group/hub/articles',
|
|
74
|
+
icon: 'file-returned',
|
|
75
|
+
matmenu: false,
|
|
76
|
+
List: []
|
|
77
|
+
},
|
|
78
|
+
{
|
|
79
|
+
name: 'Timeline',
|
|
80
|
+
routerLink: '/group/hub/timeline',
|
|
81
|
+
icon: 'list-dots',
|
|
82
|
+
matmenu: false,
|
|
83
|
+
List: []
|
|
84
|
+
},
|
|
85
|
+
{
|
|
86
|
+
name: 'eforms',
|
|
87
|
+
routerLink: '/group/hub/efroms',
|
|
88
|
+
icon: 'file-o',
|
|
89
|
+
matmenu: false,
|
|
90
|
+
List: []
|
|
91
|
+
},
|
|
92
|
+
{
|
|
93
|
+
name: 'Apps',
|
|
94
|
+
routerLink: '/group/hub/apps',
|
|
95
|
+
icon: 'card',
|
|
96
|
+
matmenu: false,
|
|
97
|
+
List: []
|
|
98
|
+
},
|
|
99
|
+
];
|
|
100
|
+
constructor(sidenavService, router) {
|
|
101
|
+
this.sidenavService = sidenavService;
|
|
102
|
+
this.router = router;
|
|
103
|
+
}
|
|
104
|
+
closeSidenav() {
|
|
105
|
+
document.documentElement.classList.remove('main-sidenav-opened');
|
|
106
|
+
// this.sidenavService.sideNavOpened.next(false);
|
|
107
|
+
}
|
|
108
|
+
navigateTo(item) {
|
|
109
|
+
window.location.href = item.routerLink;
|
|
110
|
+
}
|
|
111
|
+
innerWidth;
|
|
112
|
+
menuMobile;
|
|
113
|
+
MenuTrigger;
|
|
114
|
+
ngOnInit() {
|
|
115
|
+
this.innerWidth = window.innerWidth;
|
|
116
|
+
if (this.innerWidth < 1024) {
|
|
117
|
+
this.menuMobile = true;
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
this.menuMobile = false;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
mouseover(matmenu, i) {
|
|
124
|
+
if (!this.menuMobile) {
|
|
125
|
+
if (matmenu) {
|
|
126
|
+
document.documentElement.classList.remove('main-overlay-closed');
|
|
127
|
+
// this.MenuTrigger[i].openMenu();
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
document.documentElement.classList.add('main-overlay-closed');
|
|
131
|
+
// this.MenuTrigger[i].closeMenu();
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
goto(url, matmenu) {
|
|
136
|
+
if (!this.menuMobile) {
|
|
137
|
+
if (matmenu) {
|
|
138
|
+
document.documentElement.classList.remove('main-overlay-closed');
|
|
139
|
+
}
|
|
140
|
+
else {
|
|
141
|
+
document.documentElement.classList.add('main-overlay-closed');
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
this.router.navigate([url]);
|
|
145
|
+
}
|
|
146
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: SideNavComponent, deps: [{ token: i1.SidenavService }, { token: i2.Router }], target: i0.ɵɵFactoryTarget.Component });
|
|
147
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.8", type: SideNavComponent, isStandalone: true, selector: "app-side-nav", inputs: { isOpened: "isOpened" }, viewQueries: [{ propertyName: "MenuTrigger", first: true, predicate: ["MenuTrigger"], descendants: true }], ngImport: i0, template: "<aside>\r\n <div class=\"header d-flex d-lg-none\">\r\n <div class=\"d-flex h-100 mt-auto justify-content-between w-100\">\r\n <h1 class=\"fs-26 fw-bold fc-white logo\">academy</h1>\r\n <ds-button size=\"small\" color=\"purple\" class=\"close purple\" (click)=\"closeSidenav()\">\r\n <ds-icon icon=\"close\" class=\"fs-15 fc-white\"></ds-icon>\r\n </ds-button>\r\n </div>\r\n </div>\r\n <nav>\r\n <ul>\r\n <!-- (mouseenter)=\"menuMobile ? null : MenuTrigger.openMenu()\"-->\r\n <!-- (click)=\"goto(item.routerLink,item.matmenu) -->\r\n @for (item of Menu; track $index) {\r\n @if (item.matmenu) {\r\n <li\r\n (click)=\"closeSidenav();navigateTo(item)\" matTooltipPosition=\"right\" matTooltip=\"{{item.name }}\"\r\n [routerLinkActive]=\"'active'\" (click)=\"goto(item.routerLink!,item.matmenu)\" #MenuTrigger=\"matMenuTrigger\"\r\n [matMenuTriggerFor]=\"menuMenu\" [routerLinkActiveOptions]=\"{ exact: true }\" class=\"cursor-pointer\">\r\n <ds-icon icon=\"{{item.icon}}\" class=\"icon\"></ds-icon>\r\n <span class=\"menu-label\">\r\n {{ item.name }}\r\n </span>\r\n </li>\r\n <mat-menu #menuMenu=\"matMenu\" class=\"aside-menu visible-{{item.matmenu}}\">\r\n <app-mat-menu [title]=\"item.name \" [icon]=\"item.icon\" [list]=\"item.List\"></app-mat-menu>\r\n </mat-menu>\r\n } @else {\r\n <li\r\n (click)=\"closeSidenav();navigateTo(item)\" matTooltipPosition=\"right\" matTooltip=\"{{item.name }}\"\r\n [routerLinkActive]=\"'active'\" [routerLinkActiveOptions]=\"{ exact: true }\" class=\"cursor-pointer\">\r\n <ds-icon icon=\"{{item.icon}}\" class=\"icon\"></ds-icon>\r\n <span class=\"menu-label\">\r\n {{ item.name }}\r\n </span>\r\n </li>\r\n }\r\n }\r\n </ul>\r\n </nav>\r\n</aside>\r\n", styles: [":host ::ng-deep aside{min-width:var(--main-aside-width);width:var(--main-aside-width);height:calc(100vh - var(--main-toolbar-height));display:flex;position:var(--main-aside-position);right:var(--main-aside-right);left:var(--main-aside-left);top:var(--main-toolbar-height);z-index:var(--main-toolbar-zIndex);background-color:var(--main-aside-bc);transform:var(--main-aside-transform);transition:all .5s cubic-bezier(.685,.0473,.346,1)}@media (max-width: 1024px){:host ::ng-deep aside{height:100%;flex-direction:column;--main-toolbar-height: 0}}:host ::ng-deep aside nav{width:100%}:host ::ng-deep aside ul{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:20px;padding:0rem;margin:37px 0;list-style:none;counter-reset:itemCounter}:host ::ng-deep aside ul li{display:flex;align-items:center;flex-wrap:nowrap;overflow:hidden;max-width:calc(var(--main-aside-width-active) - 15px);width:100%;gap:var(--gap-width, 2.5rem);padding:3px 0 3px 10px;cursor:pointer;color:var(--main-aside-item-fc);border-radius:0;transition:var(--default-transition)}[dir=rtl] :host ::ng-deep aside ul li{padding:3px 10px 3px 0!important}@media (max-width: 1024px){@keyframes liAnimation{0%{transform:translateY(-500px)}to{transform:translateY(0)}}}:host ::ng-deep aside ul li.active,:host ::ng-deep aside ul li:hover{background-color:var(--main-aside-item-bc)}[dir=ltr] :host ::ng-deep aside ul li.active,[dir=ltr] :host ::ng-deep aside ul li:hover{border-left:5px solid var(--coral)}[dir=rtl] :host ::ng-deep aside ul li.active,[dir=rtl] :host ::ng-deep aside ul li:hover{border-right:5px solid var(--coral)}:host ::ng-deep aside ul li .menu-label{font-size:var(--main-aside-item-fs);flex-grow:1;opacity:1;min-width:calc(var(--main-aside-width-active) - 2rem - 40px);display:var(--main-aside-item-display)}:host ::ng-deep aside .header{background-color:#0003!important;padding:15px;flex-direction:row}:host ::ng-deep aside .header div{display:flex;align-items:center;margin-top:auto}:host ::ng-deep aside .footer{margin-top:auto;margin-bottom:80px;padding:0 30px}:host ::ng-deep aside ds-icon{font-size:1.55rem;display:inline-flex;align-items:center;justify-content:center;border-radius:3px;min-width:40px;width:40px;height:40px}:host ::ng-deep ds-button.close::part(base){height:37px;width:37px}:host ::ng-deep ds-button.close ds-icon{font-size:18px;min-width:18px;width:18px;height:18px}:host ::ng-deep .viewAll:hover{background-color:var(--purple)}:host ::ng-deep .viewAll:hover span{color:var(--white)}:host ::ng-deep .justify-content-between{justify-content:space-between}:host ::ng-deep .flex-column{flex-direction:column}:host ::ng-deep .d-flex{display:flex}:host ::ng-deep .w-100{width:100%}:host ::ng-deep .gap-3{gap:1rem!important}:host ::ng-deep ds-button.purple::part(base){--btn-border-color: var(--purple)}:host ::ng-deep ds-button.purple::part(overlay){--btn-overlay-color: var(--purple)}:host ::ng-deep ds-button.secondary::part(base){--btn-border-color: var(--secondary)}:host ::ng-deep ds-button.secondary::part(overlay){--btn-overlay-color: var(--secondary)}@media (min-width: 1024px){:host ::ng-deep .d-md-none{display:none!important}}@media (max-height: 430px){:host ::ng-deep aside .header{margin-bottom:50px}:host ::ng-deep aside nav{padding:15px 0 0;overflow:auto}:host ::ng-deep aside .footer{margin-bottom:20px}}@media (max-height: 300px){:host ::ng-deep aside .header{margin-bottom:5px}}:host ::ng-deep .logo{color:#fff}::ng-deep .aside-menu .mat-mdc-menu-content{border:none;box-shadow:none;padding:0!important}\n"], dependencies: [{ kind: "directive", type: RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: MatMenu, selector: "mat-menu", inputs: ["backdropClass", "aria-label", "aria-labelledby", "aria-describedby", "xPosition", "yPosition", "overlapTrigger", "hasBackdrop", "class", "classList"], outputs: ["closed", "close"], exportAs: ["matMenu"] }, { kind: "directive", type: MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", inputs: ["mat-menu-trigger-for", "matMenuTriggerFor", "matMenuTriggerData", "matMenuTriggerRestoreFocus"], outputs: ["menuOpened", "onMenuOpen", "menuClosed", "onMenuClose"], exportAs: ["matMenuTrigger"] }] });
|
|
148
|
+
}
|
|
149
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: SideNavComponent, decorators: [{
|
|
150
|
+
type: Component,
|
|
151
|
+
args: [{ selector: 'app-side-nav', standalone: true, imports: [RouterLinkActive, RouterLink, MatTooltipModule, MatMenu, MatMenuTrigger], schemas: [CUSTOM_ELEMENTS_SCHEMA], template: "<aside>\r\n <div class=\"header d-flex d-lg-none\">\r\n <div class=\"d-flex h-100 mt-auto justify-content-between w-100\">\r\n <h1 class=\"fs-26 fw-bold fc-white logo\">academy</h1>\r\n <ds-button size=\"small\" color=\"purple\" class=\"close purple\" (click)=\"closeSidenav()\">\r\n <ds-icon icon=\"close\" class=\"fs-15 fc-white\"></ds-icon>\r\n </ds-button>\r\n </div>\r\n </div>\r\n <nav>\r\n <ul>\r\n <!-- (mouseenter)=\"menuMobile ? null : MenuTrigger.openMenu()\"-->\r\n <!-- (click)=\"goto(item.routerLink,item.matmenu) -->\r\n @for (item of Menu; track $index) {\r\n @if (item.matmenu) {\r\n <li\r\n (click)=\"closeSidenav();navigateTo(item)\" matTooltipPosition=\"right\" matTooltip=\"{{item.name }}\"\r\n [routerLinkActive]=\"'active'\" (click)=\"goto(item.routerLink!,item.matmenu)\" #MenuTrigger=\"matMenuTrigger\"\r\n [matMenuTriggerFor]=\"menuMenu\" [routerLinkActiveOptions]=\"{ exact: true }\" class=\"cursor-pointer\">\r\n <ds-icon icon=\"{{item.icon}}\" class=\"icon\"></ds-icon>\r\n <span class=\"menu-label\">\r\n {{ item.name }}\r\n </span>\r\n </li>\r\n <mat-menu #menuMenu=\"matMenu\" class=\"aside-menu visible-{{item.matmenu}}\">\r\n <app-mat-menu [title]=\"item.name \" [icon]=\"item.icon\" [list]=\"item.List\"></app-mat-menu>\r\n </mat-menu>\r\n } @else {\r\n <li\r\n (click)=\"closeSidenav();navigateTo(item)\" matTooltipPosition=\"right\" matTooltip=\"{{item.name }}\"\r\n [routerLinkActive]=\"'active'\" [routerLinkActiveOptions]=\"{ exact: true }\" class=\"cursor-pointer\">\r\n <ds-icon icon=\"{{item.icon}}\" class=\"icon\"></ds-icon>\r\n <span class=\"menu-label\">\r\n {{ item.name }}\r\n </span>\r\n </li>\r\n }\r\n }\r\n </ul>\r\n </nav>\r\n</aside>\r\n", styles: [":host ::ng-deep aside{min-width:var(--main-aside-width);width:var(--main-aside-width);height:calc(100vh - var(--main-toolbar-height));display:flex;position:var(--main-aside-position);right:var(--main-aside-right);left:var(--main-aside-left);top:var(--main-toolbar-height);z-index:var(--main-toolbar-zIndex);background-color:var(--main-aside-bc);transform:var(--main-aside-transform);transition:all .5s cubic-bezier(.685,.0473,.346,1)}@media (max-width: 1024px){:host ::ng-deep aside{height:100%;flex-direction:column;--main-toolbar-height: 0}}:host ::ng-deep aside nav{width:100%}:host ::ng-deep aside ul{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:20px;padding:0rem;margin:37px 0;list-style:none;counter-reset:itemCounter}:host ::ng-deep aside ul li{display:flex;align-items:center;flex-wrap:nowrap;overflow:hidden;max-width:calc(var(--main-aside-width-active) - 15px);width:100%;gap:var(--gap-width, 2.5rem);padding:3px 0 3px 10px;cursor:pointer;color:var(--main-aside-item-fc);border-radius:0;transition:var(--default-transition)}[dir=rtl] :host ::ng-deep aside ul li{padding:3px 10px 3px 0!important}@media (max-width: 1024px){@keyframes liAnimation{0%{transform:translateY(-500px)}to{transform:translateY(0)}}}:host ::ng-deep aside ul li.active,:host ::ng-deep aside ul li:hover{background-color:var(--main-aside-item-bc)}[dir=ltr] :host ::ng-deep aside ul li.active,[dir=ltr] :host ::ng-deep aside ul li:hover{border-left:5px solid var(--coral)}[dir=rtl] :host ::ng-deep aside ul li.active,[dir=rtl] :host ::ng-deep aside ul li:hover{border-right:5px solid var(--coral)}:host ::ng-deep aside ul li .menu-label{font-size:var(--main-aside-item-fs);flex-grow:1;opacity:1;min-width:calc(var(--main-aside-width-active) - 2rem - 40px);display:var(--main-aside-item-display)}:host ::ng-deep aside .header{background-color:#0003!important;padding:15px;flex-direction:row}:host ::ng-deep aside .header div{display:flex;align-items:center;margin-top:auto}:host ::ng-deep aside .footer{margin-top:auto;margin-bottom:80px;padding:0 30px}:host ::ng-deep aside ds-icon{font-size:1.55rem;display:inline-flex;align-items:center;justify-content:center;border-radius:3px;min-width:40px;width:40px;height:40px}:host ::ng-deep ds-button.close::part(base){height:37px;width:37px}:host ::ng-deep ds-button.close ds-icon{font-size:18px;min-width:18px;width:18px;height:18px}:host ::ng-deep .viewAll:hover{background-color:var(--purple)}:host ::ng-deep .viewAll:hover span{color:var(--white)}:host ::ng-deep .justify-content-between{justify-content:space-between}:host ::ng-deep .flex-column{flex-direction:column}:host ::ng-deep .d-flex{display:flex}:host ::ng-deep .w-100{width:100%}:host ::ng-deep .gap-3{gap:1rem!important}:host ::ng-deep ds-button.purple::part(base){--btn-border-color: var(--purple)}:host ::ng-deep ds-button.purple::part(overlay){--btn-overlay-color: var(--purple)}:host ::ng-deep ds-button.secondary::part(base){--btn-border-color: var(--secondary)}:host ::ng-deep ds-button.secondary::part(overlay){--btn-overlay-color: var(--secondary)}@media (min-width: 1024px){:host ::ng-deep .d-md-none{display:none!important}}@media (max-height: 430px){:host ::ng-deep aside .header{margin-bottom:50px}:host ::ng-deep aside nav{padding:15px 0 0;overflow:auto}:host ::ng-deep aside .footer{margin-bottom:20px}}@media (max-height: 300px){:host ::ng-deep aside .header{margin-bottom:5px}}:host ::ng-deep .logo{color:#fff}::ng-deep .aside-menu .mat-mdc-menu-content{border:none;box-shadow:none;padding:0!important}\n"] }]
|
|
152
|
+
}], ctorParameters: () => [{ type: i1.SidenavService }, { type: i2.Router }], propDecorators: { isOpened: [{
|
|
153
|
+
type: Input
|
|
154
|
+
}], MenuTrigger: [{
|
|
155
|
+
type: ViewChild,
|
|
156
|
+
args: ['MenuTrigger']
|
|
157
|
+
}] } });
|
|
158
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-nav.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/layout/side-nav/side-nav.component.ts","../../../../../../../../projects/bpm-core/src/lib/components/app-component-sections/layout/side-nav/side-nav.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, CUSTOM_ELEMENTS_SCHEMA, Input, ViewChild} from '@angular/core';\r\nimport {Router, RouterLink, RouterLinkActive} from '@angular/router';\r\nimport {MatTooltipModule} from '@angular/material/tooltip';\r\nimport {MatMenu, MatMenuTrigger} from '@angular/material/menu';\r\nimport {SidenavService} from '../../../../services';\r\n\r\n@Component({\r\n  selector: 'app-side-nav',\r\n  standalone: true,\r\n  imports: [RouterLinkActive, RouterLink, MatTooltipModule, MatMenu, MatMenuTrigger],\r\n  templateUrl: './side-nav.component.html',\r\n  styleUrl: './side-nav.component.scss',\r\n  schemas: [CUSTOM_ELEMENTS_SCHEMA]\r\n})\r\nexport class SideNavComponent {\r\n\r\n  @Input() isOpened = false;\r\n  lang: any = '';\r\n  Menu = [\r\n    {\r\n      name: 'Home',\r\n      routerLink: '/group/hub/home1',\r\n      icon: 'home-o',\r\n      matmenu: false,\r\n      List: []\r\n    },\r\n    {\r\n      name: 'Inbox',\r\n      routerLink: '/group/hub/inbox',\r\n      icon: 'mail-o',\r\n      matmenu: false,\r\n      List: []\r\n    },\r\n    {\r\n      name: 'Dobox',\r\n      routerLink: '/group/hub/dobox',\r\n      icon: 'chick-sqaure',\r\n      matmenu: false,\r\n      List: []\r\n    },\r\n    {\r\n      name: 'Chat',\r\n      routerLink: '/group/hub/chat',\r\n      icon: 'chat-circle-2',\r\n      matmenu: false,\r\n      List: []\r\n    },\r\n    {\r\n      name: 'Mail',\r\n      routerLink: '/group/hub/mail',\r\n      icon: 'mail-f',\r\n      matmenu: false,\r\n      List: []\r\n    },\r\n    {\r\n      name: 'Meetings',\r\n      routerLink: '/group/hub/meetings',\r\n      icon: 'calendar',\r\n      matmenu: false,\r\n      List: []\r\n    },\r\n    {\r\n      name: 'Offers',\r\n      routerLink: '/group/hub/hub-offers',\r\n      icon: 'voucher',\r\n      matmenu: false,\r\n      List: []\r\n    },\r\n    {\r\n      name: 'stc today',\r\n      routerLink: '/group/hub/stc-profile',\r\n      icon: 'stc-profile-o',\r\n      matmenu: false,\r\n      List: []\r\n    },\r\n    {\r\n      name: 'Articles',\r\n      routerLink: '/group/hub/articles',\r\n      icon: 'file-returned',\r\n      matmenu: false,\r\n      List: []\r\n    },\r\n    {\r\n      name: 'Timeline',\r\n      routerLink: '/group/hub/timeline',\r\n      icon: 'list-dots',\r\n      matmenu: false,\r\n      List: []\r\n    },\r\n    {\r\n      name: 'eforms',\r\n      routerLink: '/group/hub/efroms',\r\n      icon: 'file-o',\r\n      matmenu: false,\r\n      List: []\r\n    },\r\n    {\r\n      name: 'Apps',\r\n      routerLink: '/group/hub/apps',\r\n      icon: 'card',\r\n      matmenu: false,\r\n      List: []\r\n    },\r\n  ];\r\n\r\n  constructor(public sidenavService: SidenavService, private router: Router) {}\r\n\r\n\r\n  closeSidenav() {\r\n    document.documentElement.classList.remove('main-sidenav-opened');\r\n    // this.sidenavService.sideNavOpened.next(false);\r\n  }\r\n\r\n  navigateTo(item: any) {\r\n    window.location.href = item.routerLink;\r\n  }\r\n\r\n  innerWidth: any;\r\n  menuMobile!: boolean;\r\n  @ViewChild('MenuTrigger') MenuTrigger!: MatMenuTrigger;\r\n\r\n  ngOnInit() {\r\n    this.innerWidth = window.innerWidth;\r\n    if (this.innerWidth < 1024) {\r\n      this.menuMobile = true;\r\n    } else {\r\n      this.menuMobile = false;\r\n    }\r\n  }\r\n\r\n  mouseover(matmenu: boolean, i: number) {\r\n    if (!this.menuMobile) {\r\n      if (matmenu) {\r\n        document.documentElement.classList.remove('main-overlay-closed');\r\n        // this.MenuTrigger[i].openMenu();\r\n      } else {\r\n        document.documentElement.classList.add('main-overlay-closed');\r\n        // this.MenuTrigger[i].closeMenu();\r\n      }\r\n    }\r\n  }\r\n\r\n  goto(url?: string, matmenu?: boolean) {\r\n    if (!this.menuMobile) {\r\n      if (matmenu) {\r\n        document.documentElement.classList.remove('main-overlay-closed');\r\n      } else {\r\n        document.documentElement.classList.add('main-overlay-closed');\r\n      }\r\n    }\r\n    this.router.navigate([url]);\r\n  }\r\n}\r\n","<aside>\r\n  <div class=\"header d-flex d-lg-none\">\r\n    <div class=\"d-flex h-100 mt-auto justify-content-between w-100\">\r\n      <h1 class=\"fs-26 fw-bold fc-white logo\">academy</h1>\r\n      <ds-button size=\"small\" color=\"purple\" class=\"close purple\" (click)=\"closeSidenav()\">\r\n        <ds-icon icon=\"close\" class=\"fs-15 fc-white\"></ds-icon>\r\n      </ds-button>\r\n    </div>\r\n  </div>\r\n  <nav>\r\n    <ul>\r\n      <!--  (mouseenter)=\"menuMobile ? null : MenuTrigger.openMenu()\"-->\r\n      <!-- (click)=\"goto(item.routerLink,item.matmenu) -->\r\n      @for (item of Menu; track $index) {\r\n        @if (item.matmenu) {\r\n          <li\r\n            (click)=\"closeSidenav();navigateTo(item)\"  matTooltipPosition=\"right\" matTooltip=\"{{item.name }}\"\r\n            [routerLinkActive]=\"'active'\" (click)=\"goto(item.routerLink!,item.matmenu)\" #MenuTrigger=\"matMenuTrigger\"\r\n            [matMenuTriggerFor]=\"menuMenu\" [routerLinkActiveOptions]=\"{ exact: true }\" class=\"cursor-pointer\">\r\n            <ds-icon icon=\"{{item.icon}}\" class=\"icon\"></ds-icon>\r\n            <span class=\"menu-label\">\r\n              {{ item.name }}\r\n            </span>\r\n          </li>\r\n          <mat-menu #menuMenu=\"matMenu\" class=\"aside-menu  visible-{{item.matmenu}}\">\r\n            <app-mat-menu [title]=\"item.name \" [icon]=\"item.icon\" [list]=\"item.List\"></app-mat-menu>\r\n          </mat-menu>\r\n        } @else {\r\n          <li\r\n            (click)=\"closeSidenav();navigateTo(item)\"  matTooltipPosition=\"right\" matTooltip=\"{{item.name }}\"\r\n            [routerLinkActive]=\"'active'\" [routerLinkActiveOptions]=\"{ exact: true }\" class=\"cursor-pointer\">\r\n            <ds-icon icon=\"{{item.icon}}\" class=\"icon\"></ds-icon>\r\n            <span class=\"menu-label\">\r\n              {{ item.name }}\r\n            </span>\r\n          </li>\r\n        }\r\n      }\r\n    </ul>\r\n  </nav>\r\n</aside>\r\n"]}
|