import React, { useEffect, useRef, useReducer } from "react";
import { Button, Tooltip, Row, Divider, Drawer, Image } from "antd";
import AutoTable from "@/components/AutoTable";
import getPrem from "@/utils/getPrem"; //权限判断fn
import { useRequest } from "umi";
import defaultFields from "./fields";
import { doFetch } from "@/utils/doFetch";
import DrawInitForm from "@/components/DrawInitForm";
import Details from "@/components/Details";
import { labeltemplateDetail } from "@/utils/detailTotalCard";
import Coltext from "@/components/Coltext";
import TableTransfer from "@/components/TableTransfer";
import { unitSelect } from "@/services/craft";
const initState = {
vs: false,
fields: {},
iftype: {},
curitem: {},
detail: {
dataSource: {},
totalCard: [],
},
visible: false,
vsc: false,
transferParams: {},
imgUrl: "",
};
function reducer(state, action) {
let { type } = action,
newState = {};
switch (type) {
case "add":
newState = {
...state,
vs: true,
iftype: {
title: "新增标签模板",
val: type,
},
fields: { ...action.fields },
};
break;
case "edit":
newState = {
...state,
vs: true,
iftype: {
title: "编辑标签模板",
val: type,
},
fields: { ...action.fields },
curitem: action.curitem,
};
break;
case "see":
newState = {
...state,
detail: {
dataSource: action.dataSource,
totalCard: [...labeltemplateDetail],
},
visible: true,
};
break;
case "station":
newState = {
...state,
vsc: true,
transferParams: action.transferParams,
};
break;
case "changeImgurl":
newState = {
...state,
imgUrl: action.imgUrl,
};
break;
case "close":
newState = {
vs: false,
fields: {},
iftype: {},
curitem: {},
detail: {
dataSource: {},
totalCard: [],
},
visible: false,
vsc: false,
transferParams: {},
imgUrl: "",
};
break;
}
return newState;
}
const Gather = (props) => {
let actionRef = useRef(),
ChildRef = null;
function reload() {
actionRef?.current?.reload();
ChildRef?.onRefresh();
}
const { run, loading } = useRequest(doFetch, {
manual: true,
formatResult: (res) => res,
onSuccess: (result, params) => {
if (result.code == "0000") {
reload();
dispatch({ type: "close" });
}
},
}),
[state, dispatch] = useReducer(reducer, initState),
{
vs,
fields,
iftype,
curitem,
detail,
visible,
vsc,
transferParams,
imgUrl,
} = state,
columns = [
{
title: "标签模板编号",
dataIndex: "tableNo",
key: "tableNo",
},
{
title: "标签模板名称",
dataIndex: "tableName",
key: "tableName",
render: (_, row) => {
return (
{
doFetch({
url: "/ngic-base-business/bmTable/queryDetails",
params: { id: row.id },
}).then((res) => {
if (res.code == "0000") {
let dataSource = res?.data?.data ?? {};
dispatch({ type: "see", dataSource });
}
});
}}
>
{row.tableName}
);
},
},
{
title: "标签模板类别",
dataIndex: "tableTypeName",
key: "tableTypeName",
options: [
{
label: "生产",
value: 1,
},
{
label: "检验",
value: 2,
},
{
label: "包装",
value: 3,
},
],
valueType: "select",
formItemProps: {
name: "tableType",
},
options: {
database: unitSelect,
params: { dicKey: "table_template" },
},
},
{
title: "标签长度(cm)",
dataIndex: "length",
key: "length",
search: false,
},
{
title: "标签宽度(cm)",
dataIndex: "width",
key: "width",
search: false,
},
{
title: "描述",
dataIndex: "remark",
key: "remark",
search: false,
},
{
title: "操作",
dataIndex: "option_dataindex",
key: "option_dataindex",
valueType: "option",
width: 255,
render: (text, row, _, action) => extraAction(text, row, _, action),
},
],
rightColumns = [
{
title: "字段名称",
dataIndex: "fieldName",
key: "fieldName",
},
],
leftColumns = [
{
title: "字段名称",
dataIndex: "fieldName",
key: "fieldName",
search: false,
},
];
function extraAction(text, record, _, action) {
return [
getPrem("sysDepartment_save", action, "编辑字段", () => {
let params = {
leftColumns,
rightColumns,
rightPath: "/ngic-base-business/bmTableCommonField/queryList",
leftPath: "/ngic-base-business/bmTableField/queryList",
toLeft: "/ngic-base-business/bmTableField/save",
toRight: "/ngic-base-business/bmTableField/delete",
leftCol: { span: 14 },
rightCol: { span: 9 },
leftExtraparams: { tableId: record.id },
rightExtraparams: {
tableId: record.id,
},
rightRowName: "fieldName",
leftRowName: "fieldName",
leftClickParams: { tableId: record.id },
rightClickParams: { tableId: record.id },
leftTitle: "字段信息",
rightTitle: "待选字段",
leftRowKey: "id",
leftSelectRowKey: "commonFieldIdList",
rightSelectRowKey: "commonFieldIdList",
};
dispatch({ type: "station", transferParams: params });
}),
getPrem("sysDepartment_save", action, "修改", () => {
doFetch({
url: "/ngic-base-business/bmTable/queryDetails",
params: { id: record.id },
}).then((res) => {
if (res.code == "0000") {
let data = res?.data?.data ?? {};
for (let i in defaultFields) {
defaultFields[i].value = data[i];
if (i == "tableType") {
defaultFields[i].disabled = true;
}
if (i == "tableFileId") {
doFetch({
url: "/ngic-base-business/bmTableFile/queryById",
params: { id: data[i] },
}).then((res) => {
if (res.code == "0000") {
dispatch({
type: "changeImgurl",
imgUrl:
res?.data?.dataList?.length > 0
? res?.data?.dataList[0].url
: "",
});
}
});
}
}
dispatch({ type: "edit", fields: defaultFields, curitem: data });
}
});
}),
getPrem("sysDepartment_deleteById", action, "删除", null, {
title: "确认删除该标签模板?",
onConfirm: () => {
run({
url: "/ngic-base-business/bmTable/deleteById",
params: { id: record.id },
});
},
}),
];
}
let saveData = (values, fn) => {
let newfields = JSON.parse(JSON.stringify(values));
//新增&修改
let difrid = iftype.val == "edit" ? { id: curitem.id } : {};
run({
url: "/ngic-base-business/bmTable/save",
params: { ...newfields, ...difrid },
});
};
let extrarender = [
,
];
return (
(ChildRef = node)}
>
dispatch({ type: "close" })}
footer={false}
destroyOnClose={true}
fields={fields}
submitData={(values) => {
saveData(values);
}}
onChange={(changedValues, allValues) => {
//联动操作
for (let i in changedValues) {
if (i == "tableFileId") {
if (changedValues[i]) {
doFetch({
url: "/ngic-base-business/bmTableFile/queryById",
params: { id: changedValues[i] },
}).then((res) => {
if (res.code == "0000") {
dispatch({
type: "changeImgurl",
imgUrl:
res?.data?.dataList?.length > 0
? res?.data?.dataList[0].url
: "",
});
}
});
} else {
dispatch({ type: "changeImgurl", imgUrl: "" });
}
}
}
}}
submitting={loading || !vs}
width={"50%"}
bottomNode={
imgUrl ? (
) : null
}
>
dispatch({ type: "close" })}
footer={false}
destroyOnClose={true}
width={"100%"}
{...detail}
>
dispatch({ type: "close" })}
footer={false}
destroyOnClose={true}
width={"100%"}
style={{ position: "absolute" }}
getContainer={false}
maskClosable={false}
>
);
};
export default Gather;