14e9a7fb0188be93cd471291cfdd1efd974b8a0d..4dfdc774c2e742764848177e44e75b7de518f285
2 天以前 Houjie
设备台账导入
4dfdc7 对比 | 目录
2 天以前 zhangherong
art: 生产订单SAP同步
eb50cc 对比 | 目录
2 天以前 lixiangyu
feat(cms): 废料单列表增加提交功能并优化相关逻辑
e46140 对比 | 目录
2 天以前 cuilei
检验项目页面调整
a6be89 对比 | 目录
2 天以前 cuilei
Merge remote-tracking branch 'origin/master'
7207ef 对比 | 目录
2 天以前 cuilei
设备/工艺点检表单增加批量正常选择
f849af 对比 | 目录
2 天以前 lixiangyu
feat(cms): 恢复刀具领用页面
f8c8e4 对比 | 目录
2 天以前 lixiangyu
feat(cms): 重写了刀具报废新增逻辑, 从通过刀具信息选取刀具改为通过刀具库存里的数据获取刀具 修改库存id存入刀具id的错误
a0c8a2 对比 | 目录
4 天以前 zhangherong
art: 管理员下拉框
f0bd09 对比 | 目录
5 天以前 Houjie
Merge remote-tracking branch 'origin/master'
3c5205 对比 | 目录
5 天以前 Houjie
校验
f5c794 对比 | 目录
5 天以前 lixiangyu
feat(cms): 添加刀具归还功能并优化 CuttingReceiveList组件
a17f09 对比 | 目录
5 天以前 zhangherong
art: 物料拉动,排产工单选择接口变更
8d5eae 对比 | 目录
5 天以前 zhangherong
art: 物料拉动,热处理问题修改
e79f5e 对比 | 目录
5 天以前 zhangherong
Merge remote-tracking branch 'origin/master'
426226 对比 | 目录
5 天以前 zhangherong
art: 班组管理 代码优化
c3cda9 对比 | 目录
已添加1个文件
已修改21个文件
3117 ■■■■■ 文件已修改
src/utils/util.js 26 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/base/ShiftGroupManager.vue 18 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/base/modules/group/GroupModal.vue 293 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/cms/CuttingReceiveDetailList.vue 260 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/cms/CuttingReceiveList.vue 727 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/cms/CuttingScrapDetailList.vue 5 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/cms/CuttingScrapList.vue 314 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/cms/modules/CuttingReceiveModal.vue 749 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/cms/modules/CuttingScrapModal.vue 159 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/cms/modules/JSelectScrapModal.vue 261 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/eam/base/EamMaintenanceStandardList.vue 54 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/eam/base/EamProcessParametersList.vue 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/eam/equipment/EamEquipmentList.vue 30 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/eam/equipment/modules/EamEquipmentModal.vue 23 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/mes/MesProductionOrderList.vue 65 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/mes/modules/MesMaterialTransferRequestForm.vue 50 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/mes/modules/MesProductionOrderModal.vue 5 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/mes/modules/MesProductionWorkOrderCompletenessCheckModal.vue 2 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/mes/modules/MesProductionWorkOrderEquipmentInspectionModal.vue 27 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/mes/modules/MesProductionWorkOrderProcessCheckModal.vue 37 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/mes/modules/WorkOrderSelectModal.vue 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/qms/InspectionItemList.vue 8 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/utils/util.js
@@ -512,7 +512,31 @@
  }
  return [target].concat(getParents(target), window)
}
/**
 * é‡å¤å€¼éªŒè¯å·¥å…·æ–¹æ³•
 *
 * ä½¿ç”¨ç¤ºä¾‹ï¼š
 * { validator: (rule, value, callback) => validateDuplicateValue('sys_fill_rule', 'rule_code', value, this.model.id, callback) }
 *
 * @param tableName è¢«éªŒè¯çš„表名
 * @param fieldName è¢«éªŒè¯çš„字段名
 * @param fieldVal è¢«éªŒè¯çš„值
 * @param dataId æ•°æ®ID,可空
 * @param delFlag åˆ é™¤æ ‡è®°
 * @param callback
 */
