guarantee-lsq há 2 anos atrás
pai
commit
2f10b3b188

+ 15 - 1
src/api/sb/changeLog.js

@@ -8,6 +8,21 @@ import { stringify } from 'qs'
  * @returns {*}
  */
 export function getSbChangeLogPage (parameter) {
+  return axios({
+    url: '/sb/sb-changes/page?' + stringify(parameter),
+    method: 'get',
+    headers: {
+      'Content-Type': 'application/json;charset=UTF-8'
+    }
+  })
+}
+/**
+ * page func
+ * parameter: { }
+ * @param parameter
+ * @returns {*}
+ */
+export function getSbChangeLog (parameter) {
   return axios({
     url: '/sb/change-logs/page?' + stringify(parameter),
     method: 'get',
@@ -16,7 +31,6 @@ export function getSbChangeLogPage (parameter) {
     }
   })
 }
-
 /**
  * add func
  * parameter: { }

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

@@ -60,6 +60,7 @@ const constantRouterComponents = {
   'SbInfo': () => import('@/views/sb/info/SbInfo'),
   // 测量设备基础信息
   'MeasureSbInfo': () => import('@/views/sb/info/MeasureSbInfo'),
+  'MeasureSbInfoAll': () => import('@/views/sb/info/MeasureSbInfoAll'),
   // 测量设备基础信息-需要检定-外部检定的
   'MeasureSbInfoCheck': () => import('@/views/sb/info/MeasureSbInfoCheck'),
   // 测量设备基础信息-需要检定-自检的

+ 3 - 3
src/views/sb/change-log/modules/SbChangeLogSelectModal.vue

@@ -123,14 +123,14 @@ export default {
         }, */
         {
           title: '记录类型',
-          dataIndex: 'objType',
+          dataIndex: 'changeType',
           customRender: (text, record, index) => {
             return this.BaseTool.Amount.formatter(text)
           }
         },
         {
-          title: '修改记录值',
-          dataIndex: 'updateJson'
+          title: '修改内容',
+          dataIndex: 'content'
         }
       /*  {
           title: '操作',

+ 2 - 2
src/views/sb/info/MeasureSbInfo.vue

@@ -3,7 +3,7 @@
 </template>
 
 <script>
-import SbInfo from './SbInfo'
+import SbInfo from './SbInfoC'
 export default {
   name: 'MeasureSbInfo',
   components: {
@@ -14,4 +14,4 @@ export default {
 
 <style scoped>
 
-</style>
+</style>

+ 17 - 0
src/views/sb/info/MeasureSbInfoAll.vue

@@ -0,0 +1,17 @@
+<template>
+  <SbInfo :use-type="4" :is-measure="1"/>
+</template>
+
+<script>
+import SbInfo from './SbInfoC'
+export default {
+  name: 'MeasureSbInfo',
+  components: {
+    SbInfo
+  }
+}
+</script>
+
+<style scoped>
+
+</style>

+ 1 - 1
src/views/sb/info/MeasureSbInfoCheck.vue

@@ -3,7 +3,7 @@
 </template>
 
 <script>
-import SbInfo from './SbInfo'
+import SbInfo from './SbInfoC'
 export default {
   name: 'MeasureSbInfoCheck',
   components: {

+ 2 - 2
src/views/sb/info/MeasureSbInfoCheckSelf.vue

@@ -3,7 +3,7 @@
 </template>
 
 <script>
-import SbInfo from './SbInfo'
+import SbInfo from './SbInfoC'
 export default {
   name: 'MeasureSbInfoCheckSelf',
   components: {
@@ -14,4 +14,4 @@ export default {
 
 <style scoped>
 
-</style>
+</style>

+ 2 - 2
src/views/sb/info/MeasureSbInfoInStore.vue

@@ -3,7 +3,7 @@
 </template>
 
 <script>
-import SbInfo from './SbInfo'
+import SbInfo from './SbInfoC'
 export default {
   name: 'MeasureSbInfoInStore',
   components: {
@@ -14,4 +14,4 @@ export default {
 
 <style scoped>
 
-</style>
+</style>

+ 1 - 1
src/views/sb/info/MeasureSbInfoNotCheck.vue

@@ -3,7 +3,7 @@
 </template>
 
 <script>
-import SbInfo from './SbInfo'
+import SbInfo from './SbInfoC'
 export default {
   name: 'MeasureSbInfoNotCheck',
   components: {

+ 1 - 1
src/views/sb/info/MeasureSbInfoWarn.vue

@@ -4,7 +4,7 @@
 </template>
 
 <script>
-import SbInfo from './SbInfo'
+import SbInfo from './SbInfoC'
 export default {
   name: 'MeasureSbInfoWarn',
   components: {

+ 954 - 0
src/views/sb/info/SbInfoC.vue

@@ -0,0 +1,954 @@
+<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" :style="{ display: expand ? 'block' : 'none' }">
+                    <a-form-item label="设备位号">
+                      <a-input v-model.trim="queryParam.positionNo" placeholder="设备位号"/>
+                    </a-form-item>
+                  </a-col>
+                  <a-col :md="6" :sm="24" :style="{ display: expand ? 'block' : 'none' }">
+                    <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" :style="{ display: expand ? 'block' : 'none' }">
+                    <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" :style="{ display: expand ? 'block' : 'none' }">
+                    <a-form-item label="检定日期范围">
+                      <a-range-picker v-model="dateRangeCheck" />
+                    </a-form-item>
+                  </a-col>
+                  <a-col :md="6" :sm="24" :style="{ display: expand ? 'block' : 'none' }">
+                    <a-form-item label="有效日期范围">
+                      <a-range-picker v-model="dateRange"/>
+                    </a-form-item>
+                  </a-col>
+                  <a-col :md="6" :sm="24" :style="{ display: expand ? 'block' : 'none' }">
+                    <a-form-item label="规格型号">
+                      <a-input v-model="queryParam.model" placeholder="规格型号"/>
+                    </a-form-item>
+                  </a-col>
+                  <a-col :md="6" :sm="24" :style="{ display: expand ? 'block' : 'none' }">
+                    <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" :style="{ display: expand ? 'block' : 'none' }">
+                    <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" :style="{ display: expand ? 'block' : 'none' }">
+                    <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" :style="{ display: expand ? 'block' : 'none' }">
+                    <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-row>
+              </a-form>
+              <a-row :gutter="8">
+                <a-col :span="24" :style="{ textAlign: 'right' }">
+                  <span class="table-page-search-submitButtons">
+                    <a-button type="primary" @click="handleOk">查询</a-button>
+                    <a-button style="margin-left: 8px" @click="resetSearchForm">重置</a-button>
+                    <a :style="{ marginLeft: '8px', fontSize: '12px' }" @click="expand=!expand">
+                      {{ !expand ? '展开' : '折叠' }} <a-icon :type="expand ? 'up' : 'down'" />
+                    </a>
+                  </span>
+                </a-col>
+              </a-row>
+            </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"
+              :rowClassName="rowClassName"
+            >
+              <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
+      },
+      expand: false,
+      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: 'name'
+        },
+        {
+          title: '设备位号',
+          dataIndex: 'positionNo',
+          width: 150,
+          scopedSlots: { customRender: 'positionNo' },
+          checked: true
+        },
+        {
+          title: '设备位置',
+          checked: true,
+          width: 200,
+          dataIndex: 'positionName'
+        },
+        {
+          title: '父位号',
+          dataIndex: 'ppNo',
+          width: 120,
+          checked: true
+        },
+
+        {
+          title: '设备类型',
+          checked: true,
+          dataIndex: 'type',
+          width: 150,
+          customRender: (text, record, index) => {
+            return record.typeName
+          }
+        },
+        /* {
+          title: '设备等级',
+          checked: true,
+          dataIndex: 'level',
+          width: 120,
+          customRender: (text, record, index) => {
+            return this.BaseTool.Object.getField(this.levelMap, text)
+          }
+        }, */
+        {
+          title: '规格型号',
+          dataIndex: 'model',
+          width: 150,
+          checked: true
+        },
+        {
+          title: '设备编号',
+          dataIndex: 'no',
+          width: 150,
+          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: 'zzh',
+          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: 'nextCheckDate',
+          fixed: 'right',
+          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: 'status',
+          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)
+    },
+    rowClassName (record, index) {
+      if (record.measureStatus === 1) return 'orange'
+      console.log(record)
+      switch (record.status) {
+        case 1:
+          console.log(12)
+          return 'green'
+        case 3:
+        case 4:
+          console.log(112)
+
+          return 'red'
+        case 5:
+        case 6:
+          console.log(122)
+
+          return 'gray'
+      }
+    }
+  }
+}
+</script>
+<style lang="less" scoped>
+/deep/ .green{
+  background: rgb(58, 233, 58);
+}
+/deep/ .red{
+  background: red;
+}
+/deep/ .gray{
+  background: #666;
+}
+/deep/ .orange{
+  background:orangered;
+}
+</style>