| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- import { types, getEnv } from 'mobx-state-tree';
- import { NavItem } from './NavItem';
- export const NavStore = types
- .model('NavStore', {
- main: types.maybe(NavItem),
- node: types.maybe(NavItem),
- })
- .actions(self => ({
- load(...args) {
- let children = getEnv(self).navTree;
- let main, node;
- let parents = [];
- for (let id of args) {
- node = children.find(el => el.id === id);
- if (!node) {
- throw new Error(`NavItem with id ${id} not found`);
- }
- children = node.children;
- parents.push(node);
- }
- main = parents[parents.length - 2];
- if (main.children) {
- for (let item of main.children) {
- item.active = false;
- if (item.url === node.url) {
- item.active = true;
- }
- }
- }
- self.main = NavItem.create(main);
- self.node = NavItem.create(node);
- },
- initFolderNav(folder: any, activeChildId: string) {
- const folderUrl = createFolderUrl(folder.id, folder.slug);
- let main = {
- icon: 'fa fa-folder-open',
- id: 'manage-folder',
- subTitle: 'Manage folder dashboards & permissions',
- url: '',
- text: folder.title,
- breadcrumbs: [{ title: 'Dashboards', url: 'dashboards' }],
- children: [
- {
- active: activeChildId === 'manage-folder-dashboards',
- icon: 'fa fa-fw fa-th-large',
- id: 'manage-folder-dashboards',
- text: 'Dashboards',
- url: folderUrl,
- },
- {
- active: activeChildId === 'manage-folder-permissions',
- icon: 'fa fa-fw fa-lock',
- id: 'manage-folder-permissions',
- text: 'Permissions',
- url: folderUrl + '/permissions',
- },
- {
- active: activeChildId === 'manage-folder-settings',
- icon: 'fa fa-fw fa-cog',
- id: 'manage-folder-settings',
- text: 'Settings',
- url: folderUrl + '/settings',
- },
- ],
- };
- self.main = NavItem.create(main);
- },
- }));
- function createFolderUrl(folderId: number, slug: string) {
- return `dashboards/folder/${folderId}/${slug}`;
- }
|