UNPKG

@alauda-fe/common

Version:

Alauda frontend team common codes.

151 lines 23.5 kB
import { ChangeDetectionStrategy, Component, ContentChild, TemplateRef, ViewEncapsulation, inject, ViewChild, ElementRef, Input, } from '@angular/core'; import { BehaviorSubject } from 'rxjs'; import { IframeConfigService } from '../../iframe-config/config.service'; import { PageContextService } from './context.service'; import { PageContentDirective, PageHeaderDirective, PageSiderDirective, PageToolbarDirective, } from './helper-directives'; import * as i0 from "@angular/core"; import * as i1 from "../../iframe-config/config.service"; import * as i2 from "@angular/common"; import * as i3 from "./notices/notice.component"; import * as i4 from "@angular/cdk/overlay"; const _c0 = ["header"]; function PageComponent_div_2_acl_page_notice_2_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelement(0, "acl-page-notice"); } } function PageComponent_div_2_ng_container_4_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementContainer(0); } } function PageComponent_div_2_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementStart(0, "div", 7, 0); i0.ɵɵtemplate(2, PageComponent_div_2_acl_page_notice_2_Template, 1, 0, "acl-page-notice", 8); i0.ɵɵelementStart(3, "div", 9); i0.ɵɵtemplate(4, PageComponent_div_2_ng_container_4_Template, 1, 0, "ng-container", 6); i0.ɵɵelementEnd()(); } if (rf & 2) { const ctx_r0 = i0.ɵɵnextContext(); i0.ɵɵadvance(2); i0.ɵɵproperty("ngIf", ctx_r0.showAlerts); i0.ɵɵadvance(2); i0.ɵɵproperty("ngTemplateOutlet", ctx_r0.pageHeader); } } function PageComponent_div_3_ng_container_2_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementContainer(0); } } function PageComponent_div_3_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementStart(0, "div", 10)(1, "div", 11); i0.ɵɵtemplate(2, PageComponent_div_3_ng_container_2_Template, 1, 0, "ng-container", 6); i0.ɵɵelementEnd()(); } if (rf & 2) { const ctx_r0 = i0.ɵɵnextContext(); i0.ɵɵadvance(2); i0.ɵɵproperty("ngTemplateOutlet", ctx_r0.pageSider); } } function PageComponent_div_5_ng_container_1_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementContainer(0); } } function PageComponent_div_5_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementStart(0, "div", 12); i0.ɵɵtemplate(1, PageComponent_div_5_ng_container_1_Template, 1, 0, "ng-container", 6); i0.ɵɵelementEnd(); } if (rf & 2) { const ctx_r0 = i0.ɵɵnextContext(); i0.ɵɵadvance(); i0.ɵɵproperty("ngTemplateOutlet", ctx_r0.pageToolbar); } } function PageComponent_ng_container_7_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementContainer(0); } } export class PageComponent { constructor(iframeConfigService) { this.iframeConfigService = iframeConfigService; this.showAlerts = true; this.classes = new Set(); this.classes$$ = new BehaviorSubject(this.classes); this.showToolbar$ = inject(PageContextService).showToolbar$; this.isHideMenu = this.iframeConfigService.isHideMenu; this.isHideHeader = this.iframeConfigService.isHideHeader; document.querySelector('.index-loading-spinner')?.remove(); } ngAfterViewInit() { if (this.header) { const resizeObserver = new ResizeObserver(() => { const height = Math.ceil(this.header.nativeElement.getBoundingClientRect().height); document.documentElement.style.setProperty('--acl-page-header-height', `${height}px`); }); resizeObserver.observe(this.header.nativeElement); } } addClass(cls) { cls.split(' ').forEach(cl => { this.classes.add(cl.trim()); }); this.classes$$.next(this.classes); } removeClass(cls) { cls.split(' ').forEach(cl => { this.classes.delete(cl.trim()); }); this.classes$$.next(this.classes); } static { this.ɵfac = function PageComponent_Factory(t) { return new (t || PageComponent)(i0.ɵɵdirectiveInject(i1.IframeConfigService)); }; } static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PageComponent, selectors: [["acl-page"]], contentQueries: function PageComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) { i0.ɵɵcontentQuery(dirIndex, PageHeaderDirective, 5, TemplateRef); i0.ɵɵcontentQuery(dirIndex, PageContentDirective, 5, TemplateRef); i0.ɵɵcontentQuery(dirIndex, PageSiderDirective, 5, TemplateRef); i0.ɵɵcontentQuery(dirIndex, PageToolbarDirective, 5, TemplateRef); } if (rf & 2) { let _t; i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.pageHeader = _t.first); i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.pageContent = _t.first); i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.pageSider = _t.first); i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.pageToolbar = _t.first); } }, viewQuery: function PageComponent_Query(rf, ctx) { if (rf & 1) { i0.ɵɵviewQuery(_c0, 5); } if (rf & 2) { let _t; i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.header = _t.first); } }, inputs: { showAlerts: "showAlerts" }, features: [i0.ɵɵProvidersFeature([PageContextService])], decls: 8, vars: 17, consts: [["header", ""], [1, "acl-page", 3, "ngClass"], ["class", "acl-page__header", 4, "ngIf"], ["class", "acl-page__sider-wrapper tw-fixed tw-top-0 tw-left-0 tw-h-[100vh]", 4, "ngIf"], [1, "acl-page__content"], ["class", "acl-page__toolbar", 4, "ngIf"], [4, "ngTemplateOutlet"], [1, "acl-page__header"], [4, "ngIf"], [1, "acl-page__header-content"], [1, "acl-page__sider-wrapper", "tw-fixed", "tw-top-0", "tw-left-0", "tw-h-[100vh]"], ["cdk-scrollable", "", 1, "acl-page__sider-wrapper-scroll", "tw-h-full", "tw-overflow-y-auto", "tw-overflow-x-hidden"], [1, "acl-page__toolbar"]], template: function PageComponent_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementStart(0, "div", 1); i0.ɵɵpipe(1, "async"); i0.ɵɵtemplate(2, PageComponent_div_2_Template, 5, 2, "div", 2)(3, PageComponent_div_3_Template, 3, 1, "div", 3); i0.ɵɵelementStart(4, "div", 4); i0.ɵɵtemplate(5, PageComponent_div_5_Template, 2, 1, "div", 5); i0.ɵɵpipe(6, "async"); i0.ɵɵtemplate(7, PageComponent_ng_container_7_Template, 1, 0, "ng-container", 6); i0.ɵɵelementEnd()(); } if (rf & 2) { i0.ɵɵclassProp("hasHeader", ctx.pageHeader && !ctx.isHideHeader)("hasSider", ctx.pageSider)("hasToolbar", ctx.pageToolbar)("hideHeader", ctx.isHideHeader); i0.ɵɵproperty("ngClass", i0.ɵɵpipeBind1(1, 13, ctx.classes$$)); i0.ɵɵadvance(2); i0.ɵɵproperty("ngIf", ctx.pageHeader && !ctx.isHideHeader); i0.ɵɵadvance(); i0.ɵɵproperty("ngIf", ctx.pageSider && !ctx.isHideMenu); i0.ɵɵadvance(2); i0.ɵɵproperty("ngIf", i0.ɵɵpipeBind1(6, 15, ctx.showToolbar$) && ctx.pageToolbar); i0.ɵɵadvance(2); i0.ɵɵproperty("ngTemplateOutlet", ctx.pageContent); } }, dependencies: [i2.NgClass, i2.NgIf, i2.NgTemplateOutlet, i3.NoticeComponent, i4.CdkScrollable, i2.AsyncPipe], styles: [".acl-page{min-height:100vh;background-color:rgb(var(--aui-color-main-bg))}.acl-page__header{position:fixed;top:0;left:0;right:0;z-index:600;background-color:var(--acl-page-header-background-color)}.acl-page__header-content{display:flex;justify-content:space-between;align-items:center;height:60px;padding:0 20px 0 16px}:root .acl-page__header{box-shadow:0 0 4px rgba(var(--aui-color-origin-shadow),.1)}html[aui-theme-mode=light] .acl-page__header{box-shadow:0 0 4px rgba(var(--aui-color-origin-shadow),.1)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .acl-page__header{box-shadow:0 0 4px rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .acl-page__header{box-shadow:0 0 4px rgba(var(--aui-color-origin-shadow),.75)}.acl-page__sider-wrapper{padding:44px 4px 0 10px;z-index:500;background-color:var(--acl-nav-background-color)}.acl-page__sider-wrapper-scroll{padding:44px 10px 0;width:240px;scrollbar-width:none}.sidenav-collapse .acl-page__sider-wrapper-scroll{width:60px}.sidenav-ani .acl-page__sider-wrapper-scroll{transition:width padding;transition-duration:.3s;transition-timing-function:cubic-bezier(.38,0,.24,1)}.acl-page__sider-wrapper-scroll::-webkit-scrollbar{display:none}.acl-page__sider-wrapper acl-nav-skeleton>ul{width:220px;overflow:hidden}.sidenav-collapse .acl-page__sider-wrapper acl-nav-skeleton>ul{width:40px;transform:translate(-8px)}.acl-page__toolbar{display:flex;justify-content:space-between;align-items:center;height:44px;padding:0 0 0 20px}.acl-page__content{min-height:100vh;position:relative;padding:20px;min-width:1200px}.acl-page.hasSider .acl-page__content{min-width:960px;padding-left:0;margin-left:260px}.sidenav-collapse.acl-page.hasSider .acl-page__content{margin-left:80px}.sidenav-ani.acl-page.hasSider .acl-page__content{transition:margin-left;transition-duration:.3s;transition-timing-function:cubic-bezier(.38,0,.24,1)}.acl-page.hasHeader .acl-page__content{padding-top:calc(var(--acl-page-header-height) + 20px)}.acl-page.hasHeader.hasToolbar .acl-page__content,.acl-page.hasHeader .acl-page__sider-wrapper{padding-top:var(--acl-page-header-height)}.acl-page.hideHeader .acl-page__sider-wrapper{padding-top:0}.acl-page.hideHeader .acl-page__sider-wrapper-scroll{padding-top:20px}.acl-page.hideHeader .acl-page__content{padding-top:0}\n"], encapsulation: 2, changeDetection: 0 }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(PageComponent, [{ type: Component, args: [{ selector: 'acl-page', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, preserveWhitespaces: false, providers: [PageContextService], template: "<div\n class=\"acl-page\"\n [class.hasHeader]=\"pageHeader && !isHideHeader\"\n [class.hasSider]=\"pageSider\"\n [class.hasToolbar]=\"pageToolbar\"\n [class.hideHeader]=\"isHideHeader\"\n [ngClass]=\"classes$$ | async\"\n>\n <div\n *ngIf=\"pageHeader && !isHideHeader\"\n class=\"acl-page__header\"\n #header\n >\n <acl-page-notice *ngIf=\"showAlerts\"></acl-page-notice>\n <div class=\"acl-page__header-content\">\n <ng-container *ngTemplateOutlet=\"pageHeader\"></ng-container>\n </div>\n </div>\n\n <div\n *ngIf=\"pageSider && !isHideMenu\"\n class=\"acl-page__sider-wrapper tw-fixed tw-top-0 tw-left-0 tw-h-[100vh]\"\n >\n <div\n class=\"acl-page__sider-wrapper-scroll tw-h-full tw-overflow-y-auto tw-overflow-x-hidden\"\n cdk-scrollable\n >\n <ng-container *ngTemplateOutlet=\"pageSider\"></ng-container>\n </div>\n </div>\n\n <div class=\"acl-page__content\">\n <div\n *ngIf=\"(showToolbar$ | async) && pageToolbar\"\n class=\"acl-page__toolbar\"\n >\n <ng-container *ngTemplateOutlet=\"pageToolbar\"></ng-container>\n </div>\n <ng-container *ngTemplateOutlet=\"pageContent\"></ng-container>\n </div>\n</div>\n", styles: [".acl-page{min-height:100vh;background-color:rgb(var(--aui-color-main-bg))}.acl-page__header{position:fixed;top:0;left:0;right:0;z-index:600;background-color:var(--acl-page-header-background-color)}.acl-page__header-content{display:flex;justify-content:space-between;align-items:center;height:60px;padding:0 20px 0 16px}:root .acl-page__header{box-shadow:0 0 4px rgba(var(--aui-color-origin-shadow),.1)}html[aui-theme-mode=light] .acl-page__header{box-shadow:0 0 4px rgba(var(--aui-color-origin-shadow),.1)}@media (prefers-color-scheme: dark){html[aui-theme-mode=system] .acl-page__header{box-shadow:0 0 4px rgba(var(--aui-color-origin-shadow),.75)}}html[aui-theme-mode=dark] .acl-page__header{box-shadow:0 0 4px rgba(var(--aui-color-origin-shadow),.75)}.acl-page__sider-wrapper{padding:44px 4px 0 10px;z-index:500;background-color:var(--acl-nav-background-color)}.acl-page__sider-wrapper-scroll{padding:44px 10px 0;width:240px;scrollbar-width:none}.sidenav-collapse .acl-page__sider-wrapper-scroll{width:60px}.sidenav-ani .acl-page__sider-wrapper-scroll{transition:width padding;transition-duration:.3s;transition-timing-function:cubic-bezier(.38,0,.24,1)}.acl-page__sider-wrapper-scroll::-webkit-scrollbar{display:none}.acl-page__sider-wrapper acl-nav-skeleton>ul{width:220px;overflow:hidden}.sidenav-collapse .acl-page__sider-wrapper acl-nav-skeleton>ul{width:40px;transform:translate(-8px)}.acl-page__toolbar{display:flex;justify-content:space-between;align-items:center;height:44px;padding:0 0 0 20px}.acl-page__content{min-height:100vh;position:relative;padding:20px;min-width:1200px}.acl-page.hasSider .acl-page__content{min-width:960px;padding-left:0;margin-left:260px}.sidenav-collapse.acl-page.hasSider .acl-page__content{margin-left:80px}.sidenav-ani.acl-page.hasSider .acl-page__content{transition:margin-left;transition-duration:.3s;transition-timing-function:cubic-bezier(.38,0,.24,1)}.acl-page.hasHeader .acl-page__content{padding-top:calc(var(--acl-page-header-height) + 20px)}.acl-page.hasHeader.hasToolbar .acl-page__content,.acl-page.hasHeader .acl-page__sider-wrapper{padding-top:var(--acl-page-header-height)}.acl-page.hideHeader .acl-page__sider-wrapper{padding-top:0}.acl-page.hideHeader .acl-page__sider-wrapper-scroll{padding-top:20px}.acl-page.hideHeader .acl-page__content{padding-top:0}\n"] }] }], () => [{ type: i1.IframeConfigService }], { showAlerts: [{ type: Input }], pageHeader: [{ type: ContentChild, args: [PageHeaderDirective, { read: TemplateRef }] }], pageContent: [{ type: ContentChild, args: [PageContentDirective, { read: TemplateRef }] }], pageSider: [{ type: ContentChild, args: [PageSiderDirective, { read: TemplateRef }] }], pageToolbar: [{ type: ContentChild, args: [PageToolbarDirective, { read: TemplateRef }] }], header: [{ type: ViewChild, args: ['header'] }] }); })(); (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PageComponent, { className: "PageComponent" }); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page.component.js","sourceRoot":"","sources":["../../../../../../libs/common/src/page-scaffold/page/page.component.ts","../../../../../../libs/common/src/page-scaffold/page/page.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  TemplateRef,\n  ViewEncapsulation,\n  inject,\n  ViewChild,\n  ElementRef,\n  AfterViewInit,\n  Input,\n} from '@angular/core';\nimport { BehaviorSubject } from 'rxjs';\n\nimport { IframeConfigService } from '../../iframe-config/config.service';\n\nimport { PageContextService } from './context.service';\nimport {\n  PageContentDirective,\n  PageHeaderDirective,\n  PageSiderDirective,\n  PageToolbarDirective,\n} from './helper-directives';\n\n@Component({\n  selector: 'acl-page',\n  templateUrl: './page.component.html',\n  styleUrls: ['./page.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n  providers: [PageContextService],\n})\nexport class PageComponent implements AfterViewInit {\n  @Input()\n  showAlerts = true;\n\n  @ContentChild(PageHeaderDirective, { read: TemplateRef })\n  pageHeader: TemplateRef<any>;\n\n  @ContentChild(PageContentDirective, { read: TemplateRef })\n  pageContent: TemplateRef<any>;\n\n  @ContentChild(PageSiderDirective, { read: TemplateRef })\n  pageSider: TemplateRef<any>;\n\n  @ContentChild(PageToolbarDirective, { read: TemplateRef })\n  pageToolbar: TemplateRef<any>;\n\n  @ViewChild('header')\n  header?: ElementRef<HTMLElement>;\n\n  private readonly classes: Set<string> = new Set();\n\n  classes$$ = new BehaviorSubject(this.classes);\n  showToolbar$ = inject(PageContextService).showToolbar$;\n  isHideMenu = this.iframeConfigService.isHideMenu;\n  isHideHeader = this.iframeConfigService.isHideHeader;\n\n  constructor(private readonly iframeConfigService: IframeConfigService) {\n    document.querySelector('.index-loading-spinner')?.remove();\n  }\n\n  ngAfterViewInit() {\n    if (this.header) {\n      const resizeObserver = new ResizeObserver(() => {\n        const height = Math.ceil(\n          this.header.nativeElement.getBoundingClientRect().height,\n        );\n        document.documentElement.style.setProperty(\n          '--acl-page-header-height',\n          `${height}px`,\n        );\n      });\n      resizeObserver.observe(this.header.nativeElement);\n    }\n  }\n\n  addClass(cls: string) {\n    cls.split(' ').forEach(cl => {\n      this.classes.add(cl.trim());\n    });\n    this.classes$$.next(this.classes);\n  }\n\n  removeClass(cls: string) {\n    cls.split(' ').forEach(cl => {\n      this.classes.delete(cl.trim());\n    });\n    this.classes$$.next(this.classes);\n  }\n}\n","<div\n  class=\"acl-page\"\n  [class.hasHeader]=\"pageHeader && !isHideHeader\"\n  [class.hasSider]=\"pageSider\"\n  [class.hasToolbar]=\"pageToolbar\"\n  [class.hideHeader]=\"isHideHeader\"\n  [ngClass]=\"classes$$ | async\"\n>\n  <div\n    *ngIf=\"pageHeader && !isHideHeader\"\n    class=\"acl-page__header\"\n    #header\n  >\n    <acl-page-notice *ngIf=\"showAlerts\"></acl-page-notice>\n    <div class=\"acl-page__header-content\">\n      <ng-container *ngTemplateOutlet=\"pageHeader\"></ng-container>\n    </div>\n  </div>\n\n  <div\n    *ngIf=\"pageSider && !isHideMenu\"\n    class=\"acl-page__sider-wrapper tw-fixed tw-top-0 tw-left-0 tw-h-[100vh]\"\n  >\n    <div\n      class=\"acl-page__sider-wrapper-scroll tw-h-full tw-overflow-y-auto tw-overflow-x-hidden\"\n      cdk-scrollable\n    >\n      <ng-container *ngTemplateOutlet=\"pageSider\"></ng-container>\n    </div>\n  </div>\n\n  <div class=\"acl-page__content\">\n    <div\n      *ngIf=\"(showToolbar$ | async) && pageToolbar\"\n      class=\"acl-page__toolbar\"\n    >\n      <ng-container *ngTemplateOutlet=\"pageToolbar\"></ng-container>\n    </div>\n    <ng-container *ngTemplateOutlet=\"pageContent\"></ng-container>\n  </div>\n</div>\n"]}