| <template> | 
|   <div> | 
|     <x-card :bordered="false" v-if="hasPerm('WorkPieceProcess:page')"> | 
|       <div slot="content" class="table-page-search-wrapper"> | 
|         <a-form :label-col="labelCol" :wrapper-col="wrapperCol"> | 
|           <a-row :gutter="gutter"> | 
|   | 
|             <a-col :md="colMd" :sm="colSm"> | 
|               <a-form-item label="设备名称"> | 
|                 <a-select | 
|                   show-search | 
|                   option-filter-prop="children" | 
|                   :filter-option="filterOption" | 
|                   :allowClear="true" | 
|                   style="width: 100%" | 
|                   v-model="queryParam.EquipmentID" | 
|                   placeholder="请选择" | 
|                 > | 
|                   <a-select-option v-for="(item, index) in equitypeData" :key="index" :value="item.equipmentId">{{ | 
|                     item.equipmentName | 
|                   }}</a-select-option> | 
|                 </a-select> | 
|               </a-form-item> | 
|             </a-col> | 
|   | 
|             <a-col :md="colMd" :sm="colSm"> | 
|               <a-form-item label="刀具编号"> | 
|                 <a-input v-model="queryParam.KnifeToolID" allow-clear placeholder="请输入刀具编号" /> | 
|               </a-form-item> | 
|             </a-col> | 
|             <a-col :md="colMd" :sm="colSm"> | 
|               <span class="table-page-search-submitButtons"> | 
|                 <a-button type="primary" @click="$refs.table.refresh(true)">查询</a-button> | 
|                 <a-button style="margin-left: 8px" @click="() => (queryParam = {})">重置</a-button> | 
|               </span> | 
|             </a-col> | 
|           </a-row> | 
|         </a-form> | 
|       </div> | 
|     </x-card> | 
|     <a-card :bordered="false"> | 
|       <s-table | 
|         ref="table" | 
|         :columns="columns" | 
|         :data="loadData" | 
|         :alert="true" | 
|         :rowKey="(record) => record.id" | 
|         :rowSelection="{ selectedRowKeys: selectedRowKeys, onChange: onSelectChange }" | 
|       > | 
|         <template class="table-operator" slot="operator"> | 
|           <!-- <a-button | 
|             style="margin-left: 8px" | 
|             type="info" | 
|             icon="download" | 
|             @click="KnifeToolDataMonitorToExcel()" | 
|           >导出Excel</a-button | 
|           > --> | 
|           <a-button | 
|             type="primary" | 
|             style="margin-left: 8px" | 
|             icon="plus" | 
|             @click="$refs.addEditForm.show()" | 
|           >新增</a-button> | 
|         </template> | 
|   | 
|         <span slot="equipmentIDSlots" slot-scope="text, record"> | 
|           <a @click="$refs.toolDetail.show(record)">{{ text }}</a> | 
|         </span> | 
|         <span slot="action" slot-scope="text, record"> | 
|           <a-popconfirm v-if="hasPerm('EquipmentBaseInfo:delete')" placement="topRight" title="确认删除?" @confirm="() => deleteKnifetoolequipmentmonitor(record)"> | 
|             <a>删除</a> | 
|           </a-popconfirm> | 
|           <a-divider type="vertical" v-if="hasPerm('EquipmentBaseInfo:edit') & hasPerm('EquipmentBaseInfo:delete')"/> | 
|           <!-- --> | 
|           <a v-if="hasPerm('EquipmentBaseInfo:edit')" @click="$refs.toolInfo.show(record)" >上刀</a> | 
|   | 
|         </span> | 
|       </s-table> | 
|     </a-card> | 
|   | 
|     <addEditForm ref="addEditForm" @ok="handleOk"/> | 
|     <toolOnline ref="toolInfo" @toolDetailReflesh="(record)=>$refs.toolDetail.show(record)" /> | 
|     <toolDetail ref="toolDetail" /> | 
|   </div> | 
| </template> | 
| <script> | 
| import { STable, XCard } from '@/components' | 
| import { downloadFile } from '@/utils/util' | 
| import { knifetoolequipmentmonitor, KnifeToolDataMonitorToExcel, deleteKnifetoolequipmentmonitor } from '@/api/modular/main/KnifeToolDataMonitorManage' | 
| // 获取设备下拉框数据 | 
| import { getEquipmentName } from '@/api/modular/main/EquipmentBaseInfoManage' | 
| import addEditForm from './modules/addEditForm.vue' | 
| import toolOnline from './modules/toolOnline.vue' | 
| import toolDetail from './modules/toolDetail.vue' | 
| export default { | 
|   components: { | 
|     STable, | 
|     XCard, | 
|     addEditForm, | 
|     toolOnline, | 
|     toolDetail | 
|   }, | 
|   data() { | 
|     return { | 
|       gutter: 36, | 
|       colMd: 6, | 
|       colSm: 18, | 
|       labelCol: { | 
|         xs: { span: 24 }, | 
|         sm: { span: 8 } | 
|       }, | 
|       wrapperCol: { | 
|         xs: { span: 24 }, | 
|         sm: { span: 15 } | 
|       }, | 
|       advanced: false, // 高级搜索 展开/关闭 | 
|       queryParam: {}, | 
|       columns: [ | 
|         { | 
|           title: '序号', | 
|           dataIndex: 'index', | 
|           key: 'index', | 
|           align: 'center', | 
|           customRender: (text, record, index) => `${index + 1}` | 
|         }, | 
|         { | 
|           title: '设备编号', | 
|           align: 'center', | 
|           sorter: true, | 
|           dataIndex: 'equipmentID', | 
|           scopedSlots: { customRender: 'equipmentIDSlots' } | 
|         }, | 
|         { | 
|           title: '设备名称', | 
|           align: 'center', | 
|           sorter: true, | 
|           dataIndex: 'equipmentName' | 
|         }, | 
|         { | 
|           title: '所属工序', | 
|           align: 'center', | 
|           sorter: true, | 
|           dataIndex: 'workingProcedure' | 
|         } | 
|          // { | 
|         //   title: '刀具编号', | 
|         //   align: 'center', | 
|         //   dataIndex: 'knifeToolID' | 
|         // }, | 
|         // { | 
|         //   title: '刀具名称', | 
|         //   align: 'center', | 
|         //   sorter: true, | 
|         //   dataIndex: 'knifeToolName' | 
|         // }, | 
|         // { | 
|         //   title: '设备名称', | 
|         //   align: 'center', | 
|         //   sorter: true, | 
|         //   dataIndex: 'equipmentName' | 
|         // } | 
|         // { | 
|         //   title: '启用时间', | 
|         //   align: 'center', | 
|         //   sorter: true, | 
|         //   dataIndex: 'knifeToolChangeTime' | 
|         // }, | 
|         // { | 
|         //   title: '刀具码', | 
|         //   align: 'center', | 
|         //   sorter: true, | 
|         //   dataIndex: 'knifeToolCode' | 
|         // }, | 
|         // { | 
|         //   title: '刀具型号', | 
|         //   align: 'center', | 
|         //   sorter: true, | 
|         //   dataIndex: 'knifeToolModel' | 
|         // }, | 
|         // { | 
|         //   title: '刀沿数', | 
|         //   align: 'center', | 
|         //   sorter: true, | 
|         //   dataIndex: 'knifeEdgeNumber' | 
|         // }, | 
|         // { | 
|         //   title: '刀具内部号', | 
|         //   align: 'center', | 
|         //   sorter: true, | 
|         //   dataIndex: 'knifeToolInsideID' | 
|         // }, | 
|         // { | 
|         //   title: '刀库号', | 
|         //   align: 'center', | 
|         //   sorter: true, | 
|         //   dataIndex: 'knifeWareHouseID' | 
|         // }, | 
|         // { | 
|         //   title: '刀位编号', | 
|         //   align: 'center', | 
|         //   sorter: true, | 
|         //   dataIndex: 'knifePositionID' | 
|         // }, | 
|         // { | 
|         //   title: '额定寿命', | 
|         //   align: 'center', | 
|         //   sorter: true, | 
|         //   dataIndex: 'knifeToolLife' | 
|         // }, | 
|         // { | 
|         //   title: '预警寿命', | 
|         //   align: 'center', | 
|         //   sorter: true, | 
|         //   dataIndex: 'knifeToolEarlyWarningLife' | 
|         // }, | 
|         // { | 
|         //   title: '剩余寿命', | 
|         //   align: 'center', | 
|         //   sorter: true, | 
|         //   dataIndex: 'knifeToolSurplusLife' | 
|         // } | 
|       ], | 
|       tstyle: { 'padding-bottom': '0px', 'margin-bottom': '10px' }, | 
|       // 加载数据方法 必须为 Promise 对象 | 
|       loadData: (parameter) => { | 
|         return knifetoolequipmentmonitor(Object.assign(parameter, this.queryParam)).then((res) => { | 
|           if (res.data.rows.length > 0) { | 
|             this.$refs.toolDetail.show(res.data.rows[0]) | 
|           } else { | 
|             this.$refs.toolDetail.show(null) | 
|           } | 
|           return res.data | 
|         }) | 
|       }, | 
|       selectedRowKeys: [], | 
|       selectedRows: [], | 
|       equitypeData: [] | 
|     } | 
|   }, | 
|   created() { | 
|     if (this.hasPerm('EquipmentBaseInfo:edit')) { | 
|         this.columns.push({ | 
|           title: '操作', | 
|           width: '150px', | 
|           align: 'center', | 
|           dataIndex: 'action', | 
|           scopedSlots: { customRender: 'action' } | 
|         }) | 
|       } | 
|   | 
|     this.getEquipmentName() | 
|   }, | 
|   methods: { | 
|     /** | 
|      * 查询参数组装 | 
|      */ | 
|     switchingDate() { | 
|       const obj = JSON.parse(JSON.stringify(this.queryParam)) | 
|       return obj | 
|     }, | 
|     // 刷新数据 | 
|       handleOk () { | 
|         this.$refs.table.refresh() | 
|       }, | 
|       // 删除数据 | 
|       deleteKnifetoolequipmentmonitor (record) { | 
|         deleteKnifetoolequipmentmonitor(record).then((res) => { | 
|           if (res.success) { | 
|             this.$message.success('删除成功') | 
|             this.$refs.table.refresh() | 
|           } else { | 
|             this.$message.error('删除失败') | 
|           } | 
|         }) | 
|       }, | 
|       // 导出数据 | 
|     KnifeToolDataMonitorToExcel() { | 
|       this.cardLoading = true | 
|       KnifeToolDataMonitorToExcel(this.queryParam) | 
|         .then((res) => { | 
|           this.cardLoading = false | 
|           downloadFile(res) | 
|         }) | 
|         .catch((err) => { | 
|           this.cardLoading = false | 
|           console.info(err) | 
|           this.$message.error('下载错误:获取文件流错误' + err) | 
|         }) | 
|     }, | 
|     toggleAdvanced() { | 
|       this.advanced = !this.advanced | 
|     }, | 
|     getEquipmentName() { | 
|       getEquipmentName().then((res) => { | 
|         this.equitypeData = res.data | 
|       }) | 
|     }, | 
|     onSelectChange(selectedRowKeys, selectedRows) { | 
|       this.selectedRowKeys = selectedRowKeys | 
|       this.selectedRows = selectedRows | 
|     }, | 
|     // 设备查询框筛选 | 
|     filterOption(input, option) { | 
|       return option.componentOptions.children[0].text.toLowerCase().indexOf(input.toLowerCase()) >= 0 | 
|     } | 
|   } | 
| } | 
| </script> | 
| <style lang="less"> | 
| .table-operator { | 
|   margin-bottom: 18px; | 
| } | 
| button { | 
|   margin-right: 8px; | 
| } | 
| </style> |