mirror of
https://github.com/discourse/discourse.git
synced 2025-01-08 07:26:08 +08:00
03deda2147
* Add missing icons to set
* Revert FA5 revert
This reverts commit 42572ff
* use new SVG syntax in locales
* Noscript page changes (remove login button, center "powered by" footer text)
* Cast wider net for SVG icons in settings
- include any _icon setting for SVG registry (offers better support for plugin settings)
- let themes store multiple pipe-delimited icons in a setting
- also replaces broken onebox image icon with SVG reference in cooked post processor
* interpolate icons in locales
* Fix composer whisper icon alignment
* Add support for stacked icons
* SECURITY: enforce hostname to match discourse hostname
This ensures that the hostname rails uses for various helpers always matches
the Discourse hostname
* load SVG sprite with pre-initializers
* FIX: enable caching on SVG sprites
* PERF: use JSONP for SVG sprites so they are served from CDN
This avoids needing to deal with CORS for loading of the SVG
Note, added the svg- prefix to the filename so we can quickly tell in
dev tools what the file is
* Add missing SVG sprite JSONP script to CSP
* Upgrade to FA 5.5.0
* Add support for all FA4.7 icons
- adds complete frontend and backend for renamed FA4.7 icons
- improves performance of SvgSprite.bundle and SvgSprite.all_icons
* Fix group avatar flair preview
- adds an endpoint at /svg-sprites/search/:keyword
- adds frontend ajax call that pulls icon in avatar flair preview even when it is not in subset
* Remove FA 4.7 font files
338 lines
7.4 KiB
JavaScript
338 lines
7.4 KiB
JavaScript
import { moduleForWidget, widgetTest } from "helpers/widget-test";
|
|
import { createWidget } from "discourse/widgets/widget";
|
|
import { withPluginApi } from "discourse/lib/plugin-api";
|
|
import hbs from "discourse/widgets/hbs-compiler";
|
|
|
|
moduleForWidget("base");
|
|
|
|
widgetTest("widget attributes are passed in via args", {
|
|
template: `{{mount-widget widget="hello-test" args=args}}`,
|
|
|
|
beforeEach() {
|
|
createWidget("hello-test", {
|
|
tagName: "div.test",
|
|
template: hbs`Hello {{attrs.name}}`
|
|
});
|
|
|
|
this.set("args", { name: "Robin" });
|
|
},
|
|
|
|
test(assert) {
|
|
assert.equal(this.$(".test").text(), "Hello Robin");
|
|
}
|
|
});
|
|
|
|
widgetTest("hbs template - no tagName", {
|
|
template: `{{mount-widget widget="hbs-test" args=args}}`,
|
|
|
|
beforeEach() {
|
|
createWidget("hbs-test", {
|
|
template: hbs`<div class='test'>Hello {{attrs.name}}</div>`
|
|
});
|
|
|
|
this.set("args", { name: "Robin" });
|
|
},
|
|
|
|
test(assert) {
|
|
assert.equal(this.$("div.test").text(), "Hello Robin");
|
|
}
|
|
});
|
|
|
|
widgetTest("hbs template - with tagName", {
|
|
template: `{{mount-widget widget="hbs-test" args=args}}`,
|
|
|
|
beforeEach() {
|
|
createWidget("hbs-test", {
|
|
tagName: "div.test",
|
|
template: hbs`Hello {{attrs.name}}`
|
|
});
|
|
|
|
this.set("args", { name: "Robin" });
|
|
},
|
|
|
|
test(assert) {
|
|
assert.equal(this.$("div.test").text(), "Hello Robin");
|
|
}
|
|
});
|
|
|
|
widgetTest("buildClasses", {
|
|
template: `{{mount-widget widget="classname-test" args=args}}`,
|
|
|
|
beforeEach() {
|
|
createWidget("classname-test", {
|
|
tagName: "div.test",
|
|
|
|
buildClasses(attrs) {
|
|
return ["static", attrs.dynamic];
|
|
}
|
|
});
|
|
|
|
this.set("args", { dynamic: "cool-class" });
|
|
},
|
|
|
|
test(assert) {
|
|
assert.ok(
|
|
this.$(".test.static.cool-class").length,
|
|
"it has all the classes"
|
|
);
|
|
}
|
|
});
|
|
|
|
widgetTest("buildAttributes", {
|
|
template: `{{mount-widget widget="attributes-test" args=args}}`,
|
|
|
|
beforeEach() {
|
|
createWidget("attributes-test", {
|
|
tagName: "div.test",
|
|
|
|
buildAttributes(attrs) {
|
|
return { "data-evil": "trout", "aria-label": attrs.label };
|
|
}
|
|
});
|
|
|
|
this.set("args", { label: "accessibility" });
|
|
},
|
|
|
|
test(assert) {
|
|
assert.ok(this.$(".test[data-evil=trout]").length);
|
|
assert.ok(this.$(".test[aria-label=accessibility]").length);
|
|
}
|
|
});
|
|
|
|
widgetTest("buildId", {
|
|
template: `{{mount-widget widget="id-test" args=args}}`,
|
|
|
|
beforeEach() {
|
|
createWidget("id-test", {
|
|
buildId(attrs) {
|
|
return `test-${attrs.id}`;
|
|
}
|
|
});
|
|
|
|
this.set("args", { id: 1234 });
|
|
},
|
|
|
|
test(assert) {
|
|
assert.ok(this.$("#test-1234").length);
|
|
}
|
|
});
|
|
|
|
widgetTest("widget state", {
|
|
template: `{{mount-widget widget="state-test"}}`,
|
|
|
|
beforeEach() {
|
|
createWidget("state-test", {
|
|
tagName: "button.test",
|
|
buildKey: () => `button-test`,
|
|
template: hbs`{{state.clicks}} clicks`,
|
|
|
|
defaultState() {
|
|
return { clicks: 0 };
|
|
},
|
|
|
|
click() {
|
|
this.state.clicks++;
|
|
}
|
|
});
|
|
},
|
|
|
|
async test(assert) {
|
|
assert.ok(this.$("button.test").length, "it renders the button");
|
|
assert.equal(this.$("button.test").text(), "0 clicks");
|
|
|
|
await click(this.$("button"));
|
|
assert.equal(this.$("button.test").text(), "1 clicks");
|
|
}
|
|
});
|
|
|
|
widgetTest("widget update with promise", {
|
|
template: `{{mount-widget widget="promise-test"}}`,
|
|
|
|
beforeEach() {
|
|
createWidget("promise-test", {
|
|
tagName: "button.test",
|
|
buildKey: () => "promise-test",
|
|
template: hbs`
|
|
{{#if state.name}}
|
|
{{state.name}}
|
|
{{else}}
|
|
No name
|
|
{{/if}}
|
|
`,
|
|
|
|
click() {
|
|
return new Ember.RSVP.Promise(resolve => {
|
|
Ember.run.next(() => {
|
|
this.state.name = "Robin";
|
|
resolve();
|
|
});
|
|
});
|
|
}
|
|
});
|
|
},
|
|
|
|
async test(assert) {
|
|
assert.equal(
|
|
this.$("button.test")
|
|
.text()
|
|
.trim(),
|
|
"No name"
|
|
);
|
|
|
|
await click(this.$("button"));
|
|
assert.equal(
|
|
this.$("button.test")
|
|
.text()
|
|
.trim(),
|
|
"Robin"
|
|
);
|
|
}
|
|
});
|
|
|
|
widgetTest("widget attaching", {
|
|
template: `{{mount-widget widget="attach-test"}}`,
|
|
|
|
beforeEach() {
|
|
createWidget("test-embedded", { tagName: "div.embedded" });
|
|
|
|
createWidget("attach-test", {
|
|
tagName: "div.container",
|
|
template: hbs`{{attach widget="test-embedded" attrs=attrs}}`
|
|
});
|
|
},
|
|
|
|
test(assert) {
|
|
assert.ok(this.$(".container").length, "renders container");
|
|
assert.ok(this.$(".container .embedded").length, "renders attached");
|
|
}
|
|
});
|
|
|
|
widgetTest("handlebars d-icon", {
|
|
template: `{{mount-widget widget="hbs-icon-test" args=args}}`,
|
|
|
|
beforeEach() {
|
|
createWidget("hbs-icon-test", {
|
|
template: hbs`{{d-icon "arrow-down"}}`
|
|
});
|
|
},
|
|
|
|
test(assert) {
|
|
assert.equal(this.$(".d-icon-arrow-down").length, 1);
|
|
}
|
|
});
|
|
|
|
widgetTest("handlebars i18n", {
|
|
template: `{{mount-widget widget="hbs-i18n-test" args=args}}`,
|
|
|
|
beforeEach() {
|
|
createWidget("hbs-i18n-test", {
|
|
template: hbs`
|
|
<span class='string'>{{i18n "hbs_test0"}}</span>
|
|
<span class='var'>{{i18n attrs.key}}</span>
|
|
<a href title={{i18n "hbs_test0"}}>test</a>
|
|
`
|
|
});
|
|
I18n.extras = [
|
|
{
|
|
hbs_test0: "evil",
|
|
hbs_test1: "trout"
|
|
}
|
|
];
|
|
this.set("args", { key: "hbs_test1" });
|
|
},
|
|
|
|
test(assert) {
|
|
// comin up
|
|
assert.equal(this.$("span.string").text(), "evil");
|
|
assert.equal(this.$("span.var").text(), "trout");
|
|
assert.equal(this.$("a").prop("title"), "evil");
|
|
}
|
|
});
|
|
|
|
widgetTest("handlebars #each", {
|
|
template: `{{mount-widget widget="hbs-each-test" args=args}}`,
|
|
|
|
beforeEach() {
|
|
createWidget("hbs-each-test", {
|
|
tagName: "ul",
|
|
template: hbs`
|
|
{{#each attrs.items as |item|}}
|
|
<li>{{item}}</li>
|
|
{{/each}}
|
|
`
|
|
});
|
|
|
|
this.set("args", {
|
|
items: ["one", "two", "three"]
|
|
});
|
|
},
|
|
|
|
test(assert) {
|
|
assert.equal(this.$("ul li").length, 3);
|
|
assert.equal(this.$("ul li:eq(0)").text(), "one");
|
|
}
|
|
});
|
|
|
|
widgetTest("widget decorating", {
|
|
template: `{{mount-widget widget="decorate-test"}}`,
|
|
|
|
beforeEach() {
|
|
createWidget("decorate-test", {
|
|
tagName: "div.decorate",
|
|
template: hbs`main content`
|
|
});
|
|
|
|
withPluginApi("0.1", api => {
|
|
api.decorateWidget("decorate-test:before", dec => {
|
|
return dec.h("b", "before");
|
|
});
|
|
|
|
api.decorateWidget("decorate-test:after", dec => {
|
|
return dec.h("i", "after");
|
|
});
|
|
});
|
|
},
|
|
|
|
test(assert) {
|
|
assert.ok(this.$(".decorate").length);
|
|
assert.equal(this.$(".decorate b").text(), "before");
|
|
assert.equal(this.$(".decorate i").text(), "after");
|
|
}
|
|
});
|
|
|
|
widgetTest("widget settings", {
|
|
template: `{{mount-widget widget="settings-test"}}`,
|
|
|
|
beforeEach() {
|
|
createWidget("settings-test", {
|
|
tagName: "div.settings",
|
|
template: hbs`age is {{settings.age}}`,
|
|
settings: { age: 36 }
|
|
});
|
|
},
|
|
|
|
test(assert) {
|
|
assert.equal(this.$(".settings").text(), "age is 36");
|
|
}
|
|
});
|
|
|
|
widgetTest("override settings", {
|
|
template: `{{mount-widget widget="ov-settings-test"}}`,
|
|
|
|
beforeEach() {
|
|
createWidget("ov-settings-test", {
|
|
tagName: "div.settings",
|
|
template: hbs`age is {{settings.age}}`,
|
|
settings: { age: 36 }
|
|
});
|
|
|
|
withPluginApi("0.1", api => {
|
|
api.changeWidgetSetting("ov-settings-test", "age", 37);
|
|
});
|
|
},
|
|
|
|
test(assert) {
|
|
assert.equal(this.$(".settings").text(), "age is 37");
|
|
}
|
|
});
|