Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2020-07-20 15:26:25 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2020-07-20 15:26:25 +0300
commita09983ae35713f5a2bbb100981116d31ce99826e (patch)
tree2ee2af7bd104d57086db360a7e6d8c9d5d43667a /app/assets/javascripts/vue_shared/components/file_icon.vue
parent18c5ab32b738c0b6ecb4d0df3994000482f34bd8 (diff)
Add latest changes from gitlab-org/gitlab@13-2-stable-ee
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>