export function validateDuplicateValueInDelFlag(tableName, fieldName, fieldVal, dataId, delFlag, callback) {
  if (fieldVal) {
    let params = { tableName, fieldName, fieldVal, dataId, delFlag }
    api.duplicateCheck(params).then(res => {
      res['success'] ? callback() : callback(res['message'])
    }).catch(err => {
      callback(err.message || err)
    })
  } else {
    callback()
  }
}
/**
 * æ ¹æ®ç»„件名获取父级
 * @param vm
src/views/base/ShiftGroupManager.vue
@@ -7,7 +7,13 @@
          <!-- æœç´¢åŒºåŸŸ -->
          <a-form layout="inline" @keyup.enter.native="searchQuery">
            <a-row :gutter="24">
              <a-col :md="6" :sm="8">
              <a-col :xl="6" :lg="7" :md="8" :sm="24">
                <a-form-item label="产线">
                  <j-dict-select-tag placeholder="请选择产线" v-model="queryParam.factoryId"
                                     dictCode="base_factory,factory_name,id,del_flag=0 and factory_category='3'"></j-dict-select-tag>
                </a-form-item>
              </a-col>
              <a-col :xl="6" :lg="7" :md="8" :sm="24">
                <a-form-item label="班组名称" :labelCol="{span: 5}" :wrapperCol="{span: 18, offset: 1}">
                  <a-input placeholder="" v-model="queryParam.groupName"></a-input>
                </a-form-item>
@@ -89,7 +95,7 @@
              <span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">
            <a-col :md="9" :sm="24">
             <a-button type="primary" @click="searchQuery2" icon="search" style="margin-left: 21px">查询</a-button>
              <a-button type="primary" @click="searchReset2" icon="reload" style="margin-left: 8px">重置</a-button>
              <a-button type="info" @click="searchReset2" icon="reload" style="margin-left: 8px">重置</a-button>
            </a-col>
          </span>
@@ -170,7 +176,7 @@
        queryParam2: {},
        dataSource1: [],
        dataSource2: [],
        ipagination1: {
        ipagination: {
          current: 1,
          pageSize: 10,
          pageSizeOptions: ['10', '20', '30'],
@@ -192,9 +198,9 @@
          showSizeChanger: true,
          total: 0
        },
        isorter1: {
          column: 'createTime',
          order: 'desc'
        isorter: {
          column: 'groupCode',
          order: 'asc'
        },
        isorter2: {
          column: 'createTime',
src/views/base/modules/group/GroupModal.vue
@@ -12,42 +12,37 @@
    style="top:5%;height: 85%;overflow-y: hidden">
    <a-spin :spinning="confirmLoading">
      <a-form-model ref="form"  v-bind="layout"  :model="model" :rules="validatorRules">
      <a-form-model ref="form" :model="model" :rules="validatorRules">
        <a-form-model-item label="班组编码" required prop="groupCode" :labelCol="labelCol" :wrapperCol="wrapperCol">
          <a-input v-model="model.groupCode" :disabled="roleDisabled"  placeholder="请输入班组编码"/>
          <a-input v-model="model.groupCode" :disabled="roleDisabled" placeholder="请输入班组编码" />
        </a-form-model-item>
        <a-form-model-item label="班组名称" required prop="groupName" :labelCol="labelCol" :wrapperCol="wrapperCol">
          <a-input v-model="model.groupName" placeholder="请输入班组名称"/>
          <a-input v-model="model.groupName" placeholder="请输入班组名称" />
        </a-form-model-item>
         <a-form-model-item label="班组长" prop="groupManager" :labelCol="labelCol" :wrapperCol="wrapperCol">
        <a-form-model-item label="班组长" prop="groupManager" :labelCol="labelCol" :wrapperCol="wrapperCol">
          <j-search-select-tag
            type="list"
            v-model="model.groupManager"
            :trigger-change="true"
            dict="sys_user,realname,id, del_flag='0' and status='1'"
            placeholder="请选择班组长"
          />
        </a-form-model-item>
        <a-form-model-item label="产线" prop="factoryId" :labelCol="labelCol" :wrapperCol="wrapperCol">
          <j-dict-select-tag placeholder="请选择产线" v-model="model.factoryId"
                             dictCode="base_factory,factory_name,id,del_flag=0 and factory_category='3'"></j-dict-select-tag>
        </a-form-model-item>
        <a-form-model-item label="班次" prop="shiftId" :labelCol="labelCol" :wrapperCol="wrapperCol">
          <j-dict-select-tag
                type="list"
                v-model="model.groupManager"
                :trigger-change="true"
                dictCode="sys_user,realname,id"
                placeholder="请选择班组长"
              />
        </a-form-model-item>
         <a-form-model-item label="产线" prop="factoryId" :labelCol="labelCol" :wrapperCol="wrapperCol">
         <j-select-factory
            v-model="model.factoryId"
            :multi="true"
            @back="backFactoryInfo"
            :backProduction="true"
            :treeProductOpera="true"
          ></j-select-factory>
        </a-form-model-item>
         <a-form-model-item label="班次" prop="shiftId" :labelCol="labelCol" :wrapperCol="wrapperCol">
          <j-dict-select-tag
                type="list"
                v-model="model.shiftId"
                :trigger-change="true"
                dictCode="base_shift,shift_name,id"
                placeholder="请选择班次"
              />
            type="list"
            v-model="model.shiftId"
            :trigger-change="true"
            dictCode="base_shift,shift_name,id"
            placeholder="请选择班次"
          />
        </a-form-model-item>
        <a-form-model-item label="备注" prop="remark" :labelCol="labelCol" :wrapperCol="wrapperCol">
          <a-textarea :rows="5" v-model="model.remark" placeholder="请输入备注"/>
          <a-textarea :rows="5" v-model="model.remark" placeholder="请输入备注" />
        </a-form-model-item>
      </a-form-model>
    </a-spin>
@@ -55,130 +50,138 @@
</template>
<script>
  import {duplicateCheck } from '@/api/api'
  import {postAction,requestPut} from '@/api/manage'
  import JDictSelectTag from '@/components/dict/JDictSelectTag'
  import JSelectFactory from '../../../../components/jeecgbiz/JSelectFactory'
  export default {
    name: "GroupModal",
    components: {
    JDictSelectTag,
    JSelectFactory
import { duplicateCheck } from '@/api/api'
import { postAction, requestPut } from '@/api/manage'
import JDictSelectTag from '@/components/dict/JDictSelectTag'
export default {
  name: 'GroupModal',
  components: {
    JDictSelectTag
  },
    data () {
      return {
        title:"操作",
        visible: false,
        roleDisabled: false,
        model: {},
        labelCol: {
          xs: { span: 24 },
          sm: { span: 5 },
        },
        wrapperCol: {
          xs: { span: 24 },
          sm: { span: 16 },
        },
        confirmLoading: false,
        validatorRules:{
          groupName: [
            { required: true, message: '请输入班组名称!' },
            { min: 2, max: 30, message: '长度在 2 åˆ° 30 ä¸ªå­—符', trigger: 'blur' }
          ],
          groupCode: [
            { required: true, message: '请输入班组名称!'},
            { min: 0, max: 64, message: '长度不超过 64 ä¸ªå­—符', trigger: 'blur' },
            { validator: this.validategroupCode}
          ],
          remark: [
            { min: 0, max: 126, message: '长度不超过 126 ä¸ªå­—符', trigger: 'blur' }
          ]
        },
        url: {
          add: "/base/shiftGroup/add",
          edit: "/base/shiftGroup/edit",
        },
        nextFactoryOptions: [],
      }
  data() {
    return {
      title: '操作',
      visible: false,
      roleDisabled: false,
      model: {},
      labelCol: {
        xs: { span: 24 },
        sm: { span: 5 }
      },
      wrapperCol: {
        xs: { span: 24 },
        sm: { span: 16 }
      },
      confirmLoading: false,
      validatorRules: {
        groupName: [
          { required: true, message: '请输入班组名称!' },
          { min: 2, max: 30, message: '长度在 2 åˆ° 30 ä¸ªå­—符', trigger: 'blur' }
        ],
        groupCode: [
          { required: true, message: '请输入班组名称!' },
          { min: 0, max: 64, message: '长度不超过 64 ä¸ªå­—符', trigger: 'blur' },
          { validator: this.validategroupCode }
        ],
        factoryId: [
          { required: true, message: '请选择产线!' },
        ],
        groupManager: [
          { required: true, message: '请选择班组长!' },
        ],
        shiftId: [
          { required: true, message: '请选择班班次!' },
        ],
        remark: [
          { min: 0, max: 126, message: '长度不超过 126 ä¸ªå­—符', trigger: 'blur' }
        ]
      },
      url: {
        add: '/base/shiftGroup/add',
        edit: '/base/shiftGroup/edit'
      },
      nextFactoryOptions: []
    }
  },
  created() {
    //备份model原始值
    this.modelDefault = JSON.parse(JSON.stringify(this.model))
  },
  methods: {
    add() {
      this.edit(this.modelDefault)
    },
    created () {
      //备份model原始值
      this.modelDefault = JSON.parse(JSON.stringify(this.model));
    edit(record) {
      this.model = Object.assign({}, record)
      this.visible = true
    },
    methods: {
      add () {
        this.edit(this.modelDefault);
      },
      edit (record) {
        this.model = Object.assign({}, record);
        this.visible = true;
      },
      close () {
        this.$refs.form.clearValidate();
        this.$emit('close');
        this.visible = false;
      },
      handleOk () {
        const that = this;
        // è§¦å‘表单验证
        this.$refs.form.validate(valid => {
          if (valid) {
            that.confirmLoading = true;
            let obj;
            if(!this.model.id){
              obj=postAction(this.url.add, this.model)
            }else{
              obj=requestPut(this.url.edit, this.model, {
                    id: this.model.id
                  })
            }
            obj.then((res)=>{
              if(res.success){
                that.$message.success(res.message);
                that.$emit('ok');
              }else{
                that.$message.warning(res.message);
              }
            }).finally(() => {
              that.confirmLoading = false;
              that.close();
    close() {
      this.$refs.form.clearValidate()
      this.$emit('close')
      this.visible = false
    },
    handleOk() {
      const that = this
      // è§¦å‘表单验证
      this.$refs.form.validate(valid => {
        if (valid) {
          that.confirmLoading = true
          let obj
          if (!this.model.id) {
            obj = postAction(this.url.add, this.model)
          } else {
            obj = requestPut(this.url.edit, this.model, {
              id: this.model.id
            })
          }else{
            return false;
          }
          obj.then((res) => {
            if (res.success) {
              that.$message.success(res.message)
              that.$emit('ok')
            } else {
              that.$message.warning(res.message)
            }
          }).finally(() => {
            that.confirmLoading = false
            that.close()
          })
        } else {
          return false
        }
      })
    },
    handleCancel() {
      this.close()
    },
    validategroupCode(rule, value, callback) {
      if (/[\u4E00-\u9FA5]/g.test(value)) {
        callback('班组编码不可输入汉字!')
      } else {
        let params = {
          tableName: 'base_shift_group',
          fieldName: 'group_code',
          fieldVal: value,
          dataId: this.model.id
        }
        duplicateCheck(params).then((res) => {
          if (res.success) {
            callback()
          } else {
            callback(res.message)
          }
        })
      },
      handleCancel () {
        this.close()
      },
      validategroupCode(rule, value, callback){
        if(/[\u4E00-\u9FA5]/g.test(value)){
          callback("班组编码不可输入汉字!");
        }else{
          let params = {
            tableName: "base_shift_group",
            fieldName: "group_code",
            fieldVal: value,
            dataId: this.model.id,
          };
          duplicateCheck(params).then((res)=>{
            if(res.success){
              callback();
            }else{
              callback(res.message);
            }
          });
        }
      },
      backFactoryInfo(info) {
        this.model.factoryIds = this.model.factoryId
        this.nextFactoryOptions = info.map((item, index, arr) => {
          let c = { label: item.text, value: item.value + '' }
          return c
        })
      },
      }
    },
    backFactoryInfo(info) {
      this.model.factoryIds = this.model.factoryId
      this.nextFactoryOptions = info.map((item, index, arr) => {
        let c = { label: item.text, value: item.value + '' }
        return c
      })
    }
  }
}
</script>
<style scoped>
src/views/cms/CuttingReceiveDetailList.vue
@@ -1,48 +1,48 @@
<template>
   <a-card :bordered="false">
      <!-- table区域-begin -->
      <div>
         <div class="ant-alert ant-alert-info" style="margin-bottom: 16px;">
            <i class="anticon anticon-info-circle ant-alert-icon"></i> å·²é€‰æ‹© <a
            style="font-weight: 600">{{ selectedRowKeys.length }}</a>项
            <a style="margin-left: 24px" @click="onClearSelected">清空</a>
         </div>
  <a-card :bordered="false">
    <!-- table区域-begin -->
    <div>
      <div class="ant-alert ant-alert-info" style="margin-bottom: 16px;">
        <i class="anticon anticon-info-circle ant-alert-icon"></i> å·²é€‰æ‹© <a
        style="font-weight: 600">{{ selectedRowKeys.length }}</a>项
        <a style="margin-left: 24px" @click="onClearSelected">清空</a>
      </div>
         <a-table
            ref="table"
            size="middle"
            :scroll="{x:true}"
            bordered
            rowKey="id"
            :columns="columns"
            :dataSource="dataSource"
            :pagination="ipagination"
            :loading="loading"
            class="j-table-force-nowrap"
            @change="handleTableChange">
      <a-table
        ref="table"
        size="middle"
        :scroll="{x:true}"
        bordered
        rowKey="id"
        :columns="columns"
        :dataSource="dataSource"
        :pagination="ipagination"
        :loading="loading"
        class="j-table-force-nowrap"
        @change="handleTableChange">
            <template slot="htmlSlot" slot-scope="text">
               <div v-html="text"></div>
            </template>
            <template slot="imgSlot" slot-scope="text,record">
               <span v-if="!text" style="font-size: 12px;font-style: italic;">无图片</span>
               <img v-else :src="getImgView(text)" :preview="record.id" height="25px" alt=""
                    style="max-width:80px;font-size: 12px;font-style: italic;" />
            </template>
            <template slot="fileSlot" slot-scope="text">
               <span v-if="!text" style="font-size: 12px;font-style: italic;">无文件</span>
               <a-button
                  v-else
                  :ghost="true"
                  type="primary"
                  icon="download"
                  size="small"
                  @click="downloadFile(text)">
                  ä¸‹è½½
               </a-button>
            </template>
        <template slot="htmlSlot" slot-scope="text">
          <div v-html="text"></div>
        </template>
        <template slot="imgSlot" slot-scope="text,record">
          <span v-if="!text" style="font-size: 12px;font-style: italic;">无图片</span>
          <img v-else :src="getImgView(text)" :preview="record.id" height="25px" alt=""
               style="max-width:80px;font-size: 12px;font-style: italic;" />
        </template>
        <template slot="fileSlot" slot-scope="text">
          <span v-if="!text" style="font-size: 12px;font-style: italic;">无文件</span>
          <a-button
            v-else
            :ghost="true"
            type="primary"
            icon="download"
            size="small"
            @click="downloadFile(text)">
            ä¸‹è½½
          </a-button>
        </template>
            <span slot="action" slot-scope="text, record">
        <span slot="action" slot-scope="text, record">
          <a @click="handleEdit(record)">编辑</a>
          <a-divider type="vertical" />
@@ -61,11 +61,11 @@
          </a-dropdown>
        </span>
         </a-table>
      </div>
      </a-table>
    </div>
      <cutting-receive-detail-modal ref="modalForm" @ok="modalFormOk"></cutting-receive-detail-modal>
   </a-card>
    <cutting-receive-detail-modal ref="modalForm" @ok="modalFormOk"></cutting-receive-detail-modal>
  </a-card>
</template>
<script>
@@ -75,93 +75,93 @@
import { JeecgListMixin } from '@/mixins/JeecgListMixin'
export default {
   name: 'CuttingReceiveDetailList',
   mixins: [JeecgListMixin, mixinDevice],
   components: {},
   data() {
      return {
         description: '领用单明细管理页面',
         // è¡¨å¤´
         columns: [
            {
               title: '#',
               dataIndex: '',
               key: 'rowIndex',
               width: 60,
               align: 'center',
               customRender: function(t, r, index) {
                  return parseInt(index) + 1
               }
            },
            {
               title: '刀具编码',
               align: 'center',
               dataIndex: 'cuttingCode'
            },
            {
               title: '刀具名称',
               align: 'center',
               dataIndex: 'cuttingName'
            },
            {
               title: '刀具条码',
               align: 'center',
               dataIndex: 'cuttingBarcode'
            },
            {
               title: '工件材质',
               align: 'center',
               dataIndex: 'workpieceMaterial'
            },
            {
               title: '使用寿命',
               align: 'center',
               dataIndex: 'usedLife'
            }
         ],
         url: {
            list: '/cms/cuttingReceive/detailList',
            delete: '/cms/cuttingReceiveDetail/delete',
            deleteBatch: '/cms/cuttingReceiveDetail/deleteBatch',
            exportXlsUrl: '/cms/cuttingReceiveDetail/exportXls',
            importExcelUrl: 'cms/cuttingReceiveDetail/importExcel'
  name: 'CuttingReceiveDetailList',
  mixins: [JeecgListMixin, mixinDevice],
  components: {},
  data() {
    return {
      description: '领用单明细管理页面',
      // è¡¨å¤´
      columns: [
        {
          title: '#',
          dataIndex: '',
          key: 'rowIndex',
          width: 60,
          align: 'center',
          customRender: function(t, r, index) {
            return parseInt(index) + 1
          }
        },
        {
          title: '刀具编码',
          align: 'center',
          dataIndex: 'cuttingCode'
        },
        {
          title: '刀具名称',
          align: 'center',
          dataIndex: 'cuttingName'
        },
        {
          title: '刀具条码',
          align: 'center',
          dataIndex: 'cuttingBarcode'
        },
        {
          title: '工件材质',
          align: 'center',
          dataIndex: 'workpieceMaterial'
        },
        {
          title: '使用寿命',
          align: 'center',
          dataIndex: 'usedLife'
        }
      ],
      url: {
        list: '/cms/cuttingReceive/detailList',
        delete: '/cms/cuttingReceiveDetail/delete',
        deleteBatch: '/cms/cuttingReceiveDetail/deleteBatch',
        exportXlsUrl: '/cms/cuttingReceiveDetail/exportXls',
        importExcelUrl: 'cms/cuttingReceiveDetail/importExcel'
         },
         dictOptions: {},
         superFieldList: [],
         disableMixinCreated: true
      }
   },
   created() {
      this.getSuperFieldList()
   },
   computed: {
      importExcelUrl: function() {
         return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`
      }
   },
   methods: {
      initDictConfig() {
      },
      getSuperFieldList() {
         let fieldList = []
         fieldList.push({ type: 'string', value: 'orderId', text: '领用单ID' })
         fieldList.push({ type: 'string', value: 'cuttingId', text: '刀具ID' })
         fieldList.push({ type: 'string', value: 'cuttingCode', text: '刀具编码' })  // æ·»åŠ è¿™ä¸€è¡Œ
         fieldList.push({ type: 'string', value: 'cuttingName', text: '刀具名称' })  // æ·»åŠ è¿™ä¸€è¡Œ
         fieldList.push({ type: 'string', value: 'cuttingBarcode', text: '刀具条码' })  // æ·»åŠ è¿™ä¸€è¡Œ
         fieldList.push({ type: 'string', value: 'inventoryId', text: '库存ID' })
         fieldList.push({ type: 'string', value: 'workpieceMaterial', text: '工件材质' })
         fieldList.push({ type: 'int', value: 'usedLife', text: '使用寿命' })
         this.superFieldList = fieldList
      }
   },
   mounted() {
      this.$bus.$on('getToolingStorageData', (data) => {
         this.queryParam.orderId = data.id
         this.searchQuery()
      })
   }
      dictOptions: {},
      superFieldList: [],
      disableMixinCreated: true
    }
  },
  created() {
    this.getSuperFieldList()
  },
  computed: {
    importExcelUrl: function() {
      return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`
    }
  },
  methods: {
    initDictConfig() {
    },
    getSuperFieldList() {
      let fieldList = []
      fieldList.push({ type: 'string', value: 'orderId', text: '领用单ID' })
      fieldList.push({ type: 'string', value: 'cuttingId', text: '刀具ID' })
      fieldList.push({ type: 'string', value: 'cuttingCode', text: '刀具编码' })  // æ·»åŠ è¿™ä¸€è¡Œ
      fieldList.push({ type: 'string', value: 'cuttingName', text: '刀具名称' })  // æ·»åŠ è¿™ä¸€è¡Œ
      fieldList.push({ type: 'string', value: 'cuttingBarcode', text: '刀具条码' })  // æ·»åŠ è¿™ä¸€è¡Œ
      fieldList.push({ type: 'string', value: 'inventoryId', text: '库存ID' })
      fieldList.push({ type: 'string', value: 'workpieceMaterial', text: '工件材质' })
      fieldList.push({ type: 'int', value: 'usedLife', text: '使用寿命' })
      this.superFieldList = fieldList
    }
  },
  mounted() {
    this.$bus.$on('getToolingStorageData', (data) => {
      this.queryParam.orderId = data.id
      this.searchQuery()
    })
  }
}
</script>
<style scoped>
src/views/cms/CuttingReceiveList.vue
@@ -1,126 +1,126 @@
<template>
   <a-card :bordered="false">
      <!-- æŸ¥è¯¢åŒºåŸŸ -->
      <div class="table-page-search-wrapper">
         <a-form layout="inline" @keyup.enter.native="searchQuery">
            <a-row :gutter="24">
               <a-col :md="6" :sm="8">
                  <a-form-item label="领用单状态">
                     <j-search-select-tag
                        placeholder="请选择领用单状态"
                        v-model="queryParam.orderStatus"
                        dict="order_status"
                     />
                  </a-form-item>
               </a-col>
               <a-col :md="6" :sm="8">
                  <a-form-item label="领用人">
                     <j-search-select-tag
                        placeholder="请选择领用人"
                        v-model="queryParam.receiver"
                        dict="sys_user,realname,id,del_flag!=1"
                     />
                  </a-form-item>
               </a-col>
               <a-col
                  :md="6"
                  :sm="8"
               >
  <a-card :bordered="false">
    <!-- æŸ¥è¯¢åŒºåŸŸ -->
    <div class="table-page-search-wrapper">
      <a-form layout="inline" @keyup.enter.native="searchQuery">
        <a-row :gutter="24">
          <a-col :md="6" :sm="8">
            <a-form-item label="领用单状态">
              <j-search-select-tag
                placeholder="请选择领用单状态"
                v-model="queryParam.orderStatus"
                dict="order_status"
              />
            </a-form-item>
          </a-col>
          <a-col :md="6" :sm="8">
            <a-form-item label="领用人">
              <j-search-select-tag
                placeholder="请选择领用人"
                v-model="queryParam.receiver"
                dict="sys_user,realname,id,del_flag!=1"
              />
            </a-form-item>
          </a-col>
          <a-col
            :md="6"
            :sm="8"
          >
            <span
               style="float: left;overflow: hidden;"
               class="table-page-search-submitButtons"
              style="float: left;overflow: hidden;"
              class="table-page-search-submitButtons"
            >
              <a-button
                 type="primary"
                 @click="searchQuery"
                 icon="search"
                type="primary"
                @click="searchQuery"
                icon="search"
              >查询</a-button>
              <a-button
                 type="primary"
                 @click="searchReset"
                 icon="reload"
                 style="margin-left: 8px"
                type="primary"
                @click="searchReset"
                icon="reload"
                style="margin-left: 8px"
              >重置</a-button>
            </span>
               </a-col>
            </a-row>
         </a-form>
      </div>
      <!-- æŸ¥è¯¢åŒºåŸŸ-END -->
          </a-col>
        </a-row>
      </a-form>
    </div>
    <!-- æŸ¥è¯¢åŒºåŸŸ-END -->
      <!-- æ“ä½œæŒ‰é’®åŒºåŸŸ -->
      <div class="table-operator">
         <a-button @click="handleAdd" type="primary" icon="plus">新增</a-button>
         <!-- <a-button type="primary" icon="download" @click="handleExportXls('刀具领用单')">导出</a-button>
         <a-upload name="file" :showUploadList="false" :multiple="false" :headers="tokenHeader" :action="importExcelUrl" @change="handleImportExcel">
           <a-button type="primary" icon="import">导入</a-button>
         </a-upload> -->
    <!-- æ“ä½œæŒ‰é’®åŒºåŸŸ -->
    <div class="table-operator">
      <a-button @click="handleAdd" type="primary" icon="plus">新增</a-button>
      <!-- <a-button type="primary" icon="download" @click="handleExportXls('刀具领用单')">导出</a-button>
      <a-upload name="file" :showUploadList="false" :multiple="false" :headers="tokenHeader" :action="importExcelUrl" @change="handleImportExcel">
        <a-button type="primary" icon="import">导入</a-button>
      </a-upload> -->
    </div>
    <!-- table区域-begin -->
    <div>
      <div class="ant-alert ant-alert-info" style="margin-bottom: 16px;">
        <i class="anticon anticon-info-circle ant-alert-icon"></i> å·²é€‰æ‹© <a
        style="font-weight: 600">{{ selectedRowKeys.length }}</a>项
        <a style="margin-left: 24px" @click="onClearSelected">清空</a>
      </div>
      <!-- table区域-begin -->
      <div>
         <div class="ant-alert ant-alert-info" style="margin-bottom: 16px;">
            <i class="anticon anticon-info-circle ant-alert-icon"></i> å·²é€‰æ‹© <a
            style="font-weight: 600">{{ selectedRowKeys.length }}</a>项
            <a style="margin-left: 24px" @click="onClearSelected">清空</a>
         </div>
      <a-table
        ref="table"
        size="middle"
        :scroll="{x:true}"
        bordered
        rowKey="id"
        :columns="columns"
        :dataSource="dataSource"
        :pagination="ipagination"
        :loading="loading"
        class="j-table-force-nowrap"
        :customRow="customRow"
        @change="handleTableChange">
         <a-table
            ref="table"
            size="middle"
            :scroll="{x:true}"
            bordered
            rowKey="id"
            :columns="columns"
            :dataSource="dataSource"
            :pagination="ipagination"
            :loading="loading"
            class="j-table-force-nowrap"
            :customRow="customRow"
            @change="handleTableChange">
        <template slot="htmlSlot" slot-scope="text">
          <div v-html="text"></div>
        </template>
        <template slot="imgSlot" slot-scope="text,record">
          <span v-if="!text" style="font-size: 12px;font-style: italic;">无图片</span>
          <img v-else :src="getImgView(text)" :preview="record.id" height="25px" alt=""
               style="max-width:80px;font-size: 12px;font-style: italic;" />
        </template>
        <template slot="fileSlot" slot-scope="text">
          <span v-if="!text" style="font-size: 12px;font-style: italic;">无文件</span>
          <a-button
            v-else
            :ghost="true"
            type="primary"
            icon="download"
            size="small"
            @click="downloadFile(text)">
            ä¸‹è½½
          </a-button>
        </template>
            <template slot="htmlSlot" slot-scope="text">
               <div v-html="text"></div>
            </template>
            <template slot="imgSlot" slot-scope="text,record">
               <span v-if="!text" style="font-size: 12px;font-style: italic;">无图片</span>
               <img v-else :src="getImgView(text)" :preview="record.id" height="25px" alt=""
                    style="max-width:80px;font-size: 12px;font-style: italic;" />
            </template>
            <template slot="fileSlot" slot-scope="text">
               <span v-if="!text" style="font-size: 12px;font-style: italic;">无文件</span>
               <a-button
                  v-else
                  :ghost="true"
                  type="primary"
                  icon="download"
                  size="small"
                  @click="downloadFile(text)">
                  ä¸‹è½½
               </a-button>
            </template>
        <!--        <span slot="action" slot-scope="text, record">-->
        <!--          <a @click="handleEdit(record)">编辑</a>-->
            <!--        <span slot="action" slot-scope="text, record">-->
            <!--          <a @click="handleEdit(record)">编辑</a>-->
        <!--          <a-divider type="vertical" />-->
        <!--          <a-dropdown>-->
        <!--            <a class="ant-dropdown-link">更多 <a-icon type="down" /></a>-->
        <!--            <a-menu slot="overlay">-->
        <!--              <a-menu-item>-->
        <!--                <a @click="handleDetail(record)">详情</a>-->
        <!--              </a-menu-item>-->
        <!--              <a-menu-item>-->
        <!--                <a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record.id)">-->
        <!--                  <a>删除</a>-->
        <!--                </a-popconfirm>-->
        <!--              </a-menu-item>-->
        <!--            </a-menu>-->
        <!--          </a-dropdown>-->
        <!--        </span>-->
            <!--          <a-divider type="vertical" />-->
            <!--          <a-dropdown>-->
            <!--            <a class="ant-dropdown-link">更多 <a-icon type="down" /></a>-->
            <!--            <a-menu slot="overlay">-->
            <!--              <a-menu-item>-->
            <!--                <a @click="handleDetail(record)">详情</a>-->
            <!--              </a-menu-item>-->
            <!--              <a-menu-item>-->
            <!--                <a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record.id)">-->
            <!--                  <a>删除</a>-->
            <!--                </a-popconfirm>-->
            <!--              </a-menu-item>-->
            <!--            </a-menu>-->
            <!--          </a-dropdown>-->
            <!--        </span>-->
            <span slot="action" slot-scope="text, record">
          <a @click="handleEdit(record)" :disabled="record.orderStatus === '2'">编辑</a>
        <span slot="action" slot-scope="text, record">
          <a @click="handleEdit(record)" :disabled="record.orderStatus === '2' || record.orderStatus === '3'">编辑</a>
          <a-divider type="vertical" />
          <a-dropdown>
            <a class="ant-dropdown-link">更多 <a-icon type="down" /></a>
@@ -128,15 +128,10 @@
              <a-menu-item>
                <a @click="handleDetail(record)">详情</a>
              </a-menu-item>
               <!--              <a-menu-item v-if="record.orderStatus != '2'">-->
               <!--                <a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record.id)">-->
               <!--                  <a>删除</a>-->
               <!--                </a-popconfirm>-->
               <!--              </a-menu-item>-->
              <a-menu-item v-if="record.orderStatus !== '2'">
              <a-menu-item v-if="record.orderStatus === '1'">
                  <a @click="handleSubmit(record.id)" :disabled="record.orderStatus === '3'">提交</a>
              </a-menu-item>
              <a-menu-item v-if="record.orderStatus !== '2'">
              <a-menu-item v-if="record.orderStatus === '1'">
                <a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record.id)">
                  <a>删除</a>
                </a-popconfirm>
@@ -148,15 +143,15 @@
          </a-dropdown>
        </span>
         </a-table>
      </div>
      <a-tabs defaultActiveKey="1">
         <a-tab-pane tab="刀具领用明细" key="1">
            <cutting-receive-detail-list ref="cuttingReceiveDetailList"></cutting-receive-detail-list>
         </a-tab-pane>
      </a-tabs>
      <cutting-receive-modal ref="modalForm" @ok="modalFormOk"></cutting-receive-modal>
   </a-card>
      </a-table>
    </div>
    <a-tabs defaultActiveKey="1">
      <a-tab-pane tab="刀具领用明细" key="1">
        <cutting-receive-detail-list ref="cuttingReceiveDetailList"></cutting-receive-detail-list>
      </a-tab-pane>
    </a-tabs>
    <cutting-receive-modal ref="modalForm" @ok="modalFormOk"></cutting-receive-modal>
  </a-card>
</template>
<script>
@@ -169,232 +164,288 @@
import { httpAction } from '@api/manage'
export default {
   name: 'CuttingReceiveList',
   mixins: [JeecgListMixin, mixinDevice],
   components: {
      CuttingReceiveModal,
      CuttingReceiveDetailList
   },
   data() {
  name: 'CuttingReceiveList',
  mixins: [JeecgListMixin, mixinDevice],
  components: {
    CuttingReceiveModal,
    CuttingReceiveDetailList
  },
  data() {
    return {
      description: '刀具领用单管理页面',
      // è¡¨å¤´
      columns: [
        {
          title: '#',
          dataIndex: '',
          key: 'rowIndex',
          width: 60,
          align: 'center',
          customRender: function(t, r, index) {
            return parseInt(index) + 1
          }
        },
        {
          title: '领用人',
          align: 'center',
          dataIndex: 'receiver_dictText'
        },
        {
          title: '领用时间',
          align: 'center',
          dataIndex: 'receiveTime',
          customRender: function(text) {
            return !text ? '' : (text.length > 10 ? text.substr(0, 10) : text)
          }
        },
        {
          title: '领用说明',
          align: 'center',
          dataIndex: 'receiveComment'
        },
        {
          title: '确认人',
          align: 'center',
          dataIndex: 'confirmer_dictText'
        },
        {
          title: '确认时间',
          align: 'center',
          dataIndex: 'confirmTime',
          customRender: function(text) {
            return !text ? '' : (text.length > 10 ? text.substr(0, 10) : text)
          }
        },
        {
          title: '确认意见',
          align: 'center',
          dataIndex: 'confirmComment'
        },
        {
          title: '是否会归还',
          align: 'center',
          dataIndex: 'returnFlag'
        },
        {
          title: '归还时间',
          align: 'center',
          dataIndex: 'returnTime',
          customRender: function(text) {
            return !text ? '' : (text.length > 10 ? text.substr(0, 10) : text)
          }
        },
        {
          title: '归还说明',
          align: 'center',
          dataIndex: 'returnComment'
        },
        {
          title: '归还确认人',
          align: 'center',
          dataIndex: 'returnConfirmer_dictText'
        },
        {
          title: '归还确认时间',
          align: 'center',
          dataIndex: 'returnConfirmTime',
          customRender: function(text) {
            return !text ? '' : (text.length > 10 ? text.substr(0, 10) : text)
          }
        },
        {
          title: '归还确认意见',
          align: 'center',
          dataIndex: 'returnConfirmComment'
        },
        {
          title: '领用单状态',
          align: 'center',
          dataIndex: 'orderStatus_dictText'
        },
        {
          title: '操作',
          dataIndex: 'action',
          align: 'center',
          fixed: 'right',
          width: 147,
          scopedSlots: { customRender: 'action' }
        }
      ],
      url: {
        list: '/cms/cuttingReceive/list',
        delete: '/cms/cuttingReceive/delete',
        deleteBatch: '/cms/cuttingReceive/deleteBatch',
        exportXlsUrl: '/cms/cuttingReceive/exportXls',
        importExcelUrl: 'cms/cuttingReceive/importExcel',
        submit: '/cms/cuttingReceive/submit',
        returnBack: '/cms/cuttingReceive/handleBack'
      },
      dictOptions: {},
      superFieldList: []
    }
  },
  created() {
    this.getSuperFieldList()
  },
  computed: {
    importExcelUrl: function() {
      return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`
    }
  },
  methods: {
    searchReset() {
      this.queryParam = {}
      this.$refs.cuttingReceiveDetailList.dataSource = []
      this.loadData(1)
    },
    handleEdit: function(record) {
      this.$refs.modalForm.edit(record)
      this.$refs.modalForm.title = '编辑'
      this.$refs.modalForm.disableSubmit = false
    },
    handleAdd() {
      this.$refs.modalForm.add()
      this.$refs.modalForm.title = '新增'
      this.$refs.modalForm.disableSubmit = false
    },
    handleDetail: function(record) {
      this.$refs.modalForm.edit(record)
      this.$refs.modalForm.title = '详情'
      this.$refs.modalForm.disableSubmit = true
    },
    customRow(record) {
      return {
         description: '刀具领用单管理页面',
         // è¡¨å¤´
         columns: [
            {
               title: '#',
               dataIndex: '',
               key: 'rowIndex',
               width: 60,
               align: 'center',
               customRender: function(t, r, index) {
                  return parseInt(index) + 1
               }
            },
            {
               title: '领用人',
               align: 'center',
               dataIndex: 'receiver_dictText'
            },
            {
               title: '领用时间',
               align: 'center',
               dataIndex: 'receiveTime',
               customRender: function(text) {
                  return !text ? '' : (text.length > 10 ? text.substr(0, 10) : text)
               }
            },
            {
               title: '领用说明',
               align: 'center',
               dataIndex: 'receiveComment'
            },
            {
               title: '确认人',
               align: 'center',
               dataIndex: 'confirmer_dictText'
            },
            {
               title: '确认时间',
               align: 'center',
               dataIndex: 'confirmTime',
               customRender: function(text) {
                  return !text ? '' : (text.length > 10 ? text.substr(0, 10) : text)
               }
            },
            {
               title: '确认意见',
               align: 'center',
               dataIndex: 'confirmComment'
            },
            {
               title: '是否会归还',
               align: 'center',
               dataIndex: 'returnFlag'
            },
            {
               title: '归还时间',
               align: 'center',
               dataIndex: 'returnTime',
               customRender: function(text) {
                  return !text ? '' : (text.length > 10 ? text.substr(0, 10) : text)
               }
            },
            {
               title: '归还说明',
               align: 'center',
               dataIndex: 'returnComment'
            },
            {
               title: '归还确认人',
               align: 'center',
               dataIndex: 'returnConfirmer_dictText'
            },
            {
               title: '归还确认时间',
               align: 'center',
               dataIndex: 'returnConfirmTime',
               customRender: function(text) {
                  return !text ? '' : (text.length > 10 ? text.substr(0, 10) : text)
               }
            },
            {
               title: '归还确认意见',
               align: 'center',
               dataIndex: 'returnConfirmComment'
            },
            {
               title: '领用单状态',
               align: 'center',
               dataIndex: 'orderStatus_dictText'
            },
            {
               title: '操作',
               dataIndex: 'action',
               align: 'center',
               fixed: 'right',
               width: 147,
               scopedSlots: { customRender: 'action' }
        on: {
          click: (e) => {
            //将当前选中的记录传到子页面
            this.$bus.$emit('getToolingStorageData', record)
            //点击当前行变色
            let oldList = document.querySelectorAll('.checked-td-of-add-table')
            if (oldList) {
              for (let j = 0; j < oldList.length; j++) {
                oldList[j].classList.remove('checked-td-of-add-table')
              }
            }
         ],
         url: {
            list: '/cms/cuttingReceive/list',
            delete: '/cms/cuttingReceive/delete',
            deleteBatch: '/cms/cuttingReceive/deleteBatch',
            exportXlsUrl: '/cms/cuttingReceive/exportXls',
            importExcelUrl: 'cms/cuttingReceive/importExcel',
            submit: '/cms/cuttingReceive/submit'
         },
         dictOptions: {},
         superFieldList: []
      }
   },
   created() {
      this.getSuperFieldList()
   },
   computed: {
      importExcelUrl: function() {
         return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`
      }
   },
   methods: {
      searchReset() {
         this.queryParam = {}
         this.$refs.cuttingReceiveDetailList.dataSource = []
         this.loadData(1)
      },
      handleEdit: function(record) {
         this.$refs.modalForm.edit(record)
         this.$refs.modalForm.title = '编辑'
         this.$refs.modalForm.disableSubmit = false
      },
      handleAdd() {
         this.$refs.modalForm.add()
         this.$refs.modalForm.title = '新增'
         this.$refs.modalForm.disableSubmit = false
      },
      handleDetail: function(record) {
         this.$refs.modalForm.edit(record)
         this.$refs.modalForm.title = '详情'
         this.$refs.modalForm.disableSubmit = true
      },
      customRow(record) {
         return {
            on: {
               click: (e) => {
                  //将当前选中的记录传到子页面
                  this.$bus.$emit('getToolingStorageData', record)
                  //点击当前行变色
                  let oldList = document.querySelectorAll('.checked-td-of-add-table')
                  if (oldList) {
                     for (let j = 0; j < oldList.length; j++) {
                        oldList[j].classList.remove('checked-td-of-add-table')
                     }
                  }
                  let children = e.target.parentNode.children
                  for (let i = 0; i < children.length; i++) {
                     children[i].classList.add('checked-td-of-add-table')
                  }
               }
            let children = e.target.parentNode.children
            for (let i = 0; i < children.length; i++) {
              children[i].classList.add('checked-td-of-add-table')
            }
         }
      },
          }
        }
      }
    },
      /**
       *  å•据提交
       */
      handleSubmit: function(id) {
         if (!this.url.submit) {
            this.$message.error('请设置url.submit属性!')
            return
         }
    /**
     *  å•据提交
     */
    handleSubmit: function(id) {
      if (!this.url.submit) {
        this.$message.error('请设置url.submit属性!')
        return
      }
         let targetId = id // ä»Žå‚数获取ID
         // å¦‚果没有通过参数传递ID,则检查选中的记录
         if (!targetId) {
            if (this.selectedRowKeys.length != 1) {
               this.$message.warning('请选择一条记录!')
               return
      let targetId = id // ä»Žå‚数获取ID
      // å¦‚果没有通过参数传递ID,则检查选中的记录
      if (!targetId) {
        if (this.selectedRowKeys.length != 1) {
          this.$message.warning('请选择一条记录!')
          return
        } else {
          targetId = this.selectedRowKeys[0]
        }
      }
      // å°†å‚数作为查询参数附加到URL上
      let httpurl = this.url.submit + '?orderId=' + encodeURIComponent(targetId)
      let method = 'get'
      var params = {}  // æ¸…空params,因为参数已经在URL中传递
      const that = this
      this.$confirm({
        title: '确认提交!',
        // content: '正在提交数据,请耐心等待...',
        okText: '确认',
        cancelText: '取消',
        onOk() {
          // æ˜¾ç¤ºåŠ è½½æç¤º
          const hide = that.$message.loading('正在提交数据,请耐心等待...', 0)
          // å‘送请求
          return httpAction(httpurl, params, method).then((res) => {
            hide() // éšè—åŠ è½½æç¤º
            if (res.success) {
              that.$message.success(res.message)
              that.loadData()
            } else {
               targetId = this.selectedRowKeys[0]
              that.$message.warning(res.message)
            }
         }
          }).catch(error => {
            hide() // éšè—åŠ è½½æç¤º
            that.$message.error('提交失败: ' + error.message)
          }).finally(() => {
            that.loading = false
          })
        }
      })
    },
         // å°†å‚数作为查询参数附加到URL上
         let httpurl = this.url.submit + '?orderId=' + encodeURIComponent(targetId)
         let method = 'get'
         var params = {}  // æ¸…空params,因为参数已经在URL中传递
    /**
     *  å•据领用
     */
         const that = this
    handleBack: function(id) {
      if (!this.url.returnBack) {
        this.$message.error('请设置url.return属性!')
        return
      }
         this.$confirm({
            title: '确认提交!',
            // content: '正在提交数据,请耐心等待...',
            okText: '确认',
            cancelText: '取消',
            onOk() {
               // æ˜¾ç¤ºåŠ è½½æç¤º
               const hide = that.$message.loading('正在提交数据,请耐心等待...', 0)
      let targetId = id // ä»Žå‚数获取ID
      // å¦‚果没有通过参数传递ID,则检查选中的记录
      if (!targetId) {
        if (this.selectedRowKeys.length != 1) {
          this.$message.warning('请选择一条记录!')
          return
        } else {
          targetId = this.selectedRowKeys[0]
        }
      }
               // å‘送请求
               return httpAction(httpurl, params, method).then((res) => {
                  hide() // éšè—åŠ è½½æç¤º
                  if (res.success) {
                     that.$message.success(res.message)
                     that.loadData()
                  } else {
                     that.$message.warning(res.message)
                  }
               }).catch(error => {
                  hide() // éšè—åŠ è½½æç¤º
                  that.$message.error('提交失败: ' + error.message)
               }).finally(() => {
                  that.loading = false
               })
      // å°†å‚数作为查询参数附加到URL上
      let httpurl = this.url.returnBack + '?orderId=' + encodeURIComponent(targetId)
      let method = 'get'
      var params = {}  // æ¸…空params,因为参数已经在URL中传递
      const that = this
      this.$confirm({
        title: '确认提交!',
        // content: '正在提交数据,请耐心等待...',
        okText: '确认',
        cancelText: '取消',
        onOk() {
          // æ˜¾ç¤ºåŠ è½½æç¤º
          const hide = that.$message.loading('正在提交数据,请耐心等待...', 0)
          // å‘送请求
          return httpAction(httpurl, params, method).then((res) => {
            hide() // éšè—åŠ è½½æç¤º
            if (res.success) {
              that.$message.success(res.message)
              that.loadData()
            } else {
              that.$message.warning(res.message)
            }
         })
      },
      //TODO:刀具归还 handleBack
   }
          }).catch(error => {
            hide() // éšè—åŠ è½½æç¤º
            that.$message.error('提交失败: ' + error.message)
          }).finally(() => {
            that.loading = false
          })
        }
      })
    }
  }
}
</script>
<style scoped>
src/views/cms/CuttingScrapDetailList.vue
@@ -11,7 +11,7 @@
    <!-- æ“ä½œæŒ‰é’®åŒºåŸŸ -->
    <div class="table-operator">
      <a-button @click="handleAdd" type="primary" icon="plus">新增</a-button>
