DEV: Remove INLINE_ONEBOX_* constants

There were two constants here, `INLINE_ONEBOX_LOADING_CSS_CLASS` and
`INLINE_ONEBOX_CSS_CLASS` that were both longer than the strings they
were DRYing up: `inline-onebox-loading` and `inline-onebox`

I normally appreciate constants, but in this case it meant that we had
a lot of JS imports resulting in many more lines of code (and CPU cycles
spent figuring them out.)

It also meant we had an `.erb` file and had to invoke Ruby to create the
JS file, which meant the app was harder to port to Ember CLI.

I removed the constants. It's less DRY but faster and simpler, and
arguably the loss of DRYness is not significant as you can still search
for the `inline-onebox-loading` and `inline-onebox` strings easily if
you are refactoring.
This commit is contained in:
Robin Ward 2020-05-07 16:08:48 -04:00
parent 3567a90661
commit f9608c0af5
10 changed files with 48 additions and 108 deletions

View File

@ -43,10 +43,6 @@ import {
cacheShortUploadUrl, cacheShortUploadUrl,
resolveAllShortUrls resolveAllShortUrls
} from "pretty-text/upload-short-url"; } from "pretty-text/upload-short-url";
import {
INLINE_ONEBOX_LOADING_CSS_CLASS,
INLINE_ONEBOX_CSS_CLASS
} from "pretty-text/context/inline-onebox-css-classes";
import ENV from "discourse-common/config/environment"; import ENV from "discourse-common/config/environment";
const REBUILD_SCROLL_MAP_EVENTS = ["composer:resized", "composer:typed-reply"]; const REBUILD_SCROLL_MAP_EVENTS = ["composer:resized", "composer:typed-reply"];
@ -968,32 +964,29 @@ export default Component.extend({
// Inline Oneboxes = `a.inline-onebox-loading` -> `a.inline-onebox` // Inline Oneboxes = `a.inline-onebox-loading` -> `a.inline-onebox`
let loadedOneboxes = $preview.find( let loadedOneboxes = $preview.find(
`aside.onebox, a.${LOADING_ONEBOX_CSS_CLASS}, a.${INLINE_ONEBOX_CSS_CLASS}` `aside.onebox, a.${LOADING_ONEBOX_CSS_CLASS}, a.inline-onebox-loading`
).length; ).length;
$preview $preview.find(`a.onebox, a.inline-onebox-loading`).each((_, link) => {
.find(`a.onebox, a.${INLINE_ONEBOX_LOADING_CSS_CLASS}`) const $link = $(link);
.each((_, link) => { const text = $link.text();
const $link = $(link); const isInline = $link.attr("class") === "inline-onebox-loading";
const text = $link.text(); const m = isInline ? inlineOneboxes : oneboxes;
const isInline =
$link.attr("class") === INLINE_ONEBOX_LOADING_CSS_CLASS;
const m = isInline ? inlineOneboxes : oneboxes;
if (loadedOneboxes < this.siteSettings.max_oneboxes_per_post) { if (loadedOneboxes < this.siteSettings.max_oneboxes_per_post) {
if (m[text] === undefined) { if (m[text] === undefined) {
m[text] = []; m[text] = [];
loadedOneboxes++; loadedOneboxes++;
}
m[text].push(link);
} else {
if (m[text] !== undefined) {
m[text].push(link);
} else if (isInline) {
$link.removeClass(INLINE_ONEBOX_LOADING_CSS_CLASS);
}
} }
}); m[text].push(link);
} else {
if (m[text] !== undefined) {
m[text].push(link);
} else if (isInline) {
$link.removeClass("inline-onebox-loading");
}
}
});
if (Object.keys(oneboxes).length > 0) { if (Object.keys(oneboxes).length > 0) {
this._loadOneboxes(oneboxes); this._loadOneboxes(oneboxes);

View File

@ -11,6 +11,5 @@
//= require ./pretty-text/addon/sanitizer //= require ./pretty-text/addon/sanitizer
//= require ./pretty-text/addon/oneboxer //= require ./pretty-text/addon/oneboxer
//= require ./pretty-text/addon/oneboxer-cache //= require ./pretty-text/addon/oneboxer-cache
//= require ./pretty-text/addon/context/inline-onebox-css-classes
//= require ./pretty-text/addon/inline-oneboxer //= require ./pretty-text/addon/inline-oneboxer
//= require ./pretty-text/addon/upload-short-url //= require ./pretty-text/addon/upload-short-url

View File

@ -1,5 +0,0 @@
export const INLINE_ONEBOX_LOADING_CSS_CLASS =
"<%= CookedPostProcessor::INLINE_ONEBOX_LOADING_CSS_CLASS %>";
export const INLINE_ONEBOX_CSS_CLASS =
"<%= CookedPostProcessor::INLINE_ONEBOX_CSS_CLASS %>";

View File

@ -1,9 +1,5 @@
import { lookupCache } from "pretty-text/oneboxer-cache"; import { lookupCache } from "pretty-text/oneboxer-cache";
import { cachedInlineOnebox } from "pretty-text/inline-oneboxer"; import { cachedInlineOnebox } from "pretty-text/inline-oneboxer";
import {
INLINE_ONEBOX_LOADING_CSS_CLASS,
INLINE_ONEBOX_CSS_CLASS
} from "pretty-text/context/inline-onebox-css-classes";
const ONEBOX = 1; const ONEBOX = 1;
const INLINE = 2; const INLINE = 2;
@ -103,9 +99,9 @@ function applyOnebox(state, silent) {
if (onebox && onebox.title) { if (onebox && onebox.title) {
text.content = onebox.title; text.content = onebox.title;
attrs.push(["class", INLINE_ONEBOX_CSS_CLASS]); attrs.push(["class", "inline-onebox"]);
} else if (!onebox) { } else if (!onebox) {
attrs.push(["class", INLINE_ONEBOX_LOADING_CSS_CLASS]); attrs.push(["class", "inline-onebox-loading"]);
} }
} }
} }

View File

@ -1,8 +1,3 @@
import {
INLINE_ONEBOX_LOADING_CSS_CLASS,
INLINE_ONEBOX_CSS_CLASS
} from "pretty-text/context/inline-onebox-css-classes";
const _cache = {}; const _cache = {};
export function applyInlineOneboxes(inline, ajax, opts) { export function applyInlineOneboxes(inline, ajax, opts) {
@ -27,8 +22,8 @@ export function applyInlineOneboxes(inline, ajax, opts) {
links.forEach(link => { links.forEach(link => {
$(link) $(link)
.text(onebox.title) .text(onebox.title)
.addClass(INLINE_ONEBOX_CSS_CLASS) .addClass("inline-onebox")
.removeClass(INLINE_ONEBOX_LOADING_CSS_CLASS); .removeClass("inline-onebox-loading");
}); });
} }
}); });

