dashboardList.html 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. <div class="scroll-canvas" grafana-scrollbar>
  2. <navbar model="ctrl.navModel"></navbar>
  3. <div class="page-container" style="height: 95%">
  4. <div class="page-header">
  5. <h1>Dashboards</h1>
  6. <a class="btn btn-inverse" href="/dashboard/new">
  7. <i class="gicon gicon-dashboard-new"></i>
  8. Dashboard
  9. </a>
  10. <a class="btn btn-inverse" href="/dashboard/new/?editview=new-folder">
  11. <i class="gicon gicon-folder-new"></i>
  12. Folder
  13. </a>
  14. </div>
  15. <div class="gf-form-group">
  16. <div class="gf-form width-15">
  17. <span style="position: relative;">
  18. <input type="text" class="gf-form-input" placeholder="Find Dashboard by name" tabindex="1" give-focus="true"
  19. ng-model="ctrl.query.query" ng-model-options="{ debounce: 500 }" spellcheck='false' ng-change="ctrl.onQueryChange()" />
  20. </span>
  21. </div>
  22. </div>
  23. <div class="gf-form" ng-if="ctrl.query.tag.length">
  24. Filters:
  25. <span ng-repeat="tagName in ctrl.query.tag">
  26. <a ng-click="ctrl.removeTag(tagName, $event)" tag-color-from-name="tagName" class="label label-tag">
  27. <i class="fa fa-remove"></i>
  28. {{tagName}}
  29. </a>
  30. </span>
  31. </div>
  32. <div class="gf-form">
  33. <div class="gf-form-button-row"
  34. ng-show="ctrl.hasFilters">
  35. <button
  36. type="button"
  37. class="btn gf-form-button btn-inverse btn-small"
  38. ng-click="ctrl.clearFilters()">
  39. <i class="fa fa-close"></i> Clear current search query and filters
  40. </button>
  41. </div>
  42. </div>
  43. <div class="gf-form-group">
  44. <div class="gf-form-button-row">
  45. <button type="button"
  46. class="btn gf-form-button btn-secondary"
  47. ng-disabled="!ctrl.canMove"
  48. ng-click="ctrl.moveTo()"
  49. bs-tooltip="ctrl.canMove ? '' : 'Select a dashboard to move (cannot move folders)'" data-placement="bottom">
  50. <i class="fa fa-exchange"></i>&nbsp;&nbsp;Move to...
  51. </button>
  52. <button type="button"
  53. class="btn gf-form-button btn-inverse"
  54. ng-click="ctrl.delete()"
  55. ng-disabled="!ctrl.canDelete">
  56. <i class="fa fa-trash"></i>&nbsp;&nbsp;Delete
  57. </button>
  58. </div>
  59. </div>
  60. <div class="dashboard-list">
  61. <div class="search-results-filter-row">
  62. <gf-form-switch
  63. on-change="ctrl.onSelectAllChanged()"
  64. checked="ctrl.selectAllChecked"
  65. />
  66. <div class="search-results-filter-row__filters">
  67. <select
  68. class="search-results-filter-row__filters-item gf-form-input"
  69. ng-model="ctrl.selectedStarredFilter"
  70. ng-options="t.text disable when t.disabled for t in ctrl.starredFilterOptions"
  71. ng-change="ctrl.onStarredFilterChange()"
  72. />
  73. <select
  74. class="search-results-filter-row__filters-item gf-form-input"
  75. ng-model="ctrl.selectedTagFilter"
  76. ng-options="t.term disable when t.disabled for t in ctrl.tagFilterOptions"
  77. ng-change="ctrl.onTagFilterChange()"
  78. />
  79. </div>
  80. </div>
  81. <div class="search-results-container" ng-show="ctrl.sections.length > 0" grafana-scrollbar>
  82. <div ng-repeat="section in ctrl.sections" class="search-section">
  83. <div class="search-section__header__with-checkbox" ng-hide="section.hideHeader">
  84. <gf-form-switch
  85. on-change="ctrl.selectionChanged()"
  86. checked="section.checked">
  87. </gf-form-switch>
  88. <a class="search-section__header pointer" ng-click="ctrl.toggleFolder(section)" ng-hide="section.hideHeader">
  89. <i class="search-section__header__icon" ng-class="section.icon"></i>
  90. <span class="search-section__header__text">{{::section.title}}</span>
  91. <i class="fa fa-minus search-section__header__toggle" ng-show="section.expanded"></i>
  92. <i class="fa fa-plus search-section__header__toggle" ng-hide="section.expanded"></i>
  93. </a>
  94. </div>
  95. <div ng-if="section.expanded">
  96. <div ng-repeat="item in section.items" class="search-item__with-checkbox" ng-class="{'selected': item.selected}">
  97. <gf-form-switch
  98. on-change="ctrl.selectionChanged()"
  99. checked="item.checked" />
  100. <a ng-href="{{::item.url}}" class="search-item">
  101. <span class="search-item__icon">
  102. <i class="fa fa-th-large"></i>
  103. </span>
  104. <span class="search-item__body">
  105. <div class="search-item__body-title">{{::item.title}}</div>
  106. <div class="search-item__body-sub-title" ng-show="item.folderTitle && section.hideHeader">
  107. <i class="fa fa-folder-o"></i>
  108. {{::item.folderTitle}}
  109. </div>
  110. </span>
  111. <span class="search-item__tags">
  112. <span ng-click="ctrl.filterByTag(tag, $event)" ng-repeat="tag in item.tags" tag-color-from-name="tag" class="label label-tag">
  113. {{tag}}
  114. </span>
  115. </span>
  116. <span class="search-item__actions">
  117. <i class="fa" ng-class="{'fa-star': item.isStarred, 'fa-star-o': !item.isStarred}"></i>
  118. </span>
  119. </a>
  120. </div>
  121. </div>
  122. </div>
  123. <!-- <div bindonce class="search-section" ng-repeat="dashboard in ctrl.dashboards">
  124. <gf-form-switch
  125. switch-class="gf-form-switch--table-cell"
  126. on-change="ctrl.selectionChanged()"
  127. checked="dashboard.checked">
  128. </gf-form-switch>
  129. <a class="search-item pointer "
  130. bo-href-i="{{dashboard.url}}">
  131. <span class="search-item__icon">
  132. <i class="fa fa-th-large"></i>
  133. </span>
  134. <span class="search-result-tags">
  135. <span ng-click="ctrl.filterByTag(tag, $event)" bindonce ng-repeat="tag in dashboard.tags" tag-color-from-name="tag" class="label label-tag">
  136. {{tag}}
  137. </span>
  138. <i class="fa" bo-class="{'fa-star': dashboard.isStarred, 'fa-star-o': !dashboard.isStarred}"></i>
  139. </span>
  140. <span class="search-result-link">
  141. <i class="fa search-result-icon"></i>
  142. <span bo-text="dashboard.title" />
  143. </span>
  144. </a>
  145. </div> -->
  146. </div>
  147. </div>
  148. </div>
  149. <em class="muted" ng-hide="ctrl.sections.length > 0">
  150. No Dashboards or Folders found.
  151. </em>
  152. </div>
  153. </div>