mirror of https://github.com/nocodb/nocodb
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
188 lines
6.4 KiB
188 lines
6.4 KiB
<script setup lang="ts"> |
|
import type { TabItem } from '~/composables' |
|
import { TabType } from '~/composables' |
|
import { TabMetaInj } from '~/context' |
|
import { useTabs, useUIPermission } from '#imports' |
|
import MdiPlusIcon from '~icons/mdi/plus' |
|
import MdiTableIcon from '~icons/mdi/table' |
|
import MdiCsvIcon from '~icons/mdi/file-document-outline' |
|
import MdiExcelIcon from '~icons/mdi/file-excel' |
|
import MdiJSONIcon from '~icons/mdi/code-json' |
|
import MdiAirTableIcon from '~icons/mdi/table-large' |
|
import MdiRequestDataSourceIcon from '~icons/mdi/open-in-new' |
|
import MdiView from '~icons/mdi/eye-circle-outline' |
|
import MdiAccountGroup from '~icons/mdi/account-group' |
|
|
|
const { tabs, activeTabIndex, activeTab, closeTab } = useTabs() |
|
|
|
const { isUIAllowed } = useUIPermission() |
|
|
|
const tableCreateDialog = ref(false) |
|
const airtableImportDialog = ref(false) |
|
const quickImportDialog = ref(false) |
|
const importType = ref('') |
|
const currentMenu = ref<string[]>(['addORImport']) |
|
|
|
provide(TabMetaInj, activeTab) |
|
|
|
function openQuickImportDialog(type: string) { |
|
quickImportDialog.value = true |
|
importType.value = type |
|
} |
|
|
|
const icon = (tab: TabItem) => { |
|
switch (tab.type) { |
|
case TabType.TABLE: |
|
return MdiAirTableIcon |
|
case TabType.VIEW: |
|
return MdiView |
|
case TabType.AUTH: |
|
return MdiAccountGroup |
|
} |
|
} |
|
</script> |
|
|
|
<template> |
|
<div class="h-full w-full nc-container pt-[9px]"> |
|
<div class="h-full w-full flex flex-col"> |
|
<div> |
|
<a-tabs v-model:activeKey="activeTabIndex" type="editable-card" @edit="closeTab"> |
|
<a-tab-pane v-for="(tab, i) in tabs" :key="i"> |
|
<template #tab> |
|
<div class="flex align-center gap-2"> |
|
<component :is="icon(tab)" class="text-sm"></component> |
|
{{ tab.title }} |
|
</div> |
|
</template> |
|
</a-tab-pane> |
|
|
|
<template #leftExtra> |
|
<a-menu v-model:selectedKeys="currentMenu" class="border-0" mode="horizontal"> |
|
<a-sub-menu key="addORImport"> |
|
<template #title> |
|
<div class="text-sm flex items-center gap-2 pt-[8px] pb-3"> |
|
<MdiPlusIcon /> |
|
Add / Import |
|
</div> |
|
</template> |
|
<a-menu-item-group v-if="isUIAllowed('addTable')"> |
|
<a-menu-item key="add-new-table" v-t="['a:actions:create-table']" @click="tableCreateDialog = true"> |
|
<span class="flex items-center gap-2"> |
|
<MdiTableIcon class="text-primary" /> |
|
<!-- Add new table --> |
|
{{ $t('tooltip.addTable') }} |
|
</span> |
|
</a-menu-item> |
|
</a-menu-item-group> |
|
<a-menu-item-group title="QUICK IMPORT FROM"> |
|
<a-menu-item |
|
v-if="isUIAllowed('airtableImport')" |
|
key="quick-import-airtable" |
|
v-t="['a:actions:import-airtable']" |
|
@click="airtableImportDialog = true" |
|
> |
|
<span class="flex items-center gap-2"> |
|
<MdiAirTableIcon class="text-primary" /> |
|
<!-- TODO: i18n --> |
|
Airtable |
|
</span> |
|
</a-menu-item> |
|
<a-menu-item |
|
v-if="isUIAllowed('csvImport')" |
|
key="quick-import-csv" |
|
v-t="['a:actions:import-csv']" |
|
@click="openQuickImportDialog('csv')" |
|
> |
|
<span class="flex items-center gap-2"> |
|
<MdiCsvIcon class="text-primary" /> |
|
<!-- TODO: i18n --> |
|
CSV file |
|
</span> |
|
</a-menu-item> |
|
<a-menu-item |
|
v-if="isUIAllowed('jsonImport')" |
|
key="quick-import-json" |
|
v-t="['a:actions:import-json']" |
|
@click="openQuickImportDialog('json')" |
|
> |
|
<span class="flex items-center gap-2"> |
|
<MdiJSONIcon class="text-primary" /> |
|
<!-- TODO: i18n --> |
|
JSON file |
|
</span> |
|
</a-menu-item> |
|
<a-menu-item |
|
v-if="isUIAllowed('excelImport')" |
|
key="quick-import-excel" |
|
v-t="['a:actions:import-excel']" |
|
@click="openQuickImportDialog('excel')" |
|
> |
|
<span class="flex items-center gap-2"> |
|
<MdiExcelIcon class="text-primary" /> |
|
<!-- TODO: i18n --> |
|
Microsoft Excel |
|
</span> |
|
</a-menu-item> |
|
</a-menu-item-group> |
|
<a-divider class="ma-0 mb-2" /> |
|
<a-menu-item |
|
v-if="isUIAllowed('importRequest')" |
|
key="add-new-table" |
|
v-t="['e:datasource:import-request']" |
|
class="ma-0 mt-3" |
|
> |
|
<a href="https://github.com/nocodb/nocodb/issues/2052" target="_blank" class="prose-sm pa-0"> |
|
<span class="flex items-center gap-2"> |
|
<MdiRequestDataSourceIcon class="text-primary" /> |
|
<!-- TODO: i18n --> |
|
Request a data source you need? |
|
</span> |
|
</a> |
|
</a-menu-item> |
|
</a-sub-menu> |
|
</a-menu> |
|
</template> |
|
</a-tabs> |
|
</div> |
|
|
|
<NuxtPage /> |
|
</div> |
|
|
|
<DlgTableCreate v-if="tableCreateDialog" v-model="tableCreateDialog" /> |
|
<DlgQuickImport v-if="quickImportDialog" v-model="quickImportDialog" :import-type="importType" /> |
|
<DlgAirtableImport v-if="airtableImportDialog" v-model="airtableImportDialog" /> |
|
</div> |
|
</template> |
|
|
|
<style scoped> |
|
.nc-container { |
|
height: calc(100% - var(--header-height)); |
|
flex: 1 1 100%; |
|
} |
|
|
|
:deep(.ant-tabs-nav) { |
|
@apply !mb-0; |
|
} |
|
|
|
:deep(.ant-menu-item-selected) { |
|
@apply text-inherit !bg-inherit; |
|
} |
|
|
|
:deep(.ant-menu-horizontal), |
|
:deep(.ant-menu-item::after), |
|
:deep(.ant-menu-submenu::after) { |
|
@apply !border-none; |
|
} |
|
|
|
:deep(.ant-tabs-nav-add) { |
|
@apply !hidden; |
|
} |
|
|
|
:deep(.ant-tabs-tab-active) { |
|
@apply font-weight-medium; |
|
} |
|
|
|
:deep(.ant-tabs-tab:not(.ant-tabs-tab-active)) { |
|
@apply bg-gray-100; |
|
} |
|
</style>
|
|
|