Browse Source

Merge branch 'groupmealweb' of http://10.2.1.24:10244/zhaoy/BPA.SAAS.Web into groupmealweb

groupmealweb
gwbvipvip 11 months ago
parent
commit
163550e3fc
17 changed files with 493 additions and 189 deletions
  1. +70
    -18
      src/pages/company/account/components/MenuForm.jsx
  2. +1
    -1
      src/pages/company/account/index.jsx
  3. +1
    -1
      src/pages/database/goods/goodstypemanage/components/CreateForm.jsx
  4. +31
    -11
      src/pages/device/deviceInfo/index.jsx
  5. +42
    -30
      src/pages/device/deviceVesion/index.jsx
  6. +2
    -13
      src/pages/device/product/index.jsx
  7. +3
    -3
      src/pages/device/productmanage/components/CreateForm.jsx
  8. +5
    -5
      src/pages/device/productmanage/components/CreateTopis.jsx
  9. +221
    -71
      src/pages/device/productmanage/index.jsx
  10. +5
    -0
      src/pages/device/productmanage/services.js
  11. +1
    -1
      src/pages/org/orgamange/components/CreateForm.jsx
  12. +75
    -15
      src/pages/org/roles/components/MenuForm.jsx
  13. +12
    -2
      src/pages/org/roles/index.jsx
  14. +7
    -0
      src/pages/org/roles/service.js
  15. +2
    -2
      src/pages/sys/dictionary/dictdata/components/CreateForm.jsx
  16. +15
    -15
      src/pages/sys/dictionary/dictdata/index.jsx
  17. +0
    -1
      src/pages/sys/menus/index.jsx

+ 70
- 18
src/pages/company/account/components/MenuForm.jsx View File

@@ -1,36 +1,76 @@
import React, { useState, useEffect } from 'react';
import { Modal, Tree, Row, Col, List,Tag } from 'antd';
import { Modal, Tree, Row, Col, Checkbox } from 'antd';
import api from '../service';
import Enumerable from 'linq';

