| | |
| | | title="维修工单" |
| | | :bordered="false" |
| | | > |
| | | <!-- 查询区域 --> |
| | | <div class="table-page-search-wrapper"> |
| | | <a-form |
| | | layout="inline" |
| | | @keyup.enter.native="searchQuery" |
| | | > |
| | | <a-row :gutter="24"> |
| | | </a-row> |
| | | </a-form> |
| | | </div> |
| | | <!-- 查询区域-END --> |
| | | <div class="table-page-search-wrapper"> |
| | | <a-form |
| | | layout="inline" |
| | |
| | | > |
| | | <a-row :gutter="24"> |
| | | <a-col |
| | | :md="4" |
| | | :sm="8" |
| | | :xl="6" |
| | | :lg="7" |
| | | :md="8" |
| | | :sm="24" |
| | | > |
| | | <a-form-item label="工单状态"> |
| | | <j-dict-select-tag |
| | |
| | | </a-form-item> |
| | | </a-col> |
| | | <a-col |
| | | :md="4" |
| | | :sm="8" |
| | | :xl="6" |
| | | :lg="7" |
| | | :md="8" |
| | | :sm="24" |
| | | > |
| | | <a-form-item label="单据号"> |
| | | <a-input |
| | |
| | | </a-form-item> |
| | | </a-col> |
| | | <a-col |
| | | :md="4" |
| | | :sm="8" |
| | | :xl="6" |
| | | :lg="7" |
| | | :md="8" |
| | | :sm="24" |
| | | > |
| | | <a-form-item label="设备编码"> |
| | | <a-input |
| | |
| | | ></a-input> |
| | | </a-form-item> |
| | | </a-col> |
| | | <a-col |
| | | :md="4" |
| | | :sm="8" |
| | | <a-col :span="3"> |
| | | <span |
| | | style="float: left;overflow: hidden;" |
| | | class="table-page-search-submitButtons" |
| | | > |
| | | <a |
| | | @click="handleToggleSearch" |
| | | style="margin-left: 8px" |
| | | > |
| | | {{ toggleSearchStatus ? '查询条件收起' : '详细查询' }} |
| | | <a-icon :type="toggleSearchStatus ? 'up' : 'down'" /> |
| | | </a> |
| | | </span> |
| | | </a-col> |
| | | </a-row> |
| | | |
| | | <template v-if="toggleSearchStatus"> |
| | | <a-row :gutter="24"> |
| | | <a-col |
| | | :xl="6" |
| | | :lg="7" |
| | | :md="8" |
| | | :sm="24" |
| | | > |
| | | <a-form-item label="设备名称"> |
| | | <a-input |
| | | placeholder="请输入设备名称" |
| | | v-model="queryParam.equipmentName" |
| | | ></a-input> |
| | | </a-form-item> |
| | | </a-col> |
| | | <a-col |
| | | :xl="6" |
| | | :lg="7" |
| | | :md="8" |
| | | :sm="24"> |
| | | <a-form-item |
| | | label="设备所属分类" |
| | | > |
| | | <j-dict-select-tag |
| | | dictCode="mom_eam_equipment_category,name,id" |
| | | placeholder="请输入搜索条件并选择" |
| | | v-model="queryParam.equipmentCategoryId" |
| | | /> |
| | | </a-form-item> |
| | | </a-col> |
| | | <a-col |
| | | :xl="6" |
| | | :lg="7" |
| | | :md="8" |
| | | :sm="24" |
| | | > |
| | | <a-form-item label="设备名称"> |
| | | <a-input |
| | | placeholder="请输入设备名称" |
| | | v-model="queryParam.equipmentName" |
| | | ></a-input> |
| | | <a-form-item |
| | | label="车间" |
| | | > |
| | | <j-dict-select-tag |
| | | allow-clear |
| | | placeholder="请选择资车间" |
| | | :triggerChange="true" |
| | | dictCode="mom_base_factory_model,name,id,del_flag!='1'" |
| | | v-model="queryParam.factoryModelId" |
| | | /> |
| | | </a-form-item> |
| | | </a-col> |
| | | <a-col |
| | | :md="4" |
| | | :sm="8" |
| | | :xl="6" |
| | | :lg="7" |
| | | :md="8" |
| | | :sm="24" |
| | | > |
| | | <a-button |
| | | type="primary" |
| | | @click="searchQuery" |
| | | icon="search" |
| | | style="margin-right: 5px" |
| | | >查询</a-button> |
| | | <a-button |
| | | @click="searchReset" |
| | | icon="reload" |
| | | >重置</a-button> |
| | | <a-form-item |
| | | label="是否关键设备" |
| | | > |
| | | <j-dict-select-tag |
| | | allow-clear |
| | | placeholder="请选择是否关键设备" |
| | | :triggerChange="true" |
| | | dictCode="specific_equipment" |
| | | v-model="queryParam.specificEquipment" |
| | | /> |
| | | </a-form-item> |
| | | </a-col> |
| | | </a-row> |
| | | </a-row> |
| | | <!-- <a-row :gutter="24"> |
| | | <a-col |
| | | :xl="6" |
| | | :lg="7" |
| | | :md="8" |
| | | :sm="24"> |
| | | <a-form-item |
| | | label="工区" |
| | | > |
| | | <j-dict-select-tag |
| | | allow-clear |
| | | placeholder="请选择工区" |
| | | :triggerChange="true" |
| | | dictCode="mom_base_area,name,id,del_flag!='1'" |
| | | v-model="queryParam.factoryModelId" |
| | | /> |
| | | </a-form-item> |
| | | </a-col> |
| | | </a-row> --> |
| | | </template> |
| | | </a-form> |
| | | </div> |
| | | <!-- 操作按钮区域 --> |
| | |
| | | key="1" |
| | | @click="handleAddPre(1)" |
| | | ><a-icon type="smile" />自建</a-menu-item> |
| | | <a-menu-item |
| | | <!-- <a-menu-item |
| | | key="2" |
| | | @click="handleAddPre(2)" |
| | | ><a-icon type="copy" />参照保修故障单</a-menu-item> |
| | | <a-menu-item |
| | | ><a-icon type="copy" />参照故障报修单</a-menu-item> --> |
| | | <a-menu-item |
| | | key="2" |
| | | @click="handleAddPre(3)" |
| | | ><a-icon type="copy" />参照项目性维修</a-menu-item> |
| | |
| | | icon="plus" |
| | | >新增</a-button> |
| | | </a-dropdown> |
| | | |
| | | <a-button |
| | | type="primary" |
| | | @click="searchQuery" |
| | | icon="search" |
| | | style="margin-right: 5px" |
| | | >查询</a-button> |
| | | <a-button |
| | | @click="searchReset" |
| | | icon="reload" |
| | | >重置</a-button> |
| | | <a-button |
| | | hidden |
| | | type="primary" |
| | |
| | | @click="handleDispatch()" |
| | | :disabled="selectionRows.length==0" |
| | | >派工</a-button> |
| | | <a-button |
| | | type="primary" |
| | | icon="plus" |
| | | @click="getReports" |
| | | >领取</a-button> |
| | | <!-- <a-button type="primary" icon="download" @click="handleExportXls('维修工单')">导出</a-button> |
| | | <a-upload name="file" :showUploadList="false" :multiple="false" :headers="tokenHeader" :action="importExcelUrl" @change="handleImportExcel"> |
| | | <a-button type="primary" icon="import">导入</a-button> |
| | |
| | | :dataSource="dataSource" |
| | | :pagination="ipagination" |
| | | :loading="loading" |
| | | :rowSelection="rowSelection" |
| | | @change="handleTableChange" |
| | | :customRow="clickThenSelect" |
| | | > |
| | | |
| | | <template |
| | | slot="htmlSlot" |
| | | slot-scope="text" |
| | | > |
| | | <div v-html="text"></div> |
| | | </template> |
| | | <template |
| | | slot="imgSlot" |
| | | slot-scope="text,record" |
| | | > |
| | | <span |
| | | v-if="!text" |
| | | style="font-size: 12px;font-style: italic;" |
| | | >无图片</span> |
| | | <img |
| | | v-else |
| | | :src="getImgView(text)" |
| | | :preview="record.id" |
| | | height="25px" |
| | | alt="" |
| | | style="max-width:80px;font-size: 12px;font-style: italic;" |
| | | /> |
| | | </template> |
| | | <template |
| | | slot="fileSlot" |
| | | slot-scope="text" |
| | | > |
| | | <span |
| | | v-if="!text" |
| | | style="font-size: 12px;font-style: italic;" |
| | | >无文件</span> |
| | | <a-button |
| | | v-else |
| | | :ghost="true" |
| | | type="primary" |
| | | icon="download" |
| | | size="small" |
| | | @click="downloadFile(text)" |
| | | > |
| | | 下载 |
| | | </a-button> |
| | | </template> |
| | | |
| | | <!-- <span |
| | | slot="action" |
| | | <span slot="jell" slot-scope="text"> |
| | | <j-ellipsis :value="text" :length="8" /> |
| | | </span> |
| | | <span |
| | | slot="num" |
| | | slot-scope="text, record" |
| | | > |
| | | <a-popconfirm |
| | | title="确定下发吗?" |
| | | @confirm="() => handleDistribute(record)" |
| | | > |
| | | <a v-if="record.status=='0'">下发</a> |
| | | </a-popconfirm> |
| | | <a-divider |
| | | type="vertical" |
| | | v-if="record.status=='0'" |
| | | /> |
| | | <a-popconfirm |
| | | title="确定撤回吗?" |
| | | @confirm="() => handleWithdraw(record)" |
| | | > |
| | | <a v-if="record.status=='1'">撤回</a> |
| | | </a-popconfirm> |
| | | <a-divider |
| | | type="vertical" |
| | | v-if="record.status=='1'" |
| | | /> |
| | | <a-popconfirm |
| | | title="确定领取吗?" |
| | | @confirm="() => handleReceive(record)" |
| | | > |
| | | <a v-if="record.status=='1'">领取</a> |
| | | </a-popconfirm> |
| | | <a-divider |
| | | type="vertical" |
| | | v-if="record.status=='1'" |
| | | /> |
| | | <a |
| | | v-if="record.status === '2' || record.status === '3' ||record.status === '4'" |
| | | v-if="record.status === '3' || record.status === '4' ||record.status === '5' ||record.status === '7' " |
| | | class="lot" |
| | | @click="handleOrderExe(record)" |
| | | >执行</a> |
| | | <a-divider |
| | | type="vertical" |
| | | v-if="record.status === '2' || record.status === '3' ||record.status === '4'" |
| | | /> |
| | | <a |
| | | @click="handleEditPre(record)" |
| | | v-if="record.status=='0'" |
| | | >编辑</a> |
| | | <a-divider |
| | | type="vertical" |
| | | v-if="record.status=='0'" |
| | | /> |
| | | <a-dropdown v-if="record.status=='0'"> |
| | | <a class="ant-dropdown-link">更多 <a-icon type="down" /></a> |
| | | <a-menu slot="overlay"> |
| | | <a-menu-item> |
| | | <a-popconfirm |
| | | title="确定删除吗?" |
| | | @confirm="() => handleDelete(record.id)" |
| | | > |
| | | <a>删除</a> |
| | | </a-popconfirm> |
| | | </a-menu-item> |
| | | </a-menu> |
| | | </a-dropdown> |
| | | </span> --> |
| | | ><j-ellipsis :value="text" :length="15"/></a> |
| | | <span v-else> <j-ellipsis :value="text" :length="15"/></span> |
| | | </span> |
| | | <span |
| | | slot="action" |
| | | slot-scope="text, record" |
| | |
| | | v-if="record.status == '1' && record.dispatchMethod == '1' " |
| | | @click="handleAssignOrder(record)" |
| | | >派工</a> |
| | | <a |
| | | <!-- <a |
| | | v-if="record.status == '2' && record.dispatchMethod != null " |
| | | @click="handleAssignOrder(record)" |
| | | >改派</a> |
| | | >改派</a> --> |
| | | <a-divider |
| | | v-if="record.status == '1' || record.status == '2' " |
| | | type="vertical" |
| | |
| | | tab="故障描述" |
| | | key="1" |
| | | > |
| | | <FaultDescriptionList ref="FaultDescriptionList"/> |
| | | <FaultDescriptionList ref="FaultDescriptionList" /> |
| | | </a-tab-pane> |
| | | <a-tab-pane |
| | | tab="维修要求" |
| | |
| | | <repair-order-excute-drawer |
| | | ref="repairOrderExcuteDrawer" |
| | | @ok="modalFormOk" |
| | | :repairOrderId="repairOrderFaultAnalysisMainId" |
| | | :repairOrder="excuteRepairOrder" |
| | | > |
| | | </repair-order-excute-drawer> |
| | | <fault-report-repair |
| | | ref="FaultReportRepair" |
| | | ></fault-report-repair> |
| | | </a-card> |
| | | </template> |
| | | <script> |
| | | import { JeecgListMixin } from '@/mixins/JeecgListMixin' |
| | | import RepairOrderModal from './modules/repairorder/RepairOrderModal' |
| | | import { getAction } from '@/api/manage' |
| | | import JEllipsis from '@/components/jeecg/JEllipsis' |
| | | import RepairOrderDetailList from './RepairOrderDetailList' |
| | | import RepairOrderRiskPreventionList from './RepairOrderRiskPreventionList' |
| | | import RepairOrderFaultAnalysisList from './RepairOrderFaultAnalysisList' |
| | |
| | | import RepairOrderAssignTask from './modules/repairorder/RepairOrderAssignTask.vue' |
| | | import RepairOrderExcuteDrawer from './modules/repairorder/repairOrderExcuteDrawer.vue' |
| | | import FaultDescriptionList from './FaultDescriptionList' |
| | | import FaultReportRepair from './modules/repairorder/moudles/select/FaultReportRepair.vue' |
| | | export default { |
| | | name: "RepairOrderList", |
| | | mixins: [JeecgListMixin], |
| | | components: { |
| | | JEllipsis, |
| | | RepairOrderDetailList, |
| | | RepairOrderRiskPreventionList, |
| | | RepairOrderFaultAnalysisList, |
| | |
| | | RepairOrderModal, |
| | | RepairOrderAssignTask, |
| | | RepairOrderExcuteDrawer, |
| | | FaultDescriptionList |
| | | FaultDescriptionList, |
| | | FaultReportRepair |
| | | }, |
| | | data() { |
| | | return { |
| | | description: '维修工单管理页面', |
| | | // 表头 |
| | | columns: [ |
| | | { |
| | | title: '#', |
| | | dataIndex: '', |
| | | key: 'rowIndex', |
| | | width: 60, |
| | | align: "center", |
| | | customRender: function (t, r, index) { |
| | | return parseInt(index) + 1; |
| | | } |
| | | }, |
| | | { |
| | | title: '状态', |
| | | align: "center", |
| | |
| | | { |
| | | title: '单据号', |
| | | align: "center", |
| | | dataIndex: 'num' |
| | | dataIndex: 'num', |
| | | scopedSlots: { customRender: 'num' } |
| | | }, |
| | | { |
| | | title: '业务类型', |
| | | align: "center", |
| | | dataIndex: 'businessType_dictText' |
| | | }, |
| | | // { |
| | | // title: '业务类型', |
| | | // align: "center", |
| | | // dataIndex: 'businessType_dictText' |
| | | // }, |
| | | { |
| | | title: '设备编码', |
| | | align: "center", |
| | |
| | | align: "center", |
| | | dataIndex: 'departId_dictText' |
| | | }, |
| | | // { |
| | | // title: '紧急程度', |
| | | // align: "center", |
| | | // dataIndex: 'urgency_dictText' |
| | | // }, |
| | | // { |
| | | // title: '维保方式', |
| | | // align: "center", |
| | | // dataIndex: 'maintenanceMethod_dictText' |
| | | // }, |
| | | // { |
| | | // title: '外委单位', |
| | | // align: "center", |
| | | // dataIndex: 'outsourcingUnitName' |
| | | // }, |
| | | { |
| | | title: '紧急程度', |
| | | title: '维修班组', |
| | | align: "center", |
| | | dataIndex: 'urgency_dictText' |
| | | }, |
| | | { |
| | | title: '维保方式', |
| | | align: "center", |
| | | dataIndex: 'maintenanceMethod_dictText' |
| | | }, |
| | | { |
| | | title: '委外单位', |
| | | align: "center", |
| | | dataIndex: 'outsourcingUnitName' |
| | | }, |
| | | { |
| | | title: '责任班组', |
| | | align: "center", |
| | | dataIndex: 'teamId_dictText' |
| | | dataIndex: 'teamId_dictText', |
| | | scopedSlots: { |
| | | customRender: 'jell' |
| | | } |
| | | }, |
| | | { |
| | | title: '责任人', |
| | |
| | | { |
| | | title: '故障描述', |
| | | align: "center", |
| | | dataIndex: 'faultDescription' |
| | | dataIndex: 'faultDescription', |
| | | scopedSlots: { |
| | | customRender: 'jell' |
| | | } |
| | | }, |
| | | { |
| | | title: '故障原因', |
| | | align: "center", |
| | | dataIndex: 'faultReason' |
| | | }, |
| | | { |
| | | title: '故障现象', |
| | | align: "center", |
| | | dataIndex: 'faultPhenomenon' |
| | | }, |
| | | { |
| | | title: '故障排除', |
| | | align: "center", |
| | | dataIndex: 'faultRemove' |
| | | }, |
| | | { |
| | | title: '预防措施', |
| | | align: "center", |
| | | dataIndex: 'preventiveMeasure' |
| | | }, |
| | | // { |
| | | // title: '故障时间', |
| | |
| | | // align: "center", |
| | | // dataIndex: 'isStop_dictText' |
| | | // }, |
| | | { |
| | | title: '工时定额', |
| | | align: "center", |
| | | dataIndex: 'workingHourQuota' |
| | | }, |
| | | // { |
| | | // title: '工时定额', |
| | | // align: "center", |
| | | // dataIndex: 'workingHourQuota' |
| | | // }, |
| | | { |
| | | title: '实际工时', |
| | | align: "center", |
| | |
| | | orderReceive: "eam/repairOrder/receive", |
| | | orderStart: "eam/repairOrder/start" |
| | | }, |
| | | dictOptions: { |
| | | }, |
| | | /* 分页参数 */ |
| | | ipagination: { |
| | | current: 1, |
| | |
| | | sonsAddStatus: false, |
| | | } |
| | | }, |
| | | // created() { |
| | | // this.getSuperFieldList(); |
| | | // }, |
| | | computed: { |
| | | importExcelUrl: function () { |
| | | return `${window._CONFIG['domianURL']}/${this.url.importExcelUrl}`; |
| | |
| | | } |
| | | this.loading = false; |
| | | this.$refs.FaultDescriptionList.faultId = '-1' |
| | | this.excuteRepairOrder = {} |
| | | }) |
| | | }, |
| | | // getSuperFieldList() { |
| | | // let fieldList = []; |
| | | // fieldList.push({ type: 'string', value: 'num', text: '维修订单号', dictCode: '' }) |
| | | // fieldList.push({ type: 'string', value: 'equipmentId', text: '设备台账ID', dictCode: '' }) |
| | | // fieldList.push({ type: 'string', value: 'reportRepairId', text: '故障报修单ID', dictCode: '' }) |
| | | // fieldList.push({ type: 'string', value: 'teamId', text: '班组ID', dictCode: '' }) |
| | | // fieldList.push({ type: 'string', value: 'faultDescription', text: '故障描述', dictCode: '' }) |
| | | // fieldList.push({ type: 'datetime', value: 'faultTime', text: '故障时间' }) |
| | | // fieldList.push({ type: 'string', value: 'photo', text: '故障照片', dictCode: '' }) |
| | | // fieldList.push({ type: 'string', value: 'isStop', text: '是否停机', dictCode: '' }) |
| | | // fieldList.push({ type: 'datetime', value: 'actualEndTime', text: '实际结束时间' }) |
| | | // fieldList.push({ type: 'string', value: 'maintenanceMethod', text: '维保方式', dictCode: '' }) |
| | | // fieldList.push({ type: 'string', value: 'createBy', text: '创建人', dictCode: '' }) |
| | | // fieldList.push({ type: 'datetime', value: 'createTime', text: '创建时间' }) |
| | | // this.superFieldList = fieldList |
| | | // }, |
| | | |
| | | handleAddPre(isSelfCreate) { |
| | | this.isSelfCreate = isSelfCreate; |
| | | this.handleAdd(); |
| | |
| | | if (record.reportRepairId != null && record.reportRepairId != undefined && record.reportRepairId != '') { |
| | | this.isSelfCreate = '2'; |
| | | } |
| | | else if(record.projectMaintenanceOrderId != null && record.projectMaintenanceOrderId != undefined && record.projectMaintenanceOrderId != ''){ |
| | | else if (record.projectMaintenanceOrderId != null && record.projectMaintenanceOrderId != undefined && record.projectMaintenanceOrderId != '') { |
| | | this.isSelfCreate = '3'; |
| | | }else{ |
| | | } else { |
| | | this.isSelfCreate = '1'; |
| | | } |
| | | this.handleEdit(record); |
| | |
| | | this.onClearSelected() |
| | | this.$refs.FaultDescriptionList.faultId = '-1' |
| | | }, |
| | | getReports(){ |
| | | this.$refs.FaultReportRepair.title = '故障报修单'; |
| | | this.$refs.FaultReportRepair.visible = true; |
| | | } |
| | | |
| | | }, |
| | | } |