tab_display.html 6.5 KB

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