Revert "correct more specs"

This reverts commit 40bcc6bbdc.
This commit is contained in:
Sam 2017-07-12 18:10:05 -04:00
parent 8caaa6a56e
commit d609f8a53c
3 changed files with 44 additions and 15 deletions

View File

@ -1,10 +1,9 @@
import { cook as cookIt, setup as setupIt } from 'pretty-text/engines/discourse-markdown-it'; import { cook as cookIt, setup as setupIt } from 'pretty-text/engines/discourse-markdown-it';
export function registerOption() { export function registerOption() {
// TODO next major version deprecate this if (window.console) {
// if (window.console) { window.console.log("registerOption is deprecated");
// window.console.log("registerOption is deprecated"); }
// }
} }
export function buildOptions(state) { export function buildOptions(state) {

View File

@ -1,3 +1,25 @@
import { registerOption } from 'pretty-text/pretty-text';
function insertDetails(_, summary, details) {
return `<details><summary>${summary}</summary>${details}</details>`;
}
// replace all [details] BBCode with HTML 5.1 equivalent
function replaceDetails(text) {
text = text || "";
while (text !== (text = text.replace(/\[details=([^\]]+)\]((?:(?!\[details=[^\]]+\]|\[\/details\])[\S\s])*)\[\/details\]/ig, insertDetails)));
// add new lines to make sure we *always* have a <p> element after </summary> and around </details>
// otherwise we can't hide the content since we can't target text nodes via CSS
return text.replace(/<\/summary>/ig, "</summary>\n\n")
.replace(/<\/details>/ig, "\n\n</details>\n\n");
}
registerOption((siteSettings, opts) => {
opts.features.details = true;
});
const rule = { const rule = {
tag: 'details', tag: 'details',
before: function(state, attrs) { before: function(state, attrs) {
@ -24,7 +46,11 @@ export function setup(helper) {
'details.elided' 'details.elided'
]); ]);
if (helper.markdownIt) {
helper.registerPlugin(md => { helper.registerPlugin(md => {
md.block.bbcode_ruler.push('details', rule); md.block.bbcode_ruler.push('details', rule);
}); });
} else {
helper.addPreProcessor(text => replaceDetails(text));
}
} }

View File

@ -8,7 +8,7 @@ const defaultOpts = buildOptions({
emoji_set: 'emoji_one', emoji_set: 'emoji_one',
highlighted_languages: 'json|ruby|javascript', highlighted_languages: 'json|ruby|javascript',
default_code_lang: 'auto', default_code_lang: 'auto',
censored_words: '' censored_words: 'shucks|whiz|whizzer'
}, },
getURL: url => url getURL: url => url
}); });
@ -19,13 +19,17 @@ test("details", assert => {
assert.equal(new PrettyText(defaultOpts).cook(input), expected.replace(/\/>/g, ">"), text); assert.equal(new PrettyText(defaultOpts).cook(input), expected.replace(/\/>/g, ">"), text);
}; };
cooked(`<details><summary>Info</summary>coucou</details>`, cooked(`<details><summary>Info</summary>coucou</details>`,
`<details><summary>Info</summary>coucou</details>`, `<details><summary>Info</summary>\n\n<p>coucou</p>\n\n</details>`,
"manual HTML for details"); "manual HTML for details");
cooked(` <details><summary>Info</summary>coucou</details>`,
`<details><summary>Info</summary>\n\n<p>coucou</p>\n\n</details>`,
"manual HTML for details with a space");
cooked("[details=testing]\ntest\n[/details]", cooked(`<details open="open"><summary>Info</summary>coucou</details>`,
`<details> `<details open="open"><summary>Info</summary>\n\n<p>coucou</p>\n\n</details>`,
<summary> "open attribute");
testing</summary>
<p>test</p> cooked(`<details open><summary>Info</summary>coucou</details>`,
</details>`); `<details open><summary>Info</summary>\n\n<p>coucou</p>\n\n</details>`,
"open attribute");
}); });