|
@@ -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>
|