<!--      <a-button @click="handleAdd" type="primary" icon="plus">新增</a-button>-->
      <!-- <a-button type="primary" icon="download" @click="handleExportXls('刀具报废明细')">导出</a-button>
      <a-upload name="file" :showUploadList="false" :multiple="false" :headers="tokenHeader" :action="importExcelUrl" @change="handleImportExcel">
        <a-button type="primary" icon="import">导入</a-button>
@@ -76,7 +76,6 @@
            </a-menu>
          </a-dropdown>
        </span>
      </a-table>
    </div>
@@ -137,7 +136,7 @@
          deleteBatch: "/cms/cuttingScrapDetail/deleteBatch",
          exportXlsUrl: "/cms/cuttingScrapDetail/exportXls",
          importExcelUrl: "cms/cuttingScrapDetail/importExcel",
        },
        dictOptions:{},
        superFieldList:[],
src/views/cms/CuttingScrapList.vue
@@ -7,22 +7,22 @@
          <a-col :md="6" :sm="8">
            <a-form-item label="报废单状态">
              <j-search-select-tag
                  placeholder="请选择报废单状态"
                  v-model="queryParam.orderStatus"
                  dict="order_status"
                />
                placeholder="请选择报废单状态"
                v-model="queryParam.orderStatus"
                dict="order_status"
              />
            </a-form-item>
          </a-col>
          <a-col :md="6" :sm="8">
              <a-form-item label="申请人">
                <j-search-select-tag
                  placeholder="请选择申请人"
                  v-model="queryParam.applicant"
                  dict="sys_user,realname,id,del_flag!=1"
                />
              </a-form-item>
            </a-col>
            <a-col
            <a-form-item label="申请人">
              <j-search-select-tag
                placeholder="请选择申请人"
                v-model="queryParam.applicant"
                dict="sys_user,realname,id,del_flag!=1"
              />
            </a-form-item>
          </a-col>
          <a-col
            :md="6"
            :sm="8"
          >
