Commit 94747599 authored by Vitaly Slobodin's avatar Vitaly Slobodin

Merge branch 'mrincon-refactor-page-dataset-common-functions' into 'master'

Move page path functions out of commons file

See merge request gitlab-org/gitlab!65465
parents 61820f46 7b0dad22
...@@ -11,31 +11,10 @@ import { isObject } from './type_utility'; ...@@ -11,31 +11,10 @@ import { isObject } from './type_utility';
import { getLocationHash } from './url_utility'; import { getLocationHash } from './url_utility';
export const getPagePath = (index = 0) => { export const getPagePath = (index = 0) => {
const page = $('body').attr('data-page') || ''; const { page = '' } = document?.body?.dataset;
return page.split(':')[index]; return page.split(':')[index];
}; };
export const getDashPath = (path = window.location.pathname) => path.split('/-/')[1] || null;
export const isInGroupsPage = () => getPagePath() === 'groups';
export const isInProjectPage = () => getPagePath() === 'projects';
export const getProjectSlug = () => {
if (isInProjectPage()) {
return $('body').data('project');
}
return null;
};
export const getGroupSlug = () => {
if (isInProjectPage() || isInGroupsPage()) {
return $('body').data('group');
}
return null;
};
export const checkPageAndAction = (page, action) => { export const checkPageAndAction = (page, action) => {
const pagePath = getPagePath(1); const pagePath = getPagePath(1);
const actionPath = getPagePath(2); const actionPath = getPagePath(2);
...@@ -49,6 +28,8 @@ export const isInDesignPage = () => checkPageAndAction('issues', 'designs'); ...@@ -49,6 +28,8 @@ export const isInDesignPage = () => checkPageAndAction('issues', 'designs');
export const isInMRPage = () => checkPageAndAction('merge_requests', 'show'); export const isInMRPage = () => checkPageAndAction('merge_requests', 'show');
export const isInEpicPage = () => checkPageAndAction('epics', 'show'); export const isInEpicPage = () => checkPageAndAction('epics', 'show');
export const getDashPath = (path = window.location.pathname) => path.split('/-/')[1] || null;
export const getCspNonceValue = () => { export const getCspNonceValue = () => {
const metaTag = document.querySelector('meta[name=csp-nonce]'); const metaTag = document.querySelector('meta[name=csp-nonce]');
return metaTag && metaTag.content; return metaTag && metaTag.content;
......
...@@ -8,13 +8,13 @@ import { DEFAULT_DEBOUNCE_AND_THROTTLE_MS } from '~/lib/utils/constants'; ...@@ -8,13 +8,13 @@ import { DEFAULT_DEBOUNCE_AND_THROTTLE_MS } from '~/lib/utils/constants';
import { s__, __, sprintf } from '~/locale'; import { s__, __, sprintf } from '~/locale';
import Tracking from '~/tracking'; import Tracking from '~/tracking';
import axios from './lib/utils/axios_utils'; import axios from './lib/utils/axios_utils';
import { spriteIcon } from './lib/utils/common_utils';
import { import {
isInGroupsPage, isInGroupsPage,
isInProjectPage, isInProjectPage,
getGroupSlug, getGroupSlug,
getProjectSlug, getProjectSlug,
spriteIcon, } from './search_autocomplete_utils';
} from './lib/utils/common_utils';
/** /**
* Search input in top navigation bar. * Search input in top navigation bar.
......
import { getPagePath } from './lib/utils/common_utils';
export const isInGroupsPage = () => getPagePath() === 'groups';
export const isInProjectPage = () => getPagePath() === 'projects';
export const getProjectSlug = () => {
if (isInProjectPage()) {
return document?.body?.dataset?.project;
}
return null;
};
export const getGroupSlug = () => {
if (isInProjectPage() || isInGroupsPage()) {
return document?.body?.dataset?.group;
}
return null;
};
import * as commonUtils from '~/lib/utils/common_utils'; import * as commonUtils from '~/lib/utils/common_utils';
describe('common_utils', () => { describe('common_utils', () => {
describe('getPagePath', () => {
const { getPagePath } = commonUtils;
let originalBody;
beforeEach(() => {
originalBody = document.body;
document.body = document.createElement('body');
});
afterEach(() => {
document.body = originalBody;
});
it('returns an empty path if none is defined', () => {
expect(getPagePath()).toBe('');
expect(getPagePath(0)).toBe('');
});
describe('returns a path', () => {
const mockSection = 'my_section';
const mockSubSection = 'my_sub_section';
const mockPage = 'my_page';
it('returns a page', () => {
document.body.dataset.page = mockPage;
expect(getPagePath()).toBe(mockPage);
expect(getPagePath(0)).toBe(mockPage);
});
it('returns a section and page', () => {
document.body.dataset.page = `${mockSection}:${mockPage}`;
expect(getPagePath()).toBe(mockSection);
expect(getPagePath(0)).toBe(mockSection);
expect(getPagePath(1)).toBe(mockPage);
});
it('returns a section and subsection', () => {
document.body.dataset.page = `${mockSection}:${mockSubSection}:${mockPage}`;
expect(getPagePath()).toBe(mockSection);
expect(getPagePath(0)).toBe(mockSection);
expect(getPagePath(1)).toBe(mockSubSection);
expect(getPagePath(2)).toBe(mockPage);
});
});
});
describe('parseUrl', () => { describe('parseUrl', () => {
it('returns an anchor tag with url', () => { it('returns an anchor tag with url', () => {
expect(commonUtils.parseUrl('/some/absolute/url').pathname).toContain('some/absolute/url'); expect(commonUtils.parseUrl('/some/absolute/url').pathname).toContain('some/absolute/url');
......
/* eslint-disable no-unused-expressions, consistent-return, no-param-reassign, default-case, no-return-assign */
import AxiosMockAdapter from 'axios-mock-adapter'; import AxiosMockAdapter from 'axios-mock-adapter';
import $ from 'jquery'; import $ from 'jquery';
import { mockTracking, unmockTracking } from 'helpers/tracking_helper'; import { mockTracking, unmockTracking } from 'helpers/tracking_helper';
...@@ -22,31 +21,33 @@ describe('Search autocomplete dropdown', () => { ...@@ -22,31 +21,33 @@ describe('Search autocomplete dropdown', () => {
const groupName = 'Gitlab Org'; const groupName = 'Gitlab Org';
const removeBodyAttributes = () => { const removeBodyAttributes = () => {
const $body = $('body'); const { body } = document;
$body.removeAttr('data-page'); delete body.dataset.page;
$body.removeAttr('data-project'); delete body.dataset.project;
$body.removeAttr('data-group'); delete body.dataset.group;
}; };
// Add required attributes to body before starting the test. // Add required attributes to body before starting the test.
// section would be dashboard|group|project // section would be dashboard|group|project
const addBodyAttributes = (section) => { const addBodyAttributes = (section = 'dashboard') => {
if (section == null) {
section = 'dashboard';
}
const $body = $('body');
removeBodyAttributes(); removeBodyAttributes();
const { body } = document;
switch (section) { switch (section) {
case 'dashboard': case 'dashboard':
return $body.attr('data-page', 'root:index'); body.dataset.page = 'root:index';
break;
case 'group': case 'group':
$body.attr('data-page', 'groups:show'); body.dataset.page = 'groups:show';
return $body.data('group', 'gitlab-org'); body.dataset.group = 'gitlab-org';
break;
case 'project': case 'project':
$body.attr('data-page', 'projects:show'); body.dataset.page = 'projects:show';
return $body.data('project', 'gitlab-ce'); body.dataset.project = 'gitlab-ce';
break;
default:
break;
} }
}; };
...@@ -56,34 +57,31 @@ describe('Search autocomplete dropdown', () => { ...@@ -56,34 +57,31 @@ describe('Search autocomplete dropdown', () => {
// Mock `gl` object in window for dashboard specific page. App code will need it. // Mock `gl` object in window for dashboard specific page. App code will need it.
const mockDashboardOptions = () => { const mockDashboardOptions = () => {
window.gl || (window.gl = {}); window.gl.dashboardOptions = {
return (window.gl.dashboardOptions = {
issuesPath: dashboardIssuesPath, issuesPath: dashboardIssuesPath,
mrPath: dashboardMRsPath, mrPath: dashboardMRsPath,
}); };
}; };
// Mock `gl` object in window for project specific page. App code will need it. // Mock `gl` object in window for project specific page. App code will need it.
const mockProjectOptions = () => { const mockProjectOptions = () => {
window.gl || (window.gl = {}); window.gl.projectOptions = {
return (window.gl.projectOptions = {
'gitlab-ce': { 'gitlab-ce': {
issuesPath: projectIssuesPath, issuesPath: projectIssuesPath,
mrPath: projectMRsPath, mrPath: projectMRsPath,
projectName, projectName,
}, },
}); };
}; };
const mockGroupOptions = () => { const mockGroupOptions = () => {
window.gl || (window.gl = {}); window.gl.groupOptions = {
return (window.gl.groupOptions = {
'gitlab-org': { 'gitlab-org': {
issuesPath: groupIssuesPath, issuesPath: groupIssuesPath,
mrPath: groupMRsPath, mrPath: groupMRsPath,
projectName: groupName, projectName: groupName,
}, },
}); };
}; };
const assertLinks = (list, issuesPath, mrsPath) => { const assertLinks = (list, issuesPath, mrsPath) => {
...@@ -113,7 +111,7 @@ describe('Search autocomplete dropdown', () => { ...@@ -113,7 +111,7 @@ describe('Search autocomplete dropdown', () => {
window.gon.current_username = userName; window.gon.current_username = userName;
window.gl = window.gl || (window.gl = {}); window.gl = window.gl || (window.gl = {});
return (widget = initSearchAutocomplete({ autocompletePath })); widget = initSearchAutocomplete({ autocompletePath });
}); });
afterEach(() => { afterEach(() => {
......
import {
isInGroupsPage,
isInProjectPage,
getGroupSlug,
getProjectSlug,
} from '~/search_autocomplete_utils';
describe('search_autocomplete_utils', () => {
let originalBody;
beforeEach(() => {
originalBody = document.body;
document.body = document.createElement('body');
});
afterEach(() => {
document.body = originalBody;
});
describe('isInGroupsPage', () => {
it.each`
page | result
${'groups:index'} | ${true}
${'groups:show'} | ${true}
${'projects:show'} | ${false}
`(`returns $result in for page $page`, ({ page, result }) => {
document.body.dataset.page = page;
expect(isInGroupsPage()).toBe(result);
});
});
describe('isInProjectPage', () => {
it.each`
page | result
${'projects:index'} | ${true}
${'projects:show'} | ${true}
${'groups:show'} | ${false}
`(`returns $result in for page $page`, ({ page, result }) => {
document.body.dataset.page = page;
expect(isInProjectPage()).toBe(result);
});
});
describe('getProjectSlug', () => {
it('returns null when no project is present or on project page', () => {
expect(getProjectSlug()).toBe(null);
});
it('returns null when not on project page', () => {
document.body.dataset.project = 'gitlab';
expect(getProjectSlug()).toBe(null);
});
it('returns null when project is missing', () => {
document.body.dataset.page = 'projects';
expect(getProjectSlug()).toBe(undefined);
});
it('returns project', () => {
document.body.dataset.page = 'projects';
document.body.dataset.project = 'gitlab';
expect(getProjectSlug()).toBe('gitlab');
});
it('returns project in edit page', () => {
document.body.dataset.page = 'projects:edit';
document.body.dataset.project = 'gitlab';
expect(getProjectSlug()).toBe('gitlab');
});
});
describe('getGroupSlug', () => {
it('returns null when no group is present or on group page', () => {
expect(getGroupSlug()).toBe(null);
});
it('returns null when not on group page', () => {
document.body.dataset.group = 'gitlab-org';
expect(getGroupSlug()).toBe(null);
});
it('returns null when group is missing on groups page', () => {
document.body.dataset.page = 'groups';
expect(getGroupSlug()).toBe(undefined);
});
it('returns null when group is missing on project page', () => {
document.body.dataset.page = 'project';
expect(getGroupSlug()).toBe(null);
});
it.each`
page
${'groups'}
${'groups:edit'}
${'projects'}
${'projects:edit'}
`(`returns group in page $page`, ({ page }) => {
document.body.dataset.page = page;
document.body.dataset.group = 'gitlab-org';
expect(getGroupSlug()).toBe('gitlab-org');
});
});
});
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