2019-12-06 16:12:48 -05:00
|
|
|
// Can't use aliases here because we're doing exports/require
|
|
|
|
const PAGES = require('../constants/pages');
|
|
|
|
|
2019-12-02 12:30:08 -05:00
|
|
|
exports.formatLbryUrlForWeb = uri => {
|
|
|
|
return uri.replace('lbry://', '/').replace(/#/g, ':');
|
|
|
|
};
|
|
|
|
|
|
|
|
exports.formatFileSystemPath = path => {
|
|
|
|
if (!path) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
let webUrl = path.replace(/\\/g, '/');
|
|
|
|
|
|
|
|
if (webUrl[0] !== '/') {
|
|
|
|
webUrl = `/${webUrl}`;
|
|
|
|
}
|
|
|
|
|
|
|
|
return encodeURI(`file://${webUrl}`).replace(/[?#]/g, encodeURIComponent);
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
Function that handles page redirects
|
|
|
|
ex: lbry://?rewards
|
|
|
|
ex: open.lbry.com/?rewards
|
|
|
|
*/
|
2019-12-03 12:55:29 -05:00
|
|
|
exports.formatInAppUrl = path => {
|
2019-12-02 12:30:08 -05:00
|
|
|
// Determine if we need to add a leading "/$/" for app pages
|
|
|
|
const APP_PAGE_REGEX = /(\?)([a-z]*)(.*)/;
|
|
|
|
const appPageMatches = APP_PAGE_REGEX.exec(path);
|
|
|
|
|
|
|
|
if (appPageMatches && appPageMatches.length) {
|
|
|
|
// Definitely an app page (or it's formatted like one)
|
|
|
|
const [, , page, queryString] = appPageMatches;
|
|
|
|
|
2019-12-09 14:42:10 -05:00
|
|
|
if (Object.values(PAGES).includes(page)) {
|
|
|
|
let actualUrl = '/$/' + page;
|
|
|
|
|
|
|
|
if (queryString) {
|
|
|
|
actualUrl += `?${queryString.slice(1)}`;
|
|
|
|
}
|
2019-12-03 12:55:29 -05:00
|
|
|
|
2019-12-09 14:42:10 -05:00
|
|
|
return actualUrl;
|
|
|
|
}
|
2019-12-02 12:30:08 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// Regular claim url
|
|
|
|
return path;
|
|
|
|
};
|
2019-12-06 16:12:48 -05:00
|
|
|
|
|
|
|
exports.formatWebUrlIntoLbryUrl = (pathname, search) => {
|
|
|
|
// If there is no uri, the user is on an internal page
|
|
|
|
// pathname will either be "/" or "/$/{page}"
|
|
|
|
const path = pathname.startsWith('/$/') ? pathname.slice(3) : pathname.slice(1);
|
|
|
|
let appLink = `lbry://?${path || PAGES.DISCOVER}`;
|
|
|
|
|
|
|
|
if (search) {
|
|
|
|
// We already have a leading "?" for the query param on internal pages
|
|
|
|
appLink += search.replace('?', '&');
|
|
|
|
}
|
|
|
|
|
|
|
|
return appLink;
|
|
|
|
};
|