184 lines
4.3 KiB
Vue
184 lines
4.3 KiB
Vue
<script>
|
|
import { escapeRegExp } from 'lodash';
|
|
import { GlBadge, GlLink, GlSkeletonLoading, GlTooltipDirective, GlLoadingIcon } from '@gitlab/ui';
|
|
import { visitUrl } from '~/lib/utils/url_utility';
|
|
import TimeagoTooltip from '~/vue_shared/components/time_ago_tooltip.vue';
|
|
import Icon from '~/vue_shared/components/icon.vue';
|
|
import { getIconName } from '../../utils/icon';
|
|
import getRefMixin from '../../mixins/get_ref';
|
|
import getCommit from '../../queries/getCommit.query.graphql';
|
|
|
|
export default {
|
|
components: {
|
|
GlBadge,
|
|
GlLink,
|
|
GlSkeletonLoading,
|
|
GlLoadingIcon,
|
|
TimeagoTooltip,
|
|
Icon,
|
|
},
|
|
directives: {
|
|
GlTooltip: GlTooltipDirective,
|
|
},
|
|
apollo: {
|
|
commit: {
|
|
query: getCommit,
|
|
variables() {
|
|
return {
|
|
fileName: this.name,
|
|
type: this.type,
|
|
path: this.currentPath,
|
|
projectPath: this.projectPath,
|
|
};
|
|
},
|
|
},
|
|
},
|
|
mixins: [getRefMixin],
|
|
props: {
|
|
id: {
|
|
type: String,
|
|
required: true,
|
|
},
|
|
sha: {
|
|
type: String,
|
|
required: true,
|
|
},
|
|
projectPath: {
|
|
type: String,
|
|
required: true,
|
|
},
|
|
currentPath: {
|
|
type: String,
|
|
required: true,
|
|
},
|
|
name: {
|
|
type: String,
|
|
required: true,
|
|
},
|
|
path: {
|
|
type: String,
|
|
required: true,
|
|
},
|
|
type: {
|
|
type: String,
|
|
required: true,
|
|
},
|
|
url: {
|
|
type: String,
|
|
required: false,
|
|
default: null,
|
|
},
|
|
lfsOid: {
|
|
type: String,
|
|
required: false,
|
|
default: null,
|
|
},
|
|
submoduleTreeUrl: {
|
|
type: String,
|
|
required: false,
|
|
default: null,
|
|
},
|
|
loadingPath: {
|
|
type: String,
|
|
required: false,
|
|
default: '',
|
|
},
|
|
},
|
|
data() {
|
|
return {
|
|
commit: null,
|
|
};
|
|
},
|
|
computed: {
|
|
routerLinkTo() {
|
|
return this.isFolder
|
|
? { path: `/-/tree/${escape(this.ref)}/${encodeURIComponent(this.path)}` }
|
|
: null;
|
|
},
|
|
iconName() {
|
|
return `fa-${getIconName(this.type, this.path)}`;
|
|
},
|
|
isFolder() {
|
|
return this.type === 'tree';
|
|
},
|
|
isSubmodule() {
|
|
return this.type === 'commit';
|
|
},
|
|
linkComponent() {
|
|
return this.isFolder ? 'router-link' : 'a';
|
|
},
|
|
fullPath() {
|
|
return this.path.replace(new RegExp(`^${escapeRegExp(this.currentPath)}/`), '');
|
|
},
|
|
shortSha() {
|
|
return this.sha.slice(0, 8);
|
|
},
|
|
hasLockLabel() {
|
|
return this.commit && this.commit.lockLabel;
|
|
},
|
|
},
|
|
methods: {
|
|
openRow(e) {
|
|
if (e.target.tagName === 'A') return;
|
|
|
|
if (this.isFolder && !e.metaKey) {
|
|
this.$router.push(this.routerLinkTo);
|
|
} else {
|
|
visitUrl(this.url, e.metaKey);
|
|
}
|
|
},
|
|
},
|
|
};
|
|
</script>
|
|
|
|
<template>
|
|
<tr :class="`file_${id}`" class="tree-item" @click="openRow">
|
|
<td class="tree-item-file-name">
|
|
<gl-loading-icon
|
|
v-if="path === loadingPath"
|
|
size="sm"
|
|
inline
|
|
class="d-inline-block align-text-bottom fa-fw"
|
|
/>
|
|
<i v-else :aria-label="type" role="img" :class="iconName" class="fa fa-fw"></i>
|
|
<component
|
|
:is="linkComponent"
|
|
ref="link"
|
|
:to="routerLinkTo"
|
|
:href="url"
|
|
class="str-truncated"
|
|
data-qa-selector="file_name_link"
|
|
>
|
|
{{ fullPath }}
|
|
</component>
|
|
<!-- eslint-disable-next-line @gitlab/vue-i18n/no-bare-strings -->
|
|
<gl-badge v-if="lfsOid" variant="default" class="label-lfs ml-1">LFS</gl-badge>
|
|
<template v-if="isSubmodule">
|
|
@ <gl-link :href="submoduleTreeUrl" class="commit-sha">{{ shortSha }}</gl-link>
|
|
</template>
|
|
<icon
|
|
v-if="hasLockLabel"
|
|
v-gl-tooltip
|
|
:title="commit.lockLabel"
|
|
name="lock"
|
|
:size="12"
|
|
class="ml-2 vertical-align-middle"
|
|
/>
|
|
</td>
|
|
<td class="d-none d-sm-table-cell tree-commit">
|
|
<gl-link
|
|
v-if="commit"
|
|
:href="commit.commitPath"
|
|
:title="commit.message"
|
|
class="str-truncated-100 tree-commit-link"
|
|
>
|
|
{{ commit.message }}
|
|
</gl-link>
|
|
<gl-skeleton-loading v-else :lines="1" class="h-auto" />
|
|
</td>
|
|
<td class="tree-time-ago text-right">
|
|
<timeago-tooltip v-if="commit" :time="commit.committedDate" />
|
|
<gl-skeleton-loading v-else :lines="1" class="ml-auto h-auto w-50" />
|
|
</td>
|
|
</tr>
|
|
</template>
|