This should be fully backwards compatible. Co-authored-by: Jarek Radosz <jradosz@gmail.com> Co-authored-by: Jarek Radosz <jradosz@gmail.com>
57 lines
1.5 KiB
JavaScript
57 lines
1.5 KiB
JavaScript
import componentTest, {
|
|
setupRenderingTest,
|
|
} from "discourse/tests/helpers/component-test";
|
|
import {
|
|
discourseModule,
|
|
queryAll,
|
|
} from "discourse/tests/helpers/qunit-helpers";
|
|
import hbs from "htmlbars-inline-precompile";
|
|
import { withPluginApi } from "discourse/lib/plugin-api";
|
|
|
|
discourseModule(
|
|
"Integration | Component | Widget | post-menu",
|
|
function (hooks) {
|
|
setupRenderingTest(hooks);
|
|
|
|
componentTest("add extra button", {
|
|
template: hbs`{{mount-widget widget="post-menu" args=args}}`,
|
|
beforeEach() {
|
|
this.set("args", {});
|
|
withPluginApi("0.8", (api) => {
|
|
api.addPostMenuButton("coffee", () => {
|
|
return {
|
|
action: "drinkCoffee",
|
|
icon: "coffee",
|
|
className: "hot-coffee",
|
|
title: "coffee.title",
|
|
position: "first",
|
|
};
|
|
});
|
|
});
|
|
},
|
|
async test(assert) {
|
|
assert.ok(
|
|
queryAll(".actions .extra-buttons .hot-coffee").length === 1,
|
|
"It renders extra button"
|
|
);
|
|
},
|
|
});
|
|
|
|
componentTest("remove extra button", {
|
|
template: hbs`{{mount-widget widget="post-menu" args=args}}`,
|
|
beforeEach() {
|
|
this.set("args", {});
|
|
withPluginApi("0.8", (api) => {
|
|
api.removePostMenuButton("coffee");
|
|
});
|
|
},
|
|
async test(assert) {
|
|
assert.ok(
|
|
queryAll(".actions .extra-buttons .hot-coffee").length === 0,
|
|
"It doesn't removes coffee button"
|
|
);
|
|
},
|
|
});
|
|
}
|
|
);
|