nav_model_srv.ts 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  1. import coreModule from 'app/core/core_module';
  2. import config from 'app/core/config';
  3. import _ from 'lodash';
  4. export interface NavModelItem {
  5. text: string;
  6. url: string;
  7. icon?: string;
  8. img?: string;
  9. id: string;
  10. active?: boolean;
  11. hideFromTabs?: boolean;
  12. divider?: boolean;
  13. children: NavModelItem[];
  14. }
  15. export class NavModel {
  16. breadcrumbs: NavModelItem[];
  17. main: NavModelItem;
  18. node: NavModelItem;
  19. constructor() {
  20. this.breadcrumbs = [];
  21. }
  22. }
  23. export class NavModelSrv {
  24. navItems: any;
  25. /** @ngInject */
  26. constructor(private contextSrv) {
  27. this.navItems = config.bootData.navTree;
  28. }
  29. getCfgNode() {
  30. return _.find(this.navItems, {id: 'cfg'});
  31. }
  32. getNav(...args) {
  33. var children = this.navItems;
  34. var nav = new NavModel();
  35. for (let id of args) {
  36. // if its a number then it's the index to use for main
  37. if (_.isNumber(id)) {
  38. nav.main = nav.breadcrumbs[id];
  39. break;
  40. }
  41. let node = _.find(children, {id: id});
  42. nav.breadcrumbs.push(node);
  43. nav.node = node;
  44. nav.main = node;
  45. children = node.children;
  46. }
  47. if (nav.main.children) {
  48. for (let item of nav.main.children) {
  49. item.active = false;
  50. if (item.url === nav.node.url) {
  51. item.active = true;
  52. }
  53. }
  54. }
  55. return nav;
  56. }
  57. getNotFoundNav() {
  58. var node = {
  59. text: "Page not found ",
  60. icon: "fa fa-fw fa-warning",
  61. };
  62. return {
  63. breadcrumbs: [node],
  64. node: node
  65. };
  66. }
  67. getDashboardNav(dashboard, dashNavCtrl) {
  68. // special handling for snapshots
  69. if (dashboard.meta.isSnapshot) {
  70. return {
  71. section: {
  72. title: dashboard.title,
  73. icon: 'icon-gf icon-gf-snapshot'
  74. },
  75. menu: [
  76. {
  77. title: 'Go to original dashboard',
  78. icon: 'fa fa-fw fa-external-link',
  79. url: dashboard.snapshot.originalUrl,
  80. }
  81. ]
  82. };
  83. }
  84. var menu = [];
  85. if (dashboard.meta.canEdit) {
  86. menu.push({
  87. title: 'Settings',
  88. icon: 'fa fa-fw fa-cog',
  89. clickHandler: () => dashNavCtrl.openEditView('settings')
  90. });
  91. menu.push({
  92. title: 'Templating',
  93. icon: 'fa fa-fw fa-code',
  94. clickHandler: () => dashNavCtrl.openEditView('templating')
  95. });
  96. menu.push({
  97. title: 'Annotations',
  98. icon: 'fa fa-fw fa-comment',
  99. clickHandler: () => dashNavCtrl.openEditView('annotations')
  100. });
  101. if (!dashboard.meta.isHome) {
  102. menu.push({
  103. title: 'Version history',
  104. icon: 'fa fa-fw fa-history',
  105. clickHandler: () => dashNavCtrl.openEditView('history')
  106. });
  107. }
  108. menu.push({
  109. title: 'View JSON',
  110. icon: 'fa fa-fw fa-eye',
  111. clickHandler: () => dashNavCtrl.viewJson()
  112. });
  113. }
  114. if (this.contextSrv.isEditor && !dashboard.editable) {
  115. menu.push({
  116. title: 'Make Editable',
  117. icon: 'fa fa-fw fa-edit',
  118. clickHandler: () => dashNavCtrl.makeEditable()
  119. });
  120. }
  121. if (this.contextSrv.isEditor && !dashboard.meta.isFolder) {
  122. menu.push({
  123. title: 'Save As...',
  124. icon: 'fa fa-fw fa-save',
  125. clickHandler: () => dashNavCtrl.saveDashboardAs()
  126. });
  127. }
  128. if (dashboard.meta.canSave) {
  129. menu.push({
  130. title: 'Delete',
  131. icon: 'fa fa-fw fa-trash',
  132. clickHandler: () => dashNavCtrl.deleteDashboard()
  133. });
  134. }
  135. return {
  136. section: {
  137. title: dashboard.title,
  138. icon: 'icon-gf icon-gf-dashboard'
  139. },
  140. menu: menu
  141. };
  142. }
  143. }
  144. coreModule.service('navModelSrv', NavModelSrv);