mirror of
https://github.com/nocodb/nocodb.git
synced 2026-05-04 02:37:06 +00:00
feat/Moved erd to components folder
This commit is contained in:
74
packages/nc-gui/components/erd/TableNode.vue
Normal file
74
packages/nc-gui/components/erd/TableNode.vue
Normal file
@@ -0,0 +1,74 @@
|
||||
<script setup>
|
||||
import { Handle, Position } from '@braks/vue-flow'
|
||||
import { UITypes, isVirtualCol } from 'nocodb-sdk'
|
||||
|
||||
const props = defineProps({
|
||||
data: {
|
||||
type: Object,
|
||||
required: true,
|
||||
},
|
||||
})
|
||||
|
||||
const { data } = toRefs(props)
|
||||
|
||||
provide(MetaInj, data)
|
||||
|
||||
const columns = computed(() => {
|
||||
// Hide hm related created for `mm` relations
|
||||
return data.value.columns.filter((col) => !(col.uidt === UITypes.LinkToAnotherRecord && col.system === 1))
|
||||
})
|
||||
|
||||
const pkAndFkColumns = computed(() => {
|
||||
return columns.value.filter(() => data.value.showPkAndFk).filter((col) => col.pk || col.uidt === UITypes.ForeignKey)
|
||||
})
|
||||
|
||||
const nonPkColumns = computed(() => {
|
||||
return columns.value.filter((col) => !col.pk && col.uidt !== UITypes.ForeignKey)
|
||||
})
|
||||
|
||||
const relatedColumnId = (col) =>
|
||||
col.colOptions.type === 'mm' ? col.colOptions.fk_parent_column_id : col.colOptions.fk_child_column_id
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<div class="h-full flex flex-col min-w-16 bg-gray-50 rounded-lg border-1">
|
||||
<div class="text-gray-600 text-md py-2 border-b-2 border-gray-100 w-full pl-3 bg-gray-100 font-semibold">
|
||||
{{ data.title }}
|
||||
</div>
|
||||
<div>
|
||||
<div class="keys mb-1">
|
||||
<div v-for="col in pkAndFkColumns" :key="col.title" class="w-full border-b-1 py-2 border-gray-100">
|
||||
<SmartsheetHeaderCell v-if="col" :column="col" :hide-menu="true" />
|
||||
</div>
|
||||
</div>
|
||||
<div v-for="col in nonPkColumns" :key="col.title">
|
||||
<div class="w-full h-full flex items-center min-w-32 border-b-1 border-gray-100 py-2 px-1">
|
||||
<div v-if="col.uidt === UITypes.LinkToAnotherRecord" class="flex relative w-full">
|
||||
<Handle
|
||||
:id="`s-${relatedColumnId(col)}-${data.id}`"
|
||||
class="-right-4 opacity-0"
|
||||
type="source"
|
||||
:position="Position.Right"
|
||||
/>
|
||||
<Handle
|
||||
:id="`d-${relatedColumnId(col)}-${data.id}`"
|
||||
class="-left-1 opacity-0"
|
||||
type="target"
|
||||
:position="Position.Left"
|
||||
/>
|
||||
<SmartsheetHeaderVirtualCell :column="col" :hide-menu="true" />
|
||||
</div>
|
||||
<SmartsheetHeaderVirtualCell v-else-if="isVirtualCol(col)" :column="col" :hide-menu="true" />
|
||||
|
||||
<SmartsheetHeaderCell v-else :column="col" :hide-menu="true" />
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<style scoped lang="scss">
|
||||
.keys {
|
||||
background-color: #f6f6f6;
|
||||
}
|
||||
</style>
|
||||
Reference in New Issue
Block a user