Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
e76764ed
Commit
e76764ed
authored
Jun 22, 2017
by
Phil Hughes
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'ee-33675-keep-groups-sorted-as-expected' into 'master'
Resolve "Can't sort Groups" See merge request !2156
parents
70b7e6ba
e75ae262
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
51 additions
and
15 deletions
+51
-15
app/assets/javascripts/groups/stores/groups_store.js
app/assets/javascripts/groups/stores/groups_store.js
+28
-14
spec/javascripts/groups/groups_spec.js
spec/javascripts/groups/groups_spec.js
+23
-1
No files found.
app/assets/javascripts/groups/stores/groups_store.js
View file @
e76764ed
...
@@ -47,8 +47,8 @@ export default class GroupsStore {
...
@@ -47,8 +47,8 @@ export default class GroupsStore {
// Map groups to an object
// Map groups to an object
groups
.
map
((
group
)
=>
{
groups
.
map
((
group
)
=>
{
mappedGroups
[
group
.
id
]
=
group
;
mappedGroups
[
`id
${
group
.
id
}
`
]
=
group
;
mappedGroups
[
group
.
id
].
subGroups
=
{};
mappedGroups
[
`id
${
group
.
id
}
`
].
subGroups
=
{};
return
group
;
return
group
;
});
});
...
@@ -56,26 +56,27 @@ export default class GroupsStore {
...
@@ -56,26 +56,27 @@ export default class GroupsStore {
const
currentGroup
=
mappedGroups
[
key
];
const
currentGroup
=
mappedGroups
[
key
];
if
(
currentGroup
.
parentId
)
{
if
(
currentGroup
.
parentId
)
{
// If the group is not at the root level, add it to its parent array of subGroups.
// If the group is not at the root level, add it to its parent array of subGroups.
const
findParentGroup
=
mappedGroups
[
currentGroup
.
parentId
];
const
findParentGroup
=
mappedGroups
[
`id
${
currentGroup
.
parentId
}
`
];
if
(
findParentGroup
)
{
if
(
findParentGroup
)
{
mappedGroups
[
currentGroup
.
parentId
].
subGroups
[
currentGroup
.
id
]
=
currentGroup
;
mappedGroups
[
`id
${
currentGroup
.
parentId
}
`
].
subGroups
[
`id
${
currentGroup
.
id
}
`
]
=
currentGroup
;
mappedGroups
[
currentGroup
.
parentId
].
isOpen
=
true
;
// Expand group if it has subgroups
mappedGroups
[
`id
${
currentGroup
.
parentId
}
`
].
isOpen
=
true
;
// Expand group if it has subgroups
}
else
if
(
parentGroup
&&
parentGroup
.
id
===
currentGroup
.
parentId
)
{
}
else
if
(
parentGroup
&&
parentGroup
.
id
===
currentGroup
.
parentId
)
{
tree
[
currentGroup
.
id
]
=
currentGroup
;
tree
[
`id
${
currentGroup
.
id
}
`
]
=
currentGroup
;
}
else
{
}
else
{
// Means the groups hast no direct parent.
// No parent found. We save it for later processing
// Save for later processing, we will add them to its corresponding base group
orphans
.
push
(
currentGroup
);
orphans
.
push
(
currentGroup
);
// Add to tree to preserve original order
tree
[
`id
${
currentGroup
.
id
}
`
]
=
currentGroup
;
}
}
}
else
{
}
else
{
// If the group is at the
root
level, add it to first level elements array.
// If the group is at the
top
level, add it to first level elements array.
tree
[
currentGroup
.
id
]
=
currentGroup
;
tree
[
`id
${
currentGroup
.
id
}
`
]
=
currentGroup
;
}
}
return
key
;
return
key
;
});
});
// Hopefully this array will be empty for most cases
if
(
orphans
.
length
)
{
if
(
orphans
.
length
)
{
orphans
.
map
((
orphan
)
=>
{
orphans
.
map
((
orphan
)
=>
{
let
found
=
false
;
let
found
=
false
;
...
@@ -83,11 +84,23 @@ export default class GroupsStore {
...
@@ -83,11 +84,23 @@ export default class GroupsStore {
Object
.
keys
(
tree
).
map
((
key
)
=>
{
Object
.
keys
(
tree
).
map
((
key
)
=>
{
const
group
=
tree
[
key
];
const
group
=
tree
[
key
];
if
(
currentOrphan
.
fullPath
.
lastIndexOf
(
group
.
fullPath
)
===
0
)
{
if
(
group
&&
currentOrphan
.
fullPath
.
lastIndexOf
(
group
.
fullPath
)
===
0
&&
// Make sure the currently selected orphan is not the same as the group
// we are checking here otherwise it will end up in an infinite loop
currentOrphan
.
id
!==
group
.
id
)
{
group
.
subGroups
[
currentOrphan
.
id
]
=
currentOrphan
;
group
.
subGroups
[
currentOrphan
.
id
]
=
currentOrphan
;
group
.
isOpen
=
true
;
group
.
isOpen
=
true
;
currentOrphan
.
isOrphan
=
true
;
currentOrphan
.
isOrphan
=
true
;
found
=
true
;
found
=
true
;
// Delete if group was put at the top level. If not the group will be displayed twice.
if
(
tree
[
`id
${
currentOrphan
.
id
}
`
])
{
delete
tree
[
`id
${
currentOrphan
.
id
}
`
];
}
}
}
return
key
;
return
key
;
...
@@ -95,7 +108,8 @@ export default class GroupsStore {
...
@@ -95,7 +108,8 @@ export default class GroupsStore {
if
(
!
found
)
{
if
(
!
found
)
{
currentOrphan
.
isOrphan
=
true
;
currentOrphan
.
isOrphan
=
true
;
tree
[
currentOrphan
.
id
]
=
currentOrphan
;
tree
[
`id
${
currentOrphan
.
id
}
`
]
=
currentOrphan
;
}
}
return
orphan
;
return
orphan
;
...
@@ -140,7 +154,7 @@ export default class GroupsStore {
...
@@ -140,7 +154,7 @@ export default class GroupsStore {
// eslint-disable-next-line class-methods-use-this
// eslint-disable-next-line class-methods-use-this
removeGroup
(
group
,
collection
)
{
removeGroup
(
group
,
collection
)
{
Vue
.
delete
(
collection
,
group
.
id
);
Vue
.
delete
(
collection
,
`id
${
group
.
id
}
`
);
}
}
// eslint-disable-next-line class-methods-use-this
// eslint-disable-next-line class-methods-use-this
...
...
spec/javascripts/groups/groups_spec.js
View file @
e76764ed
import
Vue
from
'
vue
'
;
import
Vue
from
'
vue
'
;
import
eventHub
from
'
~/groups/event_hub
'
;
import
groupFolderComponent
from
'
~/groups/components/group_folder.vue
'
;
import
groupFolderComponent
from
'
~/groups/components/group_folder.vue
'
;
import
groupItemComponent
from
'
~/groups/components/group_item.vue
'
;
import
groupItemComponent
from
'
~/groups/components/group_item.vue
'
;
import
groupsComponent
from
'
~/groups/components/groups.vue
'
;
import
groupsComponent
from
'
~/groups/components/groups.vue
'
;
...
@@ -46,6 +47,12 @@ describe('Groups Component', () => {
...
@@ -46,6 +47,12 @@ describe('Groups Component', () => {
expect
(
component
.
$el
.
querySelector
(
'
#group-1120
'
)).
toBeDefined
();
expect
(
component
.
$el
.
querySelector
(
'
#group-1120
'
)).
toBeDefined
();
});
});
it
(
'
should respect the order of groups
'
,
()
=>
{
const
wrap
=
component
.
$el
.
querySelector
(
'
.groups-list-tree-container > .group-list-tree
'
);
expect
(
wrap
.
querySelector
(
'
.group-row:nth-child(1)
'
).
id
).
toBe
(
'
group-12
'
);
expect
(
wrap
.
querySelector
(
'
.group-row:nth-child(2)
'
).
id
).
toBe
(
'
group-1119
'
);
});
it
(
'
should render group and its subgroup
'
,
()
=>
{
it
(
'
should render group and its subgroup
'
,
()
=>
{
const
lists
=
component
.
$el
.
querySelectorAll
(
'
.group-list-tree
'
);
const
lists
=
component
.
$el
.
querySelectorAll
(
'
.group-list-tree
'
);
...
@@ -54,11 +61,26 @@ describe('Groups Component', () => {
...
@@ -54,11 +61,26 @@ describe('Groups Component', () => {
expect
(
lists
[
0
].
querySelector
(
'
#group-1119
'
).
classList
.
contains
(
'
is-open
'
)).
toBe
(
true
);
expect
(
lists
[
0
].
querySelector
(
'
#group-1119
'
).
classList
.
contains
(
'
is-open
'
)).
toBe
(
true
);
expect
(
lists
[
0
].
querySelector
(
'
#group-1119
'
).
classList
.
contains
(
'
has-subgroups
'
)).
toBe
(
true
);
expect
(
lists
[
0
].
querySelector
(
'
#group-1119
'
).
classList
.
contains
(
'
has-subgroups
'
)).
toBe
(
true
);
expect
(
lists
[
2
].
querySelector
(
'
#group-1120
'
).
textContent
).
toContain
(
groups
[
1119
].
subGroups
[
1120
]
.
name
);
expect
(
lists
[
2
].
querySelector
(
'
#group-1120
'
).
textContent
).
toContain
(
groups
.
id1119
.
subGroups
.
id1120
.
name
);
});
});
it
(
'
should remove prefix of parent group
'
,
()
=>
{
it
(
'
should remove prefix of parent group
'
,
()
=>
{
expect
(
component
.
$el
.
querySelector
(
'
#group-12 #group-1128 .title
'
).
textContent
).
toContain
(
'
level2 / level3 / level4
'
);
expect
(
component
.
$el
.
querySelector
(
'
#group-12 #group-1128 .title
'
).
textContent
).
toContain
(
'
level2 / level3 / level4
'
);
});
});
it
(
'
should remove the group after leaving the group
'
,
(
done
)
=>
{
spyOn
(
window
,
'
confirm
'
).
and
.
returnValue
(
true
);
eventHub
.
$on
(
'
leaveGroup
'
,
(
group
,
collection
)
=>
{
store
.
removeGroup
(
group
,
collection
);
});
component
.
$el
.
querySelector
(
'
#group-12 .leave-group
'
).
click
();
Vue
.
nextTick
(()
=>
{
expect
(
component
.
$el
.
querySelector
(
'
#group-12
'
)).
toBeNull
();
done
();
});
});
});
});
});
});
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment