From ab493128b646ede67a2bfa2e16c966eb4e5f2d94 Mon Sep 17 00:00:00 2001
From: gaoshp <291585735@qq.com>
Date: 星期四, 13 六月 2024 23:19:00 +0800
Subject: [PATCH] 传输文件

---
 src/views/dnc/transport/index.vue |  288 ++++++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 271 insertions(+), 17 deletions(-)

diff --git a/src/views/dnc/transport/index.vue b/src/views/dnc/transport/index.vue
index 76a4cbb..040716b 100644
--- a/src/views/dnc/transport/index.vue
+++ b/src/views/dnc/transport/index.vue
@@ -1,7 +1,7 @@
 <!--
  * @Date: 2024-05-26 21:59:53
  * @LastEditors: Sneed
- * @LastEditTime: 2024-05-26 22:11:25
+ * @LastEditTime: 2024-06-13 23:17:58
  * @FilePath: /belleson-frontend/Users/mache/Documents/demo/cps-web/src/views/dnc/transport/index.vue
 -->
 <template>
@@ -13,21 +13,49 @@
                         <el-col :span="8" :gutter="20">
                             <el-tabs v-model="activeName" type="card" class="demo-tabs" @tab-click="handleClick">
                                 <el-tab-pane label="鎴戠殑鏂囨。" name="1">
-
+                                    <el-tree default-expand-all ref="tree" node-key="id" :data="treeData" :props="{
+                                        label: 'name',
+                                    }" @node-click="nodeClick" highlight-current :current-node-key="selectNode.id">
+                                        <template #default="{ node, data }">
+                                            <span :class="data.isGroup ? 'active' : ''" class="custom-tree-node">
+                                                <span>{{
+                                                    node.label || data.code }}</span>
+                                            </span>
+                                        </template>
+                                    </el-tree>
                                 </el-tab-pane>
                                 <el-tab-pane label="宸ヨ壓绠$悊" name="2">
-
+                                    <el-tree default-expand-all ref="tree" node-key="id" :data="treeData1" :props="{
+                                        label: (data, node) => {
+                                            return data.name || data.artName
+                                        },
+                                    }" @node-click="nodeClick" highlight-current :current-node-key="selectNode.id">
+                                        <template #default="{ node, data }">
+                                            <span :class="data.isGroup ? 'active' : ''" class="custom-tree-node">
+                                                <span>{{
+                                                    node.label || data.code }}</span>
+                                            </span>
+                                        </template>
+                                    </el-tree>
                                 </el-tab-pane>
                             </el-tabs>
                         </el-col>
                         <el-col :span="16">
-                            <el-table :data="tableData" style="width: 100%">
+                            <el-table :data="tableData" style="width: 100%" @selection-change="onSelectionChange">
                                 <el-table-column type="selection" width="50"></el-table-column>
-                                <el-table-column label="鏂囦欢鍚嶇О" prop="" width=""></el-table-column>
-                                <el-table-column label="婧愯矾寰�" prop="" width=""></el-table-column>
-                                <el-table-column label="澶у皬" prop="" width=""></el-table-column>
-                                <el-table-column label="鏂囦欢绫诲瀷" prop="" width=""></el-table-column>
-                                <el-table-column label="鏇存柊鏃堕棿" prop="" width=""></el-table-column>
+                                <el-table-column label="鏂囦欢鍚嶇О" prop="filename" width="">
+                                    <template #default="scope">
+                                        {{ scope.row.filename || scope.row.name }}
+                                    </template>
+                                </el-table-column>
+                                <el-table-column label="婧愯矾寰�" prop="sourcePath" width="">
+                                    <template #default="scope">
+                                        {{ scope.row.sourcePath || scope.row.allPathName }}
+                                    </template>
+                                </el-table-column>
+                                <el-table-column label="澶у皬" prop="contentLength" width=""></el-table-column>
+                                <el-table-column label="鏂囦欢绫诲瀷" prop="suffix" width=""></el-table-column>
+                                <el-table-column label="鏇存柊鏃堕棿" prop="updateTime" width=""></el-table-column>
                             </el-table>
                         </el-col>
                     </el-row>
@@ -35,9 +63,9 @@
                 <div class="main-container-item">
                     <el-row>
                         <el-col :span="8" :gutter="20">
-                            <el-tabs v-model="activeName" type="card" class="demo-tabs" @tab-click="handleClick">
+                            <el-tabs v-model="activeName1" type="card" class="demo-tabs" @tab-click="handleClick">
                                 <el-tab-pane label="浠ュお缃�" name="1">
