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
7eda86a4
Commit
7eda86a4
authored
Aug 18, 2020
by
Samantha Ming
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Change show more button to be a table row
Issue:
https://gitlab.com/gitlab-org/gitlab/-/issues/235672
parent
d7dd2d72
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
74 additions
and
39 deletions
+74
-39
app/assets/javascripts/repository/components/table/index.vue
app/assets/javascripts/repository/components/table/index.vue
+25
-1
app/assets/javascripts/repository/components/tree_content.vue
...assets/javascripts/repository/components/tree_content.vue
+3
-16
changelogs/unreleased/235672-convert-show-more-to-table-row.yml
...logs/unreleased/235672-convert-show-more-to-table-row.yml
+5
-0
spec/frontend/repository/components/table/index_spec.js
spec/frontend/repository/components/table/index_spec.js
+26
-2
spec/frontend/repository/components/tree_content_spec.js
spec/frontend/repository/components/tree_content_spec.js
+15
-20
No files found.
app/assets/javascripts/repository/components/table/index.vue
View file @
7eda86a4
<
script
>
<
script
>
import
{
GlSkeletonLoading
}
from
'
@gitlab/ui
'
;
import
{
GlSkeletonLoading
,
GlButton
}
from
'
@gitlab/ui
'
;
import
{
sprintf
,
__
}
from
'
../../../locale
'
;
import
{
sprintf
,
__
}
from
'
../../../locale
'
;
import
getRefMixin
from
'
../../mixins/get_ref
'
;
import
getRefMixin
from
'
../../mixins/get_ref
'
;
import
projectPathQuery
from
'
../../queries/project_path.query.graphql
'
;
import
projectPathQuery
from
'
../../queries/project_path.query.graphql
'
;
...
@@ -13,6 +13,7 @@ export default {
...
@@ -13,6 +13,7 @@ export default {
TableHeader
,
TableHeader
,
TableRow
,
TableRow
,
ParentRow
,
ParentRow
,
GlButton
,
},
},
mixins
:
[
getRefMixin
],
mixins
:
[
getRefMixin
],
apollo
:
{
apollo
:
{
...
@@ -39,6 +40,10 @@ export default {
...
@@ -39,6 +40,10 @@ export default {
required
:
false
,
required
:
false
,
default
:
''
,
default
:
''
,
},
},
hasMore
:
{
type
:
Boolean
,
required
:
true
,
},
},
},
data
()
{
data
()
{
return
{
return
{
...
@@ -65,6 +70,11 @@ export default {
...
@@ -65,6 +70,11 @@ export default {
return
!
this
.
isLoading
&&
[
''
,
'
/
'
].
indexOf
(
this
.
path
)
===
-
1
;
return
!
this
.
isLoading
&&
[
''
,
'
/
'
].
indexOf
(
this
.
path
)
===
-
1
;
},
},
},
},
methods
:
{
showMore
()
{
this
.
$emit
(
'
showMore
'
);
},
},
};
};
</
script
>
</
script
>
...
@@ -110,6 +120,20 @@ export default {
...
@@ -110,6 +120,20 @@ export default {
<td><gl-skeleton-loading
:lines=
"1"
class=
"ml-auto h-auto w-50"
/></td>
<td><gl-skeleton-loading
:lines=
"1"
class=
"ml-auto h-auto w-50"
/></td>
</tr>
</tr>
</
template
>
</
template
>
<
template
v-if=
"hasMore"
>
<tr>
<td
align=
"center"
colspan=
"3"
class=
"gl-p-0!"
>
<gl-button
variant=
"link"
class=
"gl-display-flex gl-w-full gl-py-4!"
:loading=
"isLoading"
@
click=
"showMore"
>
{{
s__
(
'
ProjectFileTree|Show more
'
)
}}
</gl-button>
</td>
</tr>
</
template
>
</tbody>
</tbody>
</table>
</table>
</div>
</div>
...
...
app/assets/javascripts/repository/components/tree_content.vue
View file @
7eda86a4
<
script
>
<
script
>
import
{
GlButton
}
from
'
@gitlab/ui
'
;
import
{
deprecatedCreateFlash
as
createFlash
}
from
'
~/flash
'
;
import
{
deprecatedCreateFlash
as
createFlash
}
from
'
~/flash
'
;
import
{
__
}
from
'
../../locale
'
;
import
{
__
}
from
'
../../locale
'
;
import
FileTable
from
'
./table/index.vue
'
;
import
FileTable
from
'
./table/index.vue
'
;
...
@@ -17,7 +16,6 @@ export default {
...
@@ -17,7 +16,6 @@ export default {
components
:
{
components
:
{
FileTable
,
FileTable
,
FilePreview
,
FilePreview
,
GlButton
,
},
},
mixins
:
[
getRefMixin
],
mixins
:
[
getRefMixin
],
apollo
:
{
apollo
:
{
...
@@ -127,7 +125,7 @@ export default {
...
@@ -127,7 +125,7 @@ export default {
.
concat
(
data
.
trees
.
pageInfo
,
data
.
submodules
.
pageInfo
,
data
.
blobs
.
pageInfo
)
.
concat
(
data
.
trees
.
pageInfo
,
data
.
submodules
.
pageInfo
,
data
.
blobs
.
pageInfo
)
.
find
(({
hasNextPage
})
=>
hasNextPage
);
.
find
(({
hasNextPage
})
=>
hasNextPage
);
},
},
s
howMore
()
{
handleS
howMore
()
{
this
.
clickedShowMore
=
true
;
this
.
clickedShowMore
=
true
;
this
.
fetchFiles
();
this
.
fetchFiles
();
},
},
...
@@ -142,20 +140,9 @@ export default {
...
@@ -142,20 +140,9 @@ export default {
:entries=
"entries"
:entries=
"entries"
:is-loading=
"isLoadingFiles"
:is-loading=
"isLoadingFiles"
:loading-path=
"loadingPath"
:loading-path=
"loadingPath"
:has-more=
"hasShowMore"
@
showMore=
"handleShowMore"
/>
/>
<div
v-if=
"hasShowMore"
class=
"gl-border-1 gl-border-gray-100 gl-rounded-base gl-border-t-none gl-border-b-solid gl-border-l-solid gl-border-r-solid gl-rounded-top-right-none gl-rounded-top-left-none gl-mt-n1"
>
<gl-button
variant=
"link"
class=
"gl-display-flex gl-w-full gl-py-4!"
:loading=
"isLoadingFiles"
@
click=
"showMore"
>
{{
s__
(
'
ProjectFileTree|Show more
'
)
}}
</gl-button>
</div>
<file-preview
v-if=
"readme"
:blob=
"readme"
/>
<file-preview
v-if=
"readme"
:blob=
"readme"
/>
</div>
</div>
</
template
>
</
template
>
changelogs/unreleased/235672-convert-show-more-to-table-row.yml
0 → 100644
View file @
7eda86a4
---
title
:
Change show more button to be a table row so to remove manual CSS styling
merge_request
:
39788
author
:
type
:
changed
spec/frontend/repository/components/table/index_spec.js
View file @
7eda86a4
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
GlSkeletonLoading
}
from
'
@gitlab/ui
'
;
import
{
GlSkeletonLoading
,
GlButton
}
from
'
@gitlab/ui
'
;
import
Table
from
'
~/repository/components/table/index.vue
'
;
import
Table
from
'
~/repository/components/table/index.vue
'
;
import
TableRow
from
'
~/repository/components/table/row.vue
'
;
import
TableRow
from
'
~/repository/components/table/row.vue
'
;
...
@@ -34,12 +34,13 @@ const MOCK_BLOBS = [
...
@@ -34,12 +34,13 @@ const MOCK_BLOBS = [
},
},
];
];
function
factory
({
path
,
isLoading
=
false
,
entries
=
{}
})
{
function
factory
({
path
,
isLoading
=
false
,
hasMore
=
true
,
entries
=
{}
})
{
vm
=
shallowMount
(
Table
,
{
vm
=
shallowMount
(
Table
,
{
propsData
:
{
propsData
:
{
path
,
path
,
isLoading
,
isLoading
,
entries
,
entries
,
hasMore
,
},
},
mocks
:
{
mocks
:
{
$apollo
,
$apollo
,
...
@@ -88,4 +89,27 @@ describe('Repository table component', () => {
...
@@ -88,4 +89,27 @@ describe('Repository table component', () => {
expect
(
rows
.
length
).
toEqual
(
3
);
expect
(
rows
.
length
).
toEqual
(
3
);
expect
(
rows
.
at
(
2
).
attributes
().
mode
).
toEqual
(
'
120000
'
);
expect
(
rows
.
at
(
2
).
attributes
().
mode
).
toEqual
(
'
120000
'
);
});
});
describe
(
'
Show more button
'
,
()
=>
{
const
showMoreButton
=
()
=>
vm
.
find
(
GlButton
);
it
.
each
`
hasMore | expectButtonToExist
${
true
}
|
${
true
}
${
false
}
|
${
false
}
`
(
'
renders correctly
'
,
({
hasMore
,
expectButtonToExist
})
=>
{
factory
({
path
:
'
/
'
,
hasMore
});
expect
(
showMoreButton
().
exists
()).
toBe
(
expectButtonToExist
);
});
it
(
'
when is clicked, emits showMore event
'
,
async
()
=>
{
factory
({
path
:
'
/
'
});
showMoreButton
().
vm
.
$emit
(
'
click
'
);
await
vm
.
vm
.
$nextTick
();
expect
(
vm
.
emitted
(
'
showMore
'
)).
toHaveLength
(
1
);
});
});
});
});
spec/frontend/repository/components/tree_content_spec.js
View file @
7eda86a4
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
shallowMount
}
from
'
@vue/test-utils
'
;
import
{
GlButton
}
from
'
@gitlab/ui
'
;
import
TreeContent
,
{
INITIAL_FETCH_COUNT
}
from
'
~/repository/components/tree_content.vue
'
;
import
TreeContent
,
{
INITIAL_FETCH_COUNT
}
from
'
~/repository/components/tree_content.vue
'
;
import
FilePreview
from
'
~/repository/components/preview/index.vue
'
;
import
FilePreview
from
'
~/repository/components/preview/index.vue
'
;
import
FileTable
from
'
~/repository/components/table/index.vue
'
;
let
vm
;
let
vm
;
let
$apollo
;
let
$apollo
;
...
@@ -82,41 +82,36 @@ describe('Repository table component', () => {
...
@@ -82,41 +82,36 @@ describe('Repository table component', () => {
});
});
});
});
describe
(
'
Show more button
'
,
()
=>
{
describe
(
'
FileTable showMore
'
,
()
=>
{
const
showMoreButton
=
()
=>
vm
.
find
(
GlButton
);
describe
(
'
when is present
'
,
()
=>
{
describe
(
'
when is present
'
,
()
=>
{
const
fileTable
=
()
=>
vm
.
find
(
FileTable
);
beforeEach
(
async
()
=>
{
beforeEach
(
async
()
=>
{
factory
(
'
/
'
);
factory
(
'
/
'
);
vm
.
setData
({
fetchCounter
:
10
,
clickedShowMore
:
false
});
await
vm
.
vm
.
$nextTick
();
});
});
it
(
'
is not rendered once it is clicked
'
,
async
()
=>
{
it
(
'
is changes hasShowMore to false when "showMore" event is emitted
'
,
async
()
=>
{
showMoreButton
().
vm
.
$emit
(
'
click
'
);
fileTable
().
vm
.
$emit
(
'
showMore
'
);
await
vm
.
vm
.
$nextTick
();
await
vm
.
vm
.
$nextTick
();
expect
(
showMoreButton
().
exists
()
).
toBe
(
false
);
expect
(
vm
.
vm
.
hasShowMore
).
toBe
(
false
);
});
});
it
(
'
is rendered
'
,
async
()
=>
{
it
(
'
changes clickedShowMore when "showMore" event is emitted
'
,
async
()
=>
{
expect
(
showMoreButton
().
exists
()).
toBe
(
true
);
fileTable
().
vm
.
$emit
(
'
showMore
'
);
});
it
(
'
changes clickedShowMore when show more button is clicked
'
,
async
()
=>
{
await
vm
.
vm
.
$nextTick
();
showMoreButton
().
vm
.
$emit
(
'
click
'
);
expect
(
vm
.
vm
.
clickedShowMore
).
toBe
(
true
);
expect
(
vm
.
vm
.
clickedShowMore
).
toBe
(
true
);
});
});
it
(
'
triggers fetchFiles when
show more button is clicked
'
,
async
()
=>
{
it
(
'
triggers fetchFiles when
"showMore" event is emitted
'
,
()
=>
{
jest
.
spyOn
(
vm
.
vm
,
'
fetchFiles
'
);
jest
.
spyOn
(
vm
.
vm
,
'
fetchFiles
'
);
showMoreButton
().
vm
.
$emit
(
'
click
'
);
fileTable
().
vm
.
$emit
(
'
showMore
'
);
expect
(
vm
.
vm
.
fetchFiles
).
to
Be
Called
();
expect
(
vm
.
vm
.
fetchFiles
).
to
HaveBeen
Called
();
});
});
});
});
...
@@ -127,7 +122,7 @@ describe('Repository table component', () => {
...
@@ -127,7 +122,7 @@ describe('Repository table component', () => {
await
vm
.
vm
.
$nextTick
();
await
vm
.
vm
.
$nextTick
();
expect
(
showMoreButton
().
exists
()
).
toBe
(
false
);
expect
(
vm
.
vm
.
hasShowMore
).
toBe
(
false
);
});
});
it
(
'
has limit of 1000 files on initial load
'
,
()
=>
{
it
(
'
has limit of 1000 files on initial load
'
,
()
=>
{
...
...
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