View File

@ -1,8 +1,3 @@
import {
INLINE_ONEBOX_LOADING_CSS_CLASS,
INLINE_ONEBOX_CSS_CLASS
} from "pretty-text/context/inline-onebox-css-classes";
// to match: // to match:
// abcd // abcd
// abcd[test] // abcd[test]
@ -121,8 +116,8 @@ export const DEFAULT_LIST = [
"a.mention", "a.mention",
"a.mention-group", "a.mention-group",
"a.onebox", "a.onebox",
`a.${INLINE_ONEBOX_CSS_CLASS}`, `a.inline-onebox`,
`a.${INLINE_ONEBOX_LOADING_CSS_CLASS}`, `a.inline-onebox-loading`,
"a[data-bbcode]", "a[data-bbcode]",
"a[name]", "a[name]",
"a[rel=nofollow]", "a[rel=nofollow]",

View File

@ -4,8 +4,6 @@
# For example, inserting the onebox content, or image sizes/thumbnails. # For example, inserting the onebox content, or image sizes/thumbnails.
class CookedPostProcessor class CookedPostProcessor
INLINE_ONEBOX_LOADING_CSS_CLASS = "inline-onebox-loading"
INLINE_ONEBOX_CSS_CLASS = "inline-onebox"
LIGHTBOX_WRAPPER_CSS_CLASS = "lightbox-wrapper" LIGHTBOX_WRAPPER_CSS_CLASS = "lightbox-wrapper"
LOADING_SIZE = 10 LOADING_SIZE = 10
LOADING_COLORS = 32 LOADING_COLORS = 32
@ -518,7 +516,7 @@ class CookedPostProcessor
oneboxes = {} oneboxes = {}
inlineOneboxes = {} inlineOneboxes = {}
Oneboxer.apply(@doc, extra_paths: [".#{INLINE_ONEBOX_LOADING_CSS_CLASS}"]) do |url, element| Oneboxer.apply(@doc, extra_paths: [".inline-onebox-loading"]) do |url, element|
is_onebox = element["class"] == Oneboxer::ONEBOX_CSS_CLASS is_onebox = element["class"] == Oneboxer::ONEBOX_CSS_CLASS
map = is_onebox ? oneboxes : inlineOneboxes map = is_onebox ? oneboxes : inlineOneboxes
skip_onebox = limit <= 0 && !map[url] skip_onebox = limit <= 0 && !map[url]
@ -724,14 +722,14 @@ class CookedPostProcessor
if title = inline_onebox&.dig(:title) if title = inline_onebox&.dig(:title)
element.children = CGI.escapeHTML(title) element.children = CGI.escapeHTML(title)
element.add_class(INLINE_ONEBOX_CSS_CLASS) element.add_class("inline-onebox")
end end
remove_inline_onebox_loading_class(element) remove_inline_onebox_loading_class(element)
end end
def remove_inline_onebox_loading_class(element) def remove_inline_onebox_loading_class(element)
element.remove_class(INLINE_ONEBOX_LOADING_CSS_CLASS) element.remove_class("inline-onebox-loading")
end end
def is_svg?(img) def is_svg?(img)

View File

@ -97,10 +97,7 @@ describe CookedPostProcessor do
cpp.post_process cpp.post_process
expect(cpp.html).to have_tag('a', expect(cpp.html).to have_tag('a',
with: { with: { href: url, class: "inline-onebox" },
href: url,
class: described_class::INLINE_ONEBOX_CSS_CLASS
},
text: title, text: title,
count: 2 count: 2
) )
@ -113,9 +110,7 @@ describe CookedPostProcessor do
) )
expect(cpp.html).to have_tag('a', expect(cpp.html).to have_tag('a',
without: { without: { class: "inline-onebox-loading" },
class: described_class::INLINE_ONEBOX_LOADING_CSS_CLASS
},
text: not_oneboxed_url, text: not_oneboxed_url,
count: 1 count: 1
) )
@ -131,10 +126,6 @@ describe CookedPostProcessor do
end end
describe 'when post contains inline oneboxes' do describe 'when post contains inline oneboxes' do
let(:loading_css_class) do
described_class::INLINE_ONEBOX_LOADING_CSS_CLASS
end
before do before do
SiteSetting.enable_inline_onebox_on_all_domains = true SiteSetting.enable_inline_onebox_on_all_domains = true
end end
@ -148,12 +139,8 @@ describe CookedPostProcessor do
cpp.post_process cpp.post_process
expect(cpp.html).to have_tag('a', expect(cpp.html).to have_tag('a',
with: { with: { href: UrlHelper.cook_url(url) },
href: UrlHelper.cook_url(url) without: { class: "inline-onebox-loading" },
},
without: {
class: loading_css_class
},
text: topic.title, text: topic.title,
count: 1 count: 1
) )
@ -163,12 +150,8 @@ describe CookedPostProcessor do
cpp.post_process cpp.post_process
expect(cpp.html).to have_tag('a', expect(cpp.html).to have_tag('a',
with: { with: { href: UrlHelper.cook_url(url) },
href: UrlHelper.cook_url(url) without: { class: "inline-onebox-loading" },
},
without: {
class: loading_css_class
},
text: topic.title, text: topic.title,
count: 1 count: 1
) )
@ -235,33 +218,21 @@ describe CookedPostProcessor do
html = cpp.html html = cpp.html
expect(html).to_not have_tag('a', expect(html).to_not have_tag('a',
with: { with: { href: url_no_path },
href: url_no_path without: { class: "inline-onebox-loading" },
},
without: {
class: loading_css_class
},
text: title text: title
) )
expect(html).to have_tag('a', expect(html).to have_tag('a',
with: { with: { href: url_with_path },
href: url_with_path without: { class: "inline-onebox-loading" },
},
without: {
class: loading_css_class
},
text: title, text: title,
count: 2 count: 2
) )
expect(html).to have_tag('a', expect(html).to have_tag('a',
with: { with: { href: url_with_query_param },
href: url_with_query_param without: { class: "inline-onebox-loading" },
},
without: {
class: loading_css_class
},
text: title, text: title,
count: 1 count: 1
) )

View File

@ -1,5 +1,4 @@
import { acceptance } from "helpers/qunit-helpers"; import { acceptance } from "helpers/qunit-helpers";
import { INLINE_ONEBOX_CSS_CLASS } from "pretty-text/context/inline-onebox-css-classes";
acceptance("Composer - Onebox", { acceptance("Composer - Onebox", {
loggedIn: true, loggedIn: true,
@ -36,10 +35,10 @@ http://www.example.com/has-title.html
.trim(), .trim(),
` `
<p><aside class=\"onebox\"><article class=\"onebox-body\"><h3><a href=\"http://www.example.com/article.html\">An interesting article</a></h3></article></aside><br> <p><aside class=\"onebox\"><article class=\"onebox-body\"><h3><a href=\"http://www.example.com/article.html\">An interesting article</a></h3></article></aside><br>
This is another test <a href=\"http://www.example.com/has-title.html\" class=\"${INLINE_ONEBOX_CSS_CLASS}\">This is a great title</a></p> This is another test <a href=\"http://www.example.com/has-title.html\" class=\"inline-onebox\">This is a great title</a></p>
<p><a href=\"http://www.example.com/no-title.html\" class=\"onebox\" target=\"_blank\">http://www.example.com/no-title.html</a></p> <p><a href=\"http://www.example.com/no-title.html\" class=\"onebox\" target=\"_blank\">http://www.example.com/no-title.html</a></p>
<p>This is another test <a href=\"http://www.example.com/no-title.html\" class=\"\">http://www.example.com/no-title.html</a><br> <p>This is another test <a href=\"http://www.example.com/no-title.html\" class=\"\">http://www.example.com/no-title.html</a><br>
This is another test <a href=\"http://www.example.com/has-title.html\" class=\"${INLINE_ONEBOX_CSS_CLASS}\">This is a great title</a></p> This is another test <a href=\"http://www.example.com/has-title.html\" class=\"inline-onebox\">This is a great title</a></p>
<p><aside class=\"onebox\"><article class=\"onebox-body\"><h3><a href=\"http://www.example.com/article.html\">An interesting article</a></h3></article></aside></p> <p><aside class=\"onebox\"><article class=\"onebox-body\"><h3><a href=\"http://www.example.com/article.html\">An interesting article</a></h3></article></aside></p>
`.trim() `.trim()
); );

View File

@ -2,7 +2,6 @@ import { buildQuote } from "discourse/lib/quote";
import Post from "discourse/models/post"; import Post from "discourse/models/post";
import PrettyText, { buildOptions } from "pretty-text/pretty-text"; import PrettyText, { buildOptions } from "pretty-text/pretty-text";
import { IMAGE_VERSION as v } from "pretty-text/emoji/version"; import { IMAGE_VERSION as v } from "pretty-text/emoji/version";
import { INLINE_ONEBOX_LOADING_CSS_CLASS } from "pretty-text/context/inline-onebox-css-classes";
import { import {
applyCachedInlineOnebox, applyCachedInlineOnebox,
deleteCachedInlineOnebox deleteCachedInlineOnebox
@ -205,7 +204,7 @@ QUnit.test("Links", assert => {
assert.cooked( assert.cooked(
`Youtube: ${link}`, `Youtube: ${link}`,
`<p>Youtube: <a href="${link}" class="${INLINE_ONEBOX_LOADING_CSS_CLASS}">${link}</a></p>`, `<p>Youtube: <a href="${link}" class="inline-onebox-loading">${link}</a></p>`,
"allows links to contain query params" "allows links to contain query params"
); );
@ -222,7 +221,7 @@ QUnit.test("Links", assert => {
assert.cooked( assert.cooked(
"Derpy: http://derp.com?__test=1", "Derpy: http://derp.com?__test=1",
`<p>Derpy: <a href="http://derp.com?__test=1" class="${INLINE_ONEBOX_LOADING_CSS_CLASS}">http://derp.com?__test=1</a></p>`, `<p>Derpy: <a href="http://derp.com?__test=1" class="inline-onebox-loading">http://derp.com?__test=1</a></p>`,
"works with double underscores in urls" "works with double underscores in urls"
); );
@ -252,7 +251,7 @@ QUnit.test("Links", assert => {
assert.cooked( assert.cooked(
"Batman: http://en.wikipedia.org/wiki/The_Dark_Knight_(film)", "Batman: http://en.wikipedia.org/wiki/The_Dark_Knight_(film)",
`<p>Batman: <a href="http://en.wikipedia.org/wiki/The_Dark_Knight_(film)" class="${INLINE_ONEBOX_LOADING_CSS_CLASS}">http://en.wikipedia.org/wiki/The_Dark_Knight_(film)</a></p>`, `<p>Batman: <a href="http://en.wikipedia.org/wiki/The_Dark_Knight_(film)" class="inline-onebox-loading">http://en.wikipedia.org/wiki/The_Dark_Knight_(film)</a></p>`,
"autolinks a URL with parentheses (like Wikipedia)" "autolinks a URL with parentheses (like Wikipedia)"
); );
@ -264,7 +263,7 @@ QUnit.test("Links", assert => {
assert.cooked( assert.cooked(
"1. View @eviltrout's profile here: http://meta.discourse.org/u/eviltrout/activity<br/>next line.", "1. View @eviltrout's profile here: http://meta.discourse.org/u/eviltrout/activity<br/>next line.",
`<ol>\n<li>View <span class="mention">@eviltrout</span>\'s profile here: <a href="http://meta.discourse.org/u/eviltrout/activity" class="${INLINE_ONEBOX_LOADING_CSS_CLASS}">http://meta.discourse.org/u/eviltrout/activity</a><br>next line.</li>\n</ol>`, `<ol>\n<li>View <span class="mention">@eviltrout</span>\'s profile here: <a href="http://meta.discourse.org/u/eviltrout/activity" class="inline-onebox-loading">http://meta.discourse.org/u/eviltrout/activity</a><br>next line.</li>\n</ol>`,
"allows autolinking within a list without inserting a paragraph." "allows autolinking within a list without inserting a paragraph."
); );
@ -289,8 +288,8 @@ QUnit.test("Links", assert => {
assert.cooked( assert.cooked(
"http://discourse.org and http://discourse.org/another_url and http://www.imdb.com/name/nm2225369", "http://discourse.org and http://discourse.org/another_url and http://www.imdb.com/name/nm2225369",
'<p><a href="http://discourse.org">http://discourse.org</a> and ' + '<p><a href="http://discourse.org">http://discourse.org</a> and ' +
`<a href="http://discourse.org/another_url" class="${INLINE_ONEBOX_LOADING_CSS_CLASS}">http://discourse.org/another_url</a> and ` + `<a href="http://discourse.org/another_url" class="inline-onebox-loading">http://discourse.org/another_url</a> and ` +
`<a href="http://www.imdb.com/name/nm2225369" class="${INLINE_ONEBOX_LOADING_CSS_CLASS}">http://www.imdb.com/name/nm2225369</a></p>`, `<a href="http://www.imdb.com/name/nm2225369" class="inline-onebox-loading">http://www.imdb.com/name/nm2225369</a></p>`,
"allows multiple links on one line" "allows multiple links on one line"
); );