<template>
  <li
    v-tooltip="deactivated ? deactivatedText : null"
    class="select__item"
    :class="{
      active: view._.selected,
      'select__item--loading': view._.loading,
      'select__item--no-options': readOnly,
      disabled: deactivated,
    }"
  >
    <a
      class="select__item-link"
      @click="!deactivated && $emit('selected', view)"
    >
      <div class="select__item-name">
        <i
          class="select__item-icon fas fa-fw"
          :class="
            (deactivated ? '' : view._.type.colorClass) +
            ' fa-' +
            view._.type.iconClass
          "
        ></i>
        <EditableViewName ref="rename" :view="view"></EditableViewName>
      </div>
    </a>
    <template v-if="!readOnly">
      <a
        ref="contextLink"
        class="select__item-options"
        @click="$refs.context.toggle($refs.contextLink, 'bottom', 'right', 0)"
        @mousedown.stop
      >
        <i class="fas fa-ellipsis-v"></i>
      </a>
      <ViewContext
        ref="context"
        :database="database"
        :table="table"
        :view="view"
        @enable-rename="enableRename"
      ></ViewContext>
    </template>
  </li>
</template>

<script>
import context from '@baserow/modules/core/mixins/context'
import ViewContext from '@baserow/modules/database/components/view/ViewContext'
import EditableViewName from '@baserow/modules/database/components/view/EditableViewName'

export default {
  name: 'ViewsContextItem',
  components: { EditableViewName, ViewContext },
  mixins: [context],
  props: {
    database: {
      type: Object,
      required: true,
    },
    view: {
      type: Object,
      required: true,
    },
    table: {
      type: Object,
      required: true,
    },
    readOnly: {
      type: Boolean,
      required: false,
      default: true,
    },
  },
  computed: {
    deactivatedText() {
      return this.$registry
        .get('view', this.view.type)
        .getDeactivatedText({ view: this.view })
    },
    deactivated() {
      return (
        !this.readOnly &&
        this.$registry
          .get('view', this.view.type)
          .isDeactivated(this.database.group.id)
      )
    },
  },
  methods: {
    enableRename() {
      this.$refs.rename.edit()
    },
  },
}
</script>