@delon/theme 12.4.2 → 13.1.0

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.
Files changed (219) hide show
  1. package/compact.css +1278 -750
  2. package/compact.min.css +1 -1
  3. package/dark.css +1325 -797
  4. package/dark.min.css +1 -1
  5. package/default.css +1286 -758
  6. package/default.min.css +1 -1
  7. package/{esm2015/layout-blank/layout-blank.js → esm2020/layout-blank/layout-blank.mjs} +0 -0
  8. package/{esm2015/layout-blank/public_api.js → esm2020/layout-blank/public_api.mjs} +0 -0
  9. package/{esm2015/layout-default/layout-default.js → esm2020/layout-default/layout-default.mjs} +0 -0
  10. package/esm2020/layout-default/layout-header-item-trigger.directive.mjs +16 -0
  11. package/esm2020/layout-default/layout-header-item.component.mjs +33 -0
  12. package/esm2020/layout-default/layout-header.component.mjs +123 -0
  13. package/esm2020/layout-default/layout-nav.component.mjs +307 -0
  14. package/esm2020/layout-default/layout.component.mjs +132 -0
  15. package/esm2020/layout-default/layout.module.mjs +69 -0
  16. package/{esm2015/layout-default/public_api.js → esm2020/layout-default/public_api.mjs} +0 -0
  17. package/{esm2015/layout-default/types.js → esm2020/layout-default/types.mjs} +0 -0
  18. package/esm2020/public_api.mjs +25 -0
  19. package/{esm2015/setting-drawer/public_api.js → esm2020/setting-drawer/public_api.mjs} +0 -0
  20. package/esm2020/setting-drawer/setting-drawer-item.component.mjs +35 -0
  21. package/esm2020/setting-drawer/setting-drawer.component.mjs +192 -0
  22. package/{esm2015/setting-drawer/setting-drawer.js → esm2020/setting-drawer/setting-drawer.mjs} +0 -0
  23. package/esm2020/setting-drawer/setting-drawer.module.mjs +68 -0
  24. package/{esm2015/setting-drawer/setting-drawer.types.js → esm2020/setting-drawer/setting-drawer.types.mjs} +0 -0
  25. package/{esm2015/src/config.js → esm2020/src/config.mjs} +0 -0
  26. package/{esm2015/src/locale/index.js → esm2020/src/locale/index.mjs} +0 -0
  27. package/{esm2015/src/locale/languages/el-GR.js → esm2020/src/locale/languages/el-GR.mjs} +0 -0
  28. package/{esm2015/src/locale/languages/en-US.js → esm2020/src/locale/languages/en-US.mjs} +0 -0
  29. package/{esm2015/src/locale/languages/es-ES.js → esm2020/src/locale/languages/es-ES.mjs} +0 -0
  30. package/{esm2015/src/locale/languages/fr-FR.js → esm2020/src/locale/languages/fr-FR.mjs} +0 -0
  31. package/{esm2015/src/locale/languages/hr-HR.js → esm2020/src/locale/languages/hr-HR.mjs} +0 -0
  32. package/{esm2015/src/locale/languages/it-IT.js → esm2020/src/locale/languages/it-IT.mjs} +0 -0
  33. package/{esm2015/src/locale/languages/ja-JP.js → esm2020/src/locale/languages/ja-JP.mjs} +0 -0
  34. package/{esm2015/src/locale/languages/ko-KR.js → esm2020/src/locale/languages/ko-KR.mjs} +0 -0
  35. package/{esm2015/src/locale/languages/pl-PL.js → esm2020/src/locale/languages/pl-PL.mjs} +0 -0
  36. package/{esm2015/src/locale/languages/sl-SI.js → esm2020/src/locale/languages/sl-SI.mjs} +0 -0
  37. package/{esm2015/src/locale/languages/tr-TR.js → esm2020/src/locale/languages/tr-TR.mjs} +0 -0
  38. package/{esm2015/src/locale/languages/zh-CN.js → esm2020/src/locale/languages/zh-CN.mjs} +0 -0
  39. package/{esm2015/src/locale/languages/zh-TW.js → esm2020/src/locale/languages/zh-TW.mjs} +0 -0
  40. package/esm2020/src/locale/locale.module.mjs +17 -0
  41. package/esm2020/src/locale/locale.service.mjs +45 -0
  42. package/{esm2015/src/locale/locale.tokens.js → esm2020/src/locale/locale.tokens.mjs} +0 -0
  43. package/{esm2015/src/locale/locale.types.js → esm2020/src/locale/locale.types.mjs} +0 -0
  44. package/{esm2015/src/locale/public_api.js → esm2020/src/locale/public_api.mjs} +0 -0
  45. package/esm2020/src/pipes/date/date.pipe.mjs +24 -0
  46. package/esm2020/src/pipes/keys/keys.pipe.mjs +21 -0
  47. package/esm2020/src/pipes/safe/html.pipe.mjs +18 -0
  48. package/esm2020/src/pipes/safe/url.pipe.mjs +18 -0
  49. package/esm2020/src/pipes/yn/yn.pipe.mjs +38 -0
  50. package/esm2020/src/router/optional-preloader.mjs +22 -0
  51. package/esm2020/src/services/drawer/drawer.helper.mjs +91 -0
  52. package/esm2020/src/services/http/http.client.mjs +154 -0
  53. package/esm2020/src/services/http/http.decorator.mjs +215 -0
  54. package/esm2020/src/services/i18n/i18n.mjs +97 -0
  55. package/esm2020/src/services/i18n/i18n.pipe.mjs +21 -0
  56. package/{esm2015/src/services/menu/interface.js → esm2020/src/services/menu/interface.mjs} +0 -0
  57. package/esm2020/src/services/menu/menu.service.mjs +252 -0
  58. package/esm2020/src/services/modal/modal.helper.mjs +106 -0
  59. package/{esm2015/src/services/preloader/preloader.js → esm2020/src/services/preloader/preloader.mjs} +0 -0
  60. package/esm2020/src/services/responsive/responsive.mjs +46 -0
  61. package/esm2020/src/services/rtl/rtl.service.mjs +101 -0
  62. package/esm2020/src/services/settings/settings.service.mjs +100 -0
  63. package/{esm2015/src/services/settings/types.js → esm2020/src/services/settings/types.mjs} +0 -0
  64. package/esm2020/src/services/title/title.service.mjs +124 -0
  65. package/esm2020/src/theme.module.mjs +76 -0
  66. package/{esm2015/src/version.js → esm2020/src/version.mjs} +1 -1
  67. package/{esm2015/theme-btn/public_api.js → esm2020/theme-btn/public_api.mjs} +0 -0
  68. package/esm2020/theme-btn/theme-btn.component.mjs +106 -0
  69. package/esm2020/theme-btn/theme-btn.mjs +5 -0
  70. package/esm2020/theme-btn/theme-btn.module.mjs +32 -0
  71. package/esm2020/theme.mjs +5 -0
  72. package/fesm2015/{layout-blank.js → layout-blank.mjs} +1 -1
  73. package/fesm2015/layout-blank.mjs.map +1 -0
  74. package/fesm2015/layout-default.mjs +654 -0
  75. package/fesm2015/layout-default.mjs.map +1 -0
  76. package/fesm2015/setting-drawer.mjs +487 -0
  77. package/fesm2015/setting-drawer.mjs.map +1 -0
  78. package/fesm2015/theme-btn.mjs +144 -0
  79. package/fesm2015/theme-btn.mjs.map +1 -0
  80. package/fesm2015/{theme.js → theme.mjs} +226 -188
  81. package/fesm2015/theme.mjs.map +1 -0
  82. package/fesm2020/layout-blank.mjs +7 -0
  83. package/fesm2020/layout-blank.mjs.map +1 -0
  84. package/fesm2020/layout-default.mjs +654 -0
  85. package/fesm2020/layout-default.mjs.map +1 -0
  86. package/fesm2020/setting-drawer.mjs +482 -0
  87. package/fesm2020/setting-drawer.mjs.map +1 -0
  88. package/fesm2020/theme-btn.mjs +141 -0
  89. package/fesm2020/theme-btn.mjs.map +1 -0
  90. package/fesm2020/theme.mjs +2575 -0
  91. package/fesm2020/theme.mjs.map +1 -0
  92. package/layout-blank/layout-blank.d.ts +1 -0
  93. package/layout-blank/package.json +5 -6
  94. package/layout-default/layout-default.d.ts +1 -0
  95. package/layout-default/layout-header-item-trigger.directive.d.ts +3 -0
  96. package/layout-default/layout-header-item.component.d.ts +3 -0
  97. package/layout-default/layout-header.component.d.ts +8 -5
  98. package/layout-default/layout-nav.component.d.ts +4 -1
  99. package/layout-default/layout.component.d.ts +6 -3
  100. package/layout-default/layout.module.d.ts +17 -0
  101. package/layout-default/package.json +5 -6
  102. package/layout-default/style/_aside.less +7 -10
  103. package/layout-default/style/_fixed.less +2 -0
  104. package/layout-default/style/_header.less +21 -0
  105. package/layout-default/style/_layout.less +7 -0
  106. package/layout-default/style/_progress-bar.less +6 -0
  107. package/layout-default/style/fix/_full-content.less +4 -0
  108. package/layout-default/style/widgets/_app-icons.less +3 -0
  109. package/layout-default/style/widgets/_user.less +5 -0
  110. package/package.json +55 -11
  111. package/public_api.d.ts +1 -0
  112. package/setting-drawer/package.json +5 -6
  113. package/setting-drawer/setting-drawer-item.component.d.ts +3 -0
  114. package/setting-drawer/setting-drawer.component.d.ts +3 -0
  115. package/setting-drawer/setting-drawer.d.ts +1 -0
  116. package/setting-drawer/setting-drawer.module.d.ts +18 -0
  117. package/setting-drawer/style/index.less +9 -0
  118. package/setting-drawer/style/rtl.less +1 -0
  119. package/src/locale/locale.module.d.ts +4 -0
  120. package/src/locale/locale.service.d.ts +3 -0
  121. package/src/pipes/date/date.pipe.d.ts +3 -0
  122. package/src/pipes/keys/keys.pipe.d.ts +3 -0
  123. package/src/pipes/safe/html.pipe.d.ts +3 -0
  124. package/src/pipes/safe/url.pipe.d.ts +3 -0
  125. package/src/pipes/yn/style/index.less +3 -0
  126. package/src/pipes/yn/yn.pipe.d.ts +3 -0
  127. package/src/services/drawer/drawer.helper.d.ts +3 -0
  128. package/src/services/http/http.client.d.ts +3 -0
  129. package/src/services/http/http.decorator.d.ts +3 -0
  130. package/src/services/i18n/i18n.d.ts +5 -0
  131. package/src/services/i18n/i18n.pipe.d.ts +3 -0
  132. package/src/services/menu/menu.service.d.ts +5 -0
  133. package/src/services/modal/modal.helper.d.ts +3 -0
  134. package/src/services/responsive/responsive.d.ts +3 -0
  135. package/src/services/rtl/rtl.service.d.ts +3 -0
  136. package/src/services/settings/settings.service.d.ts +9 -0
  137. package/src/services/title/title.service.d.ts +3 -0
  138. package/src/theme.module.d.ts +15 -0
  139. package/system/_preloader.less +10 -0
  140. package/system/_type.less +5 -0
  141. package/system/antd/_modal.less +5 -0
  142. package/system/antd/_table.less +7 -0
  143. package/system/index.less +3 -3
  144. package/system/mixins/_freak.less +2 -2
  145. package/system/mixins/_text-truncate.less +2 -0
  146. package/system/ng/_form.less +1 -0
  147. package/system/theme-default.less +3 -1
  148. package/system/utils/_display.less +9 -0
  149. package/system/utils/_other.less +2 -0
  150. package/system/utils/_scrollbar.less +3 -0
  151. package/system/widgets/_abs.less +3 -0
  152. package/system/widgets/_half-float.less +2 -0
  153. package/system/widgets/_masonry-grid.less +2 -0
  154. package/theme-btn/package.json +6 -7
  155. package/theme-btn/style/index.less +1 -0
  156. package/theme-btn/theme-btn.component.d.ts +3 -0
  157. package/theme-btn/{layout-theme-btn.d.ts → theme-btn.d.ts} +1 -0
  158. package/theme-btn/theme-btn.module.d.ts +8 -0
  159. package/theme-compact.less +1 -1
  160. package/theme-dark.less +1 -1
  161. package/theme-default.less +1 -1
  162. package/theme.d.ts +1 -1
  163. package/bundles/layout-blank.umd.js +0 -19
  164. package/bundles/layout-blank.umd.js.map +0 -1
  165. package/bundles/layout-default.umd.js +0 -876
  166. package/bundles/layout-default.umd.js.map +0 -1
  167. package/bundles/layout-theme-btn.umd.js +0 -141
  168. package/bundles/layout-theme-btn.umd.js.map +0 -1
  169. package/bundles/setting-drawer.umd.js +0 -789
  170. package/bundles/setting-drawer.umd.js.map +0 -1
  171. package/bundles/theme.umd.js +0 -3075
  172. package/bundles/theme.umd.js.map +0 -1
  173. package/esm2015/layout-default/layout-header-item-trigger.directive.js +0 -12
  174. package/esm2015/layout-default/layout-header-item.component.js +0 -23
  175. package/esm2015/layout-default/layout-header.component.js +0 -94
  176. package/esm2015/layout-default/layout-nav.component.js +0 -306
  177. package/esm2015/layout-default/layout.component.js +0 -102
  178. package/esm2015/layout-default/layout.module.js +0 -40
  179. package/esm2015/public_api.js +0 -24
  180. package/esm2015/setting-drawer/setting-drawer-item.component.js +0 -30
  181. package/esm2015/setting-drawer/setting-drawer.component.js +0 -185
  182. package/esm2015/setting-drawer/setting-drawer.module.js +0 -39
  183. package/esm2015/src/locale/locale.module.js +0 -14
  184. package/esm2015/src/locale/locale.service.js +0 -42
  185. package/esm2015/src/pipes/date/date.pipe.js +0 -23
  186. package/esm2015/src/pipes/keys/keys.pipe.js +0 -17
  187. package/esm2015/src/pipes/safe/html.pipe.js +0 -17
  188. package/esm2015/src/pipes/safe/url.pipe.js +0 -17
  189. package/esm2015/src/pipes/yn/yn.pipe.js +0 -37
  190. package/esm2015/src/router/optional-preloader.js +0 -23
  191. package/esm2015/src/services/drawer/drawer.helper.js +0 -90
  192. package/esm2015/src/services/http/http.client.js +0 -138
  193. package/esm2015/src/services/http/http.decorator.js +0 -207
  194. package/esm2015/src/services/i18n/i18n.js +0 -96
  195. package/esm2015/src/services/i18n/i18n.pipe.js +0 -17
  196. package/esm2015/src/services/menu/menu.service.js +0 -252
  197. package/esm2015/src/services/modal/modal.helper.js +0 -105
  198. package/esm2015/src/services/responsive/responsive.js +0 -48
  199. package/esm2015/src/services/rtl/rtl.service.js +0 -110
  200. package/esm2015/src/services/settings/settings.service.js +0 -82
  201. package/esm2015/src/services/title/title.service.js +0 -125
  202. package/esm2015/src/theme.module.js +0 -67
  203. package/esm2015/theme-btn/layout-theme-btn.js +0 -5
  204. package/esm2015/theme-btn/theme-btn.component.js +0 -103
  205. package/esm2015/theme-btn/theme-btn.module.js +0 -22
  206. package/esm2015/theme.js +0 -6
  207. package/fesm2015/layout-blank.js.map +0 -1
  208. package/fesm2015/layout-default.js +0 -561
  209. package/fesm2015/layout-default.js.map +0 -1
  210. package/fesm2015/layout-theme-btn.js +0 -129
  211. package/fesm2015/layout-theme-btn.js.map +0 -1
  212. package/fesm2015/setting-drawer.js +0 -448
  213. package/fesm2015/setting-drawer.js.map +0 -1
  214. package/fesm2015/theme.js.map +0 -1
  215. package/layout-blank/layout-blank.metadata.json +0 -1
  216. package/layout-default/layout-default.metadata.json +0 -1
  217. package/setting-drawer/setting-drawer.metadata.json +0 -1
  218. package/theme-btn/layout-theme-btn.metadata.json +0 -1
  219. package/theme.metadata.json +0 -1
