2018-08-17 00:30:59 +02:00
|
|
|
/*
|
2020-10-31 17:05:30 +01:00
|
|
|
* Copyright (c) 2010-2020 Tim Düsterhus.
|
2018-08-17 00:30:59 +02:00
|
|
|
*
|
|
|
|
* Use of this software is governed by the Business Source License
|
|
|
|
* included in the LICENSE file.
|
|
|
|
*
|
2020-11-20 00:08:57 +01:00
|
|
|
* Change Date: 2024-11-20
|
2018-08-17 00:30:59 +02:00
|
|
|
*
|
|
|
|
* On the date above, in accordance with the Business Source
|
|
|
|
* License, use of this software will be governed by version 2
|
|
|
|
* or later of the General Public License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
define([
|
|
|
|
'WoltLabSuite/Core/Dom/Util',
|
|
|
|
'WoltLabSuite/Core/Event/Key',
|
|
|
|
'WoltLabSuite/Core/Ui/Suggestion',
|
|
|
|
], function (DomUtil, EventKey, Suggestion) {
|
|
|
|
'use strict'
|
2020-11-01 17:41:19 +01:00
|
|
|
|
2018-08-17 00:30:59 +02:00
|
|
|
const DEPENDENCIES = ['UiInput']
|
|
|
|
class Autocompleter extends Suggestion {
|
|
|
|
constructor(input) {
|
|
|
|
const elementId = DomUtil.identify(input.input)
|
2020-10-31 17:05:30 +01:00
|
|
|
const options = {
|
|
|
|
callbackSelect: (_elementId, selection) =>
|
|
|
|
this.insertSelection(selection),
|
|
|
|
}
|
2018-08-17 00:30:59 +02:00
|
|
|
|
|
|
|
super(elementId, options)
|
|
|
|
|
|
|
|
this.input = input
|
2020-10-31 17:05:30 +01:00
|
|
|
this.completions = new Map()
|
|
|
|
this.completionId = 0
|
2018-08-17 00:30:59 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
bootstrap() {
|
|
|
|
this.input.on('beforeSubmit', (event) => {
|
|
|
|
if (event.target !== this.input) return
|
|
|
|
|
|
|
|
if (this.isActive() || this.cancelNextSubmit) {
|
|
|
|
event.detail.cancel = true
|
|
|
|
}
|
|
|
|
this.cancelNextSubmit = false
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2020-10-31 17:05:30 +01:00
|
|
|
keyDown(...args) {
|
|
|
|
return this._keyDown(...args)
|
|
|
|
}
|
|
|
|
|
2018-08-17 00:30:59 +02:00
|
|
|
_keyDown(event) {
|
2020-10-31 17:05:30 +01:00
|
|
|
const result = (super.keyDown || super._keyDown).call(this, event)
|
2018-08-17 00:30:59 +02:00
|
|
|
|
|
|
|
if (!result && EventKey.Enter(event)) {
|
|
|
|
this.cancelNextSubmit = true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-10-31 17:05:30 +01:00
|
|
|
keyUp(...args) {
|
|
|
|
return this._keyUp(...args)
|
|
|
|
}
|
|
|
|
|
2018-08-17 00:30:59 +02:00
|
|
|
_keyUp(event) {
|
|
|
|
const value = this.input.getText(true)
|
|
|
|
|
|
|
|
if (this._value !== value) {
|
2020-10-31 17:05:30 +01:00
|
|
|
this.sendCompletions([])
|
2018-08-17 00:30:59 +02:00
|
|
|
this._value = value
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-10-31 17:05:30 +01:00
|
|
|
insertSelection(selection) {
|
|
|
|
let text
|
|
|
|
if ((text = this.completions.get(parseInt(selection.objectId, 10)))) {
|
|
|
|
this.input.insertText(text, { append: false })
|
|
|
|
}
|
2018-08-17 00:30:59 +02:00
|
|
|
}
|
|
|
|
|
2020-10-31 17:05:30 +01:00
|
|
|
sendCompletions(completions) {
|
|
|
|
this.completions = new Map()
|
|
|
|
|
|
|
|
const returnValues = completions.map((completion) => {
|
|
|
|
this.completions.set(++this.completionId, completion)
|
|
|
|
return { label: completion, objectID: this.completionId }
|
|
|
|
})
|
|
|
|
|
|
|
|
this._ajaxSuccess({ returnValues })
|
2018-08-17 00:30:59 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
Autocompleter.DEPENDENCIES = DEPENDENCIES
|
|
|
|
|
|
|
|
return Autocompleter
|
|
|
|
})
|