Parcourir la source

设备修改提交报错

il y a 2 ans
Parent
commit
a69db74a36

+ 2 - 0
src/router/generator-platform-routers.js

@@ -77,6 +77,8 @@ const constantRouterComponents = {
   'MeasureLogSpecial': () => import('@/views/sb/measurelog/MeasureLogSpecial'),
   // 特种设备基础信息
   'SpecialSbInfo': () => import('@/views/sb/info/SpecialSbInfo'),
+  'SpecialSbInfo2': () => import('@/views/sb/info/SpecialSbInfo2'),
+
   // 特种设备预警
   'SpecialSbInfoWarn': () => import('@/views/sb/info/SpecialSbInfoWarn'),
   // 特种设备在库

+ 3 - 3
src/views/sb/info/SpecialSbInfo.vue

@@ -1,13 +1,13 @@
 <template>
-  <SbInfo :use-type="5" :correct-type="2" />
+  <SpecialSbInfo2 :use-type="5" :correct-type="2" />
 </template>
 
 <script>
-import SbInfo from './SbInfo'
+import SpecialSbInfo2 from './SpecialSbInfo2'
 export default {
   name: 'MySbInfo',
   components: {
-    SbInfo
+    SpecialSbInfo2
   }
 }
 </script>

+ 913 - 0
src/views/sb/info/SpecialSbInfo2.vue

@@ -0,0 +1,913 @@
+<template>
+  <div>
+    <a-card :bordered="false" v-show="visible">
+      <a-row :gutter="8" >
+        <a-col :span="24">
+          <div>
+            <div class="table-page-search-wrapper">
+              <a-form layout="inline">
+                <a-row :gutter="48">
+                  <a-col :md="6" :sm="24">
+                    <a-form-item label="关键字">
+                      <a-input v-model.trim="queryParam.keyword" placeholder="设备编号"/>
+                    </a-form-item>
+                  </a-col>
+                  <a-col :md="6" :sm="24">
+                    <a-form-item label="车间位置">
+                      <a-select v-model="queryParam.positionId" placeholder="请选择">
+                        <a-select-option
+                          v-for="({id,name}) in sbPositionData"
+                          :key="id"
+                          :label="name"
+                          :value="id">{{ name }}
+                        </a-select-option>
+                      </a-select>
+                    </a-form-item>
+                  </a-col>
+                  <a-col :md="6" :sm="24">
+                    <a-form-item label="设备名称">
+                      <a-input v-model.trim="queryParam.name" placeholder="名称"/>
+                    </a-form-item>
+                  </a-col>
+                  <a-col :md="6" :sm="24">
+                    <a-form-item label="父位号">
+                      <a-input v-model.trim="queryParam.ppNo" placeholder="父位号"/>
+                    </a-form-item>
+                  </a-col>
+                  <a-col :md="6" :sm="24">
+                    <a-form-item label="设备位号">
+                      <a-input v-model.trim="queryParam.positionNo" placeholder="设备位号"/>
+                    </a-form-item>
+                  </a-col>
+                  <a-col :md="6" :sm="24">
+                    <a-form-item label="生产商">
+                      <a-input v-model.trim="queryParam.producerId" placeholder="生产商"/>
+                    </a-form-item>
+                  </a-col>
+                  <!--                  <a-col :md="6" :sm="24">
+                    <a-form-item label="设备自编号">
+                      <a-input v-model="queryParam.zbh" placeholder="设备自编号"/>
+                    </a-form-item>
+                  </a-col>-->
+                  <a-col :md="6" :sm="24">
+                    <a-form-item label="设备等级">
+                      <a-select v-model="queryParam.level" placeholder="请选择">
+                        <a-select-option
+                          v-for="(label,value) in levelMap"
+                          :key="value"
+                          :label="label"
+                          :value="parseInt(value)">{{ label }}
+                        </a-select-option>
+                      </a-select>
+                    </a-form-item>
+                  </a-col>
+                  <!--                  <a-col :md="6" :sm="24">
+                    <a-form-item label="自定义类型">
+                      <a-select v-model="queryParam.useType" placeholder="请选择">
+                        <a-select-option
+                          v-for="(label,value) in useTypeMap"
+                          :key="value"
+                          :label="label"
+                          :value="parseInt(value)">{{ label }}
+                        </a-select-option>
+                      </a-select>
+                    </a-form-item>
+                  </a-col>-->
+                  <a-col :md="6" :sm="24">
+                    <a-form-item label="检定日期范围">
+                      <a-range-picker v-model="dateRangeCheck" />
+                    </a-form-item>
+                  </a-col>
+                  <a-col :md="6" :sm="24">
+                    <a-form-item label="有效日期范围">
+                      <a-range-picker v-model="dateRange"/>
+                    </a-form-item>
+                  </a-col>
+                  <a-col :md="6" :sm="24">
+                    <a-form-item label="规格型号">
+                      <a-input v-model="queryParam.model" placeholder="规格型号"/>
+                    </a-form-item>
+                  </a-col>
+                  <a-col :md="6" :sm="24">
+                    <a-form-item label="设备类型">
+                      <a-tree-select
+                        style="width: 100%"
+                        :dropdownStyle="{ maxHeight: '400px', overflow: 'auto' }"
+                        :treeData="treeData"
+                        :treeNodeFilterProp="'title'"
+                        :showSearch="true"
+                        v-model="queryParam.typeId"
+                        placeholder="请选择"
+                      >
+                      </a-tree-select>
+                    </a-form-item>
+                  </a-col>
+                  <a-col :md="6" :sm="24">
+                    <a-form-item label="设备状态">
+                      <a-select v-model="queryParam.status" placeholder="请选择">
+                        <a-select-option
+                          v-for="(label,value) in statusMap"
+                          :key="value"
+                          :defaultValue="DictCache.VALUE.SB_INFO_STATUS.IN_USE"
+                          :label="label"
+                          :value="parseInt(value)">{{ label }}
+                        </a-select-option>
+                      </a-select>
+                    </a-form-item>
+                  </a-col>
+                  <a-col :md="6" :sm="24">
+                    <a-form-item label="主子设备">
+                      <a-select v-model="queryParam.isChild" placeholder="请选择">
+                        <a-select-option value="1">子设备</a-select-option>
+                        <a-select-option value="2">父设备</a-select-option>
+                        <a-select-option value="3">普通设备</a-select-option>
+                      </a-select>
+                    </a-form-item>
+                  </a-col>
+                  <a-col :md="6" :sm="24">
+                    <a-form-item label="电力线路">
+                      <a-select v-model="queryParam.baoyangTimes" placeholder="请选择">
+                        <a-select-option
+                          v-for="(label,value) in lineMap"
+                          :key="value"
+                          :label="label"
+                          :value="parseInt(value)">{{ label }}
+                        </a-select-option>
+                      </a-select>
+                    </a-form-item>
+                  </a-col>
+                  <a-col :md="6 || 24" :sm="24">
+                    <span class="table-page-search-submitButtons">
+                      <a-button type="primary" @click="handleOk">查询</a-button>
+                      <a-button style="margin-left: 8px" @click="resetSearchForm">重置</a-button>
+                    </span>
+                  </a-col>
+                </a-row>
+              </a-form>
+            </div>
+
+            <div class="table-operator" style="margin-bottom: 8px;">
+              <a-button v-if="$auth('sb-infos-add')" type="primary" icon="plus" @click="handleAdd">新增</a-button>
+              <a-button style="margin-left: 8px" v-if="$auth('sb-infos-export')" type="primary" icon="download" @click="doExport">导出</a-button>
+              <!--              <a-button style="margin-left:8px;" type="primary" @click="doImport">
+                <a-icon type="upload"/>
+                新增导入
+              </a-button>-->
+              <a-button style="margin-left:8px;" type="primary" @click="doImportStandard">
+                <a-icon type="upload"/>
+                导入
+              </a-button>
+              <a-button style="margin-left:8px;" type="primary" @click="doImportForUpdate">
+                <a-icon type="upload"/>
+                修改导入
+              </a-button>
+              <a-button style="margin-left: 8px" type="primary" icon="printer" @click="handlePrintBatch()">批量打印</a-button>
+              <!-- <a-button style="margin-left: 8px" type="primary" icon="reload" @click="handleMeasureBatch()">批量检定</a-button> -->
+              <a-button style="margin-left: 8px" v-if="$auth('sb-infos-generate-code-all')" :loading="confirmLoading" type="primary" @click="batchGenerate()">重新生成二维码</a-button>
+              <a-dropdown v-action:edit v-if="selectedRowKeys.length > 0 && $auth('sb-infos-del')">
+                <a-menu slot="overlay">
+                  <a-popconfirm title="是否要删除所选数据?" @confirm="batchDelete()">
+                    <a-menu-item key="1"><a-icon type="delete" /><a>删除</a></a-menu-item>
+                  </a-popconfirm>
+                  <a-popconfirm v-if="isMeasure===1" @visibleChange="batchIncorrect()">
+                    <a-menu-item key="2"><my-icon type="icon-pandian" /><a>检定</a></a-menu-item>
+                  </a-popconfirm>
+                  <a-popconfirm v-if="isMeasure===1" @visibleChange="batchIncorrectInStore()">
+                    <a-menu-item key="3"><my-icon type="icon-pandian" /><a>入库</a></a-menu-item>
+                  </a-popconfirm>
+                  <a-popconfirm :visible="false" @visibleChange="batchLocation()">
+                    <a-menu-item key="4"><my-icon type="icon-pandian" /><a>设备位号</a></a-menu-item>
+                  </a-popconfirm>
+                </a-menu>
+                <a-button style="margin-left: 8px">
+                  批量操作 <a-icon type="down" />
+                </a-button>
+              </a-dropdown>
+            </div>
+
+            <s-table
+              ref="table"
+              @expand="onExpand"
+              size="default"
+              rowKey="id"
+              :widthSpace="true"
+              :columns="columns"
+              :data="loadData"
+              :alert="options.alert"
+              :rowSelection="options.rowSelection"
+              :scroll="{x: 1500, y: BaseTool.Constant.scrollY}"
+              showPagination="auto"
+            >
+              <template #positionNo="text,record">
+                <a @click="showChangeLog(record)">{{ text }}</a>
+              </template>
+              <span slot="action" slot-scope="record">
+                <template>
+                  <div>
+                    <!--<a-divider type="vertical" />
+                    <a-popconfirm v-if="$auth('sb-infos-del')" title="是否要删除该设备?" @confirm="batchDelete(record.id)">
+                      <a>删除</a>
+                    </a-popconfirm>
+                    <a-divider type="vertical" />
+                    <a @click="handleCopy(record)">复制</a>-->
+                    <a-dropdown>
+                      <a-menu slot="overlay">
+                        <a-menu-item key="0">
+                          <a @click="handleView(record)">查看</a>
+                        </a-menu-item>
+                        <a-menu-item key="1">
+                          <a v-if="$auth('sb-infos-edit')" @click="handleEdit(record)">修改</a>
+                        </a-menu-item>
+                        <a-menu-item key="2" v-if="isMeasure===1" >
+                          <a @click="batchIncorrect(record)">检定</a>
+                        </a-menu-item>
+                        <a-menu-item key="3" v-if="isMeasure===1" >
+                          <a @click="batchIncorrectInStore(record)">入库</a>
+                        </a-menu-item>
+                        <a-menu-item v-if="record.status != 2" key="2">
+                          <a-popconfirm title="是否要启用该设备?" @confirm="handleStart(record)">
+                            <a>启用</a>
+                          </a-popconfirm>
+                        </a-menu-item>
+                        <a-menu-item v-if="record.status != 7" key="3">
+                          <a-popconfirm title="是否要停用该设备?" @confirm="handleStop(record)">
+                            <a>停用</a>
+                          </a-popconfirm>
+                        </a-menu-item>
+                        <a-menu-item key="10">
+                          <a v-if="$auth('sb-infos-edit')" @click="handleCopy(record)">复制</a>
+                        </a-menu-item>
+                        <a-menu-item key="4">
+                          <a @click="handlePrint(record)">打印</a>
+                        </a-menu-item>
+                      </a-menu>
+                      <a-button> 操作 <a-icon type="down" /> </a-button>
+                    </a-dropdown>
+                  </div>
+                </template>
+              </span>
+              <span slot="status" slot-scope="text">
+                <badge
+                  :status="DictCache.COLOR.SB_INFO_STATUS[text]"
+                  :text="statusMap[text]" />
+              </span>
+              <span slot="measureStatus" slot-scope="text">
+                <badge
+                  :status="DictCache.COLOR.SB_MEASURE_STATUS[text]"
+                  :text="yesNoMap[text]" />
+              </span>
+            </s-table>
+          </div>
+        </a-col>
+      </a-row>
+    </a-card>
+    <base-form ref="baseModal" :parent-id="queryParam.parentId" :parent-name="queryParam.parentName" @ok="handleOk"/>
+    <base-form-status-log ref="baseModalStatusLog" @ok="handleOk"/>
+    <detail ref="detailModal" @ok="handleOk"/>
+    <download-modal ref="downloadModal"/>
+    <preview-modal ref="previewModal"/>
+    <import-form-add ref="importModal" @ok="handleOk"/>
+    <import-form-add-standard ref="importModalStandard" @ok="handleOk"/>
+    <import-form-update ref="importModalUpdate" @ok="handleOk"/>
+    <print-sb-code ref="printSbCode"/>
+    <print-in-sb-info-batch ref="printInSbInfoBatch" @ok="handleOk"/>
+    <detail-sb-measure ref="detailSbMeasureModal" @ok="handleOk"/>
+    <base-form-measure ref="baseModalMeasure" @ok="handleOk"/>
+    <base-form-measure-in-store ref="baseModalMeasureInStore" @ok="handleOk"/>
+    <base-form-location ref="baseFormLocation" @ok="handleOk" />
+    <SbChangeLogSelectModal ref="sbChangeRecordSelectModal" @ok="handleOk" />
+  </div>
+</template>
+
+<script>
+import { STable, Ellipsis } from '@/components'
+import BaseForm from './modules/BaseForm'
+import DetailSbMeasure from '@/views/sb/measurelog/modules/DetailSbCheckBatch'
+import BaseFormStatusLog from '@/views/sb/status-log/modules/BaseForm'
+import Detail from './modules/Detail'
+import BaseFormMeasure from './modules/BaseFormMeasure'
+import BaseFormMeasureInStore from './modules/BaseFormMeasureInStore'
+import BaseFormLocation from './modules/BaseFormLocation'
+import DownloadModal from '@/views/download/DownloadModal'
+import PreviewModal from '@/views/preview/PreviewModal'
+import { getSbInfoPage, deleteSbInfos, querySbInfo, fetchSbInfo, fetchSbInfos, exportSbInfo, batchLocationList } from '@/api/sb/info'
+import { queryDept } from '@/api/upms/dept'
+import { generateSbCodeAll } from '@/api/upms/code'
+import { fetchSbTypeTree } from '@/api/sb/type'
+import ImportFormAdd from './modules/ImportFormAdd'
+import ImportFormAddStandard from './modules/ImportFormAddStandard'
+import ImportFormUpdate from './modules/ImportFormUpdate'
+import PrintSbCode from '@/views/sb/info/modules/PrintSbCode'
+import PrintInSbInfoBatch from '@/views/sb/info/modules/PrintInSbInfoBatch'
+import { querySbPosition } from '@/api/sb/position'
+import SbChangeLogSelectModal from '@/views/sb/change-log/modules/SbChangeLogSelectModal'
+export default {
+  name: 'SbInfoList',
+  components: {
+    STable,
+    Ellipsis,
+    BaseForm,
+    DetailSbMeasure,
+    Detail,
+    DownloadModal,
+    PreviewModal,
+    PrintSbCode,
+    ImportFormAdd,
+    ImportFormAddStandard,
+    ImportFormUpdate,
+    PrintInSbInfoBatch,
+    BaseFormMeasure,
+    BaseFormMeasureInStore,
+    BaseFormLocation,
+    BaseFormStatusLog,
+    SbChangeLogSelectModal
+  },
+  props: {
+    filter: {
+      type: Number,
+      default: -1
+    },
+    useType: {
+      type: Number,
+      default: null
+    },
+    correctType: {
+      type: Number,
+      default: 1
+    },
+    measureStatus: {
+      type: Number,
+      default: null
+    },
+    isMeasure: {
+      type: Number,
+      default: null
+    },
+    isSelf: {
+      type: Number,
+      default: null
+    },
+    status: {
+      type: Number,
+      default: null
+    }
+  },
+  data () {
+    return {
+      // 查询参数
+      queryParam: {
+        filter: this.filter,
+        useType: this.useType,
+        measureStatus: this.measureStatus,
+        isMeasure: this.isMeasure,
+        isSelf: this.isSelf,
+        id: this.$route.query.id,
+        typeId: this.$route.query.typeId,
+        status: this.$route.query.status || this.status
+      },
+      depreciationTypeMap: {},
+      visible: true,
+      dateRange: [],
+      dateRangeCheck: [],
+      sbPositionData: [],
+      levelMap: {},
+      lineMap: {},
+      unitMap: {},
+      areaList: {},
+      companyList: {},
+      projectList: {},
+      isChildMap: {},
+      isShowMap: {},
+      deptList: {},
+      confirmLoading: false,
+      useTypeMap: {},
+      statusMap: {},
+      yesNoMap: {},
+      expandedKeys: [],
+      selectedKeys: [],
+      sourceTypeMap: {},
+      treeData: [],
+      // 表头
+      columns: [
+        /* {
+          title: '序号',
+          dataIndex: 'index',
+          width: 100,
+          checked: true,
+          customRender: (text, record, index) => {
+            return `${(this.$refs.table.localPagination.current - 1) * this.$refs.table.localPagination.pageSize + index + 1}`
+          }
+        }, */
+        {
+          title: '设备位置',
+          checked: true,
+          width: 200,
+          dataIndex: 'positionName'
+        },
+        {
+          title: '设备名称',
+          checked: true,
+          width: 200,
+          dataIndex: 'name'
+        },
+        {
+          title: '标牌号',
+          dataIndex: 'bpNo',
+          width: 150,
+          checked: true
+        },
+        {
+          title: '设备工作压力MPa',
+          dataIndex: 'sbWorkPa',
+          width: 120,
+          checked: true
+        },
+
+        {
+          title: '安全阀类型',
+          checked: true,
+          dataIndex: 'securityType',
+          width: 150
+        },
+        /* {
+          title: '设备等级',
+          checked: true,
+          dataIndex: 'level',
+          width: 120,
+          customRender: (text, record, index) => {
+            return this.BaseTool.Object.getField(this.levelMap, text)
+          }
+        }, */
+        {
+          title: '安全阀型号',
+          dataIndex: 'securityModel',
+          width: 150,
+          checked: true
+        },
+        {
+          title: '公称通径',
+          dataIndex: 'gctj',
+          width: 150,
+          checked: true
+        },
+        {
+          title: '公称压力MPa',
+          dataIndex: 'gcPa',
+          width: 120,
+          checked: true
+        },
+        /* {
+          title: '自定义类型',
+          checked: true,
+          dataIndex: 'useType',
+          width: 150,
+          customRender: (text, record, index) => {
+            return this.BaseTool.Object.getField(this.useTypeMap, text)
+          }
+        }, */
+
+        /* {
+          title: '使用机台',
+          checked: true,
+          width: 200,
+          dataIndex: 'saveUserName'
+        },
+        {
+          title: '生产商',
+          dataIndex: 'producerId',
+          width: 120,
+          checked: true
+        }, */
+        /* {
+          title: '大小尺寸',
+          dataIndex: 'zz',
+          width: 120,
+          checked: true
+        }, */
+
+        {
+          title: '所在设备最高工作压力',
+          dataIndex: 'maxPa',
+          width: 120,
+          checked: true
+        },
+
+        /* {
+          title: '是否显示',
+          dataIndex: 'isShow',
+          width: 120,
+          checked: true,
+          customRender: (text, record, index) => {
+            return this.BaseTool.Object.getField(this.isShowMap, text)
+          }
+        }, */
+
+        /*  {
+          title: '是否子设备',
+          dataIndex: 'isChild',
+          width: 120,
+          checked: true,
+          customRender: (text, record, index) => {
+            return this.BaseTool.Object.getField(this.isChildMap, text)
+          }
+        }, */
+        /* {
+          title: '资产编号',
+          dataIndex: 'financingNo',
+          width: 120,
+          checked: true
+        },
+        {
+          title: '设备原值',
+          dataIndex: 'initialValue',
+          width: 100,
+          checked: true,
+          customRender: (text, record, index) => {
+            return this.BaseTool.Amount.formatter(text)
+          }
+        },
+        {
+          title: '购置日期',
+          dataIndex: 'buyDate',
+          width: 120,
+          checked: true
+        },
+        {
+          title: '投用日期',
+          dataIndex: 'startDate',
+          width: 120,
+          checked: true
+        }, */
+        /* {
+          title: '检定日期',
+          dataIndex: 'checkDate',
+          width: 150,
+          checked: true
+        },
+        {
+          title: '检定周期',
+          dataIndex: 'checkPeriod',
+          width: 100,
+          checked: true,
+          customRender: (text, record, index) => {
+            if (record.nextCheckDate == null) {
+              return '未知'
+            } else {
+              return text + '月'
+            }
+          }
+        }, */
+        {
+          title: '整定压力',
+          dataIndex: 'zdPa',
+          width: 150,
+          checked: true
+        },
+        /*  {
+          title: '检定截止',
+          dataIndex: 'restDay',
+          width: 100,
+          checked: true,
+          customRender: (text, record, index) => {
+            if (record.nextCheckDate == null) {
+              return '未知'
+            } else {
+              return this.BaseTool.Date.getCountBetween(new Date(), record.nextCheckDate, 1) + '天'
+            }
+          }
+        }, */
+        {
+          title: '报告编号',
+          checked: true,
+          dataIndex: 'reportNo',
+          // fixed: 'right',
+          width: 100
+          // scopedSlots: { customRender: 'status' }
+        },
+        // {
+        //   title: '检定状态',
+        //   checked: true,
+        //   dataIndex: 'measureStatus',
+        //   fixed: 'right',
+        //   width: 100,
+        //   scopedSlots: { customRender: 'measureStatus' }
+        // },
+        {
+          title: '操作',
+          key: 'action',
+          checked: true,
+          fixed: 'right',
+          align: 'center',
+          width: '120',
+          scopedSlots: { customRender: 'action' }
+        }
+      ],
+      // 加载数据方法 必须为 Promise 对象
+      loadData: parameter => {
+        parameter = {
+          ...parameter,
+          ...this.queryParam,
+          dataScope: {
+            sortBy: 'asc',
+            sortName: 'no'
+          }
+        }
+        this.selectedRowKeys = []
+        return getSbInfoPage(Object.assign(parameter, this.queryParam))
+          .then(res => {
+            return res.data
+          })
+      },
+      selectedRowKeys: [],
+      selectedRows: [],
+
+      options: {
+        alert: { show: true, clear: () => { this.selectedRowKeys = [] } },
+        rowSelection: {
+          selectedRowKeys: this.selectedRowKeys,
+          onChange: this.onSelectChange
+        }
+      },
+      optionAlertShow: false
+    }
+  },
+  created () {
+    console.log('this.$route.query.parentId: ' + this.$route.query.parentId)
+    this.queryParam.parentId = this.$route.query.parentId
+    this.queryParam.parentName = this.$route.query.parentName
+    this.tableOption()
+    this.depreciationTypeMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.SBINFO_DEPRECIATIONTYPE)
+    this.levelMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.SBINFO_LEVEL)
+    this.statusMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.SB_INFO_STATUS)
+    this.unitMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.SBINFO_UNIT)
+    this.sourceTypeMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.SBTYPE_SOURCETYPE)
+    this.useTypeMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.SB_USE_TYPE)
+    this.isChildMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.SB_IS_CHILD)
+    this.isShowMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.SB_IS_SHOW)
+    this.lineMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.REMOTE_LINE)
+    this.yesNoMap = this.DictCache.getLabelByValueMapByType(this.DictCache.TYPE.YES_NO)
+    querySbPosition().then(res => {
+      this.sbPositionData = res.data
+    })
+  },
+  methods: {
+    tableOption () {
+      this.setTree()
+      if (!this.optionAlertShow) {
+        this.options = {
+          alert: { show: true, clear: () => { this.selectedRowKeys = [] } },
+          rowSelection: {
+            selectedRowKeys: this.selectedRowKeys,
+            onChange: this.onSelectChange,
+            getCheckboxProps: record => ({
+              props: {
+                disabled: false,
+                name: record.id
+              }
+            })
+          }
+        }
+        this.optionAlertShow = true
+      } else {
+        this.options = {
+          alert: false,
+          rowSelection: null
+        }
+        this.optionAlertShow = false
+      }
+    },
+    batchDelete (id) {
+      let ids = []
+      if (this.BaseTool.String.isBlank(id)) {
+        const length = this.selectedRows.length
+        if (length === 0) {
+          this.$message.info('请选择要删除的记录')
+          return
+        }
+        ids = this.selectedRows.map(item => item.id)
+      } else {
+        ids = [id]
+      }
+      deleteSbInfos(ids).then(res => {
+        this.$message.info('删除成功')
+        this.handleOk()
+        this.$refs.table.clearSelected()
+      })
+    },
+    batchGenerate () {
+      this.confirmLoading = true
+      this.$message.info('正在生成请稍后')
+      generateSbCodeAll().then(res => {
+        this.confirmLoading = false
+        this.$message.info('生成成功')
+        this.handleOk()
+        this.$refs.table.clearSelected()
+      })
+    },
+    handleEdit (record) {
+      fetchSbInfo({ id: record.id }).then(res => {
+        this.visible = false
+        const modal = this.$refs.baseModal
+        modal.base(res.data)
+      })
+    },
+    handlePrint (record) {
+      this.visible = false
+      fetchSbInfo({ id: record.id }).then(res => {
+        const modal = this.$refs.printInSbInfoBatch
+        modal.base([res.data])
+      })
+    },
+    batchLocation () {
+      let ids = []
+      const length = this.selectedRows.length
+      if (length === 0) {
+        this.$message.info('请选择设备')
+        return
+      }
+      ids = this.selectedRows.map(item => item.id)
+      console.log(ids)
+      batchLocationList({ ids }).then(res => {
+        this.visible = false
+        const modal = this.$refs.baseFormLocation
+        modal.base(res.data)
+      })
+    },
+    batchIncorrect (id) {
+      let ids = []
+      if (this.BaseTool.String.isBlank(id)) {
+        const length = this.selectedRows.length
+        if (length === 0) {
+          this.$message.info('请选择要填报的设备')
+          return
+        }
+        ids = this.selectedRows
+      } else {
+        ids = [id]
+      }
+      this.visible = false
+      const modal = this.$refs.baseModalMeasure
+      modal.base(ids, this.correctType)
+    },
+    batchIncorrectInStore (id) {
+      let ids = []
+      if (this.BaseTool.String.isBlank(id)) {
+        const length = this.selectedRows.length
+        if (length === 0) {
+          this.$message.info('请选择要填报的设备')
+          return
+        }
+        ids = this.selectedRows
+      } else {
+        ids = [id]
+      }
+      this.visible = false
+      const modal = this.$refs.baseModalMeasureInStore
+      modal.base(ids, this.correctType)
+    },
+    handleMeasureBatch () {
+      const modal = this.$refs.detailSbMeasureModal
+      modal.base()
+    },
+    handlePrintBatch () {
+      this.visible = false
+      let ids = []
+      const length = this.selectedRows.length
+      if (length === 0) {
+        this.$message.info('请选择要打印的设备')
+        return
+      }
+      ids = this.selectedRows.map(item => item.id)
+      fetchSbInfos(ids).then(res => {
+        const modal = this.$refs.printInSbInfoBatch
+        modal.base(res.data)
+      })
+    },
+    handleStart (record) {
+      const modal = this.$refs.baseModalStatusLog
+      modal.base(null, {
+        sbId: record.id,
+        sbNo: record.no,
+        changeUserId: this.$store.getters.userInfo.userId,
+        actualUser: this.$store.getters.userInfo.realName,
+        preStatus: record.status,
+        afterStatus: this.DictCache.VALUE.SB_INFO_STATUS.IN_USE
+      })
+    },
+    handleStop (record) {
+      const modal = this.$refs.baseModalStatusLog
+      modal.base(null, {
+        sbId: record.id,
+        sbNo: record.no,
+        changeUserId: this.$store.getters.userInfo.userId,
+        actualUser: this.$store.getters.userInfo.realName,
+        preStatus: record.status,
+        afterStatus: this.DictCache.VALUE.SB_INFO_STATUS.IN_STOP
+      })
+    },
+    handleAdd () {
+      this.visible = false
+      this.$refs.baseModal.base()
+    },
+    handleView (record) {
+      fetchSbInfo({ id: record.id }).then(res => {
+        this.visible = false
+        const modal = this.$refs.detailModal
+        modal.base(res.data)
+      })
+    },
+    showChangeLog (record) {
+      console.log(record)
+      console.log(this.$refs)
+      this.$refs.sbChangeRecordSelectModal.base({}, { sbId: record.id })
+    },
+    handleCopy (record) {
+      this.visible = false
+      fetchSbInfo({ id: record.id }).then(res => {
+        const modal = this.$refs.baseModal
+        modal.base(res.data, 1)
+      })
+    },
+    handleOk () {
+      this.visible = true
+      this.setTree()
+      if (this.dateRange != null) {
+        this.queryParam.nextCheckDateStart = this.dateRange[0]
+        this.queryParam.nextCheckDateEnd = this.dateRange[1]
+        this.queryParam.nextCheckDateStart = this.queryParam.nextCheckDateStart ? this.queryParam.nextCheckDateStart.format(this.BaseTool.Date.PICKER_NORM_DATE_PATTERN) : null
+        this.queryParam.nextCheckDateEnd = this.queryParam.nextCheckDateEnd ? this.queryParam.nextCheckDateEnd.format(this.BaseTool.Date.PICKER_NORM_DATE_PATTERN) : null
+      }
+      if (this.dateRangeCheck != null) {
+        this.queryParam.checkDateStart = this.dateRangeCheck[0]
+        this.queryParam.checkDateEnd = this.dateRangeCheck[1]
+        this.queryParam.checkDateStart = this.queryParam.checkDateStart ? this.queryParam.checkDateStart.format(this.BaseTool.Date.PICKER_NORM_DATE_PATTERN) : null
+        this.queryParam.checkDateEnd = this.queryParam.checkDateEnd ? this.queryParam.checkDateEnd.format(this.BaseTool.Date.PICKER_NORM_DATE_PATTERN) : null
+      }
+      this.$refs.table.refresh()
+    },
+    onSelectChange (selectedRowKeys, selectedRows) {
+      this.selectedRowKeys = selectedRowKeys
+      this.selectedRows = selectedRows
+    },
+    resetSearchForm () {
+      this.queryParam = {
+        filter: this.filter,
+        useType: this.useType,
+        measureStatus: this.measureStatus,
+        isMeasure: this.isMeasure,
+        isSelf: this.isSelf,
+        id: this.$route.query.id,
+        typeId: this.$route.query.typeId,
+        status: this.$route.query.status || this.status
+      }
+      this.visible = true
+      this.$refs.table.refresh(true)
+    },
+    doExport () {
+      const parameter = {
+        ...this.queryParam,
+        sbIds: this.selectedRowKeys,
+        dataScope: {
+          sortBy: 'asc',
+          sortName: 'no'
+        }
+      }
+      console.log(parameter)
+      exportSbInfo(parameter).then(file => {
+        this.BaseTool.UPLOAD.downLoadExportExcel(file)
+      })
+    },
+    setTree (record = {}) {
+      queryDept({ nature: this.DictCache.VALUE.SYS_DEPT_NATURE.JITUAN }).then(res => {
+        this.areaList = res.data
+      })
+      fetchSbTypeTree().then(res => {
+        this.treeData = res.data
+      })
+    },
+    onSelect: function (selectedKeys, info) {
+      this.selectedKeys = selectedKeys
+      this.queryParam.typeId = selectedKeys.length > 0 ? selectedKeys[0] : ''
+      this.$refs.table.refresh(true)
+    },
+    onExpand (expanded, record) { // expanded判断展开or收缩操作,record当前行数据
+      console.log(expanded)
+      if (expanded) {
+        querySbInfo({ positionNo: record.positionNo }).then(res => {
+          record.children = res.data
+        })
+      }
+    },
+    doImport () {
+      this.$refs.importModal.base(null, null)
+    },
+    doImportStandard () {
+      // this.$refs.importModalStandard.base()
+      this.$refs.importModalUpdate.base(null, 1)
+    },
+    doImportForUpdate () {
+      this.$refs.importModalUpdate.base(null, 2)
+    }
+  }
+}
+</script>

+ 5 - 5
src/views/sb/info/SpecialSbInfoWarn.vue

@@ -1,14 +1,14 @@
 <template>
-  <SbInfo :use-type="5" :is-measure="1" :measure-status="1">
-  </sbinfo>
+  <SpecialSbInfo2 :use-type="5" :is-measure="1" :measure-status="1">
+  </SpecialSbInfo2>
 </template>
 
 <script>
-import SbInfo from './SbInfo'
+import SpecialSbInfo2 from './SpecialSbInfo2'
 export default {
-  name: 'SpecialSbInfoWarn',
+  name: 'SpecialSbInfo2',
   components: {
-    SbInfo
+    SpecialSbInfo2
   }
 }
 </script>