@yelon/bis 12.0.18 → 12.0.19

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.
@@ -1,5 +1,5 @@
1
1
  /**
2
- * @license ng-yunzai(devcui@outlook.com) v12.0.18
2
+ * @license ng-yunzai(devcui@outlook.com) v12.0.19
3
3
  * (c) 2020 devcui https://github.com/hbyunzai/yelon/
4
4
  * License: MIT
5
5
  */
@@ -1,10 +1,12 @@
1
1
  import { ChangeDetectionStrategy, Component } from '@angular/core';
2
2
  import { CacheService } from '@yelon/cache';
3
+ import { LayoutService } from '@yelon/theme/layout-default';
3
4
  import { YzStompService } from './yz.stomp.service';
4
5
  export class YzLayoutBasicComponent {
5
- constructor(cacheService, yzStompService) {
6
+ constructor(cacheService, yzStompService, layoutService) {
6
7
  this.cacheService = cacheService;
7
8
  this.yzStompService = yzStompService;
9
+ this.layoutService = layoutService;
8
10
  this.options = {
9
11
  logoExpanded: `./assets/logo-full.svg`,
10
12
  logoCollapsed: `./assets/logo.svg`
@@ -12,6 +14,19 @@ export class YzLayoutBasicComponent {
12
14
  this.intro = '';
13
15
  this.text = '';
14
16
  this.icon = '';
17
+ this.showReuseTab = true;
18
+ this.showHeader = true;
19
+ this.showSider = true;
20
+ }
21
+ get reuseStyleSheet() {
22
+ let cascadingStyleSheet = {};
23
+ if (!this.showHeader) {
24
+ cascadingStyleSheet = Object.assign(Object.assign({}, cascadingStyleSheet), { top: 0 });
25
+ }
26
+ if (!this.showSider) {
27
+ cascadingStyleSheet = Object.assign(Object.assign({}, cascadingStyleSheet), { left: '24px' });
28
+ }
29
+ return cascadingStyleSheet;
15
30
  }
16
31
  ngOnInit() {
17
32
  const current = this.cacheService.get('_yz_current', { mode: 'none' });
@@ -22,6 +37,9 @@ export class YzLayoutBasicComponent {
22
37
  this.options.logoExpanded = project.maxLogoUrl ? project.maxLogoUrl : `./assets/logo-full.svg`;
23
38
  this.options.logoCollapsed = project.miniLogoUrl ? project.miniLogoUrl : `./assets/logo.svg`;
24
39
  this.yzStompService.listen();
40
+ this.layoutService.reuseTab.asObservable().subscribe(show => (this.showReuseTab = show));
41
+ this.layoutService.header.asObservable().subscribe(show => (this.showHeader = show));
42
+ this.layoutService.sidebar.asObservable().subscribe(show => (this.showSider = show));
25
43
  }
26
44
  ngOnDestroy() {
27
45
  this.yzStompService.unListen();
@@ -31,7 +49,7 @@ YzLayoutBasicComponent.decorators = [
31
49
  { type: Component, args: [{
32
50
  selector: 'yz-layout-basic',
33
51
  template: `
34
- <layout-default [options]="options" [asideUser]="asideUserTpl" [content]="contentTpl">
52
+ <layout-default [options]="options" [asideUser]="asideUserTpl" [content]="showReuseTab ? contentTpl : noneTpl">
35
53
  <layout-default-header-item direction="left">
36
54
  <yz-header-application></yz-header-application>
37
55
  </layout-default-header-item>
@@ -86,9 +104,12 @@ YzLayoutBasicComponent.decorators = [
86
104
  </nz-dropdown-menu>
87
105
  </ng-template>
88
106
  <ng-template #contentTpl>
89
- <reuse-tab #reuseTab></reuse-tab>
107
+ <reuse-tab #reuseTab [ngStyle]="reuseStyleSheet"></reuse-tab>
90
108
  <router-outlet (activate)="reuseTab.activate($event)"></router-outlet>
91
109
  </ng-template>
110
+ <ng-template #noneTpl>
111
+ <router-outlet></router-outlet>
112
+ </ng-template>
92
113
  </layout-default>
93
114
  `,
94
115
  changeDetection: ChangeDetectionStrategy.OnPush
@@ -96,6 +117,7 @@ YzLayoutBasicComponent.decorators = [
96
117
  ];
97
118
  YzLayoutBasicComponent.ctorParameters = () => [
98
119
  { type: CacheService },
99
- { type: YzStompService }
120
+ { type: YzStompService },
121
+ { type: LayoutService }
100
122
  ];
101
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoieXouYmFzaWMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvYmlzL2xheW91dC95ei5iYXNpYy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFJdEYsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUc1QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFtRXBELE1BQU0sT0FBTyxzQkFBc0I7SUFVakMsWUFBb0IsWUFBMEIsRUFBVSxjQUE4QjtRQUFsRSxpQkFBWSxHQUFaLFlBQVksQ0FBYztRQUFVLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtRQVR0RixZQUFPLEdBQXlCO1lBQzlCLFlBQVksRUFBRSx3QkFBd0I7WUFDdEMsYUFBYSxFQUFFLG1CQUFtQjtTQUNuQyxDQUFDO1FBRUYsVUFBSyxHQUFXLEVBQUUsQ0FBQztRQUNuQixTQUFJLEdBQVcsRUFBRSxDQUFDO1FBQ2xCLFNBQUksR0FBVyxFQUFFLENBQUM7SUFFdUUsQ0FBQztJQUUxRixRQUFRO1FBQ04sTUFBTSxPQUFPLEdBQWMsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7UUFDbEYsTUFBTSxPQUFPLEdBQWMsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsa0JBQWtCLEVBQUUsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLENBQUMsQ0FBQztRQUN2RixJQUFJLENBQUMsSUFBSSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQztRQUNqRCxJQUFJLENBQUMsS0FBSyxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQztRQUNwRCxJQUFJLENBQUMsSUFBSSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLDZCQUE2QixDQUFDO1FBQ3hFLElBQUksQ0FBQyxPQUFPLENBQUMsWUFBWSxHQUFHLE9BQU8sQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLHdCQUF3QixDQUFDO1FBQy9GLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxHQUFHLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLG1CQUFtQixDQUFDO1FBQzdGLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxFQUFFLENBQUM7SUFDL0IsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsY0FBYyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ2pDLENBQUM7OztZQTFGRixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLGlCQUFpQjtnQkFDM0IsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0E0RFQ7Z0JBQ0QsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07YUFDaEQ7OztZQXJFUSxZQUFZO1lBR1osY0FBYyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIE9uRGVzdHJveSwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IE56U2FmZUFueSB9IGZyb20gJ25nLXpvcnJvLWFudGQvY29yZS90eXBlcyc7XG5cbmltcG9ydCB7IENhY2hlU2VydmljZSB9IGZyb20gJ0B5ZWxvbi9jYWNoZSc7XG5pbXBvcnQgeyBMYXlvdXREZWZhdWx0T3B0aW9ucyB9IGZyb20gJ0B5ZWxvbi90aGVtZS9sYXlvdXQtZGVmYXVsdCc7XG5cbmltcG9ydCB7IFl6U3RvbXBTZXJ2aWNlIH0gZnJvbSAnLi95ei5zdG9tcC5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAneXotbGF5b3V0LWJhc2ljJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8bGF5b3V0LWRlZmF1bHQgW29wdGlvbnNdPVwib3B0aW9uc1wiIFthc2lkZVVzZXJdPVwiYXNpZGVVc2VyVHBsXCIgW2NvbnRlbnRdPVwiY29udGVudFRwbFwiPlxuICAgICAgPGxheW91dC1kZWZhdWx0LWhlYWRlci1pdGVtIGRpcmVjdGlvbj1cImxlZnRcIj5cbiAgICAgICAgPHl6LWhlYWRlci1hcHBsaWNhdGlvbj48L3l6LWhlYWRlci1hcHBsaWNhdGlvbj5cbiAgICAgIDwvbGF5b3V0LWRlZmF1bHQtaGVhZGVyLWl0ZW0+XG5cbiAgICAgIDxsYXlvdXQtZGVmYXVsdC1oZWFkZXItaXRlbSBkaXJlY3Rpb249XCJyaWdodFwiIGhpZGRlbj1cIm1vYmlsZVwiPlxuICAgICAgICA8eXotaGVhZGVyLW5vdGlmeT48L3l6LWhlYWRlci1ub3RpZnk+XG4gICAgICA8L2xheW91dC1kZWZhdWx0LWhlYWRlci1pdGVtPlxuXG4gICAgICA8bGF5b3V0LWRlZmF1bHQtaGVhZGVyLWl0ZW0gZGlyZWN0aW9uPVwicmlnaHRcIiBoaWRkZW49XCJtb2JpbGVcIj5cbiAgICAgICAgPHl6LWhlYWRlci10aGVtZS1idG4+PC95ei1oZWFkZXItdGhlbWUtYnRuPlxuICAgICAgPC9sYXlvdXQtZGVmYXVsdC1oZWFkZXItaXRlbT5cblxuICAgICAgPGxheW91dC1kZWZhdWx0LWhlYWRlci1pdGVtIGRpcmVjdGlvbj1cInJpZ2h0XCIgaGlkZGVuPVwibW9iaWxlXCI+XG4gICAgICAgIDxkaXZcbiAgICAgICAgICBsYXlvdXQtZGVmYXVsdC1oZWFkZXItaXRlbS10cmlnZ2VyXG4gICAgICAgICAgbnotZHJvcGRvd25cbiAgICAgICAgICBbbnpEcm9wZG93bk1lbnVdPVwic2V0dGluZ3NNZW51XCJcbiAgICAgICAgICBuelRyaWdnZXI9XCJjbGlja1wiXG4gICAgICAgICAgbnpQbGFjZW1lbnQ9XCJib3R0b21SaWdodFwiXG4gICAgICAgID5cbiAgICAgICAgICA8aSBuei1pY29uIG56VHlwZT1cInNldHRpbmdcIj48L2k+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8bnotZHJvcGRvd24tbWVudSAjc2V0dGluZ3NNZW51PVwibnpEcm9wZG93bk1lbnVcIj5cbiAgICAgICAgICA8ZGl2IG56LW1lbnUgc3R5bGU9XCJ3aWR0aDogMjAwcHg7XCI+XG4gICAgICAgICAgICA8ZGl2IG56LW1lbnUtaXRlbT5cbiAgICAgICAgICAgICAgPHl6LWhlYWRlci1mdWxsc2NyZWVuPjwveXotaGVhZGVyLWZ1bGxzY3JlZW4+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgIDxkaXYgbnotbWVudS1pdGVtPlxuICAgICAgICAgICAgICA8eXotaGVhZGVyLWNsZWFyLXN0b3JhZ2U+PC95ei1oZWFkZXItY2xlYXItc3RvcmFnZT5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgICAgPGRpdiBuei1tZW51LWl0ZW0+XG4gICAgICAgICAgICAgIDx5ei1oZWFkZXItaTE4bj48L3l6LWhlYWRlci1pMThuPlxuICAgICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvbnotZHJvcGRvd24tbWVudT5cbiAgICAgIDwvbGF5b3V0LWRlZmF1bHQtaGVhZGVyLWl0ZW0+XG4gICAgICA8bGF5b3V0LWRlZmF1bHQtaGVhZGVyLWl0ZW0gZGlyZWN0aW9uPVwicmlnaHRcIj5cbiAgICAgICAgPHl6LWhlYWRlci11c2VyPjwveXotaGVhZGVyLXVzZXI+XG4gICAgICA8L2xheW91dC1kZWZhdWx0LWhlYWRlci1pdGVtPlxuICAgICAgPG5nLXRlbXBsYXRlICNhc2lkZVVzZXJUcGw+XG4gICAgICAgIDxkaXYgbnotZHJvcGRvd24gbnpUcmlnZ2VyPVwiY2xpY2tcIiBbbnpEcm9wZG93bk1lbnVdPVwidXNlck1lbnVcIiBjbGFzcz1cInl1bnphaS1kZWZhdWx0X19hc2lkZS11c2VyXCI+XG4gICAgICAgICAgPG56LWF2YXRhciBjbGFzcz1cInl1bnphaS1kZWZhdWx0X19hc2lkZS11c2VyLWF2YXRhclwiIFtuelNyY109XCJpY29uXCI+PC9uei1hdmF0YXI+XG4gICAgICAgICAgPGRpdiBjbGFzcz1cInl1bnphaS1kZWZhdWx0X19hc2lkZS11c2VyLWluZm9cIj5cbiAgICAgICAgICAgIDxzdHJvbmc+e3sgdGV4dCB9fTwvc3Ryb25nPlxuICAgICAgICAgICAgPHAgY2xhc3M9XCJtYjBcIj57eyBpbnRybyB9fTwvcD5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxuei1kcm9wZG93bi1tZW51ICN1c2VyTWVudT1cIm56RHJvcGRvd25NZW51XCI+XG4gICAgICAgICAgPHVsIG56LW1lbnU+XG4gICAgICAgICAgICA8bGkgbnotbWVudS1pdGVtIHJvdXRlckxpbms9XCIvXCI+e3sgJ21lbnUuYmFja3RvaG9tZScgfCBpMThuIH19PC9saT5cbiAgICAgICAgICA8L3VsPlxuICAgICAgICA8L256LWRyb3Bkb3duLW1lbnU+XG4gICAgICA8L25nLXRlbXBsYXRlPlxuICAgICAgPG5nLXRlbXBsYXRlICNjb250ZW50VHBsPlxuICAgICAgICA8cmV1c2UtdGFiICNyZXVzZVRhYj48L3JldXNlLXRhYj5cbiAgICAgICAgPHJvdXRlci1vdXRsZXQgKGFjdGl2YXRlKT1cInJldXNlVGFiLmFjdGl2YXRlKCRldmVudClcIj48L3JvdXRlci1vdXRsZXQ+XG4gICAgICA8L25nLXRlbXBsYXRlPlxuICAgIDwvbGF5b3V0LWRlZmF1bHQ+XG4gIGAsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIFl6TGF5b3V0QmFzaWNDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gIG9wdGlvbnM6IExheW91dERlZmF1bHRPcHRpb25zID0ge1xuICAgIGxvZ29FeHBhbmRlZDogYC4vYXNzZXRzL2xvZ28tZnVsbC5zdmdgLFxuICAgIGxvZ29Db2xsYXBzZWQ6IGAuL2Fzc2V0cy9sb2dvLnN2Z2BcbiAgfTtcblxuICBpbnRybzogc3RyaW5nID0gJyc7XG4gIHRleHQ6IHN0cmluZyA9ICcnO1xuICBpY29uOiBzdHJpbmcgPSAnJztcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGNhY2hlU2VydmljZTogQ2FjaGVTZXJ2aWNlLCBwcml2YXRlIHl6U3RvbXBTZXJ2aWNlOiBZelN0b21wU2VydmljZSkge31cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBjb25zdCBjdXJyZW50OiBOelNhZmVBbnkgPSB0aGlzLmNhY2hlU2VydmljZS5nZXQoJ195el9jdXJyZW50JywgeyBtb2RlOiAnbm9uZScgfSk7XG4gICAgY29uc3QgcHJvamVjdDogTnpTYWZlQW55ID0gdGhpcy5jYWNoZVNlcnZpY2UuZ2V0KCdfeXpfcHJvamVjdF9pbmZvJywgeyBtb2RlOiAnbm9uZScgfSk7XG4gICAgdGhpcy50ZXh0ID0gY3VycmVudC50ZXh0ID8gY3VycmVudC50ZXh0IDogJ+W6lOeUqOWQjeensCc7XG4gICAgdGhpcy5pbnRybyA9IGN1cnJlbnQuaW50cm8gPyBjdXJyZW50LmludHJvIDogJ+W6lOeUqOaPj+i/sCc7XG4gICAgdGhpcy5pY29uID0gY3VycmVudC5pY29uID8gY3VycmVudC5pY29uIDogYC4vYXNzZXRzL3RtcC9pbWcvYXZhdGFyLmpwZ2A7XG4gICAgdGhpcy5vcHRpb25zLmxvZ29FeHBhbmRlZCA9IHByb2plY3QubWF4TG9nb1VybCA/IHByb2plY3QubWF4TG9nb1VybCA6IGAuL2Fzc2V0cy9sb2dvLWZ1bGwuc3ZnYDtcbiAgICB0aGlzLm9wdGlvbnMubG9nb0NvbGxhcHNlZCA9IHByb2plY3QubWluaUxvZ29VcmwgPyBwcm9qZWN0Lm1pbmlMb2dvVXJsIDogYC4vYXNzZXRzL2xvZ28uc3ZnYDtcbiAgICB0aGlzLnl6U3RvbXBTZXJ2aWNlLmxpc3RlbigpO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy55elN0b21wU2VydmljZS51bkxpc3RlbigpO1xuICB9XG59XG4iXX0=
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"yz.basic.component.js","sourceRoot":"","sources":["../../../../../packages/bis/layout/yz.basic.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnDestroy, OnInit } from '@angular/core';\n\nimport { CacheService } from '@yelon/cache';\nimport { LayoutDefaultOptions, LayoutService } from '@yelon/theme/layout-default';\nimport { NzSafeAny } from 'ng-zorro-antd/core/types';\n\nimport { YzStompService } from './yz.stomp.service';\n\n@Component({\n  selector: 'yz-layout-basic',\n  template: `\n    <layout-default [options]=\"options\" [asideUser]=\"asideUserTpl\" [content]=\"showReuseTab ? contentTpl : noneTpl\">\n      <layout-default-header-item direction=\"left\">\n        <yz-header-application></yz-header-application>\n      </layout-default-header-item>\n\n      <layout-default-header-item direction=\"right\" hidden=\"mobile\">\n        <yz-header-notify></yz-header-notify>\n      </layout-default-header-item>\n\n      <layout-default-header-item direction=\"right\" hidden=\"mobile\">\n        <yz-header-theme-btn></yz-header-theme-btn>\n      </layout-default-header-item>\n\n      <layout-default-header-item direction=\"right\" hidden=\"mobile\">\n        <div\n          layout-default-header-item-trigger\n          nz-dropdown\n          [nzDropdownMenu]=\"settingsMenu\"\n          nzTrigger=\"click\"\n          nzPlacement=\"bottomRight\"\n        >\n          <i nz-icon nzType=\"setting\"></i>\n        </div>\n        <nz-dropdown-menu #settingsMenu=\"nzDropdownMenu\">\n          <div nz-menu style=\"width: 200px;\">\n            <div nz-menu-item>\n              <yz-header-fullscreen></yz-header-fullscreen>\n            </div>\n            <div nz-menu-item>\n              <yz-header-clear-storage></yz-header-clear-storage>\n            </div>\n            <div nz-menu-item>\n              <yz-header-i18n></yz-header-i18n>\n            </div>\n          </div>\n        </nz-dropdown-menu>\n      </layout-default-header-item>\n      <layout-default-header-item direction=\"right\">\n        <yz-header-user></yz-header-user>\n      </layout-default-header-item>\n      <ng-template #asideUserTpl>\n        <div nz-dropdown nzTrigger=\"click\" [nzDropdownMenu]=\"userMenu\" class=\"yunzai-default__aside-user\">\n          <nz-avatar class=\"yunzai-default__aside-user-avatar\" [nzSrc]=\"icon\"></nz-avatar>\n          <div class=\"yunzai-default__aside-user-info\">\n            <strong>{{ text }}</strong>\n            <p class=\"mb0\">{{ intro }}</p>\n          </div>\n        </div>\n        <nz-dropdown-menu #userMenu=\"nzDropdownMenu\">\n          <ul nz-menu>\n            <li nz-menu-item routerLink=\"/\">{{ 'menu.backtohome' | i18n }}</li>\n          </ul>\n        </nz-dropdown-menu>\n      </ng-template>\n      <ng-template #contentTpl>\n        <reuse-tab #reuseTab [ngStyle]=\"reuseStyleSheet\"></reuse-tab>\n        <router-outlet (activate)=\"reuseTab.activate($event)\"></router-outlet>\n      </ng-template>\n      <ng-template #noneTpl>\n        <router-outlet></router-outlet>\n      </ng-template>\n    </layout-default>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class YzLayoutBasicComponent implements OnInit, OnDestroy {\n  options: LayoutDefaultOptions = {\n    logoExpanded: `./assets/logo-full.svg`,\n    logoCollapsed: `./assets/logo.svg`\n  };\n\n  intro: string = '';\n  text: string = '';\n  icon: string = '';\n\n  showReuseTab: boolean = true;\n  showHeader: boolean = true;\n  showSider: boolean = true;\n\n  get reuseStyleSheet(): NzSafeAny {\n    let cascadingStyleSheet = {};\n    if (!this.showHeader) {\n      cascadingStyleSheet = {\n        ...cascadingStyleSheet,\n        top: 0\n      };\n    }\n    if (!this.showSider) {\n      cascadingStyleSheet = {\n        ...cascadingStyleSheet,\n        left: '24px'\n      };\n    }\n    return cascadingStyleSheet;\n  }\n\n  constructor(\n    private cacheService: CacheService,\n    private yzStompService: YzStompService,\n    private layoutService: LayoutService\n  ) {}\n\n  ngOnInit(): void {\n    const current: NzSafeAny = this.cacheService.get('_yz_current', { mode: 'none' });\n    const project: NzSafeAny = this.cacheService.get('_yz_project_info', { mode: 'none' });\n    this.text = current.text ? current.text : '应用名称';\n    this.intro = current.intro ? current.intro : '应用描述';\n    this.icon = current.icon ? current.icon : `./assets/tmp/img/avatar.jpg`;\n    this.options.logoExpanded = project.maxLogoUrl ? project.maxLogoUrl : `./assets/logo-full.svg`;\n    this.options.logoCollapsed = project.miniLogoUrl ? project.miniLogoUrl : `./assets/logo.svg`;\n    this.yzStompService.listen();\n    this.layoutService.reuseTab.asObservable().subscribe(show => (this.showReuseTab = show));\n    this.layoutService.header.asObservable().subscribe(show => (this.showHeader = show));\n    this.layoutService.sidebar.asObservable().subscribe(show => (this.showSider = show));\n  }\n\n  ngOnDestroy(): void {\n    this.yzStompService.unListen();\n  }\n}\n"]}
@@ -33,6 +33,7 @@ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
33
33
  import * as i4 from '@angular/router';
34
34
  import { RouterModule, Router } from '@angular/router';
35
35
  import { YzSharedModule, ICONS } from '@yelon/bis/shared';
36
+ import { LayoutService } from '@yelon/theme/layout-default';
36
37
  import { RxStomp } from '@stomp/rx-stomp';
37
38
  import * as i3$1 from 'ng-zorro-antd/notification';
38
39
  import { NzNotificationService } from 'ng-zorro-antd/notification';
@@ -1507,9 +1508,10 @@ YzStompService.ctorParameters = () => [
1507
1508
  ];
1508
1509
 
1509
1510
  class YzLayoutBasicComponent {
1510
- constructor(cacheService, yzStompService) {
1511
+ constructor(cacheService, yzStompService, layoutService) {
1511
1512
  this.cacheService = cacheService;
1512
1513
  this.yzStompService = yzStompService;
1514
+ this.layoutService = layoutService;
1513
1515
  this.options = {
1514
1516
  logoExpanded: `./assets/logo-full.svg`,
1515
1517
  logoCollapsed: `./assets/logo.svg`
@@ -1517,6 +1519,19 @@ class YzLayoutBasicComponent {
1517
1519
  this.intro = '';
1518
1520
  this.text = '';
1519
1521
  this.icon = '';
1522
+ this.showReuseTab = true;
1523
+ this.showHeader = true;
1524
+ this.showSider = true;
1525
+ }
1526
+ get reuseStyleSheet() {
1527
+ let cascadingStyleSheet = {};
1528
+ if (!this.showHeader) {
1529
+ cascadingStyleSheet = Object.assign(Object.assign({}, cascadingStyleSheet), { top: 0 });
1530
+ }
1531
+ if (!this.showSider) {
1532
+ cascadingStyleSheet = Object.assign(Object.assign({}, cascadingStyleSheet), { left: '24px' });
1533
+ }
1534
+ return cascadingStyleSheet;
1520
1535
  }
1521
1536
  ngOnInit() {
1522
1537
  const current = this.cacheService.get('_yz_current', { mode: 'none' });
@@ -1527,6 +1542,9 @@ class YzLayoutBasicComponent {
1527
1542
  this.options.logoExpanded = project.maxLogoUrl ? project.maxLogoUrl : `./assets/logo-full.svg`;
1528
1543
  this.options.logoCollapsed = project.miniLogoUrl ? project.miniLogoUrl : `./assets/logo.svg`;
1529
1544
  this.yzStompService.listen();
1545
+ this.layoutService.reuseTab.asObservable().subscribe(show => (this.showReuseTab = show));
1546
+ this.layoutService.header.asObservable().subscribe(show => (this.showHeader = show));
1547
+ this.layoutService.sidebar.asObservable().subscribe(show => (this.showSider = show));
1530
1548
  }
1531
1549
  ngOnDestroy() {
1532
1550
  this.yzStompService.unListen();
@@ -1536,7 +1554,7 @@ YzLayoutBasicComponent.decorators = [
1536
1554
  { type: Component, args: [{
1537
1555
  selector: 'yz-layout-basic',
1538
1556
  template: `
1539
- <layout-default [options]="options" [asideUser]="asideUserTpl" [content]="contentTpl">
1557
+ <layout-default [options]="options" [asideUser]="asideUserTpl" [content]="showReuseTab ? contentTpl : noneTpl">
1540
1558
  <layout-default-header-item direction="left">
1541
1559
  <yz-header-application></yz-header-application>
1542
1560
  </layout-default-header-item>
@@ -1591,9 +1609,12 @@ YzLayoutBasicComponent.decorators = [
1591
1609
  </nz-dropdown-menu>
1592
1610
  </ng-template>
1593
1611
  <ng-template #contentTpl>
1594
- <reuse-tab #reuseTab></reuse-tab>
1612
+ <reuse-tab #reuseTab [ngStyle]="reuseStyleSheet"></reuse-tab>
1595
1613
  <router-outlet (activate)="reuseTab.activate($event)"></router-outlet>
1596
1614
  </ng-template>
1615
+ <ng-template #noneTpl>
1616
+ <router-outlet></router-outlet>
1617
+ </ng-template>
1597
1618
  </layout-default>
1598
1619
  `,
1599
1620
  changeDetection: ChangeDetectionStrategy.OnPush
@@ -1601,7 +1622,8 @@ YzLayoutBasicComponent.decorators = [
1601
1622
  ];
1602
1623
  YzLayoutBasicComponent.ctorParameters = () => [
1603
1624
  { type: CacheService },
1604
- { type: YzStompService }
1625
+ { type: YzStompService },
1626
+ { type: LayoutService }
1605
1627
  ];
1606
1628
 
1607
1629
  /*