editor.html 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. <div class="editor-row">
  2. <div class="grafana-info-box" ng-if="ctrl.panel.gauge.show">
  3. <h5>Gauge Migration</h5>
  4. <p>
  5. Gauge visualizations within the Singlestat panel are deprecated. Please
  6. migrate this panel to use the Gauge panel
  7. <div class="gf-form-button-row">
  8. <button class="btn btn-primary" ng-click="ctrl.migrateToGaugePanel(true)">
  9. Migrate to Gauge Panel
  10. </button>
  11. <button class="btn btn-inverse" ng-click="ctrl.migrateToGaugePanel(false)">
  12. Show as single stat
  13. </button>
  14. </div>
  15. <br/>
  16. <div ng-if="ctrl.panel.sparkline.show">
  17. <b>NOTE:</b> Sparklines are not supported in the gauge panel
  18. </div>
  19. <div ng-if="ctrl.panel.prefix">
  20. <b>NOTE:</b> Prefix will not be show in the gauge panel
  21. </div>
  22. <div ng-if="ctrl.panel.postfix">
  23. <b>NOTE:</b> Postfix will not be show in the gauge panel
  24. </div>
  25. <div ng-if="ctrl.panel.links && ctrl.panel.links.length">
  26. <b>NOTE:</b> Links will be in the upper left corner, rather than anywhere on the gauge
  27. </div>
  28. </p>
  29. </div>
  30. <div class="section gf-form-group">
  31. <h5 class="section-heading">Value</h5>
  32. <div class="gf-form-inline">
  33. <div class="gf-form" ng-if="ctrl.fieldNames.length > 1">
  34. <label class="gf-form-label width-6">Field</label>
  35. <div class="gf-form-select-wrapper width-12">
  36. <select class="gf-form-input" ng-model="ctrl.panel.tableColumn" ng-options="f for f in ctrl.fieldNames" ng-change="ctrl.refresh()"></select>
  37. </div>
  38. </div>
  39. </div>
  40. <div class="gf-form-inline">
  41. <div class="gf-form">
  42. <label class="gf-form-label width-6">Show</label>
  43. <div class="gf-form-select-wrapper width-12">
  44. <select class="gf-form-input" ng-model="ctrl.panel.valueName" ng-options="f.value as f.text for f in ctrl.valueNameOptions" ng-change="ctrl.refresh()"></select>
  45. </div>
  46. </div>
  47. <div class="gf-form">
  48. <label class="gf-form-label width-6">Font size</label>
  49. <div class="gf-form-select-wrapper">
  50. <select class="gf-form-input" ng-model="ctrl.panel.valueFontSize" ng-options="f for f in ctrl.fontSizes" ng-change="ctrl.render()"></select>
  51. </div>
  52. </div>
  53. </div>
  54. <div class="gf-form-inline">
  55. <div class="gf-form">
  56. <label class="gf-form-label width-6">Prefix</label>
  57. <input type="text" class="gf-form-input width-12" ng-model="ctrl.panel.prefix" ng-change="ctrl.render()" ng-model-onblur>
  58. </div>
  59. <div class="gf-form">
  60. <label class="gf-form-label width-6">Font size</label>
  61. <div class="gf-form-select-wrapper">
  62. <select class="gf-form-input" ng-model="ctrl.panel.prefixFontSize" ng-options="f for f in ctrl.fontSizes" ng-change="ctrl.render()" ng-disabled="!ctrl.canModifyText()"></select>
  63. </div>
  64. </div>
  65. </div>
  66. <div class="gf-form-inline">
  67. <div class="gf-form">
  68. <label class="gf-form-label width-6">Postfix</label>
  69. <input type="text" class="gf-form-input width-12" ng-model="ctrl.panel.postfix" ng-change="ctrl.render()" ng-model-onblur>
  70. </div>
  71. <div class="gf-form">
  72. <label class="gf-form-label width-6">Font size</label>
  73. <div class="gf-form-select-wrapper">
  74. <select class="input-small gf-form-input" ng-model="ctrl.panel.postfixFontSize" ng-options="f for f in ctrl.fontSizes" ng-change="ctrl.render()" ng-disabled="!ctrl.canModifyText()"></select>
  75. </div>
  76. </div>
  77. </div>
  78. <div class="gf-form">
  79. <label class="gf-form-label width-6">Unit</label>
  80. <div class="gf-form-dropdown-typeahead width-18" ng-model="ctrl.panel.format" dropdown-typeahead2="ctrl.unitFormats" dropdown-typeahead-on-select="ctrl.setUnitFormat($subItem)"></div>
  81. </div>
  82. <div class="gf-form">
  83. <label class="gf-form-label width-6">Decimals</label>
  84. <input type="number" class="gf-form-input width-18" placeholder="auto" data-placement="right" bs-tooltip="'Override automatic decimal precision for legend and tooltips'" ng-model="ctrl.panel.decimals" ng-change="ctrl.refresh()" ng-model-onblur>
  85. </div>
  86. </div>
  87. <div class="section gf-form-group">
  88. <h5 class="section-heading">Coloring</h5>
  89. <div class="gf-form-inline">
  90. <gf-form-switch class="gf-form" label-class="width-8" label="Background" checked="ctrl.panel.colorBackground" on-change="ctrl.render()"></gf-form-switch>
  91. <gf-form-switch class="gf-form" label-class="width-6" label="Value" checked="ctrl.panel.colorValue" on-change="ctrl.render()"></gf-form-switch>
  92. </div>
  93. <div class="gf-form-inline">
  94. <gf-form-switch class="gf-form" label-class="width-8" label="Prefix" checked="ctrl.panel.colorPrefix" on-change="ctrl.render()" ng-disabled="!ctrl.canModifyText()"></gf-form-switch>
  95. <gf-form-switch class="gf-form" label-class="width-6" label="Postfix" checked="ctrl.panel.colorPostfix" on-change="ctrl.render()" ng-disabled="!ctrl.canModifyText()"></gf-form-switch>
  96. </div>
  97. <div class="gf-form-inline">
  98. <div class="gf-form max-width-21">
  99. <label class="gf-form-label width-8">Thresholds
  100. <tip>Define two threshold values&lt;br /&gt; 50,80 will produce: value &lt; 50 = Green, 50 &lt;= value &lt; 80 = Yellow, value &gt;= 80 = Red</tip>
  101. </label>
  102. <input type="text" class="gf-form-input" ng-model="ctrl.panel.thresholds" ng-blur="ctrl.render()" placeholder="50,80"></input>
  103. </div>
  104. </div>
  105. <div class="gf-form">
  106. <label class="gf-form-label width-8">Colors</label>
  107. <span class="gf-form-label" ng-repeat="color in ctrl.panel.colors track by $index">
  108. <color-picker color="color" onChange="ctrl.onColorChange($index)"></color-picker>
  109. </span>
  110. <span class="gf-form-label">
  111. <a ng-click="ctrl.invertColorOrder()">
  112. Invert
  113. </a>
  114. </span>
  115. </div>
  116. </div>
  117. <div class="section gf-form-group">
  118. <h5 class="section-heading">Spark lines</h5>
  119. <gf-form-switch class="gf-form" label-class="width-9" label="Show" checked="ctrl.panel.sparkline.show" on-change="ctrl.refresh()"></gf-form-switch>
  120. <div ng-if="ctrl.panel.sparkline.show">
  121. <gf-form-switch class="gf-form" label-class="width-9" label="Full height" checked="ctrl.panel.sparkline.full" on-change="ctrl.render()"></gf-form-switch>
  122. <div class="gf-form">
  123. <label class="gf-form-label width-9">Y-Min</label>
  124. <input type="number" class="gf-form-input width-5" placeholder="auto" data-placement="right" ng-model="ctrl.panel.sparkline.ymin" ng-change="ctrl.render()" ng-model-onblur empty-to-null>
  125. </div>
  126. <div class="gf-form">
  127. <label class="gf-form-label width-9">Y-Max</label>
  128. <input type="number" class="gf-form-input width-5" placeholder="auto" data-placement="right" ng-model="ctrl.panel.sparkline.ymax" ng-change="ctrl.render()" ng-model-onblur empty-to-null>
  129. </div>
  130. <div class="gf-form">
  131. <label class="gf-form-label width-9">Line Color</label>
  132. <span class="gf-form-label">
  133. <color-picker color="ctrl.panel.sparkline.lineColor" onChange="ctrl.onSparklineColorChange"></color-picker>
  134. </span>
  135. </div>
  136. <div class="gf-form">
  137. <label class="gf-form-label width-9">Fill Color</label>
  138. <span class="gf-form-label">
  139. <color-picker color="ctrl.panel.sparkline.fillColor" onChange="ctrl.onSparklineFillChange"></color-picker>
  140. </span>
  141. </div>
  142. </div>
  143. </div>
  144. <div class="section gf-form-group" ng-if="ctrl.panel.gauge.show">
  145. <h5 class="section-heading">Gauge</h5>
  146. <gf-form-switch class="gf-form" label-class="width-10" switch-class="max-width-6" label="Show" checked="ctrl.panel.gauge.show" on-change="ctrl.render()"></gf-form-switch>
  147. <div ng-if="ctrl.panel.gauge.show">
  148. <div class="gf-form">
  149. <label class="gf-form-label width-10">Min</label>
  150. <input type="number" class="gf-form-input width-6" placeholder="0" data-placement="right" ng-model="ctrl.panel.gauge.minValue" ng-change="ctrl.refresh()" ng-model-onblur>
  151. <label class="gf-form-label alert-state-critical" ng-show="ctrl.invalidGaugeRange">
  152. &nbsp; <i class="fa fa-warning"></i>
  153. Min value is bigger than max.
  154. </label>
  155. </div>
  156. <div class="gf-form">
  157. <label class="gf-form-label width-10">Max</label>
  158. <input type="number" class="gf-form-input width-6" placeholder="0" data-placement="right" ng-model="ctrl.panel.gauge.maxValue" ng-change="ctrl.refresh()" ng-model-onblur>
  159. </div>
  160. <gf-form-switch class="gf-form" label-class="width-10" switch-class="max-width-6" label="Threshold labels" checked="ctrl.panel.gauge.thresholdLabels" on-change="ctrl.render()"></gf-form-switch>
  161. <gf-form-switch class="gf-form" label-class="width-10" switch-class="max-width-6" label="Threshold markers" checked="ctrl.panel.gauge.thresholdMarkers" on-change="ctrl.render()"></gf-form-switch>
  162. </div>
  163. </div>
  164. </div>