diff --git a/public/app/core/directives/dropdown_typeahead.js b/public/app/core/directives/dropdown_typeahead.js
deleted file mode 100644
index 9b677c95697..00000000000
--- a/public/app/core/directives/dropdown_typeahead.js
+++ /dev/null
@@ -1,236 +0,0 @@
-define([
- 'lodash',
- 'jquery',
- '../core_module',
-],
-function (_, $, coreModule) {
- 'use strict';
-
- coreModule.default.directive('dropdownTypeahead', function($compile) {
-
- var inputTemplate = '';
-
- var buttonTemplate = '';
-
- return {
- scope: {
- menuItems: "=dropdownTypeahead",
- dropdownTypeaheadOnSelect: "&dropdownTypeaheadOnSelect",
- model: '=ngModel'
- },
- link: function($scope, elem, attrs) {
- var $input = $(inputTemplate);
- var $button = $(buttonTemplate);
- $input.appendTo(elem);
- $button.appendTo(elem);
-
- if (attrs.linkText) {
- $button.html(attrs.linkText);
- }
-
- if (attrs.ngModel) {
- $scope.$watch('model', function(newValue) {
- _.each($scope.menuItems, function(item) {
- _.each(item.submenu, function(subItem) {
- if (subItem.value === newValue) {
- $button.html(subItem.text);
- }
- });
- });
- });
- }
-
- var typeaheadValues = _.reduce($scope.menuItems, function(memo, value, index) {
- if (!value.submenu) {
- value.click = 'menuItemSelected(' + index + ')';
- memo.push(value.text);
- } else {
- _.each(value.submenu, function(item, subIndex) {
- item.click = 'menuItemSelected(' + index + ',' + subIndex + ')';
- memo.push(value.text + ' ' + item.text);
- });
- }
- return memo;
- }, []);
-
- $scope.menuItemSelected = function(index, subIndex) {
- var menuItem = $scope.menuItems[index];
- var payload = {$item: menuItem};
- if (menuItem.submenu && subIndex !== void 0) {
- payload.$subItem = menuItem.submenu[subIndex];
- }
- $scope.dropdownTypeaheadOnSelect(payload);
- };
-
- $input.attr('data-provide', 'typeahead');
- $input.typeahead({
- source: typeaheadValues,
- minLength: 1,
- items: 10,
- updater: function (value) {
- var result = {};
- _.each($scope.menuItems, function(menuItem) {
- _.each(menuItem.submenu, function(submenuItem) {
- if (value === (menuItem.text + ' ' + submenuItem.text)) {
- result.$subItem = submenuItem;
- result.$item = menuItem;
- }
- });
- });
-
- if (result.$item) {
- $scope.$apply(function() {
- $scope.dropdownTypeaheadOnSelect(result);
- });
- }
-
- $input.trigger('blur');
- return '';
- }
- });
-
- $button.click(function() {
- $button.hide();
- $input.show();
- $input.focus();
- });
-
- $input.keyup(function() {
- elem.toggleClass('open', $input.val() === '');
- });
-
- $input.blur(function() {
- $input.hide();
- $input.val('');
- $button.show();
- $button.focus();
- // clicking the function dropdown menu won't
- // work if you remove class at once
- setTimeout(function() {
- elem.removeClass('open');
- }, 200);
- });
-
- $compile(elem.contents())($scope);
- }
- };
- });
-
- coreModule.default.directive('dropdownTypeahead2', function($compile) {
-
- var inputTemplate = '';
-
- var buttonTemplate = '';
-
- return {
- scope: {
- menuItems: "=dropdownTypeahead2",
- dropdownTypeaheadOnSelect: "&dropdownTypeaheadOnSelect",
- model: '=ngModel'
- },
- link: function($scope, elem, attrs) {
- var $input = $(inputTemplate);
- var $button = $(buttonTemplate);
- $input.appendTo(elem);
- $button.appendTo(elem);
-
- if (attrs.linkText) {
- $button.html(attrs.linkText);
- }
-
- if (attrs.ngModel) {
- $scope.$watch('model', function(newValue) {
- _.each($scope.menuItems, function(item) {
- _.each(item.submenu, function(subItem) {
- if (subItem.value === newValue) {
- $button.html(subItem.text);
- }
- });
- });
- });
- }
-
- var typeaheadValues = _.reduce($scope.menuItems, function(memo, value, index) {
- if (!value.submenu) {
- value.click = 'menuItemSelected(' + index + ')';
- memo.push(value.text);
- } else {
- _.each(value.submenu, function(item, subIndex) {
- item.click = 'menuItemSelected(' + index + ',' + subIndex + ')';
- memo.push(value.text + ' ' + item.text);
- });
- }
- return memo;
- }, []);
-
- $scope.menuItemSelected = function(index, subIndex) {
- var menuItem = $scope.menuItems[index];
- var payload = {$item: menuItem};
- if (menuItem.submenu && subIndex !== void 0) {
- payload.$subItem = menuItem.submenu[subIndex];
- }
- $scope.dropdownTypeaheadOnSelect(payload);
- };
-
- $input.attr('data-provide', 'typeahead');
- $input.typeahead({
- source: typeaheadValues,
- minLength: 1,
- items: 10,
- updater: function (value) {
- var result = {};
- _.each($scope.menuItems, function(menuItem) {
- _.each(menuItem.submenu, function(submenuItem) {
- if (value === (menuItem.text + ' ' + submenuItem.text)) {
- result.$subItem = submenuItem;
- result.$item = menuItem;
- }
- });
- });
-
- if (result.$item) {
- $scope.$apply(function() {
- $scope.dropdownTypeaheadOnSelect(result);
- });
- }
-
- $input.trigger('blur');
- return '';
- }
- });
-
- $button.click(function() {
- $button.hide();
- $input.show();
- $input.focus();
- });
-
- $input.keyup(function() {
- elem.toggleClass('open', $input.val() === '');
- });
-
- $input.blur(function() {
- $input.hide();
- $input.val('');
- $button.show();
- $button.focus();
- // clicking the function dropdown menu won't
- // work if you remove class at once
- setTimeout(function() {
- elem.removeClass('open');
- }, 200);
- });
-
- $compile(elem.contents())($scope);
- }
- };
- });
-});
diff --git a/public/app/core/directives/dropdown_typeahead.ts b/public/app/core/directives/dropdown_typeahead.ts
index 03f80f10ca7..c9e44c5e786 100644
--- a/public/app/core/directives/dropdown_typeahead.ts
+++ b/public/app/core/directives/dropdown_typeahead.ts
@@ -110,7 +110,7 @@ export function dropdownTypeahead($compile) {
$input.val('');
$button.show();
$button.focus();
- // clicking the function dropdown menu wont
+ // clicking the function dropdown menu won't
// work if you remove class at once
setTimeout(function() {
elem.removeClass('open');
@@ -228,7 +228,7 @@ export function dropdownTypeahead2($compile) {
$input.val('');
$button.show();
$button.focus();
- // clicking the function dropdown menu wont
+ // clicking the function dropdown menu won't
// work if you remove class at once
setTimeout(function() {
elem.removeClass('open');