-
+                                    <MYTree v-model="treeChecked"></MYTree>
                                 </el-tab-pane>
                                 <el-tab-pane label="鍐呴儴瀛樺偍" name="2">
 
@@ -46,30 +74,255 @@
                         </el-col>
                         <el-col :span="8">
                             <h3>绋嬪簭</h3>
-                            <el-table :data="tableData" style="width: 100%">
+                            <el-button type="primary" @click="copy">浼犺緭鑷冲綋鍓嶇洰鏍�</el-button>
+                            <!-- <el-button type="primary" @click="copy1">涓婁紶鑷充笂鏂硅矾寰�</el-button> -->
+                            <el-table :data="list1" style="width: 100%">
                                 <el-table-column type="selection" width="50"></el-table-column>
-                                <el-table-column label="鏂囦欢鍚嶇О" prop="" width=""></el-table-column>
-                                <el-table-column label="瀛樺偍绌洪棿" prop="" width=""></el-table-column>
+                                <el-table-column label="鏂囦欢鍚嶇О" prop="filename" width=""></el-table-column>
+                                <el-table-column label="鐗堟湰" prop="versionDesc" width=""></el-table-column>
+                                <el-table-column label="鏂囦欢浣嶇疆" prop="fixSpaceLocation" width=""></el-table-column>
+                                <el-table-column label="澶у皬" prop="contentLength" width=""></el-table-column>
                             </el-table>
                         </el-col>
                         <el-col :span="8">
                             <h3>鏂囦欢</h3>
-                            <el-table :data="tableData" style="width: 100%">
+                            <el-button type="primary" @click="copy3">浼犺緭鑷冲綋鍓嶇洰鏍�</el-button>
+                            <!-- <el-button type="primary">涓婁紶鑷充笂鏂硅矾寰�</el-button> -->
+                            <el-table :data="list2" style="width: 100%">
                                 <el-table-column type="selection" width="50"></el-table-column>
-                                <el-table-column label="鏂囦欢鍚嶇О" prop="" width=""></el-table-column>
-                                <el-table-column label="瀛樺偍绌洪棿" prop="" width=""></el-table-column>
+                                <el-table-column label="鏂囦欢鍚嶇О" prop="filename" width=""></el-table-column>
+                                <el-table-column label="鐗堟湰" prop="versionDesc" width=""></el-table-column>
+                                <el-table-column label="鏂囦欢浣嶇疆" prop="fixSpaceLocation" width=""></el-table-column>
+                                <el-table-column label="澶у皬" prop="contentLength" width=""></el-table-column>
                             </el-table>
                         </el-col>
                     </el-row>
                 </div>
             </div>
         </el-card>
+        <scDialog v-model="visible">
+            <scForm ref="form" :config="config" :rules="rules" v-model="form" @submit="submit">
+            </scForm>
+        </scDialog>
     </el-main>
 </template>
 
 <script>
