94 lines
2.2 KiB
Vue
94 lines
2.2 KiB
Vue
<script>
|
|
import ClipboardButton from '~/vue_shared/components/clipboard_button.vue';
|
|
import Icon from '~/vue_shared/components/icon.vue';
|
|
|
|
export default {
|
|
components: {
|
|
ClipboardButton,
|
|
Icon,
|
|
},
|
|
props: {
|
|
diffFile: {
|
|
type: Object,
|
|
required: true,
|
|
},
|
|
},
|
|
computed: {
|
|
titleTag() {
|
|
return this.diffFile.discussionPath ? 'a' : 'span';
|
|
},
|
|
},
|
|
};
|
|
</script>
|
|
|
|
<template>
|
|
<div class="file-header-content">
|
|
<div
|
|
v-if="diffFile.submodule"
|
|
>
|
|
<span>
|
|
<icon name="archive" />
|
|
<strong
|
|
v-html="diffFile.submoduleLink"
|
|
class="file-title-name"
|
|
></strong>
|
|
<clipboard-button
|
|
title="Copy file path to clipboard"
|
|
:text="diffFile.submoduleLink"
|
|
css-class="btn-default btn-transparent btn-clipboard"
|
|
/>
|
|
</span>
|
|
</div>
|
|
<template v-else>
|
|
<component
|
|
ref="titleWrapper"
|
|
:is="titleTag"
|
|
:href="diffFile.discussionPath"
|
|
>
|
|
<span v-html="diffFile.blobIcon"></span>
|
|
<span v-if="diffFile.renamedFile">
|
|
<strong
|
|
class="file-title-name has-tooltip"
|
|
:title="diffFile.oldPath"
|
|
data-container="body"
|
|
>
|
|
{{ diffFile.oldPath }}
|
|
</strong>
|
|
→
|
|
<strong
|
|
class="file-title-name has-tooltip"
|
|
:title="diffFile.newPath"
|
|
data-container="body"
|
|
>
|
|
{{ diffFile.newPath }}
|
|
</strong>
|
|
</span>
|
|
|
|
<strong
|
|
v-else
|
|
class="file-title-name has-tooltip"
|
|
:title="diffFile.oldPath"
|
|
data-container="body"
|
|
>
|
|
{{ diffFile.filePath }}
|
|
<span v-if="diffFile.deletedFile">
|
|
deleted
|
|
</span>
|
|
</strong>
|
|
</component>
|
|
|
|
<clipboard-button
|
|
title="Copy file path to clipboard"
|
|
:text="diffFile.filePath"
|
|
css-class="btn-default btn-transparent btn-clipboard"
|
|
/>
|
|
|
|
<small
|
|
v-if="diffFile.modeChanged"
|
|
ref="fileMode"
|
|
>
|
|
{{ diffFile.aMode }} → {{ diffFile.bMode }}
|
|
</small>
|
|
</template>
|
|
</div>
|
|
</template>
|