<template>
  <div v-show="show" :title="item.name">
    <!--title instead of tooltip above as the tooltip needs too much work with the current methods, i.e. not being loaded or staying open for "too long"-->
    <div class="item" :class="[item.isFile ? 'filewrapper gt-p-1 gt-ac' : '', selectedFile === genCompleteFileHash(item.file?.NameHash) ? 'selected' : '']">
      <!-- Files -->
      <SvgIcon
        v-if="item.isFile"
        name="octicon-file"
        class="svg-icon file"
      />
      <a
        v-if="item.isFile"
        class="file gt-ellipsis"
        :href="item.isFile ? '#diff-' + item.file.NameHash : ''"
      >{{ item.name }}</a>
      <SvgIcon
        v-if="item.isFile"
        :name="getIconForDiffType(item.file.Type)"
        :class="['svg-icon', getIconForDiffType(item.file.Type), 'status']"
      />

      <!-- Directories -->
      <div v-if="!item.isFile" class="directory gt-p-1 gt-ac" @click.stop="handleClick(item.isFile)">
        <SvgIcon
          class="svg-icon"
          :name="collapsed ? 'octicon-chevron-right' : 'octicon-chevron-down'"
        />
        <SvgIcon
          class="svg-icon directory"
          name="octicon-file-directory-fill"
        />
        <span class="gt-ellipsis">{{ item.name }}</span>
      </div>
      <div v-show="!collapsed">
        <DiffFileTreeItem v-for="childItem in item.children" :key="childItem.name" :item="childItem" class="list" :selected-file="selectedFile"/>
      </div>
    </div>
  </div>
</template>

<script>
import {SvgIcon} from '../svg.js';

export default {
  components: {SvgIcon},
  props: {
    item: {
      type: Object,
      required: true
    },
    show: {
      type: Boolean,
      required: false,
      default: true
    },
    selectedFile: {
      type: String,
      default: '',
      required: true
    }
  },
  data: () => ({
    collapsed: false,
  }),
  methods: {
    handleClick(itemIsFile) {
      if (itemIsFile) {
        return;
      }
      this.collapsed = !this.collapsed;
    },
    getIconForDiffType(pType) {
      const diffTypes = {
        1: 'octicon-diff-added',
        2: 'octicon-diff-modified',
        3: 'octicon-diff-removed',
        4: 'octicon-diff-renamed',
        5: 'octicon-diff-modified', // there is no octicon for copied, so modified should be ok
      };
      return diffTypes[pType];
    },
    genCompleteFileHash(hash) {
      return `#diff-${hash}`;
    }
  },
};
</script>

<style scoped>
.svg-icon.status {
  float: right;
}

.svg-icon.file {
  color: var(--color-secondary-dark-7);
}

.svg-icon.directory {
  color: var(--color-primary);
}

.svg-icon.octicon-diff-modified {
  color: var(--color-yellow);
}

.svg-icon.octicon-diff-added {
  color: var(--color-green);
}

.svg-icon.octicon-diff-removed {
  color: var(--color-red);
}

.svg-icon.octicon-diff-renamed {
  color: var(--color-teal);
}

.item.filewrapper {
  display: grid !important;
  grid-template-columns: 20px 7fr 1fr;
  padding-left: 18px !important;
}

.item.filewrapper:hover, div.directory:hover {
  color: var(--color-text);
  background: var(--color-hover);
  border-radius: 4px;
}

.item.filewrapper.selected {
  color: var(--color-text);
  background: var(--color-active);
  border-radius: 4px;
}

div.directory {
  display: grid;
  grid-template-columns: 18px 20px auto;
  user-select: none;
  cursor: pointer;
}

div.list {
  padding-bottom: 0 !important;
  padding-top: inherit !important;
}

a {
  text-decoration: none;
  color: var(--color-text);
}

a:hover {
  text-decoration: none;
  color: var(--color-text);
}
</style>