Commit 6febc3ba authored by Axel García's avatar Axel García

Filter out epic tree item chevron button from Draggable component

parent 1a7ca4b0
...@@ -40,3 +40,5 @@ export const RemoveItemModalProps = { ...@@ -40,3 +40,5 @@ export const RemoveItemModalProps = {
export const OVERFLOW_AFTER = 5; export const OVERFLOW_AFTER = 5;
export const itemRemoveModalId = 'item-remove-confirmation'; export const itemRemoveModalId = 'item-remove-confirmation';
export const treeItemChevronBtnClassName = 'btn-tree-item-chevron';
import Draggable from 'vuedraggable'; import Draggable from 'vuedraggable';
import defaultSortableConfig from '~/sortable/sortable_config'; import defaultSortableConfig from '~/sortable/sortable_config';
import { idProp, relativePositions } from '../constants'; import { idProp, relativePositions, treeItemChevronBtnClassName } from '../constants';
export default { export default {
computed: { computed: {
...@@ -17,6 +17,10 @@ export default { ...@@ -17,6 +17,10 @@ export default {
'ghost-class': 'tree-item-drag-active', 'ghost-class': 'tree-item-drag-active',
'data-parent-reference': this.parentItem.reference, 'data-parent-reference': this.parentItem.reference,
value: this.children, value: this.children,
// This filters out/ignores all the chevron buttons (used for
// expanding and collapsing epic tree items) so the drag action
// can only be performed on the actual item card.
filter: `.${treeItemChevronBtnClassName}`,
}; };
return this.userSignedIn ? options : {}; return this.userSignedIn ? options : {};
......
...@@ -7,7 +7,7 @@ import TreeRoot from 'ee/related_items_tree/components/tree_root.vue'; ...@@ -7,7 +7,7 @@ import TreeRoot from 'ee/related_items_tree/components/tree_root.vue';
import createDefaultStore from 'ee/related_items_tree/store'; import createDefaultStore from 'ee/related_items_tree/store';
import * as epicUtils from 'ee/related_items_tree/utils/epic_utils'; import * as epicUtils from 'ee/related_items_tree/utils/epic_utils';
import { ChildType } from 'ee/related_items_tree/constants'; import { ChildType, treeItemChevronBtnClassName } from 'ee/related_items_tree/constants';
import { PathIdSeparator } from 'ee/related_issues/constants'; import { PathIdSeparator } from 'ee/related_issues/constants';
import Icon from '~/vue_shared/components/icon.vue'; import Icon from '~/vue_shared/components/icon.vue';
...@@ -142,6 +142,12 @@ describe('RelatedItemsTree', () => { ...@@ -142,6 +142,12 @@ describe('RelatedItemsTree', () => {
expect(chevronButton.attributes('title')).toBe('Collapse'); expect(chevronButton.attributes('title')).toBe('Collapse');
}); });
it('has the proper class on the expand/collapse button to avoid dragging', () => {
const chevronButton = wrapper.find(GlButton);
expect(chevronButton.attributes('class')).toContain(treeItemChevronBtnClassName);
});
it('renders expand/collapse icon', () => { it('renders expand/collapse icon', () => {
const expandedIcon = wrapperExpanded.find(Icon); const expandedIcon = wrapperExpanded.find(Icon);
const collapsedIcon = wrapperCollapsed.find(Icon); const collapsedIcon = wrapperCollapsed.find(Icon);
......
...@@ -7,6 +7,7 @@ import TreeRoot from 'ee/related_items_tree/components/tree_root.vue'; ...@@ -7,6 +7,7 @@ import TreeRoot from 'ee/related_items_tree/components/tree_root.vue';
import createDefaultStore from 'ee/related_items_tree/store'; import createDefaultStore from 'ee/related_items_tree/store';
import * as epicUtils from 'ee/related_items_tree/utils/epic_utils'; import * as epicUtils from 'ee/related_items_tree/utils/epic_utils';
import { treeItemChevronBtnClassName } from 'ee/related_items_tree/constants';
import { import {
mockQueryResponse, mockQueryResponse,
...@@ -116,6 +117,7 @@ describe('RelatedItemsTree', () => { ...@@ -116,6 +117,7 @@ describe('RelatedItemsTree', () => {
'ghost-class': 'tree-item-drag-active', 'ghost-class': 'tree-item-drag-active',
'data-parent-reference': mockParentItem.reference, 'data-parent-reference': mockParentItem.reference,
value: wrapper.vm.children, value: wrapper.vm.children,
filter: `.${treeItemChevronBtnClassName}`,
}), }),
); );
}); });
......
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