Browse Source

新增离线任务结果

ai_dev
zhouhaibin 2 months ago
parent
commit
be345e5fa3
  1. 64
      src/api/documentReview/DocumentTaskResults/index.ts
  2. 34
      src/api/documentReview/DocumentTaskResults/model.ts
  3. 25
      src/views/documentReview/DocumentTaskResults/DocumentTaskResults.data.ts
  4. 68
      src/views/documentReview/DocumentTaskResults/DocumentTaskResultsModal.vue
  5. 115
      src/views/documentReview/DocumentTaskResults/index.vue

64
src/api/documentReview/DocumentTaskResults/index.ts

@ -0,0 +1,64 @@
import { defHttp } from '@/utils/http/axios';
import { ID, IDS, commonExport } from '@/api/base';
import { DocumentTaskResultsVO, DocumentTaskResultsForm, DocumentTaskResultsQuery } from './model';
/**
*
* @param params
* @returns
*/
export function DocumentTaskResultsList(params?: DocumentTaskResultsQuery) {
return defHttp.get<DocumentTaskResultsVO[]>({ url: '/productManagement/DocumentTaskResults/list', params });
}
/**
*
* @param params
* @returns
*/
export function DocumentTaskResultsExport(params?: DocumentTaskResultsQuery) {
return commonExport('/productManagement/DocumentTaskResults/export', params ?? {});
}
/**
*
* @param id id
* @returns
*/
export function DocumentTaskResultsInfo(id: ID) {
return defHttp.get<DocumentTaskResultsVO>({ url: '/productManagement/DocumentTaskResults/' + id });
}
/**
* id查询文档任务结果详细
* @param id id
* @returns
*/
export function DocumentTaskResultsInfoByTaskId(id: ID) {
return defHttp.get<DocumentTaskResultsVO>({ url: '/productManagement/DocumentTaskResults/task/' + id });
}
/**
*
* @param data
* @returns
*/
export function DocumentTaskResultsAdd(data: DocumentTaskResultsForm) {
return defHttp.postWithMsg<void>({ url: '/productManagement/DocumentTaskResults', data });
}
/**
*
* @param data
* @returns
*/
export function DocumentTaskResultsUpdate(data: DocumentTaskResultsForm) {
return defHttp.putWithMsg<void>({ url: '/productManagement/DocumentTaskResults', data });
}
/**
*
* @param id id
* @returns
*/
export function DocumentTaskResultsRemove(id: ID | IDS) {
return defHttp.deleteWithMsg<void>({ url: '/productManagement/DocumentTaskResults/' + id },);
}

34
src/api/documentReview/DocumentTaskResults/model.ts

@ -0,0 +1,34 @@
import { BaseEntity, PageQuery } from '@/api/base';
export interface DocumentTaskResultsVO {
/**
*
*/
result?: string;
}
export interface DocumentTaskResultsForm extends BaseEntity {
}
export interface DocumentTaskResultsQuery extends PageQuery {
/**
* id
*/
id?: string | number;
/**
* id
*/
documentTaskId?: string | number;
/**
*
*/
result?: string;
/**
*
*/
params?: any;
}

25
src/views/documentReview/DocumentTaskResults/DocumentTaskResults.data.ts

@ -0,0 +1,25 @@
import { BasicColumn } from '@/components/Table';
import { FormSchema } from '@/components/Form';
export const formSchemas: FormSchema[] = [
{
label: 'id',
field: 'id',
component: 'Input',
},
{
label: '任务id',
field: 'documentTaskId',
component: 'Input',
},
{
label: '任务结果',
field: 'result',
component: 'InputTextArea',
},
];
export const columns: BasicColumn[] = [
];
export const modalSchemas: FormSchema[] = [
];

68
src/views/documentReview/DocumentTaskResults/DocumentTaskResultsModal.vue

