2023-10-31 11:24:34 -05:00
|
|
|
import memoizeOne from 'memoize-one';
|
|
|
|
|
2019-06-18 10:17:27 -05:00
|
|
|
import { NavModel, NavModelItem, NavIndex } from '@grafana/data';
|
2023-05-18 11:01:59 -05:00
|
|
|
import { FOLDER_ID } from 'app/features/folders/state/navModel';
|
2018-09-02 12:36:36 -05:00
|
|
|
|
2022-10-03 09:05:19 -05:00
|
|
|
import { HOME_NAV_ID } from '../reducers/navModel';
|
|
|
|
|
2020-08-07 02:00:44 -05:00
|
|
|
const getNotFoundModel = (): NavModel => {
|
2018-09-07 10:55:38 -05:00
|
|
|
const node: NavModelItem = {
|
2018-09-02 12:36:36 -05:00
|
|
|
id: 'not-found',
|
|
|
|
text: 'Page not found',
|
2020-04-12 15:20:02 -05:00
|
|
|
icon: 'exclamation-triangle',
|
2018-09-02 12:36:36 -05:00
|
|
|
subTitle: '404 Error',
|
|
|
|
url: 'not-found',
|
|
|
|
};
|
|
|
|
|
|
|
|
return {
|
|
|
|
node: node,
|
|
|
|
main: node,
|
|
|
|
};
|
2020-08-07 02:00:44 -05:00
|
|
|
};
|
2018-09-02 12:36:36 -05:00
|
|
|
|
2023-10-31 11:24:34 -05:00
|
|
|
export const getNavModel = memoizeOne(
|
|
|
|
(navIndex: NavIndex, id: string, fallback?: NavModel, onlyChild = false): NavModel => {
|
|
|
|
if (navIndex[id]) {
|
|
|
|
const node = navIndex[id];
|
|
|
|
const main = onlyChild ? node : getRootSectionForNode(node);
|
|
|
|
const mainWithActive = enrichNodeWithActiveState(main, id);
|
2018-09-02 12:36:36 -05:00
|
|
|
|
2023-10-31 11:24:34 -05:00
|
|
|
return {
|
|
|
|
node: node,
|
|
|
|
main: mainWithActive,
|
|
|
|
};
|
|
|
|
}
|
2018-09-13 07:10:51 -05:00
|
|
|
|
2023-10-31 11:24:34 -05:00
|
|
|
if (fallback) {
|
|
|
|
return fallback;
|
|
|
|
}
|
2018-09-13 07:10:51 -05:00
|
|
|
|
2023-10-31 11:24:34 -05:00
|
|
|
return getNotFoundModel();
|
|
|
|
}
|
|
|
|
);
|
2019-01-16 08:59:05 -06:00
|
|
|
|
2022-10-07 09:33:36 -05:00
|
|
|
export function getRootSectionForNode(node: NavModelItem): NavModelItem {
|
2023-05-18 11:01:59 -05:00
|
|
|
// Don't recurse fully up the folder tree when nested folders is enabled
|
2023-11-22 09:22:00 -06:00
|
|
|
if (node.id === FOLDER_ID) {
|
2023-05-18 11:01:59 -05:00
|
|
|
return node;
|
2023-05-16 07:54:44 -05:00
|
|
|
} else {
|
|
|
|
return node.parentItem && node.parentItem.id !== HOME_NAV_ID ? getRootSectionForNode(node.parentItem) : node;
|
|
|
|
}
|
2022-08-01 08:47:52 -05:00
|
|
|
}
|
2022-07-22 03:42:41 -05:00
|
|
|
|
2022-09-13 05:24:23 -05:00
|
|
|
function enrichNodeWithActiveState(node: NavModelItem, activeId: string): NavModelItem {
|
|
|
|
if (node.id === activeId) {
|
|
|
|
return { ...node, active: true };
|
|
|
|
}
|
2022-07-22 03:42:41 -05:00
|
|
|
|
2022-09-13 05:24:23 -05:00
|
|
|
if (node.children && node.children.length > 0) {
|
|
|
|
return {
|
|
|
|
...node,
|
|
|
|
children: node.children.map((child) => enrichNodeWithActiveState(child, activeId)),
|
|
|
|
};
|
2022-08-01 08:47:52 -05:00
|
|
|
}
|
2022-08-24 11:05:12 -05:00
|
|
|
|
2022-09-13 05:24:23 -05:00
|
|
|
return node;
|
2022-07-22 03:42:41 -05:00
|
|
|
}
|
|
|
|
|
2019-01-16 08:59:05 -06:00
|
|
|
export const getTitleFromNavModel = (navModel: NavModel) => {
|
2019-02-13 04:14:53 -06:00
|
|
|
return `${navModel.main.text}${navModel.node.text ? ': ' + navModel.node.text : ''}`;
|
2019-01-16 08:59:05 -06:00
|
|
|
};
|