tab_display.html 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. <div class="edit-tab-with-sidemenu">
  2. <aside class="edit-sidemenu-aside">
  3. <ul class="edit-sidemenu">
  4. <li ng-class="{active: ctrl.subTabIndex === 0}">
  5. <a ng-click="ctrl.subTabIndex = 0">Draw options</a>
  6. </li>
  7. <li ng-class="{active: ctrl.subTabIndex === 1}">
  8. <a ng-click="ctrl.subTabIndex = 1">
  9. Series overrides <span class="muted">({{ctrl.panel.seriesOverrides.length}})</span>
  10. </a>
  11. </li>
  12. <li ng-class="{active: ctrl.subTabIndex === 2}">
  13. <a ng-click="ctrl.subTabIndex = 2">Thresholds</a>
  14. </li>
  15. </ul>
  16. </aside>
  17. <div class="edit-tab-content" ng-if="ctrl.subTabIndex === 0">
  18. <div class="section gf-form-group">
  19. <h5 class="section-heading">Draw Modes</h5>
  20. <gf-form-switch class="gf-form" label="Bars" label-class="width-5" checked="ctrl.panel.bars" on-change="ctrl.render()"></gf-form-switch>
  21. <gf-form-switch class="gf-form" label="Lines" label-class="width-5" checked="ctrl.panel.lines" on-change="ctrl.render()"></gf-form-switch>
  22. <gf-form-switch class="gf-form" label="Points" label-class="width-5" checked="ctrl.panel.points" on-change="ctrl.render()"></gf-form-switch>
  23. </div>
  24. <div class="section gf-form-group">
  25. <h5 class="section-heading">Mode Options</h5>
  26. <div class="gf-form" ng-show="ctrl.panel.lines">
  27. <label class="gf-form-label width-8">Fill</label>
  28. <div class="gf-form-select-wrapper max-width-5">
  29. <select class="gf-form-input" ng-model="ctrl.panel.fill" ng-options="f for f in [0,1,2,3,4,5,6,7,8,9,10]" ng-change="ctrl.render()"></select>
  30. </div>
  31. </div>
  32. <div class="gf-form" ng-show="ctrl.panel.lines">
  33. <label class="gf-form-label width-8">Line Width</label>
  34. <div class="gf-form-select-wrapper max-width-5">
  35. <select class="gf-form-input" ng-model="ctrl.panel.linewidth" ng-options="f for f in [0,1,2,3,4,5,6,7,8,9,10]" ng-change="ctrl.render()"></select>
  36. </div>
  37. </div>
  38. <gf-form-switch ng-show="ctrl.panel.lines" class="gf-form" label="Staircase" label-class="width-8" checked="ctrl.panel.steppedLine" on-change="ctrl.render()">
  39. </gf-form-switch>
  40. <div class="gf-form" ng-show="ctrl.panel.points">
  41. <label class="gf-form-label width-8">Point Radius</label>
  42. <div class="gf-form-select-wrapper max-width-5">
  43. <select class="gf-form-input" ng-model="ctrl.panel.pointradius" ng-options="f for f in [1,2,3,4,5,6,7,8,9,10]" ng-change="ctrl.render()"></select>
  44. </div>
  45. </div>
  46. </div>
  47. <div class="section gf-form-group">
  48. <h5 class="section-heading">Hover info</h5>
  49. <div class="gf-form">
  50. <label class="gf-form-label width-9">Mode</label>
  51. <div class="gf-form-select-wrapper max-width-8">
  52. <select class="gf-form-input" ng-model="ctrl.panel.tooltip.shared" ng-options="f.value as f.text for f in [{text: 'All series', value: true}, {text: 'Single', value: false}]" ng-change="ctrl.render()"></select>
  53. </div>
  54. </div>
  55. <div class="gf-form">
  56. <label class="gf-form-label width-9">Sort order</label>
  57. <div class="gf-form-select-wrapper max-width-8">
  58. <select class="gf-form-input" ng-model="ctrl.panel.tooltip.sort" ng-options="f.value as f.text for f in [{text: 'None', value: 0}, {text: 'Increasing', value: 1}, {text: 'Decreasing', value: 2}]" ng-change="ctrl.render()"></select>
  59. </div>
  60. </div>
  61. <div class="gf-form" ng-show="ctrl.panel.stack">
  62. <label class="gf-form-label width-9">Stacked value</label>
  63. <div class="gf-form-select-wrapper max-width-8">
  64. <select class="gf-form-input" ng-model="ctrl.panel.tooltip.value_type" ng-options="f for f in ['cumulative','individual']" ng-change="ctrl.render()"></select>
  65. </div>
  66. </div>
  67. </div>
  68. <div class="section gf-form-group">
  69. <h5 class="section-heading">Stacking & Null value</h5>
  70. <gf-form-switch class="gf-form"
  71. label="Stack" label-class="width-7"
  72. checked="ctrl.panel.stack" on-change="ctrl.render()">
  73. </gf-form-switch>
  74. <gf-form-switch class="gf-form" ng-show="ctrl.panel.stack"
  75. label="Percent" label-class="width-7"
  76. checked="ctrl.panel.percentage" on-change="ctrl.render()">
  77. </gf-form-switch>
  78. <div class="gf-form">
  79. <label class="gf-form-label width-7">Null value</label>
  80. <div class="gf-form-select-wrapper">
  81. <select class="gf-form-input max-width-8" ng-model="ctrl.panel.nullPointMode" ng-options="f for f in ['connected', 'null', 'null as zero']" ng-change="ctrl.render()"></select>
  82. </div>
  83. </div>
  84. </div>
  85. </div>
  86. <div class="edit-tab-content" ng-if="ctrl.subTabIndex === 1">
  87. <div class="gf-form-group">
  88. <h5>Series specific overrides <tip>Regex match example: /server[0-3]/i </tip></h5>
  89. <div class="gf-form-inline" ng-repeat="override in ctrl.panel.seriesOverrides" ng-controller="SeriesOverridesCtrl">
  90. <div class="gf-form">
  91. <label class="gf-form-label">alias or regex</label>
  92. </div>
  93. <div class="gf-form width-15">
  94. <input type="text" ng-model="override.alias" bs-typeahead="getSeriesNames" ng-blur="ctrl.render()" data-min-length=0 data-items=100 class="gf-form-input width-15">
  95. </div>
  96. <div class="gf-form" ng-repeat="option in currentOverrides">
  97. <label class="gf-form-label">
  98. <i class="pointer fa fa-remove" ng-click="removeOverride(option)"></i>
  99. <span ng-show="option.propertyName === 'color'">
  100. Color: <i class="fa fa-circle" ng-style="{color:option.value}"></i>
  101. </span>
  102. <span ng-show="option.propertyName !== 'color'">
  103. {{option.name}}: {{option.value}}
  104. </span>
  105. </label>
  106. </div>
  107. <div class="gf-form">
  108. <span class="dropdown" dropdown-typeahead="overrideMenu" dropdown-typeahead-on-select="setOverride($item, $subItem)">
  109. </span>
  110. </div>
  111. <div class="gf-form gf-form--grow">
  112. <div class="gf-form-label gf-form-label--grow"></div>
  113. </div>
  114. <div class="gf-form">
  115. <label class="gf-form-label">
  116. <i class="fa fa-trash pointer" ng-click="ctrl.removeSeriesOverride(override)"></i>
  117. </label>
  118. </div>
  119. </div>
  120. </div>
  121. <button class="btn btn-inverse" ng-click="ctrl.addSeriesOverride()">
  122. <i class="fa fa-plus"></i>&nbsp;Add override
  123. </button>
  124. </div>
  125. <div class="edit-tab-content" ng-if="ctrl.subTabIndex === 2">
  126. <div class="gf-form-group">
  127. <h5>Thresholds</h5>
  128. <div class="gf-form-inline" ng-repeat="threshold in ctrl.panel.thresholds">
  129. <div class="gf-form">
  130. <label class="gf-form-label">T{{$index+1}}</label>
  131. </div>
  132. <div class="gf-form">
  133. <div class="gf-form-select-wrapper">
  134. <select class="gf-form-input" ng-model="threshold.op" ng-options="f for f in ['>', '<']" ng-change="ctrl.render()"></select>
  135. </div>
  136. <input type="number" ng-model="threshold.value" class="gf-form-input width-8" ng-change="ctrl.render()" placeholder="value">
  137. </div>
  138. <div class="gf-form">
  139. <label class="gf-form-label">Color</label>
  140. <div class="gf-form-select-wrapper">
  141. <select class="gf-form-input" ng-model="threshold.colorMode" ng-options="f for f in ['custom', 'critical', 'warning', 'ok']" ng-change="ctrl.render()"></select>
  142. </div>
  143. </div>
  144. <gf-form-switch class="gf-form" label="Fill" checked="threshold.fill" on-change="ctrl.render()"></gf-form-switch>
  145. <div class="gf-form" ng-if="threshold.fill && threshold.colorMode === 'custom'">
  146. <label class="gf-form-label">Fill color</label>
  147. <span class="gf-form-label">
  148. <spectrum-picker ng-model="threshold.fillColor" ng-change="ctrl.render()" ></spectrum-picker>
  149. </span>
  150. </div>
  151. <gf-form-switch class="gf-form" label="Line" checked="threshold.line" on-change="ctrl.render()"></gf-form-switch>
  152. <div class="gf-form" ng-if="threshold.line && threshold.colorMode === 'custom'">
  153. <label class="gf-form-label">Line color</label>
  154. <span class="gf-form-label">
  155. <spectrum-picker ng-model="threshold.lineColor" ng-change="ctrl.render()" ></spectrum-picker>
  156. </span>
  157. </div>
  158. <div class="gf-form">
  159. <label class="gf-form-label">
  160. <i class="fa fa-trash pointer" ng-click="ctrl.removeThreshold($index)"></i>
  161. </label>
  162. </div>
  163. </div>
  164. <div class="gf-form-button-row">
  165. <button class="btn btn-inverse" ng-click="ctrl.addThreshold()">
  166. <i class="fa fa-plus"></i>&nbsp;Add Threshold
  167. </button>
  168. </div>
  169. </div>
  170. </div>
  171. </div>