Browse Source

Merge branch 'cad' into develop
解决冲突
# Conflicts:
# src/pages/Home/index.js

Renxy 1 year ago
parent
commit
7ac00c0961

+ 5 - 6
.umirc.ts

@@ -39,11 +39,11 @@ export default defineConfig({
   //   { src: '/ZwCloud2DSDK/ZwWasmJs.js' },
   //   { src: '/ZwCloud2DSDK/ZwWasmJs.js' },
   //   { src: '/ZwCloud2DSDK/ZwCloud2DAPI.js' },
   //   { src: '/ZwCloud2DSDK/ZwCloud2DAPI.js' },
   // ],
   // ],
-  // headScripts: [
-  //   `${publicPath}ZwCloud2DSDK/ZwCloud2D.js`,
-  //   `${publicPath}ZwCloud2DSDK/ZwWasmJs.js`,
-  //   `${publicPath}ZwCloud2DSDK/ZwCloud2DPrivateAPI.js`,
-  // ],
+  headScripts: [
+    `${publicPath}ZwCloud2DSDK/ZwCloud2D.js`,
+    `${publicPath}ZwCloud2DSDK/ZwWasmJs.js`,
+    `${publicPath}ZwCloud2DSDK/ZwCloud2DPrivateAPI.js`,
+  ],
   proxy: {
   proxy: {
     '/api': {
     '/api': {
       // target: 'http://192.168.20.232:1007/',
       // target: 'http://192.168.20.232:1007/',
@@ -177,7 +177,6 @@ export default defineConfig({
       name: 'CAD实例',
       name: 'CAD实例',
       path: '/cad',
       path: '/cad',
       component: './Cad',
       component: './Cad',
-      hideInMenu: true,
       icon: 'https://water-service-test.oss-cn-hangzhou.aliyuncs.com/doc/contract/2023-07-31/3f72fccf-4f9c-4891-a6ec-f04fe4b1d9a2.png',
       icon: 'https://water-service-test.oss-cn-hangzhou.aliyuncs.com/doc/contract/2023-07-31/3f72fccf-4f9c-4891-a6ec-f04fe4b1d9a2.png',
     },
     },
     {
     {

+ 5 - 2
src/app.tsx

@@ -1,6 +1,6 @@
 // 运行时配置
 // 运行时配置
 import { RunTimeLayoutConfig, RequestConfig } from '@umijs/max';
 import { RunTimeLayoutConfig, RequestConfig } from '@umijs/max';
-import { message } from 'antd';
+import { ConfigProvider, message } from 'antd';
 import UserDropdown from '@/components/UserDropdown';
 import UserDropdown from '@/components/UserDropdown';
 import { getToken } from '@/utils/utils';
 import { getToken } from '@/utils/utils';
 import { history } from 'umi';
 import { history } from 'umi';
@@ -9,6 +9,7 @@ import { useModel } from '@umijs/max';
 import { queryCurrentV2 } from './services/user';
 import { queryCurrentV2 } from './services/user';
 import dayjs from 'dayjs';
 import dayjs from 'dayjs';
 import 'dayjs/locale/zh-cn';
 import 'dayjs/locale/zh-cn';
+import React from 'react';
 
 
 dayjs.locale('zh-cn');
 dayjs.locale('zh-cn');
 
 
@@ -61,7 +62,9 @@ export const layout: RunTimeLayoutConfig = (initialState) => {
     logo: logo,
     logo: logo,
   };
   };
 };
 };
-
+export function rootContainer(container) {
+  return React.createElement(ConfigProvider, { prefixCls: 'antd5' }, container);
+}
 // axios配置
 // axios配置
 export const request: RequestConfig = {
 export const request: RequestConfig = {
   errorConfig: {
   errorConfig: {

+ 1 - 1
src/components/Flow/node/control-map-service/components/style.less

@@ -92,7 +92,7 @@
     grid-gap: 8px;
     grid-gap: 8px;
   }
   }
 
 
-  .ant-input-number {
+  .antd5-input-number {
     width: 100%;
     width: 100%;
   }
   }
 }
 }

+ 9 - 11
src/components/InputSelect/index.less

@@ -1,33 +1,31 @@
-.noData{
+.noData {
   position: relative;
   position: relative;
   text-align: center;
   text-align: center;
   color: #fff;
   color: #fff;
   font-size: 24px;
   font-size: 24px;
-  .noDataText{
+  .noDataText {
     position: absolute;
     position: absolute;
     left: 50%;
     left: 50%;
     bottom: 15px;
     bottom: 15px;
     transform: translateX(-50%);
     transform: translateX(-50%);
   }
   }
-  .noDataImg{
+  .noDataImg {
     display: block;
     display: block;
     margin: auto;
     margin: auto;
   }
   }
 }
 }
-.down{
+.down {
   :global {
   :global {
-    .ant-input-group-addon{
+    .antd5-input-group-addon {
       padding: 0;
       padding: 0;
       font-size: 18px;
       font-size: 18px;
     }
     }
-    
   }
   }
 }
 }
-.main{
+.main {
   position: relative;
   position: relative;
-  
 }
 }
-.downUl{
+.downUl {
   width: 100%;
   width: 100%;
   height: 300px;
   height: 300px;
   overflow-y: scroll;
   overflow-y: scroll;
@@ -39,11 +37,11 @@
   border: 1px solid #eee;
   border: 1px solid #eee;
   border-radius: 5px;
   border-radius: 5px;
   padding: 4px 0 4px 10px;
   padding: 4px 0 4px 10px;
-  & >li{
+  & > li {
     cursor: pointer;
     cursor: pointer;
     padding: 4px 0;
     padding: 4px 0;
   }
   }
-  & >li:hover{
+  & > li:hover {
     background-color: #eee;
     background-color: #eee;
   }
   }
 }
 }

+ 22 - 22
src/components/ModuleTitle/index.less

@@ -1,56 +1,56 @@
-.icon{
+.icon {
   float: left;
   float: left;
   width: 8px;
   width: 8px;
   height: 22px;
   height: 22px;
-  background-color: #366CDA;
+  background-color: #366cda;
 }
 }
-.title{
+.title {
   font-size: 16px;
   font-size: 16px;
   padding-left: 14px;
   padding-left: 14px;
 }
 }
-.right{
-  color: #366CDA;
+.right {
+  color: #366cda;
   float: right;
   float: right;
   font-size: 20px;
   font-size: 20px;
   cursor: default;
   cursor: default;
 }
 }
 
 
-.leftArrow{
-  border: solid 20px ;
-  border-color: transparent #366CDA transparent  transparent ;
+.leftArrow {
+  border: solid 20px;
+  border-color: transparent #366cda transparent transparent;
 }
 }
-.rightArrow{
-  border: solid 20px ;
-  border-color: transparent transparent  transparent #366CDA ;
+.rightArrow {
+  border: solid 20px;
+  border-color: transparent transparent transparent #366cda;
 }
 }
-.typeList{
+.typeList {
   flex-grow: 1;
   flex-grow: 1;
   display: flex;
   display: flex;
 }
 }
 
 
-.content{
+.content {
   height: 100%;
   height: 100%;
-  :global{
-    .ant-tabs-nav-wrap{
+  :global {
+    .antd5-tabs-nav-wrap {
       background: none;
       background: none;
     }
     }
-    .ant-tabs-nav .ant-tabs-tab{
+    .antd5-tabs-nav .antd5-tabs-tab {
       padding: 2px 16px;
       padding: 2px 16px;
       background-color: #2196f330;
       background-color: #2196f330;
       border: none;
       border: none;
       margin: 0 6px;
       margin: 0 6px;
     }
     }
-    .ant-tabs-tab-active{
+    .antd5-tabs-tab-active {
       color: #fff !important;
       color: #fff !important;
-      background-color: #366CDA !important;
+      background-color: #366cda !important;
     }
     }
-    .ant-tabs-tab:hover{
+    .antd5-tabs-tab:hover {
       color: #fff !important;
       color: #fff !important;
     }
     }
-    .ant-tabs-bar{
+    .antd5-tabs-bar {
       margin: 0;
       margin: 0;
     }
     }
-    // .ant-tabs-tab-prev-icon{
+    // .antd5-tabs-tab-prev-icon{
     //   border: solid 20px ;
     //   border: solid 20px ;
     //   border-color: transparent #366CDA transparent  transparent ;
     //   border-color: transparent #366CDA transparent  transparent ;
     //   i{
     //   i{
@@ -59,4 +59,4 @@
     //   }
     //   }
     // }
     // }
   }
   }
-}
+}

+ 1 - 1
src/components/UserDropdown/index.less

@@ -53,7 +53,7 @@
   }
   }
   .root {
   .root {
     :global {
     :global {
-      .ant-dropdown {
+      .antd5-dropdown {
         padding-left: 14px;
         padding-left: 14px;
         min-width: 102px;
         min-width: 102px;
       }
       }

+ 24 - 24
src/global.less

@@ -101,7 +101,7 @@ input[type='reset'] {
   width: 100% !important;
   width: 100% !important;
   height: unset !important;
   height: unset !important;
 }
 }
-.ant-pro-global-header {
+.antd5-pro-global-header {
   background: transparent;
   background: transparent;
   background-image: url(@/assets/header.png);
   background-image: url(@/assets/header.png);
   background-size: cover;
   background-size: cover;
@@ -109,80 +109,80 @@ input[type='reset'] {
   margin-inline: 0;
   margin-inline: 0;
   height: 79px;
   height: 79px;
 }
 }
-.ant-pro-layout .ant-layout-header.ant-pro-layout-header {
+.antd5-pro-layout .antd5-layout-header.antd5-pro-layout-header {
   background-color: transparent;
   background-color: transparent;
   height: 79px;
   height: 79px;
 }
 }
-.ant-layout .ant-layout-header {
+.antd5-layout .antd5-layout-header {
   height: 79px !important;
   height: 79px !important;
   line-height: 79px !important;
   line-height: 79px !important;
 }
 }
-.ant-pro-global-header-logo img {
+.antd5-pro-global-header-logo img {
   height: 40px;
   height: 40px;
 }
 }
-.ant-pro-global-header-logo-mix {
+.antd5-pro-global-header-logo-mix {
   margin-left: 62px;
   margin-left: 62px;
 }
 }
 
 
-.ant-layout-sider {
+.antd5-layout-sider {
   height: calc(100% - 79px) !important;
   height: calc(100% - 79px) !important;
   inset-block-start: 79px !important;
   inset-block-start: 79px !important;
   background-size: 132% 100% !important;
   background-size: 132% 100% !important;
   background-image: url(@/assets/SideMenu/background.png) !important;
   background-image: url(@/assets/SideMenu/background.png) !important;
 }
 }
 
 
-.ant-menu-title-content {
+.antd5-menu-title-content {
   font-size: 18px;
   font-size: 18px;
   color: #e8f7fc;
   color: #e8f7fc;
 }
 }
 
 
-.ant-pro-base-menu-icon {
+.antd5-pro-base-menu-icon {
   height: 20px;
   height: 20px;
   width: 20px;
   width: 20px;
 }
 }
-.ant-pro-base-menu-item-icon {
+.antd5-pro-base-menu-item-icon {
   margin-right: 10px;
   margin-right: 10px;
 }
 }
 
 
-.ant-menu-item,
-.ant-menu-submenu {
+.antd5-menu-item,
+.antd5-menu-submenu {
   margin-top: 15px !important;
   margin-top: 15px !important;
   margin-bottom: 15px !important;
   margin-bottom: 15px !important;
 }
 }
 
 
-.ant-menu-item,
-.ant-menu-submenu-title {
+.antd5-menu-item,
+.antd5-menu-submenu-title {
   border-bottom: 1px solid !important;
   border-bottom: 1px solid !important;
   border-image: linear-gradient(#3e6ab4, #5bbdfa) 2 2 2 2 !important;
   border-image: linear-gradient(#3e6ab4, #5bbdfa) 2 2 2 2 !important;
 }
 }
 
 
-.ant-menu-sub {
+.antd5-menu-sub {
   margin-left: 32px !important;
   margin-left: 32px !important;
-  .ant-menu-item {
+  .antd5-menu-item {
     margin-top: 10px !important;
     margin-top: 10px !important;
     margin-bottom: 10px !important;
     margin-bottom: 10px !important;
   }
   }
-  .ant-menu-title-content {
+  .antd5-menu-title-content {
     font-size: 16px;
     font-size: 16px;
     color: #e8f7fc;
     color: #e8f7fc;
   }
   }
 }
 }
 
 
-.ant-menu-submenu-arrow {
+.antd5-menu-submenu-arrow {
   color: #e8f7fc !important;
   color: #e8f7fc !important;
 }
 }
 
 
-.ant-menu-item-selected,
-.ant-pro-base-menu-collapsed
-  .ant-menu-submenu-selected
-  > .ant-menu-submenu-title,
-.ant-menu-item:active {
+.antd5-menu-item-selected,
+.antd5-pro-base-menu-collapsed
+  .antd5-menu-submenu-selected
+  > .antd5-menu-submenu-title,
+.antd5-menu-item:active {
   background-image: url(@/assets/SideMenu/selectedBackground.png);
   background-image: url(@/assets/SideMenu/selectedBackground.png);
   background-color: transparent !important;
   background-color: transparent !important;
 }
 }
 
 
-.ant-menu-submenu-popup {
-  .ant-menu {
+.antd5-menu-submenu-popup {
+  .antd5-menu {
     background-color: #1b366f !important;
     background-color: #1b366f !important;
   }
   }
 }
 }

+ 51 - 0
src/pages/Cad/components/CadOADetail.js

@@ -0,0 +1,51 @@
+import AttachmentTable from '@/components/AttachmentTable';
+import { Card, Row, Col, Table } from 'antd';
+import { useRequest, useNavigate } from '@umijs/max';
+
+const CadOADetail = (props) => {
+  let navigate = useNavigate();
+  const { data, fileList } = props;
+
+  const cadData = data?.cad_path?.split(',').map((item) => {
+    return { name: item };
+  });
+
+  const columns = [
+    {
+      title: '名称',
+      dataIndex: 'name',
+      key: 'name',
+    },
+    {
+      title: '操作',
+      render: (record) => (
+        <a
+          onClick={() =>
+            navigate('/cad/detail', {
+              state: {
+                path: record.name,
+              },
+            })
+          }
+        >
+          查看
+        </a>
+      ),
+    },
+  ];
+
+  return (
+    <Card title="图纸信息">
+      <Row gutter={20}>
+        <Col span={12}>
+          <Table dataSource={cadData} columns={columns} />
+        </Col>
+
+        <Col span={12}>
+          <AttachmentTable excelFileList={fileList} />
+        </Col>
+      </Row>
+    </Card>
+  );
+};
+export default CadOADetail;

+ 252 - 0
src/pages/Cad/components/CreateModal.js

@@ -0,0 +1,252 @@
+import ModuleTitle from '@/components/ModuleTitle/moduleTitle';
+import { advanceSubmitNextNode } from '@/services/boom';
+import { CloudUploadOutlined } from '@ant-design/icons';
+import { useModel, useRequest } from '@umijs/max';
+import {
+  Modal,
+  Form,
+  Input,
+  Upload,
+  Select,
+  Button,
+  Steps,
+  Row,
+  Col,
+  Cascader,
+} from 'antd';
+import { useEffect, useState } from 'react';
+import styles from './index.less';
+import ApprovalProcess from '@/pages/Flow/components/ApprovalProcess';
+
+//计算审批流数据
+const advance = {
+  flow_id: 67,
+  form_list: null,
+  formComponentValues: '',
+};
+const formItemValues = [
+  {
+    name: '是否PID图和平面图',
+    id: 'DDSelectField_b8169258-d569-442e-a7b0-e2bd171aaac2',
+    type: 'DDSelectField',
+    value: [],
+  },
+  // {
+  //   name: '图纸审批"',
+  //   id: 'TextField_eb5b191b-6135-48ba-a01c-5609ed367d83"',
+  //   type: 'TextField',
+  //   value: [],
+  // },
+];
+
+const CreateModal = ({
+  loading,
+  projectList,
+  dirList,
+  open,
+  onOk,
+  handleCancel,
+}) => {
+  const { userList, run: userListRun } = useModel('userList');
+  const [form] = Form.useForm();
+  const layout = {
+    labelCol: { span: 6 },
+    wrapperCol: { span: 16 },
+  };
+  console.log('-[-------------------', dirList);
+  const [upLoading, setUpLoading] = useState([]);
+  const [auditCheck, setAuditCheck] = useState([]);
+  const [approvalProcess, setApprovalProcess] = useState([]);
+  const pic_type = Form.useWatch('pic_type', form);
+
+  useEffect(() => {
+    if (!open) return;
+    form.resetFields();
+    setApprovalProcess([]);
+    userListRun();
+    const params = { ...advance };
+    runAuditList(params);
+  }, [open]);
+
+  useEffect(() => {
+    const formComponentValues = [...formItemValues];
+    formComponentValues[0].value = [pic_type];
+    runAuditList({ ...advance, formComponentValues });
+  }, [pic_type]);
+
+  //填写表单时计算审批流接口
+  const { run: runAuditList } = useRequest(
+    (data) => advanceSubmitNextNode(data),
+    {
+      debounceInterval: 500,
+      manual: true,
+      formatResult(res) {
+        setApprovalProcess(res.data[0]);
+      },
+    },
+  );
+
+  function dwgUpload() {
+    let uploadDwg = document.getElementById('uploadDwg');
+    uploadDwg.click();
+  }
+
+  function uploadDwg(event) {
+    const selectedFile = event.target.files[0];
+    if (selectedFile) {
+      // ZwCloud2D.ZwEditor.ZwSetLoadingState(true);
+      setUpLoading(true);
+      ZwCloud2D.ZwDataProcessor.uploadDwg(selectedFile).then((res) => {
+        if (res.code == 200) {
+          const oldPath = form.getFieldValue('cad_path');
+          const cad_path = oldPath
+            ? oldPath + ',' + res.data.path
+            : res.data.path;
+          form.setFieldsValue({ cad_path });
+        }
+        setUpLoading(false);
+      });
+    }
+  }
+
+  const handleOk = () => {
+    let audit_list = [];
+    let cc_list = [];
+    approvalProcess?.forEach((item, index) => {
+      let arr = item[0].is_cc === 1 ? cc_list : audit_list;
+
+      if (item[0].type === 'role') arr.push(auditCheck[index]);
+      else if (item[0].type === 'leader')
+        arr.push(
+          ...leaderData.slice(0, item[0].value).map((leader) => leader.ID),
+        );
+      else arr.push(item.map((cur) => cur.value));
+    });
+
+    form.validateFields().then((values) => {
+      if (values.project_id)
+        values.project_name = projectList.find(
+          (item) => (item.value = values.project_id),
+        )?.label;
+      if (values.dir_id) values.dir_name = values.dir_id.join(',');
+      values.dir_id = 0;
+      if (!values.cad_path) values.cad_path = 'test';
+      console.log(values, audit_list);
+      onOk(values, { audit_list: audit_list.flat(), cc_list: cc_list.flat() });
+    });
+  };
+
+  return (
+    <Modal
+      title="新建图纸"
+      width={1200}
+      open={open}
+      confirmLoading={loading}
+      onOk={handleOk}
+      onCancel={handleCancel}
+    >
+      <Row gutter={24}>
+        <Col span={16}>
+          <Form {...layout} name="basic" form={form}>
+            <Form.Item
+              name="name"
+              label="图纸名称:"
+              rules={[{ required: true }]}
+            >
+              <Input />
+            </Form.Item>
+            <Form.Item
+              name="project_id"
+              label="所属项目:"
+              rules={[{ required: true }]}
+            >
+              <Select options={projectList} />
+            </Form.Item>
+            <Form.Item
+              name="dir_id"
+              label="归档目录:"
+              rules={[{ required: true }]}
+            >
+              <Cascader
+                options={dirList}
+                fieldNames={{
+                  label: 'value',
+                  value: 'value',
+                  children: 'children',
+                }}
+              />
+              {/* <Select
+                options={[
+                  {
+                    label: '工艺',
+                    value: 1,
+                  },
+                  {
+                    label: '电气',
+                    value: 2,
+                  },
+                ]}
+              /> */}
+            </Form.Item>
+            <Form.Item
+              name="pic_type"
+              label="是否PID图和平面图"
+              rules={[{ required: true }]}
+            >
+              <Select
+                options={[
+                  {
+                    value: '是',
+                  },
+                  {
+                    value: '否',
+                  },
+                ]}
+              />
+            </Form.Item>
+            <Form.Item
+              name="version"
+              label="版本:"
+              rules={[{ required: true }]}
+            >
+              <Input />
+            </Form.Item>
+            <Form.Item name="cad_path" label="上传:">
+              <Button
+                loading={upLoading}
+                icon={<CloudUploadOutlined />}
+                onClick={dwgUpload}
+              >
+                Upload
+              </Button>
+              {form.getFieldValue('cad_path')}
+              {/* <Upload {...UploadProps}>
+            <Button icon={<CloudUploadOutlined />}>Upload</Button>
+          </Upload> */}
+            </Form.Item>
+            <Form.Item name="doc" label="备注:">
+              <Input.TextArea />
+            </Form.Item>
+          </Form>
+        </Col>
+        <Col span={8}>
+          <ApprovalProcess
+            leaderData={[]}
+            approvalProcess={approvalProcess}
+            onChange={setAuditCheck}
+          />
+        </Col>
+      </Row>
+
+      <input
+        // multiple
+        style={{ display: 'none' }}
+        id="uploadDwg"
+        type="file"
+        onChange={uploadDwg}
+        accept=".dwg, .dxf"
+      />
+    </Modal>
+  );
+};
+export default CreateModal;

+ 3 - 0
src/pages/Cad/components/index.less

@@ -0,0 +1,3 @@
+.modelItem {
+  margin: 0 40px;
+}

+ 4 - 4
src/pages/Cad/detail.js

@@ -15,11 +15,11 @@ const CadDeTail = () => {
     window.ZwCloud2D.ZwEditor.ZwInit(content);
     window.ZwCloud2D.ZwEditor.ZwInit(content);
 
 
     ZwCloud2D.ZwDataProcessor.ZwSetConnectUrl(
     ZwCloud2D.ZwDataProcessor.ZwSetConnectUrl(
-      'http://222.130.26.205:9080',
-      'http://222.130.26.205:5121',
-      'ws://222.130.26.205:5121',
+      'http://47.111.24.13:5121',
+      'http://47.111.24.13:5121',
+      'ws://47.111.24.13:5121',
     );
     );
-    ZwCloud2D.ZwDataProcessor.ZwSetLoadDwg(path);
+    ZwCloud2D.ZwDataProcessor.ZwSetLoadDwg('SDK-TC-001x.dwg');
     window.ZwCloud2D.ZwDataProcessor.ZwLoad();
     window.ZwCloud2D.ZwDataProcessor.ZwLoad();
   }, []);
   }, []);
   return (
   return (

+ 150 - 75
src/pages/Cad/index.js

@@ -1,38 +1,46 @@
 import { useRef, useEffect, useState } from 'react';
 import { useRef, useEffect, useState } from 'react';
 import PageContent from '@/components/PageContent';
 import PageContent from '@/components/PageContent';
-import { queryCadList, queryCreateCad } from '@/services/cad';
+import {
+  queryCadDirList,
+  queryCadList,
+  queryCreateCad,
+  queryProject,
+} from '@/services/cad';
 import { useRequest, useNavigate } from '@umijs/max';
 import { useRequest, useNavigate } from '@umijs/max';
-import { Table, Button, message, Space } from 'antd';
+import { Table, Button, message, Space, Select, Input } from 'antd';
+import CreateModal from './components/CreateModal';
+import { createAduit } from '@/services/boom';
 
 
 const CadDemo = () => {
 const CadDemo = () => {
   let navigate = useNavigate();
   let navigate = useNavigate();
+  const [createLoading, setCreateLoading] = useState(false);
+  const [visible, setVisible] = useState(false);
+  const [params, setParams] = useState({
+    // project_name: '',
+    // name: '',
+    page: 1,
+    page_size: 20,
+  });
+
+  const auditListRef = useRef();
+
   const columns = [
   const columns = [
     {
     {
       title: '名称',
       title: '名称',
       dataIndex: 'name',
       dataIndex: 'name',
       key: 'name',
       key: 'name',
-      align: 'center',
       width: 160,
       width: 160,
     },
     },
     {
     {
-      title: '创建人',
-      dataIndex: 'created_by',
-      key: 'created_by',
-      align: 'center',
+      title: '所属项目',
+      dataIndex: 'project_name',
+      key: 'project_name',
       width: 120,
       width: 120,
     },
     },
-    {
-      title: '创建时间',
-      dataIndex: 'created_on',
-      key: 'created_on',
-      align: 'center',
-      width: 100,
-    },
     {
     {
       title: '状态',
       title: '状态',
       dataIndex: 'status',
       dataIndex: 'status',
       key: 'status',
       key: 'status',
-      align: 'center',
       width: 100,
       width: 100,
       render: (status) => {
       render: (status) => {
         let str = '';
         let str = '';
@@ -56,90 +64,157 @@ const CadDemo = () => {
     },
     },
     {
     {
       title: '操作',
       title: '操作',
-      align: 'center',
       width: '10%',
       width: '10%',
-      render: (record) => (
-        <Space>
-          <a
-            onClick={() =>
-              navigate('/cad/detail', {
-                state: {
-                  path: record.path,
-                },
-              })
-            }
-          >
-            详情
-          </a>
-          <a onClick={() => {}}>提审</a>
-        </Space>
-      ),
+      render: (record) => {
+        return record.canShow ? (
+          <Space>
+            <a
+              onClick={() =>
+                navigate('/cad/detail', {
+                  state: {
+                    path: record.name,
+                  },
+                })
+              }
+            >
+              查看
+            </a>
+          </Space>
+        ) : (
+          ''
+        );
+      },
     },
     },
   ];
   ];
-  const [uploading, setUpLoading] = useState(false);
+
+  const { data: projectList } = useRequest(queryProject, {
+    formatResult: (res) => {
+      return res?.data?.list?.map((item) => {
+        return { label: item.Name, value: item.ID };
+      });
+    },
+  });
+
+  //请求归档目录
+  const { data: dirList } = useRequest(queryCadDirList, {
+    formatResult: (res) => {
+      return res.data;
+      // return res?.data?.list?.map((item) => {
+      //   return { label: item.Name, value: item.ID };
+      // });
+    },
+  });
 
 
   //请求列表
   //请求列表
-  const { data, run, loading } = useRequest(queryCadList);
+  const { data, run, loading } = useRequest(queryCadList, {
+    defaultParams: [params],
+    formatResult: (res) => {
+      res.data?.list?.forEach((item) => {
+        item.children?.forEach((cur) => {
+          cur.name = item.name + cur.version;
+          if (cur.cad_path) {
+            const pathList = cur.cad_path.split(',');
+            cur.children = pathList.map((item) => {
+              return {
+                name: item,
+                canShow: true,
+              };
+            });
+          }
+        });
+      });
+      return res.data?.list;
+    },
+  });
 
 
   //上传
   //上传
-  const { run: runCreate } = useRequest((data) => queryCreateCad(data), {
+  const { run: runCreate } = useRequest(queryCreateCad, {
     manual: true,
     manual: true,
-    onSuccess: () => {
-      run();
-      message.success('上传成功');
-      setUpLoading(false);
+    onSuccess: (data) => {
+      createOARun({
+        ...auditListRef.current,
+        extend_code: data.cad_id + '',
+        extend_type: 2, //2图纸
+      });
     },
     },
   });
   });
 
 
+  //发起OA审批
+  const { run: createOARun } = useRequest(
+    (data) => createAduit({ ...data, flow_id: 67, files: '' }),
+    {
+      manual: true,
+      onSuccess: () => {
+        run();
+        message.success('新建成功');
+        setVisible(false);
+        setCreateLoading(false);
+      },
+    },
+  );
+
   useEffect(() => {
   useEffect(() => {
     ZwCloud2D.ZwDataProcessor.ZwSetConnectUrl(
     ZwCloud2D.ZwDataProcessor.ZwSetConnectUrl(
-      'http://222.130.26.205:9080',
-      'http://222.130.26.205:5121',
-      'ws://222.130.26.205:5121',
+      'http://172.16.69.195:9080', //47.111.24.13
+      'http://172.16.69.195:5121',
+      'ws://172.16.69.195:5121',
     );
     );
   }, []);
   }, []);
 
 
-  function uploadDwg(event) {
-    const selectedFile = event.target.files[0];
-    if (selectedFile) {
-      // ZwCloud2D.ZwEditor.ZwSetLoadingState(true);
-      setUpLoading(true);
-      ZwCloud2D.ZwDataProcessor.uploadDwg(selectedFile).then((res) => {
-        if (res.code == 200) {
-          runCreate({ name: res.data.name, path: res.data.path });
-        }
-        setUpLoading(false);
-      });
-    }
-  }
-  function dwgUpload() {
-    let uploadDwg = document.getElementById('uploadDwg');
-    uploadDwg.click();
-  }
+  const handleCreate = (values, audit_list) => {
+    setCreateLoading(true);
+    auditListRef.current = audit_list;
+    runCreate(values);
+  };
 
 
   return (
   return (
     <PageContent>
     <PageContent>
-      <Button type="primary" onClick={dwgUpload}>
-        上传
-      </Button>
+      <Space>
+        <Button type="primary" onClick={() => setVisible(true)}>
+          新建图纸
+        </Button>
+        <div>
+          项目名称:
+          <Select
+            style={{ width: 130 }}
+            allowClear
+            options={projectList}
+            onChange={(value) => {
+              const project_name = projectList?.find(
+                (item) => item.value == value,
+              )?.label;
+              setParams({ ...params, project_name });
+            }}
+          />
+        </div>
+        <div>
+          图纸名称:
+          <Input
+            allowClear
+            style={{ width: '200px' }}
+            onChange={(e) => {
+              setParams({ ...params, name: e.target.value });
+            }}
+          />
+        </div>
+        <Button type="primary" onClick={() => run(params)}>
+          查询
+        </Button>
+      </Space>
       <Table
       <Table
+        rowKey="id"
         loading={loading}
         loading={loading}
         columns={columns}
         columns={columns}
-        dataSource={data?.list}
+        dataSource={data}
         indentSize={70}
         indentSize={70}
-        // pagination={{
-        //   ...pagination,
-        //   showSizeChanger: false,
-        //   onChange: onPageChange,
-        // }}
       />
       />
-      {/* <div id="container"></div> */}
-      <input
-        style={{ display: 'none' }}
-        id="uploadDwg"
-        type="file"
-        onChange={uploadDwg}
-        accept=".dwg, .dxf"
+      <CreateModal
+        loading={createLoading}
+        dirList={dirList}
+        projectList={projectList}
+        open={visible}
+        onOk={handleCreate}
+        handleCancel={() => setVisible(false)}
       />
       />
     </PageContent>
     </PageContent>
   );
   );

+ 3 - 0
src/pages/FileManagement/index.js

@@ -550,6 +550,9 @@ function FileManagement(props) {
     } else if (node.id == 7) {
     } else if (node.id == 7) {
       //合同归档走合同接口
       //合同归档走合同接口
       runContract(req);
       runContract(req);
+    } else if (node.dir_type == 3) {
+      //图纸文件走 部门文件 接口
+      run({ ...req, dir_id: node.id });
     } else if (node.is_limit) {
     } else if (node.is_limit) {
       //其他受控文件走classify_id
       //其他受控文件走classify_id
       runOA({ ...req, classify_id: node.classify_id });
       runOA({ ...req, classify_id: node.classify_id });

+ 1 - 1
src/pages/Flow/Audit.less

@@ -9,7 +9,7 @@
   align-items: center;
   align-items: center;
   margin-bottom: 20px;
   margin-bottom: 20px;
   :global {
   :global {
-    .ant-btn {
+    .antd5-btn {
       margin-right: 20px;
       margin-right: 20px;
     }
     }
   }
   }

+ 133 - 23
src/pages/Flow/OaAuditDetail.js

@@ -1,37 +1,56 @@
 // 审批详情
 // 审批详情
 import React, { useState, useMemo, useEffect } from 'react';
 import React, { useState, useMemo, useEffect } from 'react';
-import { Steps, Button, Tooltip, message, Spin } from 'antd';
+import { Steps, Button, Tooltip, message, Spin, Upload } from 'antd';
 import { useRequest, useModel, useLocation } from 'umi';
 import { useRequest, useModel, useLocation } from 'umi';
 import AuditModal from './components/AuditModal';
 import AuditModal from './components/AuditModal';
+import AddCCModal from './components/AddCCModal';
 import FormAndFilesNode from './components/FormAndFilesNode';
 import FormAndFilesNode from './components/FormAndFilesNode';
-import { queryAuditDetail, updateAuditList } from '@/services/boom';
+import {
+  queryAuditDetail,
+  updateAuditList,
+  updateCCList,
+  uploadAttachment,
+} from '@/services/boom';
 import { queryGetContractList } from '@/services/contract';
 import { queryGetContractList } from '@/services/contract';
 import PageContent from '@/components/PageContent';
 import PageContent from '@/components/PageContent';
 import SignModal from './components/SignModal';
 import SignModal from './components/SignModal';
 import ContractDetail from '../ContractManager/detail';
 import ContractDetail from '../ContractManager/detail';
 import { Type } from '../Profile';
 import { Type } from '../Profile';
 import { queryContractDetail } from '../../services/contract';
 import { queryContractDetail } from '../../services/contract';
+import { queryCadInfo } from '../../services/cad';
+import CadOADetail from '../Cad/components/CadOADetail';
 
 
 function OaAuditDetail(props) {
 function OaAuditDetail(props) {
   const { initialState } = useModel('@@initialState');
   const { initialState } = useModel('@@initialState');
   const user = initialState?.user || {};
   const user = initialState?.user || {};
+  const { userList, run: runUserList } = useModel('userList');
   const [auditVisible, setAuditVisible] = useState(false);
   const [auditVisible, setAuditVisible] = useState(false);
   const [visible, setVisible] = useState(false);
   const [visible, setVisible] = useState(false);
+  const [ccVisible, setCCVisible] = useState(false);
 
 
   const location = useLocation();
   const location = useLocation();
   const queryParams = new URLSearchParams(location.search);
   const queryParams = new URLSearchParams(location.search);
   // 使用queryParams来获取特定查询参数
   // 使用queryParams来获取特定查询参数
   const id = queryParams.get('id');
   const id = queryParams.get('id');
   const code = queryParams.get('code');
   const code = queryParams.get('code');
+  const type = queryParams.get('type') * 1 || Type.OA;
   const token = queryParams.get('JWT-TOKEN');
   const token = queryParams.get('JWT-TOKEN');
   if (!localStorage['JWT-TOKEN']) {
   if (!localStorage['JWT-TOKEN']) {
     localStorage['JWT-TOKEN'] = token;
     localStorage['JWT-TOKEN'] = token;
   }
   }
 
 
-  const type = code ? Type.CON : Type.OA;
+  // const type = code ? Type.CON : Type.OA;
 
 
   useEffect(() => {
   useEffect(() => {
-    if (type == Type.CON) runCon({ code });
+    runUserList();
+  }, []);
+
+  useEffect(() => {
+    if (type == Type.CON) {
+      runCon({ code });
+    } else if (type == Type.CAD) {
+      runCad({ cad_id: code * 1 });
+    }
   }, [type]);
   }, [type]);
 
 
   const { data, loading, refresh } = useRequest(queryAuditDetail, {
   const { data, loading, refresh } = useRequest(queryAuditDetail, {
@@ -41,13 +60,13 @@ function OaAuditDetail(props) {
     current_seq,
     current_seq,
     form,
     form,
     OaAuditList,
     OaAuditList,
+    OaCcs,
     Files = [],
     Files = [],
     audit_status,
     audit_status,
     AuditorInfo,
     AuditorInfo,
   } = data || {};
   } = data || {};
   // if (OaAuditList) console.log(JSON.stringify(OaAuditList));
   // if (OaAuditList) console.log(JSON.stringify(OaAuditList));
 
 
-  //请求列表
   const {
   const {
     data: conData,
     data: conData,
     run: runCon,
     run: runCon,
@@ -57,18 +76,31 @@ function OaAuditDetail(props) {
     formatResult: (res) => {
     formatResult: (res) => {
       return res?.data?.detail;
       return res?.data?.detail;
     },
     },
-    onSuccess: (res) => {},
   });
   });
-  // console.log(conData);
 
 
-  const getDescription = (node) => {
+  const {
+    data: cadData,
+    run: runCad,
+    loading: loadingCad,
+  } = useRequest(queryCadInfo, {
+    manual: true,
+    formatResult: (res) => {
+      console.log(res);
+      return res?.data?.info;
+    },
+  });
+
+  const getDescription = (node, idx) => {
     let str = node?.AuditRoleInfo
     let str = node?.AuditRoleInfo
       ? `审批人:${node?.AuditRoleInfo.Name || '-'}`
       ? `审批人:${node?.AuditRoleInfo.Name || '-'}`
       : `审批人:${node?.AuditorUser.CName || '-'}`;
       : `审批人:${node?.AuditorUser.CName || '-'}`;
-    if (node.desc) {
-      return (
-        <div>
-          {str}
+
+    //最后一个审批节点显示抄送人信息
+    const showCCList = idx == OaAuditList?.length - 1 && OaCcs.length > 0;
+    return (
+      <div>
+        {str}
+        {node.desc && (
           <div>
           <div>
             <Tooltip title={node.desc}>
             <Tooltip title={node.desc}>
               <span style={{ color: '#1A73E8', textDecoration: 'undeline' }}>
               <span style={{ color: '#1A73E8', textDecoration: 'undeline' }}>
@@ -76,10 +108,15 @@ function OaAuditDetail(props) {
               </span>
               </span>
             </Tooltip>
             </Tooltip>
           </div>
           </div>
-        </div>
-      );
-    }
-    return str;
+        )}
+        {showCCList && (
+          <div>
+            抄送人:
+            {OaCcs?.map((item) => item.User?.CName).join(',')}
+          </div>
+        )}
+      </div>
+    );
   };
   };
   const updateRes = useRequest(
   const updateRes = useRequest(
     (values) => {
     (values) => {
@@ -107,6 +144,49 @@ function OaAuditDetail(props) {
     },
     },
   );
   );
 
 
+  //加抄送人
+  const { run: runCC, loading: loadingCC } = useRequest(
+    (ids) =>
+      updateCCList({
+        oa_id: Number(id),
+        audit_list: ids,
+      }),
+    {
+      manual: true,
+      onSuccess() {
+        message.success('添加抄送人成功');
+        setCCVisible(false);
+        refresh();
+      },
+    },
+  );
+
+  //上传附件
+  const { run: runAttach, loading: loadingAttach } = useRequest(
+    uploadAttachment,
+    {
+      manual: true,
+      onSuccess() {
+        message.success('上传成功');
+      },
+    },
+  );
+
+  const handleUploadClick = () => {};
+  const UploadProps = {
+    showUploadList: false,
+    action: `/api/v1/oa/attachment/${id}`,
+    headers: {
+      'JWT-TOKEN': localStorage.getItem('JWT-TOKEN'),
+    },
+    onChange({ file, fileList }) {
+      if (file.status !== 'uploading') {
+        console.log(fileList);
+        message.success('上传成功');
+      }
+    },
+  };
+
   const btns = useMemo(() => {
   const btns = useMemo(() => {
     if (!user || !data) return;
     if (!user || !data) return;
     if (
     if (
@@ -129,27 +209,56 @@ function OaAuditDetail(props) {
         <Button key={3} onClick={() => setVisible(true)}>
         <Button key={3} onClick={() => setVisible(true)}>
           加签
           加签
         </Button>,
         </Button>,
+        <Button key={4} onClick={() => setCCVisible(true)}>
+          加抄送人
+        </Button>,
+        <Upload {...UploadProps}>
+          <Button>上传附件</Button>
+        </Upload>,
+        // <Button key={5} onClick={handleUploadClick}>
+        //   上传附件
+        // </Button>,
       ];
       ];
     }
     }
     return [];
     return [];
   }, [user, data]);
   }, [user, data]);
 
 
+  const renderDetail = () => {
+    let content = '';
+    switch (type) {
+      case Type.CAD:
+        content = <CadOADetail data={cadData} fileList={Files} />;
+        break;
+      case Type.CON:
+        content = <ContractDetail data={conData} />;
+        break;
+      default:
+        content = <FormAndFilesNode formData={form} fileList={Files} />;
+    }
+    return content;
+  };
+
   return (
   return (
     <PageContent extra={btns} loading={loading && conLoading}>
     <PageContent extra={btns} loading={loading && conLoading}>
       <Steps
       <Steps
         style={{ marginBottom: 20 }}
         style={{ marginBottom: 20 }}
         current={audit_status == 3 ? OaAuditList?.length : current_seq - 1}
         current={audit_status == 3 ? OaAuditList?.length : current_seq - 1}
         status={audit_status == 2 ? 'error' : 'process'}
         status={audit_status == 2 ? 'error' : 'process'}
-        items={OaAuditList?.map((item) => ({
+        items={OaAuditList?.map((item, idx) => ({
           title: item.seq_name,
           title: item.seq_name,
-          description: getDescription(item),
+          description: getDescription(item, idx),
         }))}
         }))}
       ></Steps>
       ></Steps>
-      {type == Type.OA ? (
-        <FormAndFilesNode formData={form} fileList={Files} />
-      ) : (
-        <ContractDetail data={conData} />
-      )}
+
+      {renderDetail()}
+
+      <AddCCModal
+        userList={userList}
+        visible={ccVisible}
+        onCancel={() => setCCVisible(false)}
+        onCreate={runCC}
+        loading={loadingCC}
+      />
 
 
       <AuditModal
       <AuditModal
         id={id}
         id={id}
@@ -158,6 +267,7 @@ function OaAuditDetail(props) {
         onOk={refresh}
         onOk={refresh}
       />
       />
       <SignModal
       <SignModal
+        userList={userList}
         visible={visible}
         visible={visible}
         onCancel={() => setVisible(false)}
         onCancel={() => setVisible(false)}
         onCreate={(values) => updateRes.run(values)}
         onCreate={(values) => updateRes.run(values)}

+ 47 - 0
src/pages/Flow/components/AddCCModal.js

@@ -0,0 +1,47 @@
+import { useState } from 'react';
+import { Modal, Form, Radio, Select, Button, message } from 'antd';
+import { useModel, useRequest } from '@umijs/max';
+
+const { Option } = Select;
+
+const AddCCModal = ({ userList, visible, onCancel, onCreate, loading }) => {
+  const [ids, setIds] = useState([]);
+
+  const handleOk = () => {
+    if (ids.length == 0) message.error('请选择抄送人');
+    onCreate(ids);
+  };
+
+  return (
+    <Modal
+      open={visible}
+      title="添加抄送人"
+      onCancel={onCancel}
+      onOk={handleOk}
+      destroyOnClose
+      confirmLoading={loading}
+    >
+      <div>
+        抄送人:
+        <Select
+          style={{ width: 200 }}
+          mode="multiple"
+          showSearch
+          filterOption={(input, option) =>
+            (option.children ?? '').toLowerCase().includes(input.toLowerCase())
+          }
+          placeholder="请选择抄送人"
+          onChange={(values) => setIds(values)}
+        >
+          {userList?.map((item) => (
+            <Option value={item.ID} key={item.ID}>
+              {item.CName}
+            </Option>
+          ))}
+        </Select>
+      </div>
+    </Modal>
+  );
+};
+
+export default AddCCModal;

+ 4 - 3
src/pages/Flow/components/SignModal.js

@@ -4,9 +4,8 @@ import { useModel, useRequest } from '@umijs/max';
 
 
 const { Option } = Select;
 const { Option } = Select;
 
 
-const SignModal = ({ visible, onCancel, onCreate, loading }) => {
+const SignModal = ({ userList, visible, onCancel, onCreate, loading }) => {
   const [form] = Form.useForm();
   const [form] = Form.useForm();
-  const { userList } = useModel('userList');
 
 
   const handleOk = () => {
   const handleOk = () => {
     form.validateFields().then((values) => {
     form.validateFields().then((values) => {
@@ -43,7 +42,9 @@ const SignModal = ({ visible, onCancel, onCreate, loading }) => {
           <Select
           <Select
             showSearch
             showSearch
             filterOption={(input, option) =>
             filterOption={(input, option) =>
-              (option.children ?? '').toLowerCase().includes(input.toLowerCase())
+              (option.children ?? '')
+                .toLowerCase()
+                .includes(input.toLowerCase())
             }
             }
             placeholder="请选择审批人"
             placeholder="请选择审批人"
           >
           >

+ 11 - 11
src/pages/Home/index.js

@@ -106,15 +106,15 @@ function HomePage(props) {
       },
       },
       Icon: require('@/assets/UnityMenu/userCenter.png'),
       Icon: require('@/assets/UnityMenu/userCenter.png'),
     },
     },
-    // {
-    //   id: 10,
-    //   name: 'cad管理',
-    //   active: true,
-    //   click: () => {
-    //     navigate('/cad');
-    //   },
-    //   Icon: require('@/assets/UnityMenu/cad.png'),
-    // },
+    {
+      id: 11,
+      name: 'cad管理',
+      active: true,
+      click: () => {
+        navigate('/cad');
+      },
+      Icon: require('@/assets/UnityMenu/cad.png'),
+    },
     {
     {
       id: 10,
       id: 10,
       name: 'Scada功能',
       name: 'Scada功能',
@@ -139,8 +139,8 @@ function MenuContent({ list }) {
   const row = useMemo(() => {
   const row = useMemo(() => {
     const result = [];
     const result = [];
     const rightList = list.filter((item) => item.permission);
     const rightList = list.filter((item) => item.permission);
-    for (let i = 0; i < list.length; i += 5) {
-      result.push(rightList.slice(i, i + 5));
+    for (let i = 0; i < list.length; i += 6) {
+      result.push(rightList.slice(i, i + 6));
     }
     }
     return result;
     return result;
   }, [list]);
   }, [list]);

+ 1 - 1
src/pages/Home/index.less

@@ -15,7 +15,7 @@
 
 
   // align-items: flex-start;
   // align-items: flex-start;
   :global {
   :global {
-    .ant-popover-inner {
+    .antd5-popover-inner {
       background: #0d1a2b;
       background: #0d1a2b;
     }
     }
   }
   }

+ 9 - 2
src/pages/Profile/index.js

@@ -20,6 +20,7 @@ import { ExclamationCircleOutlined } from '@ant-design/icons';
 export const Type = {
 export const Type = {
   OA: 1,
   OA: 1,
   CON: 2,
   CON: 2,
+  CAD: 3,
 };
 };
 
 
 function profile(props) {
 function profile(props) {
@@ -84,8 +85,14 @@ function profile(props) {
                 <a
                 <a
                   style={{ color: '#4096ff' }}
                   style={{ color: '#4096ff' }}
                   onClick={() => {
                   onClick={() => {
-                    if (record.extend_code) {
-                      navigate(`/profile/detail?id=${record.id}&code=${record.extend_code}`);
+                    if (record.extend_type == 2) {
+                      navigate(
+                        `/profile/detail?id=${record.id}&code=${record.extend_code}&type=${Type.CAD}`,
+                      );
+                    } else if (record.extend_code) {
+                      navigate(
+                        `/profile/detail?id=${record.id}&code=${record.extend_code}&type=${Type.CON}`,
+                      );
                     } else {
                     } else {
                       navigate(`/profile/detail?id=${record.id}`);
                       navigate(`/profile/detail?id=${record.id}`);
                     }
                     }

+ 17 - 0
src/services/boom.js

@@ -261,3 +261,20 @@ export async function updateAuditList(data, isAfter) {
   }
   }
   return res;
   return res;
 }
 }
+//添加抄送人
+export async function updateCCList(data) {
+  let res = await request(`/api/v1/oa/submit/add-cc`, {
+    method: 'POST',
+    data,
+  });
+  return res;
+}
+
+//审批时上传附加
+export async function uploadAttachment(data) {
+  let res = await request(`/api/v1/oa/attachment/184`, {
+    method: 'POST',
+    data,
+  });
+  return res;
+}

+ 27 - 2
src/services/cad.js

@@ -1,10 +1,35 @@
 import { request } from 'umi';
 import { request } from 'umi';
-export const queryCadList = async () => {
-  return await request('/api/contract/v1/cad');
+export const queryCadList = async (data) => {
+  return await request('/api/archive/v1/cad/list', {
+    method: 'POST',
+    data,
+  });
 };
 };
 export async function queryCreateCad(data) {
 export async function queryCreateCad(data) {
+  return request(`/api/archive/v1/cad/create`, {
+    method: 'POST',
+    data,
+  });
+}
+export const queryProject = async () => {
+  return await request('/api/v2/project');
+};
+
+export async function queryCreateCadOld(data) {
   return request(`/api/contract/v1/cad`, {
   return request(`/api/contract/v1/cad`, {
     method: 'POST',
     method: 'POST',
     data,
     data,
   });
   });
 }
 }
+export async function queryCadInfo(data) {
+  return request(`/api/archive/v1/cad/info`, {
+    method: 'POST',
+    data,
+  });
+}
+export async function queryCadDirList(data) {
+  return request(`/api/archive/v1/cad/dir-list`, {
+    method: 'POST',
+    data,
+  });
+}