@ -0,0 +1,68 @@
<template>
<BasicModal
v-bind="$attrs"
:title="title"
@register="registerInnerModal"
@ok="handleSubmit"
@cancel="resetForm"
>
<BasicForm @register="registerForm" />
</BasicModal>
</template>
<script setup lang="ts">
import { BasicModal, useModalInner } from '@/components/Modal';
import { BasicForm, useForm } from '@/components/Form';
import { computed, ref, unref } from 'vue';
import { DocumentTaskResultsInfo, DocumentTaskResultsAdd, DocumentTaskResultsUpdate } from '@/api/documentReview/DocumentTaskResults';
import { modalSchemas } from './DocumentTaskResults.data';
defineOptions({ name: 'DocumentTaskResultsModal' });
const emit = defineEmits(['register', 'reload']);
const isUpdate = ref<boolean>(false);
const title = computed<string>(() => {
return isUpdate.value ? '编辑文档任务结果' : '新增文档任务结果';
});
const [registerInnerModal, { modalLoading, closeModal }] = useModalInner(
async (data: { record?: Recordable; update: boolean }) => {
modalLoading(true);
const { record, update } = data;
isUpdate.value = update;
if (update && record) {
const ret = await DocumentTaskResultsInfo(record.id);
await setFieldsValue(ret);
}
modalLoading(false);
},
);
const [registerForm, { setFieldsValue, resetForm, validate }] = useForm({
labelWidth: 100,
showActionButtonGroup: false,
baseColProps: { span: 24 },
schemas: modalSchemas,
});
async function handleSubmit() {
try {
modalLoading(true);
const data = await validate();
if (unref(isUpdate)) {
await DocumentTaskResultsUpdate(data);
} else {
await DocumentTaskResultsAdd(data);
}
emit('reload');
closeModal();
await resetForm();
} catch (e) {
} finally {
modalLoading(false);
}
}
</script>
<style scoped></style>

115
src/views/documentReview/DocumentTaskResults/index.vue

@ -0,0 +1,115 @@
<template>
<PageWrapper dense>
<BasicTable @register="registerTable">
<template #toolbar>
<a-button
@click="downloadExcel(DocumentTaskResultsExport, '文档任务结果数据', getForm().getFieldsValue())"
v-auth="'productManagement:DocumentTaskResults:export'"
>导出</a-button
>
<a-button
type="primary"
danger
@click="multipleRemove(DocumentTaskResultsRemove)"
:disabled="!selected"
v-auth="'productManagement:DocumentTaskResults:remove'"
>删除</a-button
>
<a-button
type="primary"
@click="handleAdd"
v-auth="'productManagement:DocumentTaskResults:add'"
>新增</a-button
>
</template>
<template #bodyCell="{ column, record }">
<template v-if="column.key === 'action'">
<TableAction
stopButtonPropagation
:actions="[
{
label: '修改',
icon: IconEnum.EDIT,
type: 'primary',
ghost: true,
auth: 'productManagement:DocumentTaskResults:edit',
onClick: handleEdit.bind(null, record),
},
{
label: '删除',
icon: IconEnum.DELETE,
type: 'primary',
danger: true,
ghost: true,
auth: 'productManagement:DocumentTaskResults:remove',
popConfirm: {
placement: 'left',
title: '是否删除文档任务结果[' + record.id + ']?',
confirm: handleDelete.bind(null, record),
},
},
]"
/>
</template>
</template>
</BasicTable>
<DocumentTaskResultsModal @register="registerModal" @reload="reload" />
</PageWrapper>
</template>
<script setup lang="ts">
import { PageWrapper } from '@/components/Page';
import { BasicTable, useTable, TableAction } from '@/components/Table';
import { DocumentTaskResultsList, DocumentTaskResultsExport, DocumentTaskResultsRemove } from '@/api/documentReview/DocumentTaskResults';
import { downloadExcel } from '@/utils/file/download';
import { useModal } from '@/components/Modal';
import DocumentTaskResultsModal from './DocumentTaskResultsModal.vue';
import { formSchemas, columns } from './DocumentTaskResults.data';
import { IconEnum } from '@/enums/appEnum';
defineOptions({ name: 'DocumentTaskResults' });
const [registerTable, { reload, multipleRemove, selected, getForm }] = useTable({
rowSelection: {
type: 'checkbox',
},
title: '文档任务结果列表',
api: DocumentTaskResultsList,
showIndexColumn: false,
rowKey: 'id',
useSearchForm: true,
formConfig: {
schemas: formSchemas,
baseColProps: {
xs: 24,
sm: 24,
md: 24,
lg: 6,
},
},
columns: columns,
actionColumn: {
width: 200,
title: '操作',
key: 'action',
fixed: 'right',
},
});
const [registerModal, { openModal }] = useModal();
function handleEdit(record: Recordable) {
openModal(true, { record, update: true });
}
function handleAdd() {
openModal(true, { update: false });
}
async function handleDelete(record: Recordable) {
await DocumentTaskResultsRemove([record.id]);
await reload();
}
</script>
<style scoped></style>
Loading…
Cancel
Save