О, я как раз делал что-то подобное на прошлой неделе…
В теме вы можете добавить это в javascripts/discourse/components/new-topic-dropdown.js:
import { action } from "@ember/object";
import { getOwner } from "discourse-common/lib/get-owner";
import Composer from "discourse/models/composer";
import DropdownSelectBoxComponent from "select-kit/components/dropdown-select-box";
import { computed } from "@ember/object";
export default DropdownSelectBoxComponent.extend({
classNames: ["new-topic-dropdown"],
selectKitOptions: {
icons: ["plus"],
showFullTitle: true,
autoFilterable: false,
filterable: false,
showCaret: true,
none: "topic.create",
},
content: computed(function () {
const items = [
{
id: "new_discussion",
name: "Новая тема",
description: "Начать новое обсуждение",
icon: "comment",
},
];
items.push({
id: "new_ticket",
name: "Заявка в поддержку",
description: "Создать запрос в поддержку",
icon: "tag",
});
return items;
}),
@action
onChange(selectedAction) {
const composerController = getOwner(this).lookup("controller:composer");
let tags = null;
let categoryId = this.category ? this.category.id : null;
if (selectedAction === "new_ticket") {
tags = "ticket";
}
composerController.open({
action: Composer.CREATE_TOPIC,
draftKey: Composer.DRAFT,
categoryId: categoryId,
tags: tags,
});
},
});
Это добавляет в выпадающую кнопку опции «Новая тема» и «Заявка в поддержку»… «Новая тема» открывает композер как обычно, а «Заявка в поддержку» открывает композер с уже добавленным тегом «ticket».
…а затем в javascripts/discourse/connectors/after-create-topic-button/new-topic-dropdown.hbs:
{{#if currentUser}}
{{new-topic-dropdown category=category}}
{{/if}}
…и с помощью CSS вы, вероятно, захотите скрыть кнопку по умолчанию:
.navigation-controls {
#create-topic {
display: none;
}
}
