mirror of
https://github.com/discourse/discourse.git
synced 2025-03-02 05:23:42 +08:00
data:image/s3,"s3://crabby-images/94cbb/94cbb57df0d84bd1cbee25a6ba37820bb33959e9" alt="David Taylor"
When we "pull hotlinked images" on onebox images, they are added to the uploads table and their dominant color is calculated. This commit adds the data to the HTML so that it can be used by the client in the same way as non-onebox images. It also adds specific handling to the new `discourse-lazy-videos` plugin.
59 lines
2.0 KiB
JavaScript
59 lines
2.0 KiB
JavaScript
import { setupRenderingTest } from "discourse/tests/helpers/component-test";
|
|
import hbs from "htmlbars-inline-precompile";
|
|
import { module, test } from "qunit";
|
|
import { click, render } from "@ember/test-helpers";
|
|
|
|
module("Discourse Lazy Videos | Component | lazy-video", function (hooks) {
|
|
setupRenderingTest(hooks);
|
|
|
|
this.attributes = {
|
|
url: "https://www.youtube.com/watch?v=kPRA0W1kECg",
|
|
thumbnail: "thumbnail.jpeg",
|
|
title: "15 Sorting Algorithms in 6 Minutes",
|
|
providerName: "youtube",
|
|
id: "kPRA0W1kECg",
|
|
dominantColor: "00ffff",
|
|
};
|
|
|
|
test("displays the correct video title", async function (assert) {
|
|
await render(hbs`<LazyVideo @videoAttributes={{this.attributes}} />`);
|
|
|
|
assert.dom(".title-link").hasText(this.attributes.title);
|
|
});
|
|
|
|
test("displays the correct provider icon", async function (assert) {
|
|
await render(hbs`<LazyVideo @videoAttributes={{this.attributes}} />`);
|
|
|
|
assert.dom(".icon.youtube-icon").exists();
|
|
});
|
|
|
|
test("uses tthe dominant color from the dom", async function (assert) {
|
|
await render(hbs`<LazyVideo @videoAttributes={{this.attributes}} />`);
|
|
|
|
assert
|
|
.dom(".video-thumbnail")
|
|
.hasAttribute("style", "background-color: #00ffff;");
|
|
});
|
|
|
|
test("loads the iframe when clicked", async function (assert) {
|
|
await render(hbs`<LazyVideo @videoAttributes={{this.attributes}}/>`);
|
|
assert.dom(".lazy-video-container.video-loaded").doesNotExist();
|
|
|
|
await click(".video-thumbnail.youtube");
|
|
assert.dom(".lazy-video-container.video-loaded iframe").exists();
|
|
});
|
|
|
|
test("accepts an optional onLoadedVideo callback function", async function (assert) {
|
|
this.set("foo", 1);
|
|
this.set("onLoadedVideo", () => this.set("foo", 2));
|
|
|
|
await render(
|
|
hbs`<LazyVideo @videoAttributes={{this.attributes}} @onLoadedVideo={{this.onLoadedVideo}} />`
|
|
);
|
|
assert.strictEqual(this.foo, 1);
|
|
|
|
await click(".video-thumbnail.youtube");
|
|
assert.strictEqual(this.foo, 2);
|
|
});
|
|
});
|