@esfaenza/core 15.2.42-beta1 → 15.2.42-beta2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +24 -24
- package/components/components.module.d.ts +22 -16
- package/components/{sidebar → page-structure/sidebar}/sidebar.component.d.ts +1 -0
- package/components/public-api.d.ts +20 -15
- package/components/search/es-filters/es-filters.component.d.ts +27 -0
- package/components/search/es-filters/es-filters.service.d.ts +6 -0
- package/components/search/filters-sidebar/filters-sidebar.component.d.ts +20 -0
- package/components/search/filters-sidebar-item/filters-sidebar-item.component.d.ts +16 -0
- package/components/search/filters-sidebar-section/filters-sidebar-section.component.d.ts +9 -0
- package/components/search/filters-topbar/filters-topbar.component.d.ts +38 -0
- package/domain/models/decorators/decorators.d.ts +1 -0
- package/domain/models/user/ChangePasswordDto.d.ts +9 -0
- package/domain/models/user/ChangeProfilePictureDto.d.ts +4 -0
- package/domain/models/user/UpdateAccountRecoverySettingsDto.d.ts +6 -0
- package/domain/public-api.d.ts +4 -0
- package/esm2020/components/components.module.mjs +76 -22
- package/esm2020/components/es-modal/es-modal-head/es-modal-head.component.mjs +4 -4
- package/esm2020/components/es-modal/es-modal.component.mjs +4 -4
- package/esm2020/components/page-structure/back-top/back-top.component.mjs +43 -0
- package/esm2020/components/page-structure/base/base.component.mjs +55 -0
- package/esm2020/components/page-structure/base/reactive.component.mjs +26 -0
- package/esm2020/components/page-structure/breadcrumb/breadcrumb.component.mjs +70 -0
- package/esm2020/components/page-structure/error/404/pagenotfound.component.mjs +30 -0
- package/esm2020/components/page-structure/error/500/servererror.component.mjs +39 -0
- package/esm2020/components/page-structure/error/Angular/angularerror.component.mjs +55 -0
- package/esm2020/components/page-structure/external-page/external_pages.component.mjs +47 -0
- package/esm2020/components/page-structure/jace-login/jace-login.component.mjs +18 -0
- package/esm2020/components/page-structure/jace-resource/jace-resource.component.mjs +65 -0
- package/esm2020/components/page-structure/navbar/modules-board/jace-modules-board.component.mjs +40 -0
- package/esm2020/components/page-structure/navbar/navbar.component.loc.mjs +36 -0
- package/esm2020/components/page-structure/navbar/navbar.component.mjs +161 -0
- package/esm2020/components/page-structure/page/pages.component.mjs +60 -0
- package/esm2020/components/page-structure/redirecter/redirecter.component.mjs +53 -0
- package/esm2020/components/page-structure/sidebar/sidebar.component.mjs +302 -0
- package/esm2020/components/public-api.mjs +21 -16
- package/esm2020/components/search/es-filters/es-filters.component.mjs +56 -0
- package/esm2020/components/search/es-filters/es-filters.service.mjs +19 -0
- package/esm2020/components/search/filters-sidebar/filters-sidebar.component.mjs +65 -0
- package/esm2020/components/search/filters-sidebar-item/filters-sidebar-item.component.mjs +39 -0
- package/esm2020/components/search/filters-sidebar-section/filters-sidebar-section.component.mjs +22 -0
- package/esm2020/components/search/filters-topbar/filters-topbar.component.mjs +94 -0
- package/esm2020/directives/componentHost/componentHost.directive.mjs +4 -4
- package/esm2020/directives/directives.module.mjs +5 -5
- package/esm2020/directives/draggable/draggable.directive.mjs +4 -4
- package/esm2020/directives/es-modal/es-modal.directive.mjs +4 -4
- package/esm2020/directives/es-routerLink/es-routerLink.directive.mjs +4 -4
- package/esm2020/directives/slim-scroll/slim-scroll.directive.mjs +4 -4
- package/esm2020/directives/widget/widget.directive.mjs +4 -4
- package/esm2020/domain/models/decorators/decorators.mjs +6 -0
- package/esm2020/domain/models/user/ChangePasswordDto.mjs +11 -0
- package/esm2020/domain/models/user/ChangeProfilePictureDto.mjs +6 -0
- package/esm2020/domain/models/user/UpdateAccountRecoverySettingsDto.mjs +8 -0
- package/esm2020/domain/public-api.mjs +5 -1
- package/esm2020/lib/app.component.mjs +5 -5
- package/esm2020/lib/core.module.mjs +5 -5
- package/esm2020/modules/classes/_shared.module.mjs +5 -5
- package/esm2020/modules/classes/t_c.module.mjs +5 -5
- package/esm2020/pipes/classes/included_in.pipe.mjs +4 -4
- package/esm2020/pipes/classes/safe_html.pipe.mjs +4 -4
- package/esm2020/pipes/classes/safe_script.pipe.mjs +4 -4
- package/esm2020/pipes/classes/safe_style.pipe.mjs +4 -4
- package/esm2020/pipes/classes/safe_url.pipe.mjs +4 -4
- package/esm2020/pipes/pipes.module.mjs +5 -5
- package/esm2020/public-api.mjs +1 -1
- package/esm2020/services/classes/app.accesstoken.mjs +4 -4
- package/esm2020/services/classes/app.completedjobredirection.mjs +4 -4
- package/esm2020/services/classes/app.errorhandler.mjs +4 -4
- package/esm2020/services/classes/app.event.mjs +4 -4
- package/esm2020/services/classes/app.globalsearch.mjs +4 -4
- package/esm2020/services/classes/app.httpextensions.loc.mjs +4 -4
- package/esm2020/services/classes/app.httpextensions.mjs +4 -4
- package/esm2020/services/classes/app.menufilter.mjs +4 -4
- package/esm2020/services/classes/app.routeguard.mjs +4 -4
- package/esm2020/services/classes/app.session.mjs +4 -4
- package/esm2020/services/classes/app.state.mjs +4 -4
- package/esm2020/services/classes/preferences/app.cache.persistor.mjs +4 -4
- package/esm2020/services/classes/preferences/app.preference.persistor.mjs +4 -4
- package/esm2020/services/classes/preferences/user/app.userpreferences.base.mjs +76 -0
- package/esm2020/services/public-api.mjs +2 -1
- package/fesm2015/esfaenza-core-components.mjs +413 -82
- package/fesm2015/esfaenza-core-components.mjs.map +1 -1
- package/fesm2015/esfaenza-core-directives.mjs +22 -22
- package/fesm2015/esfaenza-core-directives.mjs.map +1 -1
- package/fesm2015/esfaenza-core-domain.mjs +32 -1
- package/fesm2015/esfaenza-core-domain.mjs.map +1 -1
- package/fesm2015/esfaenza-core-modules.mjs +8 -8
- package/fesm2015/esfaenza-core-modules.mjs.map +1 -1
- package/fesm2015/esfaenza-core-pipes.mjs +19 -19
- package/fesm2015/esfaenza-core-pipes.mjs.map +1 -1
- package/fesm2015/esfaenza-core-services.mjs +124 -44
- package/fesm2015/esfaenza-core-services.mjs.map +1 -1
- package/fesm2015/esfaenza-core.mjs +8 -8
- package/fesm2015/esfaenza-core.mjs.map +1 -1
- package/fesm2020/esfaenza-core-components.mjs +410 -82
- package/fesm2020/esfaenza-core-components.mjs.map +1 -1
- package/fesm2020/esfaenza-core-directives.mjs +22 -22
- package/fesm2020/esfaenza-core-directives.mjs.map +1 -1
- package/fesm2020/esfaenza-core-domain.mjs +32 -1
- package/fesm2020/esfaenza-core-domain.mjs.map +1 -1
- package/fesm2020/esfaenza-core-modules.mjs +8 -8
- package/fesm2020/esfaenza-core-modules.mjs.map +1 -1
- package/fesm2020/esfaenza-core-pipes.mjs +19 -19
- package/fesm2020/esfaenza-core-pipes.mjs.map +1 -1
- package/fesm2020/esfaenza-core-services.mjs +111 -44
- package/fesm2020/esfaenza-core-services.mjs.map +1 -1
- package/fesm2020/esfaenza-core.mjs +8 -8
- package/fesm2020/esfaenza-core.mjs.map +1 -1
- package/lib/core.module.d.ts +2 -1
- package/package.json +1 -1
- package/services/classes/preferences/user/app.userpreferences.base.d.ts +23 -0
- package/services/public-api.d.ts +1 -0
- package/theme/styles/_project-override.scss +63 -1
- package/theme/styles/_variables.scss +1 -1
- package/theme/styles/skins/enuma.scss +1 -0
- package/theme/styles/skins/jace.scss +63 -0
- package/esm2020/components/back-top/back-top.component.mjs +0 -43
- package/esm2020/components/base/base.component.mjs +0 -55
- package/esm2020/components/base/reactive.component.mjs +0 -26
- package/esm2020/components/breadcrumb/breadcrumb.component.mjs +0 -70
- package/esm2020/components/error/404/pagenotfound.component.mjs +0 -30
- package/esm2020/components/error/500/servererror.component.mjs +0 -39
- package/esm2020/components/error/Angular/angularerror.component.mjs +0 -55
- package/esm2020/components/external-page/external_pages.component.mjs +0 -47
- package/esm2020/components/jace-login/jace-login.component.mjs +0 -18
- package/esm2020/components/jace-resource/jace-resource.component.mjs +0 -65
- package/esm2020/components/navbar/modules-board/jace-modules-board.component.mjs +0 -40
- package/esm2020/components/navbar/navbar.component.loc.mjs +0 -36
- package/esm2020/components/navbar/navbar.component.mjs +0 -161
- package/esm2020/components/page/pages.component.mjs +0 -60
- package/esm2020/components/redirecter/redirecter.component.mjs +0 -53
- package/esm2020/components/sidebar/sidebar.component.mjs +0 -293
- /package/components/{back-top → page-structure/back-top}/back-top.component.d.ts +0 -0
- /package/components/{base → page-structure/base}/base.component.d.ts +0 -0
- /package/components/{base → page-structure/base}/reactive.component.d.ts +0 -0
- /package/components/{breadcrumb → page-structure/breadcrumb}/breadcrumb.component.d.ts +0 -0
- /package/components/{error → page-structure/error}/404/pagenotfound.component.d.ts +0 -0
- /package/components/{error → page-structure/error}/500/servererror.component.d.ts +0 -0
- /package/components/{error → page-structure/error}/Angular/angularerror.component.d.ts +0 -0
- /package/components/{external-page → page-structure/external-page}/external_pages.component.d.ts +0 -0
- /package/components/{jace-login → page-structure/jace-login}/jace-login.component.d.ts +0 -0
- /package/components/{jace-resource → page-structure/jace-resource}/jace-resource.component.d.ts +0 -0
- /package/components/{navbar → page-structure/navbar}/modules-board/jace-modules-board.component.d.ts +0 -0
- /package/components/{navbar → page-structure/navbar}/navbar.component.d.ts +0 -0
- /package/components/{navbar → page-structure/navbar}/navbar.component.loc.d.ts +0 -0
- /package/components/{page → page-structure/page}/pages.component.d.ts +0 -0
- /package/components/{redirecter → page-structure/redirecter}/redirecter.component.d.ts +0 -0
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
// Angular
|
|
2
|
+
import { Component, Inject, Optional, ViewEncapsulation } from "@angular/core";
|
|
3
|
+
import { NgIf } from "@angular/common";
|
|
4
|
+
// Applicazione
|
|
5
|
+
import { REDIRECT_MAP } from "@esfaenza/core/domain";
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@esfaenza/core/services";
|
|
8
|
+
import * as i2 from "@angular/router";
|
|
9
|
+
// TODO: loc.ts
|
|
10
|
+
export class RedirecterComponent {
|
|
11
|
+
constructor(_state, route, router, redirectMap) {
|
|
12
|
+
this._state = _state;
|
|
13
|
+
this.route = route;
|
|
14
|
+
this.router = router;
|
|
15
|
+
this.redirectMap = redirectMap;
|
|
16
|
+
this.Error = "";
|
|
17
|
+
}
|
|
18
|
+
ngOnInit() {
|
|
19
|
+
let url = this.route.snapshot.params["url"];
|
|
20
|
+
//§ = 167... non so perché ma scrivendolo esplicitamente non funziona
|
|
21
|
+
let parts = url.split(String.fromCharCode(167)).filter(s => !!s);
|
|
22
|
+
if (parts.length < 2) {
|
|
23
|
+
this.Error = "L'url passato è incompleto. Impossibile riconoscerlo";
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
else {
|
|
27
|
+
var redirect = this.redirectMap[parts[0]];
|
|
28
|
+
if (!redirect) {
|
|
29
|
+
this.Error = "L'url passato fa riferimento a un oggetto non navigabile. Impossibile procedere";
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
if (redirect.params.length != parts.length - 1) {
|
|
33
|
+
this.Error = "Il numero di parametri richiesti per navigare all'entità richiesta è diverso dal numero di parametri passato";
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
let parObject = {};
|
|
37
|
+
redirect.params.forEach((t, i) => parObject[t] = parts[i + 1]);
|
|
38
|
+
this.router.navigate(["pages/" + redirect.url, parObject]);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
RedirecterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: RedirecterComponent, deps: [{ token: i1.AppState }, { token: i2.ActivatedRoute }, { token: i2.Router }, { token: REDIRECT_MAP, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
43
|
+
RedirecterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: RedirecterComponent, isStandalone: true, selector: "redirecter", ngImport: i0, template: "<div *ngIf=\"Error\">{{Error}}</div>", dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
44
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: RedirecterComponent, decorators: [{
|
|
45
|
+
type: Component,
|
|
46
|
+
args: [{ selector: "redirecter", encapsulation: ViewEncapsulation.None, standalone: true, imports: [NgIf], template: "<div *ngIf=\"Error\">{{Error}}</div>" }]
|
|
47
|
+
}], ctorParameters: function () { return [{ type: i1.AppState }, { type: i2.ActivatedRoute }, { type: i2.Router }, { type: undefined, decorators: [{
|
|
48
|
+
type: Optional
|
|
49
|
+
}, {
|
|
50
|
+
type: Inject,
|
|
51
|
+
args: [REDIRECT_MAP]
|
|
52
|
+
}] }]; } });
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVkaXJlY3Rlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvc3JjL3BhZ2Utc3RydWN0dXJlL3JlZGlyZWN0ZXIvcmVkaXJlY3Rlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvc3JjL3BhZ2Utc3RydWN0dXJlL3JlZGlyZWN0ZXIvcmVkaXJlY3Rlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxVQUFVO0FBQ1YsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRS9FLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUt2QyxlQUFlO0FBQ2YsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHVCQUF1QixDQUFDOzs7O0FBRXJELGVBQWU7QUFRZixNQUFNLE9BQU8sbUJBQW1CO0lBSTVCLFlBQW1CLE1BQWdCLEVBQVUsS0FBcUIsRUFBUyxNQUFjLEVBQTRDLFdBQW1FO1FBQXJMLFdBQU0sR0FBTixNQUFNLENBQVU7UUFBVSxVQUFLLEdBQUwsS0FBSyxDQUFnQjtRQUFTLFdBQU0sR0FBTixNQUFNLENBQVE7UUFBNEMsZ0JBQVcsR0FBWCxXQUFXLENBQXdEO1FBRmpNLFVBQUssR0FBVyxFQUFFLENBQUM7SUFFa0wsQ0FBQztJQUU3TSxRQUFRO1FBQ0osSUFBSSxHQUFHLEdBQVcsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3BELHFFQUFxRTtRQUNyRSxJQUFJLEtBQUssR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxZQUFZLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFFakUsSUFBSSxLQUFLLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtZQUNsQixJQUFJLENBQUMsS0FBSyxHQUFHLHNEQUFzRCxDQUFDO1lBQ3BFLE9BQU87U0FDVjthQUNJO1lBQ0QsSUFBSSxRQUFRLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUMxQyxJQUFJLENBQUMsUUFBUSxFQUFFO2dCQUNYLElBQUksQ0FBQyxLQUFLLEdBQUcsaUZBQWlGLENBQUM7Z0JBQy9GLE9BQU87YUFDVjtZQUVELElBQUksUUFBUSxDQUFDLE1BQU0sQ0FBQyxNQUFNLElBQUksS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7Z0JBQzVDLElBQUksQ0FBQyxLQUFLLEdBQUcsOEdBQThHLENBQUM7Z0JBQzVILE9BQU87YUFDVjtZQUVELElBQUksU0FBUyxHQUFHLEVBQUUsQ0FBQztZQUNuQixRQUFRLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsR0FBRyxLQUFLLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDL0QsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUFDO1NBQzlEO0lBQ0wsQ0FBQzs7Z0hBL0JRLG1CQUFtQiw4RkFJbUYsWUFBWTtvR0FKbEgsbUJBQW1CLHNFQ25CaEMsc0NBQWtDLDRDRGlCcEIsSUFBSTsyRkFFTCxtQkFBbUI7a0JBUC9CLFNBQVM7K0JBQ0ksWUFBWSxpQkFDUCxpQkFBaUIsQ0FBQyxJQUFJLGNBRXpCLElBQUksV0FDUCxDQUFDLElBQUksQ0FBQzs7MEJBTTZFLFFBQVE7OzBCQUFJLE1BQU07MkJBQUMsWUFBWSIsInNvdXJjZXNDb250ZW50IjpbIi8vIEFuZ3VsYXJcclxuaW1wb3J0IHsgQ29tcG9uZW50LCBJbmplY3QsIE9wdGlvbmFsLCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IEFjdGl2YXRlZFJvdXRlLCBSb3V0ZXIgfSBmcm9tIFwiQGFuZ3VsYXIvcm91dGVyXCI7XHJcbmltcG9ydCB7IE5nSWYgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XHJcblxyXG4vLyBDb25maWd1cmF6aW9uaVxyXG5pbXBvcnQgeyBBcHBTdGF0ZSB9IGZyb20gXCJAZXNmYWVuemEvY29yZS9zZXJ2aWNlc1wiO1xyXG5cclxuLy8gQXBwbGljYXppb25lXHJcbmltcG9ydCB7IFJFRElSRUNUX01BUCB9IGZyb20gXCJAZXNmYWVuemEvY29yZS9kb21haW5cIjtcclxuXHJcbi8vIFRPRE86IGxvYy50c1xyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiBcInJlZGlyZWN0ZXJcIixcclxuICAgIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXHJcbiAgICB0ZW1wbGF0ZVVybDogXCIuL3JlZGlyZWN0ZXIuY29tcG9uZW50Lmh0bWxcIixcclxuICAgIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgICBpbXBvcnRzOiBbTmdJZl1cclxufSlcclxuZXhwb3J0IGNsYXNzIFJlZGlyZWN0ZXJDb21wb25lbnQge1xyXG5cclxuICAgIHB1YmxpYyBFcnJvcjogc3RyaW5nID0gXCJcIjtcclxuXHJcbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgX3N0YXRlOiBBcHBTdGF0ZSwgcHJpdmF0ZSByb3V0ZTogQWN0aXZhdGVkUm91dGUsIHB1YmxpYyByb3V0ZXI6IFJvdXRlciwgQE9wdGlvbmFsKCkgQEluamVjdChSRURJUkVDVF9NQVApIHByaXZhdGUgcmVkaXJlY3RNYXA6IHsgW2luZGV4OiBzdHJpbmddOiB7IHVybDogc3RyaW5nLCBwYXJhbXM6IHN0cmluZ1tdIH0gfSkgeyB9XHJcblxyXG4gICAgbmdPbkluaXQoKSB7XHJcbiAgICAgICAgbGV0IHVybDogc3RyaW5nID0gdGhpcy5yb3V0ZS5zbmFwc2hvdC5wYXJhbXNbXCJ1cmxcIl07XHJcbiAgICAgICAgLy/CpyA9IDE2Ny4uLiBub24gc28gcGVyY2jDqSBtYSBzY3JpdmVuZG9sbyBlc3BsaWNpdGFtZW50ZSBub24gZnVuemlvbmFcclxuICAgICAgICBsZXQgcGFydHMgPSB1cmwuc3BsaXQoU3RyaW5nLmZyb21DaGFyQ29kZSgxNjcpKS5maWx0ZXIocyA9PiAhIXMpO1xyXG5cclxuICAgICAgICBpZiAocGFydHMubGVuZ3RoIDwgMikge1xyXG4gICAgICAgICAgICB0aGlzLkVycm9yID0gXCJMJ3VybCBwYXNzYXRvIMOoIGluY29tcGxldG8uIEltcG9zc2liaWxlIHJpY29ub3NjZXJsb1wiO1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGVsc2Uge1xyXG4gICAgICAgICAgICB2YXIgcmVkaXJlY3QgPSB0aGlzLnJlZGlyZWN0TWFwW3BhcnRzWzBdXTtcclxuICAgICAgICAgICAgaWYgKCFyZWRpcmVjdCkge1xyXG4gICAgICAgICAgICAgICAgdGhpcy5FcnJvciA9IFwiTCd1cmwgcGFzc2F0byBmYSByaWZlcmltZW50byBhIHVuIG9nZ2V0dG8gbm9uIG5hdmlnYWJpbGUuIEltcG9zc2liaWxlIHByb2NlZGVyZVwiO1xyXG4gICAgICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgICAgICB9XHJcblxyXG4gICAgICAgICAgICBpZiAocmVkaXJlY3QucGFyYW1zLmxlbmd0aCAhPSBwYXJ0cy5sZW5ndGggLSAxKSB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLkVycm9yID0gXCJJbCBudW1lcm8gZGkgcGFyYW1ldHJpIHJpY2hpZXN0aSBwZXIgbmF2aWdhcmUgYWxsJ2VudGl0w6AgcmljaGllc3RhIMOoIGRpdmVyc28gZGFsIG51bWVybyBkaSBwYXJhbWV0cmkgcGFzc2F0b1wiO1xyXG4gICAgICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgICAgICB9XHJcblxyXG4gICAgICAgICAgICBsZXQgcGFyT2JqZWN0ID0ge307XHJcbiAgICAgICAgICAgIHJlZGlyZWN0LnBhcmFtcy5mb3JFYWNoKCh0LCBpKSA9PiBwYXJPYmplY3RbdF0gPSBwYXJ0c1tpICsgMV0pO1xyXG4gICAgICAgICAgICB0aGlzLnJvdXRlci5uYXZpZ2F0ZShbXCJwYWdlcy9cIiArIHJlZGlyZWN0LnVybCwgcGFyT2JqZWN0XSk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG59IiwiPGRpdiAqbmdJZj1cIkVycm9yXCI+e3tFcnJvcn19PC9kaXY+Il19
|
|
@@ -0,0 +1,302 @@
|
|
|
1
|
+
// Angular
|
|
2
|
+
import { ChangeDetectionStrategy, Component, HostListener, Inject, Optional, ViewChild, ViewEncapsulation } from "@angular/core";
|
|
3
|
+
import { NavigationEnd, RouterLinkActive, RouterLink } from "@angular/router";
|
|
4
|
+
import { NgClass, NgFor, NgTemplateOutlet, NgIf } from "@angular/common";
|
|
5
|
+
// Configurazioni
|
|
6
|
+
import { LocalizationModule } from "@esfaenza/localizations";
|
|
7
|
+
// EsFaenza
|
|
8
|
+
import { MENU, MENU_LOCALIZATION } from "@esfaenza/core/domain";
|
|
9
|
+
import { SlimScroll } from "@esfaenza/core/directives";
|
|
10
|
+
// Librerie
|
|
11
|
+
import { firstValueFrom } from "rxjs";
|
|
12
|
+
import { HttpParams } from "@angular/common/http";
|
|
13
|
+
import { EsTableColumnsDefinition, EsTableModule } from "@esfaenza/es-table";
|
|
14
|
+
import { FormsModule } from "@angular/forms";
|
|
15
|
+
import * as i0 from "@angular/core";
|
|
16
|
+
import * as i1 from "@esfaenza/localizations";
|
|
17
|
+
import * as i2 from "@angular/router";
|
|
18
|
+
import * as i3 from "@esfaenza/core/services";
|
|
19
|
+
import * as i4 from "@esfaenza/extensions";
|
|
20
|
+
import * as i5 from "@esfaenza/access-control";
|
|
21
|
+
import * as i6 from "@esfaenza/httpservice";
|
|
22
|
+
import * as i7 from "@esfaenza/es-table";
|
|
23
|
+
import * as i8 from "@angular/forms";
|
|
24
|
+
// Chiamate ai Repository
|
|
25
|
+
const GET_Users_GetProfilePicture = "/api/Users/GetProfilePicture";
|
|
26
|
+
export class Sidebar {
|
|
27
|
+
constructor(lc, lcMenu, cdr, _elementRef, _router, _state, zone, utiExts, aac, menuItemsRaw, menuFilteringService, sr, https, msgs, globalSearchService) {
|
|
28
|
+
this.lc = lc;
|
|
29
|
+
this.cdr = cdr;
|
|
30
|
+
this._elementRef = _elementRef;
|
|
31
|
+
this._router = _router;
|
|
32
|
+
this._state = _state;
|
|
33
|
+
this.zone = zone;
|
|
34
|
+
this.utiExts = utiExts;
|
|
35
|
+
this.aac = aac;
|
|
36
|
+
this.menuItemsRaw = menuItemsRaw;
|
|
37
|
+
this.menuFilteringService = menuFilteringService;
|
|
38
|
+
this.sr = sr;
|
|
39
|
+
this.https = https;
|
|
40
|
+
this.msgs = msgs;
|
|
41
|
+
this.globalSearchService = globalSearchService;
|
|
42
|
+
this.isMenuCollapsed = false;
|
|
43
|
+
this.isMenuShouldCollapsed = false;
|
|
44
|
+
this.applicationVersion = myconfig.AppData.ComponentVersion;
|
|
45
|
+
this.applicationName = myconfig.AppData.ModuleDescription;
|
|
46
|
+
this.user = "";
|
|
47
|
+
this.tenant = "";
|
|
48
|
+
this.SearchModel = "";
|
|
49
|
+
// TODO: Salvare dentro una service preferenze account
|
|
50
|
+
this.safeprofilepic = null;
|
|
51
|
+
// ***************************************** Gestione Ricerca Globale *****************************************
|
|
52
|
+
this.SelectedResult = null;
|
|
53
|
+
this.ShowSingleTable = false;
|
|
54
|
+
this.searchingTerm = false;
|
|
55
|
+
this.lc = this.lc.generateFromType(lcMenu);
|
|
56
|
+
this._state.subscribe("menu.isCollapsed", (isCollapsed) => {
|
|
57
|
+
this.isMenuCollapsed = isCollapsed;
|
|
58
|
+
this.cdr.markForCheck();
|
|
59
|
+
});
|
|
60
|
+
this._state.subscribe("application.DeployAvailable", (available) => {
|
|
61
|
+
if (available)
|
|
62
|
+
this.ngOnInit();
|
|
63
|
+
});
|
|
64
|
+
this._router.events.subscribe(event => {
|
|
65
|
+
if (event instanceof NavigationEnd) {
|
|
66
|
+
let width = (window.innerWidth > 0) ? window.innerWidth : screen.width;
|
|
67
|
+
if (width <= 768)
|
|
68
|
+
this._state.notifyDataChanged("menu.isCollapsed", true);
|
|
69
|
+
window.scrollTo(0, 0);
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
this.getUserProfileData();
|
|
73
|
+
}
|
|
74
|
+
async ngOnInit() {
|
|
75
|
+
let tmpMenuItems = this.getMenuItems();
|
|
76
|
+
this.menuItems = await firstValueFrom(this.menuFilteringService.filter(tmpMenuItems));
|
|
77
|
+
if (this._shouldMenuCollapse())
|
|
78
|
+
this.menuCollapse();
|
|
79
|
+
this.updateSidebarHeight();
|
|
80
|
+
this._state.setSidebarWidth(this.sidebar.nativeElement.offsetWidth);
|
|
81
|
+
this.cdr.markForCheck();
|
|
82
|
+
}
|
|
83
|
+
getMenuItems() {
|
|
84
|
+
var items = [];
|
|
85
|
+
for (let i = 0; i < this.menuItemsRaw.length; i++) {
|
|
86
|
+
let t = this.menuItemsRaw[i];
|
|
87
|
+
t.level = 1;
|
|
88
|
+
if (!t.ac || this.aac.has(t.ac)) {
|
|
89
|
+
if (!t.subMenu || t.subMenu.length == 0) {
|
|
90
|
+
t.icon = t.icon ?? "far fa-circle-small";
|
|
91
|
+
items.push(t);
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
var toPush = this.checkSubMenuOverClaims(t, 1);
|
|
95
|
+
toPush.icon = toPush.icon ?? "far fa-circle-small";
|
|
96
|
+
items.push(toPush);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
return items;
|
|
101
|
+
}
|
|
102
|
+
checkSubMenuOverClaims(menuItem, level) {
|
|
103
|
+
var item = this.utiExts.deepClone(menuItem);
|
|
104
|
+
item.subMenu = [];
|
|
105
|
+
for (let i = 0; i < menuItem.subMenu.length; i++) {
|
|
106
|
+
let t = menuItem.subMenu[i];
|
|
107
|
+
t.level = level + 1;
|
|
108
|
+
if (!t.ac || this.aac.has(t.ac)) {
|
|
109
|
+
if (!t.subMenu || t.subMenu.length == 0) {
|
|
110
|
+
t.icon = t.icon ?? "far fa-circle-small";
|
|
111
|
+
item.subMenu.push(t);
|
|
112
|
+
}
|
|
113
|
+
else {
|
|
114
|
+
var toPush = this.checkSubMenuOverClaims(t, level + 1);
|
|
115
|
+
toPush.icon = toPush.icon ?? "far fa-circle-small";
|
|
116
|
+
item.subMenu.push(toPush);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
// Calcolo qui per non doverlo calcolare lato HTML
|
|
120
|
+
t.padding_left = level > 2 ? (65 + ((level - 3) * 15) + 'px !important') : null;
|
|
121
|
+
}
|
|
122
|
+
return item;
|
|
123
|
+
}
|
|
124
|
+
//#region JQuery
|
|
125
|
+
onWindowResize() {
|
|
126
|
+
var isMenuShouldCollapsed = this._shouldMenuCollapse();
|
|
127
|
+
if (this.isMenuShouldCollapsed !== isMenuShouldCollapsed) {
|
|
128
|
+
this.menuCollapseStateChange(isMenuShouldCollapsed);
|
|
129
|
+
}
|
|
130
|
+
this.isMenuShouldCollapsed = isMenuShouldCollapsed;
|
|
131
|
+
this.updateSidebarHeight();
|
|
132
|
+
}
|
|
133
|
+
_shouldMenuCollapse() {
|
|
134
|
+
return window.innerWidth <= 768;
|
|
135
|
+
}
|
|
136
|
+
menuCollapse() {
|
|
137
|
+
this.menuCollapseStateChange(true);
|
|
138
|
+
this._state.setSidebarWidth(this.sidebar.nativeElement.offsetWidth);
|
|
139
|
+
}
|
|
140
|
+
menuCollapseStateChange(isCollapsed) {
|
|
141
|
+
this.isMenuCollapsed = isCollapsed;
|
|
142
|
+
this._state.notifyDataChanged("menu.isCollapsed", this.isMenuCollapsed);
|
|
143
|
+
}
|
|
144
|
+
menuExpand() {
|
|
145
|
+
this.menuCollapseStateChange(false);
|
|
146
|
+
this._state.setSidebarWidth(this.sidebar.nativeElement.offsetWidth);
|
|
147
|
+
}
|
|
148
|
+
hoverItem(jQueryevent) {
|
|
149
|
+
if (!this.isMenuCollapsed) {
|
|
150
|
+
this.showHoverElem = true;
|
|
151
|
+
this.hoverElemHeight = jQueryevent.currentTarget.clientHeight;
|
|
152
|
+
this.hoverElemTop = jQueryevent.currentTarget.getBoundingClientRect().top;
|
|
153
|
+
jQuery(".sidebar-hover-elem").css("top", this.hoverElemTop + "px");
|
|
154
|
+
jQuery(".sidebar-hover-elem").css("height", this.hoverElemHeight + "px");
|
|
155
|
+
jQuery(".sidebar-hover-elem").addClass("show-hover-elem");
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
sendAwayHoverElement() {
|
|
159
|
+
this.hoverElemTop = -200;
|
|
160
|
+
jQuery(".sidebar-hover-elem").css("top", this.hoverElemTop + "px");
|
|
161
|
+
}
|
|
162
|
+
updateSidebarHeight() {
|
|
163
|
+
let marginTop = 60 + 40;
|
|
164
|
+
let footerHeight = 150;
|
|
165
|
+
this.menuHeight = this._elementRef.nativeElement.children[0].clientHeight - marginTop - footerHeight;
|
|
166
|
+
}
|
|
167
|
+
//Nonostante questa funzione sia collegata con (click.out-zone) per qualche motivo angular le esegue comunque nella sua zone
|
|
168
|
+
//generando un po' di irresponsività iniziale... succede solo col click... boh
|
|
169
|
+
collapseMenu(jQueryevent, item) {
|
|
170
|
+
if (this.isMenuCollapsed)
|
|
171
|
+
this.menuExpand();
|
|
172
|
+
if (!item.level)
|
|
173
|
+
console.warn("Livello non presente in un oggetto del menu!");
|
|
174
|
+
//N.B: Tutte le funzioni di JQuery le esguo fuori da Angular dato che c'� una buona probabilit� che siano eventi asincroni
|
|
175
|
+
this.zone.runOutsideAngular(() => { this.outsideAngularClickHandler(jQueryevent, item); });
|
|
176
|
+
return false;
|
|
177
|
+
}
|
|
178
|
+
outsideAngularClickHandler(jQueryevent, item) {
|
|
179
|
+
let levelClass = item.level ? "level-" + (item.level) : "";
|
|
180
|
+
let levelClassPlusOne = item.level ? "level-" + (item.level + 1) : "";
|
|
181
|
+
let slidePeriod = 400;
|
|
182
|
+
var link = jQuery(jQueryevent.currentTarget);
|
|
183
|
+
//Se l'elemento non è espanso
|
|
184
|
+
if (!link.closest(".sidebar-item-expanded" + "_" + levelClass).length) {
|
|
185
|
+
//Tiro su tutti gli elementi dello stesso livello espansi e li chiudo
|
|
186
|
+
//Se ho compresso un menu vado a vedere se c'è anche un altro menu di livello pi� basso da richiudere
|
|
187
|
+
jQuery("ul.nav-sidebar li" + "." + (levelClassPlusOne)).each(function () {
|
|
188
|
+
let closestLi = jQuery(this).closest("li");
|
|
189
|
+
if (closestLi.children("ul").length && closestLi.hasClass("sidebar-item-expanded")) {
|
|
190
|
+
closestLi.children("ul").slideUp(slidePeriod);
|
|
191
|
+
//Le uso sempre entrambe insieme. La prima è la classe per la logica, la seconda per le animazioni
|
|
192
|
+
closestLi.removeClass("sidebar-item-expanded" + "_" + (levelClassPlusOne));
|
|
193
|
+
closestLi.removeClass("sidebar-item-expanded");
|
|
194
|
+
}
|
|
195
|
+
});
|
|
196
|
+
//Dopodich� richiudo tutti quelli del mio livello attuale
|
|
197
|
+
jQuery("ul.nav-sidebar li" + "." + levelClass).each(function () {
|
|
198
|
+
let closestLi = jQuery(this).closest("li");
|
|
199
|
+
if (closestLi.children("ul").length && closestLi.hasClass("sidebar-item-expanded")) {
|
|
200
|
+
closestLi.children("ul").slideUp(slidePeriod);
|
|
201
|
+
//Le uso sempre entrambe insieme. La prima è la classe per la logica, la seconda per le animazioni
|
|
202
|
+
closestLi.removeClass("sidebar-item-expanded" + "_" + levelClass);
|
|
203
|
+
closestLi.removeClass("sidebar-item-expanded");
|
|
204
|
+
}
|
|
205
|
+
});
|
|
206
|
+
//Dopodich� espando quello attuale
|
|
207
|
+
link.next().slideDown(slidePeriod);
|
|
208
|
+
if (item.subMenu) {
|
|
209
|
+
//Le uso sempre entrambe insieme. La prima è la classe per la logica, la seconda per le animazioni
|
|
210
|
+
link.closest("li").addClass("sidebar-item-expanded" + "_" + levelClass);
|
|
211
|
+
link.closest("li").addClass("sidebar-item-expanded");
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
else {
|
|
215
|
+
//Altrimenti, se l'elemento è già espanso lo chiudo
|
|
216
|
+
if (item.subMenu) {
|
|
217
|
+
//Le uso sempre entrambe insieme. La prima è la classe per la logica, la seconda per le animazioni
|
|
218
|
+
link.closest("li").removeClass("sidebar-item-expanded" + "_" + levelClass);
|
|
219
|
+
link.closest("li").removeClass("sidebar-item-expanded");
|
|
220
|
+
}
|
|
221
|
+
link.next().slideUp(slidePeriod);
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
//#endregion
|
|
225
|
+
onChangeTenant() {
|
|
226
|
+
window.location.href = `${myconfig.AuthUrl}/login/tenant?client=${myconfig.Client}`;
|
|
227
|
+
}
|
|
228
|
+
onLogout() {
|
|
229
|
+
window.location.href = `${myconfig.AuthUrl}/logout?client=${myconfig.Client}`;
|
|
230
|
+
}
|
|
231
|
+
getUserProfileData() {
|
|
232
|
+
var identity = this.sr.getJaceIdentity();
|
|
233
|
+
if (identity) {
|
|
234
|
+
this.user = identity.FullName;
|
|
235
|
+
this.tenant = identity.TenantName;
|
|
236
|
+
// TODO: Mettere logica dentro una service preferenze account
|
|
237
|
+
this.https.get(GET_Users_GetProfilePicture, new HttpParams().set('id', identity.IdAccount.toString())).subscribe(t => {
|
|
238
|
+
//this._state.setSanitizerPicProfile(t.image);
|
|
239
|
+
});
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
onSearchRequest() {
|
|
243
|
+
console.log("sent!");
|
|
244
|
+
this.searchingTerm = true;
|
|
245
|
+
this.searchResult = null;
|
|
246
|
+
if (!this.globalSearchService.Enabled)
|
|
247
|
+
return;
|
|
248
|
+
this.globalSearchService.search(this.searchTerm).subscribe(t => {
|
|
249
|
+
this.searchingTerm = false;
|
|
250
|
+
this.searchResult = t;
|
|
251
|
+
this.searchResult.results.forEach(t => {
|
|
252
|
+
t.est_cols = t.columns.map(c => {
|
|
253
|
+
let colLink = this.globalSearchService.generateColumnLink(c);
|
|
254
|
+
return new EsTableColumnsDefinition(c.description, c.id, colLink?.routePath, colLink?.routeProperties);
|
|
255
|
+
});
|
|
256
|
+
});
|
|
257
|
+
});
|
|
258
|
+
}
|
|
259
|
+
onSearchModelChanged() {
|
|
260
|
+
console.log("changed!");
|
|
261
|
+
if (!this.searchingTerm)
|
|
262
|
+
this.closeSearch();
|
|
263
|
+
}
|
|
264
|
+
closeSearch() {
|
|
265
|
+
this.searchingTerm = false;
|
|
266
|
+
this.searchResult = null;
|
|
267
|
+
}
|
|
268
|
+
FilterSearchResults(item = null) {
|
|
269
|
+
this.SelectedResult = null;
|
|
270
|
+
this.ShowSingleTable = true;
|
|
271
|
+
requestAnimationFrame(() => {
|
|
272
|
+
if (item)
|
|
273
|
+
this.SelectedResult = this.searchResult?.results?.find(f => f.description == item.description);
|
|
274
|
+
else
|
|
275
|
+
this.ShowSingleTable = false;
|
|
276
|
+
});
|
|
277
|
+
}
|
|
278
|
+
}
|
|
279
|
+
Sidebar.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: Sidebar, deps: [{ token: i1.LocalizationService }, { token: MENU_LOCALIZATION, optional: true }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i2.Router }, { token: i3.AppState }, { token: i0.NgZone }, { token: i4.UtilityService }, { token: i5.AccessControlService }, { token: MENU }, { token: i3.MenuFilteringService }, { token: i3.TokenService }, { token: i6.HTTPService }, { token: i4.MessageService }, { token: i3.GlobalSearchService }], target: i0.ɵɵFactoryTarget.Component });
|
|
280
|
+
Sidebar.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: Sidebar, isStandalone: true, selector: "sidebar", host: { listeners: { "window:resize.out-zone": "onWindowResize()" } }, viewQueries: [{ propertyName: "sidebar", first: true, predicate: ["sidebar"], descendants: true, static: true }], ngImport: i0, template: "<div #sidebar class=\"app-sidebar\" [class.menu-collapsed]=\"isMenuCollapsed\" (mouseleave.out-zone)=\"sendAwayHoverElement();\">\r\n <!--Jace Logo-->\r\n <div class=\"app-logo-container\">\r\n <div class=\"app-pointer\" [routerLink]=\"['/pages/dashboard']\" style=\"margin-bottom: 10px; overflow: hidden\">\r\n <!-- <div *ngIf=\"!isMenuCollapsed\" class=\"app-logo-img app-logo-placeholder d-flex\">\r\n <div class=\"app-margin-left-10\">\r\n <i style=\"color: #00aeef;\" class=\"fas fa-chevron-left\"></i> \r\n <i style=\"color: #01C38D;\" class=\"fas fa-chevron-right\"></i> \r\n </div>\r\n <div class=\"app-margin-left-10\">{{applicationName}}</div>\r\n </div> -->\r\n <img *ngIf=\"!isMenuCollapsed\" class=\"app-logo-img\" src=\"assets/img/logo/logo.png\" alt=\"\">\r\n <img *ngIf=\"isMenuCollapsed\" class=\"app-logo-img-sm\" src=\"assets/img/logo/logo_sm.png\" alt=\"\">\r\n </div>\r\n </div>\r\n <div *ngIf=\"!isMenuCollapsed\" class=\"app-sidebar-search\">\r\n <form novalidate role=\"search\" class=\"app-search\" (ngSubmit)=\"onSearchRequest()\">\r\n <input type=\"text\" placeholder=\"Ricerca...\" [(ngModel)]=\"searchTerm\" (ngModelChange)=\"onSearchModelChanged()\" name=\"search\" class=\"form-control\" autocomplete=\"off\">\r\n <a><i class=\"far fa-magnifying-glass\"></i></a>\r\n </form>\r\n </div>\r\n <!--Barra laterale con tutte le voci di Menu-->\r\n <ul class=\"nav nav-sidebar flex-column flex-nowrap\" style=\"position: relative; zoom: 1\" slim-scroll [slimScrollOptions]=\"{height: menuHeight}\">\r\n <li *ngFor=\"let item of menuItems; let last = last;\" \r\n class=\"sidebar-list-item level-{{item.level}}\" \r\n [style.margin-bottom]=\"last ? '42px' : '0px'\" \r\n [class.has-sub-menu]=\"item.subMenu\"\r\n [class.sidebar-item-expanded]=\"item.expanded\" \r\n [class.sidebar-item-wip]=\"item.wip\">\r\n <ng-container *ngTemplateOutlet=\"menuItem; context : { $implicit: item }\"></ng-container>\r\n </li>\r\n </ul>\r\n <!--Selettore Barra dei Menu-->\r\n <div class=\"sidebar-hover-elem\"></div>\r\n <!--Footer-->\r\n <div *ngIf=\"!isMenuCollapsed\" class=\"app-sidebar-footer\">\r\n <!--Minuscolo fade tra sidebar e inizio footer-->\r\n <div class=\"app-sidebar-footer-fade\"></div>\r\n <div class=\"app-padding-15\">\r\n <!--Informazioni utente collegato-->\r\n <div class=\"app-sidebar-footer-user-container\">\r\n <!--Mentre sto ancora caricando la ProfilePic mi assicuro di mostrare un placeholder-->\r\n <div *ngIf=\"!safeprofilepic\" class=\"app-sidebar-footer-user-img-placeholder\">\r\n <i class=\"far fa-2x fa-spinner fa-spin-pulse\" style=\"color: black; margin-top: 5px;\"></i>\r\n </div>\r\n <!--Una volta caricata la ProfilePic nascondo il placeholder e la mostro-->\r\n <ng-container *ngIf=\"safeprofilepic\">\r\n <img [src]=\"safeprofilepic\" alt=\"\" class=\"app-sidebar-footer-user-img app-pointer\" [routerLink]=\"['/pages/profile/user_info']\">\r\n <div class=\"app-sidebar-footer-user-status\"></div>\r\n </ng-container>\r\n <!--Username animato quando supera i 15 caratteri-->\r\n <div class=\"app-sidebar-footer-user-name-container\">\r\n <div class=\"username-text\" [class.username-text-animator]=\"user?.length > 15\">{{user}}</div>\r\n <div class=\"tenantname-text\">{{tenant}}</div>\r\n </div>\r\n </div>\r\n <!--Operazioni rapide (Logout, Cambia tenant, Guida, Supporto,...)-->\r\n <div class=\"app-sidebar-footer-quick-ops\">\r\n <div (click)=\"onLogout();\" class=\"app-sidebar-footer-op app-no-selection\"><i class=\"far fa-right-from-bracket\"></i> Logout</div>\r\n <div (click)=\"onChangeTenant();\" class=\"app-sidebar-footer-op app-no-selection\"><i class=\"far fa-right-left\"></i> Cambia Tenant</div>\r\n </div>\r\n <!--Versione corrente applicazione-->\r\n <div class=\"app-sidebar-footer-ver\">\r\n v{{applicationVersion}}\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #menuItem let-item>\r\n <a [attr.style.padding_left]=\"item.padding_left\" *ngIf=\"(!item.routerLink && !item.subMenu) || item.wip\" [href]=\"item.link ? item.link : '#'\" (click)=\"item.wip && $event.preventDefault()\" target=\"_blank\" class=\"sidebar-list-link {{item.cssClass || ''}}\" (mouseenter.out-zone)=\"hoverItem($event)\">\r\n <i *ngIf=\"item.icon\" class=\"{{ item.icon }}\"></i><span>{{ item.title | localize : lc }}</span>\r\n </a>\r\n\r\n <a [attr.style.padding_left]=\"item.padding_left\" *ngIf=\"item.routerLink && !item.subMenu && !item.wip\" class=\"sidebar-list-link {{item.cssClass || ''}}\" [routerLink]=\"[item.routerLink]\" [queryParams]=\"item.queryParams\" routerLinkActive=\"active-link\" (click.out-zone)=\"collapseMenu($event, item)\" (mouseenter.out-zone)=\"hoverItem($event)\">\r\n <i *ngIf=\"item.icon\" class=\"{{ item.icon }}\"></i><span>{{ item.title | localize : lc }}</span>\r\n </a>\r\n\r\n <a [attr.style.padding_left]=\"item.padding_left\" *ngIf=\"item.subMenu && !item.wip\" (click.out-zone)=\"collapseMenu($event, item)\" [attr.href]=\"''\" class=\"sidebar-list-link {{item.cssClass || ''}}\" (mouseenter.out-zone)=\"hoverItem($event)\">\r\n <i *ngIf=\"item.icon\" class=\"{{ item.icon }}\"></i><span>{{ item.title | localize : lc }}</span>\r\n <b class=\"far fa-angle-down\"></b>\r\n </a>\r\n\r\n <ul *ngIf=\"item.subMenu\" class=\"sidebar-sublist\">\r\n <li *ngFor=\"let subitem of item.subMenu\" class=\"sidebar-sublist-item level-{{subitem.level}}\" [class.sidebar-item-wip]=\"subitem.wip\">\r\n <ng-container *ngTemplateOutlet=\"menuItem; context : { $implicit: subitem }\"></ng-container>\r\n </li>\r\n </ul>\r\n</ng-template>\r\n\r\n<!-- Overlay per la ricerca globale -->\r\n<ng-container *ngIf=\"searchingTerm || searchResult\">\r\n <div class=\"app-absolute app-search-background\">\r\n <div class=\"app-search-result-box\">\r\n <ng-container *ngIf=\"searchingTerm\">\r\n <div class=\"app-search-card\"><i class=\"fa fa-spinner fa-spin\"></i>Sto effettuando la ricerca...</div>\r\n </ng-container>\r\n <ng-container *ngIf=\"searchResult && !searchingTerm\">\r\n <div class=\"row\" style=\"height: 100%;\">\r\n <!-- Spazio a sinistra -->\r\n <div class=\"col-md-1\"></div>\r\n <!-- Blocco con le categorie dei risultati -->\r\n <div class=\"col-md-3\">\r\n <div class=\"app-search-card\">\r\n <div class=\"app-relative\"><a class=\"fa fa-times text-danger app-absolute app-right-0 app-fs-20 app-pointer\" (click)=\"closeSearch();\"></a></div>\r\n <h4>Categorie di Ricerca</h4>\r\n <div class=\"app-pointer app-link\" [class.app-bold]=\"!SelectedResult && !ShowSingleTable\">\r\n <span (click)=\"FilterSearchResults()\">{{SelectedResult ? '-' : '>'}} Mostra Tutto</span>\r\n </div>\r\n <div *ngFor=\"let item of searchResult.results\" class=\"app-pointer app-link\" [class.app-bold]=\"SelectedResult?.description == item.description\">\r\n <span (click)=\"FilterSearchResults(item)\">{{SelectedResult?.description == item.description ? '>' : '-'}} Mostra {{item.description}} ({{item.items?.length}})</span>\r\n </div>\r\n </div>\r\n </div>\r\n <!-- Dettaglio risultati -->\r\n <div class=\"col-md-7\" style=\"overflow: auto; height: 100%;\">\r\n <ng-container *ngIf=\"!SelectedResult && !ShowSingleTable\">\r\n <div *ngFor=\"let res of searchResult.results; let i = index;\" class=\"app-search-card\" [style.margin-bottom.px]=\"i == (searchResult.results?.length - 1) ? 2 : 10\">\r\n <h4>{{res.description}}</h4>\r\n <es-table [(ngModel)]=\"res.items\" [DynamicRowColumnsDefinition]=\"res.est_cols\" [ArraymodeItemsPerPage]=\"10\"></es-table>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"SelectedResult && ShowSingleTable\">\r\n <div class=\"app-search-card\">\r\n <h4>{{SelectedResult.description}}</h4>\r\n <es-table [(ngModel)]=\"SelectedResult.items\" [DynamicRowColumnsDefinition]=\"SelectedResult.est_cols\" [ArraymodeItemsPerPage]=\"10\"></es-table>\r\n </div>\r\n </ng-container>\r\n </div>\r\n <!-- Spazio a destra -->\r\n <div class=\"col-md-1\"></div>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n</ng-container>", styles: ["@import\"https://fonts.googleapis.com/css2?family=Lato&family=Sora&display=swap\";.app-sidebar{background:#344154;box-shadow:8px 0 6px -6px #1313130a,12px 0 16px -16px #1313130d;height:100%;min-height:100%;width:230px;overflow:hidden;display:block;z-index:9}.app-sidebar.menu-collapsed{width:50px}.app-sidebar.menu-collapsed a.sidebar-list-link b{display:none}.app-sidebar.menu-collapsed .sidebar-sublist{position:absolute;top:-1px;left:52px;width:0;display:block;overflow:hidden}.sidebar-list-item{display:block;position:relative;float:none;padding:0;border-bottom:1px solid #485974}.sidebar-item-wip{cursor:default}a.sidebar-list-link{display:block;height:42px;padding-left:18px!important;padding-top:0!important;text-shadow:none;font-size:13px;letter-spacing:.02em;text-decoration:none;color:#fff;line-height:42px;white-space:nowrap;overflow:hidden;cursor:pointer;transition:all .2s ease}a.sidebar-list-link i{margin-right:16px;width:16px;display:inline-block}a.sidebar-list-link b{display:block;opacity:1;width:14px;height:14px;line-height:14px;text-shadow:none;font-size:18px;position:absolute;right:10px;top:14px;padding:0;text-align:center;transition:transform .2s linear}a.sidebar-list-link:hover{background-color:#2a3544}.sidebar-list-item.sidebar-item-expanded>.sidebar-list-link b,.sidebar-sublist-item.sidebar-item-expanded>.sidebar-list-link b{transform:rotate(180deg)}.sidebar-sublist{display:none;padding:0;list-style:none;position:relative;background-color:#3e4d64}.sidebar-sublist li{display:block;float:none;padding:0;border-bottom:none;position:relative;border-top:1px solid #485974}.sidebar-sublist li a{display:block;text-shadow:none;font-size:13px;text-decoration:none;padding-left:30px!important;height:42px;line-height:42px}.sidebar-sublist li a:hover{background-color:#2a3544}.sidebar-item-expanded>ul.sidebar-sublist{display:block;background-color:#3e4d64}.subitem-submenu-link .fa{top:14px}.sidebar-hover-elem{width:4px;background-color:#fffac2;position:absolute;top:-90px;left:226px;transition:all .2s ease;transition-property:top,height;height:36px;display:block}.sidebar.menu-collapsed .sidebar-hover-elem{left:46px}.active-link{color:#fffac2!important;font-weight:700!important;background-color:#3e4d64}@media (max-width: 544px){.sidebar.menu-collapsed{width:0}.sidebar-hover-elem,.sidebar-select-elem{display:none}}.app-logo-container{height:60px;background-color:#2a3544;display:flex;position:relative;z-index:10;margin-bottom:-1px;border-bottom:1px solid #485974;color:#fff}.app-sidebar-search{height:39px;border-bottom:42px solid #344154}.app-logo-placeholder{text-align:center;font-size:1.2rem;text-transform:uppercase;font-weight:700;margin-top:15px!important}.app-logo-img{width:210px;margin:10px 0 0 10px}.app-logo-img-sm{padding-top:10px}.app-sidebar-footer{position:relative;background-color:#344154}.app-sidebar-footer-fade{top:-42px;position:absolute;background-image:linear-gradient(to top,#344154,rgba(52,65,84,0));height:42px;width:230px;z-index:100}.app-sidebar-footer-user-container{position:relative;display:flex;margin-top:5px;color:#fff}.app-sidebar-footer-user-img-placeholder{height:40px;min-width:40px;width:40px;text-align:center}.app-sidebar-footer-user-img{height:40px;min-height:40px;min-width:40px;width:40px;border-radius:50%;border:1px solid #485974}.app-sidebar-footer-user-status{background-color:#32cd32;border:1px solid green;border-radius:50%;position:absolute;left:29px;top:29px;height:11px;width:11px}.app-sidebar-footer-user-name-container{width:150px;white-space:nowrap;overflow:hidden;margin-left:10px}.username-text{z-index:1;min-width:140px;display:flex;font-size:16px}.username-text-animator:hover{transform:translate(100%);animation:my-animation 3s linear infinite}@keyframes my-animation{0%{transform:translate(0)}to{transform:translate(-50%)}}.tenantname-text{font-size:12px}.app-sidebar-footer-quick-ops{margin-top:10px;display:flex;justify-content:space-between}.app-sidebar-footer-op{color:#fffac2;font-weight:700;cursor:pointer}.app-sidebar-footer-ver{text-align:right;margin-top:30px;color:#fff}.app-search{position:relative}.app-search a{position:absolute;top:8px;right:14px;font-size:16px;color:#fff!important}.app-search .form-control{font-size:12px;letter-spacing:.03em;height:40px;color:#fff;padding:7px 40px 7px 20px;background:#3e4d64;box-shadow:none!important;border-top:none!important;border-left:none!important;border-right:none!important;border-bottom:1px solid #485974}\n"], dependencies: [{ kind: "directive", type: SlimScroll, selector: "[slim-scroll]", inputs: ["slimScrollOptions"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: LocalizationModule }, { kind: "pipe", type: i1.LocalizePipe, name: "localize" }, { kind: "ngmodule", type: EsTableModule }, { kind: "component", type: i7.EsTableComponent, selector: "es-table", inputs: ["EsTableTemplate", "CornerMenuOptions", "ColumnsResizable", "ColumnsPinnable", "AutoUpdate", "Height", "EmptySpaceBackgroundColor", "EsTableHandledSearch", "MaxHeight", "ContainerClass", "XLSXExport", "CSVExport", "AllSearch", "HighCellDensity", "Selection", "ShowLoadingOnBootstrap", "Removal", "RemovalCondition", "Export", "ShiftClick", "CountLabel", "HidePaging", "HidePagingCount", "HidePagingButtons", "ContextMenu", "ExportFileName", "TableClass", "ExportFunction", "ExportOnlyVisibleColumns", "HasHeaderGroup", "HasSecondaryHeaderGroup", "HeaderHidden", "BodyHidden", "SelectionDisabled", "SingleSelection", "RowClassAssigner", "OrderByColumn", "MultipleOrderingDirectives", "HiddenColumns", "ColumnsOrdering", "SearchView", "SelectAll", "UseArrayModePaging", "DynamicRowColumnsDefinition", "DynamicOperations", "Hierarchy", "ParentKey", "OwnKey", "StartsExpanded", "SavePreferences", "DefaultAlignment", "PagingStyle", "RowGroupingPagingStyle", "ItemSourceProperty", "UseSelectionCache", "ShowItemGroupsColumns", "Editable", "RangeSelection", "SearchThrottle", "ArraymodeItemsPerPage"], outputs: ["onOrderChanged", "onSearchRequest", "onSelectionChanged", "onRemoval", "onAbortRemoval", "onModelChange", "onOpenContextMenu", "onCornerAction", "onDynamicOperation"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i8.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i8.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
281
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: Sidebar, decorators: [{
|
|
282
|
+
type: Component,
|
|
283
|
+
args: [{ selector: "sidebar", encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [NgClass, SlimScroll, NgFor, NgTemplateOutlet, NgIf, RouterLinkActive, RouterLink, LocalizationModule, EsTableModule, FormsModule], template: "<div #sidebar class=\"app-sidebar\" [class.menu-collapsed]=\"isMenuCollapsed\" (mouseleave.out-zone)=\"sendAwayHoverElement();\">\r\n <!--Jace Logo-->\r\n <div class=\"app-logo-container\">\r\n <div class=\"app-pointer\" [routerLink]=\"['/pages/dashboard']\" style=\"margin-bottom: 10px; overflow: hidden\">\r\n <!-- <div *ngIf=\"!isMenuCollapsed\" class=\"app-logo-img app-logo-placeholder d-flex\">\r\n <div class=\"app-margin-left-10\">\r\n <i style=\"color: #00aeef;\" class=\"fas fa-chevron-left\"></i> \r\n <i style=\"color: #01C38D;\" class=\"fas fa-chevron-right\"></i> \r\n </div>\r\n <div class=\"app-margin-left-10\">{{applicationName}}</div>\r\n </div> -->\r\n <img *ngIf=\"!isMenuCollapsed\" class=\"app-logo-img\" src=\"assets/img/logo/logo.png\" alt=\"\">\r\n <img *ngIf=\"isMenuCollapsed\" class=\"app-logo-img-sm\" src=\"assets/img/logo/logo_sm.png\" alt=\"\">\r\n </div>\r\n </div>\r\n <div *ngIf=\"!isMenuCollapsed\" class=\"app-sidebar-search\">\r\n <form novalidate role=\"search\" class=\"app-search\" (ngSubmit)=\"onSearchRequest()\">\r\n <input type=\"text\" placeholder=\"Ricerca...\" [(ngModel)]=\"searchTerm\" (ngModelChange)=\"onSearchModelChanged()\" name=\"search\" class=\"form-control\" autocomplete=\"off\">\r\n <a><i class=\"far fa-magnifying-glass\"></i></a>\r\n </form>\r\n </div>\r\n <!--Barra laterale con tutte le voci di Menu-->\r\n <ul class=\"nav nav-sidebar flex-column flex-nowrap\" style=\"position: relative; zoom: 1\" slim-scroll [slimScrollOptions]=\"{height: menuHeight}\">\r\n <li *ngFor=\"let item of menuItems; let last = last;\" \r\n class=\"sidebar-list-item level-{{item.level}}\" \r\n [style.margin-bottom]=\"last ? '42px' : '0px'\" \r\n [class.has-sub-menu]=\"item.subMenu\"\r\n [class.sidebar-item-expanded]=\"item.expanded\" \r\n [class.sidebar-item-wip]=\"item.wip\">\r\n <ng-container *ngTemplateOutlet=\"menuItem; context : { $implicit: item }\"></ng-container>\r\n </li>\r\n </ul>\r\n <!--Selettore Barra dei Menu-->\r\n <div class=\"sidebar-hover-elem\"></div>\r\n <!--Footer-->\r\n <div *ngIf=\"!isMenuCollapsed\" class=\"app-sidebar-footer\">\r\n <!--Minuscolo fade tra sidebar e inizio footer-->\r\n <div class=\"app-sidebar-footer-fade\"></div>\r\n <div class=\"app-padding-15\">\r\n <!--Informazioni utente collegato-->\r\n <div class=\"app-sidebar-footer-user-container\">\r\n <!--Mentre sto ancora caricando la ProfilePic mi assicuro di mostrare un placeholder-->\r\n <div *ngIf=\"!safeprofilepic\" class=\"app-sidebar-footer-user-img-placeholder\">\r\n <i class=\"far fa-2x fa-spinner fa-spin-pulse\" style=\"color: black; margin-top: 5px;\"></i>\r\n </div>\r\n <!--Una volta caricata la ProfilePic nascondo il placeholder e la mostro-->\r\n <ng-container *ngIf=\"safeprofilepic\">\r\n <img [src]=\"safeprofilepic\" alt=\"\" class=\"app-sidebar-footer-user-img app-pointer\" [routerLink]=\"['/pages/profile/user_info']\">\r\n <div class=\"app-sidebar-footer-user-status\"></div>\r\n </ng-container>\r\n <!--Username animato quando supera i 15 caratteri-->\r\n <div class=\"app-sidebar-footer-user-name-container\">\r\n <div class=\"username-text\" [class.username-text-animator]=\"user?.length > 15\">{{user}}</div>\r\n <div class=\"tenantname-text\">{{tenant}}</div>\r\n </div>\r\n </div>\r\n <!--Operazioni rapide (Logout, Cambia tenant, Guida, Supporto,...)-->\r\n <div class=\"app-sidebar-footer-quick-ops\">\r\n <div (click)=\"onLogout();\" class=\"app-sidebar-footer-op app-no-selection\"><i class=\"far fa-right-from-bracket\"></i> Logout</div>\r\n <div (click)=\"onChangeTenant();\" class=\"app-sidebar-footer-op app-no-selection\"><i class=\"far fa-right-left\"></i> Cambia Tenant</div>\r\n </div>\r\n <!--Versione corrente applicazione-->\r\n <div class=\"app-sidebar-footer-ver\">\r\n v{{applicationVersion}}\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #menuItem let-item>\r\n <a [attr.style.padding_left]=\"item.padding_left\" *ngIf=\"(!item.routerLink && !item.subMenu) || item.wip\" [href]=\"item.link ? item.link : '#'\" (click)=\"item.wip && $event.preventDefault()\" target=\"_blank\" class=\"sidebar-list-link {{item.cssClass || ''}}\" (mouseenter.out-zone)=\"hoverItem($event)\">\r\n <i *ngIf=\"item.icon\" class=\"{{ item.icon }}\"></i><span>{{ item.title | localize : lc }}</span>\r\n </a>\r\n\r\n <a [attr.style.padding_left]=\"item.padding_left\" *ngIf=\"item.routerLink && !item.subMenu && !item.wip\" class=\"sidebar-list-link {{item.cssClass || ''}}\" [routerLink]=\"[item.routerLink]\" [queryParams]=\"item.queryParams\" routerLinkActive=\"active-link\" (click.out-zone)=\"collapseMenu($event, item)\" (mouseenter.out-zone)=\"hoverItem($event)\">\r\n <i *ngIf=\"item.icon\" class=\"{{ item.icon }}\"></i><span>{{ item.title | localize : lc }}</span>\r\n </a>\r\n\r\n <a [attr.style.padding_left]=\"item.padding_left\" *ngIf=\"item.subMenu && !item.wip\" (click.out-zone)=\"collapseMenu($event, item)\" [attr.href]=\"''\" class=\"sidebar-list-link {{item.cssClass || ''}}\" (mouseenter.out-zone)=\"hoverItem($event)\">\r\n <i *ngIf=\"item.icon\" class=\"{{ item.icon }}\"></i><span>{{ item.title | localize : lc }}</span>\r\n <b class=\"far fa-angle-down\"></b>\r\n </a>\r\n\r\n <ul *ngIf=\"item.subMenu\" class=\"sidebar-sublist\">\r\n <li *ngFor=\"let subitem of item.subMenu\" class=\"sidebar-sublist-item level-{{subitem.level}}\" [class.sidebar-item-wip]=\"subitem.wip\">\r\n <ng-container *ngTemplateOutlet=\"menuItem; context : { $implicit: subitem }\"></ng-container>\r\n </li>\r\n </ul>\r\n</ng-template>\r\n\r\n<!-- Overlay per la ricerca globale -->\r\n<ng-container *ngIf=\"searchingTerm || searchResult\">\r\n <div class=\"app-absolute app-search-background\">\r\n <div class=\"app-search-result-box\">\r\n <ng-container *ngIf=\"searchingTerm\">\r\n <div class=\"app-search-card\"><i class=\"fa fa-spinner fa-spin\"></i>Sto effettuando la ricerca...</div>\r\n </ng-container>\r\n <ng-container *ngIf=\"searchResult && !searchingTerm\">\r\n <div class=\"row\" style=\"height: 100%;\">\r\n <!-- Spazio a sinistra -->\r\n <div class=\"col-md-1\"></div>\r\n <!-- Blocco con le categorie dei risultati -->\r\n <div class=\"col-md-3\">\r\n <div class=\"app-search-card\">\r\n <div class=\"app-relative\"><a class=\"fa fa-times text-danger app-absolute app-right-0 app-fs-20 app-pointer\" (click)=\"closeSearch();\"></a></div>\r\n <h4>Categorie di Ricerca</h4>\r\n <div class=\"app-pointer app-link\" [class.app-bold]=\"!SelectedResult && !ShowSingleTable\">\r\n <span (click)=\"FilterSearchResults()\">{{SelectedResult ? '-' : '>'}} Mostra Tutto</span>\r\n </div>\r\n <div *ngFor=\"let item of searchResult.results\" class=\"app-pointer app-link\" [class.app-bold]=\"SelectedResult?.description == item.description\">\r\n <span (click)=\"FilterSearchResults(item)\">{{SelectedResult?.description == item.description ? '>' : '-'}} Mostra {{item.description}} ({{item.items?.length}})</span>\r\n </div>\r\n </div>\r\n </div>\r\n <!-- Dettaglio risultati -->\r\n <div class=\"col-md-7\" style=\"overflow: auto; height: 100%;\">\r\n <ng-container *ngIf=\"!SelectedResult && !ShowSingleTable\">\r\n <div *ngFor=\"let res of searchResult.results; let i = index;\" class=\"app-search-card\" [style.margin-bottom.px]=\"i == (searchResult.results?.length - 1) ? 2 : 10\">\r\n <h4>{{res.description}}</h4>\r\n <es-table [(ngModel)]=\"res.items\" [DynamicRowColumnsDefinition]=\"res.est_cols\" [ArraymodeItemsPerPage]=\"10\"></es-table>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"SelectedResult && ShowSingleTable\">\r\n <div class=\"app-search-card\">\r\n <h4>{{SelectedResult.description}}</h4>\r\n <es-table [(ngModel)]=\"SelectedResult.items\" [DynamicRowColumnsDefinition]=\"SelectedResult.est_cols\" [ArraymodeItemsPerPage]=\"10\"></es-table>\r\n </div>\r\n </ng-container>\r\n </div>\r\n <!-- Spazio a destra -->\r\n <div class=\"col-md-1\"></div>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n</ng-container>", styles: ["@import\"https://fonts.googleapis.com/css2?family=Lato&family=Sora&display=swap\";.app-sidebar{background:#344154;box-shadow:8px 0 6px -6px #1313130a,12px 0 16px -16px #1313130d;height:100%;min-height:100%;width:230px;overflow:hidden;display:block;z-index:9}.app-sidebar.menu-collapsed{width:50px}.app-sidebar.menu-collapsed a.sidebar-list-link b{display:none}.app-sidebar.menu-collapsed .sidebar-sublist{position:absolute;top:-1px;left:52px;width:0;display:block;overflow:hidden}.sidebar-list-item{display:block;position:relative;float:none;padding:0;border-bottom:1px solid #485974}.sidebar-item-wip{cursor:default}a.sidebar-list-link{display:block;height:42px;padding-left:18px!important;padding-top:0!important;text-shadow:none;font-size:13px;letter-spacing:.02em;text-decoration:none;color:#fff;line-height:42px;white-space:nowrap;overflow:hidden;cursor:pointer;transition:all .2s ease}a.sidebar-list-link i{margin-right:16px;width:16px;display:inline-block}a.sidebar-list-link b{display:block;opacity:1;width:14px;height:14px;line-height:14px;text-shadow:none;font-size:18px;position:absolute;right:10px;top:14px;padding:0;text-align:center;transition:transform .2s linear}a.sidebar-list-link:hover{background-color:#2a3544}.sidebar-list-item.sidebar-item-expanded>.sidebar-list-link b,.sidebar-sublist-item.sidebar-item-expanded>.sidebar-list-link b{transform:rotate(180deg)}.sidebar-sublist{display:none;padding:0;list-style:none;position:relative;background-color:#3e4d64}.sidebar-sublist li{display:block;float:none;padding:0;border-bottom:none;position:relative;border-top:1px solid #485974}.sidebar-sublist li a{display:block;text-shadow:none;font-size:13px;text-decoration:none;padding-left:30px!important;height:42px;line-height:42px}.sidebar-sublist li a:hover{background-color:#2a3544}.sidebar-item-expanded>ul.sidebar-sublist{display:block;background-color:#3e4d64}.subitem-submenu-link .fa{top:14px}.sidebar-hover-elem{width:4px;background-color:#fffac2;position:absolute;top:-90px;left:226px;transition:all .2s ease;transition-property:top,height;height:36px;display:block}.sidebar.menu-collapsed .sidebar-hover-elem{left:46px}.active-link{color:#fffac2!important;font-weight:700!important;background-color:#3e4d64}@media (max-width: 544px){.sidebar.menu-collapsed{width:0}.sidebar-hover-elem,.sidebar-select-elem{display:none}}.app-logo-container{height:60px;background-color:#2a3544;display:flex;position:relative;z-index:10;margin-bottom:-1px;border-bottom:1px solid #485974;color:#fff}.app-sidebar-search{height:39px;border-bottom:42px solid #344154}.app-logo-placeholder{text-align:center;font-size:1.2rem;text-transform:uppercase;font-weight:700;margin-top:15px!important}.app-logo-img{width:210px;margin:10px 0 0 10px}.app-logo-img-sm{padding-top:10px}.app-sidebar-footer{position:relative;background-color:#344154}.app-sidebar-footer-fade{top:-42px;position:absolute;background-image:linear-gradient(to top,#344154,rgba(52,65,84,0));height:42px;width:230px;z-index:100}.app-sidebar-footer-user-container{position:relative;display:flex;margin-top:5px;color:#fff}.app-sidebar-footer-user-img-placeholder{height:40px;min-width:40px;width:40px;text-align:center}.app-sidebar-footer-user-img{height:40px;min-height:40px;min-width:40px;width:40px;border-radius:50%;border:1px solid #485974}.app-sidebar-footer-user-status{background-color:#32cd32;border:1px solid green;border-radius:50%;position:absolute;left:29px;top:29px;height:11px;width:11px}.app-sidebar-footer-user-name-container{width:150px;white-space:nowrap;overflow:hidden;margin-left:10px}.username-text{z-index:1;min-width:140px;display:flex;font-size:16px}.username-text-animator:hover{transform:translate(100%);animation:my-animation 3s linear infinite}@keyframes my-animation{0%{transform:translate(0)}to{transform:translate(-50%)}}.tenantname-text{font-size:12px}.app-sidebar-footer-quick-ops{margin-top:10px;display:flex;justify-content:space-between}.app-sidebar-footer-op{color:#fffac2;font-weight:700;cursor:pointer}.app-sidebar-footer-ver{text-align:right;margin-top:30px;color:#fff}.app-search{position:relative}.app-search a{position:absolute;top:8px;right:14px;font-size:16px;color:#fff!important}.app-search .form-control{font-size:12px;letter-spacing:.03em;height:40px;color:#fff;padding:7px 40px 7px 20px;background:#3e4d64;box-shadow:none!important;border-top:none!important;border-left:none!important;border-right:none!important;border-bottom:1px solid #485974}\n"] }]
|
|
284
|
+
}], ctorParameters: function () { return [{ type: i1.LocalizationService }, { type: i0.Type, decorators: [{
|
|
285
|
+
type: Optional
|
|
286
|
+
}, {
|
|
287
|
+
type: Inject,
|
|
288
|
+
args: [MENU_LOCALIZATION]
|
|
289
|
+
}] }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i2.Router }, { type: i3.AppState }, { type: i0.NgZone }, { type: i4.UtilityService }, { type: i5.AccessControlService }, { type: undefined, decorators: [{
|
|
290
|
+
type: Inject,
|
|
291
|
+
args: [MENU]
|
|
292
|
+
}] }, { type: i3.MenuFilteringService }, { type: i3.TokenService }, { type: i6.HTTPService }, { type: i4.MessageService }, { type: i3.GlobalSearchService }]; }, propDecorators: { sidebar: [{
|
|
293
|
+
type: ViewChild,
|
|
294
|
+
args: ["sidebar", { static: true }]
|
|
295
|
+
}], onWindowResize: [{
|
|
296
|
+
type: HostListener,
|
|
297
|
+
args: ["window:resize.out-zone"]
|
|
298
|
+
}] } });
|
|
299
|
+
// TODO: Spostare nel modulo preferenze account
|
|
300
|
+
export class ProfilePicture {
|
|
301
|
+
}
|
|
302
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidebar.component.js","sourceRoot":"","sources":["../../../../../../projects/core/components/src/page-structure/sidebar/sidebar.component.ts","../../../../../../projects/core/components/src/page-structure/sidebar/sidebar.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostListener, Inject, NgZone, Optional, Type, ViewChild, ViewEncapsulation } from \"@angular/core\";\r\nimport { NavigationEnd, Router, RouterLinkActive, RouterLink } from \"@angular/router\";\r\nimport { NgClass, NgFor, NgTemplateOutlet, NgIf } from \"@angular/common\";\r\n\r\n// Configurazioni\r\nimport { LocalizationService, LocalizationModule } from \"@esfaenza/localizations\";\r\n\r\n// EsFaenza\r\nimport { ApplicationMenu, EnvOptions, MENU, MENU_LOCALIZATION, SearchResult, SearchResultContainer } from \"@esfaenza/core/domain\";\r\nimport { AppState, GlobalSearchService, MenuFilteringService, TokenService } from \"@esfaenza/core/services\";\r\nimport { MessageService, UtilityService } from \"@esfaenza/extensions\";\r\nimport { AccessControlService } from \"@esfaenza/access-control\";\r\nimport { SlimScroll } from \"@esfaenza/core/directives\";\r\n\r\n// Librerie\r\nimport { firstValueFrom } from \"rxjs\";\r\nimport { HTTPService } from \"@esfaenza/httpservice\";\r\nimport { HttpParams } from \"@angular/common/http\";\r\nimport { SafeResourceUrl } from \"@angular/platform-browser\";\r\nimport { EsTableColumnsDefinition, EsTableModule } from \"@esfaenza/es-table\";\r\nimport { FormsModule } from \"@angular/forms\";\r\n\r\n// Chiamate ai Repository\r\nconst GET_Users_GetProfilePicture: string = \"/api/Users/GetProfilePicture\";\r\n\r\ndeclare var myconfig: EnvOptions;\r\ndeclare var jQuery;\r\n\r\n@Component({\r\n    selector: \"sidebar\",\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    styleUrls: [\"./sidebar.component.scss\"],\r\n    templateUrl: \"./sidebar.component.html\",\r\n    standalone: true,\r\n    imports: [NgClass, SlimScroll, NgFor, NgTemplateOutlet, NgIf, RouterLinkActive, RouterLink, LocalizationModule, EsTableModule, FormsModule]\r\n})\r\nexport class Sidebar {\r\n    public menuItems: Array<any>;\r\n    public menuHeight: number;\r\n    public isMenuCollapsed: boolean = false;\r\n    public isMenuShouldCollapsed: boolean = false;\r\n\r\n    public showHoverElem: boolean;\r\n    public hoverElemHeight: number;\r\n    public hoverElemTop: number;\r\n\r\n    public applicationVersion = myconfig.AppData.ComponentVersion;\r\n    public applicationName = myconfig.AppData.ModuleDescription;\r\n    public user = \"\";\r\n    public tenant = \"\";\r\n\r\n    public SearchModel = \"\";\r\n\r\n    @ViewChild(\"sidebar\", { static: true }) sidebar: ElementRef;\r\n\r\n    constructor(\r\n        public lc: LocalizationService, @Optional() @Inject(MENU_LOCALIZATION) lcMenu: Type<LocalizationService>, private cdr: ChangeDetectorRef, private _elementRef: ElementRef,\r\n        private _router: Router, public _state: AppState, private zone: NgZone, private utiExts: UtilityService, private aac: AccessControlService, @Inject(MENU) private menuItemsRaw: ApplicationMenu[],\r\n        private menuFilteringService: MenuFilteringService, public sr: TokenService, private https: HTTPService, private msgs: MessageService, public globalSearchService: GlobalSearchService) {\r\n\r\n        this.lc = this.lc.generateFromType(lcMenu);\r\n\r\n        this._state.subscribe(\"menu.isCollapsed\", (isCollapsed) => {\r\n            this.isMenuCollapsed = isCollapsed;\r\n            this.cdr.markForCheck();\r\n        });\r\n\r\n        this._state.subscribe(\"application.DeployAvailable\", (available: boolean) => {\r\n            if (available)\r\n                this.ngOnInit();\r\n        });\r\n\r\n        this._router.events.subscribe(event => {\r\n            if (event instanceof NavigationEnd) {\r\n                let width = (window.innerWidth > 0) ? window.innerWidth : screen.width;\r\n                if (width <= 768) \r\n                    this._state.notifyDataChanged(\"menu.isCollapsed\", true);\r\n                window.scrollTo(0, 0);\r\n            }\r\n        });\r\n\r\n        this.getUserProfileData();\r\n    }\r\n\r\n    public async ngOnInit() {\r\n        let tmpMenuItems = this.getMenuItems();\r\n        this.menuItems = await firstValueFrom(this.menuFilteringService.filter(tmpMenuItems));\r\n\r\n        if (this._shouldMenuCollapse())\r\n            this.menuCollapse();\r\n\r\n        this.updateSidebarHeight();\r\n        this._state.setSidebarWidth(this.sidebar.nativeElement.offsetWidth);\r\n        this.cdr.markForCheck();\r\n    }\r\n\r\n    private getMenuItems(): ApplicationMenu[] {\r\n        var items: ApplicationMenu[] = [];\r\n\r\n        for (let i = 0; i < this.menuItemsRaw.length; i++) {\r\n            let t = this.menuItemsRaw[i];\r\n            (<any>t).level = 1;\r\n            if (!t.ac || this.aac.has(t.ac)) {\r\n                if (!t.subMenu || t.subMenu.length == 0) {\r\n                    t.icon = t.icon ?? \"far fa-circle-small\";\r\n                    items.push(t);\r\n                }\r\n                else {\r\n                    var toPush = this.checkSubMenuOverClaims(t, 1);\r\n                    toPush.icon = toPush.icon ?? \"far fa-circle-small\";\r\n                    items.push(toPush);\r\n                }\r\n            }\r\n        }\r\n\r\n        return items;\r\n    }\r\n\r\n    private checkSubMenuOverClaims(menuItem: ApplicationMenu, level: number): ApplicationMenu {\r\n        var item: ApplicationMenu = this.utiExts.deepClone(menuItem);\r\n        item.subMenu = [];\r\n\r\n        for (let i = 0; i < menuItem.subMenu.length; i++) {\r\n            let t = menuItem.subMenu[i];\r\n            (<any>t).level = level+1;\r\n            if (!t.ac || this.aac.has(t.ac)) {\r\n                if (!t.subMenu || t.subMenu.length == 0) {\r\n                    t.icon = t.icon ?? \"far fa-circle-small\";\r\n                    item.subMenu.push(t);\r\n                }\r\n                else {\r\n                    var toPush = this.checkSubMenuOverClaims(t, level+1);\r\n                    toPush.icon = toPush.icon ?? \"far fa-circle-small\";\r\n                    item.subMenu.push(toPush);\r\n                }\r\n            }\r\n            // Calcolo qui per non doverlo calcolare lato HTML\r\n            (<any>t).padding_left = level > 2 ? (65 + ((level - 3) * 15) + 'px !important') : null;\r\n        }\r\n\r\n        return item;\r\n    }\r\n    \r\n    //#region JQuery\r\n    @HostListener(\"window:resize.out-zone\")\r\n    public onWindowResize(): void {\r\n        var isMenuShouldCollapsed = this._shouldMenuCollapse();\r\n\r\n        if (this.isMenuShouldCollapsed !== isMenuShouldCollapsed) {\r\n            this.menuCollapseStateChange(isMenuShouldCollapsed);\r\n        }\r\n        this.isMenuShouldCollapsed = isMenuShouldCollapsed;\r\n        this.updateSidebarHeight();\r\n    }\r\n\r\n    private _shouldMenuCollapse(): boolean {\r\n        return window.innerWidth <= 768;\r\n    }\r\n\r\n    public menuCollapse(): void {\r\n        this.menuCollapseStateChange(true);\r\n        this._state.setSidebarWidth(this.sidebar.nativeElement.offsetWidth);\r\n    }\r\n\r\n    public menuCollapseStateChange(isCollapsed: boolean): void {\r\n        this.isMenuCollapsed = isCollapsed;\r\n        this._state.notifyDataChanged(\"menu.isCollapsed\", this.isMenuCollapsed);\r\n    }\r\n\r\n    public menuExpand(): void {\r\n        this.menuCollapseStateChange(false);\r\n        this._state.setSidebarWidth(this.sidebar.nativeElement.offsetWidth);\r\n    }\r\n\r\n    public hoverItem(jQueryevent): void {\r\n        if(!this.isMenuCollapsed) {\r\n            this.showHoverElem = true;\r\n            this.hoverElemHeight = jQueryevent.currentTarget.clientHeight;\r\n            this.hoverElemTop = jQueryevent.currentTarget.getBoundingClientRect().top;\r\n    \r\n            jQuery(\".sidebar-hover-elem\").css(\"top\", this.hoverElemTop + \"px\");\r\n            jQuery(\".sidebar-hover-elem\").css(\"height\", this.hoverElemHeight + \"px\");\r\n            jQuery(\".sidebar-hover-elem\").addClass(\"show-hover-elem\");\r\n        }\r\n    }\r\n\r\n    public sendAwayHoverElement() {\r\n        this.hoverElemTop = -200;\r\n\r\n        jQuery(\".sidebar-hover-elem\").css(\"top\", this.hoverElemTop + \"px\");\r\n    }\r\n\r\n    public updateSidebarHeight(): void {\r\n        let marginTop = 60 + 40;\r\n        let footerHeight = 150;\r\n\r\n        this.menuHeight = this._elementRef.nativeElement.children[0].clientHeight - marginTop - footerHeight;\r\n    }\r\n\r\n    //Nonostante questa funzione sia collegata con (click.out-zone) per qualche motivo angular le esegue comunque nella sua zone\r\n    //generando un po' di irresponsività iniziale... succede solo col click... boh\r\n    public collapseMenu(jQueryevent, item): boolean {\r\n        if (this.isMenuCollapsed)\r\n            this.menuExpand();\r\n\r\n        if (!item.level)\r\n            console.warn(\"Livello non presente in un oggetto del menu!\");\r\n\r\n        //N.B: Tutte le funzioni di JQuery le esguo fuori da Angular dato che c'� una buona probabilit� che siano eventi asincroni\r\n        this.zone.runOutsideAngular(() => { this.outsideAngularClickHandler(jQueryevent, item); });\r\n\r\n        return false;\r\n    }\r\n\r\n    private outsideAngularClickHandler(jQueryevent, item) {\r\n        let levelClass = item.level ? \"level-\" + (item.level) : \"\";\r\n        let levelClassPlusOne = item.level ? \"level-\" + (item.level + 1) : \"\";\r\n        let slidePeriod = 400;\r\n\r\n        var link = jQuery(jQueryevent.currentTarget);\r\n\r\n        //Se l'elemento non è espanso\r\n        if (!link.closest(\".sidebar-item-expanded\" + \"_\" + levelClass).length) {\r\n            //Tiro su tutti gli elementi dello stesso livello espansi e li chiudo\r\n\r\n            //Se ho compresso un menu vado a vedere se c'è anche un altro menu di livello pi� basso da richiudere\r\n            jQuery(\"ul.nav-sidebar li\" + \".\" + (levelClassPlusOne)).each(function () {\r\n                let closestLi = jQuery(this).closest(\"li\");\r\n                if (closestLi.children(\"ul\").length && closestLi.hasClass(\"sidebar-item-expanded\")) {\r\n                    closestLi.children(\"ul\").slideUp(slidePeriod);\r\n                    //Le uso sempre entrambe insieme. La prima è la classe per la logica, la seconda per le animazioni\r\n                    closestLi.removeClass(\"sidebar-item-expanded\" + \"_\" + (levelClassPlusOne));\r\n                    closestLi.removeClass(\"sidebar-item-expanded\");\r\n                }\r\n            });\r\n\r\n            //Dopodich� richiudo tutti quelli del mio livello attuale\r\n            jQuery(\"ul.nav-sidebar li\" + \".\" + levelClass).each(function () {\r\n                let closestLi = jQuery(this).closest(\"li\");\r\n                if (closestLi.children(\"ul\").length && closestLi.hasClass(\"sidebar-item-expanded\")) {\r\n                    closestLi.children(\"ul\").slideUp(slidePeriod);\r\n                    //Le uso sempre entrambe insieme. La prima è la classe per la logica, la seconda per le animazioni\r\n                    closestLi.removeClass(\"sidebar-item-expanded\" + \"_\" + levelClass);\r\n                    closestLi.removeClass(\"sidebar-item-expanded\");\r\n                }\r\n            });\r\n\r\n            //Dopodich� espando quello attuale\r\n            link.next().slideDown(slidePeriod);\r\n\r\n            if (item.subMenu) {\r\n                //Le uso sempre entrambe insieme. La prima è la classe per la logica, la seconda per le animazioni\r\n                link.closest(\"li\").addClass(\"sidebar-item-expanded\" + \"_\" + levelClass);\r\n                link.closest(\"li\").addClass(\"sidebar-item-expanded\");\r\n            }\r\n        } else {\r\n            //Altrimenti, se l'elemento è già espanso lo chiudo\r\n            if (item.subMenu) {\r\n                //Le uso sempre entrambe insieme. La prima è la classe per la logica, la seconda per le animazioni\r\n                link.closest(\"li\").removeClass(\"sidebar-item-expanded\" + \"_\" + levelClass);\r\n                link.closest(\"li\").removeClass(\"sidebar-item-expanded\");\r\n            }\r\n\r\n            link.next().slideUp(slidePeriod);\r\n        }\r\n    }\r\n    //#endregion\r\n\r\n    public onChangeTenant() {\r\n        window.location.href = `${myconfig.AuthUrl}/login/tenant?client=${myconfig.Client}`;\r\n    }\r\n\r\n    public onLogout() {\r\n        window.location.href = `${myconfig.AuthUrl}/logout?client=${myconfig.Client}`;\r\n    }\r\n\r\n    // TODO: Salvare dentro una service preferenze account\r\n    public safeprofilepic: SafeResourceUrl = null;\r\n\r\n    private getUserProfileData() {\r\n        var identity = this.sr.getJaceIdentity();\r\n\r\n        if (identity) {\r\n            this.user = identity.FullName;\r\n            this.tenant = identity.TenantName;\r\n\r\n            // TODO: Mettere logica dentro una service preferenze account\r\n            this.https.get<ProfilePicture>(GET_Users_GetProfilePicture, new HttpParams().set('id', identity.IdAccount.toString())).subscribe(t => {\r\n                //this._state.setSanitizerPicProfile(t.image);\r\n            });\r\n        }\r\n    }\r\n\r\n    // ***************************************** Gestione Ricerca Globale *****************************************\r\n\r\n    public SelectedResult: SearchResult = null;\r\n    public ShowSingleTable: boolean = false;\r\n\r\n    searchTerm: string;\r\n    searchingTerm: boolean = false;\r\n    searchResult: SearchResultContainer;\r\n\r\n    onSearchRequest() {\r\n        console.log(\"sent!\")\r\n        this.searchingTerm = true;\r\n        this.searchResult = null;\r\n\r\n        if (!this.globalSearchService.Enabled)\r\n            return;\r\n\r\n        this.globalSearchService.search(this.searchTerm).subscribe(t => {\r\n            this.searchingTerm = false;\r\n            this.searchResult = t;\r\n\r\n            this.searchResult.results.forEach(t => {\r\n                t.est_cols = t.columns.map(c => {\r\n                    let colLink = this.globalSearchService.generateColumnLink(c);\r\n                    return new EsTableColumnsDefinition(c.description, c.id, colLink?.routePath, colLink?.routeProperties);\r\n                });\r\n            });\r\n        });\r\n    }\r\n\r\n    onSearchModelChanged() {\r\n        console.log(\"changed!\")\r\n        if (!this.searchingTerm)\r\n            this.closeSearch();\r\n    }\r\n\r\n    closeSearch() {\r\n        this.searchingTerm = false;\r\n        this.searchResult = null;\r\n    }\r\n\r\n    FilterSearchResults(item: SearchResult = null) {\r\n        this.SelectedResult = null;\r\n        this.ShowSingleTable = true;\r\n\r\n        requestAnimationFrame(() => {\r\n            if (item)\r\n                this.SelectedResult = this.searchResult?.results?.find(f => f.description == item.description);\r\n            else\r\n                this.ShowSingleTable = false;\r\n        });\r\n    }\r\n}\r\n\r\n// TODO: Spostare nel modulo preferenze account\r\nexport class ProfilePicture{\r\n    image: string;\r\n}","<div #sidebar class=\"app-sidebar\" [class.menu-collapsed]=\"isMenuCollapsed\" (mouseleave.out-zone)=\"sendAwayHoverElement();\">\r\n    <!--Jace Logo-->\r\n    <div class=\"app-logo-container\">\r\n        <div class=\"app-pointer\" [routerLink]=\"['/pages/dashboard']\" style=\"margin-bottom: 10px; overflow: hidden\">\r\n            <!-- <div *ngIf=\"!isMenuCollapsed\" class=\"app-logo-img app-logo-placeholder d-flex\">\r\n                <div class=\"app-margin-left-10\">\r\n                    <i style=\"color: #00aeef;\" class=\"fas fa-chevron-left\"></i>&nbsp;\r\n                    <i style=\"color: #01C38D;\" class=\"fas fa-chevron-right\"></i>&nbsp;&nbsp;\r\n                </div>\r\n                <div class=\"app-margin-left-10\">{{applicationName}}</div>\r\n            </div> -->\r\n            <img *ngIf=\"!isMenuCollapsed\" class=\"app-logo-img\" src=\"assets/img/logo/logo.png\" alt=\"\">\r\n            <img *ngIf=\"isMenuCollapsed\" class=\"app-logo-img-sm\" src=\"assets/img/logo/logo_sm.png\" alt=\"\">\r\n        </div>\r\n    </div>\r\n    <div *ngIf=\"!isMenuCollapsed\" class=\"app-sidebar-search\">\r\n        <form novalidate role=\"search\" class=\"app-search\" (ngSubmit)=\"onSearchRequest()\">\r\n            <input type=\"text\" placeholder=\"Ricerca...\" [(ngModel)]=\"searchTerm\" (ngModelChange)=\"onSearchModelChanged()\" name=\"search\" class=\"form-control\" autocomplete=\"off\">\r\n            <a><i class=\"far fa-magnifying-glass\"></i></a>\r\n        </form>\r\n    </div>\r\n    <!--Barra laterale con tutte le voci di Menu-->\r\n    <ul class=\"nav nav-sidebar flex-column flex-nowrap\" style=\"position: relative; zoom: 1\" slim-scroll [slimScrollOptions]=\"{height: menuHeight}\">\r\n        <li *ngFor=\"let item of menuItems; let last = last;\" \r\n            class=\"sidebar-list-item level-{{item.level}}\" \r\n            [style.margin-bottom]=\"last ? '42px' : '0px'\" \r\n            [class.has-sub-menu]=\"item.subMenu\"\r\n            [class.sidebar-item-expanded]=\"item.expanded\" \r\n            [class.sidebar-item-wip]=\"item.wip\">\r\n            <ng-container *ngTemplateOutlet=\"menuItem; context : { $implicit: item }\"></ng-container>\r\n        </li>\r\n    </ul>\r\n    <!--Selettore Barra dei Menu-->\r\n    <div class=\"sidebar-hover-elem\"></div>\r\n    <!--Footer-->\r\n    <div *ngIf=\"!isMenuCollapsed\" class=\"app-sidebar-footer\">\r\n        <!--Minuscolo fade tra sidebar e inizio footer-->\r\n        <div class=\"app-sidebar-footer-fade\"></div>\r\n        <div class=\"app-padding-15\">\r\n            <!--Informazioni utente collegato-->\r\n            <div class=\"app-sidebar-footer-user-container\">\r\n                <!--Mentre sto ancora caricando la ProfilePic mi assicuro di mostrare un placeholder-->\r\n                <div *ngIf=\"!safeprofilepic\" class=\"app-sidebar-footer-user-img-placeholder\">\r\n                    <i class=\"far fa-2x fa-spinner fa-spin-pulse\" style=\"color: black; margin-top: 5px;\"></i>\r\n                </div>\r\n                <!--Una volta caricata la ProfilePic nascondo il placeholder e la mostro-->\r\n                <ng-container *ngIf=\"safeprofilepic\">\r\n                    <img [src]=\"safeprofilepic\" alt=\"\" class=\"app-sidebar-footer-user-img app-pointer\" [routerLink]=\"['/pages/profile/user_info']\">\r\n                    <div class=\"app-sidebar-footer-user-status\"></div>\r\n                </ng-container>\r\n                <!--Username animato quando supera i 15 caratteri-->\r\n                <div class=\"app-sidebar-footer-user-name-container\">\r\n                    <div class=\"username-text\" [class.username-text-animator]=\"user?.length > 15\">{{user}}</div>\r\n                    <div class=\"tenantname-text\">{{tenant}}</div>\r\n                </div>\r\n            </div>\r\n            <!--Operazioni rapide (Logout, Cambia tenant, Guida, Supporto,...)-->\r\n            <div class=\"app-sidebar-footer-quick-ops\">\r\n                <div (click)=\"onLogout();\" class=\"app-sidebar-footer-op app-no-selection\"><i class=\"far fa-right-from-bracket\"></i>&nbsp;Logout</div>\r\n                <div (click)=\"onChangeTenant();\" class=\"app-sidebar-footer-op app-no-selection\"><i class=\"far fa-right-left\"></i>&nbsp;Cambia Tenant</div>\r\n            </div>\r\n            <!--Versione corrente applicazione-->\r\n            <div class=\"app-sidebar-footer-ver\">\r\n                v{{applicationVersion}}\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>\r\n\r\n<ng-template #menuItem let-item>\r\n    <a [attr.style.padding_left]=\"item.padding_left\" *ngIf=\"(!item.routerLink && !item.subMenu) || item.wip\" [href]=\"item.link ? item.link : '#'\" (click)=\"item.wip && $event.preventDefault()\" target=\"_blank\" class=\"sidebar-list-link {{item.cssClass || ''}}\" (mouseenter.out-zone)=\"hoverItem($event)\">\r\n        <i *ngIf=\"item.icon\" class=\"{{ item.icon }}\"></i><span>{{ item.title | localize : lc }}</span>\r\n    </a>\r\n\r\n    <a [attr.style.padding_left]=\"item.padding_left\" *ngIf=\"item.routerLink && !item.subMenu && !item.wip\" class=\"sidebar-list-link {{item.cssClass || ''}}\" [routerLink]=\"[item.routerLink]\" [queryParams]=\"item.queryParams\" routerLinkActive=\"active-link\" (click.out-zone)=\"collapseMenu($event, item)\" (mouseenter.out-zone)=\"hoverItem($event)\">\r\n        <i *ngIf=\"item.icon\" class=\"{{ item.icon }}\"></i><span>{{ item.title | localize : lc }}</span>\r\n    </a>\r\n\r\n    <a [attr.style.padding_left]=\"item.padding_left\" *ngIf=\"item.subMenu && !item.wip\" (click.out-zone)=\"collapseMenu($event, item)\" [attr.href]=\"''\" class=\"sidebar-list-link {{item.cssClass || ''}}\" (mouseenter.out-zone)=\"hoverItem($event)\">\r\n        <i *ngIf=\"item.icon\" class=\"{{ item.icon }}\"></i><span>{{ item.title | localize : lc }}</span>\r\n        <b class=\"far fa-angle-down\"></b>\r\n    </a>\r\n\r\n    <ul *ngIf=\"item.subMenu\" class=\"sidebar-sublist\">\r\n        <li *ngFor=\"let subitem of item.subMenu\" class=\"sidebar-sublist-item level-{{subitem.level}}\" [class.sidebar-item-wip]=\"subitem.wip\">\r\n            <ng-container *ngTemplateOutlet=\"menuItem; context : { $implicit: subitem }\"></ng-container>\r\n        </li>\r\n    </ul>\r\n</ng-template>\r\n\r\n<!-- Overlay per la ricerca globale -->\r\n<ng-container *ngIf=\"searchingTerm || searchResult\">\r\n    <div class=\"app-absolute app-search-background\">\r\n        <div class=\"app-search-result-box\">\r\n            <ng-container *ngIf=\"searchingTerm\">\r\n                <div class=\"app-search-card\"><i class=\"fa fa-spinner fa-spin\"></i>Sto effettuando la ricerca...</div>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"searchResult && !searchingTerm\">\r\n                <div class=\"row\" style=\"height: 100%;\">\r\n                    <!-- Spazio a sinistra -->\r\n                    <div class=\"col-md-1\"></div>\r\n                    <!-- Blocco con le categorie dei risultati -->\r\n                    <div class=\"col-md-3\">\r\n                        <div class=\"app-search-card\">\r\n                            <div class=\"app-relative\"><a class=\"fa fa-times text-danger app-absolute app-right-0 app-fs-20 app-pointer\" (click)=\"closeSearch();\"></a></div>\r\n                            <h4>Categorie di Ricerca</h4>\r\n                            <div class=\"app-pointer app-link\" [class.app-bold]=\"!SelectedResult && !ShowSingleTable\">\r\n                                <span (click)=\"FilterSearchResults()\">{{SelectedResult ? '-' : '>'}} Mostra Tutto</span>\r\n                            </div>\r\n                            <div *ngFor=\"let item of searchResult.results\" class=\"app-pointer app-link\" [class.app-bold]=\"SelectedResult?.description == item.description\">\r\n                                <span (click)=\"FilterSearchResults(item)\">{{SelectedResult?.description == item.description ? '>' : '-'}} Mostra {{item.description}} ({{item.items?.length}})</span>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                    <!-- Dettaglio risultati -->\r\n                    <div class=\"col-md-7\" style=\"overflow: auto; height: 100%;\">\r\n                        <ng-container *ngIf=\"!SelectedResult && !ShowSingleTable\">\r\n                            <div *ngFor=\"let res of searchResult.results; let i = index;\" class=\"app-search-card\" [style.margin-bottom.px]=\"i == (searchResult.results?.length - 1) ? 2 : 10\">\r\n                                <h4>{{res.description}}</h4>\r\n                                <es-table [(ngModel)]=\"res.items\" [DynamicRowColumnsDefinition]=\"res.est_cols\" [ArraymodeItemsPerPage]=\"10\"></es-table>\r\n                            </div>\r\n                        </ng-container>\r\n                        <ng-container *ngIf=\"SelectedResult && ShowSingleTable\">\r\n                            <div class=\"app-search-card\">\r\n                                <h4>{{SelectedResult.description}}</h4>\r\n                                <es-table [(ngModel)]=\"SelectedResult.items\" [DynamicRowColumnsDefinition]=\"SelectedResult.est_cols\" [ArraymodeItemsPerPage]=\"10\"></es-table>\r\n                            </div>\r\n                        </ng-container>\r\n                    </div>\r\n                    <!-- Spazio a destra -->\r\n                    <div class=\"col-md-1\"></div>\r\n                </div>\r\n            </ng-container>\r\n        </div>\r\n    </div>\r\n</ng-container>"]}
|
|
@@ -1,19 +1,24 @@
|
|
|
1
|
-
export * from './back-top/back-top.component';
|
|
2
|
-
export * from './breadcrumb/breadcrumb.component';
|
|
3
|
-
export * from './error/404/pagenotfound.component';
|
|
4
|
-
export * from './error/500/servererror.component';
|
|
5
|
-
export * from './error/Angular/angularerror.component';
|
|
6
|
-
export * from './page/pages.component';
|
|
7
|
-
export * from './external-page/external_pages.component';
|
|
8
|
-
export * from './jace-login/jace-login.component';
|
|
9
|
-
export * from './navbar/navbar.component';
|
|
10
|
-
export * from './navbar/modules-board/jace-modules-board.component';
|
|
11
|
-
export * from './redirecter/redirecter.component';
|
|
12
|
-
export * from './sidebar/sidebar.component';
|
|
13
|
-
export * from './base/base.component';
|
|
14
|
-
export * from './base/reactive.component';
|
|
15
|
-
export * from './jace-resource/jace-resource.component';
|
|
1
|
+
export * from './page-structure/back-top/back-top.component';
|
|
2
|
+
export * from './page-structure/breadcrumb/breadcrumb.component';
|
|
3
|
+
export * from './page-structure/error/404/pagenotfound.component';
|
|
4
|
+
export * from './page-structure/error/500/servererror.component';
|
|
5
|
+
export * from './page-structure/error/Angular/angularerror.component';
|
|
6
|
+
export * from './page-structure/page/pages.component';
|
|
7
|
+
export * from './page-structure/external-page/external_pages.component';
|
|
8
|
+
export * from './page-structure/jace-login/jace-login.component';
|
|
9
|
+
export * from './page-structure/navbar/navbar.component';
|
|
10
|
+
export * from './page-structure/navbar/modules-board/jace-modules-board.component';
|
|
11
|
+
export * from './page-structure/redirecter/redirecter.component';
|
|
12
|
+
export * from './page-structure/sidebar/sidebar.component';
|
|
13
|
+
export * from './page-structure/base/base.component';
|
|
14
|
+
export * from './page-structure/base/reactive.component';
|
|
15
|
+
export * from './page-structure/jace-resource/jace-resource.component';
|
|
16
16
|
export * from './components.module';
|
|
17
17
|
export * from "./es-modal/es-modal.component";
|
|
18
18
|
export * from "./es-modal/es-modal-head/es-modal-head.component";
|
|
19
|
-
|
|
19
|
+
export * from './search/filters-topbar/filters-topbar.component';
|
|
20
|
+
export * from './search/filters-sidebar/filters-sidebar.component';
|
|
21
|
+
export * from './search/filters-sidebar-section/filters-sidebar-section.component';
|
|
22
|
+
export * from './search/filters-sidebar-item/filters-sidebar-item.component';
|
|
23
|
+
export * from './search/es-filters/es-filters.component';
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsdURBQXVELENBQUM7QUFDdEUsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLHlEQUF5RCxDQUFDO0FBQ3hFLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYywwQ0FBMEMsQ0FBQztBQUN6RCxjQUFjLG9FQUFvRSxDQUFDO0FBQ25GLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYyx3REFBd0QsQ0FBQztBQUN2RSxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYyxvRUFBb0UsQ0FBQztBQUNuRixjQUFjLDhEQUE4RCxDQUFDO0FBQzdFLGNBQWMsMENBQTBDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3BhZ2Utc3RydWN0dXJlL2JhY2stdG9wL2JhY2stdG9wLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcGFnZS1zdHJ1Y3R1cmUvYnJlYWRjcnVtYi9icmVhZGNydW1iLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcGFnZS1zdHJ1Y3R1cmUvZXJyb3IvNDA0L3BhZ2Vub3Rmb3VuZC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3BhZ2Utc3RydWN0dXJlL2Vycm9yLzUwMC9zZXJ2ZXJlcnJvci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3BhZ2Utc3RydWN0dXJlL2Vycm9yL0FuZ3VsYXIvYW5ndWxhcmVycm9yLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcGFnZS1zdHJ1Y3R1cmUvcGFnZS9wYWdlcy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3BhZ2Utc3RydWN0dXJlL2V4dGVybmFsLXBhZ2UvZXh0ZXJuYWxfcGFnZXMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9wYWdlLXN0cnVjdHVyZS9qYWNlLWxvZ2luL2phY2UtbG9naW4uY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9wYWdlLXN0cnVjdHVyZS9uYXZiYXIvbmF2YmFyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcGFnZS1zdHJ1Y3R1cmUvbmF2YmFyL21vZHVsZXMtYm9hcmQvamFjZS1tb2R1bGVzLWJvYXJkLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcGFnZS1zdHJ1Y3R1cmUvcmVkaXJlY3Rlci9yZWRpcmVjdGVyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcGFnZS1zdHJ1Y3R1cmUvc2lkZWJhci9zaWRlYmFyLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcGFnZS1zdHJ1Y3R1cmUvYmFzZS9iYXNlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcGFnZS1zdHJ1Y3R1cmUvYmFzZS9yZWFjdGl2ZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3BhZ2Utc3RydWN0dXJlL2phY2UtcmVzb3VyY2UvamFjZS1yZXNvdXJjZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMubW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSBcIi4vZXMtbW9kYWwvZXMtbW9kYWwuY29tcG9uZW50XCI7XHJcbmV4cG9ydCAqIGZyb20gXCIuL2VzLW1vZGFsL2VzLW1vZGFsLWhlYWQvZXMtbW9kYWwtaGVhZC5jb21wb25lbnRcIjtcclxuZXhwb3J0ICogZnJvbSAnLi9zZWFyY2gvZmlsdGVycy10b3BiYXIvZmlsdGVycy10b3BiYXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9zZWFyY2gvZmlsdGVycy1zaWRlYmFyL2ZpbHRlcnMtc2lkZWJhci5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NlYXJjaC9maWx0ZXJzLXNpZGViYXItc2VjdGlvbi9maWx0ZXJzLXNpZGViYXItc2VjdGlvbi5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NlYXJjaC9maWx0ZXJzLXNpZGViYXItaXRlbS9maWx0ZXJzLXNpZGViYXItaXRlbS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NlYXJjaC9lcy1maWx0ZXJzL2VzLWZpbHRlcnMuY29tcG9uZW50JzsiXX0=
|