dashboardList.html 6.5 KB

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