Commit 31a5664d authored by Illya Klymov's avatar Illya Klymov

Merge branch 'feature/230726-repo-tabs' into 'master'

Add GlTabs to app/assets/javascripts/ide/components/repo_tabs.vue

See merge request gitlab-org/gitlab!42162
parents 91e33a9d a00fea40
<script> <script>
import { GlIcon } from '@gitlab/ui'; import { GlIcon, GlTab } from '@gitlab/ui';
import { mapActions, mapGetters } from 'vuex'; import { mapActions, mapGetters } from 'vuex';
import { __, sprintf } from '~/locale'; import { __, sprintf } from '~/locale';
...@@ -13,6 +13,7 @@ export default { ...@@ -13,6 +13,7 @@ export default {
FileIcon, FileIcon,
GlIcon, GlIcon,
ChangedFileIcon, ChangedFileIcon,
GlTab,
}, },
props: { props: {
tab: { tab: {
...@@ -71,29 +72,30 @@ export default { ...@@ -71,29 +72,30 @@ export default {
</script> </script>
<template> <template>
<li <gl-tab
:class="{ :active="tab.active"
active: tab.active, :disabled="tab.pending"
disabled: tab.pending, :title="tab.name"
}"
@click="clickFile(tab)" @click="clickFile(tab)"
@mouseover="mouseOverTab" @mouseover="mouseOverTab"
@mouseout="mouseOutTab" @mouseout="mouseOutTab"
> >
<div :title="getUrlForPath(tab.path)" class="multi-file-tab"> <template #title>
<file-icon :file-name="tab.name" :size="16" /> <div :title="getUrlForPath(tab.path)" class="multi-file-tab">
{{ tab.name }} <file-icon :file-name="tab.name" :size="16" />
<file-status-icon :file="tab" /> {{ tab.name }}
</div> <file-status-icon :file="tab" />
<button </div>
:aria-label="closeLabel" <button
:disabled="tab.pending" :aria-label="closeLabel"
type="button" :disabled="tab.pending"
class="multi-file-tab-close" type="button"
@click.stop.prevent="closeFile(tab)" class="multi-file-tab-close"
> @click.stop.prevent="closeFile(tab)"
<gl-icon v-if="!showChangedIcon" :size="12" name="close" /> >
<changed-file-icon v-else :file="tab" /> <gl-icon v-if="!showChangedIcon" :size="12" name="close" />
</button> <changed-file-icon v-else :file="tab" />
</li> </button>
</template>
</gl-tab>
</template> </template>
<script> <script>
import { GlTabs } from '@gitlab/ui';
import { mapActions, mapGetters } from 'vuex'; import { mapActions, mapGetters } from 'vuex';
import RepoTab from './repo_tab.vue'; import RepoTab from './repo_tab.vue';
export default { export default {
components: { components: {
RepoTab, RepoTab,
GlTabs,
}, },
props: { props: {
activeFile: { activeFile: {
...@@ -42,8 +44,8 @@ export default { ...@@ -42,8 +44,8 @@ export default {
<template> <template>
<div class="multi-file-tabs"> <div class="multi-file-tabs">
<ul ref="tabsScroller" class="list-unstyled gl-mb-0"> <gl-tabs>
<repo-tab v-for="tab in files" :key="tab.key" :tab="tab" /> <repo-tab v-for="tab in files" :key="tab.key" :tab="tab" />
</ul> </gl-tabs>
</div> </div>
</template> </template>
---
title: convert to GlTabs in app/assets/javascripts/ide/components/repo_tabs.vue
merge_request: 42162
author: Brandon Everett
type: added
import { GlTab } from '@gitlab/ui';
import { mount, createLocalVue } from '@vue/test-utils'; import { mount, createLocalVue } from '@vue/test-utils';
import Vuex from 'vuex'; import Vuex from 'vuex';
import { stubComponent } from 'helpers/stub_component';
import RepoTab from '~/ide/components/repo_tab.vue'; import RepoTab from '~/ide/components/repo_tab.vue';
import { createRouter } from '~/ide/ide_router'; import { createRouter } from '~/ide/ide_router';
import { createStore } from '~/ide/stores'; import { createStore } from '~/ide/stores';
...@@ -8,16 +10,25 @@ import { file } from '../helpers'; ...@@ -8,16 +10,25 @@ import { file } from '../helpers';
const localVue = createLocalVue(); const localVue = createLocalVue();
localVue.use(Vuex); localVue.use(Vuex);
const GlTabStub = stubComponent(GlTab, {
template: '<li><slot name="title" /></li>',
});
describe('RepoTab', () => { describe('RepoTab', () => {
let wrapper; let wrapper;
let store; let store;
let router; let router;
const findTab = () => wrapper.find(GlTabStub);
function createComponent(propsData) { function createComponent(propsData) {
wrapper = mount(RepoTab, { wrapper = mount(RepoTab, {
localVue, localVue,
store, store,
propsData, propsData,
stubs: {
GlTab: GlTabStub,
},
}); });
} }
...@@ -55,7 +66,7 @@ describe('RepoTab', () => { ...@@ -55,7 +66,7 @@ describe('RepoTab', () => {
jest.spyOn(wrapper.vm, 'openPendingTab').mockImplementation(() => {}); jest.spyOn(wrapper.vm, 'openPendingTab').mockImplementation(() => {});
await wrapper.trigger('click'); await findTab().vm.$emit('click');
expect(wrapper.vm.openPendingTab).not.toHaveBeenCalled(); expect(wrapper.vm.openPendingTab).not.toHaveBeenCalled();
}); });
...@@ -67,7 +78,7 @@ describe('RepoTab', () => { ...@@ -67,7 +78,7 @@ describe('RepoTab', () => {
jest.spyOn(wrapper.vm, 'clickFile').mockImplementation(() => {}); jest.spyOn(wrapper.vm, 'clickFile').mockImplementation(() => {});
wrapper.trigger('click'); findTab().vm.$emit('click');
expect(wrapper.vm.clickFile).toHaveBeenCalledWith(wrapper.vm.tab); expect(wrapper.vm.clickFile).toHaveBeenCalledWith(wrapper.vm.tab);
}); });
...@@ -91,11 +102,11 @@ describe('RepoTab', () => { ...@@ -91,11 +102,11 @@ describe('RepoTab', () => {
tab, tab,
}); });
await wrapper.trigger('mouseover'); await findTab().vm.$emit('mouseover');
expect(wrapper.find('.file-modified').exists()).toBe(false); expect(wrapper.find('.file-modified').exists()).toBe(false);
await wrapper.trigger('mouseout'); await findTab().vm.$emit('mouseout');
expect(wrapper.find('.file-modified').exists()).toBe(true); expect(wrapper.find('.file-modified').exists()).toBe(true);
}); });
......
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