const MenuForm = (props) => {
const [load, setLoad] = useState();
const [selectedRowsState, setSelectedRows] = useState();
const [load, setLoad] = useState([]);
const [checkedKeys, setCheckedKeys] = useState();
const [indeterminate, setindeterminate] = useState(false);
const [checkAll,setcheckAll] = useState(false);
useEffect(async () => {
var arr = [];
var filteredArr=[]
Enumerable.from(props.values).forEach(t => {
if(!t.isParentMenu){
arr.push(t.id);
}

if(t.id !== null && typeof t.id !== "undefined"){
filteredArr.push(t);
}
});
setCheckedKeys(arr)
console.log("props.values",props.datas)
var parm={getType:'ALL',type:props.datas.type}
var ret = await api.GetMenu(parm);
var data = Enumerable.from(ret.data).toArray();
var data =props.treeData;
if(getTreeLength(data)===filteredArr.length){
setcheckAll(true)
setindeterminate(false);
}else{
setcheckAll(false);
if(props.values.length==0){
setindeterminate(false);
}else{
setindeterminate(true);
}
}
setLoad(data);
}, [props.modalVisible])

const lbl = () => {
var arr = [];
Enumerable.from(props.values).forEach(t => {
arr.push(<Tag style={{ width: 100, margin: 'Center' }} color="processing">{t.name}</Tag>);
});
return arr;
function getTreeLength(tree) {
let length = tree.length; // 初始化计算器为根节点的子节点数量
for (let i = 0; i < tree.length; i++) {
if (Array.isArray(tree[i].children)) { // 如果当前节点有子节点
length += getTreeLength(tree[i].children); // 将子节点的长度加到计算器上
}
}
return length;
}
const onCheckAllChange = (e) => {
if(!checkAll){
var data=getAllIds(load,[]);
setCheckedKeys(data)
setcheckAll(true)
setindeterminate(false);
}else{
setCheckedKeys([])
setcheckAll(false)
setindeterminate(false);
}
};
function getAllIds(tree, result) {
console.log(tree)
//遍历树 获取id数组
for (const i in tree) {
result.push(tree[i].key); // 遍历项目满足条件后的操作
if (tree[i].children) {
//存在子节点就递归
getAllIds(tree[i].children, result);
}
}
return result;
}

var html = <Modal width={700}
bodyStyle={{ padding: '32px 40px 48px' }}
destroyOnClose
@@ -41,9 +81,21 @@ const MenuForm = (props) => {
maskClosable={false}>
<Row>
<Col span={8}>
<Checkbox indeterminate={indeterminate} onChange={onCheckAllChange} checked={checkAll}>
全选
</Checkbox>
<Tree treeData={load}
onCheck={(keys, e) => { setCheckedKeys(keys) }}
defaultExpandAll={true}
onCheck={(keys, e) => {
if(getTreeLength(props.treeData)==keys.length){
setcheckAll(true)
setindeterminate(false);
}else{
setcheckAll(false)
setindeterminate(true);
}
setCheckedKeys(keys) ;
}}
defaultExpandAll={false}
checkedKeys={checkedKeys}
checkable />
</Col>


+ 1
- 1
src/pages/company/account/index.jsx View File

@@ -123,7 +123,7 @@ const companyManage = () => {
var parm={getType:'ALL',type:0}
api.GetMenu(parm).then((r) => {
if(r.data){
setTreeData(r.data.data);
setTreeData(r.data);
}
});


+ 1
- 1
src/pages/database/goods/goodstypemanage/components/CreateForm.jsx View File

@@ -26,7 +26,7 @@ const CreateForm = (props) => {
<Form.Item name="id" hidden={true}>
<Input />
</Form.Item>
<Form.Item name="pid" label="上级名称" rules={[{ required: true }]}>
<Form.Item name="pid" label="上级名称" rules={[{ required: false }]}>
<TreeSelect
allowClear
showSearch


+ 31
- 11
src/pages/device/deviceInfo/index.jsx View File

@@ -1,5 +1,5 @@
import { PlusOutlined } from '@ant-design/icons';
import { Modal, Button, message } from 'antd';
import { Modal, Button, message,Popconfirm } from 'antd';
import React, { useState, useRef, useEffect } from 'react';
import { PageContainer, FooterToolbar } from '@ant-design/pro-layout';
import ProTable from '@ant-design/pro-table';
@@ -192,7 +192,27 @@ const GoodsTypeManage = () => {
>
更新
</a>,
<Popconfirm
type="primary"
key="primary"
title="确认删除吗?"
okText="是"
cancelText="否"
onConfirm={async () => {
await DelDeviceInfo([record.id]).then((r) => {
if(r.data){
message.success('删除成功,即将刷新');
actionRef.current.reload();
}else{
message.error('删除失败');
}
});
}}
onCancel={() => { }}
>
<a href="#">删除</a>
</Popconfirm>,
// <a
// key="copy"
// onClick={() => {
@@ -326,15 +346,15 @@ const handleRemove = async (selectedRows) => {
>
<PlusOutlined /> 新建
</Button>,
<Button
onClick={async () => {
await handleRemove(selectedRowsState);
setSelectedRows([]);
actionRef.current?.reloadAndRest?.();
}}
>
删除
</Button>,
// <Button
// onClick={async () => {
// await handleRemove(selectedRowsState);
// setSelectedRows([]);
// actionRef.current?.reloadAndRest?.();
// }}
// >
// 删除
// </Button>,
]}
request={async (params) => {
var data = [];


+ 42
- 30
src/pages/device/deviceVesion/index.jsx View File

@@ -6,7 +6,7 @@ import { PlusOutlined } from '@ant-design/icons';
import ProTable from '@ant-design/pro-table';
import CreateForm from './components/CreateForm';
import { GetDeviceVesionPage, AddDeviceVesion, DelDeviceVesion, UpdateDeviceVesion, GetProductList,UpdateStatus } from "./services"
import { history } from 'umi';
const key = 'message';

//添加
@@ -136,16 +136,17 @@ const GoodsTypeManage = () => {
dataIndex: 'productName',
valueType: 'textarea',
},
{
title: '是否存在模板',
dataIndex: 'templatePath',
valueType: 'textarea',
render: (_, record) => [
<div>
<Tag color="#f50" style={{ textAlign: "center", display: (record.templatePath == null||record.templatePath == "") ? "none" : "block" }} >存在模板</Tag>
<Tag style={{ textAlign: "center", display: (record.templatePath == null||record.templatePath == "")? "block" : "none" }} color="#2db7f5">无模板</Tag>
</div>],
},
// {
// title: '是否存在模板',
// dataIndex: 'templatePath',
// valueType: 'textarea',
// hideInSearch: true,
// render: (_, record) => [
// <div>
// <Tag color="#f50" style={{ textAlign: "center", display: (record.templatePath == null||record.templatePath == "") ? "none" : "block" }} >存在模板</Tag>
// <Tag style={{ textAlign: "center", display: (record.templatePath == null||record.templatePath == "")? "block" : "none" }} color="#2db7f5">无模板</Tag>
// </div>],
// },
{
title: '操作',
dataIndex: 'option',
@@ -182,26 +183,37 @@ const GoodsTypeManage = () => {
>
<a href="#">删除</a>
</Popconfirm>,
<a
key="config"
onClick={() => {
setCurrentRow(record);
setIsModalOpen(true);
setIsAddGoodsTemplate(false);
}} > 上传设备工艺模型</a>,
<a
key="config"
onClick={() => {
setCurrentRow(record);
setIsModalOpen(true);
setIsAddGoodsTemplate(true);
}} > 上传商品工艺模版</a>,
<a
key="config"
href={record.templatePath}

> 下载工艺模板</a>
// <a
// key="config"
// onClick={() => {
// setCurrentRow(record);
// setIsModalOpen(true);
// setIsAddGoodsTemplate(false);
// }} > 上传设备工艺模型</a>,
// <a
// key="config"
// onClick={() => {
// setCurrentRow(record);
// setIsModalOpen(true);
// setIsAddGoodsTemplate(true);
// }} > 上传商品工艺模版</a>,
// <a
// key="config"
// href={record.templatePath}

// > 下载工艺模板</a>,
<a
key="config"
onClick={() => {
history.push({
pathname: '/device/productmanage',
query: {
isAdd: false,
values: record,
tabStatus: 'basis'
},
});
}} > 管理</a>,
],
},
];


+ 2
- 13
src/pages/device/product/index.jsx View File

@@ -6,7 +6,7 @@ import { PlusOutlined } from '@ant-design/icons';
import ProTable from '@ant-design/pro-table';
import CreateForm from './components/CreateForm';
import { GetProductPage, AddProduct, DelProduct, UpdateProduct,UpdateStatus } from "./services"
import { history } from 'umi';
const key = 'message';
const { Paragraph, Text } = Typography;
const GoodsTypeManage = () => {
@@ -75,18 +75,7 @@ const GoodsTypeManage = () => {
>
<a href="#">删除</a>
</Popconfirm>,
<a
key="config"
onClick={() => {
history.push({
pathname: '/device/productmanage',
query: {
isAdd: false,
values: record,
tabStatus: 'basis'
},
});
}} > 管理</a>,
],
},
];


+ 3
- 3
src/pages/device/productmanage/components/CreateForm.jsx View File

@@ -50,7 +50,7 @@ const CreateForm = (props) => {
form.setFieldsValue({
id: props?.values?.id,
type: props?.values?.type,
deviceVersionKey: props?.values?.deviceVersionKey,
//deviceVersionKey: props?.values?.deviceVersionKey,
name: props?.values?.name,
dataType: props?.values?.dataType,
dataRange: props?.values?.dataRange,
@@ -200,7 +200,7 @@ const onChangeboolLabel1=(e)=>{
<Form.Item name="id" hidden={true}>
<Input />
</Form.Item>
<Form.Item label={'产品版本'} name="deviceVersionKey" rules={[{ required: true }]}>
{/* <Form.Item label={'产品版本'} name="deviceVersionKey" rules={[{ required: true }]}>
<Select>
{props.DeviceVesionData.map((item, index) => {
return (
@@ -210,7 +210,7 @@ const onChangeboolLabel1=(e)=>{
);
})}
</Select>
</Form.Item>
</Form.Item> */}
<Form.Item name="type" label="功能类型">
<Radio.Group name="type" defaultValue={0} value={arttue} onChange={onchagetype} disabled={disabled}>
<Radio.Button value={0}>属性</Radio.Button>


+ 5
- 5
src/pages/device/productmanage/components/CreateTopis.jsx View File

@@ -51,7 +51,7 @@ const onChange=(e)=>{
// initialValues={props?.values}
onFinish={()=>{
form.setFieldsValue({
topics:"/"+props.productCode+"/${deviceKey}/use/"+topics
topics:"/"+props.productCode+"/"+props.productVesion+"/${deviceKey}/use/"+topics
})
console.log(form.getFieldsValue())
props?.onFinish(form.getFieldsValue())
@@ -61,20 +61,20 @@ const onChange=(e)=>{
<Input />
</Form.Item>
<Form.Item name="topics" label="Topics类" rules={[{ required: true, max: 64, whitespace: true }]}>
<Input addonBefore={props.productCode+"/${deviceKey}/use/"} onChange={onChange} placeholder="请输入Topics类" />
<Input addonBefore={props.productCode+"/"+props.productVesion+"/${deviceKey}/use/"} onChange={onChange} placeholder="请输入Topics类" />
</Form.Item>
<Form.Item label={'类型'} name="topicsType" rules={[{ required: true }]}>
<Select options={[
{
value: '0',
value: 0,
label: '发布',
},
{
value: '1',
value: 1,
label: '订阅',
},
{
value: '2',
value: 2,
label: '发布和订阅',
},
]}/>


+ 221
- 71
src/pages/device/productmanage/index.jsx View File

@@ -1,5 +1,5 @@
import { DropboxOutlined, PlusOutlined,ArrowLeftOutlined } from '@ant-design/icons';
import { Button, message, Input, Upload, Modal, Popconfirm,Card,Typography } from 'antd';
import { Button, message, Input, Upload, Modal, Popconfirm,Card,Typography,Tabs } from 'antd';
import React, { useState, useRef, useEffect } from 'react';
import { PageContainer, FooterToolbar } from '@ant-design/pro-layout';
import ProTable from '@ant-design/pro-table';
@@ -16,7 +16,8 @@ import {
getproducttopicspage,
addproducttopics,
updateproducttopics,
deleteproducttopics
deleteproducttopics,
GetProduct
} from './services';
import { history } from 'umi';
const { Paragraph, Text } = Typography;
@@ -72,14 +73,16 @@ const bomtechnology = (props) => {
//绑定
const actionRef = useRef();
const actiontopisRef= useRef();
const actiontopismrRef= useRef();
const [currentRow, setCurrentRow] = useState();
const [currenttopsRow,setcurrenttopsRow] = useState();
//选中的行
const [selectedRowsState, setSelectedRows] = useState([]);
const [dataSource,setdataSource]=useState([]);
const [datafunctionSource,setdatafunctionSource]=useState([]);
const [DeviceVesionData, setDeviceVesionData] = useState([]);
const [DeviceVesionEnum, setDeviceVesionEnum] = useState({});
// const [DeviceVesionData, setDeviceVesionData] = useState([]);
// const [DeviceVesionEnum, setDeviceVesionEnum] = useState({});
const [Product, setProduct] = useState({});
const [total,settotal]=useState(0);
const [totalfun,settotalfun]=useState(0);
/** 国际化配置 */
@@ -92,17 +95,21 @@ const bomtechnology = (props) => {
SetCurrTabKey(tabStatus.tabActiveKey);
if(!props.location.query.values.id){
history.push({
pathname: '/device/product',
pathname: '/device/deviceVesion',
});
}else{
GetDeviceVesion(props.location.query.values.id).then((res)=>{
let list = {};
res.data.forEach((item) => {
list[item.id] = { text: item.vesion };
});
setDeviceVesionData(res.data)
setDeviceVesionEnum(list)
var params={productId:props.location.query.values.id,deviceTypeKey:props.location.query.values.id,current:1,pageSize:10}
// GetDeviceVesion(props.location.query.values.id).then((res)=>{
// let list = {};
// res.data.forEach((item) => {
// list[item.id] = { text: item.vesion };
// });
// setDeviceVesionData(res.data)
// setDeviceVesionEnum(list)
// })
GetProduct(props.location.query.values.productId).then((res)=>{
setProduct(res.data)
var params={productId:props.location.query.values.productId,productVesionId:props.location.query.values.id,isDefault:true,current:1,pageSize:10}
LoadfunData(params)
LoadtopisData(params);
})
@@ -195,14 +202,14 @@ const bomtechnology = (props) => {
},
},
},
{
title: '版本',
dataIndex: 'vesion',
valueType: 'select',
ellipsis: true,
search: true,
valueEnum:DeviceVesionEnum
},
// {
// title: '版本',
// dataIndex: 'vesion',
// valueType: 'select',
// ellipsis: true,
// search: true,
// valueEnum:DeviceVesionEnum
// },
{
title: '创建时间',
dataIndex: 'createAt',
@@ -242,6 +249,7 @@ const bomtechnology = (props) => {
title: 'Topics类',
dataIndex: 'topics',
valueType: 'textarea',
with:500,
render: (text) => <Paragraph style={{display:'inline'}} copyable>{text}</Paragraph>,
},
{
@@ -275,7 +283,7 @@ const bomtechnology = (props) => {
dataIndex: 'option',
valueType: 'option',
fixed: 'right',
width: 450,
width: 250,
render: (_, record) => [
<a
key="config"
@@ -293,7 +301,7 @@ const bomtechnology = (props) => {
await deleteproducttopics([record.id]).then((r) => {
message.success('删除成功,即将刷新');
var params={productId:props.location.query.values.id,current:1,pageSize:10}
var params={productId:props.location.query.values.productId,current:1,pageSize:10}
LoadtopisData(params)
});
}}
@@ -305,6 +313,60 @@ const bomtechnology = (props) => {
],
},
]
const topicsmrcolumns=[
{
title: '主键',
dataIndex: 'id',
tip: '规则名称是唯一的 key',
hideInSearch: true,
hideInTable: true,
render: (dom, entity) => {
return (
<a
onClick={() => {
setCurrentRow(entity);
setShowDetail(true);
}}
>
{dom}
</a>
);
},
},
{
title: 'Topics类',
dataIndex: 'topics',
valueType: 'textarea',
with:500,
render: (text) => <Paragraph style={{display:'inline'}} copyable>{text}</Paragraph>,
},
{
title: '类型',
dataIndex: 'topicsType',
valueType: 'select',
ellipsis: true,
search: true,
valueEnum: {
0: {
text: '发布',
},
1: {
text: '订阅',
},
2: {
text: '发布和订阅',
},
},
},
{
title: '描述',
dataIndex: 'description',
valueType: 'textarea',
ellipsis: true,
search: false,
with:350,
},
]
const operationTabList = [
{
key: 'basis',
@@ -312,7 +374,7 @@ const bomtechnology = (props) => {
},
{
key: 'topis',
tab: 'topis类列表',
tab: 'topics类列表',
},
];
@@ -341,7 +403,7 @@ const handleAdd = async (fields) => {
await addgoodstechnology(JSON.stringify(fields)).then((r) => {
if (r.data) {
message.success('添加成功');
var params={productId:props.location.query.values.id,deviceTypeKey:props.location.query.values.id,current:1,pageSize:10}
var params={productId:props.location.query.values.productId,deviceTypeKey:props.location.query.values.productId,current:1,pageSize:10}
LoadfunData(params)
handleModalVisible(false);
if (actionRef.current) {
@@ -366,7 +428,7 @@ const handleRemove = async (ids) => {
deletegoodstechnology(ids).then((r) => {
if (r.data) {
message.success('删除成功');
var params={productId:props.location.query.values.id,deviceTypeKey:props.location.query.values.id,current:1,pageSize:10}
var params={productId:props.location.query.values.productId,deviceTypeKey:props.location.query.values.productId,current:1,pageSize:10}
LoadfunData(params)
} else {
message.error(r.errors);
@@ -392,7 +454,7 @@ const handleRemove = async (ids) => {
updategoodstechnology(fields).then((r) => {
if (r.data) {
message.success('修改成功');
var params={productId:props.location.query.values.id,deviceTypeKey:props.location.query.values.id,current:1,pageSize:10}
var params={productId:props.location.query.values.productId,deviceTypeKey:props.location.query.values.productId,current:1,pageSize:10}
LoadfunData(params)
handleModalVisible(false);
if (actionRef.current) {
@@ -432,10 +494,123 @@ const handleRemove = async (ids) => {
// }
// //initGoodsType()
};
const onTabsChange=(key)=> {
console.log(key)
var params={}
if(key=="1"){
params.productId=props.location.query.values.productId
params.productVesionId=props.location.query.values.id
params.isDefault=true;
params.current=1;
params.pageSize=10
LoadtopisData(params)
}else{
//actiontopisRef.current.reload();
params.productId=props.location.query.values.productId
params.productVesionId=props.location.query.values.id
params.isDefault=false;
params.current=1;
params.pageSize=10
LoadtopisData(params)
}
}
const zdytopicslist={
zdy: (
<ProTable
id="table1"
actionRef={actiontopisRef}
rowKey="id"
pagination={{ defaultPageSize: 10,total:total }}
search={{labelWidth: 120}}
columns={topicscolumns}
toolBarRender={() => [
<Button
type="primary"
key="primary"
onClick={() => {
setcreateTopisModalVisible(true);
setcurrenttopsRow({});
}}
>
<PlusOutlined /> 新建
</Button>,
]}
//数据绑定
dataSource={dataSource}
request={async (params) => {
var data = [];
var total = 0;
params.productId=props.location.query.values.productId
params.productVesionId=props.location.query.values.id
params.isDefault=false;
await getproducttopicspage(params).then((r) => {
setdataSource( r.data.data)
data = r.data.data;
total = r.data.total;
});
return {
data: data,
success: true,
total: total,
};
}}
// 每行选择点击事件
rowSelection={{
onChange: (_, selectedRows) => {
setSelectedRows(selectedRows);
},
}}
/>
),
mr:(
<ProTable
id="table3"
actionRef={actiontopismrRef}
rowKey="id"
search={false}
pagination={{ defaultPageSize: 10,total:total }}
columns={topicsmrcolumns}
toolBarRender={false}
//数据绑定
dataSource={dataSource}
request={async (params) => {
var data = [];
var total = 0;
params.productId=props.location.query.values.productId
params.productVesionId=props.location.query.values.id
params.isDefault=true;
await getproducttopicspage(params).then((r) => {
setdataSource( r.data.data)
data = r.data.data;
total = r.data.total;
});
return {
data: data,
success: true,
total: total,
};
}}
/>
)
};
const items=[{
key: '1',
label: '默认topics',
children: zdytopicslist.mr,
},
{
key: '2',
label: '自定义topics',
children: zdytopicslist.zdy
}]
const contentList = {
basis: (
<Card style={{marginBottom: 24}} bordered={false}>
<ProTable
id="table2"
actionRef={actionRef}
rowKey="id"
pagination={{ defaultPageSize: 10 }}
@@ -472,8 +647,8 @@ const handleRemove = async (ids) => {
request={async (params) => {
var data = [];
var total = 0;
params.deviceTypeKey=props.location.query.values.id
params.productId=props.location.query.values.productId
params.productVesionId=props.location.query.values.id
await getGoodstechnologypage(params).then((r) => {
data = r.data.data;
setdatafunctionSource( r.data.data)
@@ -496,8 +671,8 @@ const handleRemove = async (ids) => {
onFinish={async (value) => {
console.log("jnlaile ")
console.log(value)
value.productId=props.location.query.values.id
var success = false;
value.productId=props.location.query.values.productId
value.deviceVersionKey=props.location.query.values.id;
if (value.id) {
await handleUpdate(value);
} else {
@@ -510,7 +685,7 @@ const handleRemove = async (ids) => {
}}
createModalVisible={createModalVisible}
values={currentRow || {}}
DeviceVesionData={DeviceVesionData}
// DeviceVesionData={DeviceVesionData}
/>
<ActionForm actionFormModalVisible={actionFormModalVisible}
values={currentRow || {} }
@@ -523,46 +698,21 @@ const handleRemove = async (ids) => {
),
topis: (
<Card style={{marginBottom: 24}} bordered={false}>
<ProTable
id="table1"
actionRef={actiontopisRef}
rowKey="id"
pagination={{ defaultPageSize: 10,total:total }}
search={{labelWidth: 120}}
columns={topicscolumns}
toolBarRender={() => [
<Button
type="primary"
key="primary"
onClick={() => {
setcreateTopisModalVisible(true);
setcurrenttopsRow({});
}}
>
<PlusOutlined /> 新建
</Button>,
<Tabs tabPosition='left' items={items} onChange={onTabsChange}/>
]}
//数据绑定
dataSource={dataSource}
// 每行选择点击事件
rowSelection={{
onChange: (_, selectedRows) => {
setSelectedRows(selectedRows);
},
}}
></ProTable>
<CreateTopis createModalVisible={createTopisModalVisible} productCode={props.location.query.values.key}
<CreateTopis createModalVisible={createTopisModalVisible} productCode={Product.key} productVesion={props.location.query.values?.vesion}
values={currenttopsRow || {}}
onFinish={async (value) => {
value.productId=props.location.query.values.id
value.productId=props.location.query.values.productId
value.productVesionId=props.location.query.values.id
if (value.id) {
await updateproducttopics(value).then((r)=>{
if (r.data) {
message.success('修改成功');
actiontopisRef.current.reload();
setcreateTopisModalVisible(false)
var params={productId:props.location.query.values.id,current:1,pageSize:10}
LoadtopisData(params)
//var params={productId:props.location.query.values.productId,current:1,pageSize:10}
//LoadtopisData(params)
} else {
message.error(r.errors);
}
@@ -571,8 +721,9 @@ const handleRemove = async (ids) => {
await addproducttopics(value).then((r)=>{
if (r.data) {
message.success('添加成功');
var params={productId:props.location.query.values.id,current:1,pageSize:10}
LoadtopisData(params)
actiontopisRef.current.reload();
// var params={productId:props.location.query.values.productId,current:1,pageSize:10}
// LoadtopisData(params)
setcreateTopisModalVisible(false)
} else {
message.error(r.errors);
@@ -590,20 +741,19 @@ const handleRemove = async (ids) => {
),
};
return (
<PageContainer host header={{
title: [<a key="back"
onClick={() => {
history.push({
pathname: '/device/product',
pathname: '/device/deviceVesion',
});
}}><ArrowLeftOutlined />返回</a>,
<div style={{backgroundColor:'#f3eaea',width:'1640px',height: '54px'}}>
<div style={{fontSize: '14px',color: 'cornflowerblue'}}>
<span style={{marginRight:20,marginLeft:10,marginTop:10,float:'left' }}>产品名称:<span style={{marginLeft:10}}>{props.location.query.values.name}</span></span>
<span style={{marginRight:120,marginLeft:10,marginTop:10,float:'right'}}>产品key: <Paragraph style={{display:'inline'}} copyable>{props.location.query.values.key}</Paragraph></span></div>
<span style={{marginRight:20,marginLeft:10,marginTop:10,float:'left' }}>产品版本:<span style={{marginLeft:10}}>{props.location.query.values?.vesion}</span></span>
<span style={{marginRight:20,marginLeft:10,marginTop:10,float:'left' }}>产品名称:<span style={{marginLeft:10}}>{Product?.name}</span></span>
<span style={{marginRight:120,marginLeft:10,marginTop:10,float:'right'}}>产品key: <Paragraph style={{display:'inline'}} copyable>{Product?.key}</Paragraph></span></div>
</div>
],
breadcrumb: {},


+ 5
- 0
src/pages/device/productmanage/services.js View File

@@ -77,4 +77,9 @@ export async function addgoodstechnology(data) {
return request(getDataBaseUrl()+`/api/devicevesion/getdevicevesion?productId=${TypeCode}`, {
method: 'Get',
});
}
export async function GetProduct(productId) {
return request(getDataBaseUrl()+`/api/product/getproduct?productId=${productId}`, {
method: 'Get',
});
}

+ 1
- 1
src/pages/org/orgamange/components/CreateForm.jsx View File

@@ -41,7 +41,7 @@ const CreateForm = (props) => {
<Form.Item name="id" hidden={true}>
<Input />
</Form.Item>
<Form.Item name="pid" label="上级名称" rules={[{ required: true }]}>
<Form.Item name="pid" label="上级名称" rules={[{ required: false }]}>
<TreeSelect
style={{ width: '100%' }}
dropdownStyle={{ maxHeight: 400, overflow: 'auto' }}


+ 75
- 15
src/pages/org/roles/components/MenuForm.jsx View File

@@ -1,31 +1,79 @@
import React, { useState, useEffect } from 'react';
import { Modal, Tree, Row, Col, List,Tag } from 'antd';
import api from './service';
import { Modal, Tree, Row, Col, Checkbox } from 'antd';
import Enumerable from 'linq';

const MenuForm = (props) => {
const [load, setLoad] = useState();
const [selectedRowsState, setSelectedRows] = useState();
const [checkedKeys, setCheckedKeys] = useState();
const [indeterminate, setindeterminate] = useState(false);
const [checkAll,setcheckAll] = useState(false);
useEffect(async () => {
var arr = [];
var filteredArr=[]
Enumerable.from(props.values).forEach(t => {
arr.push(t.id);
if(!t.isParentMenu){
arr.push(t.id);
}
if(t.id !== null && typeof t.id !== "undefined"){
filteredArr.push(t);
}
});
setCheckedKeys(arr)
var ret = await api.SelectTree();
var data = Enumerable.from(ret.data).toArray();
var data =props.treeData;
console.log("props.values",props.values)
console.log("data",data)
console.log("filteredArr",filteredArr)
if(getTreeLength(data)===filteredArr.length){
setcheckAll(true)
setindeterminate(false);
}else{
setcheckAll(false);
if(props.values.length==0){
setindeterminate(false);
}else{
setindeterminate(true);
}
}
setLoad(data);
}, [props.modalVisible])
function getTreeLength(tree) {
let length = tree.length; // 初始化计算器为根节点的子节点数量
for (let i = 0; i < tree.length; i++) {
if (Array.isArray(tree[i].children)) { // 如果当前节点有子节点
length += getTreeLength(tree[i].children); // 将子节点的长度加到计算器上
}
}
return length;
}
const onCheckAllChange = (e) => {
if(!checkAll){
var data=getAllIds(load,[]);
setCheckedKeys(data)
setcheckAll(true)
setindeterminate(false);
}else{
setCheckedKeys([])
setcheckAll(false)
setindeterminate(false);
}
};

const lbl = () => {
var arr = [];
Enumerable.from(props.values).forEach(t => {
arr.push(<Tag style={{ width: 68, margin: 'Center' }} color="processing">{t.name}</Tag>);
});
return arr;
function getAllIds(tree, result) {
console.log(tree)
//遍历树 获取id数组
for (const i in tree) {
result.push(tree[i].key); // 遍历项目满足条件后的操作
if (tree[i].children) {
//存在子节点就递归
getAllIds(tree[i].children, result);
}
}
return result;
}

var html = <Modal width={700}
bodyStyle={{ padding: '32px 40px 48px' }}
destroyOnClose
@@ -38,9 +86,21 @@ const MenuForm = (props) => {
maskClosable={false}>
<Row>
<Col span={12}>
<Checkbox indeterminate={indeterminate} onChange={onCheckAllChange} checked={checkAll}>
全选
</Checkbox>
<Tree treeData={load}
onCheck={(keys, e) => { setCheckedKeys(keys) }}
defaultExpandAll={true}
onCheck={(keys, e) => {
if(getTreeLength(props.treeData)==keys.length){
setcheckAll(true)
setindeterminate(false);
}else{
setcheckAll(false)
setindeterminate(true);
}
setCheckedKeys(keys) ;
}}
defaultExpandAll={false}
checkedKeys={checkedKeys}
checkable />
</Col>


+ 12
- 2
src/pages/org/roles/index.jsx View File

@@ -5,7 +5,7 @@ import { PageContainer, FooterToolbar } from '@ant-design/pro-layout';
import ProTable, { ProColumns, ActionType, TableDropdown } from '@ant-design/pro-table';
import Enumerable from 'linq'
import CreateForm from './components/CreateForm';
import { Page, add, edit, removeRole, setMenu, setUserGrantData, Enable, Disable, GetRoleMenu, SetDataRole } from './service';
import { Page, add, edit, removeRole, setMenu, GetMenu, GetRoleMenu, SetDataRole } from './service';
import { useAccess } from 'umi';
import MenuForm from './components/MenuForm';
import OrgForm from './components/OrgForm';
@@ -105,7 +105,7 @@ const roleManager = () => {
const [row, setRow] = useState();
const [selectedRowsState, setSelectedRows] = useState();
const [selectData, setSelectData] = useState([]);
const [treeData, setTreeData] = useState();
/**
* 删除节点
* @param selectedRows
@@ -190,6 +190,15 @@ const roleManager = () => {
return arr;
}

useEffect(() => {
var parm={getType:'ALL',type:0}
GetMenu(parm).then((r) => {
if(r.data){
setTreeData(r.data);
}
});
}, []);

const columns = [
{
@@ -342,6 +351,7 @@ const roleManager = () => {
}}
modalVisible={updateMenuModalVisible}
values={row || {}}
treeData={treeData}
/>

) : null}


+ 7
- 0
src/pages/org/roles/service.js View File

@@ -64,3 +64,10 @@ export async function SetDataRole(params) {
data:params
});
}
/** 查询功能菜单*/
export async function GetMenu(params) {
return request(getDataBaseUrl()+`​/api/menu/menuparmytrees?getType=${params.getType}&&type=${params.type}`,
{
method: 'Get',
});
}

+ 2
- 2
src/pages/sys/dictionary/dictdata/components/CreateForm.jsx View File

@@ -34,7 +34,7 @@ const CreateForm = (props) => {
<Form.Item name="code" label="字典编码" rules={[{ required: true, max: 64 }]}>
<Input placeholder="请输入字典编码" />
</Form.Item>
<Form.Item
{/* <Form.Item
name="typeId"
label="字典类型"
rules={[{ required: true, message: '请选择字典类型' }]}
@@ -48,7 +48,7 @@ const CreateForm = (props) => {
);
})}
</Select>
</Form.Item>
</Form.Item> */}
{/* <Form.Item
name="status"
label="状态"


+ 15
- 15
src/pages/sys/dictionary/dictdata/index.jsx View File

@@ -133,20 +133,20 @@ const DictDataManage = (props) => {
dataIndex: 'code',
ellipsis:true
},
{
title: '字典类型',
dataIndex: 'typeName',
hideInForm: true,
hideInSearch: true,
},
{
title: '字典类型',
dataIndex: 'typeId',
hideInForm: true,
hideInTable: true,
hideInSearch: true,
valueEnum: typeNames,
},
// {
// title: '字典类型',
// dataIndex: 'typeName',
// hideInForm: true,
// hideInSearch: true,
// },
// {
// title: '字典类型',
// dataIndex: 'typeId',
// hideInForm: true,
// hideInTable: true,
// hideInSearch: true,
// valueEnum: typeNames,
// },
{
title: '备注',
dataIndex: 'remark',
@@ -279,7 +279,7 @@ const DictDataManage = (props) => {
<CreateForm
typeNameData={typeNames}
onFinish={async (value) => {
value.typeId=props.currentRow.id;
var success = false;
if (value.id) {
success = await handleUpdate(value);


+ 0
- 1
src/pages/sys/menus/index.jsx View File

@@ -179,7 +179,6 @@ const handleUpdate = async (fields) => {
{
title: '创建时间',
dataIndex: 'createAt',
sorter: true,
hideInSearch: true,
},
{


Loading…
Cancel
Save