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.
45 lines
1.3 KiB
45 lines
1.3 KiB
<script setup lang="ts"> |
|
import type { ColumnType, TableType } from 'nocodb-sdk' |
|
import type { Ref } from 'vue' |
|
import { inject, toRef } from 'vue' |
|
import { ColumnInj, IsFormInj, MetaInj } from '~/context' |
|
import { useProvideColumnCreateStore } from '#imports' |
|
|
|
const props = defineProps<{ column: ColumnType & { meta: any }; required: boolean; hideMenu?: boolean }>() |
|
|
|
const hideMenu = toRef(props, 'hideMenu') |
|
|
|
const meta = inject(MetaInj) |
|
|
|
const isForm = inject(IsFormInj, ref(false)) |
|
|
|
const column = toRef(props, 'column') |
|
|
|
const { isUIAllowed } = useUIPermission() |
|
|
|
provide(ColumnInj, column) |
|
|
|
// instantiate column update store |
|
useProvideColumnCreateStore(meta as Ref<TableType>, column) |
|
</script> |
|
|
|
<template> |
|
<div class="flex align-center w-full text-xs font-weight-regular"> |
|
<SmartsheetHeaderCellIcon v-if="column" /> |
|
<span v-if="column" class="name" style="white-space: nowrap" :title="column.title">{{ column.title }}</span> |
|
<span v-if="(column.rqd && !column.cdf) || required" class="text-red-500"> *</span> |
|
|
|
<template v-if="!hideMenu"> |
|
<div class="flex-1" /> |
|
<SmartsheetHeaderMenu v-if="!isForm && isUIAllowed('edit-column')" /> |
|
</template> |
|
</div> |
|
</template> |
|
|
|
<style scoped> |
|
.name { |
|
max-width: calc(100% - 40px); |
|
overflow: hidden; |
|
text-overflow: ellipsis; |
|
} |
|
</style>
|
|
|