Commit de922747 authored by Marvin Karegyeya's avatar Marvin Karegyeya Committed by Phil Hughes

Gldeprecateddropdown to Gldropdown in confidential_ merge_ request/components/dropdown.vue

parent c3ac137b
<script> <script>
import { GlDeprecatedDropdown, GlDeprecatedDropdownItem, GlIcon } from '@gitlab/ui'; import { GlDropdown, GlDropdownItem } from '@gitlab/ui';
import { __ } from '~/locale'; import { __ } from '~/locale';
export default { export default {
components: { components: {
GlDeprecatedDropdown, GlDropdown,
GlDeprecatedDropdownItem, GlDropdownItem,
GlIcon,
}, },
props: { props: {
projects: { projects: {
...@@ -37,25 +36,15 @@ export default { ...@@ -37,25 +36,15 @@ export default {
</script> </script>
<template> <template>
<gl-deprecated-dropdown toggle-class="d-flex align-items-center w-100" class="w-100"> <gl-dropdown block icon="lock" :text="dropdownText">
<template #button-content> <gl-dropdown-item
<span class="str-truncated-100 mr-2">
<gl-icon name="lock" />
{{ dropdownText }}
</span>
<gl-icon name="chevron-down" class="ml-auto" />
</template>
<gl-deprecated-dropdown-item
v-for="project in projects" v-for="project in projects"
:key="project.id" :key="project.id"
:is-check-item="true"
:is-checked="project.id === selectedProject.id"
@click="selectProject(project)" @click="selectProject(project)"
> >
<gl-icon {{ project.name }}
name="mobile-issue-close" </gl-dropdown-item>
:class="{ icon: project.id !== selectedProject.id }" </gl-dropdown>
class="js-active-project-check"
/>
<span class="ml-1">{{ project.name }}</span>
</gl-deprecated-dropdown-item>
</gl-deprecated-dropdown>
</template> </template>
---
title: Replace-GlDeprecatedDropdown-with-GlDropdown-in-app/assets/javascripts/confidential_merge_request/components/dropdown.vue
merge_request: 41416
author: nuwe1
type: other
import { mount } from '@vue/test-utils'; import { mount } from '@vue/test-utils';
import { GlDeprecatedDropdownItem } from '@gitlab/ui'; import { GlDropdown, GlDropdownItem } from '@gitlab/ui';
import Dropdown from '~/confidential_merge_request/components/dropdown.vue'; import Dropdown from '~/confidential_merge_request/components/dropdown.vue';
let vm; let vm;
...@@ -30,27 +30,18 @@ describe('Confidential merge request project dropdown component', () => { ...@@ -30,27 +30,18 @@ describe('Confidential merge request project dropdown component', () => {
}, },
]); ]);
expect(vm.findAll(GlDeprecatedDropdownItem).length).toBe(2); expect(vm.findAll(GlDropdownItem).length).toBe(2);
}); });
it('renders selected project icon', () => { it('shows lock icon', () => {
factory([ factory();
{
id: 1, expect(vm.find(GlDropdown).props('icon')).toBe('lock');
name: 'test', });
},
{ it('has dropdown text', () => {
id: 2, factory();
name: 'test 2',
},
]);
expect(vm.find('.js-active-project-check').classes()).not.toContain('icon'); expect(vm.find(GlDropdown).props('text')).toBe('Select private project');
expect(
vm
.findAll('.js-active-project-check')
.at(1)
.classes(),
).toContain('icon');
}); });
}); });
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