aboutsummaryrefslogtreecommitdiff
path: root/src/client/views/nodes/WebBoxRenderer.js
diff options
context:
space:
mode:
Diffstat (limited to 'src/client/views/nodes/WebBoxRenderer.js')
-rw-r--r--src/client/views/nodes/WebBoxRenderer.js113
1 files changed, 57 insertions, 56 deletions
diff --git a/src/client/views/nodes/WebBoxRenderer.js b/src/client/views/nodes/WebBoxRenderer.js
index 425ef3e54..914adb404 100644
--- a/src/client/views/nodes/WebBoxRenderer.js
+++ b/src/client/views/nodes/WebBoxRenderer.js
@@ -2,7 +2,7 @@
*
* @param {StyleSheetList} styleSheets
*/
-var ForeignHtmlRenderer = function (styleSheets) {
+const ForeignHtmlRenderer = function (styleSheets) {
const self = this;
/**
@@ -10,7 +10,7 @@ var ForeignHtmlRenderer = function (styleSheets) {
* @param {String} binStr
*/
const binaryStringToBase64 = function (binStr) {
- return new Promise(function (resolve) {
+ return new Promise(resolve => {
const reader = new FileReader();
reader.readAsDataURL(binStr);
reader.onloadend = function () {
@@ -31,17 +31,17 @@ var ForeignHtmlRenderer = function (styleSheets) {
* @returns {Promise}
*/
const getResourceAsBase64 = function (webUrl, inurl) {
- return new Promise(function (resolve, reject) {
+ return new Promise((resolve, reject) => {
const xhr = new XMLHttpRequest();
- //const url = inurl.startsWith("/") && !inurl.startsWith("//") ? webUrl + inurl : inurl;
- //const url = CorsProxy(inurl.startsWith("/") && !inurl.startsWith("//") ? webUrl + inurl : inurl);// inurl.startsWith("http") ? CorsProxy(inurl) : inurl;
- var url = inurl;
+ // const url = inurl.startsWith("/") && !inurl.startsWith("//") ? webUrl + inurl : inurl;
+ // const url = CorsProxy(inurl.startsWith("/") && !inurl.startsWith("//") ? webUrl + inurl : inurl);// inurl.startsWith("http") ? CorsProxy(inurl) : inurl;
+ let url = inurl;
if (inurl.startsWith('/static')) {
url = new URL(webUrl).origin + inurl;
} else if (inurl.startsWith('/') && !inurl.startsWith('//')) {
url = CorsProxy(new URL(webUrl).origin + inurl);
} else if (!inurl.startsWith('http') && !inurl.startsWith('//')) {
- url = CorsProxy(webUrl + '/' + inurl);
+ url = CorsProxy(`${webUrl}/${inurl}`);
} else if (inurl.startsWith('https') && !inurl.startsWith(window.location.origin)) {
url = CorsProxy(inurl);
}
@@ -57,7 +57,7 @@ var ForeignHtmlRenderer = function (styleSheets) {
resourceBase64: resBase64,
});
} else if (xhr.readyState === XMLHttpRequest.DONE) {
- console.log("COULDN'T FIND: " + (inurl.startsWith('/') ? webUrl + inurl : inurl));
+ console.log(`COULDN'T FIND: ${inurl.startsWith('/') ? webUrl + inurl : inurl}`);
resolve({
resourceUrl: '',
resourceBase64: inurl,
@@ -76,7 +76,7 @@ var ForeignHtmlRenderer = function (styleSheets) {
*/
const getMultipleResourcesAsBase64 = function (webUrl, urls) {
const promises = [];
- for (let i = 0; i < urls.length; i++) {
+ for (let i = 0; i < urls.length; i += 1) {
promises.push(getResourceAsBase64(webUrl, urls[i]));
}
return Promise.all(promises);
@@ -98,7 +98,7 @@ var ForeignHtmlRenderer = function (styleSheets) {
}
let val = '';
- for (let i = idx + prefixToken.length; i < str.length; i++) {
+ for (let i = idx + prefixToken.length; i < str.length; i += 1) {
if (suffixTokens.indexOf(str[i]) !== -1) {
break;
}
@@ -114,6 +114,15 @@ var ForeignHtmlRenderer = function (styleSheets) {
/**
*
+ * @param {String} str
+ * @returns {String}
+ */
+ const removeQuotes = function (str) {
+ return str.replace(/["']/g, '');
+ };
+
+ /**
+ *
* @param {String} cssRuleStr
* @returns {String[]}
*/
@@ -127,13 +136,12 @@ var ForeignHtmlRenderer = function (styleSheets) {
break;
}
searchStartIndex = url.foundAtIndex + url.value.length + 1;
- if (mustEndWithQuote && url.value[url.value.length - 1] !== '"') continue;
- const unquoted = removeQuotes(url.value);
- if (!unquoted /* || (!unquoted.startsWith('http')&& !unquoted.startsWith("/") )*/ || unquoted === 'http://' || unquoted === 'https://') {
- continue;
+ if (!mustEndWithQuote || url.value[url.value.length - 1] === '"') {
+ const unquoted = removeQuotes(url.value);
+ if (unquoted /* || (!unquoted.startsWith('http')&& !unquoted.startsWith("/") ) */ && unquoted !== 'http://' && unquoted !== 'https://') {
+ if (unquoted) urlsFound.push(unquoted);
+ }
}
-
- unquoted && urlsFound.push(unquoted);
}
return urlsFound;
@@ -151,15 +159,6 @@ var ForeignHtmlRenderer = function (styleSheets) {
return getUrlsFromCssString(html, 'source=', [' ', '>', '\t'], true);
};
- /**
- *
- * @param {String} str
- * @returns {String}
- */
- const removeQuotes = function (str) {
- return str.replace(/["']/g, '');
- };
-
const escapeRegExp = function (string) {
return string.replace(/[.*+?^${}()|[\]\\]/g, '\\$&'); // $& means the whole matched string
};
@@ -172,8 +171,8 @@ var ForeignHtmlRenderer = function (styleSheets) {
*
* @returns {Promise<String>}
*/
- const buildSvgDataUri = async function (webUrl, contentHtml, width, height, scroll, xoff) {
- return new Promise(async function (resolve, reject) {
+ const buildSvgDataUri = async function (webUrl, inputContentHtml, width, height, scroll, xoff) {
+ return new Promise(async (resolve, reject) => {
/* !! The problems !!
* 1. CORS (not really an issue, expect perhaps for images, as this is a general security consideration to begin with)
* 2. Platform won't wait for external assets to load (fonts, images, etc.)
@@ -181,17 +180,19 @@ var ForeignHtmlRenderer = function (styleSheets) {
// copy styles
let cssStyles = '';
- let urlsFoundInCss = [];
+ const urlsFoundInCss = [];
- for (let i = 0; i < styleSheets.length; i++) {
+ for (let i = 0; i < styleSheets.length; i += 1) {
try {
const rules = styleSheets[i].cssRules;
- for (let j = 0; j < rules.length; j++) {
+ for (let j = 0; j < rules.length; j += 1) {
const cssRuleStr = rules[j].cssText;
urlsFoundInCss.push(...getUrlsFromCssString(cssRuleStr));
cssStyles += cssRuleStr;
}
- } catch (e) {}
+ } catch (e) {
+ /* empty */
+ }
}
// const fetchedResourcesFromStylesheets = await getMultipleResourcesAsBase64(webUrl, urlsFoundInCss);
@@ -202,15 +203,15 @@ var ForeignHtmlRenderer = function (styleSheets) {
// }
// }
- contentHtml = contentHtml
+ let contentHtml = inputContentHtml
.replace(/<source[^>]*>/g, '') // <picture> tags have a <source> which has a srcset field of image refs. instead of converting each, just use the default <img> of the picture
.replace(/noscript/g, 'div')
.replace(/<div class="mediaset"><\/div>/g, '') // when scripting isn't available (ie, rendering web pages here), <noscript> tags should become <div>'s. But for Brown CS, there's a layout problem if you leave the empty <mediaset> tag
.replace(/<link[^>]*>/g, '') // don't need to keep any linked style sheets because we've already processed all style sheets above
.replace(/srcset="([^ "]*)[^"]*"/g, 'src="$1"'); // instead of converting each item in the srcset to a data url, just convert the first one and use that
- let urlsFoundInHtml = getImageUrlsFromFromHtml(contentHtml).filter(url => !url.startsWith('data:'));
+ const urlsFoundInHtml = getImageUrlsFromFromHtml(contentHtml).filter(url => !url.startsWith('data:'));
const fetchedResources = webUrl ? await getMultipleResourcesAsBase64(webUrl, urlsFoundInHtml) : [];
- for (let i = 0; i < fetchedResources.length; i++) {
+ for (let i = 0; i < fetchedResources.length; i += 1) {
const r = fetchedResources[i];
if (r.resourceUrl) {
contentHtml = contentHtml.replace(new RegExp(escapeRegExp(r.resourceUrl), 'g'), r.resourceBase64);
@@ -230,7 +231,7 @@ var ForeignHtmlRenderer = function (styleSheets) {
// contentRootElem.style.transform = "scale(0.08)"
contentRootElem.innerHTML = styleElemString + contentHtml;
contentRootElem.setAttribute('xmlns', 'http://www.w3.org/1999/xhtml');
- //document.body.appendChild(contentRootElem);
+ // document.body.appendChild(contentRootElem);
const contentRootElemString = new XMLSerializer().serializeToString(contentRootElem);
@@ -256,13 +257,13 @@ var ForeignHtmlRenderer = function (styleSheets) {
* @return {Promise<Image>}
*/
this.renderToImage = async function (webUrl, html, width, height, scroll, xoff) {
- return new Promise(async function (resolve, reject) {
+ return new Promise(async (resolve, reject) => {
const img = new Image();
- console.log('BUILDING SVG for:' + webUrl);
+ console.log(`BUILDING SVG for: ${webUrl}`);
img.src = await buildSvgDataUri(webUrl, html, width, height, scroll, xoff);
img.onload = function () {
- console.log('IMAGE SVG created:' + webUrl);
+ console.log(`IMAGE SVG created: ${webUrl}`);
resolve(img);
};
});
@@ -276,7 +277,7 @@ var ForeignHtmlRenderer = function (styleSheets) {
* @return {Promise<Image>}
*/
this.renderToCanvas = async function (webUrl, html, width, height, scroll, xoff, oversample) {
- return new Promise(async function (resolve, reject) {
+ return new Promise(async (resolve, reject) => {
const img = await self.renderToImage(webUrl, html, width, height, scroll, xoff);
const canvas = document.createElement('canvas');
@@ -298,7 +299,7 @@ var ForeignHtmlRenderer = function (styleSheets) {
* @return {Promise<String>}
*/
this.renderToBase64Png = async function (webUrl, html, width, height, scroll, xoff, oversample) {
- return new Promise(async function (resolve, reject) {
+ return new Promise(async (resolve, reject) => {
const canvas = await self.renderToCanvas(webUrl, html, width, height, scroll, xoff, oversample);
resolve(canvas.toDataURL('image/png'));
});
@@ -320,8 +321,8 @@ export function CreateImage(webUrl, styleSheets, html, width, height, scroll, xo
);
}
-var ClipboardUtils = new (function () {
- var permissions = {
+const ClipboardUtils = new (function () {
+ const permissions = {
'image/bmp': true,
'image/gif': true,
'image/png': true,
@@ -330,8 +331,8 @@ var ClipboardUtils = new (function () {
};
function getType(types) {
- for (var j = 0; j < types.length; ++j) {
- var type = types[j];
+ for (let j = 0; j < types.length; j += 1) {
+ const type = types[j];
if (permissions[type]) {
return type;
}
@@ -339,10 +340,10 @@ var ClipboardUtils = new (function () {
return null;
}
function getItem(items) {
- for (var i = 0; i < items.length; ++i) {
- var item = items[i];
+ for (let i = 0; i < items.length; i += 1) {
+ const item = items[i];
if (item) {
- var type = getType(item.types);
+ const type = getType(item.types);
if (type) {
return item.getType(type);
}
@@ -352,7 +353,7 @@ var ClipboardUtils = new (function () {
}
function loadFile(file, callback) {
if (window.FileReader) {
- var reader = new FileReader();
+ const reader = new FileReader();
reader.onload = function () {
callback(reader.result, null);
};
@@ -366,23 +367,23 @@ var ClipboardUtils = new (function () {
}
this.readImage = function (callback) {
if (navigator.clipboard) {
- var promise = navigator.clipboard.read();
+ const promise = navigator.clipboard.read();
promise
- .then(function (items) {
- var promise = getItem(items);
- if (promise == null) {
+ .then(items => {
+ const promise2 = getItem(items);
+ if (promise2 == null) {
callback(null, null);
return;
}
- promise
- .then(function (result) {
+ promise2
+ .then(result => {
loadFile(result, callback);
})
- .catch(function (error) {
+ .catch(error => {
callback(null, 'Reading clipboard error.');
});
})
- .catch(function (error) {
+ .catch(error => {
callback(null, 'Reading clipboard error.');
});
} else {