@agorapulse/ui-components 18.1.9 → 18.1.11
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/agorapulse-ui-components-18.1.11.tgz +0 -0
- package/esm2022/nav-selector/nav-selector.component.mjs +4 -3
- package/esm2022/nav-selector/nav-selector.state.mjs +6 -4
- package/esm2022/nav-selector/utils/nav-selector.folding.mjs +3 -1
- package/esm2022/nav-selector/utils/nav-selector.multi-select.mjs +8 -15
- package/esm2022/nav-selector/utils/nav-selector.single-select.mjs +2 -8
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs +18 -24
- package/fesm2022/agorapulse-ui-components-nav-selector.mjs.map +1 -1
- package/nav-selector/nav-selector.component.d.ts +2 -1
- package/nav-selector/nav-selector.state.d.ts +0 -1
- package/package.json +1 -1
- package/agorapulse-ui-components-18.1.9.tgz +0 -0
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { isInternalNavSelectorEntryACategory, isInternalNavSelectorEntryAGroup, isInternalNavSelectorEntryALeaf, isInternalNavSelectorEntryANode, } from '../nav-selector';
|
|
2
|
-
import { computeFolded } from './leaf.utils';
|
|
3
2
|
/**
|
|
4
3
|
* NavSelectorMultiSelect is a utility class that provides methods to select an entry in multiple mode.
|
|
5
4
|
*/
|
|
@@ -47,11 +46,9 @@ export class NavSelectorMultiSelect {
|
|
|
47
46
|
};
|
|
48
47
|
}
|
|
49
48
|
else if (isInternalNavSelectorEntryACategory(entry)) {
|
|
50
|
-
const children = this.selectOnlyALeafInMultipleMode(entry.children, entryUid);
|
|
51
49
|
return {
|
|
52
50
|
...entry,
|
|
53
|
-
|
|
54
|
-
children,
|
|
51
|
+
children: this.selectOnlyALeafInMultipleMode(entry.children, entryUid),
|
|
55
52
|
};
|
|
56
53
|
}
|
|
57
54
|
else if (isInternalNavSelectorEntryAGroup(entry)) {
|
|
@@ -61,7 +58,6 @@ export class NavSelectorMultiSelect {
|
|
|
61
58
|
...entry,
|
|
62
59
|
children,
|
|
63
60
|
selected,
|
|
64
|
-
folded: computeFolded(entry, children),
|
|
65
61
|
undeterminedSelection: !selected && children.some(child => child.selected),
|
|
66
62
|
};
|
|
67
63
|
}
|
|
@@ -101,16 +97,14 @@ export class NavSelectorMultiSelect {
|
|
|
101
97
|
};
|
|
102
98
|
}
|
|
103
99
|
static selectACategoryInMultipleMode(entry, entryUid) {
|
|
104
|
-
const children = entry.children.map(child => {
|
|
105
|
-
if (isInternalNavSelectorEntryALeaf(child)) {
|
|
106
|
-
return this.selectALeafInMultipleMode(child, entryUid);
|
|
107
|
-
}
|
|
108
|
-
return this.selectAGroupInMultipleMode(child, entryUid);
|
|
109
|
-
});
|
|
110
100
|
return {
|
|
111
101
|
...entry,
|
|
112
|
-
|
|
113
|
-
|
|
102
|
+
children: entry.children.map(child => {
|
|
103
|
+
if (isInternalNavSelectorEntryALeaf(child)) {
|
|
104
|
+
return this.selectALeafInMultipleMode(child, entryUid);
|
|
105
|
+
}
|
|
106
|
+
return this.selectAGroupInMultipleMode(child, entryUid);
|
|
107
|
+
}),
|
|
114
108
|
};
|
|
115
109
|
}
|
|
116
110
|
static selectAGroupInMultipleMode(entry, entryUid) {
|
|
@@ -136,7 +130,6 @@ export class NavSelectorMultiSelect {
|
|
|
136
130
|
}
|
|
137
131
|
return {
|
|
138
132
|
...entry,
|
|
139
|
-
folded: computeFolded(entry, children),
|
|
140
133
|
children,
|
|
141
134
|
selected,
|
|
142
135
|
undeterminedSelection,
|
|
@@ -212,4 +205,4 @@ export class NavSelectorMultiSelect {
|
|
|
212
205
|
});
|
|
213
206
|
}
|
|
214
207
|
}
|
|
215
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector.multi-select.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/utils/nav-selector.multi-select.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    InternalNavSelectorCategory,\n    InternalNavSelectorEntry,\n    InternalNavSelectorGroup,\n    InternalNavSelectorLeaf,\n    isInternalNavSelectorEntryACategory,\n    isInternalNavSelectorEntryAGroup,\n    isInternalNavSelectorEntryALeaf,\n    isInternalNavSelectorEntryANode,\n} from '../nav-selector';\nimport { computeFolded } from './leaf.utils';\n\n/**\n * NavSelectorMultiSelect is a utility class that provides methods to select an entry in multiple mode.\n */\nexport class NavSelectorMultiSelect {\n    /**\n     * Select an entry in multiple mode.\n     *\n     * Categories are not selectable.\n     *\n     * Groups and leaves are selectable.\n     *\n     * Groups may be in undetermined state if some of their children are selected and some are not.\n     * @param entries nav selector entries\n     * @param entryUid the entry uid to select\n     */\n    static selectInMultipleMode(entries: InternalNavSelectorEntry[], entryUid: string): InternalNavSelectorEntry[] {\n        return entries.map(entry => {\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                return this.selectALeafInMultipleMode(entry, entryUid);\n            } else if (isInternalNavSelectorEntryAGroup(entry)) {\n                return this.selectAGroupInMultipleMode(entry, entryUid);\n            } else if (isInternalNavSelectorEntryACategory(entry)) {\n                return this.selectACategoryInMultipleMode(entry, entryUid);\n            }\n            return entry;\n        });\n    }\n\n    /**\n     * Select only a leaf in multiple mode.\n     *\n     * Categories are not selectable.\n     *\n     * Groups may be in undetermined state if some of their children are selected and some are not.\n     * @param entries nav selector entries\n     * @param entryUid the entry uid to select\n     */\n    static selectOnlyALeafInMultipleMode<T extends InternalNavSelectorEntry>(entries: T[], entryUid: string): InternalNavSelectorEntry[] {\n        return entries.map(entry => {\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                return {\n                    ...entry,\n                    selected: entry.uid === entryUid,\n                };\n            } else if (isInternalNavSelectorEntryACategory(entry)) {\n                const children = this.selectOnlyALeafInMultipleMode(entry.children, entryUid);\n                return {\n                    ...entry,\n                    folded: computeFolded(entry, children),\n                    children,\n                };\n            } else if (isInternalNavSelectorEntryAGroup(entry)) {\n                const children = entry.children.flatMap(\n                    child => this.selectOnlyALeafInMultipleMode([child], entryUid) as InternalNavSelectorLeaf[]\n                );\n                const selected = children.every(child => child.selected || (isInternalNavSelectorEntryALeaf(child) && !child.selectable));\n                return {\n                    ...entry,\n                    children,\n                    selected,\n                    folded: computeFolded(entry, children),\n                    undeterminedSelection: !selected && children.some(child => child.selected),\n                };\n            }\n            return entry;\n        });\n    }\n\n    /**\n     * Select all entries in multiple mode.\n     *\n     * Categories are not selectable.\n     *\n     * Groups and leaves are selectable.\n     * @param entries nav selector entries\n     */\n    static selectAll(entries: InternalNavSelectorEntry[]): InternalNavSelectorEntry[] {\n        return this.selectChildren(entries);\n    }\n\n    /**\n     * Unselect all entries in multiple mode.\n     *\n     * Categories are not selectable.\n     *\n     * Groups and leaves are selectable.\n     * @param entries nav selector entries\n     */\n    static unselectAll(entries: InternalNavSelectorEntry[]): InternalNavSelectorEntry[] {\n        return this.unselectChildren(entries);\n    }\n\n    private static selectALeafInMultipleMode(leaf: InternalNavSelectorLeaf, entryUid: string): InternalNavSelectorLeaf {\n        let selected = false;\n        if (leaf.selectable) {\n            selected = leaf.uid === entryUid ? !leaf.selected : leaf.selected;\n        }\n        return {\n            ...leaf,\n            selected,\n        };\n    }\n\n    private static selectACategoryInMultipleMode(entry: InternalNavSelectorCategory, entryUid: string): InternalNavSelectorCategory {\n        const children = entry.children.map(child => {\n            if (isInternalNavSelectorEntryALeaf(child)) {\n                return this.selectALeafInMultipleMode(child, entryUid);\n            }\n            return this.selectAGroupInMultipleMode(child, entryUid);\n        });\n        return {\n            ...entry,\n            folded: computeFolded(entry, children),\n            children,\n        };\n    }\n\n    private static selectAGroupInMultipleMode(entry: InternalNavSelectorGroup, entryUid: string): InternalNavSelectorGroup {\n        if (!entry.selectable) {\n            return entry;\n        }\n        let selected: boolean;\n        let children: InternalNavSelectorLeaf[];\n        let undeterminedSelection = false;\n        if (entry.uid === entryUid) {\n            selected = !entry.selected;\n            if (selected) {\n                children = this.selectLeafs(entry.children);\n            } else {\n                children = this.unselectLeafs(entry.children);\n            }\n        } else {\n            children = entry.children.map(child => this.toggleSelectLeaf(child, entryUid));\n            selected = children.every(child => child.selected || (isInternalNavSelectorEntryALeaf(child) && !child.selectable));\n            undeterminedSelection = !selected && children.some(child => child.selected);\n        }\n\n        return {\n            ...entry,\n            folded: computeFolded(entry, children),\n            children,\n            selected,\n            undeterminedSelection,\n        };\n    }\n\n    private static toggleSelectLeaf(leaf: InternalNavSelectorLeaf, uid: string): InternalNavSelectorLeaf {\n        if (leaf.uid === uid) {\n            return {\n                ...leaf,\n                selected: !leaf.selected,\n            };\n        }\n        return leaf;\n    }\n\n    private static selectLeafs(leafs: InternalNavSelectorLeaf[]): InternalNavSelectorLeaf[] {\n        return leafs.map(leaf => ({\n            ...leaf,\n            selected: leaf.selectable,\n        }));\n    }\n\n    private static unselectLeafs(leafs: InternalNavSelectorLeaf[]): InternalNavSelectorLeaf[] {\n        return leafs.map(leaf => ({\n            ...leaf,\n            selected: false,\n        }));\n    }\n\n    private static unselectChildren<T extends InternalNavSelectorEntry>(entry: T[]): InternalNavSelectorEntry[] {\n        return entry.map(child => {\n            if (isInternalNavSelectorEntryALeaf(child)) {\n                return {\n                    ...child,\n                    selected: false,\n                };\n            } else if (isInternalNavSelectorEntryACategory(child)) {\n                return {\n                    ...child,\n                    children: this.unselectChildren(child.children),\n                };\n            } else if (isInternalNavSelectorEntryANode(child)) {\n                return {\n                    ...child,\n                    children: this.unselectChildren(child.children),\n                    selected: false,\n                };\n            }\n            return child;\n        });\n    }\n\n    private static selectChildren<T extends InternalNavSelectorEntry>(entry: T[]): InternalNavSelectorEntry[] {\n        return entry.map(child => {\n            if (isInternalNavSelectorEntryALeaf(child)) {\n                return {\n                    ...child,\n                    selected: child.selectable,\n                };\n            } else if (isInternalNavSelectorEntryACategory(child)) {\n                return {\n                    ...child,\n                    children: this.selectChildren(child.children),\n                };\n            } else if (isInternalNavSelectorEntryAGroup(child)) {\n                return {\n                    ...child,\n                    children: this.selectChildren(child.children),\n                    selected: true,\n                };\n            }\n            return child;\n        });\n    }\n}\n"]}
|
|
208
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector.multi-select.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/utils/nav-selector.multi-select.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    InternalNavSelectorCategory,\n    InternalNavSelectorEntry,\n    InternalNavSelectorGroup,\n    InternalNavSelectorLeaf,\n    isInternalNavSelectorEntryACategory,\n    isInternalNavSelectorEntryAGroup,\n    isInternalNavSelectorEntryALeaf,\n    isInternalNavSelectorEntryANode,\n} from '../nav-selector';\n\n/**\n * NavSelectorMultiSelect is a utility class that provides methods to select an entry in multiple mode.\n */\nexport class NavSelectorMultiSelect {\n    /**\n     * Select an entry in multiple mode.\n     *\n     * Categories are not selectable.\n     *\n     * Groups and leaves are selectable.\n     *\n     * Groups may be in undetermined state if some of their children are selected and some are not.\n     * @param entries nav selector entries\n     * @param entryUid the entry uid to select\n     */\n    static selectInMultipleMode(entries: InternalNavSelectorEntry[], entryUid: string): InternalNavSelectorEntry[] {\n        return entries.map(entry => {\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                return this.selectALeafInMultipleMode(entry, entryUid);\n            } else if (isInternalNavSelectorEntryAGroup(entry)) {\n                return this.selectAGroupInMultipleMode(entry, entryUid);\n            } else if (isInternalNavSelectorEntryACategory(entry)) {\n                return this.selectACategoryInMultipleMode(entry, entryUid);\n            }\n            return entry;\n        });\n    }\n\n    /**\n     * Select only a leaf in multiple mode.\n     *\n     * Categories are not selectable.\n     *\n     * Groups may be in undetermined state if some of their children are selected and some are not.\n     * @param entries nav selector entries\n     * @param entryUid the entry uid to select\n     */\n    static selectOnlyALeafInMultipleMode<T extends InternalNavSelectorEntry>(entries: T[], entryUid: string): InternalNavSelectorEntry[] {\n        return entries.map(entry => {\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                return {\n                    ...entry,\n                    selected: entry.uid === entryUid,\n                };\n            } else if (isInternalNavSelectorEntryACategory(entry)) {\n                return {\n                    ...entry,\n                    children: this.selectOnlyALeafInMultipleMode(entry.children, entryUid),\n                };\n            } else if (isInternalNavSelectorEntryAGroup(entry)) {\n                const children = entry.children.flatMap(\n                    child => this.selectOnlyALeafInMultipleMode([child], entryUid) as InternalNavSelectorLeaf[]\n                );\n                const selected = children.every(child => child.selected || (isInternalNavSelectorEntryALeaf(child) && !child.selectable));\n                return {\n                    ...entry,\n                    children,\n                    selected,\n                    undeterminedSelection: !selected && children.some(child => child.selected),\n                };\n            }\n            return entry;\n        });\n    }\n\n    /**\n     * Select all entries in multiple mode.\n     *\n     * Categories are not selectable.\n     *\n     * Groups and leaves are selectable.\n     * @param entries nav selector entries\n     */\n    static selectAll(entries: InternalNavSelectorEntry[]): InternalNavSelectorEntry[] {\n        return this.selectChildren(entries);\n    }\n\n    /**\n     * Unselect all entries in multiple mode.\n     *\n     * Categories are not selectable.\n     *\n     * Groups and leaves are selectable.\n     * @param entries nav selector entries\n     */\n    static unselectAll(entries: InternalNavSelectorEntry[]): InternalNavSelectorEntry[] {\n        return this.unselectChildren(entries);\n    }\n\n    private static selectALeafInMultipleMode(leaf: InternalNavSelectorLeaf, entryUid: string): InternalNavSelectorLeaf {\n        let selected = false;\n        if (leaf.selectable) {\n            selected = leaf.uid === entryUid ? !leaf.selected : leaf.selected;\n        }\n        return {\n            ...leaf,\n            selected,\n        };\n    }\n\n    private static selectACategoryInMultipleMode(entry: InternalNavSelectorCategory, entryUid: string): InternalNavSelectorCategory {\n        return {\n            ...entry,\n            children: entry.children.map(child => {\n                if (isInternalNavSelectorEntryALeaf(child)) {\n                    return this.selectALeafInMultipleMode(child, entryUid);\n                }\n                return this.selectAGroupInMultipleMode(child, entryUid);\n            }),\n        };\n    }\n\n    private static selectAGroupInMultipleMode(entry: InternalNavSelectorGroup, entryUid: string): InternalNavSelectorGroup {\n        if (!entry.selectable) {\n            return entry;\n        }\n        let selected: boolean;\n        let children: InternalNavSelectorLeaf[];\n        let undeterminedSelection = false;\n        if (entry.uid === entryUid) {\n            selected = !entry.selected;\n            if (selected) {\n                children = this.selectLeafs(entry.children);\n            } else {\n                children = this.unselectLeafs(entry.children);\n            }\n        } else {\n            children = entry.children.map(child => this.toggleSelectLeaf(child, entryUid));\n            selected = children.every(child => child.selected || (isInternalNavSelectorEntryALeaf(child) && !child.selectable));\n            undeterminedSelection = !selected && children.some(child => child.selected);\n        }\n\n        return {\n            ...entry,\n            children,\n            selected,\n            undeterminedSelection,\n        };\n    }\n\n    private static toggleSelectLeaf(leaf: InternalNavSelectorLeaf, uid: string): InternalNavSelectorLeaf {\n        if (leaf.uid === uid) {\n            return {\n                ...leaf,\n                selected: !leaf.selected,\n            };\n        }\n        return leaf;\n    }\n\n    private static selectLeafs(leafs: InternalNavSelectorLeaf[]): InternalNavSelectorLeaf[] {\n        return leafs.map(leaf => ({\n            ...leaf,\n            selected: leaf.selectable,\n        }));\n    }\n\n    private static unselectLeafs(leafs: InternalNavSelectorLeaf[]): InternalNavSelectorLeaf[] {\n        return leafs.map(leaf => ({\n            ...leaf,\n            selected: false,\n        }));\n    }\n\n    private static unselectChildren<T extends InternalNavSelectorEntry>(entry: T[]): InternalNavSelectorEntry[] {\n        return entry.map(child => {\n            if (isInternalNavSelectorEntryALeaf(child)) {\n                return {\n                    ...child,\n                    selected: false,\n                };\n            } else if (isInternalNavSelectorEntryACategory(child)) {\n                return {\n                    ...child,\n                    children: this.unselectChildren(child.children),\n                };\n            } else if (isInternalNavSelectorEntryANode(child)) {\n                return {\n                    ...child,\n                    children: this.unselectChildren(child.children),\n                    selected: false,\n                };\n            }\n            return child;\n        });\n    }\n\n    private static selectChildren<T extends InternalNavSelectorEntry>(entry: T[]): InternalNavSelectorEntry[] {\n        return entry.map(child => {\n            if (isInternalNavSelectorEntryALeaf(child)) {\n                return {\n                    ...child,\n                    selected: child.selectable,\n                };\n            } else if (isInternalNavSelectorEntryACategory(child)) {\n                return {\n                    ...child,\n                    children: this.selectChildren(child.children),\n                };\n            } else if (isInternalNavSelectorEntryAGroup(child)) {\n                return {\n                    ...child,\n                    children: this.selectChildren(child.children),\n                    selected: true,\n                };\n            }\n            return child;\n        });\n    }\n}\n"]}
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { isInternalNavSelectorEntryALeaf, isInternalNavSelectorEntryANode, } from '../nav-selector';
|
|
2
|
-
import { computeFolded } from './leaf.utils';
|
|
3
2
|
/**
|
|
4
3
|
* NavSelectorSingleSelect is a utility class that provides methods to select a single entry in a nav selector.
|
|
5
4
|
*/
|
|
@@ -15,14 +14,9 @@ export class NavSelectorSingleSelect {
|
|
|
15
14
|
return this.selectALeaf(entry, entryUid);
|
|
16
15
|
}
|
|
17
16
|
else if (isInternalNavSelectorEntryANode(entry)) {
|
|
18
|
-
const children = entry.children.flatMap(child => this.select([child], entryUid));
|
|
19
|
-
const folded = computeFolded(entry, children);
|
|
20
17
|
return {
|
|
21
18
|
...entry,
|
|
22
|
-
|
|
23
|
-
displayCounter: folded && entry.children.some(child => child.displayCounter),
|
|
24
|
-
displayTokenInvalid: folded && entry.children.some(child => child.displayTokenInvalid),
|
|
25
|
-
children,
|
|
19
|
+
children: entry.children.flatMap(child => this.select([child], entryUid)),
|
|
26
20
|
};
|
|
27
21
|
}
|
|
28
22
|
return entry;
|
|
@@ -116,4 +110,4 @@ export class NavSelectorSingleSelect {
|
|
|
116
110
|
};
|
|
117
111
|
}
|
|
118
112
|
}
|
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector.single-select.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/utils/nav-selector.single-select.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    InternalNavSelectorEntry,\n    InternalNavSelectorLeaf,\n    InternalNavSelectorLeafDetails,\n    isInternalNavSelectorEntryALeaf,\n    isInternalNavSelectorEntryANode,\n} from '../nav-selector';\nimport { computeFolded } from './leaf.utils';\n\n/**\n * NavSelectorSingleSelect is a utility class that provides methods to select a single entry in a nav selector.\n */\nexport class NavSelectorSingleSelect {\n    /**\n     * Selects a single entry in the nav selector.\n     * @param entries nav selector entries\n     * @param entryUid the entry uid to select\n     */\n    static select<T extends InternalNavSelectorEntry>(entries: T[], entryUid: string): InternalNavSelectorEntry[] {\n        return entries.map(entry => {\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                return this.selectALeaf(entry, entryUid);\n            } else if (isInternalNavSelectorEntryANode(entry)) {\n                const children = entry.children.flatMap(child => this.select([child], entryUid));\n                const folded = computeFolded(entry, children);\n                return {\n                    ...entry,\n                    folded,\n                    displayCounter: folded && entry.children.some(child => child.displayCounter),\n                    displayTokenInvalid: folded && entry.children.some(child => child.displayTokenInvalid),\n                    children,\n                };\n            }\n            return entry;\n        });\n    }\n\n    private static selectALeaf(leaf: InternalNavSelectorLeaf, entryUid: string): InternalNavSelectorLeaf {\n        if (!!leaf.details.length) {\n            return this.selectALeafWithDetails(leaf, entryUid);\n        }\n        return this.selectALeafWithoutDetails(leaf, entryUid);\n    }\n\n    private static selectALeafWithDetails(leaf: InternalNavSelectorLeaf, entryUid: string): InternalNavSelectorLeaf {\n        if (leaf.uid === entryUid) {\n            if (!leaf.detailsDisplayable) {\n                return this.selectALeafWitDetailsNotDisplayable(leaf);\n            }\n\n            return this.selectALeafWithDisplayableDetails(leaf);\n        }\n        const details = leaf.details.map(detail => {\n            const detailSelected = detail.uid === entryUid && !detail.displayError;\n            return {\n                ...detail,\n                selected: detailSelected,\n                accessibility: {\n                    ...detail.accessibility,\n                    tabIndex: detailSelected ? 0 : -1,\n                },\n            };\n        });\n\n        return {\n            ...leaf,\n            accessibility: {\n                ...leaf.accessibility,\n                tabIndex: -1,\n            },\n            selected: false,\n            folded: !leaf.folded ? false : details.every(detail => !detail.selected),\n            detailSelected: details.some(detail => detail.selected),\n            details,\n        };\n    }\n\n    private static selectALeafWitDetailsNotDisplayable(leaf: InternalNavSelectorLeaf): InternalNavSelectorLeaf {\n        const selected = leaf.selectable;\n        return {\n            ...leaf,\n            selected,\n            accessibility: {\n                ...leaf.accessibility,\n                tabIndex: selected ? 0 : -1,\n            },\n            folded: !leaf.detailsDisplayable,\n        };\n    }\n\n    private static selectALeafWithDisplayableDetails(leaf: InternalNavSelectorLeaf): InternalNavSelectorLeaf {\n        const details = leaf.details.reduce(\n            ({ previousDetailSelected, details }, detail, idx) => {\n                const detailSelected =\n                    !previousDetailSelected && leaf.detailsDisplayable && !detail.displayError && (idx === 0 || !details[idx - 1].selected);\n                details.push({\n                    ...detail,\n                    selected: detailSelected,\n                    focusable: true,\n                    accessibility: {\n                        ...detail.accessibility,\n                        tabIndex: detailSelected ? 0 : -1,\n                    },\n                });\n                return { previousDetailSelected: previousDetailSelected || detailSelected, details };\n            },\n            { previousDetailSelected: false, details: [] as InternalNavSelectorLeafDetails[] }\n        ).details;\n        return {\n            ...leaf,\n            selected: false,\n            accessibility: {\n                ...leaf.accessibility,\n                tabIndex: -1,\n            },\n            displayCounter: false,\n            folded: !leaf.detailsDisplayable,\n            detailSelected: details.some(detail => detail.selected),\n            details,\n        };\n    }\n\n    private static selectALeafWithoutDetails(leaf: InternalNavSelectorLeaf, entryUid: string): InternalNavSelectorLeaf {\n        const selected = leaf.selectable && leaf.uid === entryUid;\n        return {\n            ...leaf,\n            selected,\n            accessibility: {\n                ...leaf.accessibility,\n                tabIndex: selected ? 0 : -1,\n            },\n            folded: true,\n        };\n    }\n}\n"]}
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav-selector.single-select.js","sourceRoot":"","sources":["../../../../../libs/ui-components/nav-selector/src/utils/nav-selector.single-select.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    InternalNavSelectorEntry,\n    InternalNavSelectorLeaf,\n    InternalNavSelectorLeafDetails,\n    isInternalNavSelectorEntryALeaf,\n    isInternalNavSelectorEntryANode,\n} from '../nav-selector';\n\n/**\n * NavSelectorSingleSelect is a utility class that provides methods to select a single entry in a nav selector.\n */\nexport class NavSelectorSingleSelect {\n    /**\n     * Selects a single entry in the nav selector.\n     * @param entries nav selector entries\n     * @param entryUid the entry uid to select\n     */\n    static select<T extends InternalNavSelectorEntry>(entries: T[], entryUid: string): InternalNavSelectorEntry[] {\n        return entries.map(entry => {\n            if (isInternalNavSelectorEntryALeaf(entry)) {\n                return this.selectALeaf(entry, entryUid);\n            } else if (isInternalNavSelectorEntryANode(entry)) {\n                return {\n                    ...entry,\n                    children: entry.children.flatMap(child => this.select([child], entryUid)),\n                };\n            }\n            return entry;\n        });\n    }\n\n    private static selectALeaf(leaf: InternalNavSelectorLeaf, entryUid: string): InternalNavSelectorLeaf {\n        if (!!leaf.details.length) {\n            return this.selectALeafWithDetails(leaf, entryUid);\n        }\n        return this.selectALeafWithoutDetails(leaf, entryUid);\n    }\n\n    private static selectALeafWithDetails(leaf: InternalNavSelectorLeaf, entryUid: string): InternalNavSelectorLeaf {\n        if (leaf.uid === entryUid) {\n            if (!leaf.detailsDisplayable) {\n                return this.selectALeafWitDetailsNotDisplayable(leaf);\n            }\n\n            return this.selectALeafWithDisplayableDetails(leaf);\n        }\n        const details = leaf.details.map(detail => {\n            const detailSelected = detail.uid === entryUid && !detail.displayError;\n            return {\n                ...detail,\n                selected: detailSelected,\n                accessibility: {\n                    ...detail.accessibility,\n                    tabIndex: detailSelected ? 0 : -1,\n                },\n            };\n        });\n\n        return {\n            ...leaf,\n            accessibility: {\n                ...leaf.accessibility,\n                tabIndex: -1,\n            },\n            selected: false,\n            folded: !leaf.folded ? false : details.every(detail => !detail.selected),\n            detailSelected: details.some(detail => detail.selected),\n            details,\n        };\n    }\n\n    private static selectALeafWitDetailsNotDisplayable(leaf: InternalNavSelectorLeaf): InternalNavSelectorLeaf {\n        const selected = leaf.selectable;\n        return {\n            ...leaf,\n            selected,\n            accessibility: {\n                ...leaf.accessibility,\n                tabIndex: selected ? 0 : -1,\n            },\n            folded: !leaf.detailsDisplayable,\n        };\n    }\n\n    private static selectALeafWithDisplayableDetails(leaf: InternalNavSelectorLeaf): InternalNavSelectorLeaf {\n        const details = leaf.details.reduce(\n            ({ previousDetailSelected, details }, detail, idx) => {\n                const detailSelected =\n                    !previousDetailSelected && leaf.detailsDisplayable && !detail.displayError && (idx === 0 || !details[idx - 1].selected);\n                details.push({\n                    ...detail,\n                    selected: detailSelected,\n                    focusable: true,\n                    accessibility: {\n                        ...detail.accessibility,\n                        tabIndex: detailSelected ? 0 : -1,\n                    },\n                });\n                return { previousDetailSelected: previousDetailSelected || detailSelected, details };\n            },\n            { previousDetailSelected: false, details: [] as InternalNavSelectorLeafDetails[] }\n        ).details;\n        return {\n            ...leaf,\n            selected: false,\n            accessibility: {\n                ...leaf.accessibility,\n                tabIndex: -1,\n            },\n            displayCounter: false,\n            folded: !leaf.detailsDisplayable,\n            detailSelected: details.some(detail => detail.selected),\n            details,\n        };\n    }\n\n    private static selectALeafWithoutDetails(leaf: InternalNavSelectorLeaf, entryUid: string): InternalNavSelectorLeaf {\n        const selected = leaf.selectable && leaf.uid === entryUid;\n        return {\n            ...leaf,\n            selected,\n            accessibility: {\n                ...leaf.accessibility,\n                tabIndex: selected ? 0 : -1,\n            },\n            folded: true,\n        };\n    }\n}\n"]}
|
|
@@ -666,6 +666,8 @@ class NavSelectorFolding {
|
|
|
666
666
|
...entry,
|
|
667
667
|
children: result.entries,
|
|
668
668
|
folded: false,
|
|
669
|
+
displayCounter: false,
|
|
670
|
+
displayTokenInvalid: false,
|
|
669
671
|
focusable: true,
|
|
670
672
|
};
|
|
671
673
|
}
|
|
@@ -730,11 +732,9 @@ class NavSelectorMultiSelect {
|
|
|
730
732
|
};
|
|
731
733
|
}
|
|
732
734
|
else if (isInternalNavSelectorEntryACategory(entry)) {
|
|
733
|
-
const children = this.selectOnlyALeafInMultipleMode(entry.children, entryUid);
|
|
734
735
|
return {
|
|
735
736
|
...entry,
|
|
736
|
-
|
|
737
|
-
children,
|
|
737
|
+
children: this.selectOnlyALeafInMultipleMode(entry.children, entryUid),
|
|
738
738
|
};
|
|
739
739
|
}
|
|
740
740
|
else if (isInternalNavSelectorEntryAGroup(entry)) {
|
|
@@ -744,7 +744,6 @@ class NavSelectorMultiSelect {
|
|
|
744
744
|
...entry,
|
|
745
745
|
children,
|
|
746
746
|
selected,
|
|
747
|
-
folded: computeFolded(entry, children),
|
|
748
747
|
undeterminedSelection: !selected && children.some(child => child.selected),
|
|
749
748
|
};
|
|
750
749
|
}
|
|
@@ -784,16 +783,14 @@ class NavSelectorMultiSelect {
|
|
|
784
783
|
};
|
|
785
784
|
}
|
|
786
785
|
static selectACategoryInMultipleMode(entry, entryUid) {
|
|
787
|
-
const children = entry.children.map(child => {
|
|
788
|
-
if (isInternalNavSelectorEntryALeaf(child)) {
|
|
789
|
-
return this.selectALeafInMultipleMode(child, entryUid);
|
|
790
|
-
}
|
|
791
|
-
return this.selectAGroupInMultipleMode(child, entryUid);
|
|
792
|
-
});
|
|
793
786
|
return {
|
|
794
787
|
...entry,
|
|
795
|
-
|
|
796
|
-
|
|
788
|
+
children: entry.children.map(child => {
|
|
789
|
+
if (isInternalNavSelectorEntryALeaf(child)) {
|
|
790
|
+
return this.selectALeafInMultipleMode(child, entryUid);
|
|
791
|
+
}
|
|
792
|
+
return this.selectAGroupInMultipleMode(child, entryUid);
|
|
793
|
+
}),
|
|
797
794
|
};
|
|
798
795
|
}
|
|
799
796
|
static selectAGroupInMultipleMode(entry, entryUid) {
|
|
@@ -819,7 +816,6 @@ class NavSelectorMultiSelect {
|
|
|
819
816
|
}
|
|
820
817
|
return {
|
|
821
818
|
...entry,
|
|
822
|
-
folded: computeFolded(entry, children),
|
|
823
819
|
children,
|
|
824
820
|
selected,
|
|
825
821
|
undeterminedSelection,
|
|
@@ -911,14 +907,9 @@ class NavSelectorSingleSelect {
|
|
|
911
907
|
return this.selectALeaf(entry, entryUid);
|
|
912
908
|
}
|
|
913
909
|
else if (isInternalNavSelectorEntryANode(entry)) {
|
|
914
|
-
const children = entry.children.flatMap(child => this.select([child], entryUid));
|
|
915
|
-
const folded = computeFolded(entry, children);
|
|
916
910
|
return {
|
|
917
911
|
...entry,
|
|
918
|
-
|
|
919
|
-
displayCounter: folded && entry.children.some(child => child.displayCounter),
|
|
920
|
-
displayTokenInvalid: folded && entry.children.some(child => child.displayTokenInvalid),
|
|
921
|
-
children,
|
|
912
|
+
children: entry.children.flatMap(child => this.select([child], entryUid)),
|
|
922
913
|
};
|
|
923
914
|
}
|
|
924
915
|
return entry;
|
|
@@ -1664,7 +1655,6 @@ class NavSelectorState {
|
|
|
1664
1655
|
viewMore: '',
|
|
1665
1656
|
viewLess: '',
|
|
1666
1657
|
});
|
|
1667
|
-
lastSelectedUids = signal([]);
|
|
1668
1658
|
isMultipleModeEnabled = this.multipleModeEnabled;
|
|
1669
1659
|
search = signal('');
|
|
1670
1660
|
noResults = computed(() => this.entries().every(({ hidden }) => hidden));
|
|
@@ -1766,10 +1756,9 @@ class NavSelectorState {
|
|
|
1766
1756
|
}
|
|
1767
1757
|
onSelectionChange(uids) {
|
|
1768
1758
|
// Avoid infinite loop if you put unexisting uids as select will generate the same entries but with different reference
|
|
1769
|
-
if (JSON.stringify(uids) === JSON.stringify(this.
|
|
1759
|
+
if (JSON.stringify(uids) === JSON.stringify(this.previousSelectedUids)) {
|
|
1770
1760
|
return;
|
|
1771
1761
|
}
|
|
1772
|
-
this.lastSelectedUids.set(uids);
|
|
1773
1762
|
const selectedUids = this.collectSelectedUids(this.entries());
|
|
1774
1763
|
const uidToSelect = uids.filter(uid => selectedUids.every(selectedUid => selectedUid !== uid));
|
|
1775
1764
|
const uidToUnselect = selectedUids.filter(uid => uids.every(selectedUid => selectedUid !== uid));
|
|
@@ -1781,9 +1770,13 @@ class NavSelectorState {
|
|
|
1781
1770
|
for (const uid of [...uidToSelect, ...uidToUnselect]) {
|
|
1782
1771
|
entries = NavSelectorMultiSelect.selectInMultipleMode(entries, uid);
|
|
1783
1772
|
}
|
|
1773
|
+
for (const uid of uidToSelect) {
|
|
1774
|
+
entries = NavSelectorFolding.unfoldParents(entries, uid, { multipleMode: true, minified: !this.expanded() });
|
|
1775
|
+
}
|
|
1784
1776
|
}
|
|
1785
1777
|
else {
|
|
1786
1778
|
entries = NavSelectorSingleSelect.select(entries, uids[0]);
|
|
1779
|
+
entries = NavSelectorFolding.unfoldParents(entries, uids[0], { multipleMode: false, minified: !this.expanded() });
|
|
1787
1780
|
}
|
|
1788
1781
|
this.entries.set(entries);
|
|
1789
1782
|
}
|
|
@@ -2744,6 +2737,7 @@ class NavSelectorComponent {
|
|
|
2744
2737
|
selectedEntryUids = model.required();
|
|
2745
2738
|
actionClicked = output();
|
|
2746
2739
|
headerProjection = contentChild('header');
|
|
2740
|
+
contentHeaderProjection = contentChild('contentHeader');
|
|
2747
2741
|
footerProjection = contentChild('footer');
|
|
2748
2742
|
displayFooter = computed(() => this.footerProjection() !== undefined);
|
|
2749
2743
|
expansionState = computed(() => (this.navSelectorState.expanded() ? 'expanded' : 'minified'));
|
|
@@ -2874,7 +2868,7 @@ class NavSelectorComponent {
|
|
|
2874
2868
|
}
|
|
2875
2869
|
}
|
|
2876
2870
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: NavSelectorComponent, deps: [{ token: NavSelectorState }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
2877
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.9", type: NavSelectorComponent, isStandalone: true, selector: "ap-nav-selector", inputs: { navSelectorEntries: { classPropertyName: "navSelectorEntries", publicName: "navSelectorEntries", isSignal: true, isRequired: true, transformFunction: null }, translatedTexts: { classPropertyName: "translatedTexts", publicName: "translatedTexts", isSignal: true, isRequired: true, transformFunction: null }, multipleModeEnabled: { classPropertyName: "multipleModeEnabled", publicName: "multipleModeEnabled", isSignal: true, isRequired: false, transformFunction: null }, detailsDisplayedLimit: { classPropertyName: "detailsDisplayedLimit", publicName: "detailsDisplayedLimit", isSignal: true, isRequired: false, transformFunction: null }, embedded: { classPropertyName: "embedded", publicName: "embedded", isSignal: true, isRequired: false, transformFunction: null }, forceExpanded: { classPropertyName: "forceExpanded", publicName: "forceExpanded", isSignal: true, isRequired: false, transformFunction: null }, expandedStateLocalStorageKey: { classPropertyName: "expandedStateLocalStorageKey", publicName: "expandedStateLocalStorageKey", isSignal: true, isRequired: false, transformFunction: null }, selectedEntryUids: { classPropertyName: "selectedEntryUids", publicName: "selectedEntryUids", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { selectedEntryUids: "selectedEntryUidsChange", actionClicked: "actionClicked", onExpansionStateChange: "onExpansionStateChange" }, host: { attributes: { "role": "tree" }, listeners: { "keydown.arrowDown": "onArrowDown($event)", "keydown.arrowUp": "onArrowUp($event)", "window:resize": "onWindowResize()" }, properties: { "class.minified": "!navSelectorState.expanded()", "class.embedded": "embedded()", "@expand": "expansionState()" } }, providers: [NavSelectorState, withSymbols(apArrowExpand, apArrowReduce, apSearch)], queries: [{ propertyName: "headerProjection", first: true, predicate: ["header"], descendants: true, isSignal: true }, { propertyName: "footerProjection", first: true, predicate: ["footer"], descendants: true, isSignal: true }], ngImport: i0, template: "<nav\n [class.embedded]=\"embedded()\">\n @let headerProjectionNotNull = headerProjection();\n @let footerProjectionNotNull = footerProjection();\n\n <div class=\"nav-selector__header\">\n @if (!embedded()) {\n @if (navSelectorState.expanded()) {\n <span class=\"h3\">{{ translatedTexts().title }}</span>\n }\n\n <button\n type=\"button\"\n class=\"expand-button\"\n [class.expanded]=\"navSelectorState.expanded()\"\n (click)=\"clickExpandButton()\">\n <ap-symbol\n size=\"sm\"\n [symbolId]=\"navSelectorState.expanded() ? 'arrow-reduce' : 'arrow-expand'\" />\n </button>\n }\n\n @if (headerProjectionNotNull) {\n <ng-container\n [ngTemplateOutlet]=\"headerProjectionNotNull\"\n [ngTemplateOutletContext]=\"{\n expanded: navSelectorState.expanded()\n }\" />\n }\n\n @if (navSelectorState.expanded()) {\n <ap-input-search\n [id]=\"componentUid + '_search'\"\n [placeholder]=\"translatedTexts().searchPlaceholder\"\n [ngModel]=\"navSelectorState.search()\"\n (ngModelChange)=\"navSelectorState.search.set($event ?? '')\" />\n } @else {\n <ap-icon-button\n (onClick)=\"onMinifiedSearchClicked()\"\n type=\"stroked\"\n role=\"search\">\n <ap-symbol symbolId=\"search\" />\n </ap-icon-button>\n }\n </div>\n\n <div\n class=\"nav-selector__content\"\n [attr.aria-multiselectable]=\"navSelectorState.isMultipleModeEnabled()\"\n role=\"tree\">\n @for (entry of navSelectorState.entries(); track entry.uid) {\n @if (!entry.hidden) {\n <div\n class=\"entry\"\n [class.folder]=\"entry.type === 'GROUP' || entry.type === 'CATEGORY'\">\n @if (entry.type === 'LEAF') {\n <ap-nav-selector-leaf\n [leaf]=\"entry\"\n (actionClicked)=\"actionClicked.emit($event)\" />\n } @else if (entry.type === 'GROUP') {\n <ap-nav-selector-group\n [group]=\"entry\"\n (actionClicked)=\"actionClicked.emit($event)\" />\n } @else if (entry.type === 'CATEGORY') {\n <ap-nav-selector-category\n [category]=\"$any(entry)\"\n (actionClicked)=\"actionClicked.emit($event)\" />\n }\n </div>\n }\n }\n @if (navSelectorState.expanded() && navSelectorState.noResults()) {\n <div class=\"no-result\">{{ translatedTexts().noResults }}</div>\n }\n </div>\n\n @if (displayFooter() && footerProjectionNotNull) {\n <div class=\"nav-selector__footer\">\n <ng-container\n [ngTemplateOutlet]=\"footerProjectionNotNull\"\n [ngTemplateOutletContext]=\"{\n expanded: navSelectorState.expanded()\n }\" />\n </div>\n }\n</nav>\n", styles: [":host,nav{width:224px}@media only screen and (min-width: 1400px){:host:not(.embedded),nav:not(.embedded){width:250px}:host:not(.embedded) .nav-selector__content,nav:not(.embedded) .nav-selector__content{width:250px}}:host{display:flex;flex-direction:column;align-items:flex-start;flex-shrink:0;flex-grow:1}:host :hover .expand-button.expanded{animation-name:translateExpandButton}:host nav{display:flex;height:100%;flex-grow:1;flex-direction:column;align-items:flex-start;flex-shrink:0;overflow:hidden;background:var(--ref-color-white);transition:width .25s cubic-bezier(.4,0,.3,1)}:host nav:not(.embedded){border-right:1px solid var(--ref-color-grey-10)}:host .nav-selector__header{position:relative;display:flex;padding:var(--ref-spacing-xs) var(--ref-spacing-sm);flex-direction:column;align-items:flex-start;gap:var(--ref-spacing-xxs);align-self:stretch;white-space:nowrap;border-bottom:1px solid var(--ref-color-grey-10);background:var(--ref-color-white)}:host .nav-selector__header .h3{color:var(--ref-color-grey-100);font-family:Averta;font-size:var(--sys-text-style-h3-size);font-style:normal;font-weight:var(--ref-font-weight-bold);line-height:var(--ref-font-line-height-lg)}:host .nav-selector__header .expand-button-container{position:absolute;right:0;top:var(--ref-spacing-xs)}:host .nav-selector__header .expand-button{animation-duration:70ms;animation-timing-function:cubic-bezier(0,0,.2,1);animation-fill-mode:forwards;animation-name:translateHideButton;display:flex;width:24px;height:24px;justify-content:center;align-items:center;background:var(--ref-color-grey-bg);border-top:1px solid var(--ref-color-grey-20);border-right:none;border-bottom:1px solid var(--ref-color-grey-20);border-left:1px solid var(--ref-color-grey-20);border-top-left-radius:var(--ref-border-radius-sm);border-bottom-left-radius:var(--ref-border-radius-sm);cursor:pointer}@keyframes translateHideButton{0%{transform:translate(0)}to{transform:translate(100%)}}@keyframes translateExpandButton{0%{transform:translate(100%)}to{transform:translate(0)}}:host .nav-selector__header .expand-button.expanded{position:absolute;right:0;top:12px;transform:translate(100%)}:host .nav-selector__header .expand-button ap-symbol[symbol-id=arrow-reduce],:host .nav-selector__header .expand-button ap-symbol[symbol-id=arrow-expand]{color:var(--ref-color-grey-80)}:host .nav-selector__header .expand-button:focus-visible{border-radius:var(--ref-border-radius-sm) 0px 0px var(--ref-border-radius-sm);border-top:1px solid var(--ref-color-grey-20);border-bottom:1px solid var(--ref-color-grey-20);border-left:1px solid var(--ref-color-grey-20);background:var(--ref-color-grey-10);box-shadow:0 0 0 1px #fff,0 0 0 3px #178dfe}:host .nav-selector__header .expand-button:focus-visible.expanded{animation-name:translateExpandButton}:host .nav-selector__header .expand-button:hover{background-color:var(--ref-color-grey-10)}:host .nav-selector__header .expand-button:active{background-color:var(--ref-color-grey-20)}:host .nav-selector__content{display:flex;flex-direction:column;align-items:flex-start;flex:1 0 0;align-self:stretch;width:224px;overflow-y:scroll;overflow-x:hidden;transition:width .25s cubic-bezier(.4,0,.3,1)}:host .nav-selector__content .entry{align-self:stretch;display:flex;flex-direction:column}:host .nav-selector__content .entry.folder{padding:var(--ref-spacing-xxs);border-bottom:1px solid var(--sys-border-color-default)}:host .nav-selector__content .entry.folder+.entry:not(.folder){padding-top:var(--ref-spacing-xxs)}:host .nav-selector__content .entry:not(.folder){padding-left:var(--ref-spacing-xxs);padding-right:var(--ref-spacing-xxs)}:host .nav-selector__content .entry:not(.folder):first-child{padding-top:var(--ref-spacing-xxs)}:host .nav-selector__content .entry:not(.folder):last-child{padding-bottom:var(--ref-spacing-xxs)}:host .nav-selector__content .entry:not(.folder):has(+.entry.folder){padding-bottom:var(--ref-spacing-xxs)}:host .nav-selector__content .entry:not(.folder)+.entry.folder{border-top:1px solid var(--sys-border-color-default)}:host .nav-selector__content .no-result{display:flex;padding:var(--ref-spacing-sm);flex-direction:column;align-items:flex-start;flex:1 0 0;align-self:stretch;color:var(--ref-color-grey-80);font-family:Averta;font-size:var(--ref-font-size-sm);font-style:italic;font-weight:400;line-height:var(--ref-font-line-height-sm)}:host .nav-selector__footer{display:flex;padding:var(--ref-spacing-xs);flex-direction:column;align-items:flex-start;gap:var(--ref-spacing-xxs);align-self:stretch;border-top:1px solid var(--sys-border-color-default);background:var(--ref-color-white)}:host.minified{width:64px}:host.minified nav{width:64px}:host.minified nav .nav-selector__header{align-items:center}:host.minified nav .nav-selector__header .expand-button{animation-name:none;border-radius:var(--ref-border-radius-sm);border:1px solid var(--ref-color-grey-20);background:var(--ref-color-grey-bg)}:host.minified nav .nav-selector__content{width:64px}:host.minified nav .nav-selector__content .entry{padding:var(--ref-spacing-xxxs)}:host.minified nav .nav-selector__footer{padding:var(--ref-spacing-xs) var(--ref-spacing-xxxs)}\n"], dependencies: [{ kind: "component", type: NavSelectorLeafComponent, selector: "ap-nav-selector-leaf", inputs: ["leaf"], outputs: ["actionClicked"] }, { kind: "component", type: NavSelectorGroupComponent, selector: "ap-nav-selector-group", inputs: ["group"], outputs: ["actionClicked"] }, { kind: "component", type: NavSelectorCategoryComponent, selector: "ap-nav-selector-category", inputs: ["category"], outputs: ["actionClicked"] }, { kind: "component", type: InputSearchComponent, selector: "ap-input-search", inputs: ["id", "placeholder", "clearable"], outputs: ["focus", "blur", "keyup"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: SymbolComponent, selector: "ap-symbol", inputs: ["symbolId", "color", "size"], outputs: ["sizeChange"] }, { kind: "component", type: IconButtonComponent, selector: "ap-icon-button", inputs: ["ariaLabel", "name", "color", "disabled", "menuTrigger", "symbolId", "locked", "loading", "type"], outputs: ["onClick", "onFocus", "onBlur", "menuOpened", "menuClosed"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], animations: [
|
|
2871
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.9", type: NavSelectorComponent, isStandalone: true, selector: "ap-nav-selector", inputs: { navSelectorEntries: { classPropertyName: "navSelectorEntries", publicName: "navSelectorEntries", isSignal: true, isRequired: true, transformFunction: null }, translatedTexts: { classPropertyName: "translatedTexts", publicName: "translatedTexts", isSignal: true, isRequired: true, transformFunction: null }, multipleModeEnabled: { classPropertyName: "multipleModeEnabled", publicName: "multipleModeEnabled", isSignal: true, isRequired: false, transformFunction: null }, detailsDisplayedLimit: { classPropertyName: "detailsDisplayedLimit", publicName: "detailsDisplayedLimit", isSignal: true, isRequired: false, transformFunction: null }, embedded: { classPropertyName: "embedded", publicName: "embedded", isSignal: true, isRequired: false, transformFunction: null }, forceExpanded: { classPropertyName: "forceExpanded", publicName: "forceExpanded", isSignal: true, isRequired: false, transformFunction: null }, expandedStateLocalStorageKey: { classPropertyName: "expandedStateLocalStorageKey", publicName: "expandedStateLocalStorageKey", isSignal: true, isRequired: false, transformFunction: null }, selectedEntryUids: { classPropertyName: "selectedEntryUids", publicName: "selectedEntryUids", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { selectedEntryUids: "selectedEntryUidsChange", actionClicked: "actionClicked", onExpansionStateChange: "onExpansionStateChange" }, host: { attributes: { "role": "tree" }, listeners: { "keydown.arrowDown": "onArrowDown($event)", "keydown.arrowUp": "onArrowUp($event)", "window:resize": "onWindowResize()" }, properties: { "class.minified": "!navSelectorState.expanded()", "class.embedded": "embedded()", "@expand": "expansionState()" } }, providers: [NavSelectorState, withSymbols(apArrowExpand, apArrowReduce, apSearch)], queries: [{ propertyName: "headerProjection", first: true, predicate: ["header"], descendants: true, isSignal: true }, { propertyName: "contentHeaderProjection", first: true, predicate: ["contentHeader"], descendants: true, isSignal: true }, { propertyName: "footerProjection", first: true, predicate: ["footer"], descendants: true, isSignal: true }], ngImport: i0, template: "<nav [class.embedded]=\"embedded()\">\n @let headerProjectionNotNull = headerProjection();\n @let contentHeaderProjectionNotNull = contentHeaderProjection();\n @let footerProjectionNotNull = footerProjection();\n\n <div class=\"nav-selector__header\">\n @if (!embedded()) {\n @if (navSelectorState.expanded()) {\n <span class=\"h3\">{{ translatedTexts().title }}</span>\n }\n\n <button\n type=\"button\"\n class=\"expand-button\"\n [class.expanded]=\"navSelectorState.expanded()\"\n (click)=\"clickExpandButton()\">\n <ap-symbol\n size=\"sm\"\n [symbolId]=\"navSelectorState.expanded() ? 'arrow-reduce' : 'arrow-expand'\" />\n </button>\n }\n\n @if (headerProjectionNotNull) {\n <ng-container\n [ngTemplateOutlet]=\"headerProjectionNotNull\"\n [ngTemplateOutletContext]=\"{\n expanded: navSelectorState.expanded(),\n }\" />\n }\n\n @if (navSelectorState.expanded()) {\n <ap-input-search\n [id]=\"componentUid + '_search'\"\n [placeholder]=\"translatedTexts().searchPlaceholder\"\n [ngModel]=\"navSelectorState.search()\"\n (ngModelChange)=\"navSelectorState.search.set($event ?? '')\" />\n } @else {\n <ap-icon-button\n (onClick)=\"onMinifiedSearchClicked()\"\n type=\"stroked\"\n role=\"search\">\n <ap-symbol symbolId=\"search\" />\n </ap-icon-button>\n }\n </div>\n\n <div\n class=\"nav-selector__content\"\n [attr.aria-multiselectable]=\"navSelectorState.isMultipleModeEnabled()\"\n role=\"tree\">\n @if (contentHeaderProjectionNotNull) {\n <ng-container\n [ngTemplateOutlet]=\"contentHeaderProjectionNotNull\"\n [ngTemplateOutletContext]=\"{\n expanded: navSelectorState.expanded(),\n }\" />\n }\n\n @for (entry of navSelectorState.entries(); track entry.uid) {\n @if (!entry.hidden) {\n <div\n class=\"entry\"\n [class.folder]=\"entry.type === 'GROUP' || entry.type === 'CATEGORY'\">\n @if (entry.type === 'LEAF') {\n <ap-nav-selector-leaf\n [leaf]=\"entry\"\n (actionClicked)=\"actionClicked.emit($event)\" />\n } @else if (entry.type === 'GROUP') {\n <ap-nav-selector-group\n [group]=\"entry\"\n (actionClicked)=\"actionClicked.emit($event)\" />\n } @else if (entry.type === 'CATEGORY') {\n <ap-nav-selector-category\n [category]=\"$any(entry)\"\n (actionClicked)=\"actionClicked.emit($event)\" />\n }\n </div>\n }\n }\n @if (navSelectorState.expanded() && navSelectorState.noResults()) {\n <div class=\"no-result\">{{ translatedTexts().noResults }}</div>\n }\n </div>\n\n @if (displayFooter() && footerProjectionNotNull) {\n <div class=\"nav-selector__footer\">\n <ng-container\n [ngTemplateOutlet]=\"footerProjectionNotNull\"\n [ngTemplateOutletContext]=\"{\n expanded: navSelectorState.expanded(),\n }\" />\n </div>\n }\n</nav>\n", styles: [":host,nav{width:224px}@media only screen and (min-width: 1400px){:host:not(.embedded),nav:not(.embedded){width:250px}:host:not(.embedded) .nav-selector__content,nav:not(.embedded) .nav-selector__content{width:250px}}:host{display:flex;flex-direction:column;align-items:flex-start;flex-shrink:0;flex-grow:1}:host :hover .expand-button.expanded{animation-name:translateExpandButton}:host nav{display:flex;height:100%;flex-grow:1;flex-direction:column;align-items:flex-start;flex-shrink:0;overflow:hidden;background:var(--ref-color-white);transition:width .25s cubic-bezier(.4,0,.3,1)}:host nav:not(.embedded){border-right:1px solid var(--ref-color-grey-10)}:host .nav-selector__header{position:relative;display:flex;padding:var(--ref-spacing-xs) var(--ref-spacing-sm);flex-direction:column;align-items:flex-start;gap:var(--ref-spacing-xxs);align-self:stretch;white-space:nowrap;border-bottom:1px solid var(--ref-color-grey-10);background:var(--ref-color-white)}:host .nav-selector__header .h3{color:var(--ref-color-grey-100);font-family:Averta;font-size:var(--sys-text-style-h3-size);font-style:normal;font-weight:var(--ref-font-weight-bold);line-height:var(--ref-font-line-height-lg)}:host .nav-selector__header .expand-button-container{position:absolute;right:0;top:var(--ref-spacing-xs)}:host .nav-selector__header .expand-button{animation-duration:70ms;animation-timing-function:cubic-bezier(0,0,.2,1);animation-fill-mode:forwards;animation-name:translateHideButton;display:flex;width:24px;height:24px;justify-content:center;align-items:center;background:var(--ref-color-grey-bg);border-top:1px solid var(--ref-color-grey-20);border-right:none;border-bottom:1px solid var(--ref-color-grey-20);border-left:1px solid var(--ref-color-grey-20);border-top-left-radius:var(--ref-border-radius-sm);border-bottom-left-radius:var(--ref-border-radius-sm);cursor:pointer}@keyframes translateHideButton{0%{transform:translate(0)}to{transform:translate(100%)}}@keyframes translateExpandButton{0%{transform:translate(100%)}to{transform:translate(0)}}:host .nav-selector__header .expand-button.expanded{position:absolute;right:0;top:12px;transform:translate(100%)}:host .nav-selector__header .expand-button ap-symbol[symbol-id=arrow-reduce],:host .nav-selector__header .expand-button ap-symbol[symbol-id=arrow-expand]{color:var(--ref-color-grey-80)}:host .nav-selector__header .expand-button:focus-visible{border-radius:var(--ref-border-radius-sm) 0px 0px var(--ref-border-radius-sm);border-top:1px solid var(--ref-color-grey-20);border-bottom:1px solid var(--ref-color-grey-20);border-left:1px solid var(--ref-color-grey-20);background:var(--ref-color-grey-10);box-shadow:0 0 0 1px #fff,0 0 0 3px #178dfe}:host .nav-selector__header .expand-button:focus-visible.expanded{animation-name:translateExpandButton}:host .nav-selector__header .expand-button:hover{background-color:var(--ref-color-grey-10)}:host .nav-selector__header .expand-button:active{background-color:var(--ref-color-grey-20)}:host .nav-selector__content{display:flex;flex-direction:column;align-items:flex-start;flex:1 0 0;align-self:stretch;width:224px;overflow-y:scroll;overflow-x:hidden;transition:width .25s cubic-bezier(.4,0,.3,1)}:host .nav-selector__content .entry{align-self:stretch;display:flex;flex-direction:column}:host .nav-selector__content .entry.folder{padding:var(--ref-spacing-xxs);border-bottom:1px solid var(--sys-border-color-default)}:host .nav-selector__content .entry.folder+.entry:not(.folder){padding-top:var(--ref-spacing-xxs)}:host .nav-selector__content .entry:not(.folder){padding-left:var(--ref-spacing-xxs);padding-right:var(--ref-spacing-xxs)}:host .nav-selector__content .entry:not(.folder):first-child{padding-top:var(--ref-spacing-xxs)}:host .nav-selector__content .entry:not(.folder):last-child{padding-bottom:var(--ref-spacing-xxs)}:host .nav-selector__content .entry:not(.folder):has(+.entry.folder){padding-bottom:var(--ref-spacing-xxs)}:host .nav-selector__content .entry:not(.folder)+.entry.folder{border-top:1px solid var(--sys-border-color-default)}:host .nav-selector__content .no-result{display:flex;padding:var(--ref-spacing-sm);flex-direction:column;align-items:flex-start;flex:1 0 0;align-self:stretch;color:var(--ref-color-grey-80);font-family:Averta;font-size:var(--ref-font-size-sm);font-style:italic;font-weight:400;line-height:var(--ref-font-line-height-sm)}:host .nav-selector__footer{display:flex;padding:var(--ref-spacing-xs);flex-direction:column;align-items:flex-start;gap:var(--ref-spacing-xxs);align-self:stretch;border-top:1px solid var(--sys-border-color-default);background:var(--ref-color-white)}:host.minified{width:64px}:host.minified nav{width:64px}:host.minified nav .nav-selector__header{align-items:center}:host.minified nav .nav-selector__header .expand-button{animation-name:none;border-radius:var(--ref-border-radius-sm);border:1px solid var(--ref-color-grey-20);background:var(--ref-color-grey-bg)}:host.minified nav .nav-selector__content{width:64px}:host.minified nav .nav-selector__content .entry{padding:var(--ref-spacing-xxxs)}:host.minified nav .nav-selector__footer{padding:var(--ref-spacing-xs) var(--ref-spacing-xxxs)}\n"], dependencies: [{ kind: "component", type: NavSelectorLeafComponent, selector: "ap-nav-selector-leaf", inputs: ["leaf"], outputs: ["actionClicked"] }, { kind: "component", type: NavSelectorGroupComponent, selector: "ap-nav-selector-group", inputs: ["group"], outputs: ["actionClicked"] }, { kind: "component", type: NavSelectorCategoryComponent, selector: "ap-nav-selector-category", inputs: ["category"], outputs: ["actionClicked"] }, { kind: "component", type: InputSearchComponent, selector: "ap-input-search", inputs: ["id", "placeholder", "clearable"], outputs: ["focus", "blur", "keyup"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: SymbolComponent, selector: "ap-symbol", inputs: ["symbolId", "color", "size"], outputs: ["sizeChange"] }, { kind: "component", type: IconButtonComponent, selector: "ap-icon-button", inputs: ["ariaLabel", "name", "color", "disabled", "menuTrigger", "symbolId", "locked", "loading", "type"], outputs: ["onClick", "onFocus", "onBlur", "menuOpened", "menuClosed"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], animations: [
|
|
2878
2872
|
trigger('expand', [
|
|
2879
2873
|
transition('expanded => minified', animate(EXPAND_ANIMATION_TIMINGS, keyframes([style({ width: EXPANDED_STATE_WIDTH }), style({ width: '100px' }), style({ width: MINIFIED_STATE_WIDTH })]))),
|
|
2880
2874
|
transition('minified => expanded', animate(EXPAND_ANIMATION_TIMINGS, keyframes([style({ width: MINIFIED_STATE_WIDTH }), style({ width: '50%' }), style({ width: '100%' })]))),
|
|
@@ -2905,7 +2899,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
2905
2899
|
transition('expanded => minified', animate(EXPAND_ANIMATION_TIMINGS, keyframes([style({ width: EXPANDED_STATE_WIDTH }), style({ width: '100px' }), style({ width: MINIFIED_STATE_WIDTH })]))),
|
|
2906
2900
|
transition('minified => expanded', animate(EXPAND_ANIMATION_TIMINGS, keyframes([style({ width: MINIFIED_STATE_WIDTH }), style({ width: '50%' }), style({ width: '100%' })]))),
|
|
2907
2901
|
]),
|
|
2908
|
-
], template: "<nav
|
|
2902
|
+
], template: "<nav [class.embedded]=\"embedded()\">\n @let headerProjectionNotNull = headerProjection();\n @let contentHeaderProjectionNotNull = contentHeaderProjection();\n @let footerProjectionNotNull = footerProjection();\n\n <div class=\"nav-selector__header\">\n @if (!embedded()) {\n @if (navSelectorState.expanded()) {\n <span class=\"h3\">{{ translatedTexts().title }}</span>\n }\n\n <button\n type=\"button\"\n class=\"expand-button\"\n [class.expanded]=\"navSelectorState.expanded()\"\n (click)=\"clickExpandButton()\">\n <ap-symbol\n size=\"sm\"\n [symbolId]=\"navSelectorState.expanded() ? 'arrow-reduce' : 'arrow-expand'\" />\n </button>\n }\n\n @if (headerProjectionNotNull) {\n <ng-container\n [ngTemplateOutlet]=\"headerProjectionNotNull\"\n [ngTemplateOutletContext]=\"{\n expanded: navSelectorState.expanded(),\n }\" />\n }\n\n @if (navSelectorState.expanded()) {\n <ap-input-search\n [id]=\"componentUid + '_search'\"\n [placeholder]=\"translatedTexts().searchPlaceholder\"\n [ngModel]=\"navSelectorState.search()\"\n (ngModelChange)=\"navSelectorState.search.set($event ?? '')\" />\n } @else {\n <ap-icon-button\n (onClick)=\"onMinifiedSearchClicked()\"\n type=\"stroked\"\n role=\"search\">\n <ap-symbol symbolId=\"search\" />\n </ap-icon-button>\n }\n </div>\n\n <div\n class=\"nav-selector__content\"\n [attr.aria-multiselectable]=\"navSelectorState.isMultipleModeEnabled()\"\n role=\"tree\">\n @if (contentHeaderProjectionNotNull) {\n <ng-container\n [ngTemplateOutlet]=\"contentHeaderProjectionNotNull\"\n [ngTemplateOutletContext]=\"{\n expanded: navSelectorState.expanded(),\n }\" />\n }\n\n @for (entry of navSelectorState.entries(); track entry.uid) {\n @if (!entry.hidden) {\n <div\n class=\"entry\"\n [class.folder]=\"entry.type === 'GROUP' || entry.type === 'CATEGORY'\">\n @if (entry.type === 'LEAF') {\n <ap-nav-selector-leaf\n [leaf]=\"entry\"\n (actionClicked)=\"actionClicked.emit($event)\" />\n } @else if (entry.type === 'GROUP') {\n <ap-nav-selector-group\n [group]=\"entry\"\n (actionClicked)=\"actionClicked.emit($event)\" />\n } @else if (entry.type === 'CATEGORY') {\n <ap-nav-selector-category\n [category]=\"$any(entry)\"\n (actionClicked)=\"actionClicked.emit($event)\" />\n }\n </div>\n }\n }\n @if (navSelectorState.expanded() && navSelectorState.noResults()) {\n <div class=\"no-result\">{{ translatedTexts().noResults }}</div>\n }\n </div>\n\n @if (displayFooter() && footerProjectionNotNull) {\n <div class=\"nav-selector__footer\">\n <ng-container\n [ngTemplateOutlet]=\"footerProjectionNotNull\"\n [ngTemplateOutletContext]=\"{\n expanded: navSelectorState.expanded(),\n }\" />\n </div>\n }\n</nav>\n", styles: [":host,nav{width:224px}@media only screen and (min-width: 1400px){:host:not(.embedded),nav:not(.embedded){width:250px}:host:not(.embedded) .nav-selector__content,nav:not(.embedded) .nav-selector__content{width:250px}}:host{display:flex;flex-direction:column;align-items:flex-start;flex-shrink:0;flex-grow:1}:host :hover .expand-button.expanded{animation-name:translateExpandButton}:host nav{display:flex;height:100%;flex-grow:1;flex-direction:column;align-items:flex-start;flex-shrink:0;overflow:hidden;background:var(--ref-color-white);transition:width .25s cubic-bezier(.4,0,.3,1)}:host nav:not(.embedded){border-right:1px solid var(--ref-color-grey-10)}:host .nav-selector__header{position:relative;display:flex;padding:var(--ref-spacing-xs) var(--ref-spacing-sm);flex-direction:column;align-items:flex-start;gap:var(--ref-spacing-xxs);align-self:stretch;white-space:nowrap;border-bottom:1px solid var(--ref-color-grey-10);background:var(--ref-color-white)}:host .nav-selector__header .h3{color:var(--ref-color-grey-100);font-family:Averta;font-size:var(--sys-text-style-h3-size);font-style:normal;font-weight:var(--ref-font-weight-bold);line-height:var(--ref-font-line-height-lg)}:host .nav-selector__header .expand-button-container{position:absolute;right:0;top:var(--ref-spacing-xs)}:host .nav-selector__header .expand-button{animation-duration:70ms;animation-timing-function:cubic-bezier(0,0,.2,1);animation-fill-mode:forwards;animation-name:translateHideButton;display:flex;width:24px;height:24px;justify-content:center;align-items:center;background:var(--ref-color-grey-bg);border-top:1px solid var(--ref-color-grey-20);border-right:none;border-bottom:1px solid var(--ref-color-grey-20);border-left:1px solid var(--ref-color-grey-20);border-top-left-radius:var(--ref-border-radius-sm);border-bottom-left-radius:var(--ref-border-radius-sm);cursor:pointer}@keyframes translateHideButton{0%{transform:translate(0)}to{transform:translate(100%)}}@keyframes translateExpandButton{0%{transform:translate(100%)}to{transform:translate(0)}}:host .nav-selector__header .expand-button.expanded{position:absolute;right:0;top:12px;transform:translate(100%)}:host .nav-selector__header .expand-button ap-symbol[symbol-id=arrow-reduce],:host .nav-selector__header .expand-button ap-symbol[symbol-id=arrow-expand]{color:var(--ref-color-grey-80)}:host .nav-selector__header .expand-button:focus-visible{border-radius:var(--ref-border-radius-sm) 0px 0px var(--ref-border-radius-sm);border-top:1px solid var(--ref-color-grey-20);border-bottom:1px solid var(--ref-color-grey-20);border-left:1px solid var(--ref-color-grey-20);background:var(--ref-color-grey-10);box-shadow:0 0 0 1px #fff,0 0 0 3px #178dfe}:host .nav-selector__header .expand-button:focus-visible.expanded{animation-name:translateExpandButton}:host .nav-selector__header .expand-button:hover{background-color:var(--ref-color-grey-10)}:host .nav-selector__header .expand-button:active{background-color:var(--ref-color-grey-20)}:host .nav-selector__content{display:flex;flex-direction:column;align-items:flex-start;flex:1 0 0;align-self:stretch;width:224px;overflow-y:scroll;overflow-x:hidden;transition:width .25s cubic-bezier(.4,0,.3,1)}:host .nav-selector__content .entry{align-self:stretch;display:flex;flex-direction:column}:host .nav-selector__content .entry.folder{padding:var(--ref-spacing-xxs);border-bottom:1px solid var(--sys-border-color-default)}:host .nav-selector__content .entry.folder+.entry:not(.folder){padding-top:var(--ref-spacing-xxs)}:host .nav-selector__content .entry:not(.folder){padding-left:var(--ref-spacing-xxs);padding-right:var(--ref-spacing-xxs)}:host .nav-selector__content .entry:not(.folder):first-child{padding-top:var(--ref-spacing-xxs)}:host .nav-selector__content .entry:not(.folder):last-child{padding-bottom:var(--ref-spacing-xxs)}:host .nav-selector__content .entry:not(.folder):has(+.entry.folder){padding-bottom:var(--ref-spacing-xxs)}:host .nav-selector__content .entry:not(.folder)+.entry.folder{border-top:1px solid var(--sys-border-color-default)}:host .nav-selector__content .no-result{display:flex;padding:var(--ref-spacing-sm);flex-direction:column;align-items:flex-start;flex:1 0 0;align-self:stretch;color:var(--ref-color-grey-80);font-family:Averta;font-size:var(--ref-font-size-sm);font-style:italic;font-weight:400;line-height:var(--ref-font-line-height-sm)}:host .nav-selector__footer{display:flex;padding:var(--ref-spacing-xs);flex-direction:column;align-items:flex-start;gap:var(--ref-spacing-xxs);align-self:stretch;border-top:1px solid var(--sys-border-color-default);background:var(--ref-color-white)}:host.minified{width:64px}:host.minified nav{width:64px}:host.minified nav .nav-selector__header{align-items:center}:host.minified nav .nav-selector__header .expand-button{animation-name:none;border-radius:var(--ref-border-radius-sm);border:1px solid var(--ref-color-grey-20);background:var(--ref-color-grey-bg)}:host.minified nav .nav-selector__content{width:64px}:host.minified nav .nav-selector__content .entry{padding:var(--ref-spacing-xxxs)}:host.minified nav .nav-selector__footer{padding:var(--ref-spacing-xs) var(--ref-spacing-xxxs)}\n"] }]
|
|
2909
2903
|
}], ctorParameters: () => [{ type: NavSelectorState }, { type: i0.ElementRef }] });
|
|
2910
2904
|
|
|
2911
2905
|
/**
|