@theseam/ui-common 0.3.12 → 0.3.13-beta.1
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/breadcrumbs/breadcrumbs/breadcrumbs.component.scss +1 -1
- package/breadcrumbs/theseam-ui-common-breadcrumbs.metadata.json +1 -1
- package/bundles/theseam-ui-common-breadcrumbs.umd.js +1 -1
- package/bundles/theseam-ui-common-framework.umd.js +939 -48
- package/bundles/theseam-ui-common-framework.umd.js.map +1 -1
- package/bundles/theseam-ui-common-layout.umd.js +14 -5
- package/bundles/theseam-ui-common-layout.umd.js.map +1 -1
- package/bundles/theseam-ui-common-menu.umd.js +4 -0
- package/bundles/theseam-ui-common-menu.umd.js.map +1 -1
- package/bundles/theseam-ui-common-table-cell-types.umd.js +3 -1
- package/bundles/theseam-ui-common-table-cell-types.umd.js.map +1 -1
- package/esm2015/breadcrumbs/breadcrumbs/breadcrumbs.component.js +1 -1
- package/esm2015/framework/base-layout/base-layout.component.js +12 -4
- package/esm2015/framework/base-layout/base-layout.module.js +4 -1
- package/esm2015/framework/base-layout/directives/base-layout-nav-toggle.directive.js +17 -3
- package/esm2015/framework/base-layout/directives/base-layout-side-bar-header.directive.js +15 -0
- package/esm2015/framework/nav/horizontal-nav/horizontal-nav.component.js +53 -0
- package/esm2015/framework/nav/index.js +6 -0
- package/esm2015/framework/nav/nav-item/nav-item.component.js +180 -0
- package/esm2015/framework/nav/nav-utils.js +110 -0
- package/esm2015/framework/nav/nav.models.js +2 -0
- package/esm2015/framework/nav/nav.module.js +42 -0
- package/esm2015/framework/nav/nav.service.js +200 -0
- package/esm2015/framework/public-api.js +2 -1
- package/esm2015/framework/side-nav/side-nav-item/side-nav-item.component.js +11 -5
- package/esm2015/framework/side-nav/side-nav-toggle/side-nav-toggle.component.js +5 -5
- package/esm2015/framework/side-nav/side-nav.component.js +68 -19
- package/esm2015/framework/side-nav/side-nav.service.js +1 -1
- package/esm2015/framework/theseam-ui-common-framework.js +13 -9
- package/esm2015/framework/top-bar/top-bar-compact-menu-btn-detail.directive.js +15 -0
- package/esm2015/framework/top-bar/top-bar-item.directive.js +9 -2
- package/esm2015/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.js +4 -3
- package/esm2015/framework/top-bar/top-bar-nav-toggle-btn-detail.directive.js +15 -0
- package/esm2015/framework/top-bar/top-bar.component.js +44 -7
- package/esm2015/framework/top-bar/top-bar.module.js +9 -3
- package/esm2015/layout/layout.service.js +12 -2
- package/esm2015/menu/menu-toggle.directive.js +6 -2
- package/esm2015/table-cell-types/table-cell-type-string/table-cell-type-string.component.js +4 -2
- package/fesm2015/theseam-ui-common-breadcrumbs.js +1 -1
- package/fesm2015/theseam-ui-common-framework.js +757 -42
- package/fesm2015/theseam-ui-common-framework.js.map +1 -1
- package/fesm2015/theseam-ui-common-layout.js +11 -2
- package/fesm2015/theseam-ui-common-layout.js.map +1 -1
- package/fesm2015/theseam-ui-common-menu.js +5 -1
- package/fesm2015/theseam-ui-common-menu.js.map +1 -1
- package/fesm2015/theseam-ui-common-table-cell-types.js +3 -1
- package/fesm2015/theseam-ui-common-table-cell-types.js.map +1 -1
- package/framework/base-layout/base-layout.component.d.ts +3 -1
- package/framework/base-layout/base-layout.component.scss +18 -10
- package/framework/base-layout/directives/base-layout-nav-toggle.directive.d.ts +7 -2
- package/framework/base-layout/directives/base-layout-side-bar-header.directive.d.ts +6 -0
- package/framework/base-layout/styles/_variables.scss +21 -0
- package/framework/nav/_nav-theme.scss +4 -0
- package/framework/nav/horizontal-nav/horizontal-nav.component.d.ts +23 -0
- package/framework/nav/horizontal-nav/horizontal-nav.component.scss +50 -0
- package/framework/nav/index.d.ts +5 -0
- package/framework/nav/nav-item/nav-item.component.d.ts +71 -0
- package/framework/nav/nav-item/nav-item.component.scss +203 -0
- package/framework/nav/nav-utils.d.ts +20 -0
- package/framework/nav/nav.models.d.ts +77 -0
- package/framework/nav/nav.module.d.ts +2 -0
- package/framework/nav/nav.service.d.ts +24 -0
- package/framework/nav/styles/_themes/light/_variables.scss +56 -0
- package/framework/nav/styles/_themes/primary/_variables.scss +56 -0
- package/framework/nav/styles/_utilities.scss +3 -0
- package/framework/nav/styles/_variables.scss +2 -0
- package/framework/public-api.d.ts +1 -0
- package/framework/side-nav/side-nav-item/side-nav-item.component.d.ts +2 -0
- package/framework/side-nav/side-nav-item/side-nav-item.component.scss +7 -5
- package/framework/side-nav/side-nav-toggle/side-nav-toggle.component.d.ts +4 -2
- package/framework/side-nav/side-nav-toggle/side-nav-toggle.component.scss +3 -6
- package/framework/side-nav/side-nav.component.d.ts +13 -1
- package/framework/side-nav/side-nav.component.scss +0 -1
- package/framework/side-nav/styles/_themes/light/_variables.scss +24 -14
- package/framework/side-nav/styles/_themes/primary/_variables.scss +8 -0
- package/framework/theseam-ui-common-framework.d.ts +12 -8
- package/framework/theseam-ui-common-framework.metadata.json +1 -1
- package/framework/top-bar/top-bar-compact-menu-btn-detail.directive.d.ts +5 -0
- package/framework/top-bar/top-bar-item.directive.d.ts +3 -0
- package/framework/top-bar/top-bar-menu-button/top-bar-menu-button.component.d.ts +4 -1
- package/framework/top-bar/top-bar-nav-toggle-btn-detail.directive.d.ts +5 -0
- package/framework/top-bar/top-bar.component.d.ts +25 -3
- package/framework/top-bar/top-bar.component.scss +7 -2
- package/layout/layout.service.d.ts +9 -1
- package/layout/theseam-ui-common-layout.metadata.json +1 -1
- package/menu/menu-toggle.directive.d.ts +2 -1
- package/menu/theseam-ui-common-menu.metadata.json +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { hasProperty, isNullOrUndefined } from '@theseam/ui-common/utils';
|
|
2
|
+
export function isHorizontalNavItemType(item, type) {
|
|
3
|
+
return item.itemType === type;
|
|
4
|
+
}
|
|
5
|
+
export function isHorizontalNavItemActive(item) {
|
|
6
|
+
var _a, _b;
|
|
7
|
+
return (_b = (_a = item.__state) === null || _a === void 0 ? void 0 : _a.active) !== null && _b !== void 0 ? _b : false;
|
|
8
|
+
}
|
|
9
|
+
export function isHorizontalNavItemExpanded(item) {
|
|
10
|
+
var _a, _b;
|
|
11
|
+
return (_b = (_a = item.__state) === null || _a === void 0 ? void 0 : _a.expanded) !== null && _b !== void 0 ? _b : false;
|
|
12
|
+
}
|
|
13
|
+
export function isHorizontalNavItemFocused(item) {
|
|
14
|
+
var _a, _b;
|
|
15
|
+
return (_b = (_a = item.__state) === null || _a === void 0 ? void 0 : _a.focused) !== null && _b !== void 0 ? _b : false;
|
|
16
|
+
}
|
|
17
|
+
export function horizontalNavItemHasChildren(item) {
|
|
18
|
+
return horizontalNavItemCanHaveChildren(item) && hasProperty(item, 'children') && item.children.length > 0;
|
|
19
|
+
}
|
|
20
|
+
export function horizontalNavItemCanHaveChildren(item) {
|
|
21
|
+
return isHorizontalNavItemType(item, 'basic') || isHorizontalNavItemType(item, 'link');
|
|
22
|
+
}
|
|
23
|
+
export function horizontalNavItemHasActiveChild(item) {
|
|
24
|
+
if (!horizontalNavItemHasChildren(item)) {
|
|
25
|
+
return false;
|
|
26
|
+
}
|
|
27
|
+
for (const child of item.children) {
|
|
28
|
+
if (getHorizontalNavItemStateProp(child, 'active') || horizontalNavItemHasActiveChild(child)) {
|
|
29
|
+
return true;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
return false;
|
|
33
|
+
}
|
|
34
|
+
export function horizontalNavItemHasExpandedChild(item) {
|
|
35
|
+
if (!horizontalNavItemHasChildren(item)) {
|
|
36
|
+
return false;
|
|
37
|
+
}
|
|
38
|
+
for (const child of item.children) {
|
|
39
|
+
if (getHorizontalNavItemStateProp(child, 'expanded')) {
|
|
40
|
+
return true;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
return false;
|
|
44
|
+
}
|
|
45
|
+
export function horizontalNavItemCanBeActive(item) {
|
|
46
|
+
return isHorizontalNavItemType(item, 'basic') || isHorizontalNavItemType(item, 'link');
|
|
47
|
+
}
|
|
48
|
+
export function horizontalNavItemCanExpand(item) {
|
|
49
|
+
return horizontalNavItemCanHaveChildren(item);
|
|
50
|
+
}
|
|
51
|
+
export function findHorizontalNavLinkItems(items) {
|
|
52
|
+
const linkItems = [];
|
|
53
|
+
const _fn = (_items) => {
|
|
54
|
+
for (const item of _items) {
|
|
55
|
+
if (isHorizontalNavItemType(item, 'link')) {
|
|
56
|
+
linkItems.push(item);
|
|
57
|
+
}
|
|
58
|
+
if (horizontalNavItemCanHaveChildren(item) && hasProperty(item, 'children')) {
|
|
59
|
+
_fn(item.children);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
_fn(items);
|
|
64
|
+
return linkItems;
|
|
65
|
+
}
|
|
66
|
+
export function setHorizontalNavItemStateProp(item, prop, value) {
|
|
67
|
+
if (hasProperty(item, '__state')) {
|
|
68
|
+
item.__state[prop] = value;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
export function getHorizontalNavItemStateProp(item, prop) {
|
|
72
|
+
return setDefaultHorizontalNavItemState(item).__state[prop];
|
|
73
|
+
}
|
|
74
|
+
export function setDefaultHorizontalNavItemState(item) {
|
|
75
|
+
if (hasProperty(item, '__state')) {
|
|
76
|
+
return item;
|
|
77
|
+
}
|
|
78
|
+
item.__state = {
|
|
79
|
+
active: false,
|
|
80
|
+
expanded: false,
|
|
81
|
+
focused: false
|
|
82
|
+
};
|
|
83
|
+
// TODO: See if there is a nice way to fix the typing for this.
|
|
84
|
+
return item;
|
|
85
|
+
}
|
|
86
|
+
export function areSameHorizontalNavItem(item1, item2) {
|
|
87
|
+
if (isNullOrUndefined(item1) || isNullOrUndefined(item2)) {
|
|
88
|
+
return false;
|
|
89
|
+
}
|
|
90
|
+
if (item1.itemType !== item2.itemType) {
|
|
91
|
+
return false;
|
|
92
|
+
}
|
|
93
|
+
if (isHorizontalNavItemType(item1, 'title') && isHorizontalNavItemType(item2, 'title')) {
|
|
94
|
+
return item1.label === item2.label;
|
|
95
|
+
}
|
|
96
|
+
else if (isHorizontalNavItemType(item1, 'divider') && isHorizontalNavItemType(item2, 'divider')) {
|
|
97
|
+
return item1.label === item2.label;
|
|
98
|
+
}
|
|
99
|
+
else if (isHorizontalNavItemType(item1, 'basic') && isHorizontalNavItemType(item2, 'basic')) {
|
|
100
|
+
return item1.label === item2.label;
|
|
101
|
+
}
|
|
102
|
+
else if (isHorizontalNavItemType(item1, 'link') && isHorizontalNavItemType(item2, 'link')) {
|
|
103
|
+
return item1.label === item2.label && item1.link === item2.link;
|
|
104
|
+
}
|
|
105
|
+
else if (isHorizontalNavItemType(item1, 'button') && isHorizontalNavItemType(item2, 'button')) {
|
|
106
|
+
return item1.onClick === item2.onClick;
|
|
107
|
+
}
|
|
108
|
+
return false;
|
|
109
|
+
}
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-utils.js","sourceRoot":"","sources":["../../../../../projects/ui-common/framework/nav/nav-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { hasProperty, isNullOrUndefined } from '@theseam/ui-common/utils'\n\nimport {\n  INavBasic,\n  INavButton,\n  INavDivider,\n  INavItem,\n  INavItemState,\n  INavLink,\n  INavTitle,\n  NavItemCanHaveChildren,\n  NavItemCanHaveState\n} from './nav.models'\n\nexport function isHorizontalNavItemType(item: INavItem, type: 'title'): item is INavTitle\nexport function isHorizontalNavItemType(item: INavItem, type: 'divider'): item is INavDivider\nexport function isHorizontalNavItemType(item: INavItem, type: 'basic'): item is INavBasic\nexport function isHorizontalNavItemType(item: INavItem, type: 'link'): item is INavLink\nexport function isHorizontalNavItemType(item: INavItem, type: 'button'): item is INavButton\nexport function isHorizontalNavItemType(item: INavItem, type: string): item is INavItem {\n  return item.itemType === type\n}\n\nexport function isHorizontalNavItemActive(item: INavItem): boolean {\n  return item.__state?.active ?? false\n}\n\nexport function isHorizontalNavItemExpanded(item: INavItem): boolean {\n  return item.__state?.expanded ?? false\n}\n\nexport function isHorizontalNavItemFocused(item: INavItem): boolean {\n  return item.__state?.focused ?? false\n}\n\nexport function horizontalNavItemHasChildren(item: INavItem): item is (INavBasic | INavLink) & Required<NavItemCanHaveChildren> {\n  return horizontalNavItemCanHaveChildren(item) && hasProperty(item, 'children') && item.children.length > 0\n}\n\nexport function horizontalNavItemCanHaveChildren(item: INavItem): item is (INavBasic | INavLink) {\n  return isHorizontalNavItemType(item, 'basic') || isHorizontalNavItemType(item, 'link')\n}\n\nexport function horizontalNavItemHasActiveChild(item: INavItem): boolean {\n  if (!horizontalNavItemHasChildren(item)) {\n    return false\n  }\n\n  for (const child of item.children) {\n    if (getHorizontalNavItemStateProp(child, 'active') || horizontalNavItemHasActiveChild(child)) {\n      return true\n    }\n  }\n\n  return false\n}\n\nexport function horizontalNavItemHasExpandedChild(item: INavItem): boolean {\n  if (!horizontalNavItemHasChildren(item)) {\n    return false\n  }\n\n  for (const child of item.children) {\n    if (getHorizontalNavItemStateProp(child, 'expanded')) {\n      return true\n    }\n  }\n\n  return false\n}\n\nexport function horizontalNavItemCanBeActive(item: INavItem): item is (INavBasic | INavLink) {\n  return isHorizontalNavItemType(item, 'basic') || isHorizontalNavItemType(item, 'link')\n}\n\nexport function horizontalNavItemCanExpand(item: INavItem): item is (INavBasic | INavLink) {\n  return horizontalNavItemCanHaveChildren(item)\n}\n\nexport function findHorizontalNavLinkItems(items: INavItem[]): INavLink[] {\n  const linkItems: INavLink[] = []\n\n  const _fn = (_items: INavItem[]) => {\n    for (const item of _items) {\n      if (isHorizontalNavItemType(item, 'link')) {\n        linkItems.push(item)\n      }\n      if (horizontalNavItemCanHaveChildren(item) && hasProperty(item, 'children')) {\n        _fn(item.children)\n      }\n    }\n  }\n  _fn(items)\n\n  return linkItems\n}\n\nexport function setHorizontalNavItemStateProp<K extends keyof INavItemState>(item: INavItem, prop: K, value: INavItemState[K]): void {\n  if (hasProperty(item, '__state')) {\n    item.__state[prop] = value\n  }\n}\n\nexport function getHorizontalNavItemStateProp<K extends keyof INavItemState>(item: INavItem, prop: K): INavItemState[K] {\n  return setDefaultHorizontalNavItemState(item).__state[prop]\n}\n\nexport function setDefaultHorizontalNavItemState(item: INavItem): INavItem & Required<NavItemCanHaveState> {\n  if (hasProperty(item, '__state')) {\n    return item\n  }\n\n  item.__state = {\n    active: false,\n    expanded: false,\n    focused: false\n  } as INavItemState\n\n  // TODO: See if there is a nice way to fix the typing for this.\n  return item as any\n}\n\nexport function areSameHorizontalNavItem(item1: INavItem | undefined, item2: INavItem | undefined): boolean {\n  if (isNullOrUndefined(item1) || isNullOrUndefined(item2)) {\n    return false\n  }\n\n  if (item1.itemType !== item2.itemType) {\n    return false\n  }\n\n  if (isHorizontalNavItemType(item1, 'title') && isHorizontalNavItemType(item2, 'title')) {\n    return item1.label === item2.label\n  } else if (isHorizontalNavItemType(item1, 'divider') && isHorizontalNavItemType(item2, 'divider')) {\n    return item1.label === item2.label\n  } else if (isHorizontalNavItemType(item1, 'basic') && isHorizontalNavItemType(item2, 'basic')) {\n    return item1.label === item2.label\n  } else if (isHorizontalNavItemType(item1, 'link') && isHorizontalNavItemType(item2, 'link')) {\n    return item1.label === item2.label && item1.link === item2.link\n  } else if (isHorizontalNavItemType(item1, 'button') && isHorizontalNavItemType(item2, 'button')) {\n    return item1.onClick === item2.onClick\n  }\n\n  return false\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2Lm1vZGVscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi9mcmFtZXdvcmsvbmF2L25hdi5tb2RlbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElzQWN0aXZlTWF0Y2hPcHRpb25zLCBVcmxDcmVhdGlvbk9wdGlvbnMgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInXG5pbXBvcnQgeyBTZWFtSWNvbiB9IGZyb20gJ0B0aGVzZWFtL3VpLWNvbW1vbi9pY29uJ1xuaW1wb3J0IHR5cGUgeyBUaGVtZVR5cGVzIH0gZnJvbSAnQHRoZXNlYW0vdWktY29tbW9uL21vZGVscydcblxuZXhwb3J0IGludGVyZmFjZSBJTmF2SXRlbVN0YXRlIHtcbiAgLy8gcGFyZW50PzogSU5hdkl0ZW1cbiAgYWN0aXZlOiBib29sZWFuXG4gIGV4cGFuZGVkOiBib29sZWFuXG4gIGZvY3VzZWQ6IGJvb2xlYW5cbn1cblxuZXhwb3J0IGludGVyZmFjZSBOYXZJdGVtQ2FuSGF2ZVN0YXRlIHtcbiAgLyoqXG4gICAqIFRoaXMgcHJvcCBpcyBtYW5hZ2VkIGJ5IHRoZSBOYXYuIElmIG1hbnVhbGx5IHNldCBpdCB3aWxsIGJlIG92ZXJ3cml0dGVuLlxuICAgKlxuICAgKiBAaWdub3JlXG4gICAqL1xuICAgX19zdGF0ZT86IElOYXZJdGVtU3RhdGVcbn1cblxuZXhwb3J0IGludGVyZmFjZSBOYXZJdGVtQ2FuSGF2ZUNoaWxkcmVuIHtcbiAgY2hpbGRyZW4/OiBJTmF2SXRlbVtdXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSU5hdkl0ZW1CYXNlPFQgZXh0ZW5kcyBzdHJpbmc+IGV4dGVuZHMgTmF2SXRlbUNhbkhhdmVTdGF0ZSB7XG4gIC8qKlxuICAgKiBkZWZhdWx0OiAncm91dGUnXG4gICAqL1xuICBpdGVtVHlwZT86IFRcblxuICBiYWRnZT86IElOYXZCYWRnZVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIElOYXZUaXRsZSBleHRlbmRzIElOYXZJdGVtQmFzZTwndGl0bGUnPiB7XG4gIGxhYmVsPzogc3RyaW5nXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSU5hdkRpdmlkZXIgZXh0ZW5kcyBJTmF2SXRlbUJhc2U8J2RpdmlkZXInPiB7XG4gIGxhYmVsPzogc3RyaW5nXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSU5hdkJhZGdlIHtcblxuICB0ZXh0Pzogc3RyaW5nXG5cbiAgdGhlbWU/OiBUaGVtZVR5cGVzXG5cbiAgLyoqXG4gICAqIENvbnRlbnQgdG8gcHJvdmlkZSB0byBhc3Npc3RpdmUgdGVjaG5vbG9neSwgc3VjaCBhcyBzY3JlZW4gcmVhZGVycy5cbiAgICovXG4gIHNyQ29udGVudD86IHN0cmluZ1xuXG4gIHRvb2x0aXA/OiBzdHJpbmcgfCBOYXZJdGVtQmFkZ2VUb29sdGlwXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSU5hdkJhc2ljIGV4dGVuZHMgSU5hdkl0ZW1CYXNlPCdiYXNpYyc+LCBOYXZJdGVtQ2FuSGF2ZUNoaWxkcmVuIHtcbiAgaWNvbj86IFNlYW1JY29uXG4gIGxhYmVsOiBzdHJpbmdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJTmF2TGluayBleHRlbmRzIElOYXZJdGVtQmFzZTwnbGluayc+LFxuICBQYXJ0aWFsPFBpY2s8VXJsQ3JlYXRpb25PcHRpb25zLCAncXVlcnlQYXJhbXMnIHwgJ2ZyYWdtZW50JyB8ICdxdWVyeVBhcmFtc0hhbmRsaW5nJyB8ICdwcmVzZXJ2ZUZyYWdtZW50Jz4+LFxuICBOYXZJdGVtQ2FuSGF2ZUNoaWxkcmVuIHtcbiAgaWNvbj86IFNlYW1JY29uXG4gIGxhYmVsOiBzdHJpbmdcblxuICBsaW5rPzogYW55W10gfCBzdHJpbmdcblxuICAvKipcbiAgICogRGVmYXVsdDogeyBwYXRoczogJ3N1YnNldCcsIHF1ZXJ5UGFyYW1zOiAnc3Vic2V0JywgZnJhZ21lbnQ6ICdpZ25vcmVkJywgbWF0cml4UGFyYW1zOiAnaWdub3JlZCcgfVxuICAgKi9cbiAgbWF0Y2hPcHRpb25zPzogUGFydGlhbDxJc0FjdGl2ZU1hdGNoT3B0aW9ucz5cbn1cblxuZXhwb3J0IGludGVyZmFjZSBJTmF2QnV0dG9uIGV4dGVuZHMgSU5hdkl0ZW1CYXNlPCdidXR0b24nPiB7XG4gIG9uQ2xpY2s6IChldmVudDogTW91c2VFdmVudCkgPT4gdm9pZFxufVxuXG5leHBvcnQgdHlwZSBJTmF2SXRlbSA9IElOYXZUaXRsZSB8IElOYXZEaXZpZGVyIHwgSU5hdkJhc2ljIHwgSU5hdkxpbmsgfCBJTmF2QnV0dG9uXG5cbmV4cG9ydCBpbnRlcmZhY2UgTmF2SXRlbVN0YXRlQ2hhbmdlZCB7XG4gIGl0ZW06IElOYXZJdGVtXG4gIHByb3A6IGtleW9mIElOYXZJdGVtU3RhdGVcbiAgcHJldlZhbHVlOiBhbnlcbiAgbmV3VmFsdWU6IGFueVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIE5hdkl0ZW1CYWRnZVRvb2x0aXAge1xuICB0b29sdGlwPzogc3RyaW5nXG4gIGNsYXNzPzogc3RyaW5nXG4gIHBsYWNlbWVudD86IHN0cmluZ1xuICBjb250YWluZXI/OiBzdHJpbmdcbiAgZGlzYWJsZWQ/OiBib29sZWFuXG59XG5cbmV4cG9ydCB0eXBlIE5hdkl0ZW1DaGlsZEFjdGlvbiA9ICdtZW51JyB8ICdleHBhbmQnIHwgJ25vbmUnIHwgbnVsbCB8IHVuZGVmaW5lZFxuXG5leHBvcnQgdHlwZSBOYXZJdGVtRXhwYW5kQWN0aW9uID0gJ3RvZ2dsZScgfCAnZXhwYW5kT25seScgfCBudWxsIHwgdW5kZWZpbmVkXG5cbmV4cG9ydCBpbnRlcmZhY2UgTmF2SXRlbUV4cGFuZGVkRXZlbnQge1xuICBuYXZJdGVtOiBJTmF2SXRlbSxcbiAgZXhwYW5kZWQ6IGJvb2xlYW5cbn1cbiJdfQ==
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { A11yModule } from '@angular/cdk/a11y';
|
|
2
|
+
import { PortalModule } from '@angular/cdk/portal';
|
|
3
|
+
import { CommonModule } from '@angular/common';
|
|
4
|
+
import { NgModule } from '@angular/core';
|
|
5
|
+
import { RouterModule } from '@angular/router';
|
|
6
|
+
import { NgbTooltipModule } from '@ng-bootstrap/ng-bootstrap';
|
|
7
|
+
import { TheSeamIconModule } from '@theseam/ui-common/icon';
|
|
8
|
+
import { TheSeamLayoutModule } from '@theseam/ui-common/layout';
|
|
9
|
+
import { TheSeamMenuModule } from '@theseam/ui-common/menu';
|
|
10
|
+
import { TheSeamScrollbarModule } from '@theseam/ui-common/scrollbar';
|
|
11
|
+
import { HorizontalNavComponent } from './horizontal-nav/horizontal-nav.component';
|
|
12
|
+
import { NavItemComponent } from './nav-item/nav-item.component';
|
|
13
|
+
import { TheSeamNavService } from './nav.service';
|
|
14
|
+
export class TheSeamNavModule {
|
|
15
|
+
}
|
|
16
|
+
TheSeamNavModule.decorators = [
|
|
17
|
+
{ type: NgModule, args: [{
|
|
18
|
+
declarations: [
|
|
19
|
+
NavItemComponent,
|
|
20
|
+
HorizontalNavComponent,
|
|
21
|
+
],
|
|
22
|
+
imports: [
|
|
23
|
+
CommonModule,
|
|
24
|
+
RouterModule,
|
|
25
|
+
TheSeamIconModule,
|
|
26
|
+
A11yModule,
|
|
27
|
+
TheSeamScrollbarModule,
|
|
28
|
+
TheSeamLayoutModule,
|
|
29
|
+
NgbTooltipModule,
|
|
30
|
+
PortalModule,
|
|
31
|
+
TheSeamMenuModule
|
|
32
|
+
],
|
|
33
|
+
exports: [
|
|
34
|
+
NavItemComponent,
|
|
35
|
+
HorizontalNavComponent,
|
|
36
|
+
],
|
|
37
|
+
providers: [
|
|
38
|
+
TheSeamNavService,
|
|
39
|
+
]
|
|
40
|
+
},] }
|
|
41
|
+
];
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi9mcmFtZXdvcmsvbmF2L25hdi5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLG1CQUFtQixDQUFBO0FBQzlDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQTtBQUNsRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDOUMsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUN4QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFFOUMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNEJBQTRCLENBQUE7QUFFN0QsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0seUJBQXlCLENBQUE7QUFDM0QsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sMkJBQTJCLENBQUE7QUFDL0QsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0seUJBQXlCLENBQUE7QUFDM0QsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sOEJBQThCLENBQUE7QUFDckUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMkNBQTJDLENBQUE7QUFFbEYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sK0JBQStCLENBQUE7QUFDaEUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFBO0FBMEJqRCxNQUFNLE9BQU8sZ0JBQWdCOzs7WUF4QjVCLFFBQVEsU0FBQztnQkFDUixZQUFZLEVBQUU7b0JBQ1osZ0JBQWdCO29CQUNoQixzQkFBc0I7aUJBQ3ZCO2dCQUNELE9BQU8sRUFBRTtvQkFDUCxZQUFZO29CQUNaLFlBQVk7b0JBQ1osaUJBQWlCO29CQUNqQixVQUFVO29CQUNWLHNCQUFzQjtvQkFDdEIsbUJBQW1CO29CQUNuQixnQkFBZ0I7b0JBQ2hCLFlBQVk7b0JBQ1osaUJBQWlCO2lCQUNsQjtnQkFDRCxPQUFPLEVBQUU7b0JBQ1AsZ0JBQWdCO29CQUNoQixzQkFBc0I7aUJBQ3ZCO2dCQUNELFNBQVMsRUFBRTtvQkFDVCxpQkFBaUI7aUJBQ2xCO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBMTF5TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2ExMXknXG5pbXBvcnQgeyBQb3J0YWxNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvcG9ydGFsJ1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJ1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgUm91dGVyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJ1xuXG5pbXBvcnQgeyBOZ2JUb29sdGlwTW9kdWxlIH0gZnJvbSAnQG5nLWJvb3RzdHJhcC9uZy1ib290c3RyYXAnXG5cbmltcG9ydCB7IFRoZVNlYW1JY29uTW9kdWxlIH0gZnJvbSAnQHRoZXNlYW0vdWktY29tbW9uL2ljb24nXG5pbXBvcnQgeyBUaGVTZWFtTGF5b3V0TW9kdWxlIH0gZnJvbSAnQHRoZXNlYW0vdWktY29tbW9uL2xheW91dCdcbmltcG9ydCB7IFRoZVNlYW1NZW51TW9kdWxlIH0gZnJvbSAnQHRoZXNlYW0vdWktY29tbW9uL21lbnUnXG5pbXBvcnQgeyBUaGVTZWFtU2Nyb2xsYmFyTW9kdWxlIH0gZnJvbSAnQHRoZXNlYW0vdWktY29tbW9uL3Njcm9sbGJhcidcbmltcG9ydCB7IEhvcml6b250YWxOYXZDb21wb25lbnQgfSBmcm9tICcuL2hvcml6b250YWwtbmF2L2hvcml6b250YWwtbmF2LmNvbXBvbmVudCdcblxuaW1wb3J0IHsgTmF2SXRlbUNvbXBvbmVudCB9IGZyb20gJy4vbmF2LWl0ZW0vbmF2LWl0ZW0uY29tcG9uZW50J1xuaW1wb3J0IHsgVGhlU2VhbU5hdlNlcnZpY2UgfSBmcm9tICcuL25hdi5zZXJ2aWNlJ1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBOYXZJdGVtQ29tcG9uZW50LFxuICAgIEhvcml6b250YWxOYXZDb21wb25lbnQsXG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgUm91dGVyTW9kdWxlLFxuICAgIFRoZVNlYW1JY29uTW9kdWxlLFxuICAgIEExMXlNb2R1bGUsXG4gICAgVGhlU2VhbVNjcm9sbGJhck1vZHVsZSxcbiAgICBUaGVTZWFtTGF5b3V0TW9kdWxlLFxuICAgIE5nYlRvb2x0aXBNb2R1bGUsXG4gICAgUG9ydGFsTW9kdWxlLFxuICAgIFRoZVNlYW1NZW51TW9kdWxlXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBOYXZJdGVtQ29tcG9uZW50LFxuICAgIEhvcml6b250YWxOYXZDb21wb25lbnQsXG4gIF0sXG4gIHByb3ZpZGVyczogW1xuICAgIFRoZVNlYW1OYXZTZXJ2aWNlLFxuICBdXG59KVxuZXhwb3J0IGNsYXNzIFRoZVNlYW1OYXZNb2R1bGUgeyB9XG4iXX0=
|
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { NavigationEnd, Router } from '@angular/router';
|
|
3
|
+
import { BehaviorSubject, defer, Observable, Subject } from 'rxjs';
|
|
4
|
+
import { distinctUntilChanged, filter, map, shareReplay, startWith, switchMap } from 'rxjs/operators';
|
|
5
|
+
import { hasProperty, notNullOrUndefined } from '@theseam/ui-common/utils';
|
|
6
|
+
import { areSameHorizontalNavItem, getHorizontalNavItemStateProp, horizontalNavItemCanExpand, horizontalNavItemHasActiveChild, horizontalNavItemHasChildren, horizontalNavItemHasExpandedChild, isHorizontalNavItemActive, isHorizontalNavItemType, setDefaultHorizontalNavItemState, setHorizontalNavItemStateProp } from './nav-utils';
|
|
7
|
+
export class TheSeamNavService {
|
|
8
|
+
constructor(_router) {
|
|
9
|
+
this._router = _router;
|
|
10
|
+
this._updatingCount = new BehaviorSubject(0);
|
|
11
|
+
this.itemChanged = new Subject();
|
|
12
|
+
this.loading$ = this._updatingCount.pipe(map(count => count > 0), distinctUntilChanged(), shareReplay({ bufferSize: 1, refCount: true }));
|
|
13
|
+
}
|
|
14
|
+
createItemsObservable(items) {
|
|
15
|
+
return defer(() => {
|
|
16
|
+
this.updateItemsStates(items);
|
|
17
|
+
this.updateRouterFocusedItem(items);
|
|
18
|
+
return new Observable((subscriber) => {
|
|
19
|
+
const stateChangeSub = this.itemChanged.pipe(switchMap(change => {
|
|
20
|
+
if (change.prop === 'focused' && change.newValue) {
|
|
21
|
+
this.updateFocusedItem(items, change.item);
|
|
22
|
+
}
|
|
23
|
+
return this.loading$.pipe(filter(loading => !loading));
|
|
24
|
+
})).subscribe(() => {
|
|
25
|
+
subscriber.next(items);
|
|
26
|
+
});
|
|
27
|
+
try {
|
|
28
|
+
this.updateItemsStates(items);
|
|
29
|
+
}
|
|
30
|
+
catch (err) {
|
|
31
|
+
subscriber.error(err);
|
|
32
|
+
}
|
|
33
|
+
const routeChangeSub = this._router.events.pipe(filter(event => event instanceof NavigationEnd)).subscribe(event => {
|
|
34
|
+
try {
|
|
35
|
+
this.updateItemsStates(items);
|
|
36
|
+
this.updateRouterFocusedItem(items);
|
|
37
|
+
}
|
|
38
|
+
catch (err) {
|
|
39
|
+
subscriber.error(err);
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
return () => {
|
|
43
|
+
stateChangeSub.unsubscribe();
|
|
44
|
+
routeChangeSub.unsubscribe();
|
|
45
|
+
};
|
|
46
|
+
}).pipe(startWith(items));
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
_incUpdatingCount() {
|
|
50
|
+
this._updatingCount.next(this._updatingCount.value + 1);
|
|
51
|
+
}
|
|
52
|
+
_decrUpdatingCount() {
|
|
53
|
+
this._updatingCount.next(this._updatingCount.value - 1);
|
|
54
|
+
}
|
|
55
|
+
updateItemsStates(items) {
|
|
56
|
+
this._incUpdatingCount();
|
|
57
|
+
try {
|
|
58
|
+
for (const item of items) {
|
|
59
|
+
if (horizontalNavItemHasChildren(item)) {
|
|
60
|
+
this.updateItemsStates(item.children);
|
|
61
|
+
}
|
|
62
|
+
this.updateItemState(item);
|
|
63
|
+
}
|
|
64
|
+
this._decrUpdatingCount();
|
|
65
|
+
}
|
|
66
|
+
catch (err) {
|
|
67
|
+
this._decrUpdatingCount();
|
|
68
|
+
throw err;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
updateItemState(item) {
|
|
72
|
+
this._incUpdatingCount();
|
|
73
|
+
try {
|
|
74
|
+
setDefaultHorizontalNavItemState(item);
|
|
75
|
+
this.setItemStateProp(item, 'active', this.horizontalNavLinkActive(item));
|
|
76
|
+
// TODO: Implement this in a more optimized way. Unless our apps start
|
|
77
|
+
// having large navs constantly updating their state, this shouldn't
|
|
78
|
+
// have much impact on performance.
|
|
79
|
+
this._updateItemExpandedState(item);
|
|
80
|
+
this._decrUpdatingCount();
|
|
81
|
+
}
|
|
82
|
+
catch (err) {
|
|
83
|
+
this._decrUpdatingCount();
|
|
84
|
+
throw err;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
horizontalNavLinkActive(item) {
|
|
88
|
+
if (isHorizontalNavItemType(item, 'link')) {
|
|
89
|
+
const url = this._getUrl(item);
|
|
90
|
+
if (notNullOrUndefined(url)) {
|
|
91
|
+
const opts = this._getMatchOptions(item);
|
|
92
|
+
return this._router.isActive(url, opts);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
return false;
|
|
96
|
+
}
|
|
97
|
+
_updateItemsExpandedState(items) {
|
|
98
|
+
for (const item of items) {
|
|
99
|
+
if (horizontalNavItemHasChildren(item)) {
|
|
100
|
+
this._updateItemsExpandedState(item.children);
|
|
101
|
+
}
|
|
102
|
+
this._updateItemExpandedState(item);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
_updateItemExpandedState(item) {
|
|
106
|
+
if (!horizontalNavItemCanExpand(item)) {
|
|
107
|
+
if (getHorizontalNavItemStateProp(item, 'expanded')) {
|
|
108
|
+
this.setItemStateProp(item, 'expanded', false);
|
|
109
|
+
}
|
|
110
|
+
return;
|
|
111
|
+
}
|
|
112
|
+
if (horizontalNavItemHasChildren(item)) {
|
|
113
|
+
this._updateItemsExpandedState(item.children);
|
|
114
|
+
}
|
|
115
|
+
if (horizontalNavItemHasActiveChild(item) || horizontalNavItemHasExpandedChild(item)) {
|
|
116
|
+
if (!getHorizontalNavItemStateProp(item, 'expanded')) {
|
|
117
|
+
this.setItemStateProp(item, 'expanded', true);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
else {
|
|
121
|
+
if (getHorizontalNavItemStateProp(item, 'expanded')) {
|
|
122
|
+
this.setItemStateProp(item, 'expanded', false);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
updateRouterFocusedItem(items) {
|
|
127
|
+
const focusedItem = items.find(i => isHorizontalNavItemActive(i)) || items.find(i => horizontalNavItemHasActiveChild(i));
|
|
128
|
+
if (notNullOrUndefined(focusedItem)) {
|
|
129
|
+
this.updateFocusedItem(items, focusedItem);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
updateFocusedItem(items, focusedItem) {
|
|
133
|
+
for (const item of items) {
|
|
134
|
+
if (areSameHorizontalNavItem(item, focusedItem)) {
|
|
135
|
+
setHorizontalNavItemStateProp(item, 'focused', true);
|
|
136
|
+
}
|
|
137
|
+
else {
|
|
138
|
+
setHorizontalNavItemStateProp(item, 'focused', false);
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
_getNavExtras(item) {
|
|
143
|
+
const navigationExtras = {};
|
|
144
|
+
if (hasProperty(item, 'queryParams')) {
|
|
145
|
+
navigationExtras.queryParams = item.queryParams;
|
|
146
|
+
}
|
|
147
|
+
if (hasProperty(item, 'fragment')) {
|
|
148
|
+
navigationExtras.fragment = item.fragment;
|
|
149
|
+
}
|
|
150
|
+
if (hasProperty(item, 'queryParamsHandling')) {
|
|
151
|
+
navigationExtras.queryParamsHandling = item.queryParamsHandling;
|
|
152
|
+
}
|
|
153
|
+
if (hasProperty(item, 'preserveFragment')) {
|
|
154
|
+
navigationExtras.preserveFragment = item.preserveFragment;
|
|
155
|
+
}
|
|
156
|
+
return navigationExtras;
|
|
157
|
+
}
|
|
158
|
+
_getUrl(item) {
|
|
159
|
+
const link = item.link;
|
|
160
|
+
if (typeof link === 'string') {
|
|
161
|
+
return this._router.createUrlTree([link], this._getNavExtras(item)).toString();
|
|
162
|
+
}
|
|
163
|
+
else if (Array.isArray(link)) {
|
|
164
|
+
return this._router.createUrlTree(link, this._getNavExtras(item)).toString();
|
|
165
|
+
}
|
|
166
|
+
return null;
|
|
167
|
+
}
|
|
168
|
+
_getMatchOptions(item) {
|
|
169
|
+
const defaultMatchOpts = {
|
|
170
|
+
paths: 'subset',
|
|
171
|
+
queryParams: 'subset',
|
|
172
|
+
fragment: 'ignored',
|
|
173
|
+
matrixParams: 'ignored'
|
|
174
|
+
};
|
|
175
|
+
if (hasProperty(item, 'matchOptions')) {
|
|
176
|
+
return Object.assign(Object.assign({}, defaultMatchOpts), item.matchOptions);
|
|
177
|
+
}
|
|
178
|
+
return defaultMatchOpts;
|
|
179
|
+
}
|
|
180
|
+
setItemStateProp(item, prop, value) {
|
|
181
|
+
const currentValue = getHorizontalNavItemStateProp(item, prop);
|
|
182
|
+
if (currentValue !== value) {
|
|
183
|
+
setHorizontalNavItemStateProp(item, prop, value);
|
|
184
|
+
const changed = {
|
|
185
|
+
item,
|
|
186
|
+
prop,
|
|
187
|
+
prevValue: currentValue,
|
|
188
|
+
newValue: value
|
|
189
|
+
};
|
|
190
|
+
this.itemChanged.next(changed);
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
TheSeamNavService.decorators = [
|
|
195
|
+
{ type: Injectable }
|
|
196
|
+
];
|
|
197
|
+
TheSeamNavService.ctorParameters = () => [
|
|
198
|
+
{ type: Router }
|
|
199
|
+
];
|
|
200
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav.service.js","sourceRoot":"","sources":["../../../../../projects/ui-common/framework/nav/nav.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core'\nimport { IsActiveMatchOptions, NavigationEnd, Router, UrlCreationOptions } from '@angular/router'\nimport { BehaviorSubject, defer, Observable, Subject, Subscriber } from 'rxjs'\nimport { distinctUntilChanged, filter, map, shareReplay, startWith, switchMap } from 'rxjs/operators'\n\nimport { hasProperty, notNullOrUndefined } from '@theseam/ui-common/utils'\n\nimport {\n  areSameHorizontalNavItem,\n  getHorizontalNavItemStateProp,\n  horizontalNavItemCanExpand,\n  horizontalNavItemHasActiveChild,\n  horizontalNavItemHasChildren,\n  horizontalNavItemHasExpandedChild,\n  isHorizontalNavItemActive,\n  isHorizontalNavItemType,\n  setDefaultHorizontalNavItemState,\n  setHorizontalNavItemStateProp\n} from './nav-utils'\nimport { INavItem, INavItemState, INavLink, NavItemStateChanged } from './nav.models'\n\n@Injectable()\nexport class TheSeamNavService {\n\n  private readonly _updatingCount = new BehaviorSubject<number>(0)\n\n  public readonly loading$: Observable<boolean>\n\n  public readonly itemChanged = new Subject<NavItemStateChanged>()\n\n  constructor(\n    private readonly _router: Router\n  ) {\n    this.loading$ = this._updatingCount.pipe(\n      map(count => count > 0),\n      distinctUntilChanged(),\n      shareReplay({ bufferSize: 1, refCount: true })\n    )\n  }\n\n  public createItemsObservable(items: INavItem[]): Observable<INavItem[]> {\n    return defer(() => {\n      this.updateItemsStates(items)\n      this.updateRouterFocusedItem(items)\n      return new Observable((subscriber: Subscriber<INavItem[]>) => {\n        const stateChangeSub = this.itemChanged.pipe(\n          switchMap(change => {\n            if (change.prop === 'focused' && change.newValue) {\n              this.updateFocusedItem(items, change.item)\n            }\n            return this.loading$.pipe(filter(loading => !loading))\n          })\n        ).subscribe(() => {\n          subscriber.next(items)\n        })\n\n        try {\n          this.updateItemsStates(items)\n        } catch (err) {\n          subscriber.error(err)\n        }\n\n        const routeChangeSub = this._router.events.pipe(\n          filter(event => event instanceof NavigationEnd),\n        ).subscribe(event => {\n          try {\n            this.updateItemsStates(items)\n            this.updateRouterFocusedItem(items)\n          } catch (err) {\n            subscriber.error(err)\n          }\n        })\n\n        return () => {\n          stateChangeSub.unsubscribe()\n          routeChangeSub.unsubscribe()\n        }\n      }).pipe(startWith(items))\n    })\n  }\n\n  private _incUpdatingCount(): void {\n    this._updatingCount.next(this._updatingCount.value + 1)\n  }\n\n  private _decrUpdatingCount(): void {\n    this._updatingCount.next(this._updatingCount.value - 1)\n  }\n\n  public updateItemsStates(items: INavItem[]): void {\n    this._incUpdatingCount()\n\n    try {\n      for (const item of items) {\n        if (horizontalNavItemHasChildren(item)) {\n          this.updateItemsStates(item.children)\n        }\n\n        this.updateItemState(item)\n      }\n\n      this._decrUpdatingCount()\n    } catch (err) {\n      this._decrUpdatingCount()\n      throw err\n    }\n  }\n\n  public updateItemState(item: INavItem): void {\n    this._incUpdatingCount()\n\n    try {\n      setDefaultHorizontalNavItemState(item)\n\n      this.setItemStateProp(item, 'active', this.horizontalNavLinkActive(item))\n\n      // TODO: Implement this in a more optimized way. Unless our apps start\n      // having large navs constantly updating their state, this shouldn't\n      // have much impact on performance.\n      this._updateItemExpandedState(item)\n\n      this._decrUpdatingCount()\n    } catch (err) {\n      this._decrUpdatingCount()\n      throw err\n    }\n  }\n\n  public horizontalNavLinkActive(item: INavItem): boolean {\n    if (isHorizontalNavItemType(item, 'link')) {\n      const url = this._getUrl(item)\n      if (notNullOrUndefined(url)) {\n        const opts = this._getMatchOptions(item)\n        return this._router.isActive(url, opts)\n      }\n    }\n    return false\n  }\n\n  private _updateItemsExpandedState(items: INavItem[]): void {\n    for (const item of items) {\n      if (horizontalNavItemHasChildren(item)) {\n        this._updateItemsExpandedState(item.children)\n      }\n      this._updateItemExpandedState(item)\n    }\n  }\n\n  private _updateItemExpandedState(item: INavItem): void {\n    if (!horizontalNavItemCanExpand(item)) {\n      if (getHorizontalNavItemStateProp(item, 'expanded')) {\n        this.setItemStateProp(item, 'expanded', false)\n      }\n      return\n    }\n\n    if (horizontalNavItemHasChildren(item)) {\n      this._updateItemsExpandedState(item.children)\n    }\n\n    if (horizontalNavItemHasActiveChild(item) || horizontalNavItemHasExpandedChild(item)) {\n      if (!getHorizontalNavItemStateProp(item, 'expanded')) {\n        this.setItemStateProp(item, 'expanded', true)\n      }\n    } else {\n      if (getHorizontalNavItemStateProp(item, 'expanded')) {\n        this.setItemStateProp(item, 'expanded', false)\n      }\n    }\n  }\n\n  public updateRouterFocusedItem(items: INavItem[]) {\n    const focusedItem = items.find(i => isHorizontalNavItemActive(i)) || items.find(i => horizontalNavItemHasActiveChild(i))\n    if (notNullOrUndefined(focusedItem)) {\n      this.updateFocusedItem(items, focusedItem)\n    }\n  }\n\n  public updateFocusedItem(items: INavItem[], focusedItem: INavItem | undefined): void {\n    for (const item of items) {\n      if (areSameHorizontalNavItem(item, focusedItem)) {\n        setHorizontalNavItemStateProp(item, 'focused', true)\n      } else {\n        setHorizontalNavItemStateProp(item, 'focused', false)\n      }\n    }\n  }\n\n  private _getNavExtras(item: INavLink): UrlCreationOptions {\n    const navigationExtras: UrlCreationOptions = { }\n    if (hasProperty(item, 'queryParams')) {\n      navigationExtras.queryParams = item.queryParams\n    }\n    if (hasProperty(item, 'fragment')) {\n      navigationExtras.fragment = item.fragment\n    }\n    if (hasProperty(item, 'queryParamsHandling')) {\n      navigationExtras.queryParamsHandling = item.queryParamsHandling\n    }\n    if (hasProperty(item, 'preserveFragment')) {\n      navigationExtras.preserveFragment = item.preserveFragment\n    }\n    return navigationExtras\n  }\n\n  private _getUrl(item: INavLink): string | null {\n    const link = item.link\n\n    if (typeof link === 'string') {\n      return this._router.createUrlTree([ link ], this._getNavExtras(item)).toString()\n    } else if (Array.isArray(link)) {\n      return this._router.createUrlTree(link, this._getNavExtras(item)).toString()\n    }\n\n    return null\n  }\n\n  private _getMatchOptions(item: INavLink): IsActiveMatchOptions {\n    const defaultMatchOpts: IsActiveMatchOptions = {\n      paths: 'subset',\n      queryParams: 'subset',\n      fragment: 'ignored',\n      matrixParams: 'ignored'\n    }\n\n    if (hasProperty(item, 'matchOptions')) {\n      return {\n        ...defaultMatchOpts,\n        ...item.matchOptions\n      }\n    }\n\n    return defaultMatchOpts\n  }\n\n  public setItemStateProp<K extends keyof INavItemState>(item: INavItem, prop: K, value: INavItemState[K]): void {\n    const currentValue = getHorizontalNavItemStateProp(item, prop)\n    if (currentValue !== value) {\n      setHorizontalNavItemStateProp(item, prop, value)\n\n      const changed: NavItemStateChanged = {\n        item,\n        prop,\n        prevValue: currentValue,\n        newValue: value\n      }\n      this.itemChanged.next(changed)\n    }\n  }\n}\n"]}
|
|
@@ -4,4 +4,5 @@ export * from './side-nav/index';
|
|
|
4
4
|
export * from './top-bar/index';
|
|
5
5
|
export * from './dynamic-router/index';
|
|
6
6
|
export * from './schema-form/index';
|
|
7
|
-
|
|
7
|
+
export * from './nav/index';
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi9mcmFtZXdvcmsvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHFCQUFxQixDQUFBO0FBQ25DLGNBQWMsbUJBQW1CLENBQUE7QUFDakMsY0FBYyxrQkFBa0IsQ0FBQTtBQUNoQyxjQUFjLGlCQUFpQixDQUFBO0FBQy9CLGNBQWMsd0JBQXdCLENBQUE7QUFDdEMsY0FBYyxxQkFBcUIsQ0FBQTtBQUNuQyxjQUFjLGFBQWEsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYmFzZS1sYXlvdXQvaW5kZXgnXG5leHBvcnQgKiBmcm9tICcuL2Rhc2hib2FyZC9pbmRleCdcbmV4cG9ydCAqIGZyb20gJy4vc2lkZS1uYXYvaW5kZXgnXG5leHBvcnQgKiBmcm9tICcuL3RvcC1iYXIvaW5kZXgnXG5leHBvcnQgKiBmcm9tICcuL2R5bmFtaWMtcm91dGVyL2luZGV4J1xuZXhwb3J0ICogZnJvbSAnLi9zY2hlbWEtZm9ybS9pbmRleCdcbmV4cG9ydCAqIGZyb20gJy4vbmF2L2luZGV4J1xuIl19
|
|
@@ -6,6 +6,7 @@ import { BehaviorSubject, Subject } from 'rxjs';
|
|
|
6
6
|
import { map } from 'rxjs/operators';
|
|
7
7
|
import { faAngleLeft } from '@fortawesome/free-solid-svg-icons';
|
|
8
8
|
import { InputBoolean, InputNumber } from '@theseam/ui-common/core';
|
|
9
|
+
import { notNullOrUndefined } from '@theseam/ui-common/utils';
|
|
9
10
|
import { SideNavComponent } from '../side-nav.component';
|
|
10
11
|
const EXPANDED_STATE = 'expanded';
|
|
11
12
|
const COLLAPSED_STATE = 'collapsed';
|
|
@@ -45,13 +46,14 @@ export class SideNavItemComponent {
|
|
|
45
46
|
this._badgeTooltip = {
|
|
46
47
|
tooltip: value,
|
|
47
48
|
placement: 'auto',
|
|
48
|
-
disabled: false
|
|
49
|
+
disabled: false,
|
|
50
|
+
container: 'body'
|
|
49
51
|
};
|
|
50
52
|
}
|
|
51
53
|
else {
|
|
52
54
|
this._badgeTooltip = Object.assign(Object.assign({}, value), { placement: value.placement || 'auto', disabled: typeof (value === null || value === void 0 ? void 0 : value.disabled) === 'boolean'
|
|
53
55
|
? value.disabled
|
|
54
|
-
: typeof value.tooltip === 'string' ? false : true });
|
|
56
|
+
: typeof value.tooltip === 'string' ? false : true, container: value.container || 'body' });
|
|
55
57
|
}
|
|
56
58
|
}
|
|
57
59
|
else {
|
|
@@ -76,11 +78,14 @@ export class SideNavItemComponent {
|
|
|
76
78
|
this._sideNav.collapse();
|
|
77
79
|
}
|
|
78
80
|
}
|
|
81
|
+
get showIconBlock() {
|
|
82
|
+
return notNullOrUndefined(this.icon) || this.hideEmptyIcon !== true;
|
|
83
|
+
}
|
|
79
84
|
}
|
|
80
85
|
SideNavItemComponent.decorators = [
|
|
81
86
|
{ type: Component, args: [{
|
|
82
87
|
selector: 'seam-side-nav-item',
|
|
83
|
-
template: "<div class=\"d-flex flex-row\">\n <ng-container *ngIf=\"itemType === 'basic'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeBasic\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'link'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeLink\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'divider'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeDivider\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'title'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeTitle\"></ng-template>\n </ng-container>\n</div>\n\n<ng-container *ngIf=\"hasChildren\">\n <div class=\"side-nav--group side-nav--group--level-{{ hierLevel + 1 }}\"\n [@childGroupAnim]=\"childGroupAnimState$ | async\">\n <seam-side-nav-item *ngFor=\"let child of children\"\n [hierLevel]=\"compact ? 0 : (hierLevel + 1)\"\n [compact]=\"compact\"\n [itemType]=\"$any(child).itemType\"\n [icon]=\"$any(child).icon\"\n [label]=\"$any(child).label\"\n [link]=\"$any(child).link\"\n [badgeText]=\"$any(child).badge?.text\"\n [badgeTheme]=\"$any(child).badge?.theme || 'danger'\"\n [badgeSrContent]=\"$any(child).badge?.srContent\"\n [badgeTooltip]=\"$any(child)?.badge?.tooltip\"\n [queryParams]=\"$any(child).queryParams\"\n routerLinkActive=\"active\"\n [routerLinkActiveOptions]=\"{ exact: true }\"\n [children]=\"$any(child)?.children\"\n [active]=\"$any(child).__state
|
|
88
|
+
template: "<div class=\"d-flex flex-row side-nav-item-wrapper\">\n <ng-container *ngIf=\"itemType === 'basic'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeBasic\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'link'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeLink\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'divider'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeDivider\"></ng-template>\n </ng-container>\n <ng-container *ngIf=\"itemType === 'title'\">\n <ng-template [ngTemplateOutlet]=\"itemTypeTitle\"></ng-template>\n </ng-container>\n</div>\n\n<ng-container *ngIf=\"hasChildren\">\n <div class=\"side-nav--group side-nav--group--level-{{ hierLevel + 1 }}\"\n [@childGroupAnim]=\"childGroupAnimState$ | async\">\n <seam-side-nav-item *ngFor=\"let child of children\"\n [hierLevel]=\"compact ? 0 : (hierLevel + 1)\"\n [compact]=\"compact\"\n [itemType]=\"$any(child).itemType\"\n [icon]=\"$any(child).icon\"\n [label]=\"$any(child).label\"\n [link]=\"$any(child).link\"\n [badgeText]=\"$any(child).badge?.text\"\n [badgeTheme]=\"$any(child).badge?.theme || 'danger'\"\n [badgeSrContent]=\"$any(child).badge?.srContent\"\n [badgeTooltip]=\"$any(child)?.badge?.tooltip\"\n [queryParams]=\"$any(child).queryParams\"\n routerLinkActive=\"active\"\n [routerLinkActiveOptions]=\"{ exact: true }\"\n [children]=\"$any(child)?.children\"\n [active]=\"$any(child).__state?.active\"\n [expanded]=\"$any(child).__state?.expanded\"\n [hideEmptyIcon]=\"hideEmptyIcon\"\n [indentSize]=\"indentSize\">\n </seam-side-nav-item>\n </div>\n</ng-container>\n\n<ng-template #itemTypeBasic>\n <button class=\"side-nav-item btn side-nav-btn p-0 d-flex flex-row align-items-stretch rounded-0 text-decoration-none text-nowrap w-100\"\n cdkMonitorElementFocus\n (click)=\"toggleChildren()\"\n [attr.aria-expanded]=\"expanded\">\n <div class=\"nav-link d-flex flex-row align-items-center w-100\" [class.nav-link__compact]=\"compact\">\n <div [style.padding-left.px]=\"hierLevel * indentSize\"></div>\n <div class=\"side-nav-item--icon\" *ngIf=\"showIconBlock\">\n <seam-icon *ngIf=\"icon\" [icon]=\"icon\"></seam-icon>\n <ng-container *ngIf=\"compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n <span *ngIf=\"!compact\" side-nav-item-label style=\"margin-left: 11px;\">\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" side-nav-item-label>{{ label }}</span>\n <ng-container *ngIf=\"!compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n\n <div *ngIf=\"hasChildren && !compact\"\n class=\"btn side-nav-btn side-nav-item--toggle-btn-container rounded-0\">\n <seam-icon\n class=\"side-nav-item--toggle-btn\"\n [class.side-nav-item--toggle-btn-expanded]=\"expanded\"\n [icon]=\"faAngleLeft\"\n type>\n </seam-icon>\n </div>\n </button>\n</ng-template>\n\n<ng-template #itemTypeLink>\n <a *ngIf=\"link; else noLink\" class=\"side-nav-item nav-link d-flex flex-row text-nowrap w-100 align-items-center\"\n [class.nav-link__compact]=\"compact\"\n [routerLink]=\"link\"\n [queryParams]=\"queryParams\"\n routerLinkActive=\"active\"\n [routerLinkActiveOptions]=\"{ exact: true }\"\n (click)=\"_linkClicked()\">\n <div [style.padding-left.px]=\"hierLevel * indentSize\"></div>\n <div class=\"side-nav-item--icon\" *ngIf=\"showIconBlock\">\n <seam-icon *ngIf=\"icon\" [icon]=\"icon\"></seam-icon>\n <ng-container *ngIf=\"compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </div>\n <span *ngIf=\"!compact\" style=\"margin-left: 11px;\" side-nav-item-label>\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" side-nav-item-label>{{ label }}</span>\n <ng-container *ngIf=\"!compact\">\n <ng-template [ngTemplateOutlet]=\"itemBadge\"></ng-template>\n </ng-container>\n </a>\n\n <ng-template #noLink>\n <a class=\"side-nav-item nav-link d-flex flex-row text-nowrap w-100 align-items-center\" [class.nav-link__compact]=\"compact\">\n <div [style.padding-left.px]=\"hierLevel * indentSize\"></div>\n <div class=\"side-nav-item--icon\" *ngIf=\"showIconBlock\">\n <seam-icon *ngIf=\"icon\" [icon]=\"icon\"></seam-icon>\n </div>\n <span *ngIf=\"!compact\" style=\"margin-left: 11px;\" side-nav-item-label>\n {{ label }}\n </span>\n <span *ngIf=\"compact\" class=\"sr-only\" side-nav-item-label>{{ label }}</span>\n </a>\n </ng-template>\n\n <button *ngIf=\"hasChildren && !compact\"\n type=\"button\"\n class=\"btn side-nav-btn side-nav-item--toggle-btn-container rounded-0\"\n (click)=\"toggleChildren()\"\n [attr.aria-expanded]=\"expanded\"\n cdkMonitorElementFocus>\n <seam-icon\n class=\"side-nav-item--toggle-btn\"\n [class.side-nav-item--toggle-btn-expanded]=\"expanded\"\n [icon]=\"faAngleLeft\"\n type>\n </seam-icon>\n <span class=\"sr-only\">Group Toggle</span>\n </button>\n</ng-template>\n\n<ng-template #itemTypeDivider>\n <div class=\"px-2 w-100\">\n <hr class=\"side-nav-item--divider\" />\n </div>\n</ng-template>\n\n<ng-template #itemTypeTitle>\n <ng-container *ngIf=\"!compact\">\n <span class=\"side-nav-item--title pt-1\" side-nav-item-label>{{ label }}</span>\n </ng-container>\n</ng-template>\n\n<ng-template #itemBadge>\n <ng-container *ngIf=\"badgeText\">\n <div class=\"badge-spacer flex-grow-1\" *ngIf=\"!compact\"></div>\n <div class=\"side-nav-item--badge\"\n [class.side-nav-item--badge-no-icon]=\"!icon\"\n [ngbTooltip]=\"$any(badgeTooltip)?.tooltip\"\n [tooltipClass]=\"$any(badgeTooltip)?.class\"\n [placement]=\"$any(badgeTooltip)?.placement\"\n [container]=\"$any(badgeTooltip)?.container\"\n [disableTooltip]=\"!badgeTooltip || !!$any(badgeTooltip)?.disabled\">\n <span class=\"badge badge-pill badge-{{ badgeTheme }}\">\n <ng-container *ngIf=\"!compact || !icon\">\n {{ badgeText }}\n </ng-container>\n <span *ngIf=\"badgeSrContent\">{{ badgeSrContent }}</span>\n </span>\n </div>\n </ng-container>\n</ng-template>\n",
|
|
84
89
|
exportAs: 'seamSideNavItem',
|
|
85
90
|
animations: [
|
|
86
91
|
trigger('childGroupAnim', [
|
|
@@ -113,7 +118,7 @@ SideNavItemComponent.decorators = [
|
|
|
113
118
|
],
|
|
114
119
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
115
120
|
encapsulation: ViewEncapsulation.None,
|
|
116
|
-
styles: ["seam-side-nav-item{display:block;transition:.25s ease-in-out background-color}seam-side-nav-item.seam-side-nav-item--active{background-color:#2a6395}seam-side-nav-item.seam-side-nav-item--active .active,seam-side-nav-item.seam-side-nav-item--active:active,seam-side-nav-item.seam-side-nav-item--active .side-nav-item.active:hover{background-color:#2a6395}seam-side-nav-item.seam-side-nav-item--active .side-nav-item:hover{background-color:#2f71a9}seam-side-nav-item.seam-side-nav-item--active .nav-link{color:#fff}seam-side-nav-item .badge{vertical-align:middle}seam-side-nav-item:not(.side-nav-item--icon) .side-nav-item--badge{pointer-events:all;margin-left:5px;margin-right:3px}seam-side-nav-item .side-nav-item--icon{position:relative;width:24px;max-width:24px;min-width:24px;height:24px;max-height:24px;min-height:24px;text-align:center}seam-side-nav-item .side-nav-item--icon .side-nav-item--badge{top:-4px;right:-4px;position:absolute}seam-side-nav-item .side-nav-item--icon .side-nav-item--badge .badge:empty{display:block;width:8px;height:8px;padding:0}seam-side-nav-item .side-nav-item--icon .side-nav-item--badge.side-nav-item--badge-no-icon{top:0px;right:0px}seam-side-nav-item .side-nav-item{min-height:45px;transition:.25s ease-in-out background-color}seam-side-nav-item .side-nav-item:hover{background-color:#2f71a9}seam-side-nav-item .side-nav-item.active{pointer-events:none;cursor:default}seam-side-nav-item a.side-nav-item:not([href]):not([tabindex]){color:#ccc}seam-side-nav-item a.side-nav-item:not([href]):not([tabindex]):hover{background-color:transparent}seam-side-nav-item .nav-link{color:#fff;padding-right:2px}seam-side-nav-item .nav-link__compact{padding-right:0;padding-left:12px}seam-side-nav-item .nav-link:last-child{padding-right:8px}seam-side-nav-item .side-nav-btn{font-weight:400;color:#fff;text-decoration:none}seam-side-nav-item .side-nav-btn:hover{color:#
|
|
121
|
+
styles: ["seam-side-nav-item{display:block;transition:.25s ease-in-out background-color}seam-side-nav-item.seam-side-nav-item--active{background-color:#2a6395}seam-side-nav-item.seam-side-nav-item--active .active,seam-side-nav-item.seam-side-nav-item--active:active,seam-side-nav-item.seam-side-nav-item--active .side-nav-item.active:hover{background-color:#2a6395}seam-side-nav-item.seam-side-nav-item--active .side-nav-item:hover{background-color:#2f71a9}seam-side-nav-item.seam-side-nav-item--active .nav-link{color:#fff}seam-side-nav-item.seam-side-nav-item--active .side-nav-btn{color:#fff}seam-side-nav-item .badge{vertical-align:middle}seam-side-nav-item:not(.side-nav-item--icon) .side-nav-item--badge{pointer-events:all;margin-left:5px;margin-right:3px}seam-side-nav-item .side-nav-item--icon{position:relative;width:24px;max-width:24px;min-width:24px;height:24px;max-height:24px;min-height:24px;text-align:center}seam-side-nav-item .side-nav-item--icon .side-nav-item--badge{top:-4px;right:-4px;position:absolute}seam-side-nav-item .side-nav-item--icon .side-nav-item--badge .badge:empty{display:block;width:8px;height:8px;padding:0}seam-side-nav-item .side-nav-item--icon .side-nav-item--badge.side-nav-item--badge-no-icon{top:0px;right:0px}seam-side-nav-item .side-nav-item{min-height:45px;transition:.25s ease-in-out background-color}seam-side-nav-item .side-nav-item:hover{background-color:#2f71a9}seam-side-nav-item .side-nav-item.active{pointer-events:none;cursor:default}seam-side-nav-item a.side-nav-item:not([href]):not([tabindex]){color:#ccc}seam-side-nav-item a.side-nav-item:not([href]):not([tabindex]):hover{background-color:transparent}seam-side-nav-item .nav-link{color:#fff;padding-right:2px}seam-side-nav-item .nav-link__compact{padding-right:0;padding-left:12px}seam-side-nav-item .nav-link:last-child{padding-right:8px}seam-side-nav-item .side-nav-btn{font-weight:400;color:#fff;text-decoration:none}seam-side-nav-item .side-nav-btn:hover{color:#fff;text-decoration:underline}seam-side-nav-item .side-nav-btn:focus,seam-side-nav-item .side-nav-btn.focus{text-decoration:underline;box-shadow:none}seam-side-nav-item .side-nav-btn:disabled,seam-side-nav-item .side-nav-btn.disabled{color:#ccc;pointer-events:none}seam-side-nav-item .cdk-keyboard-focused{outline:1px dotted;outline:5px auto -webkit-focus-ring-color}seam-side-nav-item .side-nav-item--toggle-btn-container{transition:.25s ease-in-out background-color;padding:.5rem 1rem}seam-side-nav-item button.side-nav-item--toggle-btn-container:hover{background-color:#2f71a9}seam-side-nav-item .side-nav-item--toggle-btn .svg-inline--fa{transition:.1s ease-in-out transform}seam-side-nav-item .side-nav-item--toggle-btn.side-nav-item--toggle-btn-expanded .svg-inline--fa{transform:rotate(-90deg)}seam-side-nav-item .side-nav--group{will-change:height;overflow:hidden}seam-side-nav-item .side-nav--group--level-1{background-color:#3276b1}seam-side-nav-item .side-nav--group--level-2{background-color:#2e6ea5}seam-side-nav-item .side-nav--group--level-3{background-color:#2b6699}seam-side-nav-item .side-nav--group--level-4{background-color:#285e8d}seam-side-nav-item .side-nav--group--level-5{background-color:#245681}seam-side-nav-item .side-nav--group--level-6{background-color:#214e75}seam-side-nav-item .side-nav--group--level-7{background-color:#1e4669}seam-side-nav-item .side-nav--group--level-8{background-color:#1a3e5d}seam-side-nav-item .side-nav--group--level-9{background-color:#173651}seam-side-nav-item .side-nav-item--divider{display:block;border-top:1px solid #2a6395;width:100%}seam-side-nav-item .side-nav-item--title{color:#fff;font-size:24px;padding-left:10px}seam-side-nav-item .sr-only{top:0;left:0}\n"]
|
|
117
122
|
},] }
|
|
118
123
|
];
|
|
119
124
|
SideNavItemComponent.ctorParameters = () => [
|
|
@@ -123,6 +128,7 @@ SideNavItemComponent.ctorParameters = () => [
|
|
|
123
128
|
SideNavItemComponent.propDecorators = {
|
|
124
129
|
itemType: [{ type: Input }],
|
|
125
130
|
icon: [{ type: Input }],
|
|
131
|
+
hideEmptyIcon: [{ type: Input }],
|
|
126
132
|
label: [{ type: Input }],
|
|
127
133
|
active: [{ type: Input }],
|
|
128
134
|
link: [{ type: Input }],
|
|
@@ -148,4 +154,4 @@ __decorate([
|
|
|
148
154
|
__decorate([
|
|
149
155
|
InputNumber(10)
|
|
150
156
|
], SideNavItemComponent.prototype, "indentSize", void 0);
|
|
151
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-nav-item.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/framework/side-nav/side-nav-item/side-nav-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  animate,\n  query,\n  state,\n  style,\n  transition,\n  trigger,\n} from '@angular/animations'\nimport { BooleanInput, coerceBooleanProperty, NumberInput } from '@angular/cdk/coercion'\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Host,\n  HostBinding,\n  Input,\n  OnDestroy,\n  Optional,\n  SkipSelf,\n  ViewEncapsulation\n} from '@angular/core'\nimport { BehaviorSubject, Observable, Subject } from 'rxjs'\nimport { map } from 'rxjs/operators'\n\nimport { faAngleLeft } from '@fortawesome/free-solid-svg-icons'\n\nimport { InputBoolean, InputNumber } from '@theseam/ui-common/core'\nimport type { SeamIcon } from '@theseam/ui-common/icon'\nimport type { ThemeTypes } from '@theseam/ui-common/models'\n\nimport { SideNavComponent } from '../side-nav.component'\nimport { ISideNavItem } from '../side-nav.models'\n\nexport interface SideNavItemBadgeTooltip {\n  tooltip?: string\n  class?: string\n  placement?: string\n  container?: string\n  disabled?: boolean\n}\n\nconst EXPANDED_STATE = 'expanded'\nconst COLLAPSED_STATE = 'collapsed'\n\nconst FULL_STATE = 'full'\nconst COMPACT_STATE = 'compact'\n\n@Component({\n  selector: 'seam-side-nav-item',\n  templateUrl: './side-nav-item.component.html',\n  styleUrls: ['./side-nav-item.component.scss'],\n  exportAs: 'seamSideNavItem',\n  animations: [\n    trigger('childGroupAnim', [\n      state(EXPANDED_STATE, style({ height: '*' })),\n      state(COLLAPSED_STATE, style({ height: 0, 'overflow-y': 'hidden', visibility: 'hidden' })),\n      transition(`${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`, animate('0.2s ease-in-out')),\n    ]),\n\n\n    trigger('compactAnim', [\n      // transition('* <=> *', [\n      //   query(':enter', [\n      //     style({ opacity: '0' }),\n      //     animate('5.2s ease-in-out', style({ opacity: '1' }))\n      //   ], { optional: true }),\n      //   query(':leave', [\n      //     style({ opacity: '1' }),\n      //     animate('5.2s ease-in-out', style({ opacity: '0' }))\n      //   ], { optional: true })\n      // ])\n\n      // state(FULL_STATE, style({ opacity: '1' })),\n      // state(COMPACT_STATE, style({ opacity: '0' })),\n      // transition(`${FULL_STATE} <=> ${COMPACT_STATE}`, animate('5.2s ease-in-out')),\n      // transition(`${FULL_STATE} <=> ${COMPACT_STATE}`, [\n      // transition('* <=> *', [\n      //   query(':leave', [\n      //     style({ opacity: '1' }),\n      //     animate('5.2s ease-in-out', style({ opacity: '0' }))\n      //   ], { optional: true })\n      // ]),\n\n\n    ])\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None\n})\nexport class SideNavItemComponent implements OnDestroy {\n  static ngAcceptInputType_hierLevel: NumberInput\n  static ngAcceptInputType_indentSize: NumberInput\n  static ngAcceptInputType_expanded: BooleanInput\n  static ngAcceptInputType_compact: BooleanInput\n  static ngAcceptInputType_active: BooleanInput\n\n  private readonly _ngUnsubscribe = new Subject()\n\n  readonly faAngleLeft = faAngleLeft\n\n  @Input() itemType: 'divider' | 'basic' | 'link' | 'button' | 'title' | undefined | null\n\n  @Input() icon: SeamIcon | undefined | null\n\n  @Input() label: string | undefined | null\n\n  @Input() @InputBoolean() active: boolean = false\n\n  @Input()\n  set link(value: string | undefined | null) { this._link.next(value) }\n  get link() { return this._link.value }\n  private readonly _link = new BehaviorSubject<string | undefined | null>(undefined)\n  public readonly link$ = this._link.asObservable()\n\n  @Input() queryParams: { [k: string]: any } | undefined | null\n\n  @Input() children: ISideNavItem[] | undefined | null\n\n  @Input() @InputNumber(0) hierLevel: number = 0\n\n  @Input() @InputNumber(10) indentSize: number = 10\n\n  @Input()\n  set expanded(value: boolean) { this._expanded.next(coerceBooleanProperty(value)) }\n  get expanded() { return this._expanded.value }\n  private readonly _expanded = new BehaviorSubject<boolean>(false)\n  public readonly expanded$ = this._expanded.asObservable()\n\n  @Input()\n  set compact(value: boolean) { this._compact.next(coerceBooleanProperty(value)) }\n  get compact() { return this._compact.value }\n  private readonly _compact = new BehaviorSubject<boolean>(false)\n  public readonly compact$ = this._compact.asObservable()\n\n  @Input() badgeText: string | undefined | null\n  @Input() badgeTheme: ThemeTypes | undefined | null = 'danger'\n\n  /**\n   * Content to provide to assistive technology, such as screen readers.\n   */\n  @Input() badgeSrContent: string | undefined | null\n\n  @Input()\n  get badgeTooltip() { return this._badgeTooltip }\n  set badgeTooltip(value: string | SideNavItemBadgeTooltip | undefined | null) {\n    if (value !== null && value !== undefined) {\n      if (typeof value === 'string') {\n        this._badgeTooltip = {\n          tooltip: value,\n          placement: 'auto',\n          disabled: false\n        }\n      } else {\n        this._badgeTooltip = {\n          ...value,\n          placement: value.placement || 'auto',\n          disabled: typeof value?.disabled === 'boolean'\n            ? value.disabled\n            : typeof value.tooltip === 'string' ? false : true\n        }\n      }\n    } else {\n      this._badgeTooltip = undefined\n    }\n  }\n  private _badgeTooltip: SideNavItemBadgeTooltip | undefined | null\n\n  @HostBinding('class.seam-side-nav-item--active') get _isActiveCssClass() { return this.active }\n\n  @HostBinding('attr.data-hier-level') get _attrDataHierLevel() { return this.hierLevel }\n\n  public readonly childGroupAnimState$: Observable<string>\n  public readonly compactAnimState$: Observable<string>\n\n  constructor(\n    private readonly _sideNav: SideNavComponent,\n    @Optional() @SkipSelf() @Host() private readonly _parent?: SideNavItemComponent\n  ) {\n    this.childGroupAnimState$ = this.expanded$\n      .pipe(map(expanded => expanded ? EXPANDED_STATE : COLLAPSED_STATE))\n\n    this.compactAnimState$ = this.compact$\n      .pipe(map(compact => compact ? COMPACT_STATE : FULL_STATE))\n  }\n\n  ngOnDestroy() {\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  get hasChildren() {\n    return Array.isArray(this.children) && this.children.length > 0\n  }\n\n  public toggleChildren(): void {\n    this.expanded = !this.expanded\n  }\n\n  _linkClicked() {\n    // Close nav when link is clicked while in overlay state\n    if (this._sideNav.overlay) {\n      this._sideNav.collapse()\n    }\n  }\n\n}\n"]}
|
|
157
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-nav-item.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/framework/side-nav/side-nav-item/side-nav-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  animate,\n  query,\n  state,\n  style,\n  transition,\n  trigger,\n} from '@angular/animations'\nimport { BooleanInput, coerceBooleanProperty, NumberInput } from '@angular/cdk/coercion'\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Host,\n  HostBinding,\n  Input,\n  OnDestroy,\n  Optional,\n  SkipSelf,\n  ViewEncapsulation\n} from '@angular/core'\nimport { BehaviorSubject, Observable, Subject } from 'rxjs'\nimport { map } from 'rxjs/operators'\n\nimport { faAngleLeft } from '@fortawesome/free-solid-svg-icons'\n\nimport { InputBoolean, InputNumber } from '@theseam/ui-common/core'\nimport type { SeamIcon } from '@theseam/ui-common/icon'\nimport type { ThemeTypes } from '@theseam/ui-common/models'\n\nimport { notNullOrUndefined } from '@theseam/ui-common/utils'\nimport { SideNavComponent } from '../side-nav.component'\nimport { ISideNavItem } from '../side-nav.models'\n\nexport interface SideNavItemBadgeTooltip {\n  tooltip?: string\n  class?: string\n  placement?: string\n  container?: string\n  disabled?: boolean\n}\n\nconst EXPANDED_STATE = 'expanded'\nconst COLLAPSED_STATE = 'collapsed'\n\nconst FULL_STATE = 'full'\nconst COMPACT_STATE = 'compact'\n\n@Component({\n  selector: 'seam-side-nav-item',\n  templateUrl: './side-nav-item.component.html',\n  styleUrls: ['./side-nav-item.component.scss'],\n  exportAs: 'seamSideNavItem',\n  animations: [\n    trigger('childGroupAnim', [\n      state(EXPANDED_STATE, style({ height: '*' })),\n      state(COLLAPSED_STATE, style({ height: 0, 'overflow-y': 'hidden', visibility: 'hidden' })),\n      transition(`${EXPANDED_STATE} <=> ${COLLAPSED_STATE}`, animate('0.2s ease-in-out')),\n    ]),\n\n\n    trigger('compactAnim', [\n      // transition('* <=> *', [\n      //   query(':enter', [\n      //     style({ opacity: '0' }),\n      //     animate('5.2s ease-in-out', style({ opacity: '1' }))\n      //   ], { optional: true }),\n      //   query(':leave', [\n      //     style({ opacity: '1' }),\n      //     animate('5.2s ease-in-out', style({ opacity: '0' }))\n      //   ], { optional: true })\n      // ])\n\n      // state(FULL_STATE, style({ opacity: '1' })),\n      // state(COMPACT_STATE, style({ opacity: '0' })),\n      // transition(`${FULL_STATE} <=> ${COMPACT_STATE}`, animate('5.2s ease-in-out')),\n      // transition(`${FULL_STATE} <=> ${COMPACT_STATE}`, [\n      // transition('* <=> *', [\n      //   query(':leave', [\n      //     style({ opacity: '1' }),\n      //     animate('5.2s ease-in-out', style({ opacity: '0' }))\n      //   ], { optional: true })\n      // ]),\n\n\n    ])\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None\n})\nexport class SideNavItemComponent implements OnDestroy {\n  static ngAcceptInputType_hierLevel: NumberInput\n  static ngAcceptInputType_indentSize: NumberInput\n  static ngAcceptInputType_expanded: BooleanInput\n  static ngAcceptInputType_compact: BooleanInput\n  static ngAcceptInputType_active: BooleanInput\n\n  private readonly _ngUnsubscribe = new Subject()\n\n  readonly faAngleLeft = faAngleLeft\n\n  @Input() itemType: 'divider' | 'basic' | 'link' | 'button' | 'title' | undefined | null\n\n  @Input() icon: SeamIcon | undefined | null\n\n  @Input() hideEmptyIcon: boolean | undefined | null\n\n  @Input() label: string | undefined | null\n\n  @Input() @InputBoolean() active: boolean = false\n\n  @Input()\n  set link(value: string | undefined | null) { this._link.next(value) }\n  get link() { return this._link.value }\n  private readonly _link = new BehaviorSubject<string | undefined | null>(undefined)\n  public readonly link$ = this._link.asObservable()\n\n  @Input() queryParams: { [k: string]: any } | undefined | null\n\n  @Input() children: ISideNavItem[] | undefined | null\n\n  @Input() @InputNumber(0) hierLevel: number = 0\n\n  @Input() @InputNumber(10) indentSize: number = 10\n\n  @Input()\n  set expanded(value: boolean) { this._expanded.next(coerceBooleanProperty(value)) }\n  get expanded() { return this._expanded.value }\n  private readonly _expanded = new BehaviorSubject<boolean>(false)\n  public readonly expanded$ = this._expanded.asObservable()\n\n  @Input()\n  set compact(value: boolean) { this._compact.next(coerceBooleanProperty(value)) }\n  get compact() { return this._compact.value }\n  private readonly _compact = new BehaviorSubject<boolean>(false)\n  public readonly compact$ = this._compact.asObservable()\n\n  @Input() badgeText: string | undefined | null\n  @Input() badgeTheme: ThemeTypes | undefined | null = 'danger'\n\n  /**\n   * Content to provide to assistive technology, such as screen readers.\n   */\n  @Input() badgeSrContent: string | undefined | null\n\n  @Input()\n  get badgeTooltip() { return this._badgeTooltip }\n  set badgeTooltip(value: string | SideNavItemBadgeTooltip | undefined | null) {\n    if (value !== null && value !== undefined) {\n      if (typeof value === 'string') {\n        this._badgeTooltip = {\n          tooltip: value,\n          placement: 'auto',\n          disabled: false,\n          container: 'body'\n        }\n      } else {\n        this._badgeTooltip = {\n          ...value,\n          placement: value.placement || 'auto',\n          disabled: typeof value?.disabled === 'boolean'\n            ? value.disabled\n            : typeof value.tooltip === 'string' ? false : true,\n          container: value.container || 'body'\n        }\n      }\n    } else {\n      this._badgeTooltip = undefined\n    }\n  }\n  private _badgeTooltip: SideNavItemBadgeTooltip | undefined | null\n\n  @HostBinding('class.seam-side-nav-item--active') get _isActiveCssClass() { return this.active }\n\n  @HostBinding('attr.data-hier-level') get _attrDataHierLevel() { return this.hierLevel }\n\n  public readonly childGroupAnimState$: Observable<string>\n  public readonly compactAnimState$: Observable<string>\n\n  constructor(\n    private readonly _sideNav: SideNavComponent,\n    @Optional() @SkipSelf() @Host() private readonly _parent?: SideNavItemComponent\n  ) {\n    this.childGroupAnimState$ = this.expanded$\n      .pipe(map(expanded => expanded ? EXPANDED_STATE : COLLAPSED_STATE))\n\n    this.compactAnimState$ = this.compact$\n      .pipe(map(compact => compact ? COMPACT_STATE : FULL_STATE))\n  }\n\n  ngOnDestroy() {\n    this._ngUnsubscribe.next()\n    this._ngUnsubscribe.complete()\n  }\n\n  get hasChildren() {\n    return Array.isArray(this.children) && this.children.length > 0\n  }\n\n  public toggleChildren(): void {\n    this.expanded = !this.expanded\n  }\n\n  _linkClicked() {\n    // Close nav when link is clicked while in overlay state\n    if (this._sideNav.overlay) {\n      this._sideNav.collapse()\n    }\n  }\n\n  get showIconBlock(): boolean {\n    return notNullOrUndefined(this.icon) || this.hideEmptyIcon !== true\n  }\n\n}\n"]}
|