@@ -60,7 +60,8 @@
    <!-- table区域-begin -->
    <div>
      <div class="ant-alert ant-alert-info" style="margin-bottom: 16px;">
        <i class="anticon anticon-info-circle ant-alert-icon"></i> å·²é€‰æ‹© <a style="font-weight: 600">{{ selectedRowKeys.length }}</a>项
        <i class="anticon anticon-info-circle ant-alert-icon"></i> å·²é€‰æ‹© <a
        style="font-weight: 600">{{ selectedRowKeys.length }}</a>项
        <a style="margin-left: 24px" @click="onClearSelected">清空</a>
      </div>
@@ -83,7 +84,8 @@
        </template>
        <template slot="imgSlot" slot-scope="text,record">
          <span v-if="!text" style="font-size: 12px;font-style: italic;">无图片</span>
          <img v-else :src="getImgView(text)" :preview="record.id" height="25px" alt="" style="max-width:80px;font-size: 12px;font-style: italic;"/>
          <img v-else :src="getImgView(text)" :preview="record.id" height="25px" alt=""
               style="max-width:80px;font-size: 12px;font-style: italic;" />
        </template>
        <template slot="fileSlot" slot-scope="text">
          <span v-if="!text" style="font-size: 12px;font-style: italic;">无文件</span>
@@ -108,6 +110,11 @@
              <a-menu-item>
                <a @click="handleDetail(record)">详情</a>
              </a-menu-item>
              <a-menu-item v-if="record.orderStatus != '2'">
                  <a @click="handleSubmit(record.id)" :disabled="record.orderStatus == '3'">提交</a>
              </a-menu-item>
              <a-menu-item>
                <a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record.id)">
                  <a>删除</a>
@@ -119,7 +126,7 @@
      </a-table>
    </div>
<a-tabs defaultActiveKey="1">
    <a-tabs defaultActiveKey="1">
      <a-tab-pane tab="刀具报废明细" key="1">
        <cutting-scrap-detail-list ref="cuttingScrapDetailList"></cutting-scrap-detail-list>
      </a-tab-pane>
@@ -130,126 +137,181 @@
<script>
  import '@/assets/less/TableExpand.less'
  import { mixinDevice } from '@/utils/mixin'
  import { JeecgListMixin } from '@/mixins/JeecgListMixin'
  import CuttingScrapModal from './modules/CuttingScrapModal'
  import CuttingScrapDetailList from './CuttingScrapDetailList'
