discourse/plugins/spoiler-alert/assets/javascripts/initializers/spoiler-alert.js
dependabot[bot] e7d3c344d1
Build(deps-dev): Bump the lint group across 1 directory with 4 updates (#33881)
Bumps the lint group with 4 updates in the / directory:
[@discourse/lint-configs](https://github.com/discourse/lint-configs),
[ember-template-lint](https://github.com/ember-template-lint/ember-template-lint),
[eslint](https://github.com/eslint/eslint) and
[stylelint](https://github.com/stylelint/stylelint).


Updates `@discourse/lint-configs` from 2.22.0 to 2.28.0
- [Commits](https://github.com/discourse/lint-configs/commits)

Updates `ember-template-lint` from 7.7.0 to 7.9.1
- [Release
notes](https://github.com/ember-template-lint/ember-template-lint/releases)
-
[Changelog](https://github.com/ember-template-lint/ember-template-lint/blob/master/CHANGELOG.md)
-
[Commits](https://github.com/ember-template-lint/ember-template-lint/commits)

Updates `eslint` from 9.27.0 to 9.32.0
- [Release notes](https://github.com/eslint/eslint/releases)
- [Changelog](https://github.com/eslint/eslint/blob/main/CHANGELOG.md)
- [Commits](https://github.com/eslint/eslint/compare/v9.27.0...v9.32.0)

Updates `stylelint` from 16.19.1 to 16.22.0
- [Release notes](https://github.com/stylelint/stylelint/releases)
-
[Changelog](https://github.com/stylelint/stylelint/blob/main/CHANGELOG.md)
-
[Commits](https://github.com/stylelint/stylelint/compare/16.19.1...16.22.0)

---------

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Discourse CI <ci@ci.invalid>
Co-authored-by: Jarek Radosz <jarek@cvx.dev>
2025-07-28 18:02:41 +02:00

62 lines
1.6 KiB
JavaScript
Vendored

import { withPluginApi } from "discourse/lib/plugin-api";
import {
addBlockDecorateCallback,
addTagDecorateCallback,
} from "discourse/lib/to-markdown";
import applySpoiler from "discourse/plugins/spoiler-alert/lib/apply-spoiler";
import richEditorExtension from "../lib/rich-editor-extension";
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: "wand-magic",
label: "spoiler.title",
action: (toolbarEvent) => {
toolbarEvent.applySurround("[spoiler]", "[/spoiler]", "spoiler_text", {
multiline: false,
useBlockMode: true,
});
},
});
addTagDecorateCallback(function () {
const { attributes } = this.element;
if (/\bspoiled\b/.test(attributes.class)) {
this.prefix = "[spoiler]";
this.suffix = "[/spoiler]";
}
});
addBlockDecorateCallback(function (text) {
const { name, attributes } = this.element;
if (name === "div" && /\bspoiled\b/.test(attributes.class)) {
this.prefix = "[spoiler]\n";
this.suffix = "\n[/spoiler]";
return text.trim();
}
});
api.registerRichEditorExtension(richEditorExtension);
}
export default {
name: "spoiler-alert",
initialize(container) {
const siteSettings = container.lookup("service:site-settings");
if (siteSettings.spoiler_enabled) {
withPluginApi(initializeSpoiler);
}
},
};