Commit cfce1962 authored by Miguel Rincon's avatar Miguel Rincon

Refactor getParameterByName

This change refactors getParameterByName to use queryToObject instead
of parsing URLs.
parent df7369e5
...@@ -86,11 +86,11 @@ export default class GroupFilterableList extends FilterableList { ...@@ -86,11 +86,11 @@ export default class GroupFilterableList extends FilterableList {
// Get option query param, also preserve currently applied query param // Get option query param, also preserve currently applied query param
const sortParam = getParameterByName( const sortParam = getParameterByName(
'sort', 'sort',
isOptionFilterBySort ? e.currentTarget.href : window.location.href, isOptionFilterBySort ? e.currentTarget.search : window.location.search,
); );
const archivedParam = getParameterByName( const archivedParam = getParameterByName(
'archived', 'archived',
isOptionFilterByArchivedProjects ? e.currentTarget.href : window.location.href, isOptionFilterByArchivedProjects ? e.currentTarget.search : window.location.search,
); );
if (sortParam) { if (sortParam) {
......
...@@ -107,25 +107,6 @@ export function getParameterValues(sParam, url = window.location) { ...@@ -107,25 +107,6 @@ export function getParameterValues(sParam, url = window.location) {
}, []); }, []);
} }
/**
* This function accepts the `name` of the param to parse in the url
* if the name does not exist this function will return `null`
* otherwise it will return the value of the param key provided
*
* @param {String} name
* @param {String?} urlToParse
* @returns value of the parameter as string
*/
export const getParameterByName = (name, urlToParse) => {
const url = urlToParse || window.location.href;
const parsedName = name.replace(/[[\]]/g, '\\$&');
const regex = new RegExp(`[?&]${parsedName}(=([^&#]*)|&|#|$)`);
const results = regex.exec(url);
if (!results) return null;
if (!results[2]) return '';
return decodeUrlParameter(results[2]);
};
/** /**
* Merges a URL to a set of params replacing value for * Merges a URL to a set of params replacing value for
* those already present. * those already present.
...@@ -517,6 +498,19 @@ export function queryToObject(query, { gatherArrays = false, legacySpacesDecode ...@@ -517,6 +498,19 @@ export function queryToObject(query, { gatherArrays = false, legacySpacesDecode
}, {}); }, {});
} }
/**
* This function accepts the `name` of the param to parse in the url
* if the name does not exist this function will return `null`
* otherwise it will return the value of the param key provided
*
* @param {String} name
* @param {String?} urlToParse
* @returns value of the parameter as string
*/
export const getParameterByName = (name, query = window.location.search) => {
return queryToObject(query)[name] || null;
};
/** /**
* Convert search query object back into a search query * Convert search query object back into a search query
* *
......
...@@ -54,7 +54,7 @@ describe('Compare diff version dropdowns', () => { ...@@ -54,7 +54,7 @@ describe('Compare diff version dropdowns', () => {
Object.defineProperty(window, 'location', { Object.defineProperty(window, 'location', {
writable: true, writable: true,
value: { href: `https://example.gitlab.com${diffHeadParam}` }, value: { search: diffHeadParam },
}); });
expectedFirstVersion = { expectedFirstVersion = {
......
...@@ -101,48 +101,6 @@ describe('URL utility', () => { ...@@ -101,48 +101,6 @@ describe('URL utility', () => {
}); });
}); });
describe('getParameterByName', () => {
const { getParameterByName } = urlUtils;
it('should return valid parameter', () => {
setWindowLocation({ href: 'https://gitlab.com?scope=all&p=2' });
expect(getParameterByName('p')).toEqual('2');
expect(getParameterByName('scope')).toBe('all');
});
it('should return invalid parameter', () => {
setWindowLocation({ href: 'https://gitlab.com?scope=all&p=2' });
expect(getParameterByName('fakeParameter')).toBe(null);
});
it('should return a parameter with spaces', () => {
setWindowLocation({ href: 'https://gitlab.com?search=my terms' });
expect(getParameterByName('search')).toBe('my terms');
});
it('should return a parameter with encoded spaces', () => {
setWindowLocation({ href: 'https://gitlab.com?search=my%20terms' });
expect(getParameterByName('search')).toBe('my terms');
});
it('should return a parameter with plus signs as spaces', () => {
setWindowLocation({ href: 'https://gitlab.com?search=my+terms' });
expect(getParameterByName('search')).toBe('my terms');
});
it('should return valid parameters if URL is provided', () => {
expect(getParameterByName('foo', 'http://cocteau.twins?foo=bar')).toBe('bar');
expect(getParameterByName('manan', 'http://cocteau.twins?foo=bar&manan=canchu')).toBe(
'canchu',
);
});
});
describe('mergeUrlParams', () => { describe('mergeUrlParams', () => {
const { mergeUrlParams } = urlUtils; const { mergeUrlParams } = urlUtils;
...@@ -764,6 +722,49 @@ describe('URL utility', () => { ...@@ -764,6 +722,49 @@ describe('URL utility', () => {
}); });
}); });
describe('getParameterByName', () => {
const { getParameterByName } = urlUtils;
it('should return valid parameter', () => {
setWindowLocation({ search: '?scope=all&p=2' });
expect(getParameterByName('p')).toEqual('2');
expect(getParameterByName('scope')).toBe('all');
});
it('should return invalid parameter', () => {
setWindowLocation({ search: '?scope=all&p=2' });
expect(getParameterByName('fakeParameter')).toBe(null);
});
it('should return a parameter with spaces', () => {
setWindowLocation({ search: '?search=my terms' });
expect(getParameterByName('search')).toBe('my terms');
});
it('should return a parameter with encoded spaces', () => {
setWindowLocation({ search: '?search=my%20terms' });
expect(getParameterByName('search')).toBe('my terms');
});
it('should return a parameter with plus signs as spaces', () => {
setWindowLocation({ search: '?search=my+terms' });
expect(getParameterByName('search')).toBe('my terms');
});
it('should return valid parameters if search is provided', () => {
expect(getParameterByName('foo', 'foo=bar')).toBe('bar');
expect(getParameterByName('foo', '?foo=bar')).toBe('bar');
expect(getParameterByName('manan', 'foo=bar&manan=canchu')).toBe('canchu');
expect(getParameterByName('manan', '?foo=bar&manan=canchu')).toBe('canchu');
});
});
describe('objectToQuery', () => { describe('objectToQuery', () => {
it('converts search query object back into a search query', () => { it('converts search query object back into a search query', () => {
const searchQueryObject = { one: '1', two: '2' }; const searchQueryObject = { one: '1', two: '2' };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment