Commit 18d9234f authored by Kushal Pandya's avatar Kushal Pandya

Merge branch 'add_names_only_options_for_protected_branches_selector' into 'master'

Change protected branches selector internals

See merge request gitlab-org/gitlab!79451
parents a7fb1283 0c6f228a
...@@ -21,6 +21,11 @@ export default { ...@@ -21,6 +21,11 @@ export default {
required: false, required: false,
default: () => [], default: () => [],
}, },
selectedBranchesNames: {
type: Array,
required: false,
default: () => [],
},
isInvalid: { isInvalid: {
type: Boolean, type: Boolean,
required: false, required: false,
...@@ -33,9 +38,20 @@ export default { ...@@ -33,9 +38,20 @@ export default {
initialLoading: false, initialLoading: false,
searching: false, searching: false,
searchTerm: '', searchTerm: '',
selected: this.selectedBranches[0] || ALL_BRANCHES, selected: null,
}; };
}, },
computed: {
selectedBranch() {
const idsOnly = this.selectedBranches.map((branch) => branch.id);
const selectedById = this.branches.find((branch) => idsOnly.includes(branch.id));
const selectedByName = this.branches.find((branch) =>
this.selectedBranchesNames.includes(branch.name),
);
return selectedById || selectedByName || this.selected || ALL_BRANCHES;
},
},
mounted() { mounted() {
this.initialLoading = true; this.initialLoading = true;
this.fetchBranches() this.fetchBranches()
...@@ -67,7 +83,7 @@ export default { ...@@ -67,7 +83,7 @@ export default {
this.fetchBranches(this.searchTerm); this.fetchBranches(this.searchTerm);
}, BRANCH_FETCH_DELAY), }, BRANCH_FETCH_DELAY),
isSelectedBranch(id) { isSelectedBranch(id) {
return this.selected.id === id; return this.selectedBranch.id === id;
}, },
onSelect(branch) { onSelect(branch) {
this.selected = branch; this.selected = branch;
...@@ -89,7 +105,7 @@ export default { ...@@ -89,7 +105,7 @@ export default {
<gl-dropdown <gl-dropdown
:class="{ 'is-invalid': isInvalid }" :class="{ 'is-invalid': isInvalid }"
class="gl-w-full gl-dropdown-menu-full-width" class="gl-w-full gl-dropdown-menu-full-width"
:text="selected.name" :text="selectedBranch.name"
:loading="initialLoading" :loading="initialLoading"
:header-text="$options.i18n.header" :header-text="$options.i18n.header"
> >
......
...@@ -56,25 +56,29 @@ describe('Protected Branches Selector', () => { ...@@ -56,25 +56,29 @@ describe('Protected Branches Selector', () => {
expect(findDropdown().classes('is-invalid')).toBe(true); expect(findDropdown().classes('is-invalid')).toBe(true);
}); });
it('sets the initially selected item', async () => { it.each`
selectedBranches | selectedBranchesNames | branchName
${[]} | ${['development']} | ${'development'}
${[{ id: 1, name: 'main' }]} | ${[]} | ${'main'}
${[{ id: 1, name: 'main' }]} | ${['development']} | ${'main'}
`(
'with selectedBranches and selectedBranchesNames set to $selectedBranches and $selectedBranchesNames the item checked is: $branchName',
async ({ selectedBranches, selectedBranchesNames, branchName }) => {
createComponent({ createComponent({
selectedBranches: [ selectedBranches,
{ selectedBranchesNames,
id: 1,
name: 'main',
},
],
}); });
await waitForPromises(); await waitForPromises();
expect(findDropdown().props('text')).toBe('main'); expect(findDropdown().props('text')).toBe(branchName);
expect( expect(
findDropdownItems() findDropdownItems()
.filter((item) => item.text() === 'main') .filter((item) => item.text() === branchName)
.at(0) .at(0)
.props('isChecked'), .props('isChecked'),
).toBe(true); ).toBe(true);
}); },
);
it('displays all the protected branches and all branches', async () => { it('displays all the protected branches and all branches', async () => {
createComponent(); createComponent();
......
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