|
|
@@ -1,127 +0,0 @@
|
|
|
-define([
|
|
|
- 'angular',
|
|
|
- 'lodash',
|
|
|
- '../core_module',
|
|
|
- 'app/core/config',
|
|
|
-],
|
|
|
-function (angular, _, coreModule, config) {
|
|
|
- 'use strict';
|
|
|
-
|
|
|
- coreModule.default.controller('SearchCtrl', function($scope, $location, $timeout, backendSrv) {
|
|
|
-
|
|
|
- $scope.init = function() {
|
|
|
- $scope.giveSearchFocus = 0;
|
|
|
- $scope.selectedIndex = -1;
|
|
|
- $scope.results = [];
|
|
|
- $scope.query = { query: '', tag: [], starred: false };
|
|
|
- $scope.currentSearchId = 0;
|
|
|
-
|
|
|
- $timeout(function() {
|
|
|
- $scope.giveSearchFocus = $scope.giveSearchFocus + 1;
|
|
|
- $scope.query.query = '';
|
|
|
- $scope.search();
|
|
|
- }, 100);
|
|
|
- };
|
|
|
-
|
|
|
- $scope.keyDown = function (evt) {
|
|
|
- if (evt.keyCode === 27) {
|
|
|
- $scope.dismiss();
|
|
|
- }
|
|
|
- if (evt.keyCode === 40) {
|
|
|
- $scope.moveSelection(1);
|
|
|
- }
|
|
|
- if (evt.keyCode === 38) {
|
|
|
- $scope.moveSelection(-1);
|
|
|
- }
|
|
|
- if (evt.keyCode === 13) {
|
|
|
- if ($scope.tagMode) {
|
|
|
- var tag = $scope.results[$scope.selectedIndex];
|
|
|
- if (tag) {
|
|
|
- $scope.filterByTag(tag.term);
|
|
|
- }
|
|
|
- return;
|
|
|
- }
|
|
|
-
|
|
|
- var selectedDash = $scope.results[$scope.selectedIndex];
|
|
|
- if (selectedDash) {
|
|
|
- $location.search({});
|
|
|
- $location.path(selectedDash.url);
|
|
|
- }
|
|
|
- }
|
|
|
- };
|
|
|
-
|
|
|
- $scope.moveSelection = function(direction) {
|
|
|
- var max = ($scope.results || []).length;
|
|
|
- var newIndex = $scope.selectedIndex + direction;
|
|
|
- $scope.selectedIndex = ((newIndex %= max) < 0) ? newIndex + max : newIndex;
|
|
|
- };
|
|
|
-
|
|
|
- $scope.searchDashboards = function() {
|
|
|
- $scope.tagsMode = false;
|
|
|
- $scope.currentSearchId = $scope.currentSearchId + 1;
|
|
|
- var localSearchId = $scope.currentSearchId;
|
|
|
-
|
|
|
- return backendSrv.search($scope.query).then(function(results) {
|
|
|
- if (localSearchId < $scope.currentSearchId) { return; }
|
|
|
-
|
|
|
- $scope.results = _.map(results, function(dash) {
|
|
|
- dash.url = 'dashboard/' + dash.uri;
|
|
|
- return dash;
|
|
|
- });
|
|
|
-
|
|
|
- if ($scope.queryHasNoFilters()) {
|
|
|
- $scope.results.unshift({ title: 'Home', url: config.appSubUrl + '/', type: 'dash-home' });
|
|
|
- }
|
|
|
- });
|
|
|
- };
|
|
|
-
|
|
|
- $scope.queryHasNoFilters = function() {
|
|
|
- var query = $scope.query;
|
|
|
- return query.query === '' && query.starred === false && query.tag.length === 0;
|
|
|
- };
|
|
|
-
|
|
|
- $scope.filterByTag = function(tag, evt) {
|
|
|
- $scope.query.tag.push(tag);
|
|
|
- $scope.search();
|
|
|
- $scope.giveSearchFocus = $scope.giveSearchFocus + 1;
|
|
|
- if (evt) {
|
|
|
- evt.stopPropagation();
|
|
|
- evt.preventDefault();
|
|
|
- }
|
|
|
- };
|
|
|
-
|
|
|
- $scope.removeTag = function(tag, evt) {
|
|
|
- $scope.query.tag = _.without($scope.query.tag, tag);
|
|
|
- $scope.search();
|
|
|
- $scope.giveSearchFocus = $scope.giveSearchFocus + 1;
|
|
|
- evt.stopPropagation();
|
|
|
- evt.preventDefault();
|
|
|
- };
|
|
|
-
|
|
|
- $scope.getTags = function() {
|
|
|
- return backendSrv.get('/api/dashboards/tags').then(function(results) {
|
|
|
- $scope.tagsMode = true;
|
|
|
- $scope.results = results;
|
|
|
- $scope.giveSearchFocus = $scope.giveSearchFocus + 1;
|
|
|
- });
|
|
|
- };
|
|
|
-
|
|
|
- $scope.showStarred = function() {
|
|
|
- $scope.query.starred = !$scope.query.starred;
|
|
|
- $scope.giveSearchFocus = $scope.giveSearchFocus + 1;
|
|
|
- $scope.search();
|
|
|
- };
|
|
|
-
|
|
|
- $scope.search = function() {
|
|
|
- $scope.showImport = false;
|
|
|
- $scope.selectedIndex = 0;
|
|
|
- $scope.searchDashboards();
|
|
|
- };
|
|
|
-
|
|
|
- $scope.newDashboard = function() {
|
|
|
- $location.url('dashboard/new');
|
|
|
- };
|
|
|
-
|
|
|
- });
|
|
|
-
|
|
|
-});
|