lbry-desktop/ui/util/web.js

109 lines
3 KiB
JavaScript
Raw Normal View History

const { URL, THUMBNAIL_CARDS_CDN_URL } = require('../../config');
2020-03-17 14:58:34 -04:00
const CONTINENT_COOKIE = 'continent';
2019-12-16 12:44:31 -05:00
2022-05-13 09:04:26 -03:00
function generateEmbedUrl(claimName, claimId, startTime, referralLink, newestType) {
2020-10-05 16:30:44 -04:00
let urlParams = new URLSearchParams();
2022-01-31 12:24:38 -03:00
if (startTime) {
2022-01-31 15:29:43 -03:00
urlParams.append('t', escapeHtmlProperty(startTime));
2020-10-05 16:30:44 -04:00
}
if (referralLink) {
2022-01-31 15:29:43 -03:00
urlParams.append('r', escapeHtmlProperty(referralLink));
2020-10-05 16:30:44 -04:00
}
2022-01-31 12:24:38 -03:00
const encodedUriName = encodeURIComponent(claimName).replace(/'/g, '%27').replace(/\(/g, '%28').replace(/\)/g, '%29');
2019-12-16 12:44:31 -05:00
2022-05-13 09:04:26 -03:00
let embedUrl;
if (newestType) {
embedUrl = `${URL}/$/embed/${escapeHtmlProperty(encodedUriName)}?feature=${newestType}`;
} else {
embedUrl = `${URL}/$/embed/${escapeHtmlProperty(encodedUriName)}/${escapeHtmlProperty(claimId)}`;
}
2022-01-31 12:24:38 -03:00
const embedUrlParams = urlParams.toString() ? `?${urlParams.toString()}` : '';
2022-01-29 15:24:35 -05:00
2022-01-31 12:24:38 -03:00
return `${embedUrl}${embedUrlParams}`;
}
2022-01-29 15:24:35 -05:00
2022-01-31 12:24:38 -03:00
function generateEmbedUrlEncoded(claimName, claimId, startTime, referralLink) {
return generateEmbedUrl(claimName, claimId, startTime, referralLink).replace(/\$/g, '%24');
2022-01-29 15:24:35 -05:00
}
function generateEmbedIframeData(src) {
const width = '560';
const height = '315';
const html = `<iframe id="odysee-iframe" width="${width}" height="${height}" src="${src}" allowfullscreen></iframe>`;
return { html, width, height };
}
2020-03-25 17:49:14 -04:00
function generateDownloadUrl(claimName, claimId) {
2020-03-30 09:14:01 -04:00
return `${URL}/$/download/${claimName}/${claimId}`;
2020-01-07 13:17:43 -05:00
}
2020-03-27 14:57:03 -04:00
function generateDirectUrl(claimName, claimId) {
return `${URL}/$/stream/${claimName}/${claimId}`;
}
2022-05-13 09:04:26 -03:00
function generateNewestUrl(channelName, newestType) {
return `${URL}/$/${newestType}/${channelName}`;
}
function getThumbnailCdnUrl(url) {
if (
!THUMBNAIL_CARDS_CDN_URL ||
!url ||
(url && (url.includes('https://twitter-card') || url.includes('https://cards.odysee.com')))
) {
return url;
}
if (url && !url.startsWith('data:image')) {
const encodedURL = Buffer.from(url).toString('base64');
return `${THUMBNAIL_CARDS_CDN_URL}${encodedURL}.jpg`;
}
}
function getParameterByName(name, url) {
var match = RegExp('[?&]' + name + '=([^&]*)').exec(url);
return match && decodeURIComponent(match[1].replace(/\+/g, ' '));
}
function escapeHtmlProperty(property) {
return property
? String(property)
.replace(/&/g, '&amp;')
.replace(/</g, '&lt;')
.replace(/>/g, '&gt;')
.replace(/"/g, '&quot;')
.replace(/'/g, '&#039;')
: '';
}
2022-02-08 14:45:19 -03:00
function unscapeHtmlProperty(property) {
return property
? String(property)
.replace(/&amp;/g, '&')
.replace(/&lt;/g, '<')
.replace(/&gt;/g, '>')
.replace(/&quot;/g, '"')
.replace(/&#039;/g, "'")
: '';
}
2019-11-07 14:39:22 -05:00
// module.exports needed since the web server imports this function
module.exports = {
CONTINENT_COOKIE,
generateDirectUrl,
generateDownloadUrl,
generateEmbedIframeData,
generateEmbedUrl,
2022-01-29 15:24:35 -05:00
generateEmbedUrlEncoded,
getParameterByName,
getThumbnailCdnUrl,
escapeHtmlProperty,
2022-02-08 14:45:19 -03:00
unscapeHtmlProperty,
2022-05-13 09:04:26 -03:00
generateNewestUrl,
};