2018-09-02 12:36:36 -05:00
|
|
|
import { NavModel, NavModelItem, NavIndex } from 'app/types';
|
|
|
|
|
|
|
|
function 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',
|
|
|
|
icon: 'fa fa-fw fa-warning',
|
|
|
|
subTitle: '404 Error',
|
|
|
|
url: 'not-found',
|
|
|
|
};
|
|
|
|
|
|
|
|
return {
|
|
|
|
node: node,
|
|
|
|
main: node,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2018-09-13 07:10:51 -05:00
|
|
|
export function getNavModel(navIndex: NavIndex, id: string, fallback?: NavModel): NavModel {
|
2018-09-02 12:36:36 -05:00
|
|
|
if (navIndex[id]) {
|
|
|
|
const node = navIndex[id];
|
|
|
|
const main = {
|
|
|
|
...node.parentItem,
|
|
|
|
};
|
|
|
|
|
|
|
|
main.children = main.children.map(item => {
|
|
|
|
return {
|
|
|
|
...item,
|
|
|
|
active: item.url === node.url,
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
|
|
|
return {
|
|
|
|
node: node,
|
|
|
|
main: main,
|
|
|
|
};
|
|
|
|
}
|
2018-09-13 07:10:51 -05:00
|
|
|
|
|
|
|
if (fallback) {
|
|
|
|
return fallback;
|
|
|
|
}
|
|
|
|
|
|
|
|
return getNotFoundModel();
|
2018-09-02 12:36:36 -05:00
|
|
|
}
|
2019-01-16 08:59:05 -06:00
|
|
|
|
|
|
|
export const getTitleFromNavModel = (navModel: NavModel) => {
|
|
|
|
return `${navModel.main.text}${navModel.node.text ? ': ' + navModel.node.text : '' }`;
|
|
|
|
};
|