@@ -0,0 +1,654 @@
1
+ import * as i6 from '@angular/common';
2
+ import { DOCUMENT, CommonModule } from '@angular/common';
3
+ import * as i0 from '@angular/core';
4
+ import { Component, ViewChild, Input, ChangeDetectionStrategy, EventEmitter, ViewEncapsulation, Inject, Optional, Output, ContentChildren, Directive, NgModule } from '@angular/core';
5
+ import * as i2 from '@angular/router';
6
+ import { NavigationEnd, RouteConfigLoadStart, NavigationError, NavigationCancel, RouteConfigLoadEnd, RouterModule } from '@angular/router';
7
+ import { Subject } from 'rxjs';
8
+ import { takeUntil, filter } from 'rxjs/operators';
9
+ import { updateHostClass } from '@delon/util/browser';
10
+ import * as i2$1 from 'ng-zorro-antd/message';
11
+ import { NzMessageModule } from 'ng-zorro-antd/message';
12
+ import * as i1 from '@delon/theme';
13
+ import * as i4 from 'ng-zorro-antd/icon';
14
+ import { NzIconModule } from 'ng-zorro-antd/icon';
15
+ import { __decorate } from 'tslib';
16
+ import { InputBoolean, InputNumber, ZoneOutside } from '@delon/util/decorator';
17
+ import { WINDOW } from '@delon/util/token';
18
+ import * as i3 from '@angular/platform-browser';
19
+ import * as i4$1 from '@angular/cdk/bidi';
20
+ import * as i5 from 'ng-zorro-antd/badge';
21
+ import { NzBadgeModule } from 'ng-zorro-antd/badge';
22
+ import * as i8 from 'ng-zorro-antd/tooltip';
23
+ import { NzToolTipModule } from 'ng-zorro-antd/tooltip';
24
+ import { NzAvatarModule } from 'ng-zorro-antd/avatar';
25
+ import { NzDropDownModule } from 'ng-zorro-antd/dropdown';
26
+
27
+ class LayoutDefaultHeaderItemComponent {
28
+ constructor() {
29
+ this.hidden = 'none';
30
+ this.direction = 'right';
31
+ }
32
+ }
33
+ LayoutDefaultHeaderItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: LayoutDefaultHeaderItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
34
+ LayoutDefaultHeaderItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: LayoutDefaultHeaderItemComponent, selector: "layout-default-header-item", inputs: { hidden: "hidden", direction: "direction" }, viewQueries: [{ propertyName: "host", first: true, predicate: ["host"], descendants: true, static: true }], ngImport: i0, template: `
35
+ <ng-template #host>
36
+ <ng-content></ng-content>
37
+ </ng-template>
38
+ `, isInline: true });
39
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: LayoutDefaultHeaderItemComponent, decorators: [{
40
+ type: Component,
41
+ args: [{
42
+ selector: 'layout-default-header-item',
43
+ template: `
44
+ <ng-template #host>
45
+ <ng-content></ng-content>
46
+ </ng-template>
47
+ `
48
+ }]
49
+ }], propDecorators: { host: [{
50
+ type: ViewChild,
51
+ args: ['host', { static: true }]
52
+ }], hidden: [{
53
+ type: Input
54
+ }], direction: [{
55
+ type: Input
56
+ }] } });
57
+
58
+ class LayoutDefaultHeaderComponent {
59
+ constructor(settings, cdr) {
60
+ this.settings = settings;
61
+ this.cdr = cdr;
62
+ this.destroy$ = new Subject();
63
+ this.left = [];
64
+ this.middle = [];
65
+ this.right = [];
66
+ }
67
+ get app() {
68
+ return this.settings.app;
69
+ }
70
+ get collapsed() {
71
+ return this.settings.layout.collapsed;
72
+ }
73
+ get collapsedIcon() {
74
+ let type = this.collapsed ? 'unfold' : 'fold';
75
+ if (this.settings.layout.direction === 'rtl') {
76
+ type = this.collapsed ? 'fold' : 'unfold';
77
+ }
78
+ return `menu-${type}`;
79
+ }
80
+ refresh() {
81
+ const arr = this.items.toArray();
82
+ this.left = arr.filter(i => i.direction === 'left');
83
+ this.middle = arr.filter(i => i.direction === 'middle');
84
+ this.right = arr.filter(i => i.direction === 'right');
85
+ this.cdr.detectChanges();
86
+ }
87
+ ngAfterViewInit() {
88
+ this.items.changes.pipe(takeUntil(this.destroy$)).subscribe(() => this.refresh());
89
+ this.refresh();
90
+ }
91
+ toggleCollapsed() {
92
+ this.settings.setLayout('collapsed', !this.settings.layout.collapsed);
93
+ }
94
+ ngOnDestroy() {
95
+ this.destroy$.next();
96
+ this.destroy$.complete();
97
+ }
98
+ }
99
+ LayoutDefaultHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: LayoutDefaultHeaderComponent, deps: [{ token: i1.SettingsService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
100
+ LayoutDefaultHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: LayoutDefaultHeaderComponent, selector: "layout-default-header", inputs: { items: "items", options: "options" }, host: { properties: { "class.alain-default__header": "true" } }, ngImport: i0, template: `
101
+ <ng-template #render let-ls>
102
+ <li *ngFor="let i of ls" [class.hidden-mobile]="i.hidden === 'mobile'" [class.hidden-pc]="i.hidden === 'pc'">
103
+ <ng-container *ngTemplateOutlet="i.host"></ng-container>
104
+ </li>
105
+ </ng-template>
106
+ <div class="alain-default__header-logo" [style.width.px]="options.logoFixWidth">
107
+ <a [routerLink]="options.logoLink" class="alain-default__header-logo-link">
108
+ <img class="alain-default__header-logo-expanded" [attr.src]="options.logoExpanded" [attr.alt]="app.name" />
109
+ <img class="alain-default__header-logo-collapsed" [attr.src]="options.logoCollapsed" [attr.alt]="app.name" />
110
+ </a>
111
+ </div>
112
+ <div class="alain-default__nav-wrap">
113
+ <ul class="alain-default__nav">
114
+ <li *ngIf="!options.hideAside">
115
+ <div class="alain-default__nav-item alain-default__nav-item--collapse" (click)="toggleCollapsed()">
116
+ <i nz-icon [nzType]="collapsedIcon"></i>
117
+ </div>
118
+ </li>
119
+ <ng-template [ngTemplateOutlet]="render" [ngTemplateOutletContext]="{ $implicit: left }"></ng-template>
120
+ </ul>
121
+ <div *ngIf="middle.length > 0" class="alain-default__nav alain-default__nav-middle">
122
+ <ng-container *ngTemplateOutlet="middle[0].host"></ng-container>
123
+ </div>
124
+ <ul class="alain-default__nav">
125
+ <ng-template [ngTemplateOutlet]="render" [ngTemplateOutletContext]="{ $implicit: right }"></ng-template>
126
+ </ul>
127
+ </div>
128
+ `, isInline: true, directives: [{ type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i2.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo", "routerLink"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
129
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: LayoutDefaultHeaderComponent, decorators: [{
130
+ type: Component,
131
+ args: [{
132
+ selector: 'layout-default-header',
133
+ template: `
134
+ <ng-template #render let-ls>
135
+ <li *ngFor="let i of ls" [class.hidden-mobile]="i.hidden === 'mobile'" [class.hidden-pc]="i.hidden === 'pc'">
136
+ <ng-container *ngTemplateOutlet="i.host"></ng-container>
137
+ </li>
138
+ </ng-template>
139
+ <div class="alain-default__header-logo" [style.width.px]="options.logoFixWidth">
140
+ <a [routerLink]="options.logoLink" class="alain-default__header-logo-link">
141
+ <img class="alain-default__header-logo-expanded" [attr.src]="options.logoExpanded" [attr.alt]="app.name" />
142
+ <img class="alain-default__header-logo-collapsed" [attr.src]="options.logoCollapsed" [attr.alt]="app.name" />
143
+ </a>
144
+ </div>
145
+ <div class="alain-default__nav-wrap">
146
+ <ul class="alain-default__nav">
147
+ <li *ngIf="!options.hideAside">
148
+ <div class="alain-default__nav-item alain-default__nav-item--collapse" (click)="toggleCollapsed()">
149
+ <i nz-icon [nzType]="collapsedIcon"></i>
150
+ </div>
151
+ </li>
152
+ <ng-template [ngTemplateOutlet]="render" [ngTemplateOutletContext]="{ $implicit: left }"></ng-template>
153
+ </ul>
154
+ <div *ngIf="middle.length > 0" class="alain-default__nav alain-default__nav-middle">
155
+ <ng-container *ngTemplateOutlet="middle[0].host"></ng-container>
156
+ </div>
157
+ <ul class="alain-default__nav">
158
+ <ng-template [ngTemplateOutlet]="render" [ngTemplateOutletContext]="{ $implicit: right }"></ng-template>
159
+ </ul>
160
+ </div>
161
+ `,
162
+ host: {
163
+ '[class.alain-default__header]': `true`
164
+ },
165
+ changeDetection: ChangeDetectionStrategy.OnPush
166
+ }]
167
+ }], ctorParameters: function () { return [{ type: i1.SettingsService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { items: [{
168
+ type: Input
169
+ }], options: [{
170
+ type: Input
171
+ }] } });
172
+
173
+ const SHOWCLS = 'sidebar-nav__floating-show';
174
+ const FLOATINGCLS = 'sidebar-nav__floating';
175
+ class LayoutDefaultNavComponent {
176
+ constructor(menuSrv, settings, router, render, cdr, ngZone, sanitizer, doc, win, directionality) {
177
+ this.menuSrv = menuSrv;
178
+ this.settings = settings;
179
+ this.router = router;
180
+ this.render = render;
181
+ this.cdr = cdr;
182
+ this.ngZone = ngZone;
183
+ this.sanitizer = sanitizer;
184
+ this.doc = doc;
185
+ this.win = win;
186
+ this.directionality = directionality;
187
+ this.destroy$ = new Subject();
188
+ this.dir = 'ltr';
189
+ this.list = [];
190
+ this.disabledAcl = false;
191
+ this.autoCloseUnderPad = true;
192
+ this.recursivePath = true;
193
+ this.openStrictly = false;
194
+ this.maxLevelIcon = 3;
195
+ this.select = new EventEmitter();
196
+ }
197
+ get collapsed() {
198
+ return this.settings.layout.collapsed;
199
+ }
200
+ getLinkNode(node) {
201
+ node = node.nodeName === 'A' ? node : node.parentNode;
202
+ return node.nodeName !== 'A' ? null : node;
203
+ }
204
+ floatingClickHandle(e) {
205
+ e.stopPropagation();
206
+ const linkNode = this.getLinkNode(e.target);
207
+ if (linkNode == null) {
208
+ return false;
209
+ }
210
+ const id = +linkNode.dataset.id;
211
+ // Should be ingore children title trigger event
212
+ if (isNaN(id)) {
213
+ return false;
214
+ }
215
+ let item;
216
+ this.menuSrv.visit(this.list, (i) => {
217
+ if (!item && i._id === id) {
218
+ item = i;
219
+ }
220
+ });
221
+ this.to(item);
222
+ this.hideAll();
223
+ e.preventDefault();
224
+ return false;
225
+ }
226
+ clearFloating() {
227
+ if (!this.floatingEl)
228
+ return;
229
+ this.floatingEl.removeEventListener('click', this.floatingClickHandle.bind(this));
230
+ // fix ie: https://github.com/ng-alain/delon/issues/52
231
+ if (this.floatingEl.hasOwnProperty('remove')) {
232
+ this.floatingEl.remove();
233
+ }
234
+ else if (this.floatingEl.parentNode) {
235
+ this.floatingEl.parentNode.removeChild(this.floatingEl);
236
+ }
237
+ }
238
+ genFloating() {
239
+ this.clearFloating();
240
+ this.floatingEl = this.render.createElement('div');
241
+ this.floatingEl.classList.add(`${FLOATINGCLS}-container`);
242
+ this.floatingEl.addEventListener('click', this.floatingClickHandle.bind(this), false);
243
+ this.bodyEl.appendChild(this.floatingEl);
244
+ }
245
+ genSubNode(linkNode, item) {
246
+ const id = `_sidebar-nav-${item._id}`;
247
+ const childNode = item.badge ? linkNode.nextElementSibling.nextElementSibling : linkNode.nextElementSibling;
248
+ const node = childNode.cloneNode(true);
249
+ node.id = id;
250
+ node.classList.add(FLOATINGCLS);
251
+ node.addEventListener('mouseleave', () => {
252
+ node.classList.remove(SHOWCLS);
253
+ }, false);
254
+ this.floatingEl.appendChild(node);
255
+ return node;
256
+ }
257
+ hideAll() {
258
+ const allNode = this.floatingEl.querySelectorAll(`.${FLOATINGCLS}`);
259
+ for (let i = 0; i < allNode.length; i++) {
260
+ allNode[i].classList.remove(SHOWCLS);
261
+ }
262
+ }
263
+ // calculate the node position values.
264
+ calPos(linkNode, node) {
265
+ const rect = linkNode.getBoundingClientRect();
266
+ // bug: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/14721015/
267
+ const scrollTop = Math.max(this.doc.documentElement.scrollTop, this.bodyEl.scrollTop);
268
+ const docHeight = Math.max(this.doc.documentElement.clientHeight, this.bodyEl.clientHeight);
269
+ const spacing = 5;
270
+ let offsetHeight = -spacing;
271
+ if (docHeight < rect.top + node.clientHeight) {
272
+ offsetHeight = rect.top + node.clientHeight - docHeight + spacing;
273
+ }
274
+ node.style.top = `${rect.top + scrollTop - offsetHeight}px`;
275
+ if (this.dir === 'rtl') {
276
+ node.style.right = `${rect.width + spacing}px`;
277
+ }
278
+ else {
279
+ node.style.left = `${rect.right + spacing}px`;
280
+ }
281
+ }
282
+ showSubMenu(e, item) {
283
+ if (this.collapsed !== true) {
284
+ return;
285
+ }
286
+ e.preventDefault();
287
+ const linkNode = e.target;
288
+ this.genFloating();
289
+ const subNode = this.genSubNode(linkNode, item);
290
+ this.hideAll();
291
+ subNode.classList.add(SHOWCLS);
292
+ this.calPos(linkNode, subNode);
293
+ }
294
+ to(item) {
295
+ this.select.emit(item);
296
+ if (item.disabled)
297
+ return;
298
+ if (item.externalLink) {
299
+ if (item.target === '_blank') {
300
+ this.win.open(item.externalLink);
301
+ }
302
+ else {
303
+ this.win.location.href = item.externalLink;
304
+ }
305
+ return;
306
+ }
307
+ this.ngZone.run(() => this.router.navigateByUrl(item.link));
308
+ }
309
+ toggleOpen(item) {
310
+ if (!this.openStrictly) {
311
+ this.menuSrv.visit(this.list, (i) => {
312
+ if (i !== item)
313
+ i._open = false;
314
+ });
315
+ let pItem = item._parent;
316
+ while (pItem) {
317
+ pItem._open = true;
318
+ pItem = pItem._parent;
319
+ }
320
+ }
321
+ item._open = !item._open;
322
+ this.cdr.markForCheck();
323
+ }
324
+ _click() {
325
+ if (this.isPad && this.collapsed) {
326
+ this.openAside(false);
327
+ this.hideAll();
328
+ }
329
+ }
330
+ closeSubMenu() {
331
+ if (this.collapsed) {
332
+ this.hideAll();
333
+ }
334
+ }
335
+ openedByUrl(url) {
336
+ const { menuSrv, recursivePath, openStrictly } = this;
337
+ let findItem = menuSrv.getHit(this.menuSrv.menus, url, recursivePath, (i) => {
338
+ i._selected = false;
339
+ if (!openStrictly) {
340
+ i._open = false;
341
+ }
342
+ });
343
+ if (findItem == null)
344
+ return;
345
+ do {
346
+ findItem._selected = true;
347
+ if (!openStrictly) {
348
+ findItem._open = true;
349
+ }
350
+ findItem = findItem._parent;
351
+ } while (findItem);
352
+ }
353
+ ngOnInit() {
354
+ const { doc, router, destroy$, menuSrv, settings, cdr } = this;
355
+ this.bodyEl = doc.querySelector('body');
356
+ this.openedByUrl(router.url);
357
+ this.ngZone.runOutsideAngular(() => this.genFloating());
358
+ menuSrv.change.pipe(takeUntil(destroy$)).subscribe(data => {
359
+ menuSrv.visit(data, (i, _p, depth) => {
360
+ i._text = this.sanitizer.bypassSecurityTrustHtml(i.text);
361
+ i._needIcon = depth <= this.maxLevelIcon && !!i.icon;
362
+ if (!i._aclResult) {
363
+ if (this.disabledAcl) {
364
+ i.disabled = true;
365
+ }
366
+ else {
367
+ i._hidden = true;
368
+ }
369
+ }
370
+ if (this.openStrictly) {
371
+ i._open = i.open != null ? i.open : false;
372
+ }
373
+ const icon = i.icon;
374
+ if (icon && icon.type === 'svg' && typeof icon.value === 'string') {
375
+ icon.value = this.sanitizer.bypassSecurityTrustHtml(icon.value);
376
+ }
377
+ });
378
+ this.list = menuSrv.menus.filter((w) => w._hidden !== true);
379
+ cdr.detectChanges();
380
+ });
381
+ router.events.pipe(takeUntil(destroy$)).subscribe(e => {
382
+ if (e instanceof NavigationEnd) {
383
+ this.openedByUrl(e.urlAfterRedirects);
384
+ this.underPad();
385
+ this.cdr.detectChanges();
386
+ }
387
+ });
388
+ settings.notify
389
+ .pipe(takeUntil(destroy$), filter(t => t.type === 'layout' && t.name === 'collapsed'))
390
+ .subscribe(() => this.clearFloating());
391
+ this.underPad();
392
+ this.dir = this.directionality.value;
393
+ this.directionality.change?.pipe(takeUntil(destroy$)).subscribe((direction) => {
394
+ this.dir = direction;
395
+ });
396
+ }
397
+ ngOnDestroy() {
398
+ this.destroy$.next();
399
+ this.destroy$.complete();
400
+ this.clearFloating();
401
+ }
402
+ // #region Under pad
403
+ get isPad() {
404
+ return this.doc.defaultView.innerWidth < 768;
405
+ }
406
+ underPad() {
407
+ if (this.autoCloseUnderPad && this.isPad && !this.collapsed) {
408
+ setTimeout(() => this.openAside(true));
409
+ }
410
+ }
411
+ openAside(status) {
412
+ this.settings.setLayout('collapsed', status);
413
+ }
414
+ }
415
+ LayoutDefaultNavComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: LayoutDefaultNavComponent, deps: [{ token: i1.MenuService }, { token: i1.SettingsService }, { token: i2.Router }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i3.DomSanitizer }, { token: DOCUMENT }, { token: WINDOW }, { token: i4$1.Directionality, optional: true }], target: i0.ɵɵFactoryTarget.Component });
416
+ LayoutDefaultNavComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: LayoutDefaultNavComponent, selector: "layout-default-nav", inputs: { disabledAcl: "disabledAcl", autoCloseUnderPad: "autoCloseUnderPad", recursivePath: "recursivePath", openStrictly: "openStrictly", maxLevelIcon: "maxLevelIcon" }, outputs: { select: "select" }, host: { listeners: { "click": "_click()", "document:click": "closeSubMenu()" } }, ngImport: i0, template: "<ng-template #icon let-i>\n <ng-container *ngIf=\"i\" [ngSwitch]=\"i.type\">\n <i\n *ngSwitchCase=\"'icon'\"\n class=\"sidebar-nav__item-icon\"\n nz-icon\n [nzType]=\"i.value\"\n [nzTheme]=\"i.theme\"\n [nzSpin]=\"i.spin\"\n [nzTwotoneColor]=\"i.twoToneColor\"\n [nzIconfont]=\"i.iconfont\"\n [nzRotate]=\"i.rotate\"\n ></i>\n <i *ngSwitchCase=\"'iconfont'\" class=\"sidebar-nav__item-icon\" nz-icon [nzIconfont]=\"i.iconfont\"></i>\n <img *ngSwitchCase=\"'img'\" [src]=\"i.value\" class=\"sidebar-nav__item-icon sidebar-nav__item-img\" />\n <span *ngSwitchCase=\"'svg'\" class=\"sidebar-nav__item-icon sidebar-nav__item-svg\" [innerHTML]=\"i.value\"></span>\n <i *ngSwitchDefault class=\"sidebar-nav__item-icon {{ i.value }}\"></i>\n </ng-container>\n</ng-template>\n<ng-template #tree let-ls>\n <ng-container *ngFor=\"let i of ls\">\n <li\n *ngIf=\"i._hidden !== true\"\n class=\"sidebar-nav__item\"\n [class.sidebar-nav__selected]=\"i._selected\"\n [class.sidebar-nav__open]=\"i._open\"\n >\n <!-- link -->\n <a\n *ngIf=\"i.children.length === 0\"\n (click)=\"to(i)\"\n [attr.data-id]=\"i._id\"\n class=\"sidebar-nav__item-link\"\n [ngClass]=\"{ 'sidebar-nav__item-disabled': i.disabled }\"\n (mouseenter)=\"closeSubMenu()\"\n >\n <ng-container *ngIf=\"i._needIcon\">\n <ng-container *ngIf=\"!collapsed\">\n <ng-template [ngTemplateOutlet]=\"icon\" [ngTemplateOutletContext]=\"{ $implicit: i.icon }\"></ng-template>\n </ng-container>\n <span *ngIf=\"collapsed\" nz-tooltip nzTooltipPlacement=\"right\" [nzTooltipTitle]=\"i.text\">\n <ng-template [ngTemplateOutlet]=\"icon\" [ngTemplateOutletContext]=\"{ $implicit: i.icon }\"></ng-template>\n </span>\n </ng-container>\n <span class=\"sidebar-nav__item-text\" [innerHTML]=\"i._text\" [attr.title]=\"i.text\"></span>\n </a>\n <!-- has children link -->\n <a\n *ngIf=\"i.children.length > 0\"\n (click)=\"toggleOpen(i)\"\n (mouseenter)=\"showSubMenu($event, i)\"\n class=\"sidebar-nav__item-link\"\n >\n <ng-template [ngTemplateOutlet]=\"icon\" [ngTemplateOutletContext]=\"{ $implicit: i.icon }\"></ng-template>\n <span class=\"sidebar-nav__item-text\" [innerHTML]=\"i._text\" [attr.title]=\"i.text\"></span>\n <i class=\"sidebar-nav__sub-arrow\"></i>\n </a>\n <!-- badge -->\n <nz-badge *ngIf=\"i.badge\" [nzCount]=\"i.badge\" [nzDot]=\"i.badgeDot\" nzStandalone [nzOverflowCount]=\"9\"></nz-badge>\n <ul *ngIf=\"i.children.length > 0\" class=\"sidebar-nav sidebar-nav__sub sidebar-nav__depth{{ i._depth }}\">\n <ng-template [ngTemplateOutlet]=\"tree\" [ngTemplateOutletContext]=\"{ $implicit: i.children }\"></ng-template>\n </ul>\n </li>\n </ng-container>\n</ng-template>\n<ul class=\"sidebar-nav\">\n <ng-container *ngFor=\"let group of list\">\n <li class=\"sidebar-nav__item sidebar-nav__group-title\" *ngIf=\"group.group\">\n <span [innerHTML]=\"group._text\"></span>\n </li>\n <ng-template [ngTemplateOutlet]=\"tree\" [ngTemplateOutletContext]=\"{ $implicit: group.children }\"></ng-template>\n </ng-container>\n</ul>\n", components: [{ type: i5.NzBadgeComponent, selector: "nz-badge", inputs: ["nzShowZero", "nzShowDot", "nzStandalone", "nzDot", "nzOverflowCount", "nzColor", "nzStyle", "nzText", "nzTitle", "nzStatus", "nzCount", "nzOffset"], exportAs: ["nzBadge"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i6.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i4.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }, { type: i6.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i8.NzTooltipDirective, selector: "[nz-tooltip]", inputs: ["nzTooltipTitle", "nzTooltipTitleContext", "nz-tooltip", "nzTooltipTrigger", "nzTooltipPlacement", "nzTooltipOrigin", "nzTooltipVisible", "nzTooltipMouseEnterDelay", "nzTooltipMouseLeaveDelay", "nzTooltipOverlayClassName", "nzTooltipOverlayStyle", "nzTooltipArrowPointAtCenter", "nzTooltipColor"], outputs: ["nzTooltipVisibleChange"], exportAs: ["nzTooltip"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
417
+ __decorate([
418
+ InputBoolean()
419
+ ], LayoutDefaultNavComponent.prototype, "disabledAcl", void 0);
420
+ __decorate([
421
+ InputBoolean()
422
+ ], LayoutDefaultNavComponent.prototype, "autoCloseUnderPad", void 0);
423
+ __decorate([
424
+ InputBoolean()
425
+ ], LayoutDefaultNavComponent.prototype, "recursivePath", void 0);
426
+ __decorate([
427
+ InputBoolean()
428
+ ], LayoutDefaultNavComponent.prototype, "openStrictly", void 0);
429
+ __decorate([
430
+ InputNumber()
431
+ ], LayoutDefaultNavComponent.prototype, "maxLevelIcon", void 0);
432
+ __decorate([
433
+ ZoneOutside()
434
+ ], LayoutDefaultNavComponent.prototype, "showSubMenu", null);
435
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: LayoutDefaultNavComponent, decorators: [{
436
+ type: Component,
437
+ args: [{ selector: 'layout-default-nav', host: {
438
+ '(click)': '_click()',
439
+ '(document:click)': 'closeSubMenu()'
440
+ }, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<ng-template #icon let-i>\n <ng-container *ngIf=\"i\" [ngSwitch]=\"i.type\">\n <i\n *ngSwitchCase=\"'icon'\"\n class=\"sidebar-nav__item-icon\"\n nz-icon\n [nzType]=\"i.value\"\n [nzTheme]=\"i.theme\"\n [nzSpin]=\"i.spin\"\n [nzTwotoneColor]=\"i.twoToneColor\"\n [nzIconfont]=\"i.iconfont\"\n [nzRotate]=\"i.rotate\"\n ></i>\n <i *ngSwitchCase=\"'iconfont'\" class=\"sidebar-nav__item-icon\" nz-icon [nzIconfont]=\"i.iconfont\"></i>\n <img *ngSwitchCase=\"'img'\" [src]=\"i.value\" class=\"sidebar-nav__item-icon sidebar-nav__item-img\" />\n <span *ngSwitchCase=\"'svg'\" class=\"sidebar-nav__item-icon sidebar-nav__item-svg\" [innerHTML]=\"i.value\"></span>\n <i *ngSwitchDefault class=\"sidebar-nav__item-icon {{ i.value }}\"></i>\n </ng-container>\n</ng-template>\n<ng-template #tree let-ls>\n <ng-container *ngFor=\"let i of ls\">\n <li\n *ngIf=\"i._hidden !== true\"\n class=\"sidebar-nav__item\"\n [class.sidebar-nav__selected]=\"i._selected\"\n [class.sidebar-nav__open]=\"i._open\"\n >\n <!-- link -->\n <a\n *ngIf=\"i.children.length === 0\"\n (click)=\"to(i)\"\n [attr.data-id]=\"i._id\"\n class=\"sidebar-nav__item-link\"\n [ngClass]=\"{ 'sidebar-nav__item-disabled': i.disabled }\"\n (mouseenter)=\"closeSubMenu()\"\n >\n <ng-container *ngIf=\"i._needIcon\">\n <ng-container *ngIf=\"!collapsed\">\n <ng-template [ngTemplateOutlet]=\"icon\" [ngTemplateOutletContext]=\"{ $implicit: i.icon }\"></ng-template>\n </ng-container>\n <span *ngIf=\"collapsed\" nz-tooltip nzTooltipPlacement=\"right\" [nzTooltipTitle]=\"i.text\">\n <ng-template [ngTemplateOutlet]=\"icon\" [ngTemplateOutletContext]=\"{ $implicit: i.icon }\"></ng-template>\n </span>\n </ng-container>\n <span class=\"sidebar-nav__item-text\" [innerHTML]=\"i._text\" [attr.title]=\"i.text\"></span>\n </a>\n <!-- has children link -->\n <a\n *ngIf=\"i.children.length > 0\"\n (click)=\"toggleOpen(i)\"\n (mouseenter)=\"showSubMenu($event, i)\"\n class=\"sidebar-nav__item-link\"\n >\n <ng-template [ngTemplateOutlet]=\"icon\" [ngTemplateOutletContext]=\"{ $implicit: i.icon }\"></ng-template>\n <span class=\"sidebar-nav__item-text\" [innerHTML]=\"i._text\" [attr.title]=\"i.text\"></span>\n <i class=\"sidebar-nav__sub-arrow\"></i>\n </a>\n <!-- badge -->\n <nz-badge *ngIf=\"i.badge\" [nzCount]=\"i.badge\" [nzDot]=\"i.badgeDot\" nzStandalone [nzOverflowCount]=\"9\"></nz-badge>\n <ul *ngIf=\"i.children.length > 0\" class=\"sidebar-nav sidebar-nav__sub sidebar-nav__depth{{ i._depth }}\">\n <ng-template [ngTemplateOutlet]=\"tree\" [ngTemplateOutletContext]=\"{ $implicit: i.children }\"></ng-template>\n </ul>\n </li>\n </ng-container>\n</ng-template>\n<ul class=\"sidebar-nav\">\n <ng-container *ngFor=\"let group of list\">\n <li class=\"sidebar-nav__item sidebar-nav__group-title\" *ngIf=\"group.group\">\n <span [innerHTML]=\"group._text\"></span>\n </li>\n <ng-template [ngTemplateOutlet]=\"tree\" [ngTemplateOutletContext]=\"{ $implicit: group.children }\"></ng-template>\n </ng-container>\n</ul>\n" }]
441
+ }], ctorParameters: function () { return [{ type: i1.MenuService }, { type: i1.SettingsService }, { type: i2.Router }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: i3.DomSanitizer }, { type: undefined, decorators: [{
442
+ type: Inject,
443
+ args: [DOCUMENT]
444
+ }] }, { type: undefined, decorators: [{
445
+ type: Inject,
446
+ args: [WINDOW]
447
+ }] }, { type: i4$1.Directionality, decorators: [{
448
+ type: Optional
449
+ }] }]; }, propDecorators: { disabledAcl: [{
450
+ type: Input
451
+ }], autoCloseUnderPad: [{
452
+ type: Input
453
+ }], recursivePath: [{
454
+ type: Input
455
+ }], openStrictly: [{
456
+ type: Input
457
+ }], maxLevelIcon: [{
458
+ type: Input
459
+ }], select: [{
460
+ type: Output
461
+ }], showSubMenu: [] } });
462
+
463
+ class LayoutDefaultComponent {
464
+ constructor(router, msgSrv, settings, el, renderer, doc) {
465
+ this.msgSrv = msgSrv;
466
+ this.settings = settings;
467
+ this.el = el;
468
+ this.renderer = renderer;
469
+ this.doc = doc;
470
+ this.asideUser = null;
471
+ this.nav = null;
472
+ this.content = null;
473
+ this.destroy$ = new Subject();
474
+ this.isFetching = false;
475
+ router.events.pipe(takeUntil(this.destroy$)).subscribe(ev => this.processEv(ev));
476
+ }
477
+ processEv(ev) {
478
+ if (!this.isFetching && ev instanceof RouteConfigLoadStart) {
479
+ this.isFetching = true;
480
+ }
481
+ if (ev instanceof NavigationError || ev instanceof NavigationCancel) {
482
+ this.isFetching = false;
483
+ const err = this.customError === null ? null : this.customError ?? `Could not load ${ev.url} route`;
484
+ if (err && ev instanceof NavigationError) {
485
+ this.msgSrv.error(err, { nzDuration: 1000 * 3 });
486
+ }
487
+ return;
488
+ }
489
+ if (!(ev instanceof NavigationEnd || ev instanceof RouteConfigLoadEnd)) {
490
+ return;
491
+ }
492
+ if (this.isFetching) {
493
+ setTimeout(() => {
494
+ this.isFetching = false;
495
+ }, 100);
496
+ }
497
+ }
498
+ setClass() {
499
+ const { el, doc, renderer, settings } = this;
500
+ const layout = settings.layout;
501
+ updateHostClass(el.nativeElement, renderer, {
502
+ ['alain-default']: true,
503
+ [`alain-default__fixed`]: layout.fixed,
504
+ [`alain-default__collapsed`]: layout.collapsed,
505
+ [`alain-default__hide-aside`]: this.options.hideAside
506
+ });
507
+ doc.body.classList[layout.colorWeak ? 'add' : 'remove']('color-weak');
508
+ }
509
+ ngOnInit() {
510
+ this.options = {
511
+ logoExpanded: `./assets/logo-full.svg`,
512
+ logoCollapsed: `./assets/logo.svg`,
513
+ logoLink: `/`,
514
+ hideAside: false,
515
+ ...this.options
516
+ };
517
+ const { settings, destroy$ } = this;
518
+ settings.notify.pipe(takeUntil(destroy$)).subscribe(() => this.setClass());
519
+ this.setClass();
520
+ }
521
+ ngOnDestroy() {
522
+ this.destroy$.next();
523
+ this.destroy$.complete();
524
+ }
525
+ }
526
+ LayoutDefaultComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: LayoutDefaultComponent, deps: [{ token: i2.Router }, { token: i2$1.NzMessageService }, { token: i1.SettingsService }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component });
527
+ LayoutDefaultComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.2", type: LayoutDefaultComponent, selector: "layout-default", inputs: { options: "options", asideUser: "asideUser", nav: "nav", content: "content", customError: "customError" }, queries: [{ propertyName: "headerItems", predicate: LayoutDefaultHeaderItemComponent }], exportAs: ["layoutDefault"], ngImport: i0, template: `
528
+ <div class="alain-default__progress-bar" *ngIf="isFetching"></div>
529
+ <layout-default-header [options]="options" [items]="headerItems"></layout-default-header>
530
+ <div *ngIf="!options.hideAside" class="alain-default__aside">
531
+ <div class="alain-default__aside-inner">
532
+ <ng-container *ngTemplateOutlet="asideUser"></ng-container>
533
+ <ng-container *ngTemplateOutlet="nav"></ng-container>
534
+ <layout-default-nav *ngIf="!nav" class="d-block py-lg"></layout-default-nav>
535
+ </div>
536
+ </div>
537
+ <section class="alain-default__content">
538
+ <ng-container *ngTemplateOutlet="content"></ng-container>
539
+ <ng-content></ng-content>
540
+ </section>
541
+ `, isInline: true, components: [{ type: LayoutDefaultHeaderComponent, selector: "layout-default-header", inputs: ["items", "options"] }, { type: LayoutDefaultNavComponent, selector: "layout-default-nav", inputs: ["disabledAcl", "autoCloseUnderPad", "recursivePath", "openStrictly", "maxLevelIcon"], outputs: ["select"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }] });
542
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: LayoutDefaultComponent, decorators: [{
543
+ type: Component,
544
+ args: [{
545
+ selector: 'layout-default',
546
+ exportAs: 'layoutDefault',
547
+ template: `
548
+ <div class="alain-default__progress-bar" *ngIf="isFetching"></div>
549
+ <layout-default-header [options]="options" [items]="headerItems"></layout-default-header>
550
+ <div *ngIf="!options.hideAside" class="alain-default__aside">
551
+ <div class="alain-default__aside-inner">
552
+ <ng-container *ngTemplateOutlet="asideUser"></ng-container>
553
+ <ng-container *ngTemplateOutlet="nav"></ng-container>
554
+ <layout-default-nav *ngIf="!nav" class="d-block py-lg"></layout-default-nav>
555
+ </div>
556
+ </div>
557
+ <section class="alain-default__content">
558
+ <ng-container *ngTemplateOutlet="content"></ng-container>
559
+ <ng-content></ng-content>
560
+ </section>
561
+ `
562
+ }]
563
+ }], ctorParameters: function () { return [{ type: i2.Router }, { type: i2$1.NzMessageService }, { type: i1.SettingsService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: undefined, decorators: [{
564
+ type: Inject,
565
+ args: [DOCUMENT]
566
+ }] }]; }, propDecorators: { headerItems: [{
567
+ type: ContentChildren,
568
+ args: [LayoutDefaultHeaderItemComponent, { descendants: false }]
569
+ }], options: [{
570
+ type: Input
571
+ }], asideUser: [{
572
+ type: Input
573
+ }], nav: [{
574
+ type: Input
575
+ }], content: [{
576
+ type: Input
577
+ }], customError: [{
578
+ type: Input
579
+ }] } });
580
+
581
+ class LayoutDefaultHeaderItemTriggerDirective {
582
+ }
583
+ LayoutDefaultHeaderItemTriggerDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: LayoutDefaultHeaderItemTriggerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
584
+ LayoutDefaultHeaderItemTriggerDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.1.2", type: LayoutDefaultHeaderItemTriggerDirective, selector: "[layout-default-header-item-trigger]", host: { properties: { "class.alain-default__nav-item": "true" } }, ngImport: i0 });
585
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: LayoutDefaultHeaderItemTriggerDirective, decorators: [{
586
+ type: Directive,
587
+ args: [{
588
+ selector: '[layout-default-header-item-trigger]',
589
+ host: {
590
+ '[class.alain-default__nav-item]': `true`
591
+ }
592
+ }]
593
+ }] });
594
+
595
+ const COMPONENTS = [
596
+ LayoutDefaultComponent,
597
+ LayoutDefaultNavComponent,
598
+ LayoutDefaultHeaderComponent,
599
+ LayoutDefaultHeaderItemComponent,
600
+ LayoutDefaultHeaderItemTriggerDirective
601
+ ];
602
+ class LayoutDefaultModule {
603
+ }
604
+ LayoutDefaultModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: LayoutDefaultModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
605
+ LayoutDefaultModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: LayoutDefaultModule, declarations: [LayoutDefaultComponent,
606
+ LayoutDefaultNavComponent,
607
+ LayoutDefaultHeaderComponent,
608
+ LayoutDefaultHeaderItemComponent,
609
+ LayoutDefaultHeaderItemTriggerDirective], imports: [CommonModule,
610
+ RouterModule,
611
+ NzToolTipModule,
612
+ NzIconModule,
613
+ NzAvatarModule,
614
+ NzDropDownModule,
615
+ NzMessageModule,
616
+ NzBadgeModule], exports: [LayoutDefaultComponent,
617
+ LayoutDefaultNavComponent,
618
+ LayoutDefaultHeaderComponent,
619
+ LayoutDefaultHeaderItemComponent,
620
+ LayoutDefaultHeaderItemTriggerDirective] });
621
+ LayoutDefaultModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: LayoutDefaultModule, imports: [[
622
+ CommonModule,
623
+ RouterModule,
624
+ NzToolTipModule,
625
+ NzIconModule,
626
+ NzAvatarModule,
627
+ NzDropDownModule,
628
+ NzMessageModule,
629
+ NzBadgeModule
630
+ ]] });
631
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.2", ngImport: i0, type: LayoutDefaultModule, decorators: [{
632
+ type: NgModule,
633
+ args: [{
634
+ imports: [
635
+ CommonModule,
636
+ RouterModule,
637
+ NzToolTipModule,
638
+ NzIconModule,
639
+ NzAvatarModule,
640
+ NzDropDownModule,
641
+ NzMessageModule,
642
+ NzBadgeModule
643
+ ],
644
+ declarations: COMPONENTS,
645
+ exports: COMPONENTS
646
+ }]
647
+ }] });
648
+
649
+ /**
650
+ * Generated bundle index. Do not edit.
651
+ */
652
+
653
+ export { LayoutDefaultComponent, LayoutDefaultHeaderComponent, LayoutDefaultHeaderItemComponent, LayoutDefaultHeaderItemTriggerDirective, LayoutDefaultModule, LayoutDefaultNavComponent };
654
+ //# sourceMappingURL=layout-default.mjs.map