lbry-desktop/ui/util/query-params.js

80 lines
2.4 KiB
JavaScript
Raw Normal View History

2020-07-27 16:04:12 -04:00
// @flow
import { SEARCH_OPTIONS } from 'constants/search';
const DEFAULT_SEARCH_RESULT_FROM = 0;
const DEFAULT_SEARCH_SIZE = 20;
export function parseQueryParams(queryString: string) {
if (queryString === '') return {};
2017-11-24 11:31:05 -03:00
const parts = queryString
.split('?')
2017-11-24 11:31:05 -03:00
.pop()
.split('&')
.map(p => p.split('='));
2017-05-07 19:50:32 +07:00
const params = {};
parts.forEach(array => {
const [first, second] = array;
params[first] = second;
2017-06-06 17:19:12 -04:00
});
2017-05-07 19:50:32 +07:00
return params;
}
2019-07-19 10:52:42 -04:00
// https://stackoverflow.com/questions/5999118/how-can-i-add-or-update-a-query-string-parameter
2020-07-27 16:04:12 -04:00
export function updateQueryParam(uri: string, key: string, value: string) {
2019-07-17 16:49:06 -04:00
const re = new RegExp('([?&])' + key + '=.*?(&|$)', 'i');
2019-10-10 10:53:42 +05:30
const separator = uri.includes('?') ? '&' : '?';
2019-07-17 16:49:06 -04:00
if (uri.match(re)) {
return uri.replace(re, '$1' + key + '=' + value + '$2');
} else {
return uri + separator + key + '=' + value;
}
}
2020-07-27 16:04:12 -04:00
export const getSearchQueryString = (query: string, options: any = {}) => {
const encodedQuery = encodeURIComponent(query);
const queryParams = [
`s=${encodedQuery}`,
`size=${options.size || DEFAULT_SEARCH_SIZE}`,
`from=${options.from || DEFAULT_SEARCH_RESULT_FROM}`,
];
const { isBackgroundSearch } = options;
const includeUserOptions = typeof isBackgroundSearch === 'undefined' ? false : !isBackgroundSearch;
if (includeUserOptions) {
const claimType = options[SEARCH_OPTIONS.CLAIM_TYPE];
if (claimType) {
queryParams.push(`claimType=${claimType}`);
// If they are only searching for channels, strip out the media info
if (!claimType.includes(SEARCH_OPTIONS.INCLUDE_CHANNELS)) {
queryParams.push(
`mediaType=${[
SEARCH_OPTIONS.MEDIA_FILE,
SEARCH_OPTIONS.MEDIA_AUDIO,
SEARCH_OPTIONS.MEDIA_VIDEO,
SEARCH_OPTIONS.MEDIA_TEXT,
SEARCH_OPTIONS.MEDIA_IMAGE,
SEARCH_OPTIONS.MEDIA_APPLICATION,
].reduce((acc, currentOption) => (options[currentOption] ? `${acc}${currentOption},` : acc), '')}`
);
}
}
}
const additionalOptions = {};
const { related_to } = options;
const { nsfw } = options;
if (related_to) additionalOptions['related_to'] = related_to;
if (typeof nsfw !== 'undefined') additionalOptions['nsfw'] = nsfw;
if (additionalOptions) {
Object.keys(additionalOptions).forEach(key => {
const option = additionalOptions[key];
queryParams.push(`${key}=${option}`);
});
}
return queryParams.join('&');
};