From ea8094745ccc29e8cc57ea92c296476b4273b1be Mon Sep 17 00:00:00 2001 From: =?utf8?q?Tim=20D=C3=BCsterhus?= Date: Tue, 5 Jan 2021 15:11:11 +0100 Subject: [PATCH] Add WoltLabSuite/Core/Prism/Helper --- .../files/js/WoltLabSuite/Core/Prism.js | 7 ++- .../js/WoltLabSuite/Core/Prism/Helper.js | 53 +++++++++++++++++++ .../files/ts/WoltLabSuite/Core/Prism.js | 7 ++- .../ts/WoltLabSuite/Core/Prism/Helper.ts | 50 +++++++++++++++++ 4 files changed, 113 insertions(+), 4 deletions(-) create mode 100644 wcfsetup/install/files/js/WoltLabSuite/Core/Prism/Helper.js create mode 100644 wcfsetup/install/files/ts/WoltLabSuite/Core/Prism/Helper.ts diff --git a/wcfsetup/install/files/js/WoltLabSuite/Core/Prism.js b/wcfsetup/install/files/js/WoltLabSuite/Core/Prism.js index 5fe52c74da..68b0954371 100644 --- a/wcfsetup/install/files/js/WoltLabSuite/Core/Prism.js +++ b/wcfsetup/install/files/js/WoltLabSuite/Core/Prism.js @@ -1,14 +1,17 @@ /** - * Augments the Prism syntax highlighter with additional functions. + * Loads Prism while disabling automated highlighting. * * @author Tim Duesterhus - * @copyright 2001-2019 WoltLab GmbH + * @copyright 2001-2021 WoltLab GmbH * @license GNU Lesser General Public License * @module WoltLabSuite/Core/Prism */ window.Prism = window.Prism || {}; window.Prism.manual = true; define(['prism/prism'], function () { + /** + * @deprecated 5.4 - Use WoltLabSuite/Core/Prism/Helper#splitIntoLines. + */ Prism.wscSplitIntoLines = function (container) { var frag = document.createDocumentFragment(); var lineNo = 1; diff --git a/wcfsetup/install/files/js/WoltLabSuite/Core/Prism/Helper.js b/wcfsetup/install/files/js/WoltLabSuite/Core/Prism/Helper.js new file mode 100644 index 0000000000..b929d81224 --- /dev/null +++ b/wcfsetup/install/files/js/WoltLabSuite/Core/Prism/Helper.js @@ -0,0 +1,53 @@ +define(["require", "exports"], function (require, exports) { + "use strict"; + Object.defineProperty(exports, "__esModule", { value: true }); + exports.splitIntoLines = void 0; + /** + * Provide helper functions for prism processing. + * + * @author Tim Duesterhus + * @copyright 2001-2021 WoltLab GmbH + * @license GNU Lesser General Public License + * @module WoltLabSuite/Core/Prism/Helper + */ + function splitIntoLines(container) { + const frag = document.createDocumentFragment(); + let lineNo = 1; + const newLine = () => { + const line = document.createElement("span"); + line.dataset.number = lineNo.toString(); + lineNo++; + frag.appendChild(line); + return line; + }; + const it = document.createNodeIterator(container, NodeFilter.SHOW_TEXT, { + acceptNode() { + return NodeFilter.FILTER_ACCEPT; + }, + }); + let line = newLine(); + let node; + while ((node = it.nextNode())) { + const text = node; + text.data.split(/\r?\n/).forEach((codeLine, index) => { + // We are behind a newline, insert \n and create new container. + if (index >= 1) { + line.appendChild(document.createTextNode("\n")); + line = newLine(); + } + let current = document.createTextNode(codeLine); + // Copy hierarchy (to preserve CSS classes). + let parent = text.parentNode; + while (parent && parent !== container) { + const clone = parent.cloneNode(false); + clone.appendChild(current); + current = clone; + parent = parent.parentNode; + } + line.appendChild(current); + }); + } + return frag; + } + exports.splitIntoLines = splitIntoLines; +}); diff --git a/wcfsetup/install/files/ts/WoltLabSuite/Core/Prism.js b/wcfsetup/install/files/ts/WoltLabSuite/Core/Prism.js index 5fe52c74da..68b0954371 100644 --- a/wcfsetup/install/files/ts/WoltLabSuite/Core/Prism.js +++ b/wcfsetup/install/files/ts/WoltLabSuite/Core/Prism.js @@ -1,14 +1,17 @@ /** - * Augments the Prism syntax highlighter with additional functions. + * Loads Prism while disabling automated highlighting. * * @author Tim Duesterhus - * @copyright 2001-2019 WoltLab GmbH + * @copyright 2001-2021 WoltLab GmbH * @license GNU Lesser General Public License * @module WoltLabSuite/Core/Prism */ window.Prism = window.Prism || {}; window.Prism.manual = true; define(['prism/prism'], function () { + /** + * @deprecated 5.4 - Use WoltLabSuite/Core/Prism/Helper#splitIntoLines. + */ Prism.wscSplitIntoLines = function (container) { var frag = document.createDocumentFragment(); var lineNo = 1; diff --git a/wcfsetup/install/files/ts/WoltLabSuite/Core/Prism/Helper.ts b/wcfsetup/install/files/ts/WoltLabSuite/Core/Prism/Helper.ts new file mode 100644 index 0000000000..dee334bd1c --- /dev/null +++ b/wcfsetup/install/files/ts/WoltLabSuite/Core/Prism/Helper.ts @@ -0,0 +1,50 @@ +/** + * Provide helper functions for prism processing. + * + * @author Tim Duesterhus + * @copyright 2001-2021 WoltLab GmbH + * @license GNU Lesser General Public License + * @module WoltLabSuite/Core/Prism/Helper + */ +export function splitIntoLines(container: Node): DocumentFragment { + const frag = document.createDocumentFragment(); + let lineNo = 1; + const newLine = () => { + const line = document.createElement("span"); + line.dataset.number = lineNo.toString(); + lineNo++; + frag.appendChild(line); + return line; + }; + + const it = document.createNodeIterator(container, NodeFilter.SHOW_TEXT, { + acceptNode() { + return NodeFilter.FILTER_ACCEPT; + }, + }); + + let line = newLine(); + let node; + while ((node = it.nextNode())) { + const text = node as Text; + text.data.split(/\r?\n/).forEach((codeLine, index) => { + // We are behind a newline, insert \n and create new container. + if (index >= 1) { + line.appendChild(document.createTextNode("\n")); + line = newLine(); + } + + let current: Node = document.createTextNode(codeLine); + // Copy hierarchy (to preserve CSS classes). + let parent = text.parentNode; + while (parent && parent !== container) { + const clone = parent.cloneNode(false); + clone.appendChild(current); + current = clone; + parent = parent.parentNode; + } + line.appendChild(current); + }); + } + return frag; +} -- 2.20.1