提交 494b8bf1 authored 作者: leon's avatar leon

手术工单模板

上级 1045aa75
...@@ -20,14 +20,14 @@ export interface OperationWorkOrderParams extends BasePageParams { ...@@ -20,14 +20,14 @@ export interface OperationWorkOrderParams extends BasePageParams {
* 经销商id * 经销商id
*/ */
distributorId?: number; distributorId?: number;
/**
* 手术订单id
*/
operationOrderId?: number;
/** /**
* 订单编号 * 订单编号
*/ */
orderSn?: string; orderSn?: string;
/**
* 手术订单id
*/
operationOrderId?: number;
/** /**
* 执行人ID * 执行人ID
*/ */
...@@ -76,6 +76,14 @@ export interface OperationWorkOrderParams extends BasePageParams { ...@@ -76,6 +76,14 @@ export interface OperationWorkOrderParams extends BasePageParams {
* 工单类型 IN值List * 工单类型 IN值List
*/ */
orderModeList?: Array<string>; orderModeList?: Array<string>;
/**
* 操作人ID
*/
editorId?: number;
/**
* 操作人
*/
editorName?: string;
/** /**
* 创建时间 * 创建时间
*/ */
...@@ -119,6 +127,10 @@ export interface OperationWorkOrder { ...@@ -119,6 +127,10 @@ export interface OperationWorkOrder {
* 经销商id * 经销商id
*/ */
distributorId?: number; distributorId?: number;
/**
* 订单编号
*/
orderSn?: string;
/** /**
* 手术订单id * 手术订单id
*/ */
...@@ -127,10 +139,6 @@ export interface OperationWorkOrder { ...@@ -127,10 +139,6 @@ export interface OperationWorkOrder {
* 手术订单id * 手术订单id
*/ */
operationOrder?: OperationOrder; operationOrder?: OperationOrder;
/**
* 订单编号
*/
orderSn?: string;
/** /**
* 执行人ID * 执行人ID
*/ */
...@@ -159,6 +167,14 @@ export interface OperationWorkOrder { ...@@ -159,6 +167,14 @@ export interface OperationWorkOrder {
* 工单类型 * 工单类型
*/ */
orderMode?: String; orderMode?: String;
/**
* 操作人ID
*/
editorId?: number;
/**
* 操作人
*/
editorName?: string;
/** /**
* 创建时间 * 创建时间
*/ */
......
...@@ -5,81 +5,66 @@ ...@@ -5,81 +5,66 @@
*/ */
import { defHttp } from '/@/utils/http/axios'; import { defHttp } from '/@/utils/http/axios';
import { ApiResponse } from '../model/baseModel';
import { import {
OperationWorkOrder, OperationWorkOrder,
OperationWorkOrderParams, OperationWorkOrderParams,
OperationWorkOrderPageResult, OperationWorkOrderPageResult,
OperationWorkOrderPageResponse,
OperationWorkOrderResponse,
} from '../model/operationWorkOrder'; } from '../model/operationWorkOrder';
const baseApi = '/v1/order/operation-work-order'; const baseApi = '/v1/order/operation-work-order';
/** /**
* 新增 * 新增
*/ */
export const add = (entity: OperationWorkOrder) => export const add = (entity: OperationWorkOrder) => defHttp.post<OperationWorkOrder>({ url: `${baseApi}/`, data: entity });
defHttp.post<OperationWorkOrder>({ url: `${baseApi}/`, data: entity });
/** /**
* 更新 * 更新
*/ */
export const update = (entity: OperationWorkOrder) => export const update = (entity: OperationWorkOrder) => defHttp.put<OperationWorkOrder>({ url: `${baseApi}/`, data: entity });
defHttp.put<OperationWorkOrder>({ url: `${baseApi}/`, data: entity });
/** /**
* 删除 * 删除
*/ */
export const remove = (id: any) => export const remove = (id: any) => defHttp.delete<Number>({ url: `${baseApi}/${id}` });
defHttp.delete<Number>({ url: `${baseApi}/${id}` });
/** /**
* 分页查询 * 分页查询
*/ */
export const search = (params?: OperationWorkOrderParams) => export const search = (params?: OperationWorkOrderParams) => defHttp.get<OperationWorkOrderPageResult>({ url: `${baseApi}/search`, params });
defHttp.get<OperationWorkOrderPageResult>({ url: `${baseApi}/search`, params });
/** /**
* 列表查询 * 列表查询
*/ */
export const all = (params?: OperationWorkOrderParams) => export const all = (params?: OperationWorkOrderParams) => defHttp.get<OperationWorkOrderPageResult>({ url: `${baseApi}/all`, params });
defHttp.get<OperationWorkOrderPageResult>({ url: `${baseApi}/all`, params });
/** /**
* 通过主键查询 * 通过主键查询
*/ */
export const getById = (id: any) => export const getById = (id: any) => defHttp.get<OperationWorkOrder>({ url: `${baseApi}/${id}` });
defHttp.get<OperationWorkOrder>({ url: `${baseApi}/${id}` });
/** /**
* 单个查询 * 单个查询
*/ */
export const getOne = (params?: OperationWorkOrderParams) => export const getOne = (params?: OperationWorkOrderParams) => defHttp.get<OperationWorkOrder>({ url: `${baseApi}/one`, params });
defHttp.get<OperationWorkOrder>({ url: `${baseApi}/one`, params });
/** /**
* 批量删除 * 批量删除
*/ */
export const batchRemove = (idList: Array<any>) => export const batchRemove = (idList: Array<any>) => defHttp.post<boolean>({ url: `${baseApi}/batch-delete`, data: idList });
defHttp.post<boolean>({ url: `${baseApi}/batch-delete`, data: idList });
/** /**
* 批量新增 * 批量新增
*/ */
export const batchAdd = (entityList: Array<OperationWorkOrder>) => export const batchAdd = (entityList: Array<OperationWorkOrder>) => defHttp.post<boolean>({ url: `${baseApi}/batch-save`, data: entityList });
defHttp.post<boolean>({ url: `${baseApi}/batch-save`, data: entityList });
/** /**
* 批量更新 * 批量更新
*/ */
export const batchUpdate = (entityList: Array<OperationWorkOrder>) => export const batchUpdate = (entityList: Array<OperationWorkOrder>) => defHttp.post<boolean>({ url: `${baseApi}/batch-update`, data: entityList });
defHttp.post<boolean>({ url: `${baseApi}/batch-update`, data: entityList });
/** /**
* 查询数量 * 查询数量
*/ */
export const count = (params?: OperationWorkOrderParams) => export const count = (params?: OperationWorkOrderParams) => defHttp.get<Number>({ url: `${baseApi}/count`, params });
defHttp.get<Number>({ url: `${baseApi}/count`, params });
<template> <template>
<Card :bordered="false"> <Card :bordered="false" :loading="isLoading">
<Descriptions bordered :column="3"> <Descriptions bordered :column="3">
<Descriptions.Item <Descriptions.Item
v-for="p in displayProps" v-for="p in displayProps"
...@@ -8,7 +8,7 @@ ...@@ -8,7 +8,7 @@
:span="['avatar'].includes(p.name) ? 3 : 1" :span="['avatar'].includes(p.name) ? 3 : 1"
> >
<span v-if="p.key === 'avatar'"> <span v-if="p.key === 'avatar'">
<img :src="p.value" style="width: 120px; height: 120px" /> <ImagePreview :imageList="[p.value]" style="width: 120px" />
</span> </span>
<template v-else> <template v-else>
{{ p.value }} {{ p.value }}
...@@ -18,39 +18,45 @@ ...@@ -18,39 +18,45 @@
</Card> </Card>
</template> </template>
<script lang="ts" setup name="DeviceDetail"> <script lang="ts" setup name="DeviceDetail">
import { onMounted, computed, ref, reactive } from 'vue'; import { onMounted, computed, ref } from 'vue';
import { useRoute } from 'vue-router'; import { useRoute } from 'vue-router';
import { useAsyncState } from '@vueuse/core';
import { ImagePreview } from '/@/components/Preview/index';
import { ComputedRef } from '@vue/reactivity'; import { ComputedRef } from '@vue/reactivity';
import { Descriptions, Card } from 'ant-design-vue'; import { Descriptions, Card } from 'ant-design-vue';
import { descriptionColumns } from './schema'; import { descriptionColumns } from './schema';
import * as OperationWorkOrderApi from '/@/api/order/operationWorkOrderApi'; import * as OperationWorkOrderApi from '/@/api/order/operationWorkOrderApi';
import { Device } from '/@/api/model/device'; import { OperationWorkOrder } from '/@/api/model/operationWorkOrder';
const route = useRoute(); const route = useRoute();
const id = ref(route.params?.id); const id = ref(route.params?.id);
let data = reactive({
detail: {}, // id 查询
isOver: false, const {
}); state: detail,
const getDetail = () => { isReady: isDetailReady,
OperationWorkOrderApi.getById(id.value).then((res: Device) => { isLoading,
data.isOver = true; execute,
data.detail = res; } = useAsyncState(
}); () => {
}; return OperationWorkOrderApi.getById(id.value).then((res: OperationWorkOrder) => res);
},
null,
{
immediate: false,
},
);
onMounted(() => { onMounted(() => {
getDetail(); execute();
}); });
const displayProps: ComputedRef<Array<any>> = computed(() => { const displayProps: ComputedRef<Array<any>> = computed(() => {
if (!data.isOver) return {}; if (!isDetailReady.value) return {};
const display: any = descriptionColumns.map(({ title, dataIndex = '', customRender }) => ({ const display: any = descriptionColumns.map(({ title, dataIndex = '', customRender }) => ({
key: dataIndex, key: dataIndex,
title, title,
value: customRender value: customRender ? customRender({ text: detail.value[dataIndex], record: detail.value }) : detail.value[dataIndex],
? customRender({ text: data.detail[dataIndex], record: data.detail })
: data.detail[dataIndex],
})); }));
return display; return display;
}); });
......
<template> <template>
<BasicDrawer v-bind="$attrs" @register="registerDrawer" showFooter :title="getTitle" width="600px" @ok="handleSubmit"> <BasicDrawer v-bind="$attrs" @register="registerDrawer" showFooter :confirmDisabled="getConfirmDisabled" :title="getTitle" width="600px" @ok="handleSubmit">
<a-spin :spinning="isLoading">
<BasicForm @register="registerForm" /> <BasicForm @register="registerForm" />
</a-spin>
</BasicDrawer> </BasicDrawer>
</template> </template>
<script lang="ts" setup name="OperationWorkOrderDrawer"> <script lang="ts" setup name="OperationWorkOrderDrawer">
...@@ -8,7 +10,9 @@ ...@@ -8,7 +10,9 @@
import { BasicForm, useForm } from '/@/components/Form/index'; import { BasicForm, useForm } from '/@/components/Form/index';
import { formSchema } from './schema'; import { formSchema } from './schema';
import { BasicDrawer, useDrawerInner } from '/@/components/Drawer'; import { BasicDrawer, useDrawerInner } from '/@/components/Drawer';
import { useAsyncState } from '@vueuse/core';
import * as OperationWorkOrderApi from '/@/api/order/operationWorkOrderApi'; import * as OperationWorkOrderApi from '/@/api/order/operationWorkOrderApi';
import { OperationWorkOrder } from '/@/api/model/operationWorkOrder';
const emit = defineEmits(['success', 'register']); const emit = defineEmits(['success', 'register']);
const isUpdate = ref(true); const isUpdate = ref(true);
...@@ -20,6 +24,22 @@ ...@@ -20,6 +24,22 @@
showActionButtonGroup: false, showActionButtonGroup: false,
}); });
// id 查询
const {
state: detail,
isReady: isDetailReady,
isLoading,
execute,
} = useAsyncState(
() => {
return OperationWorkOrderApi.getById(entityId.value).then((res: OperationWorkOrder) => res);
},
null,
{
immediate: false,
},
);
const [registerDrawer, { setDrawerProps, closeDrawer }] = useDrawerInner(async (data) => { const [registerDrawer, { setDrawerProps, closeDrawer }] = useDrawerInner(async (data) => {
await resetFields(); await resetFields();
setDrawerProps({ confirmLoading: false }); setDrawerProps({ confirmLoading: false });
...@@ -27,10 +47,22 @@ ...@@ -27,10 +47,22 @@
entityId.value = data?.record?.id; entityId.value = data?.record?.id;
if (unref(isUpdate)) { if (unref(isUpdate)) {
await setFieldsValue({ await execute();
...data.record, if (detail.value) {
operationOrderId: { label: data.record.operation_orderName, value: data.record.operationOrderId }, const formData: any = {
...detail.value,
operationOrderId: { label: detail.value.operation_order?.name || '(已删除/不存在)', value: detail.value.operationOrderId },
};
await setFieldsValue(formData);
}
}
}); });
const getConfirmDisabled = computed(() => {
if (unref(isUpdate)) {
return !unref(isDetailReady);
} else {
return false;
} }
}); });
......
...@@ -8,6 +8,7 @@ ...@@ -8,6 +8,7 @@
<span>已选中{{ checkedKeys.length }}条记录</span> <span>已选中{{ checkedKeys.length }}条记录</span>
<a-button type="link" @click="checkedKeys = []" size="small">清空</a-button> <a-button type="link" @click="checkedKeys = []" size="small">清空</a-button>
<a-popconfirm <a-popconfirm
v-auth="'AUTH_ORDER_OPERATION_WORK_ORDER'"
class="ml-4" class="ml-4"
title="确定要全部删除吗?" title="确定要全部删除吗?"
ok-text="是" ok-text="是"
...@@ -27,9 +28,6 @@ ...@@ -27,9 +28,6 @@
<a-button v-auth="'AUTH_ORDER_OPERATION_WORK_ORDER:ADD'" type="primary" @click="handleCreate"> 新增</a-button> <a-button v-auth="'AUTH_ORDER_OPERATION_WORK_ORDER:ADD'" type="primary" @click="handleCreate"> 新增</a-button>
</template> </template>
<template #bodyCell="{ column, record, text }"> <template #bodyCell="{ column, record, text }">
<template v-if="column.dataIndex === 'id'">
<a @click="handleView(record)"> {{ record.id }} </a>
</template>
<template v-if="[].includes(column.dataIndex)"> <template v-if="[].includes(column.dataIndex)">
<img :src="text" class="photo" alt="图片" v-if="!!text" /> <img :src="text" class="photo" alt="图片" v-if="!!text" />
</template> </template>
...@@ -42,6 +40,12 @@ ...@@ -42,6 +40,12 @@
onClick: handleEdit.bind(null, record), onClick: handleEdit.bind(null, record),
ifShow: hasPermission('AUTH_ORDER_OPERATION_WORK_ORDER:EDIT'), ifShow: hasPermission('AUTH_ORDER_OPERATION_WORK_ORDER:EDIT'),
}, },
{
tooltip: '详情',
icon: 'ant-design:eye-outlined',
onClick: handleView.bind(null, record),
ifShow: hasPermission('AUTH_ORDER_OPERATION_WORK_ORDER:QUERY'),
},
{ {
tooltip: '删除', tooltip: '删除',
icon: 'ant-design:delete-outlined', icon: 'ant-design:delete-outlined',
...@@ -60,7 +64,7 @@ ...@@ -60,7 +64,7 @@
<OperationWorkOrderDrawer @register="registerDrawer" @success="handleSuccess" /> <OperationWorkOrderDrawer @register="registerDrawer" @success="handleSuccess" />
</div> </div>
</template> </template>
<script lang="ts" setup name="DeviceIndex"> <script lang="ts" setup name="AUTH_ORDER_OPERATION_WORK_ORDER">
import { ref } from 'vue'; import { ref } from 'vue';
import { useGo } from '/@/hooks/web/usePage'; import { useGo } from '/@/hooks/web/usePage';
import { usePermission } from '/@/hooks/web/usePermission'; import { usePermission } from '/@/hooks/web/usePermission';
...@@ -75,15 +79,20 @@ ...@@ -75,15 +79,20 @@
const { hasPermission } = usePermission(); const { hasPermission } = usePermission();
const go = useGo(); const go = useGo();
const { formConfig, showTableSetting, bordered, showIndexColumn } = componentSetting.table; const {
formConfig,
showTableSetting,
bordered,
showIndexColumn,
} = componentSetting.table;
const checkedKeys = ref<Array<string | number>>([]); const checkedKeys = ref<Array<string | number>>([]);
const onSelectChange = (selectedRowKeys: (string | number)[]) => { const onSelectChange = (selectedRowKeys: (string | number)[]) => {
checkedKeys.value = selectedRowKeys; checkedKeys.value = selectedRowKeys;
}; }
const [registerDrawer, { openDrawer }] = useDrawer(); const [registerDrawer, { openDrawer }] = useDrawer();
const [registerTable, { reload }] = useTable({ const [registerTable, { reload ,setLoading}] = useTable({
title: '手术销售工单表', title: '手术销售工单表',
api: (params) => OperationWorkOrderApi.search(handleParams(params)), api: (params) => OperationWorkOrderApi.search(handleParams(params)),
columns, columns,
...@@ -94,6 +103,7 @@ ...@@ -94,6 +103,7 @@
}, },
rowSelection: { rowSelection: {
type: 'checkbox', type: 'checkbox',
// @ts-ignore
selectedRowKeys: checkedKeys, selectedRowKeys: checkedKeys,
onChange: onSelectChange, onChange: onSelectChange,
}, },
...@@ -104,10 +114,9 @@ ...@@ -104,10 +114,9 @@
canResize: false, canResize: false,
rowKey: (record: any) => record.id, rowKey: (record: any) => record.id,
actionColumn: { actionColumn: {
width: 80, width: 120,
title: '操作', title: '操作',
dataIndex: 'action', dataIndex: 'action',
fixed: 'right', fixed: 'right',
}, },
}); });
...@@ -150,14 +159,20 @@ ...@@ -150,14 +159,20 @@
}; };
const handleDelete = (record: Recordable) => { const handleDelete = (record: Recordable) => {
setLoading(true);
OperationWorkOrderApi.remove(record.id).then((_) => { OperationWorkOrderApi.remove(record.id).then((_) => {
reload(); reload();
}).catch(() => {
setLoading(false);
}); });
}; };
const handleBatchDelete = () => { const handleBatchDelete = () => {
setLoading(true);
OperationWorkOrderApi.batchRemove(checkedKeys.value).then((_) => { OperationWorkOrderApi.batchRemove(checkedKeys.value).then((_) => {
reload(); reload();
}).catch(() => {
setLoading(false);
}); });
}; };
...@@ -166,6 +181,6 @@ ...@@ -166,6 +181,6 @@
}; };
const handleView = (record) => { const handleView = (record) => {
go('/order/operation-work-order/' + record.id); go('/main/order/operation-work-order/' + record.id);
}; };
</script> </script>
...@@ -12,8 +12,13 @@ import get from 'lodash.get'; ...@@ -12,8 +12,13 @@ import get from 'lodash.get';
import * as OperationOrderApi from '/@/api/order/operationOrderApi'; import * as OperationOrderApi from '/@/api/order/operationOrderApi';
export enum StatusEnum { export enum StatusEnum {
TO_BE_USE = '待使用',
CANCEL = '已取消',
PENDING_REVIEW = '待审核', PENDING_REVIEW = '待审核',
PASSED = '已通过', PASSED = '已推送',
DELIVERED = '已发货',
BACK = '已回库',
CONFIRM = '已确认',
REJECT = '拒绝', REJECT = '拒绝',
FORBIDDEN = '禁用', FORBIDDEN = '禁用',
} }
...@@ -87,6 +92,22 @@ export const schema = { ...@@ -87,6 +92,22 @@ export const schema = {
table: { table: {
}, },
}, },
{
field: 'orderSn',
label: '订单编号',
defaultValue: undefined,
form: {
componentProps: {
allowClear: false,
placeholder: '订单编号',
},
colProps,
component: 'Input',
rules: [{ required: true, message: '请输入订单编号!' }],
},
table: {
},
},
{ {
field: 'operationOrderId', field: 'operationOrderId',
label: '手术订单id', label: '手术订单id',
...@@ -110,22 +131,6 @@ export const schema = { ...@@ -110,22 +131,6 @@ export const schema = {
customRender: ({ text, record }) => get(record, 'operationOrder.name') || text, customRender: ({ text, record }) => get(record, 'operationOrder.name') || text,
}, },
}, },
{
field: 'orderSn',
label: '订单编号',
defaultValue: undefined,
form: {
componentProps: {
allowClear: false,
placeholder: '订单编号',
},
colProps,
component: 'Input',
rules: [{ required: true, message: '请输入订单编号!' }],
},
table: {
},
},
{ {
field: 'userId', field: 'userId',
label: '执行人ID', label: '执行人ID',
...@@ -249,6 +254,38 @@ export const schema = { ...@@ -249,6 +254,38 @@ export const schema = {
}, },
}, },
}, },
{
field: 'editorId',
label: '操作人ID',
defaultValue: 1,
form: {
componentProps: {
allowClear: false,
placeholder: '操作人ID',
},
colProps,
component: 'InputNumber',
rules: [{ required: true, message: '请输入操作人ID!' }],
},
table: {
},
},
{
field: 'editorName',
label: '操作人',
defaultValue: 'admin',
form: {
componentProps: {
allowClear: false,
placeholder: '操作人',
},
colProps,
component: 'Input',
rules: [{ required: true, message: '请输入操作人!' }],
},
table: {
},
},
{ {
field: 'createTime', field: 'createTime',
label: '创建时间', label: '创建时间',
...@@ -288,10 +325,10 @@ export const schema = { ...@@ -288,10 +325,10 @@ export const schema = {
], ],
}; };
const queryFields = ['id','distributorId','operationOrderId','orderSn','userId','realName','status','remark','endTime','deleteStatus','orderMode','createTime','updateTime']; const queryFields = ['id','distributorId','orderSn','operationOrderId','userId','realName','status','remark','endTime','deleteStatus','orderMode','editorId','editorName','createTime','updateTime'];
const editFields = ['distributorId','operationOrderId','orderSn','userId','realName','status','remark','endTime','deleteStatus','orderMode']; const editFields = ['distributorId','orderSn','operationOrderId','userId','realName','status','remark','endTime','deleteStatus','orderMode'];
const tableFields = ['id','distributorId','operationOrderId','orderSn','userId','realName','status','remark','endTime','deleteStatus','orderMode','createTime','updateTime']; const tableFields = ['id','distributorId','orderSn','operationOrderId','userId','realName','status','remark','endTime','deleteStatus','orderMode','editorId','editorName','createTime','updateTime'];
const descriptionFields = ['id','distributorId','operationOrderId','orderSn','userId','realName','status','remark','endTime','deleteStatus','orderMode','createTime','updateTime']; const descriptionFields = ['id','distributorId','orderSn','operationOrderId','userId','realName','status','remark','endTime','deleteStatus','orderMode','editorId','editorName','createTime','updateTime'];
export const searchFormSchema: FormSchema[] = schema.properties.filter(item => queryFields.includes(item.field)) export const searchFormSchema: FormSchema[] = schema.properties.filter(item => queryFields.includes(item.field))
.map( .map(
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论