a8a6aecef3
特定条件下においてタグ入力が正常に行えない問題の修正
58 lines
1.4 KiB
JavaScript
Vendored
58 lines
1.4 KiB
JavaScript
Vendored
function updateTags() {
|
|
$('input[name=tags]').val(
|
|
$('#tags')
|
|
.find('li')
|
|
.map(function () {
|
|
return $(this).data('value');
|
|
})
|
|
.get()
|
|
.join(' ')
|
|
);
|
|
}
|
|
|
|
function insertTag(value) {
|
|
$('<li class="list-inline-item badge badge-primary" style="cursor: pointer;"><span class="oi oi-tag"></span> <span></span> | x</li>')
|
|
.data('value', value)
|
|
.children(':last-child')
|
|
.text(value)
|
|
.end()
|
|
.appendTo('#tags');
|
|
}
|
|
|
|
var initTags = $('input[name=tags]').val();
|
|
if (initTags.trim() !== '') {
|
|
initTags.split(' ').forEach(function (value) {
|
|
insertTag(value);
|
|
});
|
|
}
|
|
|
|
$('#tagInput').on('keydown', function (ev) {
|
|
var $this = $(this);
|
|
if ($this.val().trim() !== '') {
|
|
switch (ev.key) {
|
|
case 'Tab':
|
|
case 'Enter':
|
|
case ' ':
|
|
if (ev.originalEvent.isComposing !== true) {
|
|
insertTag($this.val().trim());
|
|
$this.val('');
|
|
updateTags();
|
|
}
|
|
ev.preventDefault();
|
|
break;
|
|
}
|
|
} else if (ev.key === 'Enter') {
|
|
// 誤爆防止
|
|
ev.preventDefault();
|
|
}
|
|
});
|
|
|
|
$('#tags')
|
|
.on('click', 'li', function (ev) {
|
|
$(this).remove();
|
|
updateTags();
|
|
})
|
|
.parent()
|
|
.on('click', function (ev) {
|
|
$('#tagInput').focus();
|
|
}); |