playlist.html 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. <navbar icon="fa fa-fw fa-list" title="Playlists" title-url="playlists">
  2. </navbar>
  3. <div class="page-container" ng-form="playlistEditForm">
  4. <div class="page-header">
  5. <h1 ng-show="ctrl.isNew()">New Playlist</h1>
  6. <h1 ng-show="!ctrl.isNew()">Edit Playlist</h1>
  7. </div>
  8. <p class="playlist-description">A playlist rotates through a pre-selected list of Dashboards. A Playlist can be a great way to build situational awareness, or just show off your metrics to your team or visitors.</p>
  9. <div class="gf-form-group">
  10. <div class="gf-form">
  11. <span class="gf-form-label width-7">Name</span>
  12. <input type="text" required ng-model="ctrl.playlist.name" class="gf-form-input max-width-21">
  13. </div>
  14. <div class="gf-form">
  15. <span class="gf-form-label width-7">Interval</span>
  16. <input type="text" required ng-model="ctrl.playlist.interval" placeholder="5m" class="gf-form-input max-width-21">
  17. </div>
  18. </div>
  19. <div class="gf-form-group">
  20. <h3 class="page-headering">Dashboards</h3>
  21. </div>
  22. <div class="row">
  23. <div class="col-md-6">
  24. <div class="playlist-search-containerwrapper">
  25. <div class="max-width-32">
  26. <h5 class="page-headering playlist-column-header">Available</h5>
  27. <div style="">
  28. <playlist-search class="playlist-search-container" search-started="ctrl.searchStarted(promise)"></playlist-search>
  29. </div>
  30. </div>
  31. </div>
  32. <div ng-if="ctrl.filteredDashboards.length > 0">
  33. <table class="grafana-options-table playlist-available-list">
  34. <tr ng-repeat="playlistItem in ctrl.filteredDashboards">
  35. <td>
  36. <i class="icon-gf icon-gf-dashboard"></i>
  37. &nbsp;&nbsp;{{playlistItem.title}}
  38. <i class="fa fa-star" ng-show="playlistItem.isStarred"></i>
  39. </td>
  40. <td class="add-dashboard">
  41. <button class="btn btn-inverse btn-mini pull-right" ng-click="ctrl.addPlaylistItem(playlistItem)">
  42. <i class="fa fa-plus"></i>
  43. Add to playlist
  44. </button>
  45. </td>
  46. </tr>
  47. </table>
  48. </div>
  49. <div class="playlist-search-results-container" ng-if="ctrl.filteredTags.length > 0;">
  50. <table class="grafana-options-table playlist-available-list">
  51. <tr ng-repeat="tag in ctrl.filteredTags">
  52. <td>
  53. <a class="search-result-tag label label-tag" tag-color-from-name="tag.term">
  54. <i class="fa fa-tag"></i>
  55. <span>{{tag.term}} &nbsp;({{tag.count}})</span>
  56. </a>
  57. </td>
  58. <td class="add-dashboard">
  59. <button class="btn btn-inverse btn-mini pull-right" ng-click="ctrl.addTagPlaylistItem(tag)">
  60. <i class="fa fa-plus"></i>
  61. Add to playlist
  62. </button>
  63. </td>
  64. </tr>
  65. </table>
  66. </div>
  67. </div>
  68. <div class="col-md-6">
  69. <h5 class="page headering playlist-column-header">Selected</h5>
  70. <table class="grafana-options-table playlist-available-list">
  71. <tr ng-repeat="playlistItem in ctrl.playlistItems">
  72. <td ng-if="playlistItem.type === 'dashboard_by_id'">
  73. <i class="icon-gf icon-gf-dashboard"></i>&nbsp;&nbsp;{{playlistItem.title}}
  74. </td>
  75. <td ng-if="playlistItem.type === 'dashboard_by_tag'">
  76. <a class="search-result-tag label label-tag" tag-color-from-name="playlistItem.title">
  77. <i class="fa fa-tag"></i>
  78. <span>{{playlistItem.title}}</span>
  79. </a>
  80. </td>
  81. <td class="selected-playlistitem-settings">
  82. <button class="btn btn-inverse btn-mini" ng-hide="$first" ng-click="ctrl.movePlaylistItemUp(playlistItem)">
  83. <i class="fa fa-arrow-up"></i>
  84. </button>
  85. <button class="btn btn-inverse btn-mini" ng-hide="$last" ng-click="ctrl.movePlaylistItemDown(playlistItem)">
  86. <i class="fa fa-arrow-down"></i>
  87. </button>
  88. <button class="btn btn-inverse btn-mini" ng-click="ctrl.removePlaylistItem(playlistItem)">
  89. <i class="fa fa-remove"></i>
  90. </button>
  91. </td>
  92. </tr>
  93. </table>
  94. </div>
  95. </div>
  96. <div class="clearfix"></div>
  97. <div class="gf-form-button-row">
  98. <a class="btn btn-success " ng-show="ctrl.isNew()"
  99. ng-disabled="ctrl.playlistEditForm.$invalid || ctrl.isPlaylistEmpty()"
  100. ng-click="ctrl.savePlaylist(ctrl.playlist, ctrl.playlistItems)">Create new playlist</a>
  101. <a class="btn btn-success" ng-show="!ctrl.isNew()"
  102. ng-disabled="ctrl.playlistEditForm.$invalid || ctrl.isPlaylistEmpty()"
  103. ng-click="ctrl.savePlaylist(ctrl.playlist, ctrl.playlistItems)">Save</a>
  104. <a class="btn-text" ng-click="ctrl.backToList()">Cancel</a>
  105. </div>
  106. </div>