Browse Source

调整装配追溯页面

user_zyx 11 months ago
parent
commit
deda3dacef

BIN
ZRAdmin-vue-main/dist.zip


+ 0 - 7
ZRAdmin-vue-main/src/api/business/outassemblerecord.js

@@ -13,13 +13,6 @@ export function listOutAssembleRecord(query) {
   })
 }
 
-export function statOutAssembleRecord(query) {
-  return request({
-    url: 'business/OutAssembleRecord/stat',
-    method: 'get',
-    params: query,
-  })
-}
 /**
 * 新增出库管理/装配记录表
 * @param data

+ 8 - 0
ZRAdmin-vue-main/src/api/business/sapbomrecord.js

@@ -12,6 +12,14 @@ export function listSapBomRecord(query) {
   })
 }
 
+export function statSapBomRecord(query) {
+  return request({
+    url: 'business/SapBomRecord/stat',
+    method: 'get',
+    params: query,
+  })
+}
+
 
 /**
 * 新增接口管理/SAP关键件清单记录表

+ 109 - 148
ZRAdmin-vue-main/src/views/Business/ReportAssemble/index.vue

@@ -8,17 +8,17 @@
 -->
 <template>
   <div>
-    <el-form :model="statParams" label-position="right" inline ref="statRef" v-show="showSearch" @submit.prevent>
+    <el-form :model="statParams" label-position="right" inline ref="statRef" @submit.prevent>
       <el-form-item label="生产令号" prop="bomNo">
         <el-input v-model="statParams.bomNo" placeholder="请输入" class="z-el-input" clearable @keyup.enter="handleStat" />
       </el-form-item>
       <el-form-item label="装配结果" prop="result">
-        <el-select v-model="statParams.result" placeholder="请选择" clearable style="width:120px" @change="handleStat">
-          <el-option v-for="dict in options.operationResultOptions" :key="dict.dictValue" :label="dict.dictLabel"
-            :value="dict.dictValue">
-            <dict-tag :options="options.operationResultOptions" :value="dict.dictValue" />
-          </el-option>
-        </el-select>
+        <el-radio-group v-model="statParams.result" @change="handleStat">
+          <el-radio-button>全部</el-radio-button>
+          <el-radio-button v-for="dict in options.operationResultOptions" :label="dict.dictValue">
+            {{ dict.dictLabel }}
+          </el-radio-button>
+        </el-radio-group>
       </el-form-item>
       <el-form-item>
         <el-button icon="search" type="primary" @click="handleStat">{{ $t('btn.search') }}</el-button>
@@ -26,27 +26,6 @@
       </el-form-item>
 
     </el-form>
-    <!-- 工具区域 -->
-    <el-row :gutter="10" class="mb8">
-      <!-- <el-col :span="1.5">
-        <el-button type="primary" v-hasPermi="['business:outassemblerecord:add']" plain icon="plus" @click="handleAdd">
-          {{ $t('btn.add') }}
-        </el-button>
-      </el-col>
-      <el-col :span="1.5">
-        <el-button type="success" :disabled="single" v-hasPermi="['business:outassemblerecord:edit']" plain icon="edit"
-          @click="handleUpdate">
-          {{ $t('btn.edit') }}
-                                                                            </el-button>
-                                                                          </el-col>
-                                                                          <el-col :span="1.5">
-                                                                            <el-button type="danger" :disabled="multiple" v-hasPermi="['business:outassemblerecord:delete']" plain
-                                                                              icon="delete" @click="handleDelete">
-                                                                              {{ $t('btn.delete') }}
-                                                                            </el-button>
-                                                                          </el-col> -->
-      <!-- <right-toolbar v-model:showSearch="showSearch" @queryTable="getList" :columns="columns"></right-toolbar> -->
-    </el-row>
 
     <!-- 数据区域 -->
     <el-table :data="dataStat" v-loading="loading" ref="table" highlight-current-row @sort-change="sortChange"
@@ -71,60 +50,58 @@
 
 
     <!-- 装配追溯对话框 -->
-    <el-dialog :title="title" v-model="open" width="70%">
+    <el-dialog :title="title" v-model="open" width="70%" @close="closeDialog">
       <el-form :model="queryParams" label-position="right" inline ref="queryRef" v-show="showSearch" @submit.prevent>
-        <el-form-item label="物料编码" prop="materialCode">
-          <el-input v-model="queryParams.materialCode" placeholder="请输入" class="z-el-input" clearable
-            @keyup.enter="handleQuery(title)" />
-        </el-form-item>
-        <el-form-item label="物料名称" prop="materialName">
-          <el-input v-model="queryParams.materialName" placeholder="请输入" class="z-el-input" clearable
-            @keyup.enter="handleQuery(title)" />
-        </el-form-item>
-        <el-form-item label="物料类型" prop="category">
-          <el-select v-model="queryParams.category" placeholder="请选择" clearable style="width:120px"
-            @change="handleQuery(title)">
-            <el-option v-for="dict in options.materialTypeOptions" :key="dict.dictValue" :label="dict.dictLabel"
-              :value="dict.dictValue">
-              <dict-tag :options="options.materialTypeOptions" :value="dict.dictValue" />
-            </el-option>
-          </el-select>
-        </el-form-item>
-        <el-form-item label="规格型号 / 图号" prop="materialSpec">
-          <el-input v-model="queryParams.materialSpec" placeholder="请输入" class="z-el-input" clearable
-            @keyup.enter="handleQuery(title)" />
-        </el-form-item>
-        <el-form-item label="装配结果" prop="result">
-          <el-select v-model="queryParams.result" placeholder="请选择" clearable style="width:120px"
-            @change="handleQuery(title)">
-            <el-option v-for="dict in options.operationResultOptions" :key="dict.dictValue" :label="dict.dictLabel"
-              :value="dict.dictValue">
-              <dict-tag :options="options.operationResultOptions" :value="dict.dictValue" />
-            </el-option>
-          </el-select>
-        </el-form-item>
-        <el-form-item label="关键件标识" prop="keyFlag">
-          <el-select v-model="queryParams.keyFlag" placeholder="请选择" clearable style="width:120px"
-            @change="handleQuery(title)">
-            <el-option v-for="dict in options.keyFlagOptions" :key="dict.dictValue" :label="dict.dictLabel"
-              :value="dict.dictValue">
-              <dict-tag :options="options.keyFlagOptions" :value="dict.dictValue" />
-            </el-option>
-          </el-select>
-        </el-form-item>
-        <el-form-item label="BN / SN码">
-          <el-input v-model="queryParams.bnSnCode" placeholder="请输入" class="z-el-input" clearable
-            @keyup.enter="handleQuery(title)" />
-        </el-form-item>
-        <el-form-item label="创建时间">
-          <el-date-picker v-model="queryCreateTime" style="width: 400px" type="datetimerange" range-separator="-"
-            @change="handleQuery(title)" start-placeholder="开始时间" end-placeholder="结束时间"></el-date-picker>
-        </el-form-item>
-        <el-form-item>
-          <el-button icon="search" type="primary" @click="handleQuery(title)">{{ $t('btn.search') }}</el-button>
-          <el-button icon="refresh" @click="resetQuery(title)">{{ $t('btn.reset') }}</el-button>
-        </el-form-item>
-
+        <el-row>
+          <el-form-item label="物料名称" prop="materialName">
+            <el-input v-model="queryParams.materialName" placeholder="请输入" class="z-el-input" clearable
+              @keyup.enter="handleQuery(title)" />
+          </el-form-item>
+          <el-form-item label="物料编码" prop="materialCode">
+            <el-input v-model="queryParams.materialCode" placeholder="请输入" class="z-el-input" clearable
+              @keyup.enter="handleQuery(title)" />
+          </el-form-item>
+          <el-form-item label="规格型号 / 图号" prop="materialSpec">
+            <el-input v-model="queryParams.materialSpec" placeholder="请输入" class="z-el-input" clearable
+              @keyup.enter="handleQuery(title)" />
+          </el-form-item>
+        </el-row>
+        <el-row>
+          <el-form-item label="物料类型" prop="category">
+            <el-radio-group v-model="queryParams.category" @change="handleQuery(title)">
+              <el-radio-button>全部</el-radio-button>
+              <el-radio-button v-for="dict in options.materialTypeOptions" :label="dict.dictValue">
+                {{ dict.dictLabel }}
+              </el-radio-button>
+            </el-radio-group>
+          </el-form-item>
+          <el-form-item label="装配结果" prop="result">
+            <el-radio-group v-model="queryParams.result" @change="handleQuery(title)">
+              <el-radio-button>全部</el-radio-button>
+              <el-radio-button v-for="dict in options.operationResultOptions" :label="dict.dictValue">
+                {{ dict.dictLabel }}
+              </el-radio-button>
+            </el-radio-group>
+          </el-form-item>
+          <el-form-item label="关键件标识" prop="keyFlag">
+            <el-radio-group v-model="queryParams.keyFlag" @change="handleQuery(title)">
+              <el-radio-button>全部</el-radio-button>
+              <el-radio-button v-for="dict in options.keyFlagOptions" :label="dict.dictValue">
+                {{ dict.dictLabel }}
+              </el-radio-button>
+            </el-radio-group>
+          </el-form-item>
+        </el-row>
+        <el-row>
+          <el-form-item label="装配时间">
+            <el-date-picker v-model="queryAssTime" style="width: 400px" type="datetimerange" range-separator="-"
+              @change="handleQuery(title)" start-placeholder="开始时间" end-placeholder="结束时间"></el-date-picker>
+          </el-form-item>
+          <el-form-item>
+            <el-button icon="search" type="primary" @click="handleQuery(title)">{{ $t('btn.search') }}</el-button>
+            <el-button icon="refresh" @click="resetQuery">{{ $t('btn.reset') }}</el-button>
+          </el-form-item>
+        </el-row>
       </el-form>
       <el-row :gutter="10" class="mb8">
         <el-col :span="1.5">
@@ -135,26 +112,31 @@
         </el-col>
         <right-toolbar v-model:showSearch="showSearch" @queryTable="getList" :columns="columns"></right-toolbar>
       </el-row>
-      <el-table :data="dataList" v-loading="loading" ref="table" highlight-current-row @sort-change="sortChange"
-        @selection-change="handleSelectionChange">
-        <!-- <el-table-column type="selection" width="50" align="center" /> -->
+      <!-- 数据区域 -->
+      <el-table :data="dataList" v-loading="loading" ref="table" highlight-current-row @sort-change="sortChange">
         <el-table-column type="index" label="序号" width="50" align="center" />
-        <el-table-column prop="assembleId" label="ID" align="center" v-if="columns.showColumn('assembleId')" />
+        <el-table-column prop="id" label="ID" align="center" v-if="columns.showColumn('id')" />
         <el-table-column prop="bomNo" label="生产令号" align="center" :show-overflow-tooltip="true"
           v-if="columns.showColumn('bomNo')" />
-        <el-table-column prop="materialCode" label="物料编码" align="center" :show-overflow-tooltip="true"
-          v-if="columns.showColumn('materialCode')" />
-        <el-table-column prop="materialName" label="物料名称" align="center" :show-overflow-tooltip="true"
-          v-if="columns.showColumn('materialName')" />
-        <el-table-column prop="materialSpec" label="规格型号 / 图号" align="center" :show-overflow-tooltip="true" width="120"
-          v-if="columns.showColumn('materialSpec')" />
+        <el-table-column prop="equipmentName" label="设备名称" align="center" :show-overflow-tooltip="true"
+          v-if="columns.showColumn('equipmentName')" />
+        <el-table-column prop="makeBy" label="编制人员" align="center" :show-overflow-tooltip="true"
+          v-if="columns.showColumn('makeBy')" />
+        <el-table-column prop="makeTime" label="编制时间" align="center" :show-overflow-tooltip="true"
+          v-if="columns.showColumn('makeTime')" />
         <el-table-column prop="category" label="物料类型" align="center" :show-overflow-tooltip="true"
-          v-if="columns.showColumn('category')">
+          v-if="columns.showColumn('category')" width="70">
           <template #default="scope">
             <dict-tag :options="options.materialTypeOptions" :value="scope.row.category" />
           </template>
         </el-table-column>
-        <el-table-column prop="keyFlag" label="关键件" align="center" v-if="columns.showColumn('keyFlag')">
+        <el-table-column prop="materialCode" label="物料编码" align="center" :show-overflow-tooltip="true"
+          v-if="columns.showColumn('materialCode')" />
+        <el-table-column prop="materialName" label="物料名称" align="center" :show-overflow-tooltip="true"
+          v-if="columns.showColumn('materialName')" />
+        <el-table-column prop="materialSpec" label="规格型号/图号" align="center" :show-overflow-tooltip="true"
+          v-if="columns.showColumn('materialSpec')" />
+        <el-table-column prop="keyFlag" label="关键件标识" align="center" v-if="columns.showColumn('keyFlag')" width="80">
           <template #default="scope">
             <el-icon v-if="scope.row.keyFlag" color="red">
               <StarFilled />
@@ -162,42 +144,24 @@
             <el-icon v-else />
           </template>
         </el-table-column>
-        <el-table-column prop="bnSnCode" label="BN / SN码" align="center" :show-overflow-tooltip="true"
-          v-if="columns.showColumn('bnSnCode')" />
-        <el-table-column prop="result" label="装配结果" align="center" v-if="columns.showColumn('result')">
+        <el-table-column prop="qty" label="需求数量" align="center" v-if="columns.showColumn('qty')" width="70" />
+        <el-table-column prop="assembleQty" label="装配数量" align="center" v-if="columns.showColumn('assembleQty')"
+          width="70" />
+        <el-table-column prop="result" label="装配结果" align="center" v-if="columns.showColumn('result')" width="70">
           <template #default="scope">
             <dict-tag :options="options.operationResultOptions" :value="scope.row.result" />
           </template>
         </el-table-column>
-        <el-table-column prop="picture" label="实物图片" align="center" v-if="columns.showColumn('picture')">
-          <template #default="scope">
-            <el-image preview-teleported :hide-on-click-modal="true" lazy class="table-td-thumb" fit="contain"
-              :src="scope.row.picture" :preview-src-list="[scope.row.picture]">
-              <div>
-                <el-icon :size="15">
-                  <document />
-                </el-icon>
-              </div>
-            </el-image>
-          </template>
-        </el-table-column>
-        <el-table-column prop="assembleQty" label="装配数量" align="center" v-if="columns.showColumn('assembleQty')" />
-        <el-table-column prop="remark" label="备注" align="center" :show-overflow-tooltip="true"
-          v-if="columns.showColumn('remark')" />
+        <el-table-column prop="assBy" label="装配人" align="center" v-if="columns.showColumn('assBy')" />
+        <el-table-column prop="assTime" label="装配时间" align="center" width="160" v-if="columns.showColumn('assTime')" />
         <el-table-column prop="createBy" label="创建人" align="center" v-if="columns.showColumn('createBy')" />
         <el-table-column prop="createTime" label="创建时间" align="center" width="160"
           v-if="columns.showColumn('createTime')" />
         <el-table-column prop="updateBy" label="更新人" align="center" v-if="columns.showColumn('updateBy')" />
         <el-table-column prop="updateTime" label="更新时间" align="center" width="160"
           v-if="columns.showColumn('updateTime')" />
-        <!-- <el-table-column label="操作" align="center" width="160">
-                                      <template #default="scope">
-                                        <el-button v-hasPermi="['business:outassemblerecord:edit']" type="success" plain icon="edit" title="编辑"
-                                          @click="handleUpdate(scope.row)"></el-button>
-                                        <el-button v-hasPermi="['business:outassemblerecord:delete']" type="danger" plain icon="delete" title="删除"
-                                          @click="handleDelete(scope.row)"></el-button>
-                                      </template>
-                                    </el-table-column> -->
+        <el-table-column prop="remark" label="备注" align="center" :show-overflow-tooltip="true"
+          v-if="columns.showColumn('remark')" />
       </el-table>
       <pagination class="mt10" background :total="total" v-model:page="queryParams.pageNum"
         v-model:limit="queryParams.pageSize" @pagination="getList" />
@@ -207,11 +171,9 @@
 
 <script setup name="outassemblerecord">
 import {
-  listOutAssembleRecord, addOutAssembleRecord, delOutAssembleRecord, updateOutAssembleRecord, getOutAssembleRecord, statOutAssembleRecord
-
+  listSapBomRecord, statSapBomRecord
 }
-  from '@/api/business/outassemblerecord.js'
-
+  from '@/api/business/sapbomrecord.js'
 const { proxy } = getCurrentInstance()
 // 选中assembleId数组数组
 const ids = ref([])
@@ -219,7 +181,7 @@ const single = ref(true)
 const multiple = ref(true)
 const loading = ref(false)
 const showSearch = ref(true)
-const queryCreateTime = ref([])
+const queryAssTime = ref([])
 const queryParams = reactive({
   pageNum: 1,
   pageSize: 10,
@@ -243,19 +205,23 @@ const statParams = reactive({
   sortType: 'asc',
 })
 const columns = ref([
-  { visible: false, prop: 'assembleId', label: 'ID' },
+  { visible: false, prop: 'id', label: 'ID' },
   { visible: false, prop: 'bomNo', label: '生产令号' },
+  { visible: true, prop: 'equipmentName', label: '设备名称' },
+  { visible: false, prop: 'makeBy', label: '编制人员' },
+  { visible: false, prop: 'makeTime', label: '编制时间' },
+  { visible: true, prop: 'category', label: '物料类型' },
   { visible: true, prop: 'materialCode', label: '物料编码' },
   { visible: true, prop: 'materialName', label: '物料名称' },
-  { visible: true, prop: 'materialSpec', label: '物料规格' },
-  { visible: true, prop: 'category', label: '物料类型' },
-  { visible: true, prop: 'keyFlag', label: '关键件' },
-  { visible: true, prop: 'bnSnCode', label: 'BN/SN码' },
-  { visible: true, prop: 'result', label: '装配结果' },
-  { visible: true, prop: 'picture', label: '实物图片' },
+  { visible: true, prop: 'materialSpec', label: '规格型号/图号' },
+  { visible: true, prop: 'keyFlag', label: '关键件标识' },
+  { visible: true, prop: 'qty', label: '需求数量' },
   { visible: true, prop: 'assembleQty', label: '装配数量' },
-  { visible: true, prop: 'createBy', label: '创建人' },
-  { visible: true, prop: 'createTime', label: '创建时间' },
+  { visible: true, prop: 'result', label: '装配结果' },
+  { visible: true, prop: 'assBy', label: '装配人' },
+  { visible: true, prop: 'assTime', label: '装配时间' },
+  { visible: false, prop: 'createBy', label: '创建人' },
+  { visible: false, prop: 'createTime', label: '创建时间' },
   { visible: false, prop: 'updateBy', label: '更新人' },
   { visible: false, prop: 'updateTime', label: '更新时间' },
   { visible: false, prop: 'remark', label: '备注' },
@@ -269,7 +235,7 @@ const defaultTime = ref([new Date(2000, 1, 1, 0, 0, 0), new Date(2000, 2, 1, 23,
 
 function getStat() {
   loading.value = true
-  statOutAssembleRecord(statParams).then(res => {
+  statSapBomRecord(statParams).then(res => {
     const { code, data } = res
     if (code == 200) {
       dataStat.value = data.result
@@ -281,7 +247,7 @@ function getStat() {
 }
 function getList() {
   loading.value = true
-  listOutAssembleRecord(queryParams).then(res => {
+  listSapBomRecord(queryParams).then(res => {
     const { code, data } = res
     if (code == 200) {
       dataList.value = data.result
@@ -296,16 +262,16 @@ function handleQuery(bomNo) {
   queryParams.pageNum = 1
   queryParams.bomNo = bomNo
   title.value = bomNo
-  if (queryCreateTime.value != null) {
-    queryParams.beginTime = queryCreateTime.value[0]
-    queryParams.endTime = queryCreateTime.value[1]
-    // console.log(queryParams)
+  if (queryAssTime.value != null) {
+    queryParams.beginTime = queryAssTime.value[0]
+    queryParams.endTime = queryAssTime.value[1]
   }
   else {
     queryParams.beginTime = undefined
     queryParams.endTime = undefined
   }
   open.value = true
+  // console.log(queryParams)
   getList()
 }
 // 查询
@@ -315,7 +281,7 @@ function handleStat() {
 }
 // 重置查询操作
 function resetQuery() {
-  queryCreateTime.value = []
+  queryAssTime.value = []
   proxy.resetForm("queryRef")
   handleQuery(title.value)
 }
@@ -323,12 +289,6 @@ function resetStat() {
   proxy.resetForm("statRef")
   handleStat()
 }
-// 多选框选中数据
-function handleSelectionChange(selection) {
-  ids.value = selection.map((item) => item.assembleId);
-  single.value = selection.length != 1
-  multiple.value = !selection.length;
-}
 
 // 自定义排序
 function sortChange(column) {
@@ -342,7 +302,7 @@ function sortChange(column) {
   }
   queryParams.sort = sort
   queryParams.sortType = sortType
-  handleQuery()
+  handleQuery(title)()
 }
 
 /*************** form操作 ***************/
@@ -372,7 +332,8 @@ proxy.getDicts(dictParams).then((response) => {
 // 关闭dialog
 function closeDialog() {
   open.value = false
-  reset()
+  queryAssTime.value = []
+  proxy.resetForm("queryRef")
 }
 
 handleStat()

+ 0 - 1
ZRAdmin-vue-main/src/views/Business/SapBomRecord/index.vue

@@ -305,7 +305,6 @@
 <script setup name="sapbomrecord">
 import {
   listSapBomRecord, addSapBomRecord, delSapBomRecord, updateSapBomRecord, getSapBomRecord,
-
 }
   from '@/api/business/sapbomrecord.js'