discourse/plugins/spoiler-alert/assets/javascripts/initializers/spoiler-alert.js
Blake Erickson 89580ee379
FEATURE: Bundle discourse-spoiler-alert plugin into core (#24030)
* FEATURE: Bundle discourse-spoiler-alert plugin into core

Formerly https://github.com/discourse/discourse-spoiler-alert

* DEV: Switch to new addComposerToolbarPopupMenuOption plugin API

`api.addToolbarPopupMenuOptionsCallback` has been deprecated in 913fd3a7b3

This commit was just added to the plugin, so adding it here.

49f86ba72e
2023-10-23 13:50:43 -06:00

59 lines
1.5 KiB
JavaScript

import { withPluginApi } from "discourse/lib/plugin-api";
import {
addBlockDecorateCallback,
addTagDecorateCallback,
} from "discourse/lib/to-markdown";
import applySpoiler from "discourse/plugins/discourse-spoiler-alert/lib/apply-spoiler";
function spoil(element) {
element.querySelectorAll(".spoiler").forEach((spoiler) => {
spoiler.classList.remove("spoiler");
spoiler.classList.add("spoiled");
applySpoiler(spoiler);
});
}
export function initializeSpoiler(api) {
api.decorateCookedElement(spoil, { id: "spoiler-alert" });
api.addComposerToolbarPopupMenuOption({
icon: "magic",
label: "spoiler.title",
action: (toolbarEvent) => {
toolbarEvent.applySurround("[spoiler]", "[/spoiler]", "spoiler_text", {
multiline: false,
useBlockMode: true,
});
},
});
addTagDecorateCallback(function () {
if (this.element.attributes.class === "spoiled") {
this.prefix = "[spoiler]";
this.suffix = "[/spoiler]";
}
});
addBlockDecorateCallback(function (text) {
const { name, attributes } = this.element;
if (name === "div" && attributes.class === "spoiled") {
this.prefix = "[spoiler]";
this.suffix = "[/spoiler]";
return text.trim();
}
});
}
export default {
name: "spoiler-alert",
initialize(container) {
const siteSettings = container.lookup("site-settings:main");
if (siteSettings.spoiler_enabled) {
withPluginApi("1.15.0", initializeSpoiler);
}
},
};