client/posts: add tag implications when autocompleting mass tag inputs
Closes #334. This solution should function similar to single post tagging. Implications are automatically added but this also allows for them to review and manually remove any unwanted implications.
This commit is contained in:
parent
3e69edc117
commit
1bbcaf11f7
2 changed files with 23 additions and 6 deletions
|
@ -182,7 +182,7 @@
|
||||||
.hint
|
.hint
|
||||||
display: none
|
display: none
|
||||||
input[name=tag]
|
input[name=tag]
|
||||||
width: 12em
|
width: 24em
|
||||||
@media (max-width: 1000px)
|
@media (max-width: 1000px)
|
||||||
display: block
|
display: block
|
||||||
width: 100%
|
width: 100%
|
||||||
|
|
|
@ -6,6 +6,7 @@ const keyboard = require("../util/keyboard.js");
|
||||||
const misc = require("../util/misc.js");
|
const misc = require("../util/misc.js");
|
||||||
const search = require("../util/search.js");
|
const search = require("../util/search.js");
|
||||||
const views = require("../util/views.js");
|
const views = require("../util/views.js");
|
||||||
|
const TagList = require("../models/tag_list.js");
|
||||||
const TagAutoCompleteControl = require("../controls/tag_auto_complete_control.js");
|
const TagAutoCompleteControl = require("../controls/tag_auto_complete_control.js");
|
||||||
|
|
||||||
const template = views.getTemplate("posts-header");
|
const template = views.getTemplate("posts-header");
|
||||||
|
@ -74,11 +75,27 @@ class BulkTagEditor extends BulkEditor {
|
||||||
this._autoCompleteControl = new TagAutoCompleteControl(
|
this._autoCompleteControl = new TagAutoCompleteControl(
|
||||||
this._inputNode,
|
this._inputNode,
|
||||||
{
|
{
|
||||||
confirm: (tag) =>
|
confirm: (tag) => {
|
||||||
this._autoCompleteControl.replaceSelectedText(
|
let tag_list = new TagList();
|
||||||
tag.names[0],
|
tag_list
|
||||||
false
|
.addByName(tag.names[0], true)
|
||||||
),
|
.then(
|
||||||
|
() => {
|
||||||
|
return tag_list
|
||||||
|
.map((s) => s.names[0])
|
||||||
|
.join(" ");
|
||||||
|
},
|
||||||
|
(err) => {
|
||||||
|
return tag.names[0];
|
||||||
|
}
|
||||||
|
)
|
||||||
|
.then((tag_str) => {
|
||||||
|
this._autoCompleteControl.replaceSelectedText(
|
||||||
|
tag_str,
|
||||||
|
false
|
||||||
|
);
|
||||||
|
});
|
||||||
|
},
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
this._hostNode.addEventListener("submit", (e) =>
|
this._hostNode.addEventListener("submit", (e) =>
|
||||||
|
|
Loading…
Reference in a new issue