Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
N
nexpie-grafana-theme
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Registry
Registry
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Kornkitt Poolsup
nexpie-grafana-theme
Commits
d6185260
Commit
d6185260
authored
Jul 01, 2015
by
Adam Heinz
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Copy/paste influxdb query editor.
parent
a1dcd5f0
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
536 additions
and
6 deletions
+536
-6
public/app/plugins/datasource/elasticsearch/datasource.js
+3
-5
public/app/plugins/datasource/elasticsearch/partials/query.editor.html
+243
-0
public/app/plugins/datasource/elasticsearch/plugin.json
+1
-0
public/app/plugins/datasource/elasticsearch/queryBuilder.js
+0
-1
public/app/plugins/datasource/elasticsearch/queryCtrl.js
+289
-0
No files found.
public/app/plugins/datasource/elasticsearch/datasource.js
View file @
d6185260
...
...
@@ -5,6 +5,7 @@ define([
'kbn'
,
'moment'
,
'./queryBuilder'
,
'./queryCtrl'
,
'./directives'
],
function
(
angular
,
_
,
config
,
kbn
,
moment
,
ElasticQueryBuilder
)
{
...
...
@@ -295,21 +296,18 @@ function (angular, _, config, kbn, moment, ElasticQueryBuilder) {
ElasticDatasource
.
prototype
.
query
=
function
(
options
)
{
var
self
=
this
;
var
allQueries
=
_
.
map
(
options
.
targets
,
function
(
target
)
{
var
allQueries
=
options
.
targets
.
map
(
function
(
target
)
{
if
(
target
.
hide
)
{
return
[];
}
var
queryBuilder
=
new
ElasticQueryBuilder
(
target
);
var
query
=
queryBuilder
.
build
();
query
=
query
.
replace
(
/
\$
interval/g
,
target
.
interval
||
options
.
interval
);
query
=
query
.
replace
(
/
\$
rangeFrom/g
,
options
.
range
.
from
);
query
=
query
.
replace
(
/
\$
rangeTo/g
,
options
.
range
.
to
);
query
=
query
.
replace
(
/
\$
maxDataPoints/g
,
options
.
maxDataPoints
);
query
=
templateSrv
.
replace
(
query
,
options
.
scopedVars
);
return
query
;
}).
join
(
"
\
n"
);
// replace templated variables
// allQueries = templateSrv.replace(allQueries, options.scopedVars);
return
this
.
_post
(
'/_search?search_type=count'
,
allQueries
).
then
(
function
(
results
)
{
if
(
!
results
||
!
results
.
facets
)
{
return
{
data
:
[]
};
...
...
public/app/plugins/datasource/elasticsearch/partials/query.editor.html
0 → 100644
View file @
d6185260
<div
class=
"editor-row"
>
<div
ng-repeat=
"target in panel.targets"
ng-controller=
"ElasticQueryCtrl"
ng-init=
"init()"
ng-class=
"{'tight-form-disabled': target.hide}"
class=
"tight-form-container-no-item-borders"
style=
"margin-bottom: 10px"
>
<div
class=
"tight-form"
>
<ul
class=
"tight-form-list pull-right"
>
<li
ng-show=
"parserError"
class=
"tight-form-item"
>
<a
bs-tooltip=
"parserError"
style=
"color: rgb(229, 189, 28)"
role=
"menuitem"
>
<i
class=
"fa fa-warning"
></i>
</a>
</li>
<li
class=
"tight-form-item"
>
<a
class=
"pointer"
tabindex=
"1"
ng-click=
"toggleQueryMode()"
>
<i
class=
"fa fa-pencil"
></i>
</a>
</li>
<li
class=
"tight-form-item"
>
<div
class=
"dropdown"
>
<a
class=
"pointer dropdown-toggle"
data-toggle=
"dropdown"
tabindex=
"1"
>
<i
class=
"fa fa-bars"
></i>
</a>
<ul
class=
"dropdown-menu pull-right"
role=
"menu"
>
<li
role=
"menuitem"
>
<a
tabindex=
"1"
ng-click=
"duplicate()"
>
Duplicate
</a>
</li>
<li
role=
"menuitem"
>
<a
tabindex=
"1"
ng-click=
"moveMetricQuery($index, $index-1)"
>
Move up
</a>
</li>
<li
role=
"menuitem"
>
<a
tabindex=
"1"
ng-click=
"moveMetricQuery($index, $index+1)"
>
Move down
</a>
</li>
</ul>
</div>
</li>
<li
class=
"tight-form-item last"
>
<a
class=
"pointer"
tabindex=
"1"
ng-click=
"removeDataQuery(target)"
>
<i
class=
"fa fa-remove"
></i>
</a>
</li>
</ul>
<ul
class=
"tight-form-list"
>
<li>
<a
class=
"tight-form-item"
ng-click=
"target.hide = !target.hide; get_data();"
role=
"menuitem"
>
<i
class=
"fa fa-eye"
></i>
</a>
</li>
</ul>
<input
type=
"text"
class=
"tight-form-clear-input"
style=
"width: 80%"
ng-model=
"target.query"
focus-me=
"target.rawQuery"
spellcheck=
'false'
ng-model-onblur
ng-change=
"get_data()"
ng-show=
"target.rawQuery"
/>
<ul
class=
"tight-form-list"
role=
"menu"
ng-hide=
"target.rawQuery"
>
<li
class=
"tight-form-item query-keyword"
style=
"width: 75px;"
>
SELECT
</li>
<li
class=
"dropdown tight-form-item"
>
<a
gf-dropdown=
"functionMenu"
class=
"dropdown-toggle"
data-toggle=
"dropdown"
>
{{target.function}}
<span>
(value)
</span>
</a>
</li>
</ul>
<div
class=
"clearfix"
></div>
</div>
<div
class=
"tight-form"
ng-hide=
"target.rawQuery"
>
<ul
class=
"tight-form-list"
>
<li
class=
"tight-form-item"
>
<i
class=
"fa fa-eye invisible"
></i>
</li>
<li
class=
"tight-form-item query-keyword"
style=
"width: 75px;"
>
FROM
</li>
<li>
<metric-segment
segment=
"measurementSegment"
get-alt-segments=
"getMeasurements()"
on-value-changed=
"measurementChanged()"
></metric-segment>
</li>
</ul>
<div
class=
"clearfix"
></div>
</div>
<div
class=
"tight-form"
ng-hide=
"target.rawQuery"
>
<ul
class=
"tight-form-list"
>
<li
class=
"tight-form-item"
>
<i
class=
"fa fa-eye invisible"
></i>
</li>
<li
class=
"tight-form-item query-keyword"
style=
"width: 75px;"
>
WHERE
</li>
<li
ng-repeat=
"segment in tagSegments"
>
<metric-segment
segment=
"segment"
get-alt-segments=
"getTagsOrValues(segment, $index)"
on-value-changed=
"tagSegmentUpdated(segment, $index)"
></metric-segment>
</li>
</ul>
<div
class=
"clearfix"
></div>
</div>
<div
class=
"tight-form"
>
<ul
class=
"tight-form-list"
ng-hide=
"target.rawQuery"
>
<li
class=
"tight-form-item"
>
<i
class=
"fa fa-eye invisible"
></i>
</li>
<li
class=
"tight-form-item"
>
<span
class=
"query-keyword"
>
GROUP BY
</span>
</li>
<li
class=
"tight-form-item"
>
time($interval)
</li>
<li
ng-repeat=
"segment in groupBySegments"
>
<metric-segment
segment=
"segment"
get-alt-segments=
"getGroupByTagSegments(segment, 0)"
on-value-changed=
"groupByTagUpdated(segment, $index)"
></metric-segment>
</li>
<li
class=
"dropdown"
>
<a
class=
"tight-form-item pointer"
data-toggle=
"dropdown"
bs-tooltip=
"'Insert missing values, important when stacking'"
data-placement=
"right"
>
<span
ng-show=
"target.fill"
>
fill ({{target.fill}})
</span>
<span
ng-show=
"!target.fill"
>
no fill
</span>
</a>
<ul
class=
"dropdown-menu"
>
<li><a
ng-click=
"target.fill = ''"
>
no fill
</a></li>
<li><a
ng-click=
"target.fill = 'null'"
>
fill (null)
</a></li>
<li><a
ng-click=
"target.fill = '0'"
>
fill (0)
</a></li>
</ul>
</li>
</ul>
<ul
class=
"tight-form-list pull-right"
>
<li
class=
"tight-form-item"
>
Alias pattern
</li>
<li>
<input
type=
"text"
class=
"input-medium tight-form-input"
ng-model=
"target.alias"
spellcheck=
'false'
placeholder=
"alias"
ng-blur=
"get_data()"
>
</li>
</ul>
<div
class=
"clearfix"
></div>
</div>
</div>
</div>
<section
class=
"grafana-metric-options"
>
<div
class=
"tight-form"
>
<ul
class=
"tight-form-list"
>
<li
class=
"tight-form-item tight-form-item-icon"
>
<i
class=
"fa fa-wrench"
></i>
</li>
<li
class=
"tight-form-item"
>
Group by time interval
</li>
<li>
<input
type=
"text"
class=
"input-medium tight-form-input"
ng-model=
"panel.interval"
ng-blur=
"get_data();"
spellcheck=
'false'
placeholder=
"example: >10s"
>
</li>
<li
class=
"tight-form-item"
>
<i
class=
"fa fa-question-circle"
bs-tooltip=
"'Set a low limit by having a greater sign: example: >60s'"
data-placement=
"right"
></i>
</li>
</ul>
<div
class=
"clearfix"
></div>
</div>
<div
class=
"tight-form"
>
<ul
class=
"tight-form-list"
>
<li
class=
"tight-form-item tight-form-item-icon"
>
<i
class=
"fa fa-info-circle"
></i>
</li>
<li
class=
"tight-form-item"
>
<a
ng-click=
"toggleEditorHelp(1);"
bs-tooltip=
"'click to show helpful info'"
data-placement=
"bottom"
>
alias patterns
</a>
</li>
<li
class=
"tight-form-item"
>
<a
ng-click=
"toggleEditorHelp(2)"
bs-tooltip=
"'click to show helpful info'"
data-placement=
"bottom"
>
stacking
&
and fill
</a>
</li>
<li
class=
"tight-form-item"
>
<a
ng-click=
"toggleEditorHelp(3)"
bs-tooltip=
"'click to show helpful info'"
data-placement=
"bottom"
>
group by time
</a>
</li>
</ul>
<div
class=
"clearfix"
></div>
</div>
</section>
<div
class=
"editor-row"
>
<div
class=
"pull-left"
style=
"margin-top: 30px;"
>
<div
class=
"grafana-info-box span6"
ng-if=
"editorHelpIndex === 1"
>
<h5>
Alias patterns
</h5>
<ul>
<li>
$m = replaced with measurement name
</li>
<li>
$measurement = replaced with measurement name
</li>
<li>
$tag_hostname = replaced with the value of the hostname tag
</li>
<li>
You can also use [[tag_hostname]] pattern replacement syntax
</li>
</ul>
</div>
<div
class=
"grafana-info-box span6"
ng-if=
"editorHelpIndex === 2"
>
<h5>
Stacking and fill
</h5>
<ul>
<li>
When stacking is enabled it important that points align
</li>
<li>
If there are missing points for one series it can cause gaps or missing bars
</li>
<li>
You must use fill(0), and select a group by time low limit
</li>
<li>
Use the group by time option below your queries and specify for example
>
10s if your metrics are written every 10 seconds
</li>
<li>
This will insert zeros for series that are missing measurements and will make stacking work properly
</li>
</ul>
</div>
<div
class=
"grafana-info-box span6"
ng-if=
"editorHelpIndex === 3"
>
<h5>
Group by time
</h5>
<ul>
<li>
Group by time is important, otherwise the query could return many thousands of datapoints that will slow down Grafana
</li>
<li>
Leave the group by time field empty for each query and it will be calculated based on time range and pixel width of the graph
</li>
<li>
If you use fill(0) or fill(null) set a low limit for the auto group by time interval
</li>
<li>
The low limit can only be set in the group by time option below your queries
</li>
<li>
You set a low limit by adding a greater sign before the interval
</li>
<li>
Example:
>
60s if you write metrics to ElasticDB every 60 seconds
</li>
</ul>
</div>
</div>
</div>
public/app/plugins/datasource/elasticsearch/plugin.json
View file @
d6185260
...
...
@@ -9,6 +9,7 @@
"partials"
:
{
"config"
:
"app/plugins/datasource/elasticsearch/partials/config.html"
,
"query"
:
"app/plugins/datasource/elasticsearch/partials/query.editor.html"
,
"annotations"
:
"app/plugins/datasource/elasticsearch/partials/annotations.editor.html"
},
...
...
public/app/plugins/datasource/elasticsearch/queryBuilder.js
View file @
d6185260
...
...
@@ -20,7 +20,6 @@ function () {
}
}
},
"fields"
:
[],
"query"
:
{
"filtered"
:
{
"filter"
:
{
...
...
public/app/plugins/datasource/elasticsearch/queryCtrl.js
0 → 100644
View file @
d6185260
define
([
'angular'
,
'lodash'
,
'./queryBuilder'
,
],
function
(
angular
,
_
,
ElasticQueryBuilder
)
{
'use strict'
;
var
module
=
angular
.
module
(
'grafana.controllers'
);
module
.
controller
(
'ElasticQueryCtrl'
,
function
(
$scope
,
$timeout
,
$sce
,
templateSrv
,
$q
)
{
$scope
.
functionList
=
[
'count'
,
'min'
,
'max'
,
'total'
,
'mean'
];
$scope
.
functionMenu
=
_
.
map
(
$scope
.
functionList
,
function
(
func
)
{
return
{
text
:
func
,
click
:
"changeFunction('"
+
func
+
"');"
};
});
$scope
.
init
=
function
()
{
var
target
=
$scope
.
target
;
target
.
function
=
target
.
function
||
'mean'
;
target
.
tags
=
target
.
tags
||
[];
target
.
groupByTags
=
target
.
groupByTags
||
[];
$scope
.
queryBuilder
=
new
ElasticQueryBuilder
(
target
);
if
(
!
target
.
measurement
)
{
$scope
.
measurementSegment
=
MetricSegment
.
newSelectMeasurement
();
}
else
{
$scope
.
measurementSegment
=
new
MetricSegment
(
target
.
measurement
);
}
$scope
.
tagSegments
=
[];
_
.
each
(
target
.
tags
,
function
(
tag
)
{
if
(
tag
.
condition
)
{
$scope
.
tagSegments
.
push
(
MetricSegment
.
newCondition
(
tag
.
condition
));
}
$scope
.
tagSegments
.
push
(
new
MetricSegment
({
value
:
tag
.
key
,
type
:
'key'
,
cssClass
:
'query-segment-key'
}));
$scope
.
tagSegments
.
push
(
new
MetricSegment
.
newOperator
(
"="
));
$scope
.
tagSegments
.
push
(
new
MetricSegment
({
value
:
tag
.
value
,
type
:
'value'
,
cssClass
:
'query-segment-value'
}));
});
$scope
.
fixTagSegments
();
$scope
.
groupBySegments
=
[];
_
.
each
(
target
.
groupByTags
,
function
(
tag
)
{
$scope
.
groupBySegments
.
push
(
new
MetricSegment
(
tag
));
});
$scope
.
groupBySegments
.
push
(
MetricSegment
.
newPlusButton
());
$scope
.
removeTagFilterSegment
=
new
MetricSegment
({
fake
:
true
,
value
:
'-- remove tag filter --'
});
$scope
.
removeGroupBySegment
=
new
MetricSegment
({
fake
:
true
,
value
:
'-- remove group by --'
});
};
$scope
.
fixTagSegments
=
function
()
{
var
count
=
$scope
.
tagSegments
.
length
;
var
lastSegment
=
$scope
.
tagSegments
[
Math
.
max
(
count
-
1
,
0
)];
if
(
!
lastSegment
||
lastSegment
.
type
!==
'plus-button'
)
{
$scope
.
tagSegments
.
push
(
MetricSegment
.
newPlusButton
());
}
};
$scope
.
groupByTagUpdated
=
function
(
segment
,
index
)
{
if
(
segment
.
value
===
$scope
.
removeGroupBySegment
.
value
)
{
$scope
.
target
.
groupByTags
.
splice
(
index
,
1
);
$scope
.
groupBySegments
.
splice
(
index
,
1
);
$scope
.
$parent
.
get_data
();
return
;
}
if
(
index
===
$scope
.
groupBySegments
.
length
-
1
)
{
$scope
.
groupBySegments
.
push
(
MetricSegment
.
newPlusButton
());
}
segment
.
type
=
'group-by-key'
;
segment
.
fake
=
false
;
$scope
.
target
.
groupByTags
[
index
]
=
segment
.
value
;
$scope
.
$parent
.
get_data
();
};
$scope
.
changeFunction
=
function
(
func
)
{
$scope
.
target
.
function
=
func
;
$scope
.
$parent
.
get_data
();
};
$scope
.
measurementChanged
=
function
()
{
$scope
.
target
.
measurement
=
$scope
.
measurementSegment
.
value
;
$scope
.
$parent
.
get_data
();
};
$scope
.
toggleQueryMode
=
function
()
{
$scope
.
target
.
rawQuery
=
!
$scope
.
target
.
rawQuery
;
};
$scope
.
moveMetricQuery
=
function
(
fromIndex
,
toIndex
)
{
_
.
move
(
$scope
.
panel
.
targets
,
fromIndex
,
toIndex
);
};
$scope
.
duplicate
=
function
()
{
var
clone
=
angular
.
copy
(
$scope
.
target
);
$scope
.
panel
.
targets
.
push
(
clone
);
};
$scope
.
getMeasurements
=
function
()
{
var
query
=
$scope
.
queryBuilder
.
buildExploreQuery
(
'MEASUREMENTS'
);
return
$scope
.
datasource
.
metricFindQuery
(
query
)
.
then
(
$scope
.
transformToSegments
)
.
then
(
$scope
.
addTemplateVariableSegments
)
.
then
(
null
,
$scope
.
handleQueryError
);
};
$scope
.
handleQueryError
=
function
(
err
)
{
$scope
.
parserError
=
err
.
message
||
'Failed to issue metric query'
;
return
[];
};
$scope
.
transformToSegments
=
function
(
results
)
{
return
_
.
map
(
results
,
function
(
segment
)
{
return
new
MetricSegment
({
value
:
segment
.
text
,
expandable
:
segment
.
expandable
});
});
};
$scope
.
addTemplateVariableSegments
=
function
(
segments
)
{
_
.
each
(
templateSrv
.
variables
,
function
(
variable
)
{
segments
.
unshift
(
new
MetricSegment
({
type
:
'template'
,
value
:
'$'
+
variable
.
name
,
expandable
:
true
}));
});
return
segments
;
};
$scope
.
getTagsOrValues
=
function
(
segment
,
index
)
{
var
query
;
if
(
segment
.
type
===
'key'
||
segment
.
type
===
'plus-button'
)
{
query
=
$scope
.
queryBuilder
.
buildExploreQuery
(
'TAG_KEYS'
);
}
else
if
(
segment
.
type
===
'value'
)
{
query
=
$scope
.
queryBuilder
.
buildExploreQuery
(
'TAG_VALUES'
,
$scope
.
tagSegments
[
index
-
2
].
value
);
}
else
if
(
segment
.
type
===
'condition'
)
{
return
$q
.
when
([
new
MetricSegment
(
'AND'
),
new
MetricSegment
(
'OR'
)]);
}
else
{
return
$q
.
when
([]);
}
return
$scope
.
datasource
.
metricFindQuery
(
query
)
.
then
(
$scope
.
transformToSegments
)
.
then
(
$scope
.
addTemplateVariableSegments
)
.
then
(
function
(
results
)
{
if
(
segment
.
type
===
'key'
)
{
results
.
splice
(
0
,
0
,
angular
.
copy
(
$scope
.
removeTagFilterSegment
));
}
return
results
;
})
.
then
(
null
,
$scope
.
handleQueryError
);
};
$scope
.
getGroupByTagSegments
=
function
(
segment
)
{
var
query
=
$scope
.
queryBuilder
.
buildExploreQuery
(
'TAG_KEYS'
);
return
$scope
.
datasource
.
metricFindQuery
(
query
)
.
then
(
$scope
.
transformToSegments
)
.
then
(
$scope
.
addTemplateVariableSegments
)
.
then
(
function
(
results
)
{
if
(
segment
.
type
!==
'plus-button'
)
{
results
.
splice
(
0
,
0
,
angular
.
copy
(
$scope
.
removeGroupBySegment
));
}
return
results
;
})
.
then
(
null
,
$scope
.
handleQueryError
);
};
$scope
.
tagSegmentUpdated
=
function
(
segment
,
index
)
{
$scope
.
tagSegments
[
index
]
=
segment
;
// handle remove tag condition
if
(
segment
.
value
===
$scope
.
removeTagFilterSegment
.
value
)
{
$scope
.
tagSegments
.
splice
(
index
,
3
);
if
(
$scope
.
tagSegments
.
length
===
0
)
{
$scope
.
tagSegments
.
push
(
MetricSegment
.
newPlusButton
());
}
else
if
(
$scope
.
tagSegments
.
length
>
2
)
{
$scope
.
tagSegments
.
splice
(
Math
.
max
(
index
-
1
,
0
),
1
);
if
(
$scope
.
tagSegments
[
$scope
.
tagSegments
.
length
-
1
].
type
!==
'plus-button'
)
{
$scope
.
tagSegments
.
push
(
MetricSegment
.
newPlusButton
());
}
}
}
else
{
if
(
segment
.
type
===
'plus-button'
)
{
if
(
index
>
2
)
{
$scope
.
tagSegments
.
splice
(
index
,
0
,
MetricSegment
.
newCondition
(
'AND'
));
}
$scope
.
tagSegments
.
push
(
MetricSegment
.
newOperator
(
'='
));
$scope
.
tagSegments
.
push
(
MetricSegment
.
newFake
(
'select tag value'
,
'value'
,
'query-segment-value'
));
segment
.
type
=
'key'
;
segment
.
cssClass
=
'query-segment-key'
;
}
if
((
index
+
1
)
===
$scope
.
tagSegments
.
length
)
{
$scope
.
tagSegments
.
push
(
MetricSegment
.
newPlusButton
());
}
}
$scope
.
rebuildTargetTagConditions
();
};
$scope
.
rebuildTargetTagConditions
=
function
()
{
var
tags
=
[];
var
tagIndex
=
0
;
_
.
each
(
$scope
.
tagSegments
,
function
(
segment2
,
index
)
{
if
(
segment2
.
type
===
'key'
)
{
if
(
tags
.
length
===
0
)
{
tags
.
push
({});
}
tags
[
tagIndex
].
key
=
segment2
.
value
;
}
else
if
(
segment2
.
type
===
'value'
)
{
tags
[
tagIndex
].
value
=
segment2
.
value
;
$scope
.
tagSegments
[
index
-
1
]
=
$scope
.
getTagValueOperator
(
segment2
.
value
);
}
else
if
(
segment2
.
type
===
'condition'
)
{
tags
.
push
({
condition
:
segment2
.
value
});
tagIndex
+=
1
;
}
});
$scope
.
target
.
tags
=
tags
;
$scope
.
$parent
.
get_data
();
};
$scope
.
getTagValueOperator
=
function
(
tagValue
)
{
if
(
tagValue
[
0
]
===
'/'
&&
tagValue
[
tagValue
.
length
-
1
]
===
'/'
)
{
return
MetricSegment
.
newOperator
(
'=~'
);
}
return
MetricSegment
.
newOperator
(
'='
);
};
function
MetricSegment
(
options
)
{
if
(
options
===
'*'
||
options
.
value
===
'*'
)
{
this
.
value
=
'*'
;
this
.
html
=
$sce
.
trustAsHtml
(
'<i class="fa fa-asterisk"><i>'
);
this
.
expandable
=
true
;
return
;
}
if
(
_
.
isString
(
options
))
{
this
.
value
=
options
;
this
.
html
=
$sce
.
trustAsHtml
(
this
.
value
);
return
;
}
this
.
cssClass
=
options
.
cssClass
;
this
.
type
=
options
.
type
;
this
.
fake
=
options
.
fake
;
this
.
value
=
options
.
value
;
this
.
type
=
options
.
type
;
this
.
expandable
=
options
.
expandable
;
this
.
html
=
options
.
html
||
$sce
.
trustAsHtml
(
templateSrv
.
highlightVariablesAsHtml
(
this
.
value
));
}
MetricSegment
.
newSelectMeasurement
=
function
()
{
return
new
MetricSegment
({
value
:
'select measurement'
,
fake
:
true
});
};
MetricSegment
.
newFake
=
function
(
text
,
type
,
cssClass
)
{
return
new
MetricSegment
({
value
:
text
,
fake
:
true
,
type
:
type
,
cssClass
:
cssClass
});
};
MetricSegment
.
newCondition
=
function
(
condition
)
{
return
new
MetricSegment
({
value
:
condition
,
type
:
'condition'
,
cssClass
:
'query-keyword'
});
};
MetricSegment
.
newOperator
=
function
(
op
)
{
return
new
MetricSegment
({
value
:
op
,
type
:
'operator'
,
cssClass
:
'query-segment-operator'
});
};
MetricSegment
.
newPlusButton
=
function
()
{
return
new
MetricSegment
({
fake
:
true
,
html
:
'<i class="fa fa-plus "></i>'
,
type
:
'plus-button'
});
};
MetricSegment
.
newSelectTagValue
=
function
()
{
return
new
MetricSegment
({
value
:
'select tag value'
,
fake
:
true
});
};
});
});
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment