mirror of https://github.com/grafana/grafana
parent
805fd18b7b
commit
a1faaa133c
@ -1,138 +1,113 @@ |
||||
<div class="tight-form" ng-class="{'tight-form-disabled': agg.hide}"> |
||||
<ul class="tight-form-list"> |
||||
<li class="tight-form-item query-keyword tight-form-align" style="width: 75px;"> |
||||
<div class="gf-form-inline" ng-class="{'gf-form-disabled': agg.hide}"> |
||||
<div class="gf-form"> |
||||
<label class="gf-form-label query-keyword width-7"> |
||||
Metric |
||||
|
||||
<a ng-click="toggleShowMetric()" bs-tooltip="'Click to toggle show / hide metric'"> |
||||
<i class="fa fa-eye" ng-hide="agg.hide"></i> |
||||
<i class="fa fa-eye-slash" ng-show="agg.hide"></i> |
||||
</a> |
||||
</li> |
||||
<li> |
||||
<metric-segment-model property="agg.type" options="metricAggTypes" on-change="onTypeChange()" custom="false" css-class="tight-form-item-large"></metric-segment-model> |
||||
</li> |
||||
<li ng-if="aggDef.requiresField"> |
||||
<metric-segment-model property="agg.field" get-options="getFieldsInternal()" on-change="onChange()" css-class="tight-form-item-xxlarge"></metric-segment-model> |
||||
</li> |
||||
<li ng-if="aggDef.isPipelineAgg"> |
||||
<metric-segment-model property="agg.pipelineAgg" options="pipelineAggOptions" on-change="onChangeInternal()" custom="false" css-class="tight-form-item-xxlarge"></metric-segment-model> |
||||
</li> |
||||
<li class="tight-form-item last" ng-if="settingsLinkText"> |
||||
</label> |
||||
</div> |
||||
|
||||
<div class="gf-form"> |
||||
<metric-segment-model property="agg.type" options="metricAggTypes" on-change="onTypeChange()" custom="false" css-class="tight-form-item-large"></metric-segment-model> |
||||
<metric-segment-model ng-if="aggDef.requiresField" property="agg.field" get-options="getFieldsInternal()" on-change="onChange()" css-class="tight-form-item-xxlarge"></metric-segment-model> |
||||
<metric-segment-model ng-if="aggDef.isPipelineAgg" property="agg.pipelineAgg" options="pipelineAggOptions" on-change="onChangeInternal()" custom="false" css-class="tight-form-item-xxlarge"></metric-segment-model> |
||||
</div> |
||||
|
||||
<div class="gf-form" ng-if="settingsLinkText"> |
||||
<label class="gf-form-label"> |
||||
<a ng-click="toggleOptions()"> |
||||
<i class="fa fa-caret-down" ng-show="showOptions"></i> |
||||
<i class="fa fa-caret-right" ng-hide="showOptions"></i> |
||||
{{settingsLinkText}} |
||||
{{settingsLinkText}} |
||||
</a> |
||||
</li> |
||||
</ul> |
||||
</label> |
||||
</div> |
||||
|
||||
<div class="gf-form-filler"></div> |
||||
|
||||
<ul class="tight-form-list pull-right"> |
||||
<li class="tight-form-item last" ng-if="isFirst"> |
||||
<div class="gf-form"> |
||||
<label class="gf-form-label" ng-if="isFirst"> |
||||
<a class="pointer" ng-click="addMetricAgg()"><i class="fa fa-plus"></i></a> |
||||
</li> |
||||
<li class="tight-form-item last" ng-if="!isSingle"> |
||||
</label> |
||||
<label class="gf-form-label" ng-if="!isSingle"> |
||||
<a class="pointer" ng-click="removeMetricAgg()"><i class="fa fa-minus"></i></a> |
||||
</li> |
||||
</ul> |
||||
<div class="clearfix"></div> |
||||
</label> |
||||
</div> |
||||
|
||||
</div> |
||||
|
||||
<div class="tight-form" ng-if="showOptions"> |
||||
<div class="tight-form-inner-box tight-form-container"> |
||||
<div class="tight-form" ng-if="agg.type === 'derivative'"> |
||||
<ul class="tight-form-list"> |
||||
<li class="tight-form-item" style="width: 75px;"> |
||||
Unit |
||||
</li> |
||||
<li> |
||||
<input type="text" class="input-medium tight-form-input last" ng-model="agg.settings.unit" ng-blur="onChangeInternal()" spellcheck='false'> |
||||
</li> |
||||
</ul> |
||||
<div class="clearfix"></div> |
||||
</div> |
||||
<div class="gf-form-group" ng-if="showOptions"> |
||||
<div class="gf-form" ng-if="agg.type === 'derivative'"> |
||||
<label class="gf-form-label width-8">Unit</label> |
||||
<input type="text" class="gf-form-input max-width-10" ng-model="agg.settings.unit" ng-blur="onChangeInternal()" spellcheck='false'> |
||||
</div> |
||||
|
||||
<div class="tight-form" ng-if="agg.type === 'moving_avg'"> |
||||
<ul class="tight-form-list"> |
||||
<li class="tight-form-item" style="width: 75px;"> |
||||
Window |
||||
</li> |
||||
<li> |
||||
<input type="number" class="input-medium tight-form-input last" ng-model="agg.settings.window" ng-blur="onChangeInternal()" spellcheck='false'> |
||||
</li> |
||||
</ul> |
||||
<div class="clearfix"></div> |
||||
</div> |
||||
<div class="tight-form" ng-if="agg.type === 'moving_avg'"> |
||||
<ul class="tight-form-list"> |
||||
<li class="tight-form-item" style="width: 75px;"> |
||||
Model |
||||
</li> |
||||
<li> |
||||
<input type="text" class="input-medium tight-form-input last" ng-change="onChangeInternal()" ng-model="agg.settings.model" blur="onChange()" spellcheck='false'> |
||||
</li> |
||||
</ul> |
||||
<div class="clearfix"></div> |
||||
</div> |
||||
<div class="tight-form last" ng-if="agg.type === 'percentiles'"> |
||||
<ul class="tight-form-list"> |
||||
<li class="tight-form-item"> |
||||
Percentiles |
||||
</li> |
||||
<li> |
||||
<input type="text" class="input-xlarge tight-form-input last" ng-model="agg.settings.percents" array-join ng-blur="onChange()"></input> |
||||
</li> |
||||
</ul> |
||||
<div class="clearfix"></div> |
||||
</div> |
||||
<div ng-if="agg.type === 'extended_stats'"> |
||||
<div class="tight-form" ng-repeat="stat in extendedStats"> |
||||
<ul class="tight-form-list"> |
||||
<li class="tight-form-item" style="width: 100px"> |
||||
{{stat.text}} |
||||
</li> |
||||
<li class="tight-form-item last"> |
||||
<editor-checkbox text="" model="agg.meta.{{stat.value}}" change="onChange()"></editor-checkbox> |
||||
</li> |
||||
</ul> |
||||
<div class="clearfix"></div> |
||||
</div> |
||||
</div> |
||||
<div class="tight-form" ng-if="agg.type === 'extended_stats'"> |
||||
<ul class="tight-form-list"> |
||||
<li class="tight-form-item" style="width: 100px"> |
||||
Sigma |
||||
</li> |
||||
<li> |
||||
<input type="number" class="input-mini tight-form-input last" placeholder="3" ng-model="agg.settings.sigma" ng-blur="onChange()"></input> |
||||
</li> |
||||
</ul> |
||||
<div class="clearfix"></div> |
||||
</div> |
||||
<div class="gf-form" ng-if="agg.type === 'moving_avg'"> |
||||
<label class="gf-form-label width-8">Window</label> |
||||
<input type="number" class="gf-form-input max-width-10" ng-model="agg.settings.window" ng-blur="onChangeInternal()" spellcheck='false'> |
||||
</div> |
||||
|
||||
<div class="tight-form" ng-if="aggDef.supportsInlineScript"> |
||||
<ul class="tight-form-list"> |
||||
<li class="tight-form-item" style="width: 100px;"> |
||||
Script |
||||
</li> |
||||
<li> |
||||
<input type="text" class="input-medium tight-form-input last" empty-to-null ng-model="agg.inlineScript" ng-blur="onChangeInternal()" spellcheck='false' placeholder="_value * 1"> |
||||
</li> |
||||
</ul> |
||||
<div class="clearfix"></div> |
||||
</div> |
||||
<div class="gf-form" ng-if="agg.type === 'moving_avg'"> |
||||
<label class="gf-form-label width-8">Model</label> |
||||
<input type="text" class="gf-form-input max-width-10" ng-change="onChangeInternal()" ng-model="agg.settings.model" blur="onChange()" spellcheck='false'> |
||||
</div> |
||||
|
||||
<div class="gf-form" ng-if="agg.type === 'percentiles'"> |
||||
<label class="gf-form-label">Percentiles</label> |
||||
<input type="text" class="gf-form-input max-width-25" ng-model="agg.settings.percents" array-join ng-blur="onChange()"></input> |
||||
</div> |
||||
|
||||
<div class="tight-form" ng-if="aggDef.supportsMissing"> |
||||
<ul class="tight-form-list"> |
||||
<li class="tight-form-item" style="width: 100px;"> |
||||
Missing |
||||
<tip>The missing parameter defines how documents that are missing a value should be treated. By default they will be ignored but it is also possible to treat them as if they had a value</tip> |
||||
<div ng-if="agg.type === 'extended_stats'"> |
||||
<div class="gf-form" ng-repeat="stat in extendedStats"> |
||||
<ul class="gf-form-list"> |
||||
<li class="tight-form-item" style="width: 100px"> |
||||
{{stat.text}} |
||||
</li> |
||||
<li> |
||||
<input type="number" class="input-medium tight-form-input last" empty-to-null ng-model="agg.settings.missing" ng-blur="onChangeInternal()" spellcheck='false'> |
||||
<li class="tight-form-item last"> |
||||
<editor-checkbox text="" model="agg.meta.{{stat.value}}" change="onChange()"></editor-checkbox> |
||||
</li> |
||||
</ul> |
||||
<div class="clearfix"></div> |
||||
</div> |
||||
</div> |
||||
<div class="tight-form" ng-if="agg.type === 'extended_stats'"> |
||||
<ul class="tight-form-list"> |
||||
<li class="tight-form-item" style="width: 100px"> |
||||
Sigma |
||||
</li> |
||||
<li> |
||||
<input type="number" class="input-mini tight-form-input last" placeholder="3" ng-model="agg.settings.sigma" ng-blur="onChange()"></input> |
||||
</li> |
||||
</ul> |
||||
<div class="clearfix"></div> |
||||
</div> |
||||
|
||||
<div class="tight-form" ng-if="aggDef.supportsInlineScript"> |
||||
<ul class="tight-form-list"> |
||||
<li class="tight-form-item" style="width: 100px;"> |
||||
Script |
||||
</li> |
||||
<li> |
||||
<input type="text" class="input-medium tight-form-input last" empty-to-null ng-model="agg.inlineScript" ng-blur="onChangeInternal()" spellcheck='false' placeholder="_value * 1"> |
||||
</li> |
||||
</ul> |
||||
<div class="clearfix"></div> |
||||
</div> |
||||
|
||||
<div class="tight-form" ng-if="aggDef.supportsMissing"> |
||||
<ul class="tight-form-list"> |
||||
<li class="tight-form-item" style="width: 100px;"> |
||||
Missing |
||||
<tip>The missing parameter defines how documents that are missing a value should be treated. By default they will be ignored but it is also possible to treat them as if they had a value</tip> |
||||
</li> |
||||
<li> |
||||
<input type="number" class="input-medium tight-form-input last" empty-to-null ng-model="agg.settings.missing" ng-blur="onChangeInternal()" spellcheck='false'> |
||||
</li> |
||||
</ul> |
||||
<div class="clearfix"></div> |
||||
</div> |
||||
|
||||
</div> |
||||
|
@ -1,36 +1,31 @@ |
||||
<query-editor-row ctrl="ctrl"></query-editor-row> |
||||
<query-editor-row query-ctrl="ctrl"> |
||||
|
||||
<div class="tight-form"> |
||||
<ul class="tight-form-list"> |
||||
<li class="tight-form-item query-keyword" style="width: 75px"> |
||||
Query |
||||
</li> |
||||
<li> |
||||
<input type="text" class="tight-form-input" style="width: 345px;" ng-model="ctrl.target.query" spellcheck='false' placeholder="Lucene query" ng-blur="ctrl.refresh()"> |
||||
</li> |
||||
<li class="tight-form-item query-keyword"> |
||||
Alias |
||||
</li> |
||||
<li> |
||||
<input type="text" class="tight-form-input" style="width: 200px;" ng-model="ctrl.target.alias" spellcheck='false' placeholder="alias patterns (empty = auto)" ng-blur="ctrl.refresh()"> |
||||
</li> |
||||
</ul> |
||||
</div> |
||||
<div class="gf-form-inline"> |
||||
<div class="gf-form gf-form-flex"> |
||||
<label class="gf-form-label query-keyword width-7">Query</label> |
||||
<input type="text" class="gf-form-input" ng-model="ctrl.target.query" spellcheck='false' placeholder="Lucene query" ng-blur="ctrl.refresh()"> |
||||
</div> |
||||
<div class="gf-form max-width-15"> |
||||
<label class="gf-form-label query-keyword">Alias</label> |
||||
<input type="text" class="gf-form-input" ng-model="ctrl.target.alias" spellcheck='false' placeholder="alias patterns (empty = auto)" ng-blur="ctrl.refresh()"> |
||||
</div> |
||||
</div> |
||||
|
||||
<div ng-repeat="agg in ctrl.target.metrics"> |
||||
<elastic-metric-agg |
||||
target="ctrl.target" index="$index" |
||||
get-fields="ctrl.getFields($fieldType)" |
||||
on-change="ctrl.queryUpdated()" |
||||
es-version="ctrl.esVersion"> |
||||
</elastic-metric-agg> |
||||
</div> |
||||
<div ng-repeat="agg in ctrl.target.metrics"> |
||||
<elastic-metric-agg |
||||
target="ctrl.target" index="$index" |
||||
get-fields="ctrl.getFields($fieldType)" |
||||
on-change="ctrl.queryUpdated()" |
||||
es-version="ctrl.esVersion"> |
||||
</elastic-metric-agg> |
||||
</div> |
||||
|
||||
<div ng-repeat="agg in ctrl.target.bucketAggs"> |
||||
<elastic-bucket-agg |
||||
target="ctrl.target" index="$index" |
||||
get-fields="ctrl.getFields($fieldType)" |
||||
on-change="ctrl.queryUpdated()"> |
||||
</elastic-bucket-agg> |
||||
</div> |
||||
<div ng-repeat="agg in ctrl.target.bucketAggs"> |
||||
<elastic-bucket-agg |
||||
target="ctrl.target" index="$index" |
||||
get-fields="ctrl.getFields($fieldType)" |
||||
on-change="ctrl.queryUpdated()"> |
||||
</elastic-bucket-agg> |
||||
</div> |
||||
|
||||
</query-editor-row> |
||||
|
Loading…
Reference in new issue