FolderPageLoader.ts 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. export class FolderPageLoader {
  2. constructor(private backendSrv) {}
  3. load(ctrl, uid, activeChildId) {
  4. ctrl.navModel = {
  5. main: {
  6. icon: 'fa fa-folder-open',
  7. id: 'manage-folder',
  8. subTitle: 'Manage folder dashboards & permissions',
  9. url: '',
  10. text: '',
  11. breadcrumbs: [{ title: 'Dashboards', url: 'dashboards' }],
  12. children: [
  13. {
  14. active: activeChildId === 'manage-folder-dashboards',
  15. icon: 'fa fa-fw fa-th-large',
  16. id: 'manage-folder-dashboards',
  17. text: 'Dashboards',
  18. url: 'dashboards',
  19. },
  20. {
  21. active: activeChildId === 'manage-folder-permissions',
  22. icon: 'fa fa-fw fa-lock',
  23. id: 'manage-folder-permissions',
  24. text: 'Permissions',
  25. url: 'dashboards/permissions',
  26. },
  27. {
  28. active: activeChildId === 'manage-folder-settings',
  29. icon: 'gicon gicon-cog',
  30. id: 'manage-folder-settings',
  31. text: 'Settings',
  32. url: 'dashboards/settings',
  33. },
  34. ],
  35. },
  36. };
  37. return this.backendSrv.getFolderByUid(uid).then(folder => {
  38. ctrl.folderId = folder.id;
  39. const folderTitle = folder.title;
  40. const folderUrl = folder.url;
  41. ctrl.navModel.main.text = folderTitle;
  42. const dashTab = ctrl.navModel.main.children.find(child => child.id === 'manage-folder-dashboards');
  43. dashTab.url = folderUrl;
  44. if (folder.canAdmin) {
  45. const permTab = ctrl.navModel.main.children.find(child => child.id === 'manage-folder-permissions');
  46. permTab.url = folderUrl + '/permissions';
  47. const settingsTab = ctrl.navModel.main.children.find(child => child.id === 'manage-folder-settings');
  48. settingsTab.url = folderUrl + '/settings';
  49. } else {
  50. ctrl.navModel.main.children = [dashTab];
  51. }
  52. return folder;
  53. });
  54. }
  55. }