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.
This repo is archived. You can view files and clone it, but cannot push or open issues/pull-requests.

44 lines
1.3 KiB

<script lang="ts" setup>
import { importTableColumns, importTableSearchFormSchema } from '../codegen.data'
2 years ago
import { BasicModal, useModalInner } from '@/components/Modal'
import { BasicTable, useTable } from '@/components/Table'
import { createCodegenList, getSchemaTableList } from '@/api/infra/codegen'
defineOptions({ name: 'InfraImportTableModal' })
2 years ago
const emit = defineEmits(['success', 'register'])
const [registerTable, { getSelectRowKeys, getForm }] = useTable({
2 years ago
api: getSchemaTableList,
columns: importTableColumns,
formConfig: {
labelWidth: 80,
schemas: importTableSearchFormSchema,
2 years ago
},
rowSelection: { type: 'checkbox' },
rowKey: 'name',
useSearchForm: true,
pagination: false,
showTableSetting: false,
showIndexColumn: false,
immediate: false,
2 years ago
})
const [registerModal, { setModalProps, closeModal }] = useModalInner(async () => {
setModalProps({ confirmLoading: false })
})
async function handleSubmit() {
const datas = await getSelectRowKeys()
const form = await getForm()
await createCodegenList({ dataSourceConfigId: form.getFieldsValue().dataSourceConfigId, tableNames: datas })
2 years ago
closeModal()
emit('success')
}
</script>
<template>
<BasicModal v-bind="$attrs" :width="800" title="导入" @register="registerModal" @ok="handleSubmit">
<BasicTable @register="registerTable" />
</BasicModal>
</template>