import '@/assets/less/TableExpand.less'
import { mixinDevice } from '@/utils/mixin'
import { JeecgListMixin } from '@/mixins/JeecgListMixin'
import CuttingScrapModal from './modules/CuttingScrapModal'
import CuttingScrapDetailList from './CuttingScrapDetailList'
import { httpAction } from '@api/manage'
  export default {
    name: 'CuttingScrapList',
    mixins:[JeecgListMixin, mixinDevice],
    components: {
      CuttingScrapModal,
      CuttingScrapDetailList
    },
    data () {
      return {
        description: '刀具报废管理页面',
        // è¡¨å¤´
        columns: [
          {
            title: '#',
            dataIndex: '',
            key:'rowIndex',
            width:60,
            align:"center",
            customRender:function (t,r,index) {
              return parseInt(index)+1;
            }
          },
          {
            title:'申请人',
            align:"center",
            dataIndex: 'applicant_dictText'
          },
          {
            title:'申请时间',
            align:"center",
            dataIndex: 'applicationTime',
            customRender:function (text) {
              return !text?"":(text.length>10?text.substr(0,10):text)
            }
          },
          {
            title:'申请说明',
            align:"center",
            dataIndex: 'applicationComment'
          },
          {
            title:'确认人',
            align:"center",
            dataIndex: 'confirmer_dictText'
          },
          {
            title:'确认时间',
            align:"center",
            dataIndex: 'confirmTime',
            customRender:function (text) {
              return !text?"":(text.length>10?text.substr(0,10):text)
            }
          },
          {
            title:'确认意见',
            align:"center",
            dataIndex: 'confirmComment'
          },
           {
            title:'报废单状态',
            align:"center",
            dataIndex: 'orderStatus'
          },
          {
            title: '操作',
            dataIndex: 'action',
            align:"center",
            fixed:"right",
            width:147,
            scopedSlots: { customRender: 'action' }
export default {
  name: 'CuttingScrapList',
  mixins: [JeecgListMixin, mixinDevice],
  components: {
    CuttingScrapModal,
    CuttingScrapDetailList
  },
  data() {
    return {
      description: '刀具报废管理页面',
      // è¡¨å¤´
      columns: [
        {
          title: '#',
          dataIndex: '',
          key: 'rowIndex',
          width: 60,
          align: 'center',
          customRender: function(t, r, index) {
            return parseInt(index) + 1
          }
        ],
        url: {
          list: "/cms/cuttingScrap/list",
          delete: "/cms/cuttingScrap/delete",
          deleteBatch: "/cms/cuttingScrap/deleteBatch",
          exportXlsUrl: "/cms/cuttingScrap/exportXls",
          importExcelUrl: "cms/cuttingScrap/importExcel",
        },
        dictOptions:{},
        superFieldList:[],
      }
    },
    created() {
    this.getSuperFieldList();
    },
    computed: {
      importExcelUrl: function(){
        return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`;
        {
          title: '申请人',
          align: 'center',
          dataIndex: 'applicant_dictText'
        },
        {
          title: '申请时间',
          align: 'center',
          dataIndex: 'applicationTime',
          customRender: function(text) {
            return !text ? '' : (text.length > 10 ? text.substr(0, 10) : text)
          }
        },
        {
          title: '申请说明',
          align: 'center',
          dataIndex: 'applicationComment'
        },
        {
          title: '确认人',
          align: 'center',
          dataIndex: 'confirmer_dictText'
        },
        {
          title: '确认时间',
          align: 'center',
          dataIndex: 'confirmTime',
          customRender: function(text) {
            return !text ? '' : (text.length > 10 ? text.substr(0, 10) : text)
          }
        },
        {
          title: '确认意见',
          align: 'center',
          dataIndex: 'confirmComment'
        },
        {
          title: '报废单状态',
          align: 'center',
          dataIndex: 'orderStatus_dictText'
        },
        {
          title: '操作',
          dataIndex: 'action',
          align: 'center',
          fixed: 'right',
          width: 147,
          scopedSlots: { customRender: 'action' }
        }
      ],
      url: {
        list: '/cms/cuttingScrap/list',
        delete: '/cms/cuttingScrap/delete',
        deleteBatch: '/cms/cuttingScrap/deleteBatch',
        exportXlsUrl: '/cms/cuttingScrap/exportXls',
        importExcelUrl: 'cms/cuttingScrap/importExcel'
      },
    },
    methods: {
     searchReset() {
      dictOptions: {},
      superFieldList: []
    }
  },
  created() {
    this.getSuperFieldList()
  },
  computed: {
    importExcelUrl: function() {
      return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`
    }
  },
  methods: {
    searchReset() {
      this.queryParam = {}
      this.$refs.cuttingScrapDetailList.dataSource = []
      this.loadData(1);
      this.loadData(1)
    },
      handleEdit: function (record) {
        this.$refs.modalForm.edit(record)
        this.$refs.modalForm.title = '编辑'
        this.$refs.modalForm.disableSubmit = false
    handleEdit: function(record) {
      this.$refs.modalForm.edit(record)
      this.$refs.modalForm.title = '编辑'
      this.$refs.modalForm.disableSubmit = false
    },
    handleAdd() {
      this.$refs.modalForm.add()
      this.$refs.modalForm.title = '新增'
      this.$refs.modalForm.disableSubmit = false
    },
    handleDetail:function(record){
      this.$refs.modalForm.edit(record);
      this.$refs.modalForm.title="详情";
      this.$refs.modalForm.disableSubmit = true;
    handleDetail: function(record) {
      this.$refs.modalForm.edit(record)
      this.$refs.modalForm.title = '详情'
      this.$refs.modalForm.disableSubmit = true
    },
     customRow(record) {
    //  å•据提交
    handleSubmit: function(id) {
      if (!this.url.submit) {
        this.$message.error('请设置url.submit属性!')
        return
      }
      let targetId = id // ä»Žå‚数获取ID
      // å¦‚果没有通过参数传递ID,则检查选中的记录
      if (!targetId) {
        if (this.selectedRowKeys.length != 1) {
          this.$message.warning('请选择一条记录!')
          return
        } else {
          targetId = this.selectedRowKeys[0]
        }
      }
      // å°†å‚数作为查询参数附加到URL上
      let httpurl = this.url.submit + '?orderId=' + encodeURIComponent(targetId)
      let method = 'get'
      var params = {}  // æ¸…空params,因为参数已经在URL中传递
      const that = this
      this.$confirm({
        title: '确认提交!',
        // content: '正在提交数据,请耐心等待...',
        okText: '确认',
        cancelText: '取消',
        onOk() {
          // æ˜¾ç¤ºåŠ è½½æç¤º
          const hide = that.$message.loading('正在提交数据,请耐心等待...', 0)
          // å‘送请求
          return httpAction(httpurl, params, method).then((res) => {
            hide() // éšè—åŠ è½½æç¤º
            if (res.success) {
              that.$message.success(res.message)
              that.loadData()
            } else {
              that.$message.warning(res.message)
            }
          }).catch(error => {
            hide() // éšè—åŠ è½½æç¤º
            that.$message.error('提交失败: ' + error.message)
          }).finally(() => {
            that.loading = false
          })
        }
      })
    },
    customRow(record) {
      return {
        on: {
          click: (e) => {
@@ -266,13 +328,13 @@
            for (let i = 0; i < children.length; i++) {
              children[i].classList.add('checked-td-of-add-table')
            }
          },
        },
          }
        }
      }
    },
    }
  }
}
</script>
<style scoped>
  @import '~@assets/less/common.less';
@import '~@assets/less/common.less';
</style>
src/views/cms/modules/CuttingReceiveModal.vue
@@ -1,165 +1,165 @@
<template>
   <a-modal :title="title" :visible="visible" :fullScreen="true" :width="1200" @ok="handleOk" @cancel="handleCancel">
      <a-spin :spinning="confirmLoading">
         <a-form :form="form">
            <a-row style="width: 100%">
               <a-col :span="24 / 2">
                  <a-form-item label="领用人" :labelCol="labelCol" :wrapperCol="wrapperCol">
                     <j-search-select-tag
                        :disabled="disableSubmit"
                        placeholder="请选择领用人"
                        v-decorator="['receiver', { rules: [{ required: true, message: '请选择领用人' }] }]"
                        dict="sys_user,realname,id,del_flag=0"
                     />
                  </a-form-item>
               </a-col>
               <a-col :span="24 / 2">
                  <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="领用日期">
                     <a-date-picker
                        :disabled="disableSubmit"
                        style="width: 100%"
                        v-decorator="['receiveTime', validatorRules.receiveTime]"
                     />
                  </a-form-item>
               </a-col>
            </a-row>
            <a-row style="width: 100%">
               <a-col :span="24">
                  <a-form-item label="领用说明" :labelCol="{span:3}" :wrapperCol="{span:21}">
                     <a-textarea :disabled="disableSubmit" placeholder="请输入领用说明"
                                 v-decorator="['receiveComment', validatorRules.receiveComment]" />
                  </a-form-item>
               </a-col>
            </a-row>
            <a-row style="width: 100%">
               <a-col :span="24 / 2">
                  <a-form-item label="确认人" :labelCol="labelCol" :wrapperCol="wrapperCol">
                     <j-search-select-tag
                        :disabled="disableSubmit"
                        placeholder="请选择确认人"
                        v-decorator="['confirmer', { rules: [{ required: false, message: '请选择确认人' }] }]"
                        dict="sys_user,realname,id,del_flag=0"
                     />
                  </a-form-item>
               </a-col>
               <a-col :span="24 / 2">
                  <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="确认日期">
                     <a-date-picker
                        :disabled="disableSubmit"
                        style="width: 100%"
                        v-decorator="['confirmTime', validatorRules.confirmTime]"
                     />
                  </a-form-item>
               </a-col>
            </a-row>
            <a-row style="width: 100%">
               <a-col :span="24">
                  <a-form-item label="确认意见" :labelCol="{span:3}" :wrapperCol="{span:21}">
                     <a-textarea :disabled="disableSubmit" placeholder="请输入确认意见"
                                 v-decorator="['confirmComment', validatorRules.confirmComment]" />
                  </a-form-item>
               </a-col>
            </a-row>
            <a-row style="width: 100%">
               <a-col :span="24 / 2">
                  <a-form-item label="是否会归还" :labelCol="labelCol" :wrapperCol="wrapperCol">
                     <a-input :disabled="disableSubmit" placeholder="请输入是否会归还"
                              v-decorator="['returnFlag', validatorRules.returnFlag]"></a-input>
                  </a-form-item>
               </a-col>
               <a-col :span="24 / 2">
                  <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="归还日期">
                     <a-date-picker
                        :disabled="disableSubmit"
                        style="width: 100%"
                        v-decorator="['returnTime', validatorRules.returnTime]"
                     />
                  </a-form-item>
               </a-col>
            </a-row>
            <a-row style="width: 100%">
               <a-col :span="24">
                  <a-form-item label="归还说明" :labelCol="{span:3}" :wrapperCol="{span:21}">
                     <a-textarea :disabled="disableSubmit" placeholder="请输入归还说明"
                                 v-decorator="['returnComment', validatorRules.returnComment]" />
                  </a-form-item>
               </a-col>
            </a-row>
            <a-row style="width: 100%">
               <a-col :span="24 / 2">
                  <a-form-item label="归还确认人" :labelCol="labelCol" :wrapperCol="wrapperCol">
                     <j-search-select-tag
                        :disabled="disableSubmit"
                        placeholder="请选择归还确认人"
                        v-decorator="['returnConfirmer', { rules: [{ required: false, message: '请选择归还确认人' }] }]"
                        dict="sys_user,realname,id,del_flag=0"
                     />
                  </a-form-item>
               </a-col>
               <a-col :span="24 / 2">
                  <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="归还确认日期">
                     <a-date-picker
                        :disabled="disableSubmit"
                        style="width: 100%"
                        v-decorator="['returnConfirmTime', validatorRules.returnConfirmTime]"
                     />
                  </a-form-item>
               </a-col>
            </a-row>
            <a-row style="width: 100%">
               <a-col :span="24">
                  <a-form-item label="归还确认意见" :labelCol="{span:3}" :wrapperCol="{span:21}">
                     <a-textarea :disabled="disableSubmit" placeholder="请输入归还确认意见"
                                 v-decorator="['returnConfirmComment', validatorRules.returnConfirmComment]" />
                  </a-form-item>
               </a-col>
            </a-row>
         </a-form>
      </a-spin>
      <a-button type="primary" :style="{ marginBottom: '8px' }" @click="selectTooling()">选择库存刀具</a-button>
      <a-table
         ref="table"
         bordered
         size="middle"
         rowKey="id"
         :columns="columns"
         :dataSource="dataSource"
         :pagination="ipagination"
         :loading="loading"
      >
         <template v-for="col in columns" :slot="col.dataIndex" slot-scope="text, record, index">
            <div :key="col.dataIndex">
               <a-input
                  :value="text"
                  :disabled="disableSubmit"
                  v-if="col.dataIndex === 'workpieceMaterial'"
                  @change="(e)=>handleChange(e.target.value, record.key, col, index)"
               />
               <a-input-number
                  v-if="col.dataIndex === 'usedLife'"
                  :value="text"
                  @change="(e) => handleChange(e, record.key, col, index)"
                  :min="1"
               />
            </div>
         </template>
         <span slot="action" slot-scope="text, record, index">
  <a-modal :title="title" :visible="visible" :fullScreen="true" :width="1200" @ok="handleOk" @cancel="handleCancel">
    <a-spin :spinning="confirmLoading">
      <a-form :form="form">
        <a-row style="width: 100%">
          <a-col :span="24 / 2">
            <a-form-item label="领用人" :labelCol="labelCol" :wrapperCol="wrapperCol">
              <j-search-select-tag
                :disabled="disableSubmit"
                placeholder="请选择领用人"
                v-decorator="['receiver', { rules: [{ required: true, message: '请选择领用人' }] }]"
                dict="sys_user,realname,id,del_flag=0"
              />
            </a-form-item>
          </a-col>
          <a-col :span="24 / 2">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="领用日期">
              <a-date-picker
                :disabled="disableSubmit"
                style="width: 100%"
                v-decorator="['receiveTime', validatorRules.receiveTime]"
              />
            </a-form-item>
          </a-col>
        </a-row>
        <a-row style="width: 100%">
          <a-col :span="24">
            <a-form-item label="领用说明" :labelCol="{span:3}" :wrapperCol="{span:21}">
              <a-textarea :disabled="disableSubmit" placeholder="请输入领用说明"
                          v-decorator="['receiveComment', validatorRules.receiveComment]" />
            </a-form-item>
          </a-col>
        </a-row>
        <a-row style="width: 100%">
          <a-col :span="24 / 2">
            <a-form-item label="确认人" :labelCol="labelCol" :wrapperCol="wrapperCol">
              <j-search-select-tag
                :disabled="disableSubmit"
                placeholder="请选择确认人"
                v-decorator="['confirmer', { rules: [{ required: false, message: '请选择确认人' }] }]"
                dict="sys_user,realname,id,del_flag=0"
              />
            </a-form-item>
          </a-col>
          <a-col :span="24 / 2">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="确认日期">
              <a-date-picker
                :disabled="disableSubmit"
                style="width: 100%"
                v-decorator="['confirmTime', validatorRules.confirmTime]"
              />
            </a-form-item>
          </a-col>
        </a-row>
        <a-row style="width: 100%">
          <a-col :span="24">
            <a-form-item label="确认意见" :labelCol="{span:3}" :wrapperCol="{span:21}">
              <a-textarea :disabled="disableSubmit" placeholder="请输入确认意见"
                          v-decorator="['confirmComment', validatorRules.confirmComment]" />
            </a-form-item>
          </a-col>
        </a-row>
        <a-row style="width: 100%">
          <a-col :span="24 / 2">
            <a-form-item label="是否会归还" :labelCol="labelCol" :wrapperCol="wrapperCol">
              <a-input :disabled="disableSubmit" placeholder="请输入是否会归还"
                       v-decorator="['returnFlag', validatorRules.returnFlag]"></a-input>
            </a-form-item>
          </a-col>
          <a-col :span="24 / 2">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="归还日期">
              <a-date-picker
                :disabled="disableSubmit"
                style="width: 100%"
                v-decorator="['returnTime', validatorRules.returnTime]"
              />
            </a-form-item>
          </a-col>
        </a-row>
        <a-row style="width: 100%">
          <a-col :span="24">
            <a-form-item label="归还说明" :labelCol="{span:3}" :wrapperCol="{span:21}">
              <a-textarea :disabled="disableSubmit" placeholder="请输入归还说明"
                          v-decorator="['returnComment', validatorRules.returnComment]" />
            </a-form-item>
          </a-col>
        </a-row>
        <a-row style="width: 100%">
          <a-col :span="24 / 2">
            <a-form-item label="归还确认人" :labelCol="labelCol" :wrapperCol="wrapperCol">
              <j-search-select-tag
                :disabled="disableSubmit"
                placeholder="请选择归还确认人"
                v-decorator="['returnConfirmer', { rules: [{ required: false, message: '请选择归还确认人' }] }]"
                dict="sys_user,realname,id,del_flag=0"
              />
            </a-form-item>
          </a-col>
          <a-col :span="24 / 2">
            <a-form-item :labelCol="labelCol" :wrapperCol="wrapperCol" label="归还确认日期">
              <a-date-picker
                :disabled="disableSubmit"
                style="width: 100%"
                v-decorator="['returnConfirmTime', validatorRules.returnConfirmTime]"
              />
            </a-form-item>
          </a-col>
        </a-row>
        <a-row style="width: 100%">
          <a-col :span="24">
            <a-form-item label="归还确认意见" :labelCol="{span:3}" :wrapperCol="{span:21}">
              <a-textarea :disabled="disableSubmit" placeholder="请输入归还确认意见"
                          v-decorator="['returnConfirmComment', validatorRules.returnConfirmComment]" />
            </a-form-item>
          </a-col>
        </a-row>
      </a-form>
    </a-spin>
    <a-button type="primary" :style="{ marginBottom: '8px' }" @click="selectTooling()">选择库存刀具</a-button>
    <a-table
      ref="table"
      bordered
      size="middle"
      rowKey="id"
      :columns="columns"
      :dataSource="dataSource"
      :pagination="ipagination"
      :loading="loading"
    >
      <template v-for="col in columns" :slot="col.dataIndex" slot-scope="text, record, index">
        <div :key="col.dataIndex">
          <a-input
            :value="text"
            :disabled="disableSubmit"
            v-if="col.dataIndex === 'workpieceMaterial'"
            @change="(e)=>handleChange(e.target.value, record.key, col, index)"
          />
          <a-input-number
            v-if="col.dataIndex === 'usedLife'"
            :value="text"
            @change="(e) => handleChange(e, record.key, col, index)"
            :min="1"
          />
        </div>
      </template>
      <span slot="action" slot-scope="text, record, index">
        <a-popconfirm title="确定删除吗?" @confirm="() => handleDelete(record, index)">
          <a>删除</a>
        </a-popconfirm>
      </span>
      </a-table>
      <template slot="footer" v-if="disableSubmit == false">
         <a-button :style="{ marginRight: '8px' }" @click="handleCancel">关闭</a-button>
         <a-button @click="handleOk" type="primary">提交</a-button>
      </template>
    </a-table>
    <template slot="footer" v-if="disableSubmit == false">
      <a-button :style="{ marginRight: '8px' }" @click="handleCancel">关闭</a-button>
      <a-button @click="handleOk" type="primary">提交</a-button>
    </template>
      <template slot="footer" v-if="disableSubmit == true">
         <a-button :style="{ marginRight: '8px' }" @click="handleCancel">关闭</a-button>
      </template>
      <j-select-inventory-modal ref="inventoryModalForm" @ok="modalFormOk"></j-select-inventory-modal>
      <!--    <j-select-tooling-modal ref="toolingModalForm" @ok="modalFormOk"></j-select-tooling-modal>-->
   </a-modal>
    <template slot="footer" v-if="disableSubmit == true">
      <a-button :style="{ marginRight: '8px' }" @click="handleCancel">关闭</a-button>
    </template>
    <j-select-inventory-modal ref="inventoryModalForm" @ok="modalFormOk"></j-select-inventory-modal>
    <!--    <j-select-tooling-modal ref="toolingModalForm" @ok="modalFormOk"></j-select-tooling-modal>-->
  </a-modal>
</template>
<script>
@@ -176,226 +176,225 @@
import JSelectInventoryModal from '@views/cms/modules/JSelectInventoryModal.vue'
export default {
   name: 'CuttingInboundModal',
   components: {
      JSelectToolingModal,
      JSelectInventoryModal,
      JMultiSelectTag,
      JDictSelectTag,
      store,
      moment
   },
   data() {
      return {
         /* åˆ†é¡µå‚æ•° */
         ipagination: {
            current: 1,
            pageSize: 10,
            pageSizeOptions: ['10', '20', '30'],
            showTotal: (total, range) => {
               return range[0] + '-' + range[1] + ' å…±' + total + '条'
            },
            showQuickJumper: true,
            showSizeChanger: true,
            total: 0
         },
         title: '新增',
         visible: false,
         selectedRowKeys: {},
         model: {},
         labelCol: {
            xs: { span: 24 },
            sm: { span: 6 }
         },
         wrapperCol: {
            xs: { span: 24 },
            sm: { span: 18 }
         },
         confirmLoading: false,
         loading: false,
         form: this.$form.createForm(this),
         dataSource: [],
         param: {},
         validatorRules: {},
         columns: [
            {
               title: '#',
               dataIndex: '',
               key: 'rowIndex',
               width: 50,
               align: 'center',
               customRender: function(t, r, index) {
                  return parseInt(index) + 1
               }
            },
            {
               title: '刀具编码',
               align: 'center',
               dataIndex: 'cuttingCode',
               width: 150
            },
            {
               title: '刀具名称',
               align: 'center',
               dataIndex: 'cuttingName'
            },
            {
               title: '工件材质',
               align: 'center',
               dataIndex: 'workpieceMaterial',
               scopedSlots: { customRender: 'workpieceMaterial' }
            },
            {
               title: '使用寿命',
               align: 'center',
               dataIndex: 'usedLife',
               scopedSlots: { customRender: 'usedLife' }
            },
            {
               title: '操作',
               align: 'center',
               dataIndex: 'action',
               scopedSlots: { customRender: 'action' }
            }
         ],
         url: {
            add: '/cms/cuttingReceive/add',
            detailList: '/cms/cuttingReceive/detailList'
         },
         orderId: '',
         disableSubmit: false
  name: 'CuttingInboundModal',
  components: {
    JSelectInventoryModal,
    JMultiSelectTag,
    JDictSelectTag,
    store,
    moment
  },
  data() {
    return {
      /* åˆ†é¡µå‚æ•° */
      ipagination: {
        current: 1,
        pageSize: 10,
        pageSizeOptions: ['10', '20', '30'],
        showTotal: (total, range) => {
          return range[0] + '-' + range[1] + ' å…±' + total + '条'
        },
        showQuickJumper: true,
        showSizeChanger: true,
        total: 0
      },
      title: '新增',
      visible: false,
      selectedRowKeys: {},
      model: {},
      labelCol: {
        xs: { span: 24 },
        sm: { span: 6 }
      },
      wrapperCol: {
        xs: { span: 24 },
        sm: { span: 18 }
      },
      confirmLoading: false,
      loading: false,
      form: this.$form.createForm(this),
      dataSource: [],
      param: {},
      validatorRules: {},
      columns: [
        {
          title: '#',
          dataIndex: '',
          key: 'rowIndex',
          width: 50,
          align: 'center',
          customRender: function(t, r, index) {
            return parseInt(index) + 1
          }
        },
        {
          title: '刀具编码',
          align: 'center',
          dataIndex: 'cuttingCode',
          width: 150
        },
        {
          title: '刀具名称',
          align: 'center',
          dataIndex: 'cuttingName'
        },
        {
          title: '工件材质',
          align: 'center',
          dataIndex: 'workpieceMaterial',
          scopedSlots: { customRender: 'workpieceMaterial' }
        },
        {
          title: '使用寿命',
          align: 'center',
          dataIndex: 'usedLife',
          scopedSlots: { customRender: 'usedLife' }
        },
        {
          title: '操作',
          align: 'center',
          dataIndex: 'action',
          scopedSlots: { customRender: 'action' }
        }
      ],
      url: {
        add: '/cms/cuttingReceive/add',
        detailList: '/cms/cuttingReceive/detailList'
      },
      orderId: '',
      disableSubmit: false
    }
  },
  methods: {
    modalFormOk() {
    },
    getQueryParams() {
      this.param.pageNo = this.ipagination.current
      this.param.pageSize = this.ipagination.pageSize
      return filterObj(this.param)
    },
    add() {
      let receiver = store.getters.userInfo.id
      let receiveTime = moment(new Date()).format('YYYY-MM-DD HH:mm:ss')
      this.edit({ receiver: receiver, receiveTime: receiveTime })
    },
    edit(record) {
      record.receiver = store.getters.userInfo.id
      record.receiveTime = moment(new Date()).format('YYYY-MM-DD HH:mm:ss')
      this.form.resetFields()
      this.model = Object.assign({}, record)
      this.visible = true
      this.disableSubmit = false
      if (record.id) {
        this.orderId = record.id
        this.detailList(this.orderId)
      }
   },
   methods: {
      modalFormOk() {
      },
      getQueryParams() {
         this.param.pageNo = this.ipagination.current
         this.param.pageSize = this.ipagination.pageSize
         return filterObj(this.param)
      },
      add() {
         let receiver = store.getters.userInfo.id
         let receiveTime = moment(new Date()).format('YYYY-MM-DD HH:mm:ss')
         this.edit({ receiver: receiver, receiveTime: receiveTime })
      },
      edit(record) {
         record.receiver = store.getters.userInfo.id
         record.receiveTime = moment(new Date()).format('YYYY-MM-DD HH:mm:ss')
         this.form.resetFields()
         this.model = Object.assign({}, record)
         this.visible = true
         this.disableSubmit = false
         if (record.id) {
            this.orderId = record.id
            this.detailList(this.orderId)
         }
         this.$nextTick(() => {
            this.form.setFieldsValue(
               pick(this.model, 'receiver', 'receiveTime', 'receiveComment', 'confirmer', 'confirmTime', 'confirmComment'
                  , 'returnFlag', 'returnTime', 'returnComment', 'returnConfirmer', 'returnConfirmTime', 'returnConfirmComment')
            )
         })
      },
      handleDelete(record, index) {
         this.dataSource.splice(index, 1)
      },
      handleChange(value, key, column, index) {
         //let t = (this.ipaginationm.current - 1) * this.ipaginationm.pageSize + index
         const temp = [...this.dataSource]
         const target = temp.filter((item) => key === item.key)[index]
         if (target) {
            target[column.dataIndex] = value
            this.dataSource = temp
         }
      },
      selectTooling: function() {
         let ids = []
         for (let i = 0; i < this.dataSource.length; i++) {
            ids.push(this.dataSource[i].inventoryId)
            console.log('当前数据源:', this.dataSource)
         }
         // this.$refs.toolingModalForm.showModal(ids)
         // this.$refs.toolingModalForm.title = '选择刀具'
         // this.$refs.toolingModalForm.disableSubmit = false
         this.$refs.inventoryModalForm.showModal(ids)
         this.$refs.inventoryModalForm.title = '选择库存刀具'
         this.$refs.inventoryModalForm.disableSubmit = false
      },
      detailList(orderId) {
         this.param.orderId = orderId
         getAction(this.url.detailList, this.getQueryParams()).then((res) => {
            if (res.success) {
               this.dataSource = res.result
            }
         })
      },
      filterOption(input, option) {
         return option.componentOptions.children[0].text.toLowerCase().indexOf(input.toLowerCase()) >= 0
      },
      handleOk() {
         if (this.dataSource.length == 0) {
            this.$message.error('请先选择入库刀具')
            return
         }
         const that = this
         // è§¦å‘表单验证
         this.form.validateFields((err, values) => {
            if (!err) {
               that.confirmLoading = true
               let formData = Object.assign(this.model, values)
               formData.detailData = this.dataSource
               // ç¡®ä¿ detailData åŒ…含 inventoryId
               formData.detailData = this.dataSource.map(item => ({
                  ...item,
                  // ç¡®ä¿ inventoryId è¢«æ­£ç¡®ä¼ é€’
                  inventoryId: item.inventoryId
               }))
               postAction(that.url.add, formData)
                  .then((res) => {
                     if (res.success) {
                        that.$message.success('领用成功')
                        that.$emit('ok', new Date())
                     } else {
                        that.$message.warning(res.message)
                     }
                  })
                  .finally(() => {
                     that.confirmLoading = false
                     that.close()
                  })
            }
         })
      },
      handleCancel() {
         this.close()
      },
      close() {
         this.$emit('close')
         this.dataSource = []
         this.visible = false
         this.disableSubmit = false
      }
   },
   mounted() {
      this.$bus.$on('selectionRows', (data) => {
         console.log('接收到的选择数据:', data)
         //getCurrSelected äº‹ä»¶ æŽ¥æ”¶ç»„件传递的参数
         for (let i = 0; i < data.length; i++) {
            this.dataSource.push({
               inventoryId: data[i].id,
               cuttingCode: data[i].cuttingCode,
               cuttingName: data[i].cuttingName,
               cuttingId: data[i].cuttingId
            })
         }
         console.log('更新后的数据源:', this.dataSource)
      this.$nextTick(() => {
        this.form.setFieldsValue(
          pick(this.model, 'receiver', 'receiveTime', 'receiveComment', 'confirmer', 'confirmTime', 'confirmComment'
            , 'returnFlag', 'returnTime', 'returnComment', 'returnConfirmer', 'returnConfirmTime', 'returnConfirmComment')
        )
      })
   }
    },
    handleDelete(record, index) {
      this.dataSource.splice(index, 1)
    },
    handleChange(value, key, column, index) {
      //let t = (this.ipaginationm.current - 1) * this.ipaginationm.pageSize + index
      const temp = [...this.dataSource]
      const target = temp.filter((item) => key === item.key)[index]
      if (target) {
        target[column.dataIndex] = value
        this.dataSource = temp
      }
    },
    selectTooling: function() {
      let ids = []
      for (let i = 0; i < this.dataSource.length; i++) {
        ids.push(this.dataSource[i].inventoryId)
        console.log('当前数据源:', this.dataSource)
      }
      // this.$refs.toolingModalForm.showModal(ids)
      // this.$refs.toolingModalForm.title = '选择刀具'
      // this.$refs.toolingModalForm.disableSubmit = false
      this.$refs.inventoryModalForm.showModal(ids)
      this.$refs.inventoryModalForm.title = '选择库存刀具'
      this.$refs.inventoryModalForm.disableSubmit = false
    },
    detailList(orderId) {
      this.param.orderId = orderId
      getAction(this.url.detailList, this.getQueryParams()).then((res) => {
        if (res.success) {
          this.dataSource = res.result
        }
      })
    },
    filterOption(input, option) {
      return option.componentOptions.children[0].text.toLowerCase().indexOf(input.toLowerCase()) >= 0
    },
    handleOk() {
      if (this.dataSource.length == 0) {
        this.$message.error('请先选择入库刀具')
        return
      }
      const that = this
      // è§¦å‘表单验证
      this.form.validateFields((err, values) => {
        if (!err) {
          that.confirmLoading = true
          let formData = Object.assign(this.model, values)
          formData.detailData = this.dataSource
          // ç¡®ä¿ detailData åŒ…含 inventoryId
          formData.detailData = this.dataSource.map(item => ({
            ...item,
            // ç¡®ä¿ inventoryId è¢«æ­£ç¡®ä¼ é€’
            inventoryId: item.inventoryId
          }))
          postAction(that.url.add, formData)
            .then((res) => {
              if (res.success) {
                that.$message.success('领用成功')
                that.$emit('ok', new Date())
              } else {
                that.$message.warning(res.message)
              }
            })
            .finally(() => {
              that.confirmLoading = false
              that.close()
            })
        }
      })
    },
    handleCancel() {
      this.close()
    },
    close() {
      this.$emit('close')
      this.dataSource = []
      this.visible = false
      this.disableSubmit = false
    }
  },
  mounted() {
    this.$bus.$on('selectionRows', (data) => {
      console.log('接收到的选择数据:', data)
      //getCurrSelected äº‹ä»¶ æŽ¥æ”¶ç»„件传递的参数
      for (let i = 0; i < data.length; i++) {
        this.dataSource.push({
          inventoryId: data[i].id,
          cuttingCode: data[i].cuttingCode,
          cuttingName: data[i].cuttingName,
          cuttingId: data[i].cuttingId
        })
      }
      console.log('更新后的数据源:', this.dataSource)
    })
  }
}
</script>
src/views/cms/modules/CuttingScrapModal.vue
@@ -3,7 +3,7 @@
    <a-spin :spinning="confirmLoading">
      <a-form :form="form">
        <a-row style="width: 100%">
           <a-col :span="24 / 2">
          <a-col :span="24 / 2">
            <a-form-item label="申请人" :labelCol="labelCol" :wrapperCol="wrapperCol">
              <j-search-select-tag
                :disabled="disableSubmit"
@@ -26,12 +26,13 @@
        <a-row style="width: 100%">
          <a-col :span="24">
            <a-form-item label="申请说明" :labelCol="{span:3}" :wrapperCol="{span:21}">
              <a-textarea :disabled="disableSubmit" placeholder="请输入申请说明" v-decorator="['applicationComment', validatorRules.applicationComment]" />
              <a-textarea :disabled="disableSubmit" placeholder="请输入申请说明"
                          v-decorator="['applicationComment', validatorRules.applicationComment]" />
            </a-form-item>
          </a-col>
        </a-row>
        <a-row style="width: 100%">
           <a-col :span="24 / 2">
          <a-col :span="24 / 2">
            <a-form-item label="确认人" :labelCol="labelCol" :wrapperCol="wrapperCol">
              <j-search-select-tag
                :disabled="disableSubmit"
@@ -54,14 +55,16 @@
        <a-row style="width: 100%">
          <a-col :span="24">
            <a-form-item label="确认意见" :labelCol="{span:3}" :wrapperCol="{span:21}">
              <a-textarea :disabled="disableSubmit" placeholder="请输入确认意见" v-decorator="['confirmComment', validatorRules.confirmComment]" />
              <a-textarea :disabled="disableSubmit" placeholder="请输入确认意见"
                          v-decorator="['confirmComment', validatorRules.confirmComment]" />
            </a-form-item>
          </a-col>
        </a-row>
      </a-form>
    </a-spin>
    <a-button type="primary" :style="{ marginBottom: '8px' }" @click="selectTooling()"
      >选择刀具</a-button
    >选择报废刀具
    </a-button
    >
    <a-table
      ref="table"
@@ -75,13 +78,13 @@
    >
      <template v-for="col in columns" :slot="col.dataIndex" slot-scope="text, record, index">
        <div :key="col.dataIndex">
         <a-input
                    :value="text"
                    :disabled="disableSubmit"
                    v-if="col.dataIndex == 'newCuttingId'"
                    @change="(e)=>handleChange(e.target.value, record.key, col, index)"
                  />
          <a-input
            :value="text"
            :disabled="disableSubmit"
            v-if="col.dataIndex == 'newCuttingId'"
            @change="(e)=>handleChange(e.target.value, record.key, col, index)"
          />
        </div>
      </template>
      <span slot="action" slot-scope="text, record, index">
@@ -98,33 +101,35 @@
    <template slot="footer" v-if="disableSubmit == true">
      <a-button :style="{ marginRight: '8px' }" @click="handleCancel">关闭</a-button>
    </template>
    <j-select-tooling-modal ref="toolingModalForm" @ok="modalFormOk"></j-select-tooling-modal>
    <j-select-scrap-modal ref="scrapModalForm" @ok="modalFormOk"></j-select-scrap-modal>
  </a-modal>
</template>
<script>
  import pick from 'lodash.pick'
  import JSelectToolingModal from './JSelectToolingModal'
  import moment from 'moment'
  import { getAction, postAction, requestPut } from '@/api/manage'
  import JDictSelectTag from '@/components/dict/JDictSelectTag'
  import JSearchSelectTag from '@/components/dict/JSearchSelectTag'
  import JMultiSelectTag from '@/components/dict/JMultiSelectTag'
  import { filterObj } from '@/utils/util'
  import store from '@/store/'
  export default {
    name: 'CuttingInboundModal',
    components: {
    JSelectToolingModal,
import pick from 'lodash.pick'
import JSelectToolingModal from './JSelectToolingModal'
import moment from 'moment'
import { getAction, postAction, requestPut } from '@/api/manage'
import JDictSelectTag from '@/components/dict/JDictSelectTag'
import JSearchSelectTag from '@/components/dict/JSearchSelectTag'
import JMultiSelectTag from '@/components/dict/JMultiSelectTag'
import { filterObj } from '@/utils/util'
import store from '@/store/'
import JSelectScrapModal from '@views/cms/modules/JSelectScrapModal.vue'
export default {
  name: 'CuttingInboundModal',
  components: {
    JSelectScrapModal,
    JMultiSelectTag,
    JDictSelectTag,
    store,
    moment,
    moment
  },
    data () {
      return {
         /* åˆ†é¡µå‚æ•° */
  data() {
    return {
      /* åˆ†é¡µå‚æ•° */
      ipagination: {
        current: 1,
        pageSize: 10,
@@ -134,27 +139,26 @@
        },
        showQuickJumper: true,
        showSizeChanger: true,
        total: 0,
        total: 0
      },
      title:'新增',
         visible: false,
         selectedRowKeys: {},
      title: '新增',
      visible: false,
      selectedRowKeys: {},
      model: {},
      labelCol: {
        xs: { span: 24 },
        sm: { span: 6 },
        sm: { span: 6 }
      },
      wrapperCol: {
        xs: { span: 24 },
        sm: { span: 18 },
        sm: { span: 18 }
      },
      confirmLoading: false,
      loading: false,
      form: this.$form.createForm(this),
      dataSource: [],
      param: {},
      validatorRules: {
      },
      validatorRules: {},
      columns: [
        {
          title: '#',
@@ -162,47 +166,47 @@
          key: 'rowIndex',
          width: 50,
          align: 'center',
          customRender: function (t, r, index) {
          customRender: function(t, r, index) {
            return parseInt(index) + 1
          },
          }
        },
        {
          title: '刀具编码',
          align: 'center',
          dataIndex: 'cuttingCode',
          width: 150,
          width: 150
        },
        {
          title: '刀具名称',
          align: 'center',
          dataIndex: 'cuttingName',
          dataIndex: 'cuttingName'
        },
        {
          title: '操作',
          dataIndex: 'action',
          align: 'center',
          scopedSlots: { customRender: 'action' },
        },
          scopedSlots: { customRender: 'action' }
        }
      ],
      url: {
        add: '/cms/cuttingScrap/add',
        detailList: '/cms/cuttingScrap/detailList',
        detailList: '/cms/cuttingScrap/detailList'
      },
      orderId:'',
      disableSubmit:false
      }
    },
    methods: {
      modalFormOk(){
      orderId: '',
      disableSubmit: false
    }
  },
  methods: {
    modalFormOk() {
      },
       getQueryParams() {
    },
    getQueryParams() {
      this.param.pageNo = this.ipagination.current
      this.param.pageSize = this.ipagination.pageSize
      return filterObj(this.param)
    },
      add() {
    add() {
      let applicant = store.getters.userInfo.id
      let applicationTime = moment(new Date()).format('YYYY-MM-DD HH:mm:ss')
      this.edit({ applicant: applicant, applicationTime: applicationTime })
@@ -224,7 +228,7 @@
        )
      })
    },
     handleDelete(record, index) {
    handleDelete(record, index) {
      this.dataSource.splice(index, 1)
    },
    handleChange(value, key, column, index) {
@@ -236,14 +240,15 @@
        this.dataSource = temp
      }
    },
    selectTooling: function () {
    selectTooling: function() {
      let ids = []
      for (let i = 0; i < this.dataSource.length; i++) {
        ids.push(this.dataSource[i].cuttingId)
        ids.push(this.dataSource[i].inventoryId)
      }
      this.$refs.toolingModalForm.showModal(ids)
      this.$refs.toolingModalForm.title = '选择刀具'
      this.$refs.toolingModalForm.disableSubmit = false
      this.$refs.scrapModalForm.showModal(ids)
      this.$refs.scrapModalForm.title = '选择报废刀具'
      this.$refs.scrapModalForm.disableSubmit = false
    },
    detailList(orderId) {
      this.param.orderId = orderId
@@ -262,17 +267,32 @@
        return
      }
      const that = this
      // è§¦å‘表单验证
      this.form.validateFields((err, values) => {
        if (!err) {
          that.confirmLoading = true
          let formData = Object.assign(this.model, values)
          formData.detailData = this.dataSource
          // ç¡®ä¿ä¼ é€’给后端的数据包含所有必要字段
          formData.detailData = this.dataSource.map(item => {
            return {
              // æ˜Žç¡®æŒ‡å®šæ¯ä¸ªå­—段,确保 inventoryId è¢«æ­£ç¡®ä¼ é€’
              inventoryId: item.inventoryId,
              cuttingId: item.cuttingId,
              cuttingCode: item.cuttingCode,
              cuttingName: item.cuttingName,
              // å¦‚果还有其他字段也需要包含
              ...item // åŒ…含其他可能存在的字段
            }
          })
          postAction(that.url.add, formData)
            .then((res) => {
              if (res.success) {
                that.$message.success('报废成功')
                that.$emit('ok', new Date())
                that.$message.success('报废成功')
              } else {
                that.$message.warning(res.message)
              }
@@ -292,19 +312,24 @@
      this.dataSource = []
      this.visible = false
      this.disableSubmit = false
    },
    },
    mounted() {
    }
  },
  mounted() {
    this.$bus.$on('selectionRows', (data) => {
      //getCurrSelected äº‹ä»¶ æŽ¥æ”¶ç»„件传递的参数
      for (let i = 0; i < data.length; i++) {
        this.dataSource.push({
          cuttingId: data[i].id,
          // cuttingId: data[i].id,
          // cuttingCode: data[i].cuttingCode,
          // cuttingName: data[i].cuttingName
          inventoryId: data[i].id,
          cuttingCode: data[i].cuttingCode,
          cuttingName: data[i].cuttingName
          cuttingName: data[i].cuttingName,
          cuttingId: data[i].cuttingId,
        })
      }
    })
  },
    console.log('更新后的数据源:', this.dataSource)
  }
}
</script>
src/views/cms/modules/JSelectScrapModal.vue
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,261 @@
<template>
  <!--支持全屏缩放-->
  <!--选择刀具的弹窗,根据这个弹窗将选择刀具从刀具信息迁移到刀具库存,用来领用刀具库存里的刀具  -->
  <j-modal
    :visible="visible"
    :title="title"
    switchFullscreen
    :width="1200"
    @ok="handleSubmit"
    @cancel="close"
    style="top: 50px"
    cancelText="关闭"
  >
    <a-card :bordered="false">
      <div class="table-page-search-wrapper">
        <a-form layout="inline" @keyup.enter.native="searchQuery">
          <a-row :gutter="24">
            <a-col :xl="6" :lg="7" :md="8" :sm="24">
              <a-form-item label="刀具编码">
                <a-input placeholder="请输入刀具编码,支持模糊查询" v-model="queryParam.cuttingCode"></a-input>
              </a-form-item>
            </a-col>
            <a-col :xl="6" :lg="7" :md="8" :sm="24">
              <a-form-item label="刀具名称">
                <a-input placeholder="请输入刀具名称,支持模糊查询" v-model="queryParam.cuttingName"></a-input>
              </a-form-item>
            </a-col>
            <a-button type="primary" @click="searchQuery" icon="search">查询</a-button>
            <a-button type="primary" @click="searchReset" icon="reload" style="margin-left: 8px">重置</a-button>
          </a-row>
        </a-form>
      </div>
      <!--刀具列表-->
      <a-table
        ref="table"
        :scroll="scrollTrigger"
        size="middle"
        rowKey="id"
        :columns="columns"
        :dataSource="dataSource"
        :pagination="ipagination"
        :rowSelection="rowSelection"
        :loading="loading"
        @change="handleTableChange"
      >
      </a-table>
    </a-card>
  </j-modal>
</template>
<script>
import { filterObj } from '@/utils/util'
import { getAction } from '@/api/manage'
export default {
  name: 'JSelectScrapModal',
  components: {},
  props: {},
  data() {
    return {
      queryParam: {},
      columns: [
        {
          title: '#',
          dataIndex: '',
          key: 'rowIndex',
          width: 50,
          align: 'center',
          customRender: function (t, r, index) {
            return parseInt(index) + 1
          },
        },
        {
          title: '刀具编码',
          align: 'center',
          dataIndex: 'cuttingCode',
          sorter: true,
        },
        {
          title: '刀具名称',
          align: 'center',
          dataIndex: 'cuttingName',
          sorter: true,
        },
        {
          title: '刀具分类',
          align: 'center',
          dataIndex: 'cuttingCategory',
          sorter: true,
        },
        {
          title:'刀具条码',
          align: 'center',
          dataIndex: 'cuttingBarcode',
          sorter: true,
        },
        {
          title:'刀具当前寿命(百分比)',
          align: 'center',
          dataIndex: 'currentLife',
          sorter: true,
        },
        {
          title:'库存id',
          align: 'center',
          dataIndex: 'id',
          sorter: true,
        }
      ],
      selectedRowKeys: [],
      oldSlelectRows: [],
      scrollTrigger: {},
      dataSource: [],
      selectionRows: [],
      title: '根据查询结果选择刀具',
      ipagination: {
        current: 1,
        pageSize: 10,
        pageSizeOptions: ['5', '10', '20'],
        showTotal: (total, range) => {
          return range[0] + '-' + range[1] + ' å…±' + total + '条'
        },
        showQuickJumper: true,
        showSizeChanger: true,
        total: 0,
      },
      isorter: {
        column: 'num',
        order: 'desc',
      },
      departTree: [],
      visible: false,
      loading: false,
      url: {
        // list: '/cms/cuttingTool/getCuttingToolList',
        list:'/cms/cuttingScrap/getInventoryToolList'
      },
    }
  },
  computed: {
    rowSelection() {
      return {
        type: 'checkbox',
        onChange: (selectedRowKeys, selectedRows) => {
          this.selectedRowKeys = selectedRowKeys
          this.onSelectChange(selectedRows)
        },
        getCheckboxProps: (record) => ({
          props: {
            disabled: record.distable,
          },
        }),
        selectedRowKeys: this.selectedRowKeys,
      }
    },
  },
  watch: {},
  created() {},
  methods: {
    async loadData(arg) {
      if (arg === 1) {
        this.ipagination.current = 1
      }
      let that = this
      this.loading = true
      let params = this.getQueryParams() //查询条件
      await getAction(this.url.list, params).then((res) => {
        if (res.success) {
          for (let i = 0; i < res.result.records.length; i++) {
            if (that.oldSlelectRows.indexOf(res.result.records[i].id) > -1) {
              res.result.records[i].distable = true
            } else {
              res.result.records[i].distable = false
            }
          }
          this.dataSource = res.result.records
          this.ipagination.total = res.result.total
        }
        if (res.code === 510) {
          this.$message.warning(res.message)
        }
        this.loading = false
      })
    },
    showModal(oldSlelectRows) {
      this.oldSlelectRows = oldSlelectRows
      this.visible = true
      this.loadData(1)
    },
    getQueryParams() {
      let param = Object.assign({}, this.queryParam, this.isorter)
      param.field = this.getQueryField()
      param.pageNo = this.ipagination.current
      param.pageSize = this.ipagination.pageSize
      return filterObj(param)
    },
    //查询条件处理
    getQueryField() {
      let str = 'id,'
      for (let a = 0; a < this.columns.length; a++) {
        str += ',' + this.columns[a].dataIndex
      }
      return str
    },
    searchReset(num) {
      let that = this
      if (num !== 0) {
        that.loadData(1)
      }
      that.selectborrowIds = []
    },
    close() {
      this.searchReset(0)
      this.selectedRowKeys = []
      this.visible = false
    },
    handleTableChange(pagination, filters, sorter) {
      if (Object.keys(sorter).length > 0) {
        this.isorter.column = sorter.field
        this.isorter.order = 'ascend' === sorter.order ? 'asc' : 'desc'
      }
      this.ipagination = pagination
      this.loadData()
    },
    handleSubmit() {
      this.$bus.$emit('selectionRows', this.selectionRows)
      this.searchReset(0)
      this.close()
    },
    onSelectChange(selectionRows) {
      this.selectionRows = selectionRows
    },
    onSearch() {
      this.loadData(1)
    },
    searchQuery() {
      this.loadData(1);
    },
    // searchReset() {
    //   this.queryParam = {}
    //   this.loadData(1)
    // },
  },
}
</script>
<style scoped>
.ant-table-tbody .ant-table-row td {
  padding-top: 10px;
  padding-bottom: 10px;
}
#components-layout-demo-custom-trigger .trigger {
  font-size: 18px;
  line-height: 64px;
  padding: 0 24px;
  cursor: pointer;
  transition: color 0.3s;
}
</style>
src/views/eam/base/EamMaintenanceStandardList.vue
@@ -123,11 +123,11 @@
            icon="import"
          >点检标准导入</a-button>
        </a-upload>
        <a-button
          type="primary"
          icon="download"
          @click="handleTemplateXlsDownload(url.inspectionXlsDownloadUrl)"
        >点检标准模板下载</a-button>
<!--        <a-button-->
<!--          type="primary"-->
<!--          icon="download"-->
<!--          @click="handleTemplateXlsDownload(url.inspectionXlsDownloadUrl)"-->
<!--        >点检标准模板下载</a-button>-->
        <a-upload
          name="file"
          :showUploadList="false"
@@ -141,11 +141,11 @@
            icon="import"
          >季保标准导入</a-button>
        </a-upload>
        <a-button
          type="primary"
          icon="download"
          @click="handleTemplateXlsDownload(url.secondMaintenanceXlsDownloadUrl)"
        >季保标准模板下载</a-button>
<!--        <a-button-->
<!--          type="primary"-->
<!--          icon="download"-->
<!--          @click="handleTemplateXlsDownload(url.secondMaintenanceXlsDownloadUrl)"-->
<!--        >季保标准模板下载</a-button>-->
        <a-upload
          name="file"
          :showUploadList="false"
@@ -159,11 +159,11 @@
            icon="import"
          >年保标准导入</a-button>
        </a-upload>
        <a-button
          type="primary"
          icon="download"
          @click="handleTemplateXlsDownload(url.thirdMaintenanceXlsDownloadUrl)"
        >年保标准模板下载</a-button>
<!--        <a-button-->
<!--          type="primary"-->
<!--          icon="download"-->
<!--          @click="handleTemplateXlsDownload(url.thirdMaintenanceXlsDownloadUrl)"-->
<!--        >年保标准模板下载</a-button>-->
        <a-dropdown v-if="selectedRowKeys.length > 0">
          <a-menu slot="overlay">
            <a-menu-item
@@ -340,11 +340,11 @@
          align: 'center',
          dataIndex: 'fileCode'
        },
        {
          title: '保养周期(天)',
          align: 'center',
          dataIndex: 'maintenancePeriod'
        },
        // {
        //   title: '保养周期(天)',
        //   align: 'center',
        //   dataIndex: 'maintenancePeriod'
        // },
        {
          title: '初始日期',
          align: 'center',
@@ -383,9 +383,14 @@
        deleteBatch: '/eam/maintenanceStandard/deleteBatch',
        exportXlsUrl: 'eam/maintenanceStandard/exportXls',
        inspectionImportExcel: 'eam/maintenanceStandard/inspectionImportExcel',
        weekMaintenanceImportExcel: 'eam/maintenanceStandard/weekMaintenanceImportExcel',
        secondMaintenanceImportExcel: 'eam/maintenanceStandard/secondMaintenanceImportExcel',
        thirdMaintenanceImportExcel: 'eam/maintenanceStandard/thirdMaintenanceImportExcel',
        /**
         * å­£ä¿
         */
        secondMaintenanceImportExcel: 'eam/maintenanceStandard/maintenanceImportExcel',
        /**
         * å¹´ä¿
         */
        thirdMaintenanceImportExcel: 'eam/maintenanceStandard/annualMaintenanceImportExcel',
        inspectionXlsDownloadUrl: '导入模板/点检标准导入模板_v1.0.xlsx',
        weekMaintenanceXlsDownloadUrl: '导入模板/周保标准导入模板_v1.0.xlsx',
        secondMaintenanceXlsDownloadUrl: '导入模板/二保标准导入模板_v1.0.xlsx',
@@ -400,9 +405,6 @@
  computed: {
    inspectionImportExcel: function () {
      return `${window._CONFIG['domianURL']}/${this.url.inspectionImportExcel}`
    },
    weekMaintenanceImportExcel: function () {
      return `${window._CONFIG['domianURL']}/${this.url.weekMaintenanceImportExcel}`
    },
    secondMaintenanceImportExcel: function () {
      return `${window._CONFIG['domianURL']}/${this.url.secondMaintenanceImportExcel}`
src/views/eam/base/EamProcessParametersList.vue
@@ -6,7 +6,7 @@
      <a-form layout="inline" @keyup.enter.native="searchQuery">
        <a-row :gutter="24">
          <a-col :xl="6" :lg="7" :md="8" :sm="24">
            <a-form-item label="参数编码4444">
            <a-form-item label="参数编码">
              <j-input placeholder="请输入参数编码" v-model="queryParam.parameterCode"></j-input>
            </a-form-item>
          </a-col>
src/views/eam/equipment/EamEquipmentList.vue
@@ -289,7 +289,7 @@
        <eam-week-maintenance-order-list ref="tabPaneTableListRef3" :isDisplayOperation="false"/>
      </a-tab-pane>-->
      <a-tab-pane
        tab="二保工单"
        tab="季报工单"
        :key="3"
      >
        <eam-second-maintenance-order-list
@@ -298,7 +298,7 @@
        />
      </a-tab-pane>
      <a-tab-pane
        tab="三保工单"
        tab="年保工单"
        :key="4"
      >
        <eam-third-maintenance-order-list
@@ -344,15 +344,15 @@
          :isDisplayOperation="false"
        />
      </a-tab-pane>
      <a-tab-pane
        tab="设备油液"
        :key="9"
      >
        <eam-equipment-fluid-list
          ref="tabPaneTableListRef9"
          :isDisplayOperation="false"
        />
      </a-tab-pane>
<!--      <a-tab-pane-->
<!--        tab="设备油液"-->
<!--        :key="9"-->
<!--      >-->
<!--        <eam-equipment-fluid-list-->
<!--          ref="tabPaneTableListRef9"-->
<!--          :isDisplayOperation="false"-->
<!--        />-->
<!--      </a-tab-pane>-->
    </a-tabs>
    <!-- è¡¨å•区域 -->
@@ -377,25 +377,25 @@
import '@/assets/less/TableExpand.less'
import EamEquipmentModal from './modules/EamEquipmentModal'
import { JeecgListMixin } from '@/mixins/JeecgListMixin'
import { getAction, templateXlsDownload } from '@api/manage'
import { getAction } from '@api/manage'
import NameplateModal from '@views/eam/equipment/modules/NameplateModal.vue'
import { getSystemConfigValue } from '@api/api'
import ResumeDrawer from '@views/eam/equipment/modules/ResumeDrawer.vue'
import EamMaintenanceStandardList from '@views/eam/base/EamMaintenanceStandardList.vue'
import EamRepairOrderList from '../repair/EamRepairOrderList'
// import EamInspectionOrderList from '../maintenance/EamInspectionOrderList'
import EamInspectionOrderList from '../maintenance/EamInspectionOrderList'
import EamEquipmentAttachmentList from '@views/eam/equipment/EamEquipmentAttachmentList.vue'
// import EamWeekMaintenanceOrderList from '@views/eam/maintenance/EamWeekMaintenanceOrderList.vue'
import EamEquipmentProcessList from '@views/eam/equipment/modules/EamEquipmentProcessList.vue'
import EamEquipmentPrecisionList from '@views/eam/equipment/modules/EamEquipmentPrecisionList.vue'
// import EamSecondMaintenanceOrderList from '@views/eam/maintenance/EamSecondMaintenanceOrderList.vue'
// import EamThirdMaintenanceOrderList from '@views/eam/maintenance/EamThirdMaintenanceOrderList.vue'
import EamEquipmentFluidList from '@views/eam/equipment/modules/EamEquipmentFluidList.vue'
import { hasPermission } from '@/utils/hasPermission' // æ·»åŠ è¿™ä¸€è¡Œ
export default {
  name: 'EamEquipmentList',
  mixins: [JeecgListMixin],
  components: {
    EamInspectionOrderList,
    EamMaintenanceStandardList,
    ResumeDrawer,
    NameplateModal,
@@ -403,7 +403,7 @@
    EamEquipmentAttachmentList,
    EamEquipmentProcessList,
    EamEquipmentPrecisionList,
    EamEquipmentFluidList
  },
  data() {
    return {
src/views/eam/equipment/modules/EamEquipmentModal.vue
@@ -50,11 +50,16 @@
                </a-form-model-item>
              </a-col>
              <a-col :span="8">
                <a-form-model-item prop="equipmentType"
                                   label="设备种类">
                  <j-tree-dict placeholder="请选择设备种类" v-model="model.equipmentType" parent-code="equipment_category" field="code" :async="true" :disabled="disableSubmit"></j-tree-dict>
                <a-form-model-item prop="overallDimensions" label="外形尺寸">
                  <a-input :placeholder="disableSubmit?'':'请输入外形尺寸'" v-model="model.overallDimensions" :disabled="disableSubmit"/>
                </a-form-model-item>
              </a-col>
<!--              <a-col :span="8">-->
<!--                <a-form-model-item prop="equipmentType"-->
<!--                                   label="设备种类">-->
<!--                  <j-tree-dict placeholder="请选择设备种类" v-model="model.equipmentType" parent-code="equipment_category" field="code" :async="true" :disabled="disableSubmit"></j-tree-dict>-->
<!--                </a-form-model-item>-->
<!--              </a-col>-->
            </a-row>
            <a-row>
              <a-col :span="8">
@@ -97,11 +102,7 @@
              <a-input :placeholder="disableSubmit?'':'请输入重量'" v-model="model.equipmentWeight" :disabled="disableSubmit"/>
            </a-form-model-item>
          </a-col>
          <a-col :span="6">
            <a-form-model-item prop="overallDimensions" label="外形尺寸">
              <a-input :placeholder="disableSubmit?'':'请输入外形尺寸'" v-model="model.overallDimensions" :disabled="disableSubmit"/>
            </a-form-model-item>
          </a-col>
        </a-row>
        <a-row :gutter="24">
@@ -183,12 +184,12 @@
        <a-row :gutter="24">
          <a-col :span="6">
            <a-form-model-item prop="orgId" label="使用车间">
            <a-form-model-item prop="orgId" label="所属产线">
              <a-tree-select v-model="model.orgId"
                             style="width: 100%"
                             :tree-data="treeData"
                             :dropdown-style="{ maxHeight: '400px', overflow: 'auto' }"
                             placeholder="请选择使用车间"
                             placeholder="请选择所属产线"
                             allow-clear
                             tree-default-expand-all
                             :disabled="editable || disableSubmit"
@@ -198,7 +199,7 @@
          </a-col>
          <a-col :span="6">
            <a-form-model-item prop="equipmentManager" label="设备管理员">
              <j-search-select-tag  placeholder="请选择设备管理员" v-model="model.equipmentManager" dict="sys_user,realname, username, del_flag=0 and post='PCR0004' and status=1" :disabled="disableSubmit"/>
              <j-search-select-tag  placeholder="请选择设备管理员" v-model="model.equipmentManager" dict="sys_user,realname, username, del_flag=0 and status=1" :disabled="disableSubmit"/>
            </a-form-model-item>
          </a-col>
          <a-col :span="6">
src/views/mes/MesProductionOrderList.vue
@@ -20,21 +20,27 @@
              <j-input placeholder="请输入物料编号" v-model="queryParam.materialNumber"></j-input>
            </a-form-item>
          </a-col>
          <a-col :xl="6" :lg="7" :md="8" :sm="24">
            <a-form-item label="物料名称">
              <j-input placeholder="请输入物料名称" v-model="queryParam.materialName"></j-input>
            </a-form-item>
          </a-col>
          <a-col :xl="6" :lg="7" :md="8" :sm="24">
            <a-form-item label="订单状态">
              <j-dict-select-tag dictCode="production_order_status" placeholder="请选择订单状态"
                                 v-model="queryParam.orderStatus"></j-dict-select-tag>
            </a-form-item>
          </a-col>
          <template v-if="toggleSearchStatus">
            <a-col :xl="6" :lg="7" :md="8" :sm="24">
              <a-form-item label="物料名称">
                <j-input placeholder="请输入物料名称" v-model="queryParam.materialName"></j-input>
              </a-form-item>
            </a-col>
            <a-col :xl="6" :lg="7" :md="8" :sm="24">
              <a-form-item label="订单状态">
                <j-dict-select-tag dictCode="production_order_status" placeholder="请选择订单状态"
                                   v-model="queryParam.orderStatus"></j-dict-select-tag>
              </a-form-item>
            </a-col>
          </template>
          <a-col :xl="6" :lg="7" :md="8" :sm="24">
            <span style="float: left;overflow: hidden;" class="table-page-search-submitButtons">
              <a-button type="primary" @click="searchQuery" icon="search">查询</a-button>
              <a-button type="info" @click="searchReset" icon="reload" style="margin-left: 8px">重置</a-button>
               <a @click="handleToggleSearch" style="margin-left: 8px">
                {{ toggleSearchStatus ? '收起' : '展开' }}
                <a-icon :type="toggleSearchStatus ? 'up' : 'down'" />
              </a>
            </span>
          </a-col>
        </a-row>
@@ -64,6 +70,10 @@
        class="j-table-force-nowrap"
        @change="handleTableChange">
        <span slot="action" slot-scope="text, record">
          <a-popconfirm title="确定同步最新数据吗?" @confirm="() => handleSync(record.id)">
          <a>删除</a>
        </a-popconfirm>
          <a-divider type="vertical" />
          <a @click="handleEdit(record)">编辑</a>
          <a-divider type="vertical" />
          <a @click="handleDetail(record)">详情</a>
@@ -81,6 +91,7 @@
import { mixinDevice } from '@/utils/mixin'
import { JeecgListMixin } from '@/mixins/JeecgListMixin'
import MesProductionOrderModal from './modules/MesProductionOrderModal'
import { getAction } from '@api/manage'
export default {
  name: 'MesProductionOrderList',
@@ -102,25 +113,25 @@
          customRender: function(t, r, index) {
            return parseInt(index) + 1
          },
          fixed: 'left',
          fixed: 'left'
        },
        {
          title: '生产订单号',
          align: 'center',
          dataIndex: 'orderCode',
          fixed: 'left',
          fixed: 'left'
        },
        {
          title: '订单类型',
          align: 'center',
          dataIndex: 'orderCategory_dictText',
          fixed: 'left',
          fixed: 'left'
        },
        {
          title: '物料编号',
          align: 'center',
          dataIndex: 'materialNumber',
          fixed: 'left',
          fixed: 'left'
        },
        {
          title: '物料名称',
@@ -248,15 +259,31 @@
      ],
      url: {
        list: '/mes/productionOrder/list',
      },
      dictOptions: {},
        syncSapProductionOrder: '/mes/productionOrder/syncSapProductionOrder'
      }
    }
  },
  created() {
  },
  computed: {
  },
  computed: {},
  methods: {
    handleSync(id) {
      let that = this
      getAction(that.url.syncSapProductionOrder, { id: id }).then((res) => {
        if (res.success) {
          that.$notification.success({
            message: '消息',
            description: res.message
          })
          that.loadData()
        } else {
          that.$notification.warning({
            message: '消息',
            description: res.message
          })
        }
      })
    }
  }
}
</script>
src/views/mes/modules/MesMaterialTransferRequestForm.vue
@@ -42,11 +42,9 @@
          </a-col>
          <a-col :span="12">
            <a-form-model-item label="拉动物料" :labelCol="labelCol" :wrapperCol="wrapperCol" prop="materialNumber">
              <a-select v-model="model.materialNumber" placeholder="请选择拉动物料" @change="handleMaterialNumberChange">
                <a-select-option v-for="item in materialList" :value="item.materialNumber" :title="item.materialName" :key="item.materialNumber">
                  {{ item.materialName }}
                </a-select-option>
              </a-select>
              <j-search-select-tag v-model="model.materialNumber" placeholder="请选择拉动物料"
                                   :dict-options="materialList" @change="handleMaterialNumberChange">
              </j-search-select-tag>
            </a-form-model-item>
          </a-col>
          <a-col :span="12">
@@ -118,7 +116,7 @@
        workOrderQuery: '/mes/mesProductionWorkOrder/queryById'
      },
      materialList: [], //物料列表
      workOrderObj: {}, //工单对象
      workOrderObj: {} //工单对象
    }
  },
  computed: {
@@ -140,17 +138,21 @@
      this.model.workOrderCode = this.model.workOrderId_dictText
      this.visible = true
      if (this.model.workOrderId) {
        this.editable = true;
        this.editable = true
        let workOrderRes = await this.loadProductionWorkOrder(this.model.workOrderId)
        if(!workOrderRes.success || !workOrderRes.result) {
          return;
        if (!workOrderRes.success || !workOrderRes.result) {
          return
        }
        //排产工单赋值
        this.workOrderObj = Object.assign({}, workOrderRes.result);
        this.workOrderObj = Object.assign({}, workOrderRes.result)
        //物料列表
        let materialListRes = await this.loadMaterialList(workOrderRes.result.materialNumber)
        if (materialListRes.success && materialListRes.result && materialListRes.result.length > 0) {
          this.materialList = [...materialListRes.result]
          this.materialList = materialListRes.result.map(item => ({
            ...item,
            value: item.materialNumber,
            text: item.materialName
          }))
        } else {
          this.materialList = []
        }
@@ -163,24 +165,28 @@
          this.model.targetWarehouseId = undefined
          this.model.warehouseName = ''
        }
      }else {
        this.editable = false;
      } else {
        this.editable = false
      }
    },
    async selectConfirm(rows) {
      if (rows && rows.length > 0) {
        //清空关联数据
        this.model.materialNumber = undefined;
        this.model.materialName = '';
        this.model.specifiedQuantity = 0;
        this.model.materialNumber = undefined
        this.model.materialName = ''
        this.model.specifiedQuantity = 0
        //赋值新的数据
        this.model.workOrderId = rows[0].id
        this.model.workOrderCode = rows[0].workOrderCode
        //排产工单赋值
        this.workOrderObj = Object.assign({}, rows[0]);
        this.workOrderObj = Object.assign({}, rows[0])
        let materialListRes = await this.loadMaterialList(rows[0].materialNumber)
        if (materialListRes.success && materialListRes.result && materialListRes.result.length > 0) {
          this.materialList = [...materialListRes.result]
          this.materialList = materialListRes.result.map(item => ({
            ...item,
            value: item.materialNumber,
            text: item.materialName
          }))
        } else {
          this.materialList = []
        }
@@ -194,13 +200,13 @@
        }
      } else {
        //清空关联数据
        this.model.materialNumber = undefined;
        this.model.materialName = '';
        this.model.specifiedQuantity = 0;
        this.model.materialNumber = undefined
        this.model.materialName = ''
        this.model.specifiedQuantity = 0
        this.materialList = []
        this.model.targetWarehouseId = undefined
        this.model.warehouseName = ''
        this.workOrderObj = {};
        this.workOrderObj = {}
      }
    },
    submitForm() {
src/views/mes/modules/MesProductionOrderModal.vue
@@ -56,6 +56,11 @@
    },
    handleCancel() {
      this.close()
    },
    // æ‰“开详情弹窗时清除表单校验
    removeValidate() {
      if (this.$refs.realForm)
        this.$refs.realForm.clearValidate()
    }
  }
}
src/views/mes/modules/MesProductionWorkOrderCompletenessCheckModal.vue
@@ -147,9 +147,11 @@
    },
    submitCallback(){
      this.$emit('ok');
      this.dataSource = []
      this.visible = false;
    },
    handleCancel () {
      this.dataSource = []
      this.close()
    }
  }
src/views/mes/modules/MesProductionWorkOrderEquipmentInspectionModal.vue
@@ -40,6 +40,11 @@
            </a-form-model-item>
          </a-col>
        </a-row>
        <a-row :gutter="24" v-if="selectedCount > 1" style="margin-bottom: 10px;">
          <a-col :span="24">
            <a-button type="primary" @click="batchSetNormal">批量点检正常</a-button>
          </a-col>
        </a-row>
        <a-row :gutter="24">
          <vxe-table
            ref="table"
@@ -50,7 +55,11 @@
            :data="dataSource"
            :edit-config="{trigger: 'click', mode: 'cell'}"
            :edit-rules="editRules"
            :checkbox-config="{trigger: 'cell', highlight: true}"
            @checkbox-change="onSelectChange"
            @checkbox-all="onSelectChange"
          >
            <vxe-table-column type="checkbox" width="40"></vxe-table-column>
            <vxe-table-column title="序号" field="itemCode" width="50" align="center"></vxe-table-column>
            <vxe-table-column title="部位" field="itemPart" align="center"></vxe-table-column>
            <vxe-table-column title="保养项目" field="itemName" align="center"></vxe-table-column>
@@ -142,7 +151,8 @@
        updateOrderInspectionStatus: '/mes/mesProductionWorkOrder/edit'
      },
      inspectionEquipmentOptions: [],
      workOrderId: null
      workOrderId: null,
      selectedCount: 0
    }
  },
  computed: {
@@ -182,6 +192,17 @@
          this.dataSource = res.result.maintenanceStandardDetailList
        }
      })
    },
    onSelectChange({records}) {
      this.selectedCount = records.length;
    },
    batchSetNormal() {
      const selectRecords = this.$refs.table.getCheckboxRecords();
      selectRecords.forEach(record => {
        record.inspectionResult = '1'
        record.exceptionDescription = ''
      });
      this.$refs.table.syncData()
    },
    handleOk () {
      this.$refs.table.validate((valid) => {
@@ -234,6 +255,10 @@
      }
      this.model = {}
      this.dataSource = []
      this.selectedCount = 0
      if (this.$refs.table) {
        this.$refs.table.clearCheckboxRow()
      }
    },
    submitCallback(){
      this.$emit('ok');
src/views/mes/modules/MesProductionWorkOrderProcessCheckModal.vue
@@ -18,6 +18,11 @@
            </a-form-model-item>
          </a-col>
        </a-row>
        <a-row :gutter="24" v-if="selectedCount > 1" style="margin-bottom: 10px;">
          <a-col :span="24">
            <a-button type="primary" @click="batchSetNormal">批量点检正常</a-button>
          </a-col>
        </a-row>
        <a-row :gutter="24">
          <vxe-table
            ref="table"
@@ -28,7 +33,11 @@
            :data="dataSource"
            :edit-config="{trigger: 'click', mode: 'cell'}"
            :edit-rules="editRules"
            :checkbox-config="{trigger: 'cell', highlight: true}"
            @checkbox-change="onSelectChange"
            @checkbox-all="onSelectChange"
          >
            <vxe-table-column type="checkbox" width="40"></vxe-table-column>
            <vxe-table-column title="序号" type="seq" width="50" align="center"></vxe-table-column>
            <vxe-table-column title="参数编码" field="parameterCode" align="center"></vxe-table-column>
            <vxe-table-column title="参数名称" field="parameterName" align="center"></vxe-table-column>
@@ -40,9 +49,9 @@
            <vxe-table-column title="计量单位" field="parameterUnit" align="center"></vxe-table-column>
            <vxe-table-column title="参数范围" field="parameterPeriod" align="center"></vxe-table-column>
            <vxe-table-column title="点检结果" field="checkResult" align="center"
                              :edit-render="{name: '$select', options: checkResultOptions, events: {change: handleCheckResultChange}}">
                              :edit-render="{name: '$select', options: checkResultOptions}">
              <template #default="{ row }">
                <span v-if="row.checkResult">{{ row.checkResultLabel }}</span>
                <span v-if="row.checkResult">{{ getCheckResultLabel(row.checkResult) }}</span>
                <span v-else class="placeholder-text">请选择点检结果</span>
              </template>
            </vxe-table-column>
@@ -125,7 +134,8 @@
        updateOrderInspectionStatus: '/mes/mesProductionWorkOrder/edit'
      },
      processCheckEquipmentOptions: [],
      workOrderId: null
      workOrderId: null,
      selectedCount: 0
    }
  },
  computed: {
@@ -134,9 +144,9 @@
    }
  },
  methods: {
    handleCheckResultChange($event, value) {
      const selected = this.checkResultOptions.find(item => item.value === value.value)
      $event.row.checkResultLabel = selected.label
    getCheckResultLabel(value) {
      const selected = this.checkResultOptions.find(item => item.value === value)
      return selected ? selected.label : ''
    },
    inspect (record) {
      this.resetFormData()
@@ -165,6 +175,17 @@
          this.dataSource = res.result
        }
      })
    },
    onSelectChange({records}) {
      this.selectedCount = records.length;
    },
    batchSetNormal() {
      const selectRecords = this.$refs.table.getCheckboxRecords();
      selectRecords.forEach(record => {
        record.checkResult = '1'
        record.exceptionDescription = ''
      });
      this.$refs.table.syncData()
    },
    handleOk () {
      this.$refs.table.validate((valid) => {
@@ -214,6 +235,10 @@
    resetFormData() {
      this.model = {}
      this.dataSource = []
      this.selectedCount = 0
      if (this.$refs.table) {
        this.$refs.table.clearCheckboxRow()
      }
    },
    submitCallback(){
      this.$emit('ok');
src/views/mes/modules/WorkOrderSelectModal.vue
@@ -70,7 +70,7 @@
        workOrderStatus: this.orderStatus,
      },
      url: {
        list: "/mes/mesProductionWorkOrder/list"
        list: "/mes/mesProductionWorkOrder/queryWorkOrderByTransfer"
      },
      columns: [
        {
src/views/qms/InspectionItemList.vue
@@ -197,17 +197,17 @@
        {
          title: '检验项目分类',
          align: "center",
          dataIndex: 'itemCategoryName'
          dataIndex: 'itemCategory_dictText'
        },
        {
          title: '定量/定性',
          align: "center",
          dataIndex: 'qualitativeOrQuantitativeName'
          dataIndex: 'qualitativeOrQuantitative_dictText'
        },
        {
          title: '测量工具',
          align: "center",
          dataIndex: 'inspectionToolsNames'
          dataIndex: 'inspectionToolNames'
        },
        {
          title: '备注',
@@ -232,7 +232,7 @@
        }
      ],
      url: {
        list: '/qms/inspectionItem/queryList',
        list: '/qms/inspectionItem/list',
        delete: '/qms/inspectionItem/delete',
        active: '/qms/inspectionItem/active',
      },