ngx-material-navigation 0.0.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/CONTRIBUTING.md +97 -0
- package/LICENSE.md +21 -0
- package/README.md +119 -0
- package/components/footer/footer.component.d.ts +13 -0
- package/components/footer/footer.module.d.ts +8 -0
- package/components/navbar/nav-element/nav-element.component.d.ts +35 -0
- package/components/navbar/nav-element/nav-element.module.d.ts +13 -0
- package/components/navbar/nav-menu/nav-menu.component.d.ts +42 -0
- package/components/navbar/nav-menu/nav-menu.module.d.ts +11 -0
- package/components/navbar/navbar.component.d.ts +53 -0
- package/components/navbar/navbar.module.d.ts +11 -0
- package/esm2020/components/footer/footer.component.mjs +17 -0
- package/esm2020/components/footer/footer.module.mjs +22 -0
- package/esm2020/components/navbar/nav-element/nav-element.component.mjs +51 -0
- package/esm2020/components/navbar/nav-element/nav-element.module.mjs +42 -0
- package/esm2020/components/navbar/nav-menu/nav-menu.component.mjs +71 -0
- package/esm2020/components/navbar/nav-menu/nav-menu.module.mjs +34 -0
- package/esm2020/components/navbar/navbar.component.mjs +97 -0
- package/esm2020/components/navbar/navbar.module.mjs +34 -0
- package/esm2020/models/nav-button.model.mjs +2 -0
- package/esm2020/models/nav-image.model.mjs +2 -0
- package/esm2020/models/nav-link.model.mjs +8 -0
- package/esm2020/models/nav-menu.model.mjs +2 -0
- package/esm2020/models/nav-title.model.mjs +2 -0
- package/esm2020/models/nav.model.mjs +4 -0
- package/esm2020/models/navbar.model.mjs +2 -0
- package/esm2020/ngx-material-navigation.mjs +5 -0
- package/esm2020/public-api.mjs +16 -0
- package/esm2020/utilities/nav.utilities.mjs +198 -0
- package/fesm2015/ngx-material-navigation.mjs +551 -0
- package/fesm2015/ngx-material-navigation.mjs.map +1 -0
- package/fesm2020/ngx-material-navigation.mjs +551 -0
- package/fesm2020/ngx-material-navigation.mjs.map +1 -0
- package/models/nav-button.model.d.ts +11 -0
- package/models/nav-image.model.d.ts +40 -0
- package/models/nav-link.model.d.ts +39 -0
- package/models/nav-menu.model.d.ts +28 -0
- package/models/nav-title.model.d.ts +52 -0
- package/models/nav.model.d.ts +23 -0
- package/models/navbar.model.d.ts +11 -0
- package/ngx-material-navigation.d.ts +5 -0
- package/package.json +39 -0
- package/public-api.d.ts +12 -0
- package/utilities/nav.utilities.d.ts +81 -0
|
@@ -0,0 +1,198 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Contains HelperMethods around handling Navigation.
|
|
3
|
+
*/
|
|
4
|
+
export class NavUtilities {
|
|
5
|
+
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
6
|
+
static asTitle(element) {
|
|
7
|
+
return element;
|
|
8
|
+
}
|
|
9
|
+
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
10
|
+
static asAngularRoute(route) {
|
|
11
|
+
return route;
|
|
12
|
+
}
|
|
13
|
+
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
14
|
+
static asStringRoute(route) {
|
|
15
|
+
return route;
|
|
16
|
+
}
|
|
17
|
+
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
18
|
+
static asInternalLink(element) {
|
|
19
|
+
return element;
|
|
20
|
+
}
|
|
21
|
+
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
22
|
+
static asExternalLink(element) {
|
|
23
|
+
return element;
|
|
24
|
+
}
|
|
25
|
+
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
26
|
+
static asMenu(element) {
|
|
27
|
+
return element;
|
|
28
|
+
}
|
|
29
|
+
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
30
|
+
static asButton(element) {
|
|
31
|
+
return element;
|
|
32
|
+
}
|
|
33
|
+
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
34
|
+
static asImage(element) {
|
|
35
|
+
return element;
|
|
36
|
+
}
|
|
37
|
+
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
38
|
+
static asImageWithInternalLink(element) {
|
|
39
|
+
return element;
|
|
40
|
+
}
|
|
41
|
+
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
42
|
+
static asImageWithExternalLink(element) {
|
|
43
|
+
return element;
|
|
44
|
+
}
|
|
45
|
+
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
46
|
+
static asTitleWithInternalLink(element) {
|
|
47
|
+
return element;
|
|
48
|
+
}
|
|
49
|
+
// eslint-disable-next-line jsdoc/require-jsdoc
|
|
50
|
+
static asTitleWithExternalLink(element) {
|
|
51
|
+
return element;
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Checks if the provided element is a NavInternalLink.
|
|
55
|
+
*
|
|
56
|
+
* @param element - The element to check.
|
|
57
|
+
* @returns Whether or not the given element is a NavInternalLink.
|
|
58
|
+
*/
|
|
59
|
+
static isInternalLink(element) {
|
|
60
|
+
if (element.route) {
|
|
61
|
+
return true;
|
|
62
|
+
}
|
|
63
|
+
return false;
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Checks if the provided element is a NavMenu.
|
|
67
|
+
*
|
|
68
|
+
* @param element - The element to check.
|
|
69
|
+
* @returns Whether or not the given element is a NavMenu.
|
|
70
|
+
*/
|
|
71
|
+
static isMenu(element) {
|
|
72
|
+
if (element.elements) {
|
|
73
|
+
return true;
|
|
74
|
+
}
|
|
75
|
+
return false;
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Checks if the provided value is an angular route.
|
|
79
|
+
*
|
|
80
|
+
* @param route - The value to check.
|
|
81
|
+
* @returns Whether or not the given value is an angular route.
|
|
82
|
+
*/
|
|
83
|
+
static isAngularRoute(route) {
|
|
84
|
+
if (route.path) {
|
|
85
|
+
return true;
|
|
86
|
+
}
|
|
87
|
+
return false;
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Checks if the provided element is a NavElement.
|
|
91
|
+
*
|
|
92
|
+
* @param value - The element to check.
|
|
93
|
+
* @returns Whether or not the given element is a NavElement.
|
|
94
|
+
*/
|
|
95
|
+
static isNavElement(value) {
|
|
96
|
+
if (value.type) {
|
|
97
|
+
return true;
|
|
98
|
+
}
|
|
99
|
+
return false;
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Gets the angular routes.
|
|
103
|
+
* Extracts them from the navbarRows and adds any additional routes provided in additionalRoutes.
|
|
104
|
+
*
|
|
105
|
+
* @param navbarRows - The NavbarRows used as a configuration for the navbar element.
|
|
106
|
+
* @param additionalRoutes - Any additional routes that aren't included in the NavbarRows.
|
|
107
|
+
* @returns All found angular routes.
|
|
108
|
+
*/
|
|
109
|
+
static getAngularRoutes(navbarRows = [], additionalRoutes = []) {
|
|
110
|
+
let allRoutes = [];
|
|
111
|
+
allRoutes = allRoutes.concat(NavUtilities.getRoutesFromNavbar(navbarRows));
|
|
112
|
+
allRoutes = allRoutes.concat(additionalRoutes);
|
|
113
|
+
// Filters to only contain unique paths
|
|
114
|
+
const uniquePaths = [];
|
|
115
|
+
const res = [];
|
|
116
|
+
for (const route of allRoutes) {
|
|
117
|
+
if (!uniquePaths.find(r => r === route.path)) {
|
|
118
|
+
res.push(route);
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
return res;
|
|
122
|
+
}
|
|
123
|
+
static getRoutesFromNavbar(navbarRows) {
|
|
124
|
+
let res = [];
|
|
125
|
+
for (const row of navbarRows) {
|
|
126
|
+
res = res.concat(NavUtilities.getRoutesFromElements(row.elements));
|
|
127
|
+
}
|
|
128
|
+
;
|
|
129
|
+
return res;
|
|
130
|
+
}
|
|
131
|
+
static getRoutesFromElements(elements) {
|
|
132
|
+
let res = [];
|
|
133
|
+
const internalLinks = elements.filter(e => NavUtilities.isInternalLink(e));
|
|
134
|
+
const angularRoutes = internalLinks.filter(l => NavUtilities.isAngularRoute(l.route)).map(l => l.route);
|
|
135
|
+
res = res.concat(angularRoutes);
|
|
136
|
+
const menus = elements.filter(e => NavUtilities.isMenu(e));
|
|
137
|
+
for (const menu of menus) {
|
|
138
|
+
res = res.concat(NavUtilities.getRoutesFromElements(menu.elements));
|
|
139
|
+
}
|
|
140
|
+
return res;
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* Get all elements at the provided position with the provided screenWidth from the given elements.
|
|
144
|
+
*
|
|
145
|
+
* @param position - The position for which to get the elements.
|
|
146
|
+
* @param screenWidth - The current screen width. Is needed to hide elements that are already collapsed into the sidenav.
|
|
147
|
+
* @param rows - The rows to get the elements from.
|
|
148
|
+
* @returns All Elements for the provided input.
|
|
149
|
+
*/
|
|
150
|
+
static getNavbarElements(position, screenWidth, rows) {
|
|
151
|
+
if (!rows || !rows.length) {
|
|
152
|
+
return [];
|
|
153
|
+
}
|
|
154
|
+
let res = [];
|
|
155
|
+
for (const row of rows) {
|
|
156
|
+
res = res.concat(row.elements);
|
|
157
|
+
}
|
|
158
|
+
if (position === 'left') {
|
|
159
|
+
res = res.filter(e => !e.position || e.position === position);
|
|
160
|
+
}
|
|
161
|
+
else {
|
|
162
|
+
res = res.filter(e => e.position === position);
|
|
163
|
+
}
|
|
164
|
+
switch (screenWidth) {
|
|
165
|
+
case 'lg':
|
|
166
|
+
return res.filter(e => e.collapse !== 'always' && e.collapse !== 'lg');
|
|
167
|
+
case 'md':
|
|
168
|
+
return res.filter(e => e.collapse !== 'always' && e.collapse !== 'lg' && e.collapse !== 'md');
|
|
169
|
+
case 'sm':
|
|
170
|
+
return res.filter(e => e.collapse !== 'always' && e.collapse !== 'lg' && e.collapse !== 'md' && e.collapse !== 'sm');
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
/**
|
|
174
|
+
* Gets all the elements to display in the sidenav.
|
|
175
|
+
*
|
|
176
|
+
* @param screenWidth - The current screen width.
|
|
177
|
+
* @param rows - The rows to get the elements from.
|
|
178
|
+
* @returns The NavElements to display in the sidenav.
|
|
179
|
+
*/
|
|
180
|
+
static getSidenavElements(screenWidth, rows) {
|
|
181
|
+
if (!rows || !rows.length) {
|
|
182
|
+
return [];
|
|
183
|
+
}
|
|
184
|
+
let res = [];
|
|
185
|
+
for (const row of rows) {
|
|
186
|
+
res = res.concat(row.elements);
|
|
187
|
+
}
|
|
188
|
+
switch (screenWidth) {
|
|
189
|
+
case 'lg':
|
|
190
|
+
return res.filter(e => e.collapse === 'always' || e.collapse === 'lg');
|
|
191
|
+
case 'md':
|
|
192
|
+
return res.filter(e => e.collapse === 'always' || e.collapse === 'lg' || e.collapse === 'md');
|
|
193
|
+
case 'sm':
|
|
194
|
+
return res.filter(e => e.collapse === 'always' || e.collapse === 'lg' || e.collapse === 'md' || e.collapse === 'sm');
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nav.utilities.js","sourceRoot":"","sources":["../../../../projects/ngx-material-navigation/src/utilities/nav.utilities.ts"],"names":[],"mappings":"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","sourcesContent":["import { Route, Routes } from '@angular/router';\r\nimport { NavButton } from '../models/nav-button.model';\r\nimport { NavMenu, NavMenuElement } from '../models/nav-menu.model';\r\nimport { NavImage, NavImageWithExternalLink, NavImageWithInternalLink } from '../models/nav-image.model';\r\nimport { NavTitle, NavTitleWithExternalLink, NavTitleWithInternalLink } from '../models/nav-title.model';\r\nimport { NavElement } from '../models/nav.model';\r\nimport { NavExternalLink, NavInternalLink } from '../models/nav-link.model';\r\nimport { NavbarRow } from '../models/navbar.model';\r\n\r\n/**\r\n * Contains HelperMethods around handling Navigation.\r\n */\r\nexport abstract class NavUtilities {\r\n\r\n    // eslint-disable-next-line jsdoc/require-jsdoc\r\n    static asTitle(element: NavElement): NavTitle {\r\n        return element as NavTitle;\r\n    }\r\n\r\n    // eslint-disable-next-line jsdoc/require-jsdoc\r\n    static asAngularRoute(route: Route | string): Route {\r\n        return route as Route;\r\n    }\r\n\r\n    // eslint-disable-next-line jsdoc/require-jsdoc\r\n    static asStringRoute(route: Route | string): string {\r\n        return route as string;\r\n    }\r\n\r\n    // eslint-disable-next-line jsdoc/require-jsdoc\r\n    static asInternalLink(element: NavElement | NavMenuElement): NavInternalLink {\r\n        return element as NavInternalLink;\r\n    }\r\n\r\n    // eslint-disable-next-line jsdoc/require-jsdoc\r\n    static asExternalLink(element: NavElement | NavMenuElement): NavExternalLink {\r\n        return element as NavExternalLink;\r\n    }\r\n\r\n    // eslint-disable-next-line jsdoc/require-jsdoc\r\n    static asMenu(element: NavElement | NavMenuElement): NavMenu {\r\n        return element as NavMenu;\r\n    }\r\n\r\n    // eslint-disable-next-line jsdoc/require-jsdoc\r\n    static asButton(element: NavElement): NavButton {\r\n        return element as NavButton;\r\n    }\r\n\r\n    // eslint-disable-next-line jsdoc/require-jsdoc\r\n    static asImage(element: NavElement): NavImage {\r\n        return element as NavImage;\r\n    }\r\n\r\n    // eslint-disable-next-line jsdoc/require-jsdoc\r\n    static asImageWithInternalLink(element: NavElement): NavImageWithInternalLink {\r\n        return element as NavImageWithInternalLink;\r\n    }\r\n\r\n    // eslint-disable-next-line jsdoc/require-jsdoc\r\n    static asImageWithExternalLink(element: NavElement): NavImageWithExternalLink {\r\n        return element as NavImageWithExternalLink;\r\n    }\r\n\r\n    // eslint-disable-next-line jsdoc/require-jsdoc\r\n    static asTitleWithInternalLink(element: NavElement): NavTitleWithInternalLink {\r\n        return element as NavTitleWithInternalLink;\r\n    }\r\n\r\n    // eslint-disable-next-line jsdoc/require-jsdoc\r\n    static asTitleWithExternalLink(element: NavElement): NavTitleWithExternalLink {\r\n        return element as NavTitleWithExternalLink;\r\n    }\r\n\r\n    /**\r\n     * Checks if the provided element is a NavInternalLink.\r\n     *\r\n     * @param element - The element to check.\r\n     * @returns Whether or not the given element is a NavInternalLink.\r\n     */\r\n    static isInternalLink(element: NavElement): element is NavInternalLink {\r\n        if ((element as NavInternalLink).route) {\r\n            return true;\r\n        }\r\n        return false;\r\n    }\r\n\r\n    /**\r\n     * Checks if the provided element is a NavMenu.\r\n     *\r\n     * @param element - The element to check.\r\n     * @returns Whether or not the given element is a NavMenu.\r\n     */\r\n    static isMenu(element: NavElement): element is NavMenu {\r\n        if ((element as NavMenu).elements) {\r\n            return true;\r\n        }\r\n        return false;\r\n    }\r\n\r\n    /**\r\n     * Checks if the provided value is an angular route.\r\n     *\r\n     * @param route - The value to check.\r\n     * @returns Whether or not the given value is an angular route.\r\n     */\r\n    static isAngularRoute(route: Route | string): route is Route {\r\n        if ((route as Route).path) {\r\n            return true;\r\n        }\r\n        return false;\r\n    }\r\n\r\n    /**\r\n     * Checks if the provided element is a NavElement.\r\n     *\r\n     * @param value - The element to check.\r\n     * @returns Whether or not the given element is a NavElement.\r\n     */\r\n    static isNavElement(value: NavElement | NavbarRow): value is NavElement {\r\n        if ((value as NavElement).type) {\r\n            return true;\r\n        }\r\n        return false;\r\n    }\r\n\r\n    /**\r\n     * Gets the angular routes.\r\n     * Extracts them from the navbarRows and adds any additional routes provided in additionalRoutes.\r\n     *\r\n     * @param navbarRows - The NavbarRows used as a configuration for the navbar element.\r\n     * @param additionalRoutes - Any additional routes that aren't included in the NavbarRows.\r\n     * @returns All found angular routes.\r\n     */\r\n    static getAngularRoutes(navbarRows: NavbarRow[] = [], additionalRoutes: Routes = []): Routes {\r\n        let allRoutes: Routes = [];\r\n        allRoutes = allRoutes.concat(NavUtilities.getRoutesFromNavbar(navbarRows));\r\n        allRoutes = allRoutes.concat(additionalRoutes);\r\n        // Filters to only contain unique paths\r\n        const uniquePaths: string[] = [];\r\n        const res: Routes = [];\r\n        for (const route of allRoutes) {\r\n            if (!uniquePaths.find(r => r === route.path)) {\r\n                res.push(route);\r\n            }\r\n        }\r\n        return res;\r\n    }\r\n\r\n    private static getRoutesFromNavbar(navbarRows: NavbarRow[]): Routes {\r\n        let res: Routes = [];\r\n        for (const row of navbarRows) {\r\n            res = res.concat(NavUtilities.getRoutesFromElements(row.elements));\r\n        };\r\n        return res;\r\n    }\r\n\r\n    private static getRoutesFromElements(elements: NavElement[]): Routes {\r\n        let res: Routes = [];\r\n        const internalLinks: NavInternalLink[] = elements.filter(e => NavUtilities.isInternalLink(e)) as NavInternalLink[];\r\n        const angularRoutes: Routes = internalLinks.filter(l => NavUtilities.isAngularRoute(l.route)).map(l => l.route) as Routes;\r\n        res = res.concat(angularRoutes);\r\n        const menus: NavMenu[] = elements.filter(e => NavUtilities.isMenu(e)) as NavMenu[];\r\n        for (const menu of menus) {\r\n            res = res.concat(NavUtilities.getRoutesFromElements(menu.elements as NavElement[]));\r\n        }\r\n        return res;\r\n    }\r\n\r\n    /**\r\n     * Get all elements at the provided position with the provided screenWidth from the given elements.\r\n     *\r\n     * @param position - The position for which to get the elements.\r\n     * @param screenWidth - The current screen width. Is needed to hide elements that are already collapsed into the sidenav.\r\n     * @param rows - The rows to get the elements from.\r\n     * @returns All Elements for the provided input.\r\n     */\r\n    static getNavbarElements(\r\n        position: 'left' | 'center' | 'right',\r\n        screenWidth: 'lg' | 'md' | 'sm',\r\n        rows?: NavbarRow[]\r\n    ): NavElement[] {\r\n        if (!rows || !rows.length) {\r\n            return [];\r\n        }\r\n        let res: NavElement[] = [];\r\n        for (const row of rows ) {\r\n            res = res.concat(row.elements);\r\n        }\r\n\r\n        if (position === 'left') {\r\n            res = res.filter(e => !e.position || e.position === position);\r\n        }\r\n        else {\r\n            res = res.filter(e => e.position === position);\r\n        }\r\n        switch (screenWidth) {\r\n            case 'lg':\r\n                return res.filter(e => e.collapse !== 'always' && e.collapse !== 'lg');\r\n            case 'md':\r\n                return res.filter(e => e.collapse !== 'always' && e.collapse !== 'lg' && e.collapse !== 'md');\r\n            case 'sm':\r\n                return res.filter(e => e.collapse !== 'always' && e.collapse !== 'lg' && e.collapse !== 'md' && e.collapse !== 'sm');\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Gets all the elements to display in the sidenav.\r\n     *\r\n     * @param screenWidth - The current screen width.\r\n     * @param rows - The rows to get the elements from.\r\n     * @returns The NavElements to display in the sidenav.\r\n     */\r\n    static getSidenavElements(screenWidth: 'lg' | 'md' | 'sm', rows?: NavbarRow[]): NavElement[] {\r\n        if (!rows || !rows.length) {\r\n            return [];\r\n        }\r\n        let res: NavElement[] = [];\r\n        for (const row of rows) {\r\n            res = res.concat(row.elements);\r\n        }\r\n        switch (screenWidth) {\r\n            case 'lg':\r\n                return res.filter(e => e.collapse === 'always' || e.collapse === 'lg');\r\n            case 'md':\r\n                return res.filter(e => e.collapse === 'always' || e.collapse === 'lg' || e.collapse === 'md');\r\n            case 'sm':\r\n                return res.filter(e => e.collapse === 'always' || e.collapse === 'lg' || e.collapse === 'md' || e.collapse === 'sm');\r\n        }\r\n    }\r\n}"]}
|