@@ -175,14 +175,14 @@ const goodstechnologymaken = (props) => { | |||||
item.data.forEach(item => { | item.data.forEach(item => { | ||||
const obj = {}; | const obj = {}; | ||||
let propsdatanew = []; | let propsdatanew = []; | ||||
let propsdata = Technologyacton.filter(x => x.technologyId == item.chnologyId) | |||||
let propsdata = Technologyacton?.filter(x => x.technologyId == item.chnologyId) | |||||
obj.stepName = item.stepName; | obj.stepName = item.stepName; | ||||
obj.id = item.id; | obj.id = item.id; | ||||
obj.chnologyId = item.chnologyId; | obj.chnologyId = item.chnologyId; | ||||
obj.sort = item.sort; | obj.sort = item.sort; | ||||
obj.actionJson = item.actionJson | obj.actionJson = item.actionJson | ||||
obj.optiondata = JSON.parse(item.actionJson) | obj.optiondata = JSON.parse(item.actionJson) | ||||
propsdata.forEach(x => { | |||||
propsdata?.forEach(x => { | |||||
let sd = { | let sd = { | ||||
id: x.id, | id: x.id, | ||||
actionName: x.actionName, | actionName: x.actionName, | ||||
@@ -205,10 +205,11 @@ const goodstechnologymaken = (props) => { | |||||
} | } | ||||
const GetGoodsTechnologyvalue=(value,va,item)=>{ | const GetGoodsTechnologyvalue=(value,va,item)=>{ | ||||
let godata=[] | let godata=[] | ||||
console.log("va",va) | |||||
GetGoodsTechnology(value).then((r)=>{ | GetGoodsTechnology(value).then((r)=>{ | ||||
if (r.data.length > 0) { | if (r.data.length > 0) { | ||||
var Technologyacton=[]; | var Technologyacton=[]; | ||||
godata = r.data.map(x => { | |||||
godata = r.data?.map(x => { | |||||
if(x.technologyActionInfo.length>0){ | if(x.technologyActionInfo.length>0){ | ||||
x.technologyActionInfo.forEach(p=>{ | x.technologyActionInfo.forEach(p=>{ | ||||
@@ -217,8 +218,12 @@ const goodstechnologymaken = (props) => { | |||||
} | } | ||||
return { value: x.id, label: x.name } | return { value: x.id, label: x.name } | ||||
}) | }) | ||||
console.log("godata",godata) | |||||
setTechnologyattralldata(Technologyacton) | setTechnologyattralldata(Technologyacton) | ||||
setgoodstechnologydata(godata) | setgoodstechnologydata(godata) | ||||
}else{ | |||||
setTechnologyattralldata([]) | |||||
setgoodstechnologydata([]) | |||||
} | } | ||||
//setfromdata([]) | //setfromdata([]) | ||||
if(va=="edit"){ | if(va=="edit"){ | ||||
@@ -431,6 +436,7 @@ const goodstechnologymaken = (props) => { | |||||
<div style={{ fontSize: 16, marginBottom: 5, color: '#1890ff', fontWeight: 600 }}>选择设备: | <div style={{ fontSize: 16, marginBottom: 5, color: '#1890ff', fontWeight: 600 }}>选择设备: | ||||
<Select | <Select | ||||
showSearch | showSearch | ||||
allowClear | |||||
style={{ | style={{ | ||||
width: 200, | width: 200, | ||||
marginRight: 10 | marginRight: 10 | ||||
@@ -5,77 +5,13 @@ import { PageContainer, FooterToolbar } from '@ant-design/pro-layout'; | |||||
import ProTable from '@ant-design/pro-table'; | import ProTable from '@ant-design/pro-table'; | ||||
import ProDescriptions from '@ant-design/pro-descriptions'; | import ProDescriptions from '@ant-design/pro-descriptions'; | ||||
import { history } from 'umi'; | import { history } from 'umi'; | ||||
import { getDataBaseUrl } from '@/global_data'; | |||||
import { | import { | ||||
goods, | goods, | ||||
addGoods, | |||||
updateGoods, | |||||
removeGoods, | removeGoods, | ||||
gettree, | gettree, | ||||
getBomInfo, | |||||
AddBomApi, | |||||
getbompage, | |||||
upload, | |||||
GoodsTemplateExport | |||||
} from './service'; | } from './service'; | ||||
/** | |||||
* 添加节点 | |||||
* | |||||
* @param fields | |||||
*/ | |||||
const handleAdd = async (fields) => { | |||||
console.log('fields', fields); | |||||
const hide = message.loading('正在添加'); | |||||
fields.createBy = 'admin'; | |||||
try { | |||||
await addGoods(JSON.stringify(fields)).then((r) => { | |||||
if (r.data) { | |||||
message.success('添加成功'); | |||||
} else { | |||||
message.error('添加失败请重试!'); | |||||
} | |||||
}); | |||||
hide(); | |||||
return true; | |||||
} catch (error) { | |||||
hide(); | |||||
message.error('添加失败请重试!'); | |||||
return false; | |||||
} | |||||
}; | |||||
/** | |||||
* 更新节点 | |||||
* | |||||
* @param fields | |||||
*/ | |||||
const handleUpdate = async (fields) => { | |||||
const hide = message.loading('正在配置'); | |||||
try { | |||||
await updateGoods({ | |||||
id: fields.id, | |||||
code: fields.code, | |||||
name: fields.name, | |||||
price: fields.price, | |||||
imgUrl: fields.imgUrl, | |||||
remark: fields.remark, | |||||
status: fields.status, | |||||
goodsTypeId: fields.goodsTypeId, | |||||
}).then((r) => { | |||||
if (r.data) { | |||||
message.success('配置成功'); | |||||
} else { | |||||
message.error('配置失败请重试!'); | |||||
} | |||||
}); | |||||
return true; | |||||
} catch (error) { | |||||
hide(); | |||||
return false; | |||||
} | |||||
}; | |||||
/** | /** | ||||
* 删除节点 | * 删除节点 | ||||
* | * | ||||
@@ -302,7 +238,7 @@ const GoodsManage = () => { | |||||
: Upload.LIST_IGNORE; | : Upload.LIST_IGNORE; | ||||
}, | }, | ||||
name: 'file', | name: 'file', | ||||
action: '/saasbase/api/goodes/ExportGood', | |||||
action: getDataBaseUrl()+'/api/goods/exportgood', | |||||
headers: { | headers: { | ||||
// authorization: 'authorization-text', | // authorization: 'authorization-text', | ||||
Authorization: 'Bearer ' + localStorage.getItem('token') | Authorization: 'Bearer ' + localStorage.getItem('token') | ||||
@@ -21,6 +21,7 @@ const ActionForm = (props) => { | |||||
const [createModalVisible, handleModalVisible] = useState(false); | const [createModalVisible, handleModalVisible] = useState(false); | ||||
const options = { | const options = { | ||||
text:{value:'text',text: `text(字符串)`}, | text:{value:'text',text: `text(字符串)`}, | ||||
textareaary:{value:'textareaary',text: `textarea(字符串数组)`}, | |||||
select:{ value: `select`, text: `enum(枚举)`}, | select:{ value: `select`, text: `enum(枚举)`}, | ||||
// money:{ value: `money`, text: `金额输入`}, | // money:{ value: `money`, text: `金额输入`}, | ||||
textarea:{ value: `textarea`, text: `text(文本域)`}, | textarea:{ value: `textarea`, text: `text(文本域)`}, | ||||
@@ -83,12 +84,12 @@ const ActionForm = (props) => { | |||||
// } | // } | ||||
// } | // } | ||||
// }, | // }, | ||||
{ | |||||
title: '排序', | |||||
dataIndex: 'sort', | |||||
valueType:'digit', | |||||
width: '8%', | |||||
}, | |||||
// { | |||||
// title: '排序', | |||||
// dataIndex: 'sort', | |||||
// valueType:'digit', | |||||
// width: '8%', | |||||
// }, | |||||
{ | { | ||||
title: '操作', | title: '操作', | ||||
valueType: 'option', | valueType: 'option', | ||||
@@ -8,8 +8,11 @@ const CreateAction = (props) => { | |||||
const [valueType, setValueType] = useState('text'); | const [valueType, setValueType] = useState('text'); | ||||
const [layoutType, setLayoutType] = useState('Form'); | const [layoutType, setLayoutType] = useState('Form'); | ||||
const [optionitem,setoptionitem]=useState([]) | const [optionitem,setoptionitem]=useState([]) | ||||
const [jsontext,setjsontext]=useState('') | |||||
const [modalVisit, setModalVisit] = useState(false); | const [modalVisit, setModalVisit] = useState(false); | ||||
const [shuUpdate, setshuUpdate] = useState(false); | const [shuUpdate, setshuUpdate] = useState(false); | ||||
const { TextArea } = Input; | |||||
useEffect(() => { | useEffect(() => { | ||||
formRef.current?.setFieldsValue(props.values); | formRef.current?.setFieldsValue(props.values); | ||||
if(props.createModalVisible){ | if(props.createModalVisible){ | ||||
@@ -34,6 +37,8 @@ const CreateAction = (props) => { | |||||
ary.push({actionValueName:op[t].actionValueName}) | ary.push({actionValueName:op[t].actionValueName}) | ||||
} | } | ||||
setoptionitem(ary); | setoptionitem(ary); | ||||
}if(props.values.actionType=="textareaary"){ | |||||
setjsontext(props.values.actionValue) | |||||
}else{ | }else{ | ||||
setValueType(props.values.actionType); | setValueType(props.values.actionType); | ||||
setLayoutType('Form'); | setLayoutType('Form'); | ||||
@@ -55,6 +60,7 @@ const handleChange=(value)=>{ | |||||
} | } | ||||
const options = [ | const options = [ | ||||
{value:'text',label: `text(字符串)`}, | {value:'text',label: `text(字符串)`}, | ||||
{value:'textareaary',label: `textarea(字符串数组)`}, | |||||
{ value: `select`, label: `enum(枚举)`}, | { value: `select`, label: `enum(枚举)`}, | ||||
// { value: `money`, label: `金额输入`}, | // { value: `money`, label: `金额输入`}, | ||||
{ value: `textarea`, label: `text(文本域)`}, | { value: `textarea`, label: `text(文本域)`}, | ||||
@@ -129,6 +135,17 @@ const handleChange=(value)=>{ | |||||
renderFormItem: () => <Input placeholder="输入类型值" disabled /> | renderFormItem: () => <Input placeholder="输入类型值" disabled /> | ||||
}, | }, | ||||
]; | ]; | ||||
case 'textareaary': | |||||
return [ | |||||
{ | |||||
dataIndex: 'actionValue', | |||||
valueType: 'text', | |||||
initialValue:jsontext, | |||||
renderFormItem: () => <TextArea | |||||
placeholder="数据格式:[data1:{value1:'1'},{value2:'2'},data2:{value1:'1'},{value2:'2'}]" | |||||
autoSize={{minRows: 10,maxRows: 100}}/> | |||||
}, | |||||
]; | |||||
default: | default: | ||||
return [{ | return [{ | ||||
dataIndex: 'actionValue', | dataIndex: 'actionValue', | ||||
@@ -213,9 +230,9 @@ const handleChange=(value)=>{ | |||||
<Form.Item name="isBatch" label="是否绑定物料" valuePropName="checked"> | <Form.Item name="isBatch" label="是否绑定物料" valuePropName="checked"> | ||||
<Switch checkedChildren="是" unCheckedChildren="否"/> | <Switch checkedChildren="是" unCheckedChildren="否"/> | ||||
</Form.Item> */} | </Form.Item> */} | ||||
<Form.Item name="sort" label="排序"> | |||||
{/* <Form.Item name="sort" label="排序"> | |||||
<Input placeholder="请输入排序" /> | <Input placeholder="请输入排序" /> | ||||
</Form.Item> | |||||
</Form.Item> */} | |||||
<Button htmlType="button" style={{float:'right',left:10}} onClick={props.onCancel} > | <Button htmlType="button" style={{float:'right',left:10}} onClick={props.onCancel} > | ||||
取消 | 取消 | ||||
</Button> | </Button> | ||||
@@ -12,6 +12,7 @@ const CreateForm = (props) => { | |||||
const [disaenumbled, setdisaenumbled] = useState('none'); | const [disaenumbled, setdisaenumbled] = useState('none'); | ||||
const [displaybool,setdisplaybool]=useState('none'); | const [displaybool,setdisplaybool]=useState('none'); | ||||
const [displaylength,setdisplaylength]=useState('none'); | const [displaylength,setdisplaylength]=useState('none'); | ||||
const [displaytxtjson,setdisplaytxtjson]=useState('none'); | |||||
const [minnumber, setminnumber] = useState(0); | const [minnumber, setminnumber] = useState(0); | ||||
const [maxnumber, setmaxnumber] = useState(1); | const [maxnumber, setmaxnumber] = useState(1); | ||||
const [ReadWrite, setReadWrite] = useState(0); | const [ReadWrite, setReadWrite] = useState(0); | ||||
@@ -22,6 +23,7 @@ const CreateForm = (props) => { | |||||
const options = [ | const options = [ | ||||
{ value: `digit`, label: `int32(整型)`}, | { value: `digit`, label: `int32(整型)`}, | ||||
{value:'text',label: `text(字符串)`}, | {value:'text',label: `text(字符串)`}, | ||||
{value:'textareaary',label: `textarea(字符串数组)`}, | |||||
{ value: `select`, label: `enum(枚举)`}, | { value: `select`, label: `enum(枚举)`}, | ||||
// { value: `money`, label: `金额输入`}, | // { value: `money`, label: `金额输入`}, | ||||
{ value: `textarea`, label: `text(文本域)`}, | { value: `textarea`, label: `text(文本域)`}, | ||||
@@ -61,7 +63,8 @@ const CreateForm = (props) => { | |||||
description:props?.values?.description, | description:props?.values?.description, | ||||
readWrite:props?.values?.readWrite, | readWrite:props?.values?.readWrite, | ||||
dataLength:props?.values?.dataLength, | dataLength:props?.values?.dataLength, | ||||
boolLabel:props?.values?.BoolLabel, | |||||
boolLabel:props?.values?.boolLabel, | |||||
dataJson:props?.values?.dataJson | |||||
}); | }); | ||||
if(props?.values?.boolLabel){ | if(props?.values?.boolLabel){ | ||||
var boolLabel=props?.values?.boolLabel.split(':') | var boolLabel=props?.values?.boolLabel.split(':') | ||||
@@ -141,21 +144,32 @@ const onChangedataType=(value)=>{ | |||||
setdisanumbled('none') | setdisanumbled('none') | ||||
setdisplaybool('none') | setdisplaybool('none') | ||||
setdisplaylength('none') | setdisplaylength('none') | ||||
setdisplaytxtjson('none') | |||||
}else if(value=="switch"){ | }else if(value=="switch"){ | ||||
setdisplaybool('block') | setdisplaybool('block') | ||||
setdisaenumbled('none') | setdisaenumbled('none') | ||||
setdisanumbled('none') | setdisanumbled('none') | ||||
setdisplaylength('none') | setdisplaylength('none') | ||||
setdisplaytxtjson('none') | |||||
}else if(value=="text"){ | }else if(value=="text"){ | ||||
setdisplaybool('none') | setdisplaybool('none') | ||||
setdisaenumbled('none') | setdisaenumbled('none') | ||||
setdisanumbled('none') | setdisanumbled('none') | ||||
setdisplaylength('block') | setdisplaylength('block') | ||||
}else{ | |||||
setdisplaytxtjson('none') | |||||
}else if(value=="textareaary"){ | |||||
setdisplaybool('none') | |||||
setdisaenumbled('none') | |||||
setdisanumbled('none') | |||||
setdisplaylength('none') | |||||
setdisplaytxtjson('block') | |||||
} | |||||
else{ | |||||
setdisplaylength('none') | setdisplaylength('none') | ||||
setdisplaybool('none') | setdisplaybool('none') | ||||
setdisaenumbled('none') | setdisaenumbled('none') | ||||
setdisanumbled('none') | setdisanumbled('none') | ||||
setdisplaytxtjson('none') | |||||
} | } | ||||
} | } | ||||
const onChangewrite=(e)=>{ | const onChangewrite=(e)=>{ | ||||
@@ -283,6 +297,11 @@ const onChangeboolLabel1=(e)=>{ | |||||
<Input placeholder="10240" defaultValue="10240" addonAfter="字节" /> | <Input placeholder="10240" defaultValue="10240" addonAfter="字节" /> | ||||
</Form.Item> | </Form.Item> | ||||
<Form.Item style={{display:displaytxtjson}} name="dataJson" label="数组字符串" rules={[{ required: false }]}> | |||||
<TextArea | |||||
placeholder="数据格式:[data1:{value1:'1'},{value2:'2'},data2:{value1:'1'},{value2:'2'}]" | |||||
autoSize={{minRows: 10,maxRows: 100}}/> | |||||
</Form.Item> | |||||
<Form.Item style={{display:display}} name="readWrite" label="读写类型" rules={[{ required: false }]}> | <Form.Item style={{display:display}} name="readWrite" label="读写类型" rules={[{ required: false }]}> | ||||
<Radio.Group onChange={onChangewrite} name="radiogroup" defaultValue={0} value={ReadWrite}> | <Radio.Group onChange={onChangewrite} name="radiogroup" defaultValue={0} value={ReadWrite}> | ||||
<Radio value={0}>读写</Radio> | <Radio value={0}>读写</Radio> | ||||
@@ -400,6 +400,10 @@ const handleAdd = async (fields) => { | |||||
fields.dataType=""; | fields.dataType=""; | ||||
} | } | ||||
if(check){ | if(check){ | ||||
if(fields.dataJson!=undefined){ | |||||
fields.dataJson=JSON.parse(fields.dataJson) | |||||
} | |||||
await addgoodstechnology(JSON.stringify(fields)).then((r) => { | await addgoodstechnology(JSON.stringify(fields)).then((r) => { | ||||
if (r.data) { | if (r.data) { | ||||
message.success('添加成功'); | message.success('添加成功'); | ||||
@@ -33,12 +33,12 @@ const GoodsTypeManage = () => { | |||||
message.error(`${file.name} 不是 exelce 文件`); | message.error(`${file.name} 不是 exelce 文件`); | ||||
} | } | ||||
if(ProductVesionId.length==0){ | if(ProductVesionId.length==0){ | ||||
message.error(`请选择产品`); | |||||
message.error(`请选择版本`); | |||||
Upload.LIST_IGNORE | Upload.LIST_IGNORE | ||||
return Upload.LIST_IGNORE; | return Upload.LIST_IGNORE; | ||||
} | } | ||||
if(deviceTypeKey.length==0){ | if(deviceTypeKey.length==0){ | ||||
message.error(`请选择版本`); | |||||
message.error(`请选择产品`); | |||||
return Upload.LIST_IGNORE; | return Upload.LIST_IGNORE; | ||||
} | } | ||||
@@ -209,6 +209,10 @@ const GoodsTypeManage = () => { | |||||
setversion(sd?.label) | setversion(sd?.label) | ||||
} | } | ||||
const onCancel=()=>{ | const onCancel=()=>{ | ||||
console.log("ss") | |||||
setdeviceTypeKey(""); | |||||
setProductVesionId(''); | |||||
setDeviceVesionData([]) | |||||
handleModalVisible(false); | handleModalVisible(false); | ||||
} | } | ||||
return ( | return ( | ||||