summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/vue_shared/components/file_icon.vue
diff options
context:
space:
mode:
Diffstat (limited to 'app/assets/javascripts/vue_shared/components/file_icon.vue')
-rw-r--r--app/assets/javascripts/vue_shared/components/file_icon.vue24
1 files changed, 16 insertions, 8 deletions
diff --git a/app/assets/javascripts/vue_shared/components/file_icon.vue b/app/assets/javascripts/vue_shared/components/file_icon.vue
index b084ebdf774..7484486d6b4 100644
--- a/app/assets/javascripts/vue_shared/components/file_icon.vue
+++ b/app/assets/javascripts/vue_shared/components/file_icon.vue
@@ -1,6 +1,7 @@
<script>
import { GlLoadingIcon, GlIcon } from '@gitlab/ui';
import getIconForFile from './file_icon/file_icon_map';
+import { FILE_SYMLINK_MODE } from '../constants';
/* This is a re-usable vue component for rendering a svg sprite
icon
@@ -24,6 +25,11 @@ export default {
type: String,
required: true,
},
+ fileMode: {
+ type: String,
+ required: false,
+ default: '',
+ },
folder: {
type: Boolean,
@@ -60,8 +66,12 @@ export default {
},
},
computed: {
+ isSymlink() {
+ return this.fileMode === FILE_SYMLINK_MODE;
+ },
spriteHref() {
const iconName = this.submodule ? 'folder-git' : getIconForFile(this.fileName) || 'file';
+
return `${gon.sprite_file_icons}#${iconName}`;
},
folderIconName() {
@@ -75,13 +85,11 @@ export default {
</script>
<template>
<span>
- <svg v-if="!loading && !folder" :class="[iconSizeClass, cssClasses]">
- <use v-bind="{ 'xlink:href': spriteHref }" /></svg
- ><gl-icon
- v-if="!loading && folder"
- :name="folderIconName"
- :size="size"
- class="folder-icon"
- /><gl-loading-icon v-if="loading" :inline="true" />
+ <gl-loading-icon v-if="loading" :inline="true" />
+ <gl-icon v-else-if="isSymlink" name="symlink" :size="size" />
+ <svg v-else-if="!folder" :class="[iconSizeClass, cssClasses]">
+ <use v-bind="{ 'xlink:href': spriteHref }" />
+ </svg>
+ <gl-icon v-else :name="folderIconName" :size="size" class="folder-icon" />
</span>
</template>