+import MYTree from '@/views/mdc/MYTree.vue'
 export default {
+    components: {
+        MYTree,
+    },
+    computed: {
+        list1() {
+            return this.list.filter(v => v.fileType == 1)
+        },
+        list2() {
+            return this.list.filter(v => v.fileType == 2)
+        }
+    },
+    data() {
+        return {
+            activeName: '1',
+            activeName1: '1',
+            selectNode: {},
+            treeData: [],
+            treeData1: [],
+            tableData: [],
+            treeChecked: {},
+            list: [],
+            workTreeData: [],
+            config: {
+                labelWidth: 120,
+                formItems: [
+                    {
+                        component: 'el-tree-select',
+                        label: '鏂囦欢浣嶇疆',
+                        name: 'storageSpaceId',
+                        options: {
+                            multiple: false,
+                            data: [],
+                            hidecheckbox: true,
+                            props: {
+                                label: 'name'
+                            },
+                            checkStrictly: true
+                        }
+                    }
+                ]
+            },
+            visible: false,
+            form: {},
+            rules: {
+                name: [
+                    { required: true, message: '璇疯緭鍏ュ鍚�' }
+                ]
+            },
+            selection: [],
+            fileType: 1,
+        }
+    },
+    watch: {
+        activeName() {
+            this.selectNode = {}
+            this.selection = []
+        },
+        'selectNode.id'(val) {
+            console.log(val, '>>>>>>>')
+            if (val !== undefined && val !== '')
+                if (this.activeName === '1') {
+                    this.$HTTP.get(`/api/blade-dnc/folder?parent=${val}`).then(res => {
+                        if (res.success) {
+                            this.tableData = res.data.fileList
+                        } else {
+                            this.tableData = []
+                        }
+                    }).catch(err => {
+                        this.tableData = []
+                    })
+                } else {
+                    this.$HTTP.get(`/api/blade-dnc/dnc-art-file/list?artBagId=${val}`).then(res => {
+                        if (res.success) {
+                            this.tableData = res.data
+                        } else {
+                            this.tableData = []
+                        }
+                    }).catch(err => {
+                        this.tableData = []
+                    })
+                }
+        },
+        treeChecked(val) {
+            if (val?.length > 0) {
+                this.getFileList(val?.[0])
+                this.$HTTP.get(`/api/blade-dnc/dnc-fixed-space/direct-loading-space-tree?workstationId=${val?.[0]}`).then(res => {
+                    if (res.success) {
+                        this.workTreeData = this.formatData(res.data)
+                        console.log(this.workTreeData)
+                    } else {
+                        this.workTreeData = []
+                    }
+                }).catch(err => {
+                    this.workTreeData = []
+                })
+            }
+            console.log(val)
+        }
+    },
+    created() {
+        this.init()
+    },
+    methods: {
+        formatData(data, current) {
+            let newData = []
+            if (!current) {
+                newData = data.filter(item => item.parentId == 0).map(v => {
+                    v.children = this.formatData(data, v).sort((a, b) => {
+                        return b.sort - a.sort
+                    })
+                    return v
+                })
+            } else {
+                let res = data.filter(v => v.parentId === current.id)
+                res = res.map(item => {
+                    item.children = this.formatData(data, item).sort((a, b) => {
+                        return b.sort - a.sort
+                    })
+                    return item
+                })
+                return res
+            }
+            return newData
+        },
+        init() {
+            this.selectNode = {
+                id: ''
+            }
+            this.$HTTP.get(`/api/blade-dnc/folder/folder-tree`).then(res => {
+                this.treeData = [{
+                    group: true,
+                    id: 0,
+                    name: '鎴戠殑鏂囨。',
+                    children: res.data
+                }]
+                // this.selectNode = {
+                //     group: true,
+                //     id: 0,
+                //     name: '鎴戠殑鏂囨。',
+                // }
+            })
+            this.$HTTP.get(`/api/blade-dnc/dnc-process-catalogue/art-tree`).then(res => {
+                this.treeData1 = res.data
+            })
+        },
+        nodeClick(node) {
+            this.selectNode = node
+        },
+        onSelectionChange(selection) {
+            this.selection = selection
+        },
+        getFileList(workstationId) {
+            this.$HTTP.post(`/api/blade-dnc/transfer-directory/fileList`, {
+                fileLocations: [2],
+                workstationId
+            }).then(res => {
+                if (res.success) {
 
+                    this.list = res.data
+                } else {
+                    this.list = []
+                }
+            }).catch(err => {
+                this.list = []
+            })
+        },
+        copy() {
+            this.fileType = 1
+            this.visible = true
+            this.config.formItems[0].options.data = this.workTreeData
+        },
+        copy3() {
+            this.fileType = 2
+            this.visible = true
+            this.config.formItems[0].options.data = this.workTreeData
+        },
+        submit() {
+            console.log(this.form)
+            let data = {
+                workstationDirectoryFileVOList: this.selection.map(v => {
+                    return {
+                        contentLength: v.contentLength,
+                        contentMd5: v.contentMd5,
+                        contentType: v.contentType,
+                        fileId: v.id,
+                        fileSource: v.fileType,
+                        fileType: this.fileType,
+                        filename: v.filename || v.name,
+                        lastModified: v.lastModified || new Date().getTime(),
+                        link: v.link,
+                        objectKey: v.objectKey,
+                        originalFilename: v.originalFilename,
+                        originalFilename: v.filename || v.name,
+                        storageSpace: 1,
+                        storageSpaceId: this.form.storageSpaceId,
+                        suffix: v.suffix,
+                        workstationId: '',
+                        workstationName: ''
+                    }
+                }),
+                workstationIds: this.treeChecked
+            }
+            this.$HTTP.post(`/api/blade-dnc/transfer-directory/duplicate-file`, data).then(res => {
+                if (res.success) {
+                    this.$HTTP.post(`/api/blade-dnc/transfer-directory/file`, data).then(res => {
+                        this.visible = false
+                        this.getFileList(this.treeChecked?.[0])
+                    })
+
+                }
+            })
+        }
+    },
 }
 </script>
 
@@ -80,6 +333,7 @@
     height: 100%;
 
     &-item {
+        overflow: auto;
         height: 50%;
         flex: 0 0 auto;
     }

--
Gitblit v1.9.3