@mediusinc/mng-commons-layout 6.0.0-rc.2 → 6.0.0-rc.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/README.md +3 -0
- package/components/index.d.ts +10 -0
- package/{lib → components/lib}/components/footer.component.d.ts +1 -1
- package/{lib → components/lib}/components/main-layout.component.d.ts +1 -1
- package/{lib → components/lib}/components/menu-item.component.d.ts +2 -2
- package/{lib → components/lib}/components/menu.component.d.ts +1 -1
- package/{lib → components/lib}/components/settings.component.d.ts +1 -2
- package/{lib → components/lib}/components/sidebar.component.d.ts +1 -1
- package/{lib → components/lib}/components/topbar.component.d.ts +2 -2
- package/components/pages/error/README.md +3 -0
- package/components/pages/error/index.d.ts +3 -0
- package/{lib/components/pages/error → components/pages/error/lib}/error.page.component.d.ts +1 -1
- package/components/pages/main/README.md +3 -0
- package/components/pages/main/index.d.ts +2 -0
- package/components/pages/main/lazy/README.md +3 -0
- package/components/pages/main/lazy/index.d.ts +1 -0
- package/components/pages/main/lazy/lib/route-builder.d.ts +8 -0
- package/components/pages/main/lib/main-layout.component.d.ts +23 -0
- package/components/pages/not-found/README.md +3 -0
- package/components/pages/not-found/index.d.ts +3 -0
- package/{lib/components/pages/not-found → components/pages/not-found/lib}/not-found.page.component.d.ts +1 -1
- package/esm2022/components/index.mjs +12 -0
- package/esm2022/components/lib/components/breadcrumb.component.mjs +29 -0
- package/esm2022/components/lib/components/footer.component.mjs +23 -0
- package/esm2022/components/lib/components/main-layout.component.mjs +86 -0
- package/esm2022/components/lib/components/menu-item.component.mjs +169 -0
- package/esm2022/components/lib/components/menu.component.mjs +36 -0
- package/esm2022/components/lib/components/settings.component.mjs +87 -0
- package/esm2022/components/lib/components/sidebar.component.mjs +51 -0
- package/esm2022/components/lib/components/topbar-user.component.mjs +51 -0
- package/esm2022/components/lib/components/topbar.component.mjs +37 -0
- package/esm2022/components/lib/components/version.component.mjs +95 -0
- package/esm2022/components/mediusinc-mng-commons-layout-components.mjs +5 -0
- package/esm2022/components/pages/error/index.mjs +4 -0
- package/esm2022/components/pages/error/lib/error.page.component.mjs +20 -0
- package/esm2022/components/pages/error/mediusinc-mng-commons-layout-components-pages-error.mjs +5 -0
- package/esm2022/components/pages/main/index.mjs +3 -0
- package/esm2022/components/pages/main/lazy/index.mjs +2 -0
- package/esm2022/components/pages/main/lazy/lib/route-builder.mjs +11 -0
- package/esm2022/components/pages/main/lazy/mediusinc-mng-commons-layout-components-pages-main-lazy.mjs +5 -0
- package/esm2022/components/pages/main/lib/main-layout.component.mjs +84 -0
- package/esm2022/components/pages/main/lib/route-builder.mjs +12 -0
- package/esm2022/components/pages/main/mediusinc-mng-commons-layout-components-pages-main.mjs +5 -0
- package/esm2022/components/pages/not-found/index.mjs +4 -0
- package/esm2022/components/pages/not-found/lib/not-found.page.component.mjs +20 -0
- package/esm2022/components/pages/not-found/mediusinc-mng-commons-layout-components-pages-not-found.mjs +5 -0
- package/esm2022/index.mjs +2 -15
- package/esm2022/lib/helpers/menu-items.mjs +4 -1
- package/esm2022/lib/services/layout-feature-config.token.mjs +1 -1
- package/fesm2022/mediusinc-mng-commons-layout-components-pages-error.mjs +27 -0
- package/fesm2022/mediusinc-mng-commons-layout-components-pages-error.mjs.map +1 -0
- package/fesm2022/mediusinc-mng-commons-layout-components-pages-main-lazy.mjs +18 -0
- package/fesm2022/mediusinc-mng-commons-layout-components-pages-main-lazy.mjs.map +1 -0
- package/fesm2022/mediusinc-mng-commons-layout-components-pages-main.mjs +101 -0
- package/fesm2022/mediusinc-mng-commons-layout-components-pages-main.mjs.map +1 -0
- package/fesm2022/mediusinc-mng-commons-layout-components-pages-not-found.mjs +27 -0
- package/fesm2022/mediusinc-mng-commons-layout-components-pages-not-found.mjs.map +1 -0
- package/fesm2022/mediusinc-mng-commons-layout-components.mjs +600 -0
- package/fesm2022/mediusinc-mng-commons-layout-components.mjs.map +1 -0
- package/fesm2022/mediusinc-mng-commons-layout.mjs +69 -683
- package/fesm2022/mediusinc-mng-commons-layout.mjs.map +1 -1
- package/index.d.ts +1 -13
- package/lib/helpers/menu-items.d.ts +3 -0
- package/lib/services/layout-feature-config.token.d.ts +2 -2
- package/lib/services/layout.service.d.ts +2 -2
- package/package.json +32 -2
- package/version-info.json +6 -6
- package/esm2022/lib/components/breadcrumb.component.mjs +0 -29
- package/esm2022/lib/components/footer.component.mjs +0 -25
- package/esm2022/lib/components/main-layout.component.mjs +0 -88
- package/esm2022/lib/components/menu-item.component.mjs +0 -170
- package/esm2022/lib/components/menu.component.mjs +0 -38
- package/esm2022/lib/components/pages/error/error.page.component.mjs +0 -20
- package/esm2022/lib/components/pages/not-found/not-found.page.component.mjs +0 -20
- package/esm2022/lib/components/settings.component.mjs +0 -87
- package/esm2022/lib/components/sidebar.component.mjs +0 -52
- package/esm2022/lib/components/topbar-user.component.mjs +0 -52
- package/esm2022/lib/components/topbar.component.mjs +0 -39
- package/esm2022/lib/components/version.component.mjs +0 -96
- package/esm2022/lib/helpers/route-builder.mjs +0 -12
- /package/{lib → components/lib}/components/breadcrumb.component.d.ts +0 -0
- /package/{lib → components/lib}/components/topbar-user.component.d.ts +0 -0
- /package/{lib → components/lib}/components/version.component.d.ts +0 -0
- /package/{lib/helpers → components/pages/main/lib}/route-builder.d.ts +0 -0
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export * from './lib/components/footer.component';
|
|
2
|
+
export * from './lib/components/breadcrumb.component';
|
|
3
|
+
export * from './lib/components/main-layout.component';
|
|
4
|
+
export * from './lib/components/menu.component';
|
|
5
|
+
export * from './lib/components/menu-item.component';
|
|
6
|
+
export * from './lib/components/settings.component';
|
|
7
|
+
export * from './lib/components/sidebar.component';
|
|
8
|
+
export * from './lib/components/topbar.component';
|
|
9
|
+
export * from './lib/components/topbar-user.component';
|
|
10
|
+
export * from './lib/components/version.component';
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Type } from '@angular/core';
|
|
2
|
+
import { LayoutService } from '@mediusinc/mng-commons-layout';
|
|
2
3
|
import { CommonsService } from '@mediusinc/mng-commons/core';
|
|
3
|
-
import { LayoutService } from '../services/layout.service';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class FooterComponent {
|
|
6
6
|
private config;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { OnDestroy, Type } from '@angular/core';
|
|
2
|
-
import { LayoutService } from '
|
|
2
|
+
import { LayoutService } from '@mediusinc/mng-commons-layout';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export declare class MainLayoutComponent implements OnDestroy {
|
|
5
5
|
private readonly config;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { AnimationEvent } from '@angular/animations';
|
|
2
|
+
import { LayoutService } from '@mediusinc/mng-commons-layout';
|
|
2
3
|
import { InternalCommonsMenuItem } from '@mediusinc/mng-commons/core';
|
|
3
|
-
import { LayoutService } from '../services/layout.service';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class MenuItemComponent {
|
|
6
6
|
private readonly menuService;
|
|
@@ -15,7 +15,7 @@ export declare class MenuItemComponent {
|
|
|
15
15
|
private menuChangeEvents;
|
|
16
16
|
active: import("@angular/core").Signal<boolean>;
|
|
17
17
|
visible: import("@angular/core").Signal<boolean>;
|
|
18
|
-
submenuAnimation: import("@angular/core").Signal<"
|
|
18
|
+
submenuAnimation: import("@angular/core").Signal<"collapsed" | "expanded" | "hidden" | "visible">;
|
|
19
19
|
constructor();
|
|
20
20
|
itemClick(event: Event): void;
|
|
21
21
|
onSubmenuAnimated(event: AnimationEvent): void;
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import { Injector } from '@angular/core';
|
|
2
2
|
import { TranslateService } from '@ngx-translate/core';
|
|
3
|
+
import { LayoutMenuMode, LayoutService } from '@mediusinc/mng-commons-layout';
|
|
3
4
|
import { ColorScheme, CommonsService } from '@mediusinc/mng-commons/core';
|
|
4
|
-
import { LayoutMenuMode } from '../services/layout-feature-config.token';
|
|
5
|
-
import { LayoutService } from '../services/layout.service';
|
|
6
5
|
import * as i0 from "@angular/core";
|
|
7
6
|
interface ColorSchemeOption {
|
|
8
7
|
value: ColorScheme;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ElementRef, Type } from '@angular/core';
|
|
2
|
-
import { LayoutService } from '
|
|
2
|
+
import { LayoutService } from '@mediusinc/mng-commons-layout';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export declare class SidebarComponent {
|
|
5
5
|
private readonly config;
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { ElementRef, Type } from '@angular/core';
|
|
2
|
+
import { LayoutService } from '@mediusinc/mng-commons-layout';
|
|
2
3
|
import { CommonsService } from '@mediusinc/mng-commons/core';
|
|
3
|
-
import { LayoutService } from '../services/layout.service';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class TopbarComponent {
|
|
6
6
|
readonly el: ElementRef<any>;
|
|
7
7
|
readonly commons: CommonsService;
|
|
8
8
|
readonly layout: LayoutService;
|
|
9
|
-
|
|
9
|
+
protected readonly config: import("@mediusinc/mng-commons-layout").LayoutFeatureConfig | null;
|
|
10
10
|
topbarUserComponent: import("@angular/core").WritableSignal<Type<any> | undefined>;
|
|
11
11
|
breadcrumbComponent: import("@angular/core").WritableSignal<Type<any> | undefined>;
|
|
12
12
|
onMenuButtonClick(): void;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './lib/route-builder';
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { RouteBuilder } from '@mediusinc/mng-commons/core';
|
|
2
|
+
/**
|
|
3
|
+
* Creates a layout route on the specified path.
|
|
4
|
+
*
|
|
5
|
+
* @param {String} path - The path of the route.
|
|
6
|
+
* @return {RouteBuilder} - The route builder for the layout route.
|
|
7
|
+
*/
|
|
8
|
+
export declare function createLayoutLazyRoute(path: string): RouteBuilder;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { OnDestroy, Type } from '@angular/core';
|
|
2
|
+
import { LayoutService } from '@mediusinc/mng-commons-layout';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class MainLayoutComponent implements OnDestroy {
|
|
5
|
+
private readonly config;
|
|
6
|
+
readonly layout: LayoutService;
|
|
7
|
+
private readonly menuService;
|
|
8
|
+
private readonly renderer;
|
|
9
|
+
private appTopbar;
|
|
10
|
+
readonly ripple: import("@angular/core").WritableSignal<boolean>;
|
|
11
|
+
topbarComponent: import("@angular/core").WritableSignal<Type<any> | undefined>;
|
|
12
|
+
breadcrumbsComponent: import("@angular/core").WritableSignal<Type<any> | undefined>;
|
|
13
|
+
footerComponent: import("@angular/core").WritableSignal<Type<any> | undefined>;
|
|
14
|
+
useNotificationWrapper: import("@angular/core").WritableSignal<boolean>;
|
|
15
|
+
private menuOutsideClickListener;
|
|
16
|
+
constructor();
|
|
17
|
+
blockBodyScroll(): void;
|
|
18
|
+
unblockBodyScroll(): void;
|
|
19
|
+
hideMenu(): void;
|
|
20
|
+
ngOnDestroy(): void;
|
|
21
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<MainLayoutComponent, never>;
|
|
22
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<MainLayoutComponent, "mng-main-layout", never, {}, {}, never, never, true, never>;
|
|
23
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
// components
|
|
2
|
+
export * from './lib/components/footer.component';
|
|
3
|
+
export * from './lib/components/breadcrumb.component';
|
|
4
|
+
export * from './lib/components/main-layout.component';
|
|
5
|
+
export * from './lib/components/menu.component';
|
|
6
|
+
export * from './lib/components/menu-item.component';
|
|
7
|
+
export * from './lib/components/settings.component';
|
|
8
|
+
export * from './lib/components/sidebar.component';
|
|
9
|
+
export * from './lib/components/topbar.component';
|
|
10
|
+
export * from './lib/components/topbar-user.component';
|
|
11
|
+
export * from './lib/components/version.component';
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9jb21wb25lbnRzL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxhQUFhO0FBQ2IsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyxvQ0FBb0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8vIGNvbXBvbmVudHNcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvZm9vdGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2JyZWFkY3J1bWIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvbWFpbi1sYXlvdXQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvbWVudS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9tZW51LWl0ZW0uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvc2V0dGluZ3MuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvc2lkZWJhci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy90b3BiYXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvdG9wYmFyLXVzZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvdmVyc2lvbi5jb21wb25lbnQnO1xuIl19
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, inject } from '@angular/core';
|
|
2
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
3
|
+
import { CommonsService } from '@mediusinc/mng-commons/core';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@ngx-translate/core";
|
|
6
|
+
export class BreadcrumbComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.commons = inject(CommonsService);
|
|
9
|
+
this.mappedBreadcrumbs = computed(() => {
|
|
10
|
+
const items = this.commons.breadcrumbs();
|
|
11
|
+
return items.map(el => this.mapMenuItem(el));
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
mapMenuItem(item) {
|
|
15
|
+
return {
|
|
16
|
+
...item,
|
|
17
|
+
url: item.href,
|
|
18
|
+
badgeStyleClass: item.badgeClassName,
|
|
19
|
+
styleClass: item.className
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: BreadcrumbComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
23
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.12", type: BreadcrumbComponent, isStandalone: true, selector: "mng-breadcrumb", ngImport: i0, template: "<div class=\"layout-breadcrumb flex align-items-center relative h-3rem\">\n <nav>\n <ol class=\"relative z-2\">\n @for (item of mappedBreadcrumbs(); track item.id; let last = $last) {\n <li>{{ item.label! | translate }}</li>\n @if (!last) {\n <li class=\"layout-breadcrumb-chevron\">/</li>\n }\n }\n </ol>\n </nav>\n</div>\n", dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
24
|
+
}
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: BreadcrumbComponent, decorators: [{
|
|
26
|
+
type: Component,
|
|
27
|
+
args: [{ standalone: true, selector: 'mng-breadcrumb', imports: [TranslateModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"layout-breadcrumb flex align-items-center relative h-3rem\">\n <nav>\n <ol class=\"relative z-2\">\n @for (item of mappedBreadcrumbs(); track item.id; let last = $last) {\n <li>{{ item.label! | translate }}</li>\n @if (!last) {\n <li class=\"layout-breadcrumb-chevron\">/</li>\n }\n }\n </ol>\n </nav>\n</div>\n" }]
|
|
28
|
+
}] });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJlYWRjcnVtYi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9icmVhZGNydW1iLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL2NvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2JyZWFkY3J1bWIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRW5GLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUdwRCxPQUFPLEVBQWtCLGNBQWMsRUFBQyxNQUFNLDZCQUE2QixDQUFDOzs7QUFTNUUsTUFBTSxPQUFPLG1CQUFtQjtJQVBoQztRQVFZLFlBQU8sR0FBRyxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUM7UUFFbEMsc0JBQWlCLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUNyQyxNQUFNLEtBQUssR0FBc0IsSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUM1RCxPQUFPLEtBQUssQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDakQsQ0FBQyxDQUFDLENBQUM7S0FVTjtJQVJXLFdBQVcsQ0FBQyxJQUFxQjtRQUNyQyxPQUFPO1lBQ0gsR0FBRyxJQUFJO1lBQ1AsR0FBRyxFQUFFLElBQUksQ0FBQyxJQUFJO1lBQ2QsZUFBZSxFQUFFLElBQUksQ0FBQyxjQUFjO1lBQ3BDLFVBQVUsRUFBRSxJQUFJLENBQUMsU0FBUztTQUM3QixDQUFDO0lBQ04sQ0FBQzsrR0FmUSxtQkFBbUI7bUdBQW5CLG1CQUFtQiwwRUNkaEMsZ2JBWUEsMkNERmMsZUFBZTs7NEZBSWhCLG1CQUFtQjtrQkFQL0IsU0FBUztpQ0FDTSxJQUFJLFlBQ04sZ0JBQWdCLFdBQ2pCLENBQUMsZUFBZSxDQUFDLG1CQUVULHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGNvbXB1dGVkLCBpbmplY3R9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge1RyYW5zbGF0ZU1vZHVsZX0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQge01lbnVJdGVtfSBmcm9tICdwcmltZW5nL2FwaSc7XG5cbmltcG9ydCB7Q29tbW9uc01lbnVJdGVtLCBDb21tb25zU2VydmljZX0gZnJvbSAnQG1lZGl1c2luYy9tbmctY29tbW9ucy9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBzZWxlY3RvcjogJ21uZy1icmVhZGNydW1iJyxcbiAgICBpbXBvcnRzOiBbVHJhbnNsYXRlTW9kdWxlXSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vYnJlYWRjcnVtYi5jb21wb25lbnQuaHRtbCcsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgQnJlYWRjcnVtYkNvbXBvbmVudCB7XG4gICAgcHJpdmF0ZSBjb21tb25zID0gaW5qZWN0KENvbW1vbnNTZXJ2aWNlKTtcblxuICAgIHB1YmxpYyBtYXBwZWRCcmVhZGNydW1icyA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICAgICAgY29uc3QgaXRlbXM6IENvbW1vbnNNZW51SXRlbVtdID0gdGhpcy5jb21tb25zLmJyZWFkY3J1bWJzKCk7XG4gICAgICAgIHJldHVybiBpdGVtcy5tYXAoZWwgPT4gdGhpcy5tYXBNZW51SXRlbShlbCkpO1xuICAgIH0pO1xuXG4gICAgcHJpdmF0ZSBtYXBNZW51SXRlbShpdGVtOiBDb21tb25zTWVudUl0ZW0pOiBNZW51SXRlbSB7XG4gICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAuLi5pdGVtLFxuICAgICAgICAgICAgdXJsOiBpdGVtLmhyZWYsXG4gICAgICAgICAgICBiYWRnZVN0eWxlQ2xhc3M6IGl0ZW0uYmFkZ2VDbGFzc05hbWUsXG4gICAgICAgICAgICBzdHlsZUNsYXNzOiBpdGVtLmNsYXNzTmFtZVxuICAgICAgICB9O1xuICAgIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJsYXlvdXQtYnJlYWRjcnVtYiBmbGV4IGFsaWduLWl0ZW1zLWNlbnRlciByZWxhdGl2ZSBoLTNyZW1cIj5cbiAgICA8bmF2PlxuICAgICAgICA8b2wgY2xhc3M9XCJyZWxhdGl2ZSB6LTJcIj5cbiAgICAgICAgICAgIEBmb3IgKGl0ZW0gb2YgbWFwcGVkQnJlYWRjcnVtYnMoKTsgdHJhY2sgaXRlbS5pZDsgbGV0IGxhc3QgPSAkbGFzdCkge1xuICAgICAgICAgICAgICAgIDxsaT57eyBpdGVtLmxhYmVsISB8IHRyYW5zbGF0ZSB9fTwvbGk+XG4gICAgICAgICAgICAgICAgQGlmICghbGFzdCkge1xuICAgICAgICAgICAgICAgICAgICA8bGkgY2xhc3M9XCJsYXlvdXQtYnJlYWRjcnVtYi1jaGV2cm9uXCI+LzwvbGk+XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICA8L29sPlxuICAgIDwvbmF2PlxuPC9kaXY+XG4iXX0=
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, inject, signal } from '@angular/core';
|
|
2
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
3
|
+
import { COMMONS_LAYOUT_FEATURE_CONFIG_IT, LayoutService } from '@mediusinc/mng-commons-layout';
|
|
4
|
+
import { CommonsService, ComponentDirective } from '@mediusinc/mng-commons/core';
|
|
5
|
+
import { VersionComponent } from './version.component';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@ngx-translate/core";
|
|
8
|
+
export class FooterComponent {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.config = inject(COMMONS_LAYOUT_FEATURE_CONFIG_IT, { optional: true });
|
|
11
|
+
this.layout = inject(LayoutService);
|
|
12
|
+
this.commons = inject(CommonsService);
|
|
13
|
+
this.currentYear = signal(new Date().getFullYear());
|
|
14
|
+
this.versionComponent = signal(this.config?.components?.version === false ? undefined : (this.config?.components?.version ?? VersionComponent));
|
|
15
|
+
}
|
|
16
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: FooterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
17
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.12", type: FooterComponent, isStandalone: true, selector: "mng-footer", ngImport: i0, template: "<div class=\"layout-footer\">\n <div class=\"footer-logo-container\">\n @if (layout.appLogo()) {\n <img id=\"footer-logo\" [src]=\"layout.appLogo()\" alt=\"atlantis-layout\" />\n }\n <span class=\"app-name\">{{ commons.appName() | translate }}</span>\n </div>\n <div class=\"flex flex-column\">\n <div>\n <span class=\"copyright\">© {{ commons.appOwner() | translate }} - {{ currentYear() }}</span>\n </div>\n @if (versionComponent()) {\n <div class=\"version\" [mngComponent]=\"versionComponent()\" [inputs]=\"{version: commons.appVersion()}\" [attachToHost]=\"true\"></div>\n }\n </div>\n</div>\n", dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "directive", type: ComponentDirective, selector: "[mngComponent]", inputs: ["mngComponent", "injectionToken", "inputs", "attachToHost", "parentInjector"], outputs: ["instanceCreated"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
18
|
+
}
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: FooterComponent, decorators: [{
|
|
20
|
+
type: Component,
|
|
21
|
+
args: [{ standalone: true, selector: 'mng-footer', imports: [TranslateModule, ComponentDirective], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"layout-footer\">\n <div class=\"footer-logo-container\">\n @if (layout.appLogo()) {\n <img id=\"footer-logo\" [src]=\"layout.appLogo()\" alt=\"atlantis-layout\" />\n }\n <span class=\"app-name\">{{ commons.appName() | translate }}</span>\n </div>\n <div class=\"flex flex-column\">\n <div>\n <span class=\"copyright\">© {{ commons.appOwner() | translate }} - {{ currentYear() }}</span>\n </div>\n @if (versionComponent()) {\n <div class=\"version\" [mngComponent]=\"versionComponent()\" [inputs]=\"{version: commons.appVersion()}\" [attachToHost]=\"true\"></div>\n }\n </div>\n</div>\n" }]
|
|
22
|
+
}] });
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9vdGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2NvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2Zvb3Rlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9mb290ZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBUSxNQUFNLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRXZGLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUVwRCxPQUFPLEVBQUMsZ0NBQWdDLEVBQUUsYUFBYSxFQUFDLE1BQU0sK0JBQStCLENBQUM7QUFDOUYsT0FBTyxFQUFDLGNBQWMsRUFBRSxrQkFBa0IsRUFBQyxNQUFNLDZCQUE2QixDQUFDO0FBRS9FLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLHFCQUFxQixDQUFDOzs7QUFTckQsTUFBTSxPQUFPLGVBQWU7SUFQNUI7UUFRWSxXQUFNLEdBQUcsTUFBTSxDQUFDLGdDQUFnQyxFQUFFLEVBQUMsUUFBUSxFQUFFLElBQUksRUFBQyxDQUFDLENBQUM7UUFDNUQsV0FBTSxHQUFHLE1BQU0sQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUN4QyxZQUFPLEdBQUcsTUFBTSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBRWpDLGdCQUFXLEdBQUcsTUFBTSxDQUFDLElBQUksSUFBSSxFQUFFLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztRQUMvQyxxQkFBZ0IsR0FBRyxNQUFNLENBQXdCLElBQUksQ0FBQyxNQUFNLEVBQUUsVUFBVSxFQUFFLE9BQU8sS0FBSyxLQUFLLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLFVBQVUsRUFBRSxPQUFPLElBQUksZ0JBQWdCLENBQUMsQ0FBQyxDQUFDO0tBQzVLOytHQVBZLGVBQWU7bUdBQWYsZUFBZSxzRUNoQjVCLDJyQkFnQkEsMkNESGMsZUFBZSw0RkFBRSxrQkFBa0I7OzRGQUdwQyxlQUFlO2tCQVAzQixTQUFTO2lDQUNNLElBQUksWUFDTixZQUFZLFdBRWIsQ0FBQyxlQUFlLEVBQUUsa0JBQWtCLENBQUMsbUJBQzdCLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIFR5cGUsIGluamVjdCwgc2lnbmFsfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtUcmFuc2xhdGVNb2R1bGV9IGZyb20gJ0BuZ3gtdHJhbnNsYXRlL2NvcmUnO1xuXG5pbXBvcnQge0NPTU1PTlNfTEFZT1VUX0ZFQVRVUkVfQ09ORklHX0lULCBMYXlvdXRTZXJ2aWNlfSBmcm9tICdAbWVkaXVzaW5jL21uZy1jb21tb25zLWxheW91dCc7XG5pbXBvcnQge0NvbW1vbnNTZXJ2aWNlLCBDb21wb25lbnREaXJlY3RpdmV9IGZyb20gJ0BtZWRpdXNpbmMvbW5nLWNvbW1vbnMvY29yZSc7XG5cbmltcG9ydCB7VmVyc2lvbkNvbXBvbmVudH0gZnJvbSAnLi92ZXJzaW9uLmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc2VsZWN0b3I6ICdtbmctZm9vdGVyJyxcbiAgICB0ZW1wbGF0ZVVybDogJ2Zvb3Rlci5jb21wb25lbnQuaHRtbCcsXG4gICAgaW1wb3J0czogW1RyYW5zbGF0ZU1vZHVsZSwgQ29tcG9uZW50RGlyZWN0aXZlXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBGb290ZXJDb21wb25lbnQge1xuICAgIHByaXZhdGUgY29uZmlnID0gaW5qZWN0KENPTU1PTlNfTEFZT1VUX0ZFQVRVUkVfQ09ORklHX0lULCB7b3B0aW9uYWw6IHRydWV9KTtcbiAgICBwdWJsaWMgcmVhZG9ubHkgbGF5b3V0ID0gaW5qZWN0KExheW91dFNlcnZpY2UpO1xuICAgIHB1YmxpYyBjb21tb25zID0gaW5qZWN0KENvbW1vbnNTZXJ2aWNlKTtcblxuICAgIHB1YmxpYyBjdXJyZW50WWVhciA9IHNpZ25hbChuZXcgRGF0ZSgpLmdldEZ1bGxZZWFyKCkpO1xuICAgIHB1YmxpYyB2ZXJzaW9uQ29tcG9uZW50ID0gc2lnbmFsPFR5cGU8YW55PiB8IHVuZGVmaW5lZD4odGhpcy5jb25maWc/LmNvbXBvbmVudHM/LnZlcnNpb24gPT09IGZhbHNlID8gdW5kZWZpbmVkIDogKHRoaXMuY29uZmlnPy5jb21wb25lbnRzPy52ZXJzaW9uID8/IFZlcnNpb25Db21wb25lbnQpKTtcbn1cbiIsIjxkaXYgY2xhc3M9XCJsYXlvdXQtZm9vdGVyXCI+XG4gICAgPGRpdiBjbGFzcz1cImZvb3Rlci1sb2dvLWNvbnRhaW5lclwiPlxuICAgICAgICBAaWYgKGxheW91dC5hcHBMb2dvKCkpIHtcbiAgICAgICAgICAgIDxpbWcgaWQ9XCJmb290ZXItbG9nb1wiIFtzcmNdPVwibGF5b3V0LmFwcExvZ28oKVwiIGFsdD1cImF0bGFudGlzLWxheW91dFwiIC8+XG4gICAgICAgIH1cbiAgICAgICAgPHNwYW4gY2xhc3M9XCJhcHAtbmFtZVwiPnt7IGNvbW1vbnMuYXBwTmFtZSgpIHwgdHJhbnNsYXRlIH19PC9zcGFuPlxuICAgIDwvZGl2PlxuICAgIDxkaXYgY2xhc3M9XCJmbGV4IGZsZXgtY29sdW1uXCI+XG4gICAgICAgIDxkaXY+XG4gICAgICAgICAgICA8c3BhbiBjbGFzcz1cImNvcHlyaWdodFwiPiYjMTY5OyB7eyBjb21tb25zLmFwcE93bmVyKCkgfCB0cmFuc2xhdGUgfX0gLSB7eyBjdXJyZW50WWVhcigpIH19PC9zcGFuPlxuICAgICAgICA8L2Rpdj5cbiAgICAgICAgQGlmICh2ZXJzaW9uQ29tcG9uZW50KCkpIHtcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJ2ZXJzaW9uXCIgW21uZ0NvbXBvbmVudF09XCJ2ZXJzaW9uQ29tcG9uZW50KClcIiBbaW5wdXRzXT1cInt2ZXJzaW9uOiBjb21tb25zLmFwcFZlcnNpb24oKX1cIiBbYXR0YWNoVG9Ib3N0XT1cInRydWVcIj48L2Rpdj5cbiAgICAgICAgfVxuICAgIDwvZGl2PlxuPC9kaXY+XG4iXX0=
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { NgClass, NgTemplateOutlet } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, Renderer2, inject, signal, viewChild } from '@angular/core';
|
|
3
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
4
|
+
import { RouterModule } from '@angular/router';
|
|
5
|
+
import { COMMONS_LAYOUT_FEATURE_CONFIG_IT, LayoutService, MenuService } from '@mediusinc/mng-commons-layout';
|
|
6
|
+
import { ComponentDirective, NotificationWrapperComponent } from '@mediusinc/mng-commons/core';
|
|
7
|
+
import { BreadcrumbComponent } from './breadcrumb.component';
|
|
8
|
+
import { FooterComponent } from './footer.component';
|
|
9
|
+
import { TopbarComponent } from './topbar.component';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@angular/router";
|
|
12
|
+
export class MainLayoutComponent {
|
|
13
|
+
constructor() {
|
|
14
|
+
// private readonly commonsService = inject(CommonsService);
|
|
15
|
+
this.config = inject(COMMONS_LAYOUT_FEATURE_CONFIG_IT, { optional: true });
|
|
16
|
+
this.layout = inject(LayoutService);
|
|
17
|
+
this.menuService = inject(MenuService);
|
|
18
|
+
this.renderer = inject(Renderer2);
|
|
19
|
+
this.appTopbar = viewChild('topbarCmp');
|
|
20
|
+
this.ripple = signal(this.config?.ripple ?? true);
|
|
21
|
+
this.topbarComponent = signal(this.config?.components?.topbar === false ? undefined : (this.config?.components?.topbar ?? TopbarComponent));
|
|
22
|
+
this.breadcrumbsComponent = signal(this.config?.components?.breadcrumb === false ? undefined : (this.config?.components?.breadcrumb ?? BreadcrumbComponent));
|
|
23
|
+
this.footerComponent = signal(this.config?.components?.footer === false ? undefined : (this.config?.components?.footer ?? FooterComponent));
|
|
24
|
+
this.useNotificationWrapper = signal(!this.config?.disableNotificationWrapper);
|
|
25
|
+
this.layout.overlayOpen$.pipe(takeUntilDestroyed()).subscribe(() => {
|
|
26
|
+
if (!this.menuOutsideClickListener) {
|
|
27
|
+
this.menuOutsideClickListener = this.renderer.listen('document', 'click', event => {
|
|
28
|
+
const isOutsideClicked = !(this.appTopbar()?.nativeElement.isSameNode(event.target) || this.appTopbar()?.nativeElement.contains(event.target));
|
|
29
|
+
if (isOutsideClicked) {
|
|
30
|
+
this.hideMenu();
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
if (this.layout.state().staticMenuMobileActive) {
|
|
35
|
+
this.blockBodyScroll();
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
blockBodyScroll() {
|
|
40
|
+
if (document.body.classList) {
|
|
41
|
+
document.body.classList.add('blocked-scroll');
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
document.body.className += ' blocked-scroll';
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
unblockBodyScroll() {
|
|
48
|
+
if (document.body.classList) {
|
|
49
|
+
document.body.classList.remove('blocked-scroll');
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
document.body.className = document.body.className.replace(new RegExp('(^|\\b)' + 'blocked-scroll'.split(' ').join('|') + '(\\b|$)', 'gi'), ' ');
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
hideMenu() {
|
|
56
|
+
this.layout.state.update(state => ({
|
|
57
|
+
...state,
|
|
58
|
+
overlayMenuActive: false,
|
|
59
|
+
staticMenuMobileActive: false,
|
|
60
|
+
menuHoverActive: false
|
|
61
|
+
}));
|
|
62
|
+
if (this.layout.submenuOverlayKey() !== undefined) {
|
|
63
|
+
this.layout.onOverlaySubmenuClose();
|
|
64
|
+
}
|
|
65
|
+
if (!(this.layout.isSlim() || this.layout.isSlimPlus())) {
|
|
66
|
+
this.menuService.reset();
|
|
67
|
+
}
|
|
68
|
+
if (this.menuOutsideClickListener) {
|
|
69
|
+
this.menuOutsideClickListener();
|
|
70
|
+
this.menuOutsideClickListener = null;
|
|
71
|
+
}
|
|
72
|
+
this.unblockBodyScroll();
|
|
73
|
+
}
|
|
74
|
+
ngOnDestroy() {
|
|
75
|
+
if (this.menuOutsideClickListener) {
|
|
76
|
+
this.menuOutsideClickListener();
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: MainLayoutComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
80
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.12", type: MainLayoutComponent, isStandalone: true, selector: "mng-main-layout", viewQueries: [{ propertyName: "appTopbar", first: true, predicate: ["topbarCmp"], descendants: true, isSignal: true }], ngImport: i0, template: "@if (useNotificationWrapper()) {\n <mng-notification-wrapper>\n <ng-template [ngTemplateOutlet]=\"content\"></ng-template>\n </mng-notification-wrapper>\n} @else {\n <ng-template [ngTemplateOutlet]=\"content\"></ng-template>\n}\n\n<ng-template #content>\n <div\n class=\"layout-container\"\n [ngClass]=\"{\n 'layout-light': layout.colorScheme() === 'light',\n 'layout-dark': layout.colorScheme() === 'dark',\n 'layout-overlay': layout.menuMode() === 'overlay',\n 'layout-static': layout.menuMode() === 'static',\n 'layout-reveal': layout.menuMode() === 'reveal',\n 'layout-drawer': layout.menuMode() === 'drawer',\n 'layout-slim': layout.menuMode() === 'slim',\n 'layout-slim-plus': layout.menuMode() === 'slim-plus',\n 'layout-static-inactive': layout.state().staticMenuDesktopInactive && layout.menuMode() === 'static',\n 'layout-overlay-active': layout.state().overlayMenuActive,\n 'layout-mobile-active': layout.state().staticMenuMobileActive,\n 'p-ripple-disabled': !ripple(),\n 'layout-sidebar-active': layout.state().sidebarActive,\n 'layout-sidebar-anchored': layout.state().anchored\n }\">\n <div class=\"layout-content-wrapper\">\n @if (topbarComponent()) {\n <div #topbarCmp class=\"layout-topbar-wrapper\" [mngComponent]=\"topbarComponent()\" [attachToHost]=\"true\"></div>\n }\n @if (breadcrumbsComponent()) {\n <div class=\"content-breadcrumb\">\n <div [mngComponent]=\"breadcrumbsComponent()\" [attachToHost]=\"true\"></div>\n </div>\n }\n <div class=\"layout-content\">\n <router-outlet></router-outlet>\n </div>\n <div class=\"layout-mask\"></div>\n @if (footerComponent()) {\n <div [mngComponent]=\"footerComponent()\" [attachToHost]=\"true\"></div>\n }\n </div>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: RouterModule }, { kind: "directive", type: i1.RouterOutlet, selector: "router-outlet", inputs: ["name"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }, { kind: "directive", type: ComponentDirective, selector: "[mngComponent]", inputs: ["mngComponent", "injectionToken", "inputs", "attachToHost", "parentInjector"], outputs: ["instanceCreated"] }, { kind: "component", type: NotificationWrapperComponent, selector: "mng-notification-wrapper" }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
81
|
+
}
|
|
82
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: MainLayoutComponent, decorators: [{
|
|
83
|
+
type: Component,
|
|
84
|
+
args: [{ standalone: true, selector: 'mng-main-layout', imports: [NgClass, RouterModule, ComponentDirective, NotificationWrapperComponent, NgTemplateOutlet], changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (useNotificationWrapper()) {\n <mng-notification-wrapper>\n <ng-template [ngTemplateOutlet]=\"content\"></ng-template>\n </mng-notification-wrapper>\n} @else {\n <ng-template [ngTemplateOutlet]=\"content\"></ng-template>\n}\n\n<ng-template #content>\n <div\n class=\"layout-container\"\n [ngClass]=\"{\n 'layout-light': layout.colorScheme() === 'light',\n 'layout-dark': layout.colorScheme() === 'dark',\n 'layout-overlay': layout.menuMode() === 'overlay',\n 'layout-static': layout.menuMode() === 'static',\n 'layout-reveal': layout.menuMode() === 'reveal',\n 'layout-drawer': layout.menuMode() === 'drawer',\n 'layout-slim': layout.menuMode() === 'slim',\n 'layout-slim-plus': layout.menuMode() === 'slim-plus',\n 'layout-static-inactive': layout.state().staticMenuDesktopInactive && layout.menuMode() === 'static',\n 'layout-overlay-active': layout.state().overlayMenuActive,\n 'layout-mobile-active': layout.state().staticMenuMobileActive,\n 'p-ripple-disabled': !ripple(),\n 'layout-sidebar-active': layout.state().sidebarActive,\n 'layout-sidebar-anchored': layout.state().anchored\n }\">\n <div class=\"layout-content-wrapper\">\n @if (topbarComponent()) {\n <div #topbarCmp class=\"layout-topbar-wrapper\" [mngComponent]=\"topbarComponent()\" [attachToHost]=\"true\"></div>\n }\n @if (breadcrumbsComponent()) {\n <div class=\"content-breadcrumb\">\n <div [mngComponent]=\"breadcrumbsComponent()\" [attachToHost]=\"true\"></div>\n </div>\n }\n <div class=\"layout-content\">\n <router-outlet></router-outlet>\n </div>\n <div class=\"layout-mask\"></div>\n @if (footerComponent()) {\n <div [mngComponent]=\"footerComponent()\" [attachToHost]=\"true\"></div>\n }\n </div>\n </div>\n</ng-template>\n" }]
|
|
85
|
+
}], ctorParameters: () => [] });
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main-layout.component.js","sourceRoot":"","sources":["../../../../../components/src/lib/components/main-layout.component.ts","../../../../../components/src/lib/components/main-layout.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,OAAO,EAAE,gBAAgB,EAAC,MAAM,iBAAiB,CAAC;AAC1D,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAyB,SAAS,EAAQ,MAAM,EAAE,MAAM,EAAE,SAAS,EAAC,MAAM,eAAe,CAAC;AACpI,OAAO,EAAC,kBAAkB,EAAC,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAE7C,OAAO,EAAC,gCAAgC,EAAE,aAAa,EAAE,WAAW,EAAC,MAAM,+BAA+B,CAAC;AAC3G,OAAO,EAAC,kBAAkB,EAAE,4BAA4B,EAAC,MAAM,6BAA6B,CAAC;AAE7F,OAAO,EAAC,mBAAmB,EAAC,MAAM,wBAAwB,CAAC;AAC3D,OAAO,EAAC,eAAe,EAAC,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAC,eAAe,EAAC,MAAM,oBAAoB,CAAC;;;AASnD,MAAM,OAAO,mBAAmB;IAoB5B;QAnBA,4DAA4D;QAC3C,WAAM,GAAG,MAAM,CAAC,gCAAgC,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAC;QACrE,WAAM,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;QAC9B,gBAAW,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAClC,aAAQ,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;QAEtC,cAAS,GAAG,SAAS,CAAa,WAAW,CAAC,CAAC;QAEvC,WAAM,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,IAAI,IAAI,CAAC,CAAC;QAEtD,oBAAe,GAAG,MAAM,CAAwB,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,KAAK,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,IAAI,eAAe,CAAC,CAAC,CAAC;QAC9J,yBAAoB,GAAG,MAAM,CAChC,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE,UAAU,KAAK,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE,UAAU,IAAI,mBAAmB,CAAC,CAC3H,CAAC;QACK,oBAAe,GAAG,MAAM,CAAwB,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,KAAK,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,IAAI,eAAe,CAAC,CAAC,CAAC;QAE9J,2BAAsB,GAAG,MAAM,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,0BAA0B,CAAC,CAAC;QAI7E,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC/D,IAAI,CAAC,IAAI,CAAC,wBAAwB,EAAE,CAAC;gBACjC,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,UAAU,EAAE,OAAO,EAAE,KAAK,CAAC,EAAE;oBAC9E,MAAM,gBAAgB,GAAG,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,EAAE,aAAa,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE,EAAE,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC;oBAC/I,IAAI,gBAAgB,EAAE,CAAC;wBACnB,IAAI,CAAC,QAAQ,EAAE,CAAC;oBACpB,CAAC;gBACL,CAAC,CAAC,CAAC;YACP,CAAC;YACD,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,sBAAsB,EAAE,CAAC;gBAC7C,IAAI,CAAC,eAAe,EAAE,CAAC;YAC3B,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,eAAe;QACX,IAAI,QAAQ,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YAC1B,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;QAClD,CAAC;aAAM,CAAC;YACJ,QAAQ,CAAC,IAAI,CAAC,SAAS,IAAI,iBAAiB,CAAC;QACjD,CAAC;IACL,CAAC;IAED,iBAAiB;QACb,IAAI,QAAQ,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YAC1B,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;QACrD,CAAC;aAAM,CAAC;YACJ,QAAQ,CAAC,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,MAAM,CAAC,SAAS,GAAG,gBAAgB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,SAAS,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC;QACpJ,CAAC;IACL,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YAC/B,GAAG,KAAK;YACR,iBAAiB,EAAE,KAAK;YACxB,sBAAsB,EAAE,KAAK;YAC7B,eAAe,EAAE,KAAK;SACzB,CAAC,CAAC,CAAC;QAEJ,IAAI,IAAI,CAAC,MAAM,CAAC,iBAAiB,EAAE,KAAK,SAAS,EAAE,CAAC;YAChD,IAAI,CAAC,MAAM,CAAC,qBAAqB,EAAE,CAAC;QACxC,CAAC;QACD,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,CAAC,EAAE,CAAC;YACtD,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;QAC7B,CAAC;QAED,IAAI,IAAI,CAAC,wBAAwB,EAAE,CAAC;YAChC,IAAI,CAAC,wBAAwB,EAAE,CAAC;YAChC,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC;QACzC,CAAC;QACD,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC7B,CAAC;IAED,WAAW;QACP,IAAI,IAAI,CAAC,wBAAwB,EAAE,CAAC;YAChC,IAAI,CAAC,wBAAwB,EAAE,CAAC;QACpC,CAAC;IACL,CAAC;+GA9EQ,mBAAmB;mGAAnB,mBAAmB,mMCnBhC,ikEA8CA,4CD/Bc,OAAO,mFAAE,YAAY,yMAAE,kBAAkB,iLAAE,4BAA4B,qEAAE,gBAAgB;;4FAI1F,mBAAmB;kBAP/B,SAAS;iCACM,IAAI,YACN,iBAAiB,WAClB,CAAC,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,4BAA4B,EAAE,gBAAgB,CAAC,mBAEnF,uBAAuB,CAAC,MAAM","sourcesContent":["import {NgClass, NgTemplateOutlet} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, ElementRef, OnDestroy, Renderer2, Type, inject, signal, viewChild} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {RouterModule} from '@angular/router';\n\nimport {COMMONS_LAYOUT_FEATURE_CONFIG_IT, LayoutService, MenuService} from '@mediusinc/mng-commons-layout';\nimport {ComponentDirective, NotificationWrapperComponent} from '@mediusinc/mng-commons/core';\n\nimport {BreadcrumbComponent} from './breadcrumb.component';\nimport {FooterComponent} from './footer.component';\nimport {TopbarComponent} from './topbar.component';\n\n@Component({\n    standalone: true,\n    selector: 'mng-main-layout',\n    imports: [NgClass, RouterModule, ComponentDirective, NotificationWrapperComponent, NgTemplateOutlet],\n    templateUrl: './main-layout.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MainLayoutComponent implements OnDestroy {\n    // private readonly commonsService = inject(CommonsService);\n    private readonly config = inject(COMMONS_LAYOUT_FEATURE_CONFIG_IT, {optional: true});\n    public readonly layout = inject(LayoutService);\n    private readonly menuService = inject(MenuService);\n    private readonly renderer = inject(Renderer2);\n\n    private appTopbar = viewChild<ElementRef>('topbarCmp');\n\n    public readonly ripple = signal(this.config?.ripple ?? true);\n\n    public topbarComponent = signal<Type<any> | undefined>(this.config?.components?.topbar === false ? undefined : (this.config?.components?.topbar ?? TopbarComponent));\n    public breadcrumbsComponent = signal<Type<any> | undefined>(\n        this.config?.components?.breadcrumb === false ? undefined : (this.config?.components?.breadcrumb ?? BreadcrumbComponent)\n    );\n    public footerComponent = signal<Type<any> | undefined>(this.config?.components?.footer === false ? undefined : (this.config?.components?.footer ?? FooterComponent));\n\n    public useNotificationWrapper = signal(!this.config?.disableNotificationWrapper);\n    private menuOutsideClickListener: any;\n\n    constructor() {\n        this.layout.overlayOpen$.pipe(takeUntilDestroyed()).subscribe(() => {\n            if (!this.menuOutsideClickListener) {\n                this.menuOutsideClickListener = this.renderer.listen('document', 'click', event => {\n                    const isOutsideClicked = !(this.appTopbar()?.nativeElement.isSameNode(event.target) || this.appTopbar()?.nativeElement.contains(event.target));\n                    if (isOutsideClicked) {\n                        this.hideMenu();\n                    }\n                });\n            }\n            if (this.layout.state().staticMenuMobileActive) {\n                this.blockBodyScroll();\n            }\n        });\n    }\n\n    blockBodyScroll(): void {\n        if (document.body.classList) {\n            document.body.classList.add('blocked-scroll');\n        } else {\n            document.body.className += ' blocked-scroll';\n        }\n    }\n\n    unblockBodyScroll(): void {\n        if (document.body.classList) {\n            document.body.classList.remove('blocked-scroll');\n        } else {\n            document.body.className = document.body.className.replace(new RegExp('(^|\\\\b)' + 'blocked-scroll'.split(' ').join('|') + '(\\\\b|$)', 'gi'), ' ');\n        }\n    }\n\n    hideMenu() {\n        this.layout.state.update(state => ({\n            ...state,\n            overlayMenuActive: false,\n            staticMenuMobileActive: false,\n            menuHoverActive: false\n        }));\n\n        if (this.layout.submenuOverlayKey() !== undefined) {\n            this.layout.onOverlaySubmenuClose();\n        }\n        if (!(this.layout.isSlim() || this.layout.isSlimPlus())) {\n            this.menuService.reset();\n        }\n\n        if (this.menuOutsideClickListener) {\n            this.menuOutsideClickListener();\n            this.menuOutsideClickListener = null;\n        }\n        this.unblockBodyScroll();\n    }\n\n    ngOnDestroy() {\n        if (this.menuOutsideClickListener) {\n            this.menuOutsideClickListener();\n        }\n    }\n}\n","@if (useNotificationWrapper()) {\n    <mng-notification-wrapper>\n        <ng-template [ngTemplateOutlet]=\"content\"></ng-template>\n    </mng-notification-wrapper>\n} @else {\n    <ng-template [ngTemplateOutlet]=\"content\"></ng-template>\n}\n\n<ng-template #content>\n    <div\n        class=\"layout-container\"\n        [ngClass]=\"{\n            'layout-light': layout.colorScheme() === 'light',\n            'layout-dark': layout.colorScheme() === 'dark',\n            'layout-overlay': layout.menuMode() === 'overlay',\n            'layout-static': layout.menuMode() === 'static',\n            'layout-reveal': layout.menuMode() === 'reveal',\n            'layout-drawer': layout.menuMode() === 'drawer',\n            'layout-slim': layout.menuMode() === 'slim',\n            'layout-slim-plus': layout.menuMode() === 'slim-plus',\n            'layout-static-inactive': layout.state().staticMenuDesktopInactive && layout.menuMode() === 'static',\n            'layout-overlay-active': layout.state().overlayMenuActive,\n            'layout-mobile-active': layout.state().staticMenuMobileActive,\n            'p-ripple-disabled': !ripple(),\n            'layout-sidebar-active': layout.state().sidebarActive,\n            'layout-sidebar-anchored': layout.state().anchored\n        }\">\n        <div class=\"layout-content-wrapper\">\n            @if (topbarComponent()) {\n                <div #topbarCmp class=\"layout-topbar-wrapper\" [mngComponent]=\"topbarComponent()\" [attachToHost]=\"true\"></div>\n            }\n            @if (breadcrumbsComponent()) {\n                <div class=\"content-breadcrumb\">\n                    <div [mngComponent]=\"breadcrumbsComponent()\" [attachToHost]=\"true\"></div>\n                </div>\n            }\n            <div class=\"layout-content\">\n                <router-outlet></router-outlet>\n            </div>\n            <div class=\"layout-mask\"></div>\n            @if (footerComponent()) {\n                <div [mngComponent]=\"footerComponent()\" [attachToHost]=\"true\"></div>\n            }\n        </div>\n    </div>\n</ng-template>\n"]}
|