Commit 2c04e7ba authored by Samantha Ming's avatar Samantha Ming

Add edit button to repo blob header

Part of an issue that convert Repo Blob from HAML to Vue:

https://gitlab.com/gitlab-org/gitlab/-/issues/323210
parent cfdd2aca
...@@ -7,10 +7,12 @@ import { SIMPLE_BLOB_VIEWER, RICH_BLOB_VIEWER } from '~/blob/components/constant ...@@ -7,10 +7,12 @@ import { SIMPLE_BLOB_VIEWER, RICH_BLOB_VIEWER } from '~/blob/components/constant
import createFlash from '~/flash'; import createFlash from '~/flash';
import { __ } from '~/locale'; import { __ } from '~/locale';
import blobInfoQuery from '../queries/blob_info.query.graphql'; import blobInfoQuery from '../queries/blob_info.query.graphql';
import BlobHeaderEdit from './blob_header_edit.vue';
export default { export default {
components: { components: {
BlobHeader, BlobHeader,
BlobHeaderEdit,
BlobContent, BlobContent,
GlLoadingIcon, GlLoadingIcon,
}, },
...@@ -122,7 +124,11 @@ export default { ...@@ -122,7 +124,11 @@ export default {
:active-viewer-type="viewer.type" :active-viewer-type="viewer.type"
:has-render-error="hasRenderError" :has-render-error="hasRenderError"
@viewer-changed="switchViewer" @viewer-changed="switchViewer"
/> >
<template #actions>
<blob-header-edit :edit-path="blobInfo.editBlobPath" />
</template>
</blob-header>
<blob-content <blob-content
:blob="blobInfo" :blob="blobInfo"
:content="blobInfo.rawTextBlob" :content="blobInfo.rawTextBlob"
......
<script>
import { GlButton } from '@gitlab/ui';
import { __ } from '~/locale';
export default {
i18n: {
edit: __('Edit'),
},
components: {
GlButton,
},
props: {
editPath: {
type: String,
required: true,
},
},
};
</script>
<template>
<gl-button category="primary" variant="confirm" class="gl-mr-3" :href="editPath">
{{ $options.i18n.edit }}
</gl-button>
</template>
import { GlLoadingIcon } from '@gitlab/ui'; import { GlLoadingIcon } from '@gitlab/ui';
import { shallowMount } from '@vue/test-utils'; import { shallowMount, mount } from '@vue/test-utils';
import BlobContent from '~/blob/components/blob_content.vue'; import BlobContent from '~/blob/components/blob_content.vue';
import BlobHeader from '~/blob/components/blob_header.vue'; import BlobHeader from '~/blob/components/blob_header.vue';
import BlobContentViewer from '~/repository/components/blob_content_viewer.vue'; import BlobContentViewer from '~/repository/components/blob_content_viewer.vue';
import BlobHeaderEdit from '~/repository/components/blob_header_edit.vue';
let wrapper; let wrapper;
const simpleMockData = { const simpleMockData = {
...@@ -44,8 +45,11 @@ const richMockData = { ...@@ -44,8 +45,11 @@ const richMockData = {
}, },
}; };
function factory({ props = {}, mockData = {} } = {}, loading = false) { const createFactory = (mountFn) => (
wrapper = shallowMount(BlobContentViewer, { { props = {}, mockData = {}, stubs = {} } = {},
loading = false,
) => {
wrapper = mountFn(BlobContentViewer, {
propsData: { propsData: {
path: 'some_file.js', path: 'some_file.js',
projectPath: 'some/path', projectPath: 'some/path',
...@@ -60,20 +64,21 @@ function factory({ props = {}, mockData = {} } = {}, loading = false) { ...@@ -60,20 +64,21 @@ function factory({ props = {}, mockData = {} } = {}, loading = false) {
}, },
}, },
}, },
stubs,
}); });
wrapper.setData(mockData); wrapper.setData(mockData);
} };
const factory = createFactory(shallowMount);
const fullFactory = createFactory(mount);
describe('Blob content viewer component', () => { describe('Blob content viewer component', () => {
const findLoadingIcon = () => wrapper.find(GlLoadingIcon); const findLoadingIcon = () => wrapper.find(GlLoadingIcon);
const findBlobHeader = () => wrapper.find(BlobHeader); const findBlobHeader = () => wrapper.find(BlobHeader);
const findBlobHeaderEdit = () => wrapper.find(BlobHeaderEdit);
const findBlobContent = () => wrapper.find(BlobContent); const findBlobContent = () => wrapper.find(BlobContent);
beforeEach(() => {
factory({ mockData: { blobInfo: simpleMockData } });
});
afterEach(() => { afterEach(() => {
wrapper.destroy(); wrapper.destroy();
}); });
...@@ -85,6 +90,10 @@ describe('Blob content viewer component', () => { ...@@ -85,6 +90,10 @@ describe('Blob content viewer component', () => {
}); });
describe('simple viewer', () => { describe('simple viewer', () => {
beforeEach(() => {
factory({ mockData: { blobInfo: simpleMockData } });
});
it('renders a BlobHeader component', () => { it('renders a BlobHeader component', () => {
expect(findBlobHeader().props('activeViewerType')).toEqual('simple'); expect(findBlobHeader().props('activeViewerType')).toEqual('simple');
expect(findBlobHeader().props('hasRenderError')).toEqual(false); expect(findBlobHeader().props('hasRenderError')).toEqual(false);
...@@ -150,4 +159,28 @@ describe('Blob content viewer component', () => { ...@@ -150,4 +159,28 @@ describe('Blob content viewer component', () => {
); );
}); });
}); });
describe('BlobHeader action slot', () => {
it('renders BlobHeaderEdit button in simple viewer', async () => {
fullFactory({
mockData: { blobInfo: simpleMockData },
stubs: {
BlobContent: true,
},
});
await wrapper.vm.$nextTick();
expect(findBlobHeaderEdit().props('editPath')).toEqual('some_file.js/edit');
});
it('renders BlobHeaderEdit button in rich viewer', async () => {
fullFactory({
mockData: { blobInfo: richMockData },
stubs: {
BlobContent: true,
},
});
await wrapper.vm.$nextTick();
expect(findBlobHeaderEdit().props('editPath')).toEqual('some_file.js/edit');
});
});
}); });
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