Commit 7fd347f3 authored by Savas Vedova's avatar Savas Vedova

Merge branch 'peterhegman/fix-settings-panels-deep-linking' into 'master'

Fix deep linking into settings panels

See merge request gitlab-org/gitlab!79689
parents d9e7267b 850f9790
...@@ -18,8 +18,6 @@ export function expandSection(sectionArg) { ...@@ -18,8 +18,6 @@ export function expandSection(sectionArg) {
const $section = $(sectionArg); const $section = $(sectionArg);
$section.find('.js-settings-toggle:not(.js-settings-toggle-trigger-only)').text(__('Collapse')); $section.find('.js-settings-toggle:not(.js-settings-toggle-trigger-only)').text(__('Collapse'));
// eslint-disable-next-line @gitlab/no-global-event-off
$section.find('.settings-content').off('scroll.expandSection').scrollTop(0);
$section.addClass('expanded'); $section.addClass('expanded');
if (!$section.hasClass('no-animate')) { if (!$section.hasClass('no-animate')) {
$section $section
...@@ -32,7 +30,6 @@ export function closeSection(sectionArg) { ...@@ -32,7 +30,6 @@ export function closeSection(sectionArg) {
const $section = $(sectionArg); const $section = $(sectionArg);
$section.find('.js-settings-toggle:not(.js-settings-toggle-trigger-only)').text(__('Expand')); $section.find('.js-settings-toggle:not(.js-settings-toggle-trigger-only)').text(__('Expand'));
$section.find('.settings-content').on('scroll.expandSection', () => expandSection($section));
$section.removeClass('expanded'); $section.removeClass('expanded');
if (!$section.hasClass('no-animate')) { if (!$section.hasClass('no-animate')) {
$section $section
...@@ -55,18 +52,16 @@ export default function initSettingsPanels() { ...@@ -55,18 +52,16 @@ export default function initSettingsPanels() {
const $section = $(elm); const $section = $(elm);
$section.on('click.toggleSection', '.js-settings-toggle', () => toggleSection($section)); $section.on('click.toggleSection', '.js-settings-toggle', () => toggleSection($section));
if (!isExpanded($section)) {
$section.find('.settings-content').on('scroll.expandSection', () => {
$section.removeClass('no-animate');
expandSection($section);
});
}
});
if (window.location.hash) { if (window.location.hash) {
const $target = $(window.location.hash); const $target = $(window.location.hash);
if ($target.length && $target.hasClass('settings')) { if (
expandSection($target); $target.length &&
!isExpanded($section) &&
($section.is($target) || $section.find($target).length)
) {
$section.addClass('no-animate');
expandSection($section);
} }
} }
});
} }
...@@ -24,6 +24,20 @@ describe('Settings Panels', () => { ...@@ -24,6 +24,20 @@ describe('Settings Panels', () => {
expect(isExpanded(panel)).toBe(true); expect(isExpanded(panel)).toBe(true);
}); });
it('should expand panel containing linked hash', () => {
window.location.hash = '#group_description';
const panel = document.querySelector('#js-general-settings');
// Our test environment automatically expands everything so we need to clear that out first
panel.classList.remove('expanded');
expect(isExpanded(panel)).toBe(false);
initSettingsPanels();
expect(isExpanded(panel)).toBe(true);
});
}); });
it('does not change the text content of triggers', () => { it('does not change the text content of triggers', () => {
......
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