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
9d66d77d
Commit
9d66d77d
authored
Aug 14, 2013
by
Rashid Khan
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Retrieve fields from mapping when index changes. Use sort[] response to sort table fields
parent
e7203d40
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
81 additions
and
44 deletions
+81
-44
js/services.js
+71
-3
js/shared.js
+0
-33
panels/table/module.html
+2
-2
panels/table/module.js
+8
-6
No files found.
js/services.js
View file @
9d66d77d
...
...
@@ -4,15 +4,82 @@
'use strict'
;
angular
.
module
(
'kibana.services'
,
[])
.
service
(
'fields'
,
function
()
{
.
service
(
'fields'
,
function
(
dashboard
,
$rootScope
,
$http
)
{
// Save a reference to this
var
self
=
this
;
this
.
list
=
[
'_type'
];
this
.
mapping
=
{};
this
.
add_fields
=
function
(
f
)
{
self
.
list
=
_
.
union
(
f
,
self
.
list
);
//self.list = _.union(f,self.list);
};
$rootScope
.
$watch
(
function
(){
return
dashboard
.
indices
;},
function
(
n
)
{
if
(
!
_
.
isUndefined
(
n
)
&&
n
.
length
)
{
// Only get the mapping for indices we don't know it for
var
indices
=
_
.
difference
(
n
,
_
.
keys
(
self
.
mapping
));
// Only get the mapping if there are indices
if
(
indices
.
length
>
0
)
{
self
.
map
(
indices
).
then
(
function
(
result
)
{
self
.
mapping
=
_
.
extend
(
self
.
mapping
,
result
);
self
.
list
=
mapFields
(
self
.
mapping
);
});
// Otherwise just use the cached mapping
}
else
{
self
.
list
=
mapFields
(
_
.
pick
(
self
.
mapping
,
n
));
}
}
});
var
mapFields
=
function
(
m
)
{
var
fields
=
[];
_
.
each
(
m
,
function
(
types
,
index
)
{
_
.
each
(
types
,
function
(
v
,
k
)
{
fields
=
_
.
union
(
fields
,
_
.
keys
(
v
));
});
});
return
fields
;
};
this
.
map
=
function
(
indices
)
{
var
request
=
$http
({
url
:
config
.
elasticsearch
+
"/"
+
indices
.
join
(
','
)
+
"/_mapping"
,
method
:
"GET"
});
return
request
.
then
(
function
(
p
)
{
var
mapping
=
{};
_
.
each
(
p
.
data
,
function
(
v
,
k
)
{
mapping
[
k
]
=
{};
_
.
each
(
v
,
function
(
v
,
f
)
{
mapping
[
k
][
f
]
=
flatten
(
v
);
});
});
return
mapping
;
});
};
var
flatten
=
function
(
obj
,
prefix
)
{
var
propName
=
(
prefix
)
?
prefix
:
''
,
dot
=
(
prefix
)
?
'.'
:
''
,
ret
=
{};
for
(
var
attr
in
obj
){
// For now only support multi field on the top level
// and if if there is a default field set.
if
(
obj
[
attr
][
'type'
]
===
'multi_field'
)
{
ret
[
attr
]
=
obj
[
attr
][
'fields'
][
attr
]
||
obj
[
attr
];
continue
;
}
if
(
attr
===
'properties'
)
{
_
.
extend
(
ret
,
flatten
(
obj
[
attr
],
propName
));
}
else
if
(
typeof
obj
[
attr
]
===
'object'
){
_
.
extend
(
ret
,
flatten
(
obj
[
attr
],
propName
+
dot
+
attr
));
}
else
{
ret
[
propName
]
=
obj
;
}
}
return
ret
;
};
})
...
...
@@ -383,6 +450,7 @@ angular.module('kibana.services', [])
};
// This special function looks for all time filters, and returns a time range according to the mode
// No idea when max would actually be used
this
.
timeRange
=
function
(
mode
)
{
var
_t
=
_
.
where
(
self
.
list
,{
type
:
'time'
,
active
:
true
});
if
(
_t
.
length
===
0
)
{
...
...
js/shared.js
View file @
9d66d77d
...
...
@@ -71,39 +71,6 @@
return
value
;
};
// Probably useless now, leaving for cases where you might not want
// a flat dot notated data structure
kbn
.
get_field_value
=
function
(
object
,
field
,
opt
)
{
var
value
=
kbn
.
recurse_field_dots
(
object
.
_source
,
field
);
if
(
value
===
null
)
{
return
''
;
}
if
(
_
.
isArray
(
value
))
{
if
(
opt
===
'raw'
)
{
return
value
;
}
else
{
var
complex
=
false
;
_
.
each
(
value
,
function
(
el
,
index
)
{
if
(
typeof
(
el
)
===
'object'
)
{
complex
=
true
;
}
});
if
(
complex
)
{
return
JSON
.
stringify
(
value
,
null
,
4
);
}
return
value
.
toString
();
}
}
if
(
typeof
value
===
'object'
&&
value
!==
null
)
{
// Leaving this out for now
//return opt == 'raw' ? value : JSON.stringify(value,null,4)
return
JSON
.
stringify
(
value
,
null
,
4
);
}
return
(
value
!==
null
)
?
value
.
toString
()
:
''
;
};
kbn
.
top_field_values
=
function
(
docs
,
field
,
count
)
{
var
counts
=
_
.
countBy
(
_
.
pluck
(
docs
,
field
),
function
(
field
){
return
_
.
isUndefined
(
field
)
?
''
:
field
;
...
...
panels/table/module.html
View file @
9d66d77d
...
...
@@ -15,8 +15,8 @@
<div
ng-class=
"{'span3':panel.field_list}"
ng-show=
"panel.field_list"
>
<div
class=
"sidebar-nav"
>
<h5>
Fields
<i
class=
" icon-chevron-sign-left pointer "
ng-click=
"panel.field_list = !panel.field_list"
bs-tooltip=
"'Hide field list'"
ng-show=
"panel.field_list"
></i></h5>
<ul
class=
"unstyled"
style=
"
height:{{
row.height}};overflow-y:auto;overflow-x:hidden;"
>
<li
ng-style=
"panel.style"
ng-repeat=
"field in
all_fields
"
>
<ul
class=
"unstyled"
style=
"
{{panel.overflow}}:{{panel.height ||
row.height}};overflow-y:auto;overflow-x:hidden;"
>
<li
ng-style=
"panel.style"
ng-repeat=
"field in
fields.list
"
>
<i
class=
"pointer"
ng-class=
"{'icon-check': _.contains(panel.fields,field),'icon-check-empty': !_.contains(panel.fields,field)}"
ng-click=
"toggle_field(field)"
></i>
<a
data-unique=
"1"
bs-popover=
"'panels/table/micropanel.html'"
data-placement=
"right"
ng-click=
"toggle_micropanel(field)"
ng-class=
"{label: _.contains(panel.fields,field)}"
>
{{field}}
</a>
</li>
...
...
panels/table/module.js
View file @
9d66d77d
...
...
@@ -61,6 +61,7 @@ angular.module('kibana.table', [])
$scope
.
$on
(
'refresh'
,
function
(){
$scope
.
get_data
();});
$scope
.
fields
=
fields
;
$scope
.
get_data
();
};
...
...
@@ -188,7 +189,11 @@ angular.module('kibana.table', [])
$scope
.
data
=
$scope
.
data
.
concat
(
_
.
map
(
results
.
hits
.
hits
,
function
(
hit
)
{
return
{
_source
:
kbn
.
flatten_json
(
hit
.
_source
),
highlight
:
kbn
.
flatten_json
(
hit
.
highlight
||
{})
highlight
:
kbn
.
flatten_json
(
hit
.
highlight
||
{}),
_type
:
hit
.
_type
,
_index
:
hit
.
_index
,
_id
:
hit
.
_id
,
_sort
:
hit
.
sort
};
}));
...
...
@@ -196,7 +201,7 @@ angular.module('kibana.table', [])
// Sort the data
$scope
.
data
=
_
.
sortBy
(
$scope
.
data
,
function
(
v
){
return
v
.
_so
urce
[
$scope
.
panel
.
sort
[
0
]
];
return
v
.
_so
rt
[
0
];
});
// Reverse if needed
...
...
@@ -210,15 +215,12 @@ angular.module('kibana.table', [])
}
else
{
return
;
}
$scope
.
all_fields
=
kbn
.
get_all_fields
(
_
.
pluck
(
$scope
.
data
,
'_source'
));
fields
.
add_fields
(
$scope
.
all_fields
);
// If we're not sorting in reverse chrono order, query every index for
// size*pages results
// Otherwise, only get size*pages results then stop querying
//($scope.data.length < $scope.panel.size*$scope.panel.pages
// || !(($scope.panel.sort[0] === $scope.time.field) && $scope.panel.sort[1] === 'desc'))
// || !(($scope.panel.sort[0] === $scope.time.field) && $scope.panel.sort[1] === 'desc'))
if
(
$scope
.
data
.
length
<
$scope
.
panel
.
size
*
$scope
.
panel
.
pages
&&
_segment
+
1
<
dashboard
.
indices
.
length
)
{
$scope
.
get_data
(
_segment
+
1
,
$scope
.
query_id
);
...
...
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