tab_display.html 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  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">
  14. Thresholds <span class="muted">({{ctrl.panel.thresholds.length}})</span>
  15. </a>
  16. </li>
  17. </ul>
  18. </aside>
  19. <div class="edit-tab-content" ng-if="ctrl.subTabIndex === 0">
  20. <div class="section gf-form-group">
  21. <h5 class="section-heading">Draw Modes</h5>
  22. <gf-form-switch class="gf-form" label="Bars" label-class="width-5" checked="ctrl.panel.bars" on-change="ctrl.render()"></gf-form-switch>
  23. <gf-form-switch class="gf-form" label="Lines" label-class="width-5" checked="ctrl.panel.lines" on-change="ctrl.render()"></gf-form-switch>
  24. <gf-form-switch class="gf-form" label="Points" label-class="width-5" checked="ctrl.panel.points" on-change="ctrl.render()"></gf-form-switch>
  25. </div>
  26. <div class="section gf-form-group">
  27. <h5 class="section-heading">Mode Options</h5>
  28. <div class="gf-form">
  29. <label class="gf-form-label width-8">Fill</label>
  30. <div class="gf-form-select-wrapper max-width-5">
  31. <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()" ng-disabled="!ctrl.panel.lines"></select>
  32. </div>
  33. </div>
  34. <div class="gf-form">
  35. <label class="gf-form-label width-8">Line Width</label>
  36. <div class="gf-form-select-wrapper max-width-5">
  37. <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()" ng-disabled="!ctrl.panel.lines"></select>
  38. </div>
  39. </div>
  40. <gf-form-switch ng-disabled="!ctrl.panel.lines" class="gf-form" label="Staircase" label-class="width-8" checked="ctrl.panel.steppedLine" on-change="ctrl.render()">
  41. </gf-form-switch>
  42. <div class="gf-form">
  43. <label class="gf-form-label width-8">Point Radius</label>
  44. <div class="gf-form-select-wrapper max-width-5">
  45. <select class="gf-form-input" ng-model="ctrl.panel.pointradius" ng-options="f for f in [0.5,1,2,3,4,5,6,7,8,9,10]" ng-change="ctrl.render()" ng-disabled="!ctrl.panel.points"></select>
  46. </div>
  47. </div>
  48. </div>
  49. <div class="section gf-form-group">
  50. <h5 class="section-heading">Hover tooltip</h5>
  51. <div class="gf-form">
  52. <label class="gf-form-label width-9">Mode</label>
  53. <div class="gf-form-select-wrapper max-width-8">
  54. <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>
  55. </div>
  56. </div>
  57. <div class="gf-form">
  58. <label class="gf-form-label width-9">Sort order</label>
  59. <div class="gf-form-select-wrapper max-width-8">
  60. <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>
  61. </div>
  62. </div>
  63. <div class="gf-form" ng-show="ctrl.panel.stack">
  64. <label class="gf-form-label width-9">Stacked value</label>
  65. <div class="gf-form-select-wrapper max-width-8">
  66. <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>
  67. </div>
  68. </div>
  69. </div>
  70. <div class="section gf-form-group">
  71. <h5 class="section-heading">Stacking & Null value</h5>
  72. <gf-form-switch class="gf-form" label="Stack" label-class="width-7" checked="ctrl.panel.stack" on-change="ctrl.refresh()">
  73. </gf-form-switch>
  74. <gf-form-switch class="gf-form" ng-show="ctrl.panel.stack" label="Percent" label-class="width-7" checked="ctrl.panel.percentage" on-change="ctrl.render()">
  75. </gf-form-switch>
  76. <div class="gf-form">
  77. <label class="gf-form-label width-7">Null value</label>
  78. <div class="gf-form-select-wrapper">
  79. <select class="gf-form-input max-width-9" ng-model="ctrl.panel.nullPointMode" ng-options="f for f in ['connected', 'null', 'null as zero']" ng-change="ctrl.render()"></select>
  80. </div>
  81. </div>
  82. </div>
  83. </div>
  84. <div class="edit-tab-content" ng-if="ctrl.subTabIndex === 1">
  85. <div class="gf-form-group">
  86. <h5>Series specific overrides <tip>Regex match example: /server[0-3]/i </tip></h5>
  87. <div class="gf-form-inline" ng-repeat="override in ctrl.panel.seriesOverrides" ng-controller="SeriesOverridesCtrl">
  88. <div class="gf-form">
  89. <label class="gf-form-label">alias or regex</label>
  90. </div>
  91. <div class="gf-form width-15">
  92. <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">
  93. </div>
  94. <div class="gf-form" ng-repeat="option in currentOverrides">
  95. <label class="gf-form-label">
  96. <i class="pointer fa fa-remove" ng-click="removeOverride(option)"></i>
  97. <span ng-show="option.propertyName === 'color'">
  98. Color: <i class="fa fa-circle" ng-style="{color:option.value}"></i>
  99. </span>
  100. <span ng-show="option.propertyName !== 'color'">
  101. {{option.name}}: {{option.value}}
  102. </span>
  103. </label>
  104. </div>
  105. <div class="gf-form">
  106. <span class="dropdown" dropdown-typeahead="overrideMenu" dropdown-typeahead-on-select="setOverride($item, $subItem)">
  107. </span>
  108. </div>
  109. <div class="gf-form gf-form--grow">
  110. <div class="gf-form-label gf-form-label--grow"></div>
  111. </div>
  112. <div class="gf-form">
  113. <label class="gf-form-label">
  114. <i class="fa fa-trash pointer" ng-click="ctrl.removeSeriesOverride(override)"></i>
  115. </label>
  116. </div>
  117. </div>
  118. </div>
  119. <button class="btn btn-inverse" ng-click="ctrl.addSeriesOverride()">
  120. <i class="fa fa-plus"></i>&nbsp;Add override
  121. </button>
  122. </div>
  123. <div class="edit-tab-content" ng-if="ctrl.subTabIndex === 2">
  124. <graph-threshold-form panel-ctrl="ctrl"></graph-threshold-form>
  125. </div>
  126. </div>