mirror of
https://github.com/overleaf/overleaf.git
synced 2024-12-28 02:03:50 +00:00
Support more input configuration attributes in the input suggestions component.
This commit is contained in:
parent
3ddb8d0bef
commit
82f359e735
1 changed files with 11 additions and 6 deletions
|
@ -12,13 +12,13 @@ define [
|
|||
ctrl.showHint = false
|
||||
ctrl.hasFocus = false
|
||||
ctrl.suggestion = null
|
||||
ctrl.onBlur()
|
||||
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
|
||||
|
||||
ctrl.suggestion = null
|
||||
ctrl.showHint = false
|
||||
$scope.$watch "$ctrl.localNgModel", (newVal, oldVal) ->
|
||||
if ctrl.hasFocus and newVal != oldVal
|
||||
ctrl.suggestion = null
|
||||
|
@ -34,16 +34,21 @@ define [
|
|||
App.component "inputSuggestions", {
|
||||
bindings:
|
||||
localNgModel: "=ngModel"
|
||||
localNgModelOptions: "=?ngModelOptions"
|
||||
getSuggestion: "&"
|
||||
inputId: "@"
|
||||
inputPlaceholder: "@"
|
||||
onBlur: "&?"
|
||||
inputId: "@?"
|
||||
inputName: "@?"
|
||||
inputPlaceholder: "@?"
|
||||
inputType: "@?"
|
||||
inputRequired: "=?"
|
||||
controller: inputSuggestionsController
|
||||
template: """
|
||||
<div class="input-suggestions">
|
||||
<div type="text" + $ctrl.suggestion" class="form-control input-suggestions-shadow" ng-show="$ctrl.showHint">
|
||||
<span ng-bind="$ctrl.localNgModel" class="input-suggestions-shadow-existing"></span><span ng-bind="$ctrl.suggestion" class="input-suggestions-shadow-suggested"></span>
|
||||
</div>
|
||||
<input type="text" ng-focus="$ctrl.handleFocus()" ng-keyDown="$ctrl.handleKeyDown($event)" ng-blur="$ctrl.handleBlur()" ng-model="$ctrl.localNgModel" ng-model-options="{ debounce: 50 }" class="form-control input-suggestions-main" ng-attr-id="{{ ::$ctrl.inputId }}" ng-attr-placeholder="{{ ::$ctrl.inputPlaceholder }}">
|
||||
<input type="text" ng-focus="$ctrl.handleFocus()" ng-keyDown="$ctrl.handleKeyDown($event)" ng-blur="$ctrl.handleBlur()" ng-model="$ctrl.localNgModel" ng-model-options="$ctrl.localNgModelOptions" ng-model-options="{ debounce: 50 }" class="form-control input-suggestions-main" ng-attr-id="{{ ::$ctrl.inputId }}" ng-attr-placeholder="{{ ::$ctrl.inputPlaceholder }}" ng-attr-type="{{ ::$ctrl.inputType }}" ng-attr-name="{{ ::$ctrl.inputName }}" ng-required="::$ctrl.inputRequired">
|
||||
</div>
|
||||
"""
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue