<template>
  <div class="select-application">
    <template v-if="hasDatabases">
      <APIDocsSelectDatabaseWorkspace
        v-for="workspace in workspaces"
        :key="workspace.id"
        :workspace="workspace"
        :selected="selected"
      ></APIDocsSelectDatabaseWorkspace>
    </template>
    <p v-else>
      {{ $t('apiDocsSelectDatabase') }}
    </p>
  </div>
</template>

<script>
import { mapState } from 'vuex'

import { DatabaseApplicationType } from '@baserow/modules/database/applicationTypes'
import APIDocsSelectDatabaseWorkspace from '@baserow/modules/database/components/docs/APIDocsSelectDatabaseWorkspace'

export default {
  name: 'APIDocsSelectDatabase',
  components: { APIDocsSelectDatabaseWorkspace },
  props: {
    selected: {
      type: Number,
      required: false,
      default: -1,
    },
  },
  computed: {
    hasDatabases() {
      const databaseType = DatabaseApplicationType.getType()
      return (
        this.$store.getters['application/getAll'].filter(
          (application) => application.type === databaseType
        ).length > 0
      )
    },
    ...mapState({
      workspaces: (state) => state.workspace.items,
    }),
  },
}
</script>