From 1df8c044ee1e2490a3dd2c2532dc703d7baddaad Mon Sep 17 00:00:00 2001 From: Paulo Reis Date: Fri, 15 Jun 2018 11:27:24 +0100 Subject: [PATCH] Add component for auto-completing inputs. --- .../coffee/components/inputSuggestions.coffee | 49 +++++++++++++++++++ .../components/input-suggestions.less | 21 ++++++++ 2 files changed, 70 insertions(+) create mode 100644 services/web/public/coffee/components/inputSuggestions.coffee create mode 100644 services/web/public/stylesheets/components/input-suggestions.less diff --git a/services/web/public/coffee/components/inputSuggestions.coffee b/services/web/public/coffee/components/inputSuggestions.coffee new file mode 100644 index 0000000000..c5bfbbf933 --- /dev/null +++ b/services/web/public/coffee/components/inputSuggestions.coffee @@ -0,0 +1,49 @@ +define [ + "base" +], (App) -> + inputSuggestionsController = ($scope, $element, $attrs) -> + ctrl = @ + ctrl.showHint = false + ctrl.hasFocus = false + ctrl.handleFocus = () -> + ctrl.hasFocus = true + ctrl.suggestion = null + ctrl.handleBlur = () -> + ctrl.showHint = false + ctrl.hasFocus = false + ctrl.suggestion = null + ctrl.handleKeyDown = ($event) -> + if ($event.which == 9 or $event.which == 13) and ctrl.suggestion? and ctrl.suggestion != "" + $event.preventDefault() + ctrl.localNgModel += ctrl.suggestion + ctrl.suggestion = null + ctrl.showHint = false + + $scope.$watch "$ctrl.localNgModel", (newVal, oldVal) -> + if ctrl.hasFocus and newVal != oldVal + ctrl.suggestion = null + ctrl.showHint = false + ctrl.getSuggestion({ userInput: newVal }) + .then (suggestion) -> + if suggestion? and newVal == ctrl.localNgModel + ctrl.showHint = true + ctrl.suggestion = suggestion.replace newVal, "" + .catch () -> ctrl.suggestion = null + return + + App.component "inputSuggestions", { + bindings: + localNgModel: "=ngModel" + getSuggestion: "&" + inputId: "@" + inputPlaceholder: "@" + controller: inputSuggestionsController + template: """ +
+
+ +
+ +
+ """ + } diff --git a/services/web/public/stylesheets/components/input-suggestions.less b/services/web/public/stylesheets/components/input-suggestions.less new file mode 100644 index 0000000000..bf2fd4a253 --- /dev/null +++ b/services/web/public/stylesheets/components/input-suggestions.less @@ -0,0 +1,21 @@ +.input-suggestions { + position: relative; + height: @input-height-base; +} + .input-suggestions-main { + position: absolute; + top: 0; + background-color: transparent; + } + + .input-suggestions-shadow { + background-color: @input-bg; + padding-top: 4px; + } + .input-suggestions-shadow-existing { + color: transparent; + } + + .input-suggestions-shadow-suggested { + color: lighten(@input-color, 25%); + } \ No newline at end of file