From fcbb4059f11d1e2b320d581bf6f960d9965142c6 Mon Sep 17 00:00:00 2001
From: pjb <123456>
Date: 星期二, 08 七月 2025 08:58:18 +0800
Subject: [PATCH] Merge branch 'ycds-wms-dev' of http://47.97.1.152:5880/r/zy-asrs-master into ycds-wms-dev

---
 zy-asrs-admin/src/components/orderDetl/edit.vue |  701 +++++++++++++++++++++++++++++----------------------------
 1 files changed, 356 insertions(+), 345 deletions(-)

diff --git a/zy-asrs-admin/src/components/orderDetl/edit.vue b/zy-asrs-admin/src/components/orderDetl/edit.vue
index 291aafc..2b23c19 100644
--- a/zy-asrs-admin/src/components/orderDetl/edit.vue
+++ b/zy-asrs-admin/src/components/orderDetl/edit.vue
@@ -1,345 +1,356 @@
-<script setup>
-import { getCurrentInstance, ref, watch, reactive } from 'vue';
-import { useRouter } from "vue-router";
-import { get, post, postForm } from '@/utils/request.js'
-import { message, Modal } from 'ant-design-vue';
-import { logout } from '@/config.js';
-import { formatMessage } from '@/utils/localeUtils.js';
-import useTableSearch from '@/utils/tableUtils.jsx';
-import { debounce } from 'lodash-es';
-const context = getCurrentInstance()?.appContext.config.globalProperties;
-
-const router = useRouter();
-
-const TABLE_KEY = 'table-locDetl';
-
-let tableData = ref([]);
-let deleteDetlId = ref([]);
-let orderId = ref(null);
-let isAdd = ref(false);
-getColumns();
-
-const {
-    getColumnSearchProps,
-} = useTableSearch();
-
-const state = reactive({
-    selectedRowKeys: [],
-    loading: false,
-    columns: [],
-});
-
-let defaultColumns = [
-    {
-        title: '#',
-        dataIndex: '_id',
-        width: 60,
-        ellipsis: true,
-    },
-    {
-        title: formatMessage('db.man_loc_detl.matnr', '鍟嗗搧缂栧彿'),
-        dataIndex: 'matnr',
-        width: 140,
-        ellipsis: true,
-    },
-    {
-        title: formatMessage('db.man_loc_detl.maktx', '鍟嗗搧鍚嶇О'),
-        dataIndex: 'maktx',
-        width: 140,
-        ellipsis: true,
-    },
-    {
-        title: formatMessage('db.man_loc_detl.batch', '鎵瑰彿'),
-        dataIndex: 'batch',
-        width: 140,
-        ellipsis: true,
-        editable: true,
-    },
-    {
-        title: formatMessage('db.man_loc_detl.anfme', '鏁伴噺'),
-        dataIndex: 'anfme',
-        width: 140,
-        ellipsis: true,
-        editable: true,
-    },
-    // {
-    //     title: formatMessage('db.man_loc_detl.qty', '宸插畬鎴愭暟閲�'),
-    //     dataIndex: 'qty',
-    //     width: 140,
-    //     ellipsis: true,
-    //     editable: true,
-    // },
-    // {
-    //     title: formatMessage('db.man_loc_detl.workQty', '浣滀笟涓暟閲�'),
-    //     dataIndex: 'workQty',
-    //     width: 140,
-    //     ellipsis: true,
-    //     editable: true,
-    // },
-    // {
-    //     title: formatMessage('db.man_loc_detl.memo', '澶囨敞'),
-    //     dataIndex: 'memo',
-    //     width: 140,
-    //     ellipsis: true,
-    //     editable: true,
-    // },
-];
-
-const fieldList = [];
-//鍔犺浇鎵╁睍瀛楁
-async function getColumns() {
-    let fieldResp = await post('/api/matField/list', {
-        fieldType: 1
-    })
-    let fieldResult = fieldResp.data;
-    let tmp = defaultColumns;
-    if (fieldResult.code == 200) {
-        let data = fieldResult.data;
-
-        if (!isAdd.value) {
-            tmp.push({
-                title: formatMessage('db.man_loc_detl.qty', '宸插畬鎴愭暟閲�'),
-                dataIndex: 'qty',
-                width: 140,
-                ellipsis: true,
-                editable: true,
-            })
-
-            tmp.push({
-                title: formatMessage('db.man_loc_detl.workQty', '浣滀笟涓暟閲�'),
-                dataIndex: 'workQty',
-                width: 140,
-                ellipsis: true,
-                editable: true,
-            })
-        }
-
-        data.forEach((item) => {
-            tmp.push({
-                title: formatMessage(item.language, item.describe),
-                name: item.name,
-                dataIndex: item.name,
-                key: item.name,
-                width: 140,
-                editable: true,
-            })
-
-            fieldList.push(item.name);
-        })
-
-        tmp.push({
-            title: formatMessage('db.man_loc_detl.memo', '澶囨敞'),
-            dataIndex: 'memo',
-            width: 140,
-            ellipsis: true,
-            editable: true,
-        })
-
-        tmp.push({
-            title: formatMessage('common.operation', '鎿嶄綔'),
-            name: 'oper',
-            dataIndex: 'oper',
-            key: 'oper',
-            width: 140,
-        })
-
-        state.columns = tmp;
-    } else if (result.code === 401) {
-        message.error(result.msg);
-        logout()
-    } else {
-        message.error(result.msg);
-    }
-}
-
-const openAddDetl = ref(false);
-const matChecked = ref([]);
-const matQueryList = ref(null);
-const matFetching = ref(false);
-const matSelectList = ref([]);
-const addDetl = () => {
-    openAddDetl.value = true;
-}
-
-const handleAddDetlOk = () => {
-    let origin = tableData.value;
-    let index = origin.length + 1;
-    matSelectList.value.forEach((item) => {
-        let data = {
-            _id: index++,
-            matnr: item.data.matnr,
-            maktx: item.data.maktx,
-            batch: '',
-            anfme: 0,
-            qty: 0,
-            workQty: 0,
-            memo: ''
-        };
-        fieldList.forEach((field) => {
-            data[field] = '';
-        })
-        origin.push(data)
-    })
-    tableData.value = origin;
-
-    openAddDetl.value = false;
-    matSelectList.value = [];
-    matChecked.value = [];
-}
-
-const handleAddDetlCancel = () => {
-    matSelectList.value = [];
-    matChecked.value = [];
-}
-
-const handleSearch = debounce(val => {
-    matQuery(val);
-}, 600)
-
-const handleSelect = (value, option) => {
-    let flag = true;
-    matSelectList.value.forEach((item) => {
-        if (item.value == value) {
-            flag = false;
-        }
-    })
-
-    if (flag) {
-        matSelectList.value.push(option)
-    }
-}
-
-const handleDeselect = (value, option) => {
-    let tmp = [];
-    matSelectList.value.forEach((item) => {
-        if (item.value != value) {
-            tmp.push(item);
-        }
-    })
-
-    matSelectList.value = tmp;
-}
-
-matQuery(null);
-function matQuery(condition) {
-    matFetching.value = true;
-    post('/api/mat/page', {
-        current: 1,
-        pageSize: 10,
-        condition: condition
-    }).then((resp) => {
-        let result = resp.data;
-        let tmp = []
-        result.data.records.forEach((item) => {
-            tmp.push({
-                value: item.matnr,
-                label: item.matnr + '_' + item.maktx,
-                data: item
-            })
-        })
-        matQueryList.value = tmp;
-        matFetching.value = false;
-    })
-}
-
-const handleDel = (record) => {
-    let tmp = [];
-    tableData.value.forEach((item) => {
-        if (item._id != record._id) {
-            tmp.push(item);
-        }
-    })
-
-    //閲嶅缓绱㈠紩
-    let index = 1;
-    tmp.forEach((item) => {
-        item._id = index++;
-    })
-
-    if (record.detlId != undefined) {
-        deleteDetlId.value.push(record.detlId);
-    }
-
-    tableData.value = tmp;
-}
-
-watch(orderId, (newVal, oldVal) => {
-    if (newVal == undefined || newVal == null) {
-        tableData.value = [];
-        getColumns()
-        return;
-    }
-
-    get("/api/orderDetl/orderId/" + newVal, {}).then((resp) => {
-        let result = resp.data;
-        let index = 1;
-        let tmp = [];
-        result.data.forEach((item) => {
-            let data = {
-                _id: index++,
-                detlId: item.id,
-                matnr: item.mat$.matnr,
-                maktx: item.mat$.maktx,
-                batch: item.batch,
-                anfme: item.anfme,
-                qty: item.qty,
-                workQty: item.workQty,
-                memo: item.memo
-            };
-            fieldList.forEach((field) => {
-                data[field] = item[field];
-            })
-            tmp.push(data)
-        })
-        tableData.value = tmp;
-    })
-
-})
-
-defineExpose({
-    tableData,
-    orderId,
-    deleteDetlId,
-    isAdd,
-})
-
-</script>
-
-<script>
-export default {
-    name: 'orderDetlComponent'
-}
-</script>
-
-<template>
-    <div>
-        <div class="table-header">
-            <a-button @click="addDetl()" type="primary">{{ formatMessage('page.add', '娣诲姞鏄庣粏') }}</a-button>
-        </div>
-        <a-table :data-source="tableData" :defaultExpandAllRows="false" :key="TABLE_KEY" rowKey="id"
-            :scroll="{ y: 768 }" :columns="state.columns">
-            <template #bodyCell="{ column, record, index }">
-                <template v-if="column.dataIndex === 'oper'">
-                    <div style="display: flex;justify-content: space-evenly;">
-                        <a-button type="link" danger @click="handleDel(record)">{{ formatMessage('page.delete', '鍒犻櫎')
-                            }}</a-button>
-                    </div>
-                </template>
-
-                <template v-if="column.editable">
-                    <a-input v-model:value="record[column.dataIndex]" />
-                </template>
-            </template>
-        </a-table>
-
-        <a-modal v-model:open="openAddDetl" :title="formatMessage('component.orderDetl.edit.addDetl', '娣诲姞鏄庣粏')"
-            @ok="handleAddDetlOk" @cancel="handleAddDetlCancel">
-            <a-select v-model:value="matChecked" :options="matQueryList" mode="multiple"
-                :placeholder="formatMessage('component.orderDetl.edit.selectMat', '璇烽�夋嫨鐗╂枡')" @search="handleSearch"
-                :filter-option="false" :not-found-content="matFetching ? undefined : null" @select="handleSelect"
-                @deselect="handleDeselect"></a-select>
-        </a-modal>
-    </div>
-</template>
-
-<style></style>
+<script setup>
+import { getCurrentInstance, ref, watch, reactive } from 'vue';
+import { useRouter } from "vue-router";
+import { get, post, postForm } from '@/utils/request.js'
+import { message, Modal } from 'ant-design-vue';
+import { logout } from '@/config.js';
+import { formatMessage } from '@/utils/localeUtils.js';
+import useTableSearch from '@/utils/tableUtils.jsx';
+import { debounce } from 'lodash-es';
+const context = getCurrentInstance()?.appContext.config.globalProperties;
+
+const router = useRouter();
+
+const TABLE_KEY = 'table-locDetl';
+
+const props = defineProps({
+    ioModel: null
+})
+
+let tableData = ref([]);
+let deleteDetlId = ref([]);
+let orderId = ref(null);
+let isAdd = ref(false);
+getColumns();
+
+const {
+    getColumnSearchProps,
+} = useTableSearch();
+
+const state = reactive({
+    selectedRowKeys: [],
+    loading: false,
+    columns: [],
+});
+
+let defaultColumns = [
+    {
+        title: '#',
+        dataIndex: '_id',
+        width: 60,
+        ellipsis: true,
+    },
+    {
+        title: formatMessage('db.man_loc_detl.matnr', '鍟嗗搧缂栧彿'),
+        dataIndex: 'matnr',
+        width: 200,
+        ellipsis: true,
+    },
+    {
+        title: formatMessage('db.man_loc_detl.maktx', '鍟嗗搧鍚嶇О'),
+        dataIndex: 'maktx',
+        width: 140,
+        ellipsis: true,
+    },
+    {
+        title: formatMessage('db.man_loc_detl.batch', '鎵瑰彿'),
+        dataIndex: 'batch',
+        width: 140,
+        ellipsis: true,
+        editable: true,
+    },
+    {
+        title: formatMessage('db.man_loc_detl.anfme', '鏁伴噺'),
+        dataIndex: 'anfme',
+        width: 140,
+        ellipsis: true,
+        editable: true,
+    },
+    // {
+    //     title: formatMessage('db.man_loc_detl.qty', '宸插畬鎴愭暟閲�'),
+    //     dataIndex: 'qty',
+    //     width: 140,
+    //     ellipsis: true,
+    //     editable: true,
+    // },
+    // {
+    //     title: formatMessage('db.man_loc_detl.workQty', '浣滀笟涓暟閲�'),
+    //     dataIndex: 'workQty',
+    //     width: 140,
+    //     ellipsis: true,
+    //     editable: true,
+    // },
+    // {
+    //     title: formatMessage('db.man_loc_detl.memo', '澶囨敞'),
+    //     dataIndex: 'memo',
+    //     width: 140,
+    //     ellipsis: true,
+    //     editable: true,
+    // },
+];
+
+const fieldList = [];
+//鍔犺浇鎵╁睍瀛楁
+async function getColumns() {
+    let fieldResp = await post('/api/matField/list', {
+        fieldType: 1
+    })
+    let fieldResult = fieldResp.data;
+    let tmp = defaultColumns;
+    if (fieldResult.code == 200) {
+        let data = fieldResult.data;
+
+        if (!isAdd.value) {
+            tmp.push({
+                title: formatMessage('db.man_loc_detl.qty', '宸插畬鎴愭暟閲�'),
+                dataIndex: 'qty',
+                width: 140,
+                ellipsis: true,
+                editable: true,
+            })
+
+            tmp.push({
+                title: formatMessage('db.man_loc_detl.workQty', '浣滀笟涓暟閲�'),
+                dataIndex: 'workQty',
+                width: 140,
+                ellipsis: true,
+                editable: true,
+            })
+        }
+
+        data.forEach((item) => {
+            tmp.push({
+                title: formatMessage(item.language, item.describe),
+                name: item.name,
+                dataIndex: item.name,
+                key: item.name,
+                width: 140,
+                editable: true,
+            })
+
+            fieldList.push(item.name);
+        })
+
+        tmp.push({
+            title: formatMessage('db.man_loc_detl.memo', '澶囨敞'),
+            dataIndex: 'memo',
+            width: 140,
+            ellipsis: true,
+            editable: true,
+        })
+
+        tmp.push({
+            title: formatMessage('common.operation', '鎿嶄綔'),
+            name: 'oper',
+            dataIndex: 'oper',
+            key: 'oper',
+            width: 140,
+        })
+
+        state.columns = tmp;
+    } else if (result.code === 401) {
+        message.error(result.msg);
+        logout()
+    } else {
+        message.error(result.msg);
+    }
+}
+
+const openAddDetl = ref(false);
+const matChecked = ref([]);
+const matQueryList = ref(null);
+const matFetching = ref(false);
+const searchText = ref('')
+const matSelectList = ref([]);
+const addDetl = () => {
+    openAddDetl.value = true;
+}
+
+const handleAddDetlOk = () => {
+    let origin = tableData.value;
+    let index = origin.length + 1;
+    matSelectList.value.forEach((item) => {
+        let data = {
+            _id: index++,
+            matnr: item.data.matnr,
+            maktx: item.data.maktx,
+            batch: '',
+            anfme: 0,
+            qty: 0,
+            workQty: 0,
+            memo: ''
+        };
+        fieldList.forEach((field) => {
+            data[field] = '';
+        })
+        origin.push(data)
+    })
+    tableData.value = origin;
+
+    openAddDetl.value = false;
+    matSelectList.value = [];
+    matChecked.value = [];
+}
+
+const handleAddDetlCancel = () => {
+    matSelectList.value = [];
+    matChecked.value = [];
+}
+
+const handleSearch = debounce(val => {
+    searchText.value = val
+    matQuery(val);
+}, 600)
+
+const handleSelect = (value, option) => {
+    let flag = true;
+    matSelectList.value.forEach((item) => {
+        if (item.value == value) {
+            flag = false;
+        }
+    })
+
+    if (flag) {
+        matSelectList.value.push(option)
+    }
+}
+
+const handleDeselect = (value, option) => {
+    let tmp = [];
+    matSelectList.value.forEach((item) => {
+        if (item.value != value) {
+            tmp.push(item);
+        }
+    })
+
+    matSelectList.value = tmp;
+}
+
+matQuery(null);
+
+function matQuery(condition) {
+    matFetching.value = true;
+    let url = '/api/mat/page'
+    if (props.ioModel == 2) {
+        url = '/api/locs/mats/page'
+    } 
+    post(url, {
+        current: 1,
+        pageSize: 10,
+        condition: condition
+    }).then((resp) => {
+        let result = resp.data;
+        let tmp = []
+        result.data.records.forEach((item) => {
+            tmp.push({
+                value: item.matnr,
+                label: item.matnr + '_' + item.maktx,
+                data: item
+            })
+        })
+        matQueryList.value = tmp;
+        matFetching.value = false;
+    })
+}
+
+const handleDel = (record) => {
+    let tmp = [];
+    tableData.value.forEach((item) => {
+        if (item._id != record._id) {
+            tmp.push(item);
+        }
+    })
+
+    //閲嶅缓绱㈠紩
+    let index = 1;
+    tmp.forEach((item) => {
+        item._id = index++;
+    })
+
+    if (record.detlId != undefined) {
+        deleteDetlId.value.push(record.detlId);
+    }
+
+    tableData.value = tmp;
+}
+
+watch(orderId, (newVal, oldVal) => {
+    if (newVal == undefined || newVal == null) {
+        tableData.value = [];
+        getColumns()
+        return;
+    }
+
+    get("/api/orderDetl/orderId/" + newVal, {}).then((resp) => {
+        let result = resp.data;
+        let index = 1;
+        let tmp = [];
+        result.data.forEach((item) => {
+            let data = {
+                _id: index++,
+                detlId: item.id,
+                matnr: item.mat$.matnr,
+                maktx: item.mat$.maktx,
+                batch: item.batch,
+                anfme: item.anfme,
+                qty: item.qty,
+                workQty: item.workQty,
+                memo: item.memo
+            };
+            fieldList.forEach((field) => {
+                data[field] = item[field];
+            })
+            tmp.push(data)
+        })
+        tableData.value = tmp;
+    })
+
+})
+
+defineExpose({
+    tableData,
+    orderId,
+    deleteDetlId,
+    isAdd,
+})
+
+</script>
+
+<script>
+export default {
+    name: 'orderDetlComponent'
+}
+</script>
+
+<template>
+    <div>
+        <div class="table-header">
+            <a-button @click="addDetl()" type="primary">{{ formatMessage('page.add', '娣诲姞鏄庣粏') }}</a-button>
+        </div>
+        <a-table :data-source="tableData" :defaultExpandAllRows="false" :key="TABLE_KEY" rowKey="id"
+            :scroll="{ y: 768 }" :columns="state.columns">
+            <template #bodyCell="{ column, record, index }">
+                <template v-if="column.dataIndex === 'oper'">
+                    <div style="display: flex;justify-content: space-evenly;">
+                        <a-button type="link" danger @click="handleDel(record)">{{ formatMessage('page.delete', '鍒犻櫎')
+                            }}</a-button>
+                    </div>
+                </template>
+
+                <template v-if="column.editable">
+                    <a-input v-model:value="record[column.dataIndex]" />
+                </template>
+            </template>
+        </a-table>
+
+        <a-modal v-model:open="openAddDetl" :title="formatMessage('component.orderDetl.edit.addDetl', '娣诲姞鏄庣粏')"
+            @ok="handleAddDetlOk" @cancel="handleAddDetlCancel">
+            <a-select v-model:value="matChecked" :options="matQueryList" mode="multiple" :searchValue="searchText"
+                :placeholder="formatMessage('component.orderDetl.edit.selectMat', '璇烽�夋嫨鐗╂枡')" @search="handleSearch"
+                :filter-option="false" :not-found-content="matFetching ? undefined : null"  @select="handleSelect" allowClear
+                @deselect="handleDeselect" ></a-select>
+        </a-modal>
+    </div>
+</template>
+
+<style></style>

--
Gitblit v1.9.1