设备相关
parent
486e2c7176
commit
1e7a037a41
@ -1,27 +1,76 @@
|
||||
<template>
|
||||
<div id="app">
|
||||
<router-view />
|
||||
<router-view/>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
export default {
|
||||
name: 'App',
|
||||
metaInfo() {
|
||||
return {
|
||||
title: this.$store.state.settings.dynamicTitle && this.$store.state.settings.title,
|
||||
titleTemplate: title => {
|
||||
return title ? `${title} - ${process.env.VUE_APP_TITLE}` : process.env.VUE_APP_TITLE
|
||||
}
|
||||
}
|
||||
export default {
|
||||
name: 'App',
|
||||
metaInfo() {
|
||||
return {
|
||||
title: this.$store.state.settings.dynamicTitle && this.$store.state.settings.title,
|
||||
titleTemplate: title => {
|
||||
return title ? `${title} - ${process.env.VUE_APP_TITLE}` : process.env.VUE_APP_TITLE
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
<style>
|
||||
.width-full{
|
||||
|
||||
/* 滚动条样式 */
|
||||
::-webkit-scrollbar {
|
||||
width: 10px; /* 滚动条宽度 */
|
||||
height: 10px; /* 滚动条高度 */
|
||||
}
|
||||
|
||||
/* 滚动条轨道 */
|
||||
::-webkit-scrollbar-track {
|
||||
background-color: #f5f5f5; /* 滚动条轨道颜色 */
|
||||
border-radius: 25px; /* 滚动条轨道圆角 */
|
||||
}
|
||||
|
||||
/* 滚动条滑块 */
|
||||
::-webkit-scrollbar-thumb {
|
||||
background-color: #888; /* 滚动条滑块颜色 */
|
||||
border-radius: 25px; /* 滚动条轨道圆角 */
|
||||
}
|
||||
|
||||
/* 鼠标悬停时滚动条滑块颜色 */
|
||||
::-webkit-scrollbar-thumb:hover {
|
||||
background-color: #555; /* 鼠标悬停时滚动条滑块颜色 */
|
||||
}
|
||||
|
||||
.color-red {
|
||||
color: red;
|
||||
}
|
||||
|
||||
.p10 {
|
||||
padding: 10px;
|
||||
}
|
||||
|
||||
.width-full {
|
||||
width: 100%;
|
||||
}
|
||||
.w90-percent{
|
||||
width:90%;
|
||||
|
||||
.height-full {
|
||||
height: 100%;
|
||||
}
|
||||
|
||||
.w90-percent {
|
||||
width: 90%;
|
||||
}
|
||||
|
||||
.align-right {
|
||||
text-align: right;
|
||||
}
|
||||
|
||||
.align-left {
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
.align-center {
|
||||
text-align: center;
|
||||
}
|
||||
</style>
|
||||
|
@ -0,0 +1,61 @@
|
||||
import axios from "@/utils/request";
|
||||
|
||||
export function changeOrderPage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/changeOrder/page",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function saveChangeOrder(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/changeOrder/save",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function changeOrderDetailByUser(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/changeOrder/detailByUser",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function cancelChangeOrder(orderId, query) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/changeOrder/cancel/${orderId}`,
|
||||
method: "GET",
|
||||
params: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function confirmChangeOrder(orderId, query) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/changeOrder/confirm/${orderId}`,
|
||||
method: "GET",
|
||||
params: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function rejectChangeOrder(orderId, query) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/changeOrder/reject/${orderId}`,
|
||||
method: "GET",
|
||||
params: query
|
||||
}
|
||||
)
|
||||
}
|
@ -0,0 +1,49 @@
|
||||
import axios from "@/utils/request";
|
||||
|
||||
export function deviceCheckGenByPlanId(planId) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/check/gen/${planId}`,
|
||||
method: "GET"
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function deviceCheckPage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/check/page`,
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function deviceCheckPageByDept(query) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/check/pageByDept`,
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function deviceCheckPrint(taskId) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/check/info/print/${taskId}`,
|
||||
method: "GET"
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function deviceCheckPrintByDeviceCode(taskId, deviceCode) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/check/info/print/${taskId}/${deviceCode}`,
|
||||
method: "GET"
|
||||
}
|
||||
)
|
||||
}
|
||||
|
@ -0,0 +1,21 @@
|
||||
import axios from "@/utils/request";
|
||||
export function deviceCheckDetailPage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/check/detail/page`,
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function deviceCheckDetailRepair(query) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/check/detail/repair`,
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
@ -0,0 +1,20 @@
|
||||
import axios from "@/utils/request";
|
||||
export function deviceCheckDetailItemPage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/check/detail/item/page`,
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
export function deviceCheckDetailItemFinish(query) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/check/detail/item/finish`,
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
@ -0,0 +1,40 @@
|
||||
import axios from "@/utils/request";
|
||||
|
||||
export function genCheckItemCode() {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/checkItemDict/code/gen",
|
||||
method: "GET"
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function deviceCheckItemDictPage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/checkItemDict/page",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function saveDeviceCheckItemDict(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/checkItemDict/save",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function delDeviceCheckItemDict(query) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/checkItemDict/del/${query}`,
|
||||
method: "DELETE"
|
||||
}
|
||||
)
|
||||
}
|
||||
|
@ -0,0 +1,79 @@
|
||||
import axios from "@/utils/request";
|
||||
|
||||
export function devicePage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/info/page",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function detailByUserPage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/info/detailByUser/page",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function deviceAllPage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/info/all/page",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function detailPage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/info/detail/page",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function deviceDetailInfo(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/detailInfo/page",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function deviceLogs(deviceCode) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/log/${deviceCode}`,
|
||||
method: "GET"
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function genDeviceCode(deviceCode) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/code/gen`,
|
||||
method: "GET"
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function genDeviceQR(deviceCode) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/genQR/${deviceCode}`,
|
||||
method: "GET"
|
||||
}
|
||||
)
|
||||
}
|
||||
|
@ -0,0 +1,40 @@
|
||||
import axios from "@/utils/request";
|
||||
|
||||
export function devicePlanPage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/plan/page",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function devicePlanSave(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/plan/save",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function devicePlanInfo(planId) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/plan/info/${planId}`,
|
||||
method: "GET"
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function devicePlanDel(planId) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/plan/del/${planId}`,
|
||||
method: "DELETE"
|
||||
}
|
||||
)
|
||||
}
|
||||
|
@ -0,0 +1,49 @@
|
||||
import axios from "@/utils/request";
|
||||
|
||||
export function devicePlanDetailGroupPage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/plan/detailGroup/page",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
export function devicePlanDetailPage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/plan/detail/page",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function devicePlanDetailAdd(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/plan/detail/add",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function devicePlanDetailDel(planId,productId) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/plan/detail/delByProductId/${planId}/${productId}`,
|
||||
method: "DELETE"
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function devicePlanDetailDelByDeviceCode(planId,deviceCode) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/plan/detail/delByDeviceCode/${planId}/${deviceCode}`,
|
||||
method: "DELETE"
|
||||
}
|
||||
)
|
||||
}
|
||||
|
@ -0,0 +1,40 @@
|
||||
import axios from "@/utils/request";
|
||||
|
||||
export function devicePlanDetailItemPage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/plan/detail/item/page",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function devicePlanDetailItemAdd(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/plan/detail/item/add",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function devicePlanDetailItemDel(planId,productId,itemCode) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/plan/detail/item/delByProductId/${planId}/${productId}/${itemCode}`,
|
||||
method: "DELETE"
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function devicePlanDetailItemByDeviceCodeDel(planId,deviceCode,itemCode) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/plan/detail/item/delByDeviceCode/${planId}/${deviceCode}/${itemCode}`,
|
||||
method: "DELETE"
|
||||
}
|
||||
)
|
||||
}
|
||||
|
@ -0,0 +1,29 @@
|
||||
import axios from "@/utils/request";
|
||||
|
||||
export function deviceRepairByUserPage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/repair/byUser/page",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function deviceRepairInfo(repairId) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/repair/info/${repairId}`,
|
||||
method: "GET"
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function finishRepairByUser(repairId) {
|
||||
return axios(
|
||||
{
|
||||
url: `/udi/device/repair/finishByUser/${repairId}`,
|
||||
method: "GET"
|
||||
}
|
||||
)
|
||||
}
|
@ -0,0 +1,51 @@
|
||||
import axios from "@/utils/request";
|
||||
|
||||
export function deviceRepairApplyPage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/repair/apply/page",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function deviceRepairApplyHallPage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/repair/apply/hall/page",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function deviceRepairApplyConfirmByUserPage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/repair/apply/confirmByUser/page",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function deviceRepairApplyAdd(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/repair/apply/add",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
|
||||
export function confirmDeviceRepairApply(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/repair/apply/confirm",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
@ -0,0 +1,20 @@
|
||||
import axios from "@/utils/request";
|
||||
|
||||
export function deviceRepairApplyDetailPage(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/repair/apply/detail/page",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
||||
export function deviceRepairApplyDetailDiagnosis(query) {
|
||||
return axios(
|
||||
{
|
||||
url: "/udi/device/repair/apply/detail/diagnosis",
|
||||
method: "POST",
|
||||
data: query
|
||||
}
|
||||
)
|
||||
}
|
@ -0,0 +1,35 @@
|
||||
export const deviceChangeType = {
|
||||
ADD: {key: "ADD", tagType: "primary", desc: "新增入库"},
|
||||
CHANGE: {key: "CHANGE", tagType: "warning", desc: "变更归属"},
|
||||
DESTROY: {key: "DESTROY", tagType: "danger", desc: "销毁/报废"},
|
||||
}
|
||||
|
||||
export const deviceChangeStatus = {
|
||||
WAIT_CONFIRM: {key: "WAIT_CONFIRM", tagType: "warning", desc: "待目标部门确认"},
|
||||
REJECT_CONFIRM: {key: "REJECT_CONFIRM", tagType: "danger", desc: "目标部门拒绝"},
|
||||
FINISH: {key: "FINISH", tagType: "success", desc: "已完成"},
|
||||
CANCEL: {key: "CANCEL", tagType: "info", desc: "已取消"},
|
||||
}
|
||||
|
||||
export const deviceStatus = {
|
||||
NORMAL: {key: "NORMAL", tagType: "success", desc: "正常"},
|
||||
CHANGE: {key: "CHANGE", tagType: "warning", desc: "变更归属中"},
|
||||
REPAIR_APPLY: {key: "REPAIR_APPLY", tagType: "warning", desc: "维修申请中"},
|
||||
REPAIR: {key: "REPAIR", tagType: "danger", desc: "维修中"},
|
||||
// CHECK: {key: "CHECK", tagType: "warning", desc: "等待巡检"},
|
||||
DESTROY: {key: "DESTROY", tagType: "danger", desc: "销毁/报废"},
|
||||
}
|
||||
|
||||
export const deviceRepairApplyStatus = {
|
||||
WAIT_PROCESS: {key: "WAIT_PROCESS", tagType: "warning", desc: "待受理"},
|
||||
PROCESSING: {key: "PROCESSING", tagType: "primary", desc: "受理中"},
|
||||
// REPAIRING: {key: "REPAIRING", tagType: "primary", desc: "维修中"},
|
||||
FINISH: {key: "FINISH", tagType: "success", desc: "完成"},
|
||||
}
|
||||
|
||||
export const deviceRepairApplyDetailStatus = {
|
||||
WAIT_DIAGNOSIS: {key: "WAIT_DIAGNOSIS", tagType: "warning", desc: "待诊断"},
|
||||
// WAIT_REPAIR: {key: "WAIT_REPAIR", tagType: "warning", desc: "待维修"},
|
||||
REPAIRING: {key: "REPAIRING", tagType: "primary", desc: "维修中"},
|
||||
FINISH: {key: "FINISH", tagType: "success", desc: "完成"},
|
||||
}
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,40 @@
|
||||
import {filterList} from "@/api/system/invWarehouse";
|
||||
|
||||
|
||||
export default {
|
||||
name: "deptSelect",
|
||||
props: {value: {required: true},notCode:null},
|
||||
data() {
|
||||
return {
|
||||
val: '',
|
||||
list: [],
|
||||
}
|
||||
},
|
||||
watch: {
|
||||
val(newVal) {
|
||||
this.$emit('update:value', newVal);
|
||||
},
|
||||
value(newVal) {
|
||||
this.val = newVal
|
||||
},
|
||||
},
|
||||
created() {
|
||||
this.val = this.value
|
||||
this.getList()
|
||||
},
|
||||
methods: {
|
||||
getList() {
|
||||
filterList({enable: true}).then(res => {
|
||||
if (res.code == 20000) {
|
||||
this.list = res.data.list || []
|
||||
if(this.notCode!=null) {
|
||||
let index = this.list.findIndex(i => i.code == this.notCode);
|
||||
if(index!=-1){
|
||||
this.list.splice(index,1)
|
||||
}
|
||||
}
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
@ -0,0 +1,9 @@
|
||||
<template>
|
||||
|
||||
<el-select v-model="val" class="width-full" placeholder="请选择" filterable clearable>
|
||||
<el-option v-for="item in list" :key="item.id" :label="item.name" :value="item.code"/>
|
||||
</el-select>
|
||||
</template>
|
||||
|
||||
<script src="./index.js">
|
||||
</script>
|
@ -0,0 +1,41 @@
|
||||
import {getBasicThirdSys} from "@/api/basic/basicThirdSys";
|
||||
import {getLoading} from "@/utils";
|
||||
import {deviceRepairInfo} from "@/api/dev/deviceRepairApi";
|
||||
|
||||
|
||||
export default {
|
||||
name: "deviceRepairDialog",
|
||||
props: {repairId: {require: true}},
|
||||
data() {
|
||||
return {
|
||||
info: null
|
||||
}
|
||||
},
|
||||
watch: {
|
||||
val(newVal) {
|
||||
this.$emit('update:value', newVal);
|
||||
},
|
||||
value(newVal) {
|
||||
this.val = newVal
|
||||
},
|
||||
},
|
||||
created() {
|
||||
this.val = this.value
|
||||
this.getInfo()
|
||||
},
|
||||
methods: {
|
||||
getInfo() {
|
||||
let load = getLoading(this)
|
||||
deviceRepairInfo(this.repairId).then(res => {
|
||||
load.close()
|
||||
if (res.code != 20000) {
|
||||
this.$message.error(res.message)
|
||||
return
|
||||
}
|
||||
this.info = res.data
|
||||
}).catch(() => {
|
||||
load.close()
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
@ -0,0 +1,47 @@
|
||||
<template>
|
||||
<el-card v-if="info">
|
||||
<div slot="header" class="clearfix">
|
||||
<div class="fl">
|
||||
{{ `设备号:${info.deviceCode}` }}
|
||||
</div>
|
||||
<div class="fr">
|
||||
<el-button @click="getInfo">刷新</el-button>
|
||||
</div>
|
||||
</div>
|
||||
<el-descriptions border label-style="width:90px" :column="4">
|
||||
<el-descriptions-item label="维修号">{{ info.id }}</el-descriptions-item>
|
||||
<el-descriptions-item label="状态"><el-tag :type="info.finishFlag?'success':'warning'">{{
|
||||
info.finishFlag ? '已完成' : '未完成'
|
||||
}}</el-tag></el-descriptions-item>
|
||||
<el-descriptions-item label="名称">{{ info.productName }}</el-descriptions-item>
|
||||
<el-descriptions-item label="规格">{{ info.ggxh }}</el-descriptions-item>
|
||||
<el-descriptions-item label="销售标识">{{ info.nameCode }}</el-descriptions-item>
|
||||
<el-descriptions-item label="注册/备案号">{{ info.zczbhhzbapzbh }}</el-descriptions-item>
|
||||
<el-descriptions-item label="生产企业">{{ info.manufactory }}</el-descriptions-item>
|
||||
<el-descriptions-item label="供应商">{{ info.supName }}</el-descriptions-item>
|
||||
<el-descriptions-item label="批次号">{{ info.batchNo }}</el-descriptions-item>
|
||||
<el-descriptions-item label="序列号">{{ info.serialNo }}</el-descriptions-item>
|
||||
<el-descriptions-item label="udi码">{{ info.udi }}</el-descriptions-item>
|
||||
<el-descriptions-item label="生产日期">{{ info.productionDate }}</el-descriptions-item>
|
||||
<el-descriptions-item label="过期时间">{{ info.expireDate }}</el-descriptions-item>
|
||||
<el-descriptions-item label="维修方式" :span="1">
|
||||
{{ info.innerFlag ? '内部维修' : '外部维修' }}
|
||||
</el-descriptions-item>
|
||||
<el-descriptions-item label="维修人姓名" :span="1">
|
||||
{{ info.repairUserName }}
|
||||
</el-descriptions-item>
|
||||
<el-descriptions-item label="维修人电话" :span="1">
|
||||
{{ info.repairUserPhone }}
|
||||
</el-descriptions-item>
|
||||
<el-descriptions-item label="问题描述" :label-style="{'height': '100px'}" :span="4">
|
||||
{{ info.description }}
|
||||
</el-descriptions-item>
|
||||
<el-descriptions-item label="诊断信息" :label-style="{'height': '100px'}" :span="4">
|
||||
{{ info.diagnosisInfo }}
|
||||
</el-descriptions-item>
|
||||
</el-descriptions>
|
||||
</el-card>
|
||||
</template>
|
||||
|
||||
<script src="./index.js">
|
||||
</script>
|
@ -0,0 +1,50 @@
|
||||
import {deviceDetailInfo} from "@/api/dev/deviceInfoApi";
|
||||
|
||||
let query = {
|
||||
page: 1,
|
||||
limit: 10,
|
||||
productName: null,
|
||||
deviceCode: null,
|
||||
planId: null,
|
||||
}
|
||||
export default {
|
||||
name: "planChooseDevice",
|
||||
props: {planId: {required: true}, selectChangeFunc: {required: true, type: Function}},
|
||||
data() {
|
||||
return {
|
||||
showSearch:true,
|
||||
loading: false,
|
||||
query:{...query},
|
||||
list: [],
|
||||
total:0,
|
||||
}
|
||||
},
|
||||
created(){
|
||||
this.query = {...query,planId:this.planId}
|
||||
this.getList()
|
||||
},
|
||||
methods: {
|
||||
onReset(){
|
||||
this.query = {...query,planId:this.planId}
|
||||
this.getList()
|
||||
},
|
||||
getList() {
|
||||
this.loading = true
|
||||
deviceDetailInfo(this.query)
|
||||
.then((res) => {
|
||||
this.loading = false
|
||||
if(res.code!=20000){
|
||||
this.$message.error(res.message)
|
||||
return
|
||||
}
|
||||
this.list = res.data.list || [];
|
||||
this.total = res.data.total || 0;
|
||||
})
|
||||
.catch(() => {
|
||||
this.loading = false
|
||||
this.list = [];
|
||||
this.total = 0;
|
||||
});
|
||||
},
|
||||
},
|
||||
}
|
@ -0,0 +1,90 @@
|
||||
<template>
|
||||
<div>
|
||||
<el-card>
|
||||
|
||||
<el-form :model="query" v-if="showSearch" label-width="auto">
|
||||
<el-row :gutter="20">
|
||||
<el-col :span="6">
|
||||
<el-form-item label="设备编码">
|
||||
<el-input v-model="query.deviceCode" clearable/>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="6">
|
||||
<el-form-item label="设备名称">
|
||||
<el-input v-model="query.productName" clearable/>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<!-- <el-col :span="6">-->
|
||||
<!-- <el-form-item label="设备状态">-->
|
||||
<!-- <el-select v-model="query.status"-->
|
||||
<!-- style="width: 100%"-->
|
||||
<!-- clearable>-->
|
||||
<!-- <el-option-->
|
||||
<!-- v-for="item in deviceStatus"-->
|
||||
<!-- :key="item.key"-->
|
||||
<!-- :label="item.desc"-->
|
||||
<!-- :value="item.key">-->
|
||||
<!-- </el-option>-->
|
||||
<!-- </el-select>-->
|
||||
<!-- </el-form-item>-->
|
||||
<!-- </el-col>-->
|
||||
</el-row>
|
||||
</el-form>
|
||||
<div class="top-right-btn">
|
||||
<el-button-group>
|
||||
<el-button icon="el-icon-view" type="primary" @click="showSearch = !showSearch">显示/隐藏搜索栏</el-button>
|
||||
<el-button
|
||||
type="primary"
|
||||
icon="el-icon-refresh"
|
||||
@click="onReset"
|
||||
>重置
|
||||
</el-button>
|
||||
<el-button type="primary" icon="el-icon-search" @click="query.page=1;getList()"
|
||||
>查询
|
||||
</el-button>
|
||||
</el-button-group>
|
||||
</div>
|
||||
<el-divider style="margin: 15px"></el-divider>
|
||||
<el-table :data="list" v-loading="loading" @selection-change="(val)=>{selectChangeFunc(val)}"
|
||||
@row-click="(row)=>{$refs.table.toggleRowSelection(row)}" ref="table" row-key="deviceCode">
|
||||
<el-table-column type="selection" width="55"></el-table-column>
|
||||
<el-table-column label="序号" width="50" type="index"/>
|
||||
<el-table-column label="科室" width="150" prop="deptName"/>
|
||||
<el-table-column label="设备编码" width="150" prop="deviceCode"/>
|
||||
<el-table-column label="最小销售标识" width="150" prop="nameCode"/>
|
||||
<el-table-column label="名称" width="150" prop="productName"/>
|
||||
<el-table-column label="规格型号" width="160" prop="ggxh"/>
|
||||
<!-- <el-table-column label="状态" width="120" prop="statusName">-->
|
||||
<!-- <template scope="scope">-->
|
||||
<!-- <el-tag :type="deviceStatus[scope.row.status].tagType">{{ scope.row.statusName }}</el-tag>-->
|
||||
<!-- </template>-->
|
||||
<!-- </el-table-column>-->
|
||||
<el-table-column label="变更次数" width="100" prop="changeCount"/>
|
||||
<el-table-column label="维修次数" width="100" prop="repairCount"/>
|
||||
<el-table-column label="巡检次数" width="100" prop="checkCount"/>
|
||||
<el-table-column label="计量单位" width="100" prop="measname"/>
|
||||
<el-table-column label="生产企业" width="180" prop="manufactory"/>
|
||||
<el-table-column label="批次号" width="100" prop="batchNo"/>
|
||||
<el-table-column label="序列号" width="100" prop="serialNo"/>
|
||||
<el-table-column label="生产日期" width="140" prop="productionDate"/>
|
||||
<el-table-column label="过期时间" width="140" prop="expireDate"/>
|
||||
<el-table-column label="供应商" width="100" prop="supName"/>
|
||||
<el-table-column label="udi码" width="150" prop="udi"/>
|
||||
<el-table-column label="注册/备案号" width="150" prop="zczbhhzbapzbh"/>
|
||||
</el-table>
|
||||
<pagination
|
||||
v-show="total>0"
|
||||
:total="total"
|
||||
:page.sync="query.page"
|
||||
:limit.sync="query.limit"
|
||||
@pagination="getList"
|
||||
/>
|
||||
</el-card>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script src="./index.js"/>
|
||||
|
||||
<style scoped>
|
||||
|
||||
</style>
|
@ -0,0 +1,335 @@
|
||||
<template>
|
||||
<div>
|
||||
<el-card>
|
||||
|
||||
<el-form :model="query" v-if="showSearch" label-width="auto">
|
||||
<el-row :gutter="20">
|
||||
<!-- <el-col :span="6">-->
|
||||
<!-- <el-form-item label="负责部门">-->
|
||||
<!-- <deptSelect :value.sync="query.chargeDeptCode"/>-->
|
||||
<!-- </el-form-item>-->
|
||||
<!-- </el-col>-->
|
||||
</el-row>
|
||||
</el-form>
|
||||
<div class="top-right-btn">
|
||||
<el-button-group>
|
||||
<el-button icon="el-icon-view" type="primary" @click="showSearch = !showSearch">显示/隐藏搜索栏</el-button>
|
||||
<el-button
|
||||
type="primary"
|
||||
icon="el-icon-refresh"
|
||||
@click="onReset"
|
||||
>重置
|
||||
</el-button>
|
||||
<el-button type="primary" icon="el-icon-search" @click="search"
|
||||
>查询
|
||||
</el-button>
|
||||
</el-button-group>
|
||||
</div>
|
||||
<el-divider style="margin: 15px"></el-divider>
|
||||
|
||||
<el-table :data="list" @row-click="rowClick" v-loading="loading" click-row-light>
|
||||
<el-table-column label="序号" width="50" type="index"/>
|
||||
<el-table-column label="任务id" width="150" prop="taskId"/>
|
||||
<el-table-column label="任务名称" width="150" prop="name"/>
|
||||
<el-table-column label="计划名称" width="150" prop="planName"/>
|
||||
<el-table-column label="系统生成" width="80" prop="sysFlag">
|
||||
<template scope="scope">
|
||||
{{ scope.row.sysFlag ? '是' : '否' }}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="完成情况" width="80" prop="finishFlag">
|
||||
<template scope="scope">
|
||||
<el-tag v-if="scope.row.finishFlag==true" type="success">已完成</el-tag>
|
||||
<el-tag v-if="scope.row.finishFlag==false" type="warning">未完成</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="负责部门" width="160" prop="chargeDeptName"/>
|
||||
<!-- <el-table-column label="负责人" width="160" prop="checkUserName"/>-->
|
||||
<!-- <el-table-column label="负责人联系方式" width="160" prop="checkUserPhone"/>-->
|
||||
<el-table-column label="设备数量" width="50" prop="deviceCount"/>
|
||||
<el-table-column label="完成数量" width="50" prop="finishCount"/>
|
||||
<el-table-column label="异常数量" class-name="color-red" width="50" prop="exceptionCount"/>
|
||||
<el-table-column label="创建时间" width="160" prop="createTime"/>
|
||||
<el-table-column label="创建人" width="160" prop="createUserName"/>
|
||||
</el-table>
|
||||
<pagination
|
||||
v-show="total>0"
|
||||
:total="total"
|
||||
:page.sync="query.page"
|
||||
:limit.sync="query.limit"
|
||||
@pagination="getList"
|
||||
/>
|
||||
</el-card>
|
||||
|
||||
<el-card>
|
||||
<div slot="header" class="clearfix">
|
||||
<div class="fl">{{
|
||||
`任务详情 ${clickRow ? '——' + clickRow.name : ''}`
|
||||
}}
|
||||
</div>
|
||||
<div v-if="clickRow" class="fr">
|
||||
<el-button @click="getDetailList">刷新</el-button>
|
||||
</div>
|
||||
</div>
|
||||
<el-form v-if="clickRow" :model="detailQuery" inline label-width="auto">
|
||||
<el-row :gutter="20">
|
||||
<el-col>
|
||||
<el-form-item label="设备编码">
|
||||
<el-input v-model.trim="detailQuery.deviceCode" clearable/>
|
||||
</el-form-item>
|
||||
<el-button type="primary" icon="el-icon-search" @click="getDetailList"
|
||||
>查询
|
||||
</el-button>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form>
|
||||
<el-table :data="detailList" v-loading="detailLoading">
|
||||
<el-table-column label="序号" width="50" type="index"/>
|
||||
<el-table-column label="科室" width="150" prop="deptName"/>
|
||||
<el-table-column label="设备编码" width="150" prop="deviceCode"/>
|
||||
<el-table-column label="完成情况" width="80" prop="finishFlag">
|
||||
<template scope="scope">
|
||||
<el-tag v-if="scope.row.finishFlag==true" type="success">已完成</el-tag>
|
||||
<el-tag v-if="scope.row.finishFlag==false" type="warning">未完成</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="完成时间" width="160" prop="finishTime"/>
|
||||
<el-table-column label="最小销售标识" width="150" prop="nameCode"/>
|
||||
<el-table-column label="名称" width="150" prop="productName"/>
|
||||
<el-table-column label="项目数量" width="50" prop="itemCount"/>
|
||||
<el-table-column label="完成数量" width="50" prop="finishCount"/>
|
||||
<el-table-column label="异常数量" class-name="color-red" width="50" prop="exceptionCount"/>
|
||||
<el-table-column label="规格型号" width="160" prop="ggxh"/>
|
||||
<!-- <el-table-column label="状态" width="120" prop="statusName">-->
|
||||
<!-- <template scope="scope">-->
|
||||
<!-- <el-tag :type="deviceStatus[scope.row.status].tagType">{{ scope.row.statusName }}</el-tag>-->
|
||||
<!-- </template>-->
|
||||
<!-- </el-table-column>-->
|
||||
<el-table-column label="计量单位" width="100" prop="measname"/>
|
||||
<el-table-column label="生产企业" width="180" prop="manufactory"/>
|
||||
<el-table-column label="批次号" width="100" prop="batchNo"/>
|
||||
<el-table-column label="序列号" width="100" prop="serialNo"/>
|
||||
<el-table-column label="生产日期" width="140" prop="productionDate"/>
|
||||
<el-table-column label="过期时间" width="140" prop="expireDate"/>
|
||||
<el-table-column label="供应商" width="100" prop="supName"/>
|
||||
<el-table-column label="udi码" width="150" prop="udi"/>
|
||||
<el-table-column label="注册/备案号" width="150" prop="zczbhhzbapzbh"/>
|
||||
<el-table-column label="操作" width="170" fixed="right">
|
||||
<template scope="scope">
|
||||
<el-button type="text" @click="openItem(scope.row)"
|
||||
>查看巡检项目
|
||||
</el-button>
|
||||
<el-button v-if="scope.row.finishFlag&&scope.row.exceptionCount>0&&!scope.row.repairId" type="text"
|
||||
@click="createRepair(scope.row)"
|
||||
>创建维修
|
||||
</el-button>
|
||||
<el-button v-if="scope.row.repairId" type="text"
|
||||
@click="repairId = scope.row.repairId"
|
||||
>查看维修单
|
||||
</el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
<pagination
|
||||
v-show="detailTotal>0"
|
||||
:total="detailTotal"
|
||||
:page.sync="detailQuery.page"
|
||||
:limit.sync="detailQuery.limit"
|
||||
@pagination="getDetailList"
|
||||
/>
|
||||
|
||||
</el-card>
|
||||
<el-dialog
|
||||
:visible="true"
|
||||
v-if="itemDialogFlag"
|
||||
width="80%"
|
||||
:title="`巡检项目${itemQuery.title?'--'+itemQuery.title:''}`"
|
||||
@close="itemDialogFlag = false"
|
||||
>
|
||||
<el-card>
|
||||
<div slot="header" class="clearfix">
|
||||
<div class="fr">
|
||||
<el-button type="" @click="getDetailItemList">刷新</el-button>
|
||||
</div>
|
||||
</div>
|
||||
<el-table :data="itemList" v-loading="itemLoading">
|
||||
<el-table-column label="序号" width="50" type="index"/>
|
||||
<el-table-column label="项目编码" width="150" prop="itemCode"/>
|
||||
<el-table-column label="完成情况" width="80" prop="finishFlag">
|
||||
<template scope="scope">
|
||||
<el-tag v-if="scope.row.finishFlag==true" type="success">已完成</el-tag>
|
||||
<el-tag v-if="scope.row.finishFlag==false" type="warning">未完成</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="完成时间" width="160" prop="finishTime"/>
|
||||
<el-table-column label="巡检部门" width="100" prop="checkDeptName"/>
|
||||
<el-table-column label="巡检人" width="100" prop="checkUserName"/>
|
||||
<el-table-column label="异常情况" width="80" prop="finishFlag">
|
||||
<template scope="scope">
|
||||
<el-tag v-if="scope.row.normalFlag==true" type="success">正常</el-tag>
|
||||
<el-tag v-if="scope.row.normalFlag==false" type="danger">异常</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="项目名称" width="150" prop="itemName"/>
|
||||
<el-table-column label="项目内容" width="450" prop="itemContent"/>
|
||||
<el-table-column label="巡检意见" width="450" prop="suggestion"/>
|
||||
<el-table-column label="操作" width="100" fixed="right">
|
||||
<template scope="scope">
|
||||
<el-button v-if="scope.row.finishFlag==false" type="text"
|
||||
@click="itemRow = {...scope.row,normalFlag:true}">完成
|
||||
</el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
<pagination
|
||||
v-show="itemTotal>0"
|
||||
:total="itemTotal"
|
||||
:page.sync="itemQuery.page"
|
||||
:limit.sync="itemQuery.limit"
|
||||
@pagination="getDetailItemList"
|
||||
/>
|
||||
</el-card>
|
||||
</el-dialog>
|
||||
|
||||
|
||||
<el-dialog
|
||||
:visible="true"
|
||||
v-if="itemRow"
|
||||
width="80%"
|
||||
@close="itemRow = null"
|
||||
>
|
||||
<el-card>
|
||||
<div slot="header" class="clearfix">
|
||||
<div class="fl">
|
||||
{{ `巡检项目--${itemRow.itemName}[${itemRow.itemCode}]` }}
|
||||
</div>
|
||||
<div class="fr">
|
||||
<el-button @click="itemRow = null">取消</el-button>
|
||||
<el-button type="primary" @click="commitItemCheck">提交</el-button>
|
||||
</div>
|
||||
</div>
|
||||
<el-form :model="itemRow" :rules="itemRules" ref="itemForm" label-width="auto">
|
||||
<el-descriptions border :column="2" label-style="width:100px">
|
||||
<el-descriptions-item label="设备信息" :span="2">
|
||||
{{ itemQuery.title }}
|
||||
</el-descriptions-item>
|
||||
<el-descriptions-item label="项目编码">
|
||||
{{ itemRow.itemCode }}
|
||||
</el-descriptions-item>
|
||||
<el-descriptions-item label="项目名称">
|
||||
{{ itemRow.itemName }}
|
||||
</el-descriptions-item>
|
||||
<el-descriptions-item label="项目内容" label-style="height:150px;" :span="2">
|
||||
{{ itemRow.itemContent }}
|
||||
</el-descriptions-item>
|
||||
<el-descriptions-item label="异常情况" :span="2">
|
||||
<el-form-item label=" " prop="normalFlag" style="margin-bottom: 0px">
|
||||
<el-radio-group v-model="itemRow.normalFlag">
|
||||
<el-radio :label="true">正常</el-radio>
|
||||
<el-radio :label="false">异常</el-radio>
|
||||
</el-radio-group>
|
||||
</el-form-item>
|
||||
</el-descriptions-item>
|
||||
<el-descriptions-item label="巡检意见" :span="2">
|
||||
<el-form-item label=" " prop="suggestion" style="margin-bottom: 10px">
|
||||
<el-input type="textarea" resize="none" :autosize="{ minRows: 4, maxRows: 4 }" clearable
|
||||
show-word-limit
|
||||
maxlength="300" v-model.trim="itemRow.suggestion"/>
|
||||
</el-form-item>
|
||||
</el-descriptions-item>
|
||||
</el-descriptions>
|
||||
</el-form>
|
||||
</el-card>
|
||||
</el-dialog>
|
||||
|
||||
<el-dialog
|
||||
:visible="true"
|
||||
title="创建维修单"
|
||||
v-if="repairRow"
|
||||
width="80%"
|
||||
@close="repairRow = null"
|
||||
>
|
||||
<el-card>
|
||||
<div slot="header" class="clearfix">
|
||||
<div class="fl">
|
||||
{{ `巡检设备--${repairRow.deviceCode}--${repairRow.productName}(${repairRow.ggxh})` }}
|
||||
</div>
|
||||
<div class="fr">
|
||||
<el-button @click="repairRow = null">取消</el-button>
|
||||
<el-button type="primary" @click="commitRepair">提交</el-button>
|
||||
</div>
|
||||
</div>
|
||||
<el-form :model="repairRow" :rules="repairRules" ref="repairForm" label-width="auto">
|
||||
<el-descriptions border label-style="width:90px" :column="3">
|
||||
<el-descriptions-item label="名称">{{ repairRow.productName }}</el-descriptions-item>
|
||||
<el-descriptions-item label="规格">{{ repairRow.ggxh }}</el-descriptions-item>
|
||||
<el-descriptions-item label="销售标识">{{ repairRow.nameCode }}</el-descriptions-item>
|
||||
<el-descriptions-item label="注册/备案号">{{ repairRow.zczbhhzbapzbh }}</el-descriptions-item>
|
||||
<el-descriptions-item label="生产企业">{{ repairRow.manufactory }}</el-descriptions-item>
|
||||
<el-descriptions-item label="供应商">{{ repairRow.supName }}</el-descriptions-item>
|
||||
<el-descriptions-item label="批次号">{{ repairRow.batchNo }}</el-descriptions-item>
|
||||
<el-descriptions-item label="序列号">{{ repairRow.serialNo }}</el-descriptions-item>
|
||||
<el-descriptions-item label="udi码">{{ repairRow.udi }}</el-descriptions-item>
|
||||
<el-descriptions-item label="生产日期">{{ repairRow.productionDate }}</el-descriptions-item>
|
||||
<el-descriptions-item label="过期时间">{{ repairRow.expireDate }}</el-descriptions-item>
|
||||
<el-descriptions-item label=""></el-descriptions-item>
|
||||
<el-descriptions-item label="问题描述" :label-style="{'height': '100px'}" :span="3">
|
||||
<el-form-item label=" " prop="description" style="margin-bottom: 10px">
|
||||
<el-input type="textarea" resize="none" :autosize="{ minRows: 4, maxRows: 4 }" clearable
|
||||
show-word-limit
|
||||
maxlength="300" v-model.trim="repairRow.description"/>
|
||||
</el-form-item>
|
||||
</el-descriptions-item>
|
||||
<el-descriptions-item label="维修方式" :span="3">
|
||||
<el-form-item label=" " prop="innerFlag" style="margin-bottom: 0">
|
||||
<el-radio-group v-model="repairRow.innerFlag">
|
||||
<el-radio :label="true">内部维修</el-radio>
|
||||
<el-radio :label="false">外部维修</el-radio>
|
||||
</el-radio-group>
|
||||
</el-form-item>
|
||||
</el-descriptions-item>
|
||||
<el-descriptions-item label="维修人姓名" :span="3">
|
||||
<el-form-item label=" " prop="repairUserName" style="margin-bottom: 10px">
|
||||
<el-input v-model.trim="repairRow.repairUserName" placeholder="请输入维修人姓名"/>
|
||||
</el-form-item>
|
||||
</el-descriptions-item>
|
||||
<el-descriptions-item label="维修人电话" :span="3">
|
||||
<el-form-item label=" " prop="repairUserPhone" style="margin-bottom: 10px">
|
||||
<el-input v-model.trim="repairRow.repairUserPhone" placeholder="请输入维修人电话"/>
|
||||
</el-form-item>
|
||||
</el-descriptions-item>
|
||||
<el-descriptions-item label="诊断信息" :label-style="{'height': '100px'}" :span="3">
|
||||
<el-form-item label=" " prop="diagnosisInfo" style="margin-bottom: 10px">
|
||||
<el-input type="textarea" resize="none" :autosize="{ minRows: 4, maxRows: 4 }" clearable
|
||||
show-word-limit
|
||||
maxlength="300" v-model.trim="repairRow.diagnosisInfo"/>
|
||||
</el-form-item>
|
||||
</el-descriptions-item>
|
||||
</el-descriptions>
|
||||
</el-form>
|
||||
</el-card>
|
||||
</el-dialog>
|
||||
|
||||
|
||||
<el-dialog
|
||||
visible
|
||||
v-if="repairId"
|
||||
@close="repairId=null"
|
||||
title="维修单信息"
|
||||
width="80%"
|
||||
>
|
||||
<deviceRepairDialog :repairId="repairId"/>
|
||||
</el-dialog>
|
||||
|
||||
</div>
|
||||
|
||||
</template>
|
||||
|
||||
<script src="./js/deptDeviceCheck.js"/>
|
||||
|
||||
<style scoped>
|
||||
|
||||
/deep/ .el-dialog__body {
|
||||
padding: 0 0 20px 0;
|
||||
}
|
||||
</style>
|
@ -0,0 +1,26 @@
|
||||
<template>
|
||||
<div>
|
||||
<deviceChangeOrder :type="deviceChangeType.ADD"/>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import deviceChangeOrder from "@/views/dev/deviceChangeOrder.vue";
|
||||
import {deviceChangeType} from "@/utils/enum";
|
||||
|
||||
export default {
|
||||
computed: {
|
||||
deviceChangeType() {
|
||||
return deviceChangeType
|
||||
}
|
||||
},
|
||||
components: {deviceChangeOrder},
|
||||
data(){
|
||||
return{
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style></style>
|
@ -0,0 +1,26 @@
|
||||
<template>
|
||||
<div>
|
||||
<deviceChangeOrder :type="deviceChangeType.CHANGE"/>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import deviceChangeOrder from "@/views/dev/deviceChangeOrder.vue";
|
||||
import {deviceChangeType} from "@/utils/enum";
|
||||
|
||||
export default {
|
||||
computed: {
|
||||
deviceChangeType() {
|
||||
return deviceChangeType
|
||||
}
|
||||
},
|
||||
components: {deviceChangeOrder},
|
||||
data(){
|
||||
return{
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style></style>
|
@ -0,0 +1,26 @@
|
||||
<template>
|
||||
<div>
|
||||
<deviceChangeOrder :type="deviceChangeType.DESTROY"/>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import deviceChangeOrder from "@/views/dev/deviceChangeOrder.vue";
|
||||
import {deviceChangeType} from "@/utils/enum";
|
||||
|
||||
export default {
|
||||
computed: {
|
||||
deviceChangeType() {
|
||||
return deviceChangeType
|
||||
}
|
||||
},
|
||||
components: {deviceChangeOrder},
|
||||
data(){
|
||||
return{
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
</script>
|
||||
|
||||
<style></style>
|
@ -0,0 +1,322 @@
|
||||
<template>
|
||||
<div>
|
||||
<el-card>
|
||||
|
||||
<el-form :model="query" v-if="showSearch" label-width="auto">
|
||||
<el-row :gutter="20">
|
||||
<el-col :span="6">
|
||||
<el-form-item label="负责部门">
|
||||
<deptSelect :value.sync="query.chargeDeptCode"/>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form>
|
||||
<div class="top-right-btn">
|
||||
<el-button-group>
|
||||
<el-button icon="el-icon-view" type="primary" @click="showSearch = !showSearch">显示/隐藏搜索栏</el-button>
|
||||
<el-button
|
||||
type="primary"
|
||||
icon="el-icon-refresh"
|
||||
@click="onReset"
|
||||
>重置
|
||||
</el-button>
|
||||
<el-button type="primary" icon="el-icon-search" @click="search"
|
||||
>查询
|
||||
</el-button>
|
||||
</el-button-group>
|
||||
</div>
|
||||
<el-divider style="margin: 15px"></el-divider>
|
||||
|
||||
<el-table :data="list" @row-click="rowClick" v-loading="loading" click-row-light>
|
||||
<el-table-column label="序号" width="50" type="index"/>
|
||||
<el-table-column label="任务id" width="150" prop="taskId"/>
|
||||
<el-table-column label="任务名称" width="150" prop="name"/>
|
||||
<el-table-column label="计划名称" width="150" prop="planName"/>
|
||||
<el-table-column label="系统生成" width="80" prop="sysFlag">
|
||||
<template scope="scope">
|
||||
{{ scope.row.sysFlag ? '是' : '否' }}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="完成情况" width="80" prop="finishFlag">
|
||||
<template scope="scope">
|
||||
<el-tag v-if="scope.row.finishFlag==true" type="success">已完成</el-tag>
|
||||
<el-tag v-if="scope.row.finishFlag==false" type="warning">未完成</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="负责部门" width="160" prop="chargeDeptName"/>
|
||||
<!-- <el-table-column label="负责人" width="160" prop="checkUserName"/>-->
|
||||
<!-- <el-table-column label="负责人联系方式" width="160" prop="checkUserPhone"/>-->
|
||||
<el-table-column label="设备数量" width="50" prop="deviceCount"/>
|
||||
<el-table-column label="完成数量" width="50" prop="finishCount"/>
|
||||
<el-table-column label="创建时间" width="160" prop="createTime"/>
|
||||
<el-table-column label="创建人" width="160" prop="createUserName"/>
|
||||
<!-- <el-table-column label="状态" width="120" prop="statusName">-->
|
||||
<!-- <template scope="scope">-->
|
||||
<!-- <el-tag :type="deviceStatus[scope.row.status].tagType">{{scope.row.statusName}}</el-tag>-->
|
||||
<!-- </template>-->
|
||||
<!-- </el-table-column>-->
|
||||
<!-- <el-table-column label="数量" width="120" prop="count"/>-->
|
||||
<!-- <el-table-column label="计量单位" width="100" prop="measname"/>-->
|
||||
<!-- <el-table-column label="生产企业" width="180" prop="manufactory"/>-->
|
||||
<!-- <el-table-column label="批次号" width="100" prop="batchNo"/>-->
|
||||
<!-- <el-table-column label="序列号" width="100" prop="serialNo"/>-->
|
||||
<!-- <el-table-column label="生产日期" width="140" prop="productionDate"/>-->
|
||||
<!-- <el-table-column label="过期时间" width="140" prop="expireDate"/>-->
|
||||
<!-- <el-table-column label="供应商" width="100" prop="supName"/>-->
|
||||
<!-- <el-table-column label="udi码" width="150" prop="udi"/>-->
|
||||
<!-- <el-table-column label="注册/备案号" width="150" prop="zczbhhzbapzbh"/>-->
|
||||
<!-- <el-table-column label="操作" width="120" fixed="right">-->
|
||||
<!-- <template scope="scope">-->
|
||||
|
||||
<!-- <el-button type="text" @click="print(scope.row.taskId)"-->
|
||||
<!-- >打印-->
|
||||
<!-- </el-button>-->
|
||||
<!-- </template>-->
|
||||
<!-- </el-table-column>-->
|
||||
</el-table>
|
||||
<pagination
|
||||
v-show="total>0"
|
||||
:total="total"
|
||||
:page.sync="query.page"
|
||||
:limit.sync="query.limit"
|
||||
@pagination="getList"
|
||||
/>
|
||||
</el-card>
|
||||
|
||||
<el-card>
|
||||
<div slot="header" class="clearfix">
|
||||
<div class="fl">{{
|
||||
`任务详情 ${clickRow ? '——' + clickRow.name : ''}`
|
||||
}}
|
||||
</div>
|
||||
<div v-if="clickRow" class="fr">
|
||||
<el-button @click="getDetailList">刷新</el-button>
|
||||
</div>
|
||||
</div>
|
||||
<el-form v-if="clickRow" :model="detailQuery" inline label-width="auto">
|
||||
<el-row :gutter="20">
|
||||
<el-col>
|
||||
<el-form-item label="设备编码">
|
||||
<el-input v-model.trim="detailQuery.deviceCode" clearable/>
|
||||
</el-form-item>
|
||||
<el-button type="primary" icon="el-icon-search" @click="getDetailList"
|
||||
>查询
|
||||
</el-button>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form>
|
||||
<el-table :data="detailList" v-loading="detailLoading">
|
||||
<el-table-column label="序号" width="50" type="index"/>
|
||||
<el-table-column label="科室" width="150" prop="deptName"/>
|
||||
<el-table-column label="设备编码" width="150" prop="deviceCode"/>
|
||||
<el-table-column label="完成情况" width="80" prop="finishFlag">
|
||||
<template scope="scope">
|
||||
<el-tag v-if="scope.row.finishFlag==true" type="success">已完成</el-tag>
|
||||
<el-tag v-if="scope.row.finishFlag==false" type="warning">未完成</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="最小销售标识" width="150" prop="nameCode"/>
|
||||
<el-table-column label="名称" width="150" prop="productName"/>
|
||||
<el-table-column label="项目数量" width="50" prop="itemCount"/>
|
||||
<el-table-column label="完成数量" width="50" prop="finishCount"/>
|
||||
<el-table-column label="规格型号" width="160" prop="ggxh"/>
|
||||
<!-- <el-table-column label="状态" width="120" prop="statusName">-->
|
||||
<!-- <template scope="scope">-->
|
||||
<!-- <el-tag :type="deviceStatus[scope.row.status].tagType">{{ scope.row.statusName }}</el-tag>-->
|
||||
<!-- </template>-->
|
||||
<!-- </el-table-column>-->
|
||||
<el-table-column label="计量单位" width="100" prop="measname"/>
|
||||
<el-table-column label="生产企业" width="180" prop="manufactory"/>
|
||||
<el-table-column label="批次号" width="100" prop="batchNo"/>
|
||||
<el-table-column label="序列号" width="100" prop="serialNo"/>
|
||||
<el-table-column label="生产日期" width="140" prop="productionDate"/>
|
||||
<el-table-column label="过期时间" width="140" prop="expireDate"/>
|
||||
<el-table-column label="供应商" width="100" prop="supName"/>
|
||||
<el-table-column label="udi码" width="150" prop="udi"/>
|
||||
<el-table-column label="注册/备案号" width="150" prop="zczbhhzbapzbh"/>
|
||||
<el-table-column label="操作" width="170" fixed="right">
|
||||
<template scope="scope">
|
||||
<el-button type="text" @click="openItem(scope.row)"
|
||||
>查看巡检项目
|
||||
</el-button>
|
||||
<el-button v-if="scope.row.repairId" type="text" @click="repairId = scope.row.repairId"
|
||||
>查看维修单
|
||||
</el-button>
|
||||
<!-- <el-button type="text" @click="print(scope.row.taskId,scope.row.deviceCode)"-->
|
||||
<!-- >打印-->
|
||||
<!-- </el-button>-->
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
<pagination
|
||||
v-show="detailTotal>0"
|
||||
:total="detailTotal"
|
||||
:page.sync="detailQuery.page"
|
||||
:limit.sync="detailQuery.limit"
|
||||
@pagination="getDetailList"
|
||||
/>
|
||||
|
||||
</el-card>
|
||||
<el-dialog
|
||||
:visible="true"
|
||||
v-if="itemDialogFlag"
|
||||
width="80%"
|
||||
:title="`巡检项目${itemQuery.title?'--'+itemQuery.title:''}`"
|
||||
@close="itemDialogFlag = false"
|
||||
>
|
||||
<el-card>
|
||||
<div slot="header" class="clearfix">
|
||||
<div class="fr">
|
||||
<el-button type="" @click="getDetailItemList">刷新</el-button>
|
||||
</div>
|
||||
</div>
|
||||
<el-table :data="itemList" v-loading="itemLoading">
|
||||
<el-table-column label="序号" width="50" type="index"/>
|
||||
<el-table-column label="项目编码" width="150" prop="itemCode"/>
|
||||
<el-table-column label="完成情况" width="80" prop="finishFlag">
|
||||
<template scope="scope">
|
||||
<el-tag v-if="scope.row.finishFlag==true" type="success">已完成</el-tag>
|
||||
<el-tag v-if="scope.row.finishFlag==false" type="warning">未完成</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="完成时间" width="160" prop="finishTime"/>
|
||||
<el-table-column label="巡检部门" width="100" prop="checkDeptName"/>
|
||||
<el-table-column label="巡检人" width="100" prop="checkUserName"/>
|
||||
<el-table-column label="异常情况" width="80" prop="finishFlag">
|
||||
<template scope="scope">
|
||||
<el-tag v-if="scope.row.normalFlag==true" type="success">正常</el-tag>
|
||||
<el-tag v-if="scope.row.normalFlag==false" type="danger">异常</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="项目名称" width="150" prop="itemName"/>
|
||||
<el-table-column label="项目内容" width="450" prop="itemContent"/>
|
||||
<el-table-column label="巡检意见" width="450" prop="suggestion"/>
|
||||
</el-table>
|
||||
<pagination
|
||||
v-show="itemTotal>0"
|
||||
:total="itemTotal"
|
||||
:page.sync="itemQuery.page"
|
||||
:limit.sync="itemQuery.limit"
|
||||
@pagination="getDetailItemList"
|
||||
/>
|
||||
</el-card>
|
||||
</el-dialog>
|
||||
|
||||
<el-dialog
|
||||
visible
|
||||
v-if="repairId"
|
||||
@close="repairId=null"
|
||||
title="维修单信息"
|
||||
width="80%"
|
||||
>
|
||||
<deviceRepairDialog :repairId="repairId"/>
|
||||
</el-dialog>
|
||||
|
||||
<!-- <div id="printDiv" v-if="checkPrintData" v-show="false">-->
|
||||
<!-- <div class="width-full p10" style="height:100vh;overflow-y: auto" v-for="item in checkPrintData.details">-->
|
||||
<!-- <h1 align="center" style="font-size: 26px;font-weight: bolder;">巡检任务单</h1>-->
|
||||
<!-- <el-descriptions colon column="2" label-style="width:100px;">-->
|
||||
<!-- <el-descriptions-item label="任务标识">-->
|
||||
<!-- {{ checkPrintData.info.taskId }}-->
|
||||
<!-- </el-descriptions-item>-->
|
||||
<!-- <el-descriptions-item label="任务时间">-->
|
||||
<!-- {{ checkPrintData.info.createTime }}-->
|
||||
<!-- </el-descriptions-item>-->
|
||||
<!-- <el-descriptions-item label="打印时间">-->
|
||||
<!-- {{ checkPrintData.printTime }}-->
|
||||
<!-- </el-descriptions-item>-->
|
||||
<!-- <el-descriptions-item label="任务名称">-->
|
||||
<!-- {{ checkPrintData.info.name }}-->
|
||||
<!-- </el-descriptions-item>-->
|
||||
<!-- <el-descriptions-item label="计划名称">-->
|
||||
<!-- {{ checkPrintData.info.planName }}-->
|
||||
<!-- </el-descriptions-item>-->
|
||||
<!-- <el-descriptions-item label="负责部门">-->
|
||||
<!-- {{ checkPrintData.info.chargeDeptName }}-->
|
||||
<!-- </el-descriptions-item>-->
|
||||
<!-- <el-descriptions-item label="设备名称">-->
|
||||
<!-- {{ item.deviceCode }}-->
|
||||
<!-- </el-descriptions-item>-->
|
||||
<!-- <el-descriptions-item label="设备编号">-->
|
||||
<!-- {{ item.productName }}-->
|
||||
<!-- </el-descriptions-item>-->
|
||||
<!-- <el-descriptions-item label="设备规格">-->
|
||||
<!-- {{ item.ggxh }}-->
|
||||
<!-- </el-descriptions-item>-->
|
||||
<!-- <el-descriptions-item label="销售标识">-->
|
||||
<!-- {{ item.nameCode }}-->
|
||||
<!-- </el-descriptions-item>-->
|
||||
<!-- <el-descriptions-item label="注册/备案号">-->
|
||||
<!-- {{ item.zczbhhzbapzbh }}-->
|
||||
<!-- </el-descriptions-item>-->
|
||||
<!-- <el-descriptions-item label="计量单位">-->
|
||||
<!-- {{ item.measname }}-->
|
||||
<!-- </el-descriptions-item>-->
|
||||
<!-- <el-descriptions-item label="生产企业">-->
|
||||
<!-- {{ item.manufactory }}-->
|
||||
<!-- </el-descriptions-item>-->
|
||||
<!-- <el-descriptions-item label="使用部门">-->
|
||||
<!-- {{ item.deptName }}-->
|
||||
<!-- </el-descriptions-item>-->
|
||||
<!-- <el-descriptions-item label="UDI码">-->
|
||||
<!-- {{ item.udi }}-->
|
||||
<!-- </el-descriptions-item>-->
|
||||
<!-- <el-descriptions-item label="有效期">-->
|
||||
<!-- {{ item.productionDate }} ~ {{ item.expireDate }}-->
|
||||
<!-- </el-descriptions-item>-->
|
||||
<!-- <el-descriptions-item label="供应商">-->
|
||||
<!-- {{ item.supName }}-->
|
||||
<!-- </el-descriptions-item>-->
|
||||
<!-- </el-descriptions>-->
|
||||
<!-- <table border=1 cellspacing=0 cellpadding=1 width="100%" style="border-collapse:collapse" bordercolor="#333333">-->
|
||||
<!-- <thead>-->
|
||||
<!-- <th width="50px">-->
|
||||
<!-- <b>序号</b>-->
|
||||
<!-- </th>-->
|
||||
<!-- <th style="width: calc((100vh - 50px) / 4)">-->
|
||||
<!-- <b>项目名称</b>-->
|
||||
<!-- </th>-->
|
||||
<!-- <th style="width:calc((100vh - 50px) / 4)">-->
|
||||
<!-- <b>项目编码</b>-->
|
||||
<!-- </th>-->
|
||||
<!-- <th style="width:calc((100vh - 50px) / 4)">-->
|
||||
<!-- <b>项目内容</b>-->
|
||||
<!-- </th>-->
|
||||
<!-- <th style="width:calc((100vh - 50px) / 4)">-->
|
||||
<!-- <b>巡检意见</b>-->
|
||||
<!-- </th>-->
|
||||
<!-- </thead>-->
|
||||
<!-- <tbody>-->
|
||||
<!-- <tr align="center" v-for="(v,i) in item.detailItems" style="height: 200px;">-->
|
||||
<!-- <td>{{ i + 1 }}</td>-->
|
||||
<!-- <td>{{ v.itemName }}</td>-->
|
||||
<!-- <td>{{ v.itemCode }}</td>-->
|
||||
<!-- <td>{{ v.itemContent }}</td>-->
|
||||
<!-- <td>{{ v.suggestion }}</td>-->
|
||||
<!-- </tr>-->
|
||||
<!-- </tbody>-->
|
||||
<!-- <!– <el-table-column :show-overflow-tooltip="false" label="序号" type="index" width="50px"/>–>-->
|
||||
<!-- <!– <el-table-column :show-overflow-tooltip="false" label="项目名称" prop="itemName"–>-->
|
||||
<!-- <!– width="calc((100vh - 50px) / 4)"/>–>-->
|
||||
<!-- <!– <el-table-column :show-overflow-tooltip="false" label="项目编码" prop="itemCode"–>-->
|
||||
<!-- <!– width="calc((100vh - 50px) / 4)"/>–>-->
|
||||
<!-- <!– <el-table-column :show-overflow-tooltip="false" label="项目内容" prop="itemContent"–>-->
|
||||
<!-- <!– width="calc((100vh - 50px) / 4)"/>–>-->
|
||||
<!-- <!– <el-table-column :show-overflow-tooltip="false" label="巡检意见" prop="suggestion"–>-->
|
||||
<!-- <!– width="calc((100vh - 50px) / 4)"/>–>-->
|
||||
<!-- </table>-->
|
||||
<!-- </div>-->
|
||||
<!-- </div>-->
|
||||
|
||||
</div>
|
||||
|
||||
</template>
|
||||
|
||||
<script src="./js/deviceCheck.js"/>
|
||||
|
||||
<style scoped>
|
||||
|
||||
/deep/ .el-dialog__body {
|
||||
padding: 0 0 20px 0;
|
||||
}
|
||||
</style>
|
@ -0,0 +1,115 @@
|
||||
<template>
|
||||
<div>
|
||||
<el-card>
|
||||
|
||||
<el-form :model="query" v-if="showSearch" label-width="auto">
|
||||
<el-row :gutter="20">
|
||||
<el-col :span="6">
|
||||
<el-form-item label="项目编码">
|
||||
<el-input v-model="query.code" clearable/>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="6">
|
||||
<el-form-item label="项目名称">
|
||||
<el-input v-model="query.name" clearable/>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form>
|
||||
<div class="top-right-btn">
|
||||
<el-button-group>
|
||||
<el-button icon="el-icon-view" type="primary" @click="showSearch = !showSearch">显示/隐藏搜索栏</el-button>
|
||||
<el-button
|
||||
type="primary"
|
||||
icon="el-icon-refresh"
|
||||
@click="onReset"
|
||||
>重置
|
||||
</el-button>
|
||||
<el-button type="primary" icon="el-icon-search" @click="search"
|
||||
>查询
|
||||
</el-button>
|
||||
<el-button type="primary" icon="el-icon-plus" @click="openCreate"
|
||||
>新增
|
||||
</el-button>
|
||||
</el-button-group>
|
||||
</div>
|
||||
<el-divider style="margin: 15px"></el-divider>
|
||||
|
||||
<el-table :data="list" @selection-change="(val)=>{if(isChoose){selectChangFunc(val)}}"
|
||||
@row-click="(row)=>{if(isChoose){$refs.table.toggleRowSelection(row)}}" ref="table"
|
||||
v-loading="loading"
|
||||
click-row-light>
|
||||
<el-table-column type="selection" width="55" v-if="isChoose"></el-table-column>
|
||||
<el-table-column label="序号" width="50" type="index"/>
|
||||
<el-table-column label="项目编码" width="150" prop="code"/>
|
||||
<el-table-column label="项目名称" width="200" prop="name"/>
|
||||
<el-table-column label="项目内容" width="500" prop="content"/>
|
||||
<el-table-column label="创建人" width="120" prop="createUserName"/>
|
||||
<el-table-column label="创建时间" width="140" prop="createTime"/>
|
||||
<el-table-column label="操作" v-if="!isChoose" fixed="right" width="80">
|
||||
<template slot-scope="scope">
|
||||
<el-button type="text"@click="delFunc(scope.row)">删除</el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
<pagination
|
||||
v-show="total>0"
|
||||
:total="total"
|
||||
:page.sync="query.page"
|
||||
:limit.sync="query.limit"
|
||||
@pagination="getList"
|
||||
/>
|
||||
</el-card>
|
||||
|
||||
<el-dialog
|
||||
:visible="createFlag"
|
||||
v-if="createFlag"
|
||||
width="50%"
|
||||
title="创建巡检项目"
|
||||
@close="createFlag = false"
|
||||
>
|
||||
<el-card>
|
||||
<div slot="header" class="clearfix">
|
||||
<div class="fr">
|
||||
<el-button @click="createFlag = false">取消</el-button>
|
||||
<el-button type="primary" @click="saveFunc">保存</el-button>
|
||||
</div>
|
||||
</div>
|
||||
<el-form :model="saveData" ref="saveForm" :rules="formRule" label-width="auto">
|
||||
<el-row>
|
||||
<el-col>
|
||||
<el-form-item label="项目编码" prop="code">
|
||||
<el-input v-model="saveData.code" clearable show-word-limit maxlength="20">
|
||||
<el-button slot="append" @click="genCode">生成</el-button>
|
||||
</el-input>
|
||||
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col>
|
||||
<el-form-item label="项目名称" prop="name">
|
||||
<el-input v-model="saveData.name" clearable show-word-limit maxlength="100"/>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col>
|
||||
<el-form-item label="项目内容" prop="content">
|
||||
<el-input v-model="saveData.content" type="textarea" resize="none"
|
||||
:autosize="{ minRows: 8, maxRows: 8 }" clearable show-word-limit maxlength="500"/>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form>
|
||||
</el-card>
|
||||
</el-dialog>
|
||||
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script src="./js/deviceCheckItemDict.js"/>
|
||||
|
||||
<style scoped>
|
||||
|
||||
/deep/ .el-dialog__body {
|
||||
padding: 0 0 20px 0;
|
||||
}
|
||||
|
||||
</style>
|
@ -0,0 +1,217 @@
|
||||
<template>
|
||||
<div>
|
||||
<el-card>
|
||||
|
||||
<el-form :model="query" v-if="showSearch" label-width="auto">
|
||||
<el-row :gutter="20">
|
||||
<el-col :span="6">
|
||||
<el-form-item label="设备编码">
|
||||
<el-input v-model="query.deviceCode" clearable/>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="6">
|
||||
<el-form-item label="设备名称">
|
||||
<el-input v-model="query.productName" clearable/>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="6">
|
||||
<el-form-item label="设备状态">
|
||||
<el-select v-model="query.status"
|
||||
style="width: 100%"
|
||||
clearable>
|
||||
<el-option
|
||||
v-for="item in deviceStatus"
|
||||
:key="item.key"
|
||||
:label="item.desc"
|
||||
:value="item.key">
|
||||
</el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form>
|
||||
<div class="top-right-btn">
|
||||
<el-button-group>
|
||||
<el-button icon="el-icon-view" type="primary" @click="showSearch = !showSearch">显示/隐藏搜索栏</el-button>
|
||||
<el-button
|
||||
type="primary"
|
||||
icon="el-icon-refresh"
|
||||
@click="onReset"
|
||||
>重置
|
||||
</el-button>
|
||||
<el-button type="primary" icon="el-icon-search" @click="search"
|
||||
>查询
|
||||
</el-button>
|
||||
</el-button-group>
|
||||
</div>
|
||||
<el-divider style="margin: 15px"></el-divider>
|
||||
|
||||
<el-table :data="list" @row-click="rowClick" v-loading="loading" click-row-light>
|
||||
<el-table-column label="序号" width="50" type="index"/>
|
||||
<el-table-column label="科室" width="150" prop="deptName"/>
|
||||
<el-table-column label="最小销售标识" width="150" prop="nameCode"/>
|
||||
<el-table-column label="设备名称" width="150" prop="productName"/>
|
||||
<el-table-column label="规格型号" width="160" prop="ggxh"/>
|
||||
<el-table-column label="状态" width="120" prop="statusName">
|
||||
<template scope="scope">
|
||||
<el-tag :type="deviceStatus[scope.row.status].tagType">{{ scope.row.statusName }}</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="巡检锁定" width="120">
|
||||
<template scope="scope">
|
||||
<el-tag :type="scope.row.checkLock?'primark':'info'">{{ scope.row.checkLock ? '是' : '否'}}</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="数量" width="120" prop="count"/>
|
||||
<el-table-column label="计量单位" width="100" prop="measname"/>
|
||||
<el-table-column label="生产企业" width="180" prop="manufactory"/>
|
||||
<!-- <el-table-column label="批次号" width="100" prop="batchNo"/>-->
|
||||
<!-- <el-table-column label="序列号" width="100" prop="serialNo"/>-->
|
||||
<!-- <el-table-column label="生产日期" width="140" prop="productionDate"/>-->
|
||||
<!-- <el-table-column label="过期时间" width="140" prop="expireDate"/>-->
|
||||
<!-- <el-table-column label="供应商" width="100" prop="supName"/>-->
|
||||
<!-- <el-table-column label="udi码" width="150" prop="udi"/>-->
|
||||
<!-- <el-table-column label="注册/备案号" width="150" prop="zczbhhzbapzbh"/>-->
|
||||
<!-- <el-table-column label="操作" width="120" fixed="right">-->
|
||||
<!-- <template scope="scope">-->
|
||||
|
||||
<!-- <el-button type="text"-->
|
||||
<!-- >详情-->
|
||||
<!-- </el-button>-->
|
||||
<!-- </template>-->
|
||||
<!-- </el-table-column>-->
|
||||
</el-table>
|
||||
<pagination
|
||||
v-show="total>0"
|
||||
:total="total"
|
||||
:page.sync="query.page"
|
||||
:limit.sync="query.limit"
|
||||
@pagination="getList"
|
||||
/>
|
||||
</el-card>
|
||||
|
||||
<el-card>
|
||||
<div slot="header" class="clearfix">
|
||||
<div class="fl">
|
||||
{{
|
||||
`设备详情 ${clickRow ? '——' + clickRow.productName + '(' + clickRow.ggxh + ')' : ''}`
|
||||
}}
|
||||
</div>
|
||||
<div class="fr">
|
||||
<el-button @click="getDetailList">刷新</el-button>
|
||||
</div>
|
||||
</div>
|
||||
<el-form v-if="clickRow" :model="detailQuery" inline label-width="auto">
|
||||
<el-row :gutter="20">
|
||||
<el-col>
|
||||
<el-form-item label="设备编码">
|
||||
<el-input v-model.trim="detailQuery.deviceCode" clearable/>
|
||||
</el-form-item>
|
||||
<el-button type="primary" icon="el-icon-search" @click="getDetailList"
|
||||
>查询
|
||||
</el-button>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form>
|
||||
<el-table :data="detailList" v-loading="detailLoading">
|
||||
<el-table-column label="序号" width="50" type="index"/>
|
||||
<el-table-column label="科室" width="150" prop="deptName"/>
|
||||
<el-table-column label="设备编码" width="150" prop="deviceCode"/>
|
||||
<el-table-column label="最小销售标识" width="150" prop="nameCode"/>
|
||||
<el-table-column label="名称" width="150" prop="productName"/>
|
||||
<el-table-column label="规格型号" width="160" prop="ggxh"/>
|
||||
<el-table-column label="状态" width="120" prop="statusName">
|
||||
<template scope="scope">
|
||||
<el-tag :type="deviceStatus[scope.row.status].tagType">{{ scope.row.statusName }}</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="巡检锁定" width="120">
|
||||
<template scope="scope">
|
||||
<el-tag :type="scope.row.checkLock?'primark':'info'">{{ scope.row.checkLock ? '是' : '否'}}</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="变更次数" width="100" prop="changeCount"/>
|
||||
<el-table-column label="维修次数" width="100" prop="repairCount"/>
|
||||
<el-table-column label="巡检次数" width="100" prop="checkCount"/>
|
||||
<el-table-column label="计量单位" width="100" prop="measname"/>
|
||||
<el-table-column label="生产企业" width="180" prop="manufactory"/>
|
||||
<el-table-column label="批次号" width="100" prop="batchNo"/>
|
||||
<el-table-column label="序列号" width="100" prop="serialNo"/>
|
||||
<el-table-column label="生产日期" width="140" prop="productionDate"/>
|
||||
<el-table-column label="过期时间" width="140" prop="expireDate"/>
|
||||
<el-table-column label="供应商" width="100" prop="supName"/>
|
||||
<el-table-column label="udi码" width="150" prop="udi"/>
|
||||
<el-table-column label="注册/备案号" width="150" prop="zczbhhzbapzbh"/>
|
||||
<el-table-column label="操作" :width="150" fixed="right">
|
||||
<template scope="scope">
|
||||
<el-button type="text" class="mr5" @click="getDeviceLogs(scope.row)"
|
||||
>变更日志
|
||||
</el-button>
|
||||
<el-popover class="mr5"
|
||||
placement="left"
|
||||
trigger="click">
|
||||
<div v-if="scope.row.QR" align="center">
|
||||
<el-image :src="scope.row.QR" style="display: block"/>
|
||||
<el-button style="display: block"
|
||||
@click="downloadBase64Image(scope.row.QR,`${scope.row.deviceCode}——${scope.row.productName}——${scope.row.ggxh}`)">
|
||||
下载
|
||||
</el-button>
|
||||
</div>
|
||||
<el-button slot="reference" type="text" @click="genQR(scope.row)"
|
||||
>设备码
|
||||
</el-button>
|
||||
</el-popover>
|
||||
<el-button v-if="isChoose&&scope.row.status==deviceStatus.NORMAL.key&&scope.row.checkLock==false" type="text"
|
||||
@click="chooseFunc(scope.row)"
|
||||
>选择
|
||||
</el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
<pagination
|
||||
v-show="detailTotal>0"
|
||||
:total="detailTotal"
|
||||
:page.sync="detailQuery.page"
|
||||
:limit.sync="detailQuery.limit"
|
||||
@pagination="getDetailList"
|
||||
/>
|
||||
|
||||
</el-card>
|
||||
|
||||
<el-dialog
|
||||
:title="`设备变更日志——${productRow.productName}(${productRow.deviceCode})`"
|
||||
:visible="true"
|
||||
v-if="showLog"
|
||||
@close="showLog = false"
|
||||
>
|
||||
<el-timeline>
|
||||
<el-timeline-item placement="top"
|
||||
v-for="(item, index) in logList"
|
||||
:key="index"
|
||||
size="large"
|
||||
icon="el-icon-s-promotion"
|
||||
:type="deviceChangeType[item.type].tagType"
|
||||
:timestamp="item.createTime">
|
||||
<el-card style="margin-left: 0px">
|
||||
<div slot="header">
|
||||
<div style="font-size: 24px">
|
||||
{{ item.typeName }}
|
||||
</div>
|
||||
</div>
|
||||
<el-descriptions>
|
||||
<el-descriptions-item label="操作部门">{{ item.deptName }}</el-descriptions-item>
|
||||
<el-descriptions-item label="操作人">{{ item.createUserName }}</el-descriptions-item>
|
||||
<el-descriptions-item label="变更单号">{{ item.changeOrderId }}</el-descriptions-item>
|
||||
<el-descriptions-item label="目标部门">{{ item.toDeptName }}</el-descriptions-item>
|
||||
<el-descriptions-item label="确认人">{{ item.confirmUserName }}</el-descriptions-item>
|
||||
<el-descriptions-item label="确认时间">{{ item.confirmTime }}</el-descriptions-item>
|
||||
</el-descriptions>
|
||||
</el-card>
|
||||
</el-timeline-item>
|
||||
</el-timeline>
|
||||
</el-dialog>
|
||||
</div>
|
||||
|
||||
</template>
|
||||
|
||||
<script src="./js/deviceInfo.js"/>
|
@ -0,0 +1,223 @@
|
||||
<template>
|
||||
<div>
|
||||
<el-card>
|
||||
|
||||
<el-form :model="query" v-if="showSearch" label-width="auto">
|
||||
<el-row :gutter="20">
|
||||
<el-col :span="6">
|
||||
<el-form-item label="所属科室">
|
||||
<deptSelect :value.sync="query.deptCode"/>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="6">
|
||||
<el-form-item label="设备编码">
|
||||
<el-input v-model="query.deviceCode" clearable/>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="6">
|
||||
<el-form-item label="设备名称">
|
||||
<el-input v-model="query.productName" clearable/>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="6">
|
||||
<el-form-item label="设备状态">
|
||||
<el-select v-model="query.status"
|
||||
style="width: 100%"
|
||||
clearable>
|
||||
<el-option
|
||||
v-for="item in deviceStatus"
|
||||
:key="item.key"
|
||||
:label="item.desc"
|
||||
:value="item.key">
|
||||
</el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form>
|
||||
<div class="top-right-btn">
|
||||
<el-button-group>
|
||||
<el-button icon="el-icon-view" type="primary" @click="showSearch = !showSearch">显示/隐藏搜索栏</el-button>
|
||||
<el-button
|
||||
type="primary"
|
||||
icon="el-icon-refresh"
|
||||
@click="onReset"
|
||||
>重置
|
||||
</el-button>
|
||||
<el-button type="primary" icon="el-icon-search" @click="search"
|
||||
>查询
|
||||
</el-button>
|
||||
</el-button-group>
|
||||
</div>
|
||||
<el-divider style="margin: 15px"></el-divider>
|
||||
|
||||
<el-table :data="list" @row-click="rowClick" v-loading="loading" click-row-light>
|
||||
<el-table-column label="序号" width="50" type="index"/>
|
||||
<el-table-column label="科室" width="150" prop="deptName"/>
|
||||
<el-table-column label="最小销售标识" width="150" prop="nameCode"/>
|
||||
<el-table-column label="设备名称" width="150" prop="productName"/>
|
||||
<el-table-column label="规格型号" width="160" prop="ggxh"/>
|
||||
<el-table-column label="状态" width="120" prop="statusName">
|
||||
<template scope="scope">
|
||||
<el-tag :type="deviceStatus[scope.row.status].tagType">{{ scope.row.statusName }}</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="巡检锁定" width="120">
|
||||
<template scope="scope">
|
||||
<el-tag :type="scope.row.checkLock?'primark':'info'">{{ scope.row.checkLock ? '是' : '否' }}</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="数量" width="120" prop="count"/>
|
||||
<el-table-column label="计量单位" width="100" prop="measname"/>
|
||||
<el-table-column label="生产企业" width="180" prop="manufactory"/>
|
||||
<!-- <el-table-column label="批次号" width="100" prop="batchNo"/>-->
|
||||
<!-- <el-table-column label="序列号" width="100" prop="serialNo"/>-->
|
||||
<!-- <el-table-column label="生产日期" width="140" prop="productionDate"/>-->
|
||||
<!-- <el-table-column label="过期时间" width="140" prop="expireDate"/>-->
|
||||
<!-- <el-table-column label="供应商" width="100" prop="supName"/>-->
|
||||
<!-- <el-table-column label="udi码" width="150" prop="udi"/>-->
|
||||
<!-- <el-table-column label="注册/备案号" width="150" prop="zczbhhzbapzbh"/>-->
|
||||
<!-- <el-table-column label="操作" width="120" fixed="right">-->
|
||||
<!-- <template scope="scope">-->
|
||||
|
||||
<!-- <el-button type="text"-->
|
||||
<!-- >详情-->
|
||||
<!-- </el-button>-->
|
||||
<!-- </template>-->
|
||||
<!-- </el-table-column>-->
|
||||
</el-table>
|
||||
<pagination
|
||||
v-show="total>0"
|
||||
:total="total"
|
||||
:page.sync="query.page"
|
||||
:limit.sync="query.limit"
|
||||
@pagination="getList"
|
||||
/>
|
||||
</el-card>
|
||||
|
||||
<el-card>
|
||||
<div slot="header" class="clearfix">
|
||||
<div class="fl">
|
||||
{{
|
||||
`设备详情 ${clickRow ? '——' + clickRow.productName + '(' + clickRow.ggxh + ')' : ''}`
|
||||
}}
|
||||
</div>
|
||||
<div class="fr">
|
||||
<el-button @click="getDetailList">刷新</el-button>
|
||||
</div>
|
||||
</div>
|
||||
<el-form v-if="clickRow" :model="detailQuery" inline label-width="auto">
|
||||
<el-row :gutter="20">
|
||||
<el-col>
|
||||
<el-form-item label="设备编码">
|
||||
<el-input v-model.trim="detailQuery.deviceCode" clearable/>
|
||||
</el-form-item>
|
||||
<el-button type="primary" icon="el-icon-search" @click="getDetailList"
|
||||
>查询
|
||||
</el-button>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form>
|
||||
<el-table :data="detailList" v-loading="detailLoading">
|
||||
<el-table-column label="序号" width="50" type="index"/>
|
||||
<el-table-column label="科室" width="150" prop="deptName"/>
|
||||
<el-table-column label="设备编码" width="150" prop="deviceCode"/>
|
||||
<el-table-column label="最小销售标识" width="150" prop="nameCode"/>
|
||||
<el-table-column label="名称" width="150" prop="productName"/>
|
||||
<el-table-column label="规格型号" width="160" prop="ggxh"/>
|
||||
<el-table-column label="状态" width="120" prop="statusName">
|
||||
<template scope="scope">
|
||||
<el-tag :type="deviceStatus[scope.row.status].tagType">{{ scope.row.statusName }}</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="巡检锁定" width="120">
|
||||
<template scope="scope">
|
||||
<el-tag :type="scope.row.checkLock?'primark':'info'">{{ scope.row.checkLock ? '是' : '否' }}</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="变更次数" width="100" prop="changeCount"/>
|
||||
<el-table-column label="维修次数" width="100" prop="repairCount"/>
|
||||
<el-table-column label="巡检次数" width="100" prop="checkCount"/>
|
||||
<el-table-column label="计量单位" width="100" prop="measname"/>
|
||||
<el-table-column label="生产企业" width="180" prop="manufactory"/>
|
||||
<el-table-column label="批次号" width="100" prop="batchNo"/>
|
||||
<el-table-column label="序列号" width="100" prop="serialNo"/>
|
||||
<el-table-column label="生产日期" width="140" prop="productionDate"/>
|
||||
<el-table-column label="过期时间" width="140" prop="expireDate"/>
|
||||
<el-table-column label="供应商" width="100" prop="supName"/>
|
||||
<el-table-column label="udi码" width="150" prop="udi"/>
|
||||
<el-table-column label="注册/备案号" width="150" prop="zczbhhzbapzbh"/>
|
||||
<el-table-column label="操作" :width="150" fixed="right">
|
||||
<template scope="scope">
|
||||
<el-button class="mr10" type="text" @click="getDeviceLogs(scope.row)"
|
||||
>变更日志
|
||||
</el-button>
|
||||
<el-popover class="mr10"
|
||||
placement="left"
|
||||
width="300"
|
||||
trigger="click">
|
||||
<div v-if="scope.row.QR" align="center">
|
||||
<el-image :src="scope.row.QR" style="display: block"/>
|
||||
<el-button style="display: block"
|
||||
@click="downloadBase64Image(scope.row.QR,`${scope.row.deviceCode}——${scope.row.productName}——${scope.row.ggxh}`)">
|
||||
下载
|
||||
</el-button>
|
||||
</div>
|
||||
<el-button slot="reference" type="text" @click="genQR(scope.row)"
|
||||
>设备码
|
||||
</el-button>
|
||||
</el-popover>
|
||||
<el-button v-if="isChoose&&scope.row.status==deviceStatus.NORMAL.key" type="text"
|
||||
@click="chooseFunc(scope.row)"
|
||||
>选择
|
||||
</el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
<pagination
|
||||
v-show="detailTotal>0"
|
||||
:total="detailTotal"
|
||||
:page.sync="detailQuery.page"
|
||||
:limit.sync="detailQuery.limit"
|
||||
@pagination="getDetailList"
|
||||
/>
|
||||
|
||||
</el-card>
|
||||
|
||||
<el-dialog
|
||||
:title="`设备变更日志——${productRow.productName}(${productRow.deviceCode})`"
|
||||
:visible="true"
|
||||
v-if="showLog"
|
||||
@close="showLog = false"
|
||||
>
|
||||
<el-timeline>
|
||||
<el-timeline-item placement="top"
|
||||
v-for="(item, index) in logList"
|
||||
:key="index"
|
||||
size="large"
|
||||
icon="el-icon-s-promotion"
|
||||
:type="deviceChangeType[item.type].tagType"
|
||||
:timestamp="item.createTime">
|
||||
<el-card style="margin-left: 0px">
|
||||
<div slot="header">
|
||||
<div style="font-size: 24px">
|
||||
{{ item.typeName }}
|
||||
</div>
|
||||
</div>
|
||||
<el-descriptions>
|
||||
<el-descriptions-item label="操作部门">{{ item.deptName }}</el-descriptions-item>
|
||||
<el-descriptions-item label="操作人">{{ item.createUserName }}</el-descriptions-item>
|
||||
<el-descriptions-item label="变更单号">{{ item.changeOrderId }}</el-descriptions-item>
|
||||
<el-descriptions-item label="目标部门">{{ item.toDeptName }}</el-descriptions-item>
|
||||
<el-descriptions-item label="确认人">{{ item.confirmUserName }}</el-descriptions-item>
|
||||
<el-descriptions-item label="确认时间">{{ item.confirmTime }}</el-descriptions-item>
|
||||
</el-descriptions>
|
||||
</el-card>
|
||||
</el-timeline-item>
|
||||
</el-timeline>
|
||||
</el-dialog>
|
||||
</div>
|
||||
|
||||
</template>
|
||||
|
||||
<script src="./js/deviceInfoFull.js"/>
|
@ -0,0 +1,134 @@
|
||||
<template>
|
||||
<div>
|
||||
<el-card>
|
||||
|
||||
<el-form :model="query" v-if="showSearch" label-width="auto">
|
||||
<el-row :gutter="20">
|
||||
<el-col :span="6">
|
||||
<el-form-item label="设备编码">
|
||||
<el-input v-model.trim="query.deviceCode" @keyup.enter.native="search" clearable/>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
<el-col :span="6">
|
||||
<el-form-item label="完成状态">
|
||||
<el-select v-model="query.isFinish" clearable>
|
||||
<el-option label="未完成" value="false">未完成</el-option>
|
||||
<el-option label="已完成" value="true">已完成</el-option>
|
||||
</el-select>
|
||||
</el-form-item>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-form>
|
||||
<div class="top-right-btn">
|
||||
<el-button-group>
|
||||
<el-button icon="el-icon-view" type="primary" @click="showSearch = !showSearch">显示/隐藏搜索栏</el-button>
|
||||
<el-button
|
||||
type="primary"
|
||||
icon="el-icon-refresh"
|
||||
@click="onReset"
|
||||
>重置
|
||||
</el-button>
|
||||
<el-button type="primary" icon="el-icon-search" @click="search"
|
||||
>查询
|
||||
</el-button>
|
||||
<!-- <el-button type="primary" icon="el-icon-plus" @click="openCreate"-->
|
||||
<!-- >新增-->
|
||||
<!-- </el-button>-->
|
||||
</el-button-group>
|
||||
</div>
|
||||
<el-divider style="margin: 15px"></el-divider>
|
||||
|
||||
<el-table :data="list" ref="table"
|
||||
v-loading="loading" highlight-current-row
|
||||
click-row-light>
|
||||
<el-table-column label="序号" width="50" type="index"/>
|
||||
<el-table-column label="维修号" width="150" prop="id"/>
|
||||
<el-table-column label="状态" width="150" prop="statusName">
|
||||
<template scope="scope">
|
||||
<el-tag :type="scope.row.finishFlag?'success':'warning'">{{
|
||||
scope.row.finishFlag ? '已完成' : '未完成'
|
||||
}}
|
||||
</el-tag>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="维修方式" width="150" prop="statusName">
|
||||
<template scope="scope">
|
||||
{{ scope.row.innerFlag ? '内部维修' : '外部维修' }}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="设备编码" width="150" prop="deviceCode"/>
|
||||
<el-table-column label="维修人姓名" width="150" prop="repairUserName"/>
|
||||
<el-table-column label="维修人电话" width="150" prop="repairUserPhone"/>
|
||||
<el-table-column label="最小销售标识" width="150" prop="nameCode"/>
|
||||
<el-table-column label="名称" width="150" prop="productName"/>
|
||||
<el-table-column label="规格型号" width="160" prop="ggxh"/>
|
||||
<el-table-column label="问题描述" width="160" prop="description"/>
|
||||
<el-table-column label="诊断信息" width="160" prop="diagnosisInfo"/>
|
||||
<el-table-column label="计量单位" width="100" prop="measname"/>
|
||||
<el-table-column label="批次号" width="100" prop="batchNo"/>
|
||||
<el-table-column label="序列号" width="100" prop="serialNo"/>
|
||||
<el-table-column label="生产日期" width="140" prop="productionDate"/>
|
||||
<el-table-column label="过期时间" width="140" prop="expireDate"/>
|
||||
<el-table-column label="供应商" width="100" prop="supName"/>
|
||||
<el-table-column label="udi码" width="150" prop="udi"/>
|
||||
<el-table-column label="注册/备案号" width="150" prop="zczbhhzbapzbh"/>
|
||||
<el-table-column label="生产企业" width="180" prop="manufactory"/>
|
||||
<el-table-column label="操作" fixed="right" width="80">
|
||||
<template slot-scope="scope">
|
||||
<el-button type="text" v-if="!scope.row.finishFlag" @click="finishFunc(scope.row)">完成维修</el-button>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
<pagination
|
||||
v-show="total>0"
|
||||
:total="total"
|
||||
:page.sync="query.page"
|
||||
:limit.sync="query.limit"
|
||||
@pagination="getList"
|
||||
/>
|
||||
</el-card>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script src="./js/deviceRepair.js"/>
|
||||
|
||||
<style lang="scss" scoped>
|
||||
|
||||
.grid-container {
|
||||
height: inherit;
|
||||
grid-template-columns: repeat(1, 1fr);
|
||||
display: grid;
|
||||
grid-gap: 10px;
|
||||
|
||||
.el-card {
|
||||
margin: 0;
|
||||
padding-top: 0;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
.grid-item {
|
||||
height: 100%;
|
||||
padding: 15px;
|
||||
|
||||
.el-row, .el-col {
|
||||
height: 100%;
|
||||
}
|
||||
|
||||
.header {
|
||||
color: #676a6c;
|
||||
font-size: 20px;
|
||||
font-weight: bolder;
|
||||
}
|
||||
|
||||
.el-table {
|
||||
margin-top: 10px;
|
||||
width: 100%;
|
||||
}
|
||||
}
|
||||
|
||||
::v-deep .el-dialog__body {
|
||||
padding: 0 0 20px 0;
|
||||
}
|
||||
|
||||
</style>
|
@ -0,0 +1,220 @@
|
||||
import {detailByUserPage, deviceLogs, devicePage} from "@/api/dev/deviceInfoApi";
|
||||
import {deviceChangeStatus, deviceChangeType, deviceStatus} from "@/utils/enum";
|
||||
import {
|
||||
deviceCheckPage,
|
||||
deviceCheckPageByDept,
|
||||
deviceCheckPrint,
|
||||
deviceCheckPrintByDeviceCode
|
||||
} from "@/api/dev/deviceCheckApi";
|
||||
import {deviceCheckDetailPage, deviceCheckDetailRepair} from "@/api/dev/deviceCheckDetailApi";
|
||||
import {deviceCheckDetailItemFinish, deviceCheckDetailItemPage} from "@/api/dev/deviceCheckDetailItemApi";
|
||||
import {copyProperties, getLoading} from "@/utils";
|
||||
|
||||
let query = {
|
||||
page: 1,
|
||||
limit: 10,
|
||||
chargeDeptCode: null,
|
||||
finishFlag: null,
|
||||
}
|
||||
|
||||
let detailQuery = {
|
||||
page: 1,
|
||||
limit: 10,
|
||||
taskId: null,
|
||||
deviceCode:null,
|
||||
}
|
||||
|
||||
let itemQuery = {
|
||||
page: 1,
|
||||
limit: 10,
|
||||
taskId: null,
|
||||
deviceCode: null,
|
||||
}
|
||||
let repairData = {
|
||||
taskId: null,
|
||||
deviceCode: null,
|
||||
description: null,
|
||||
diagnosisInfo: null,
|
||||
innerFlag: true,
|
||||
repairUserName: null,
|
||||
repairUserPhone: null,
|
||||
}
|
||||
|
||||
export default {
|
||||
name: "deptDeviceCheck",
|
||||
computed: {},
|
||||
data() {
|
||||
return {
|
||||
clickRow: null,
|
||||
showSearch: true,
|
||||
loading: false,
|
||||
total: .0,
|
||||
list: [],
|
||||
query: {...query},
|
||||
//设备详情=============================================
|
||||
detailLoading: false,
|
||||
detailQuery: {...detailQuery},
|
||||
detailList: [],
|
||||
detailTotal: 0,
|
||||
showLog: false,
|
||||
//===================================================
|
||||
itemDialogFlag: false,
|
||||
itemQuery: {...itemQuery},
|
||||
itemList: [],
|
||||
itemTotal: 0,
|
||||
itemLoading: false,
|
||||
checkPrintData: null,
|
||||
itemRow: null,
|
||||
itemRules: {
|
||||
normalFlag: [{required: true, message: "请选择异常情况", trigger: ["change", "blur"]}],
|
||||
suggestion: [{required: true, message: "巡检意见不能为空", trigger: ["change", "blur"]}],
|
||||
},
|
||||
repairRow: null,
|
||||
repairRules: {
|
||||
innerFlag: [{
|
||||
required: true,
|
||||
message: "请选择维修方式",
|
||||
trigger: ["change", "blur"]
|
||||
}],
|
||||
repairUserName: [{
|
||||
required: true,
|
||||
message: "维修人姓名不能为空",
|
||||
trigger: ["change", "blur"]
|
||||
}],
|
||||
repairUserPhone: [{
|
||||
required: true,
|
||||
message: "维修人电话不能为空",
|
||||
trigger: ["change", "blur"]
|
||||
}],
|
||||
description: [{required: true, message: "问题描述不能为空", trigger: ["change", "blur"]}],
|
||||
diagnosisInfo: [{required: true, message: "诊断信息不能为空", trigger: ["change", "blur"]}],
|
||||
},
|
||||
repairId:null,
|
||||
}
|
||||
},
|
||||
created() {
|
||||
this.getList()
|
||||
},
|
||||
methods: {
|
||||
commitRepair(){
|
||||
this.$refs.repairForm.validate(b => {
|
||||
if (!b) {
|
||||
return
|
||||
}
|
||||
let load = getLoading(this)
|
||||
deviceCheckDetailRepair(this.repairRow).then(res => {
|
||||
load.close()
|
||||
if (res.code != 20000) {
|
||||
this.$message.error(res.message)
|
||||
return
|
||||
}
|
||||
this.$message.success(res.message)
|
||||
this.getDetailList()
|
||||
this.getList()
|
||||
this.repairRow = null
|
||||
}).catch(() => {
|
||||
load.close()
|
||||
})
|
||||
})
|
||||
},
|
||||
createRepair(row) {
|
||||
let data = copyProperties(row, {...repairData});
|
||||
this.repairRow = _.extend({}, row, data)
|
||||
},
|
||||
commitItemCheck() {
|
||||
this.$refs.itemForm.validate(b => {
|
||||
if (!b) {
|
||||
return
|
||||
}
|
||||
let load = getLoading(this)
|
||||
deviceCheckDetailItemFinish(this.itemRow).then(res => {
|
||||
load.close()
|
||||
if (res.code != 20000) {
|
||||
this.$message.error(res.message)
|
||||
return
|
||||
}
|
||||
this.$message.success(res.message)
|
||||
this.getDetailItemList()
|
||||
this.getDetailList()
|
||||
this.getList()
|
||||
this.itemRow = null
|
||||
}).catch(() => {
|
||||
load.close()
|
||||
})
|
||||
})
|
||||
},
|
||||
openItem(row) {
|
||||
this.itemQuery = {
|
||||
...itemQuery,
|
||||
taskId: row.taskId,
|
||||
deviceCode: row.deviceCode,
|
||||
title: `[${row.deviceCode}]--${row.productName}(${row.nameCode})`
|
||||
}
|
||||
this.itemDialogFlag = true
|
||||
this.getDetailItemList()
|
||||
},
|
||||
getDetailItemList() {
|
||||
this.itemLoading = true
|
||||
deviceCheckDetailItemPage(this.itemQuery).then(res => {
|
||||
this.itemLoading = false
|
||||
if (res.code != 20000) {
|
||||
this.$message.error(res.message)
|
||||
return
|
||||
}
|
||||
this.itemList = res.data.list || []
|
||||
this.itemTotal = res.data.total || 0
|
||||
}).catch(e => {
|
||||
this.itemLoading = false
|
||||
this.itemList = []
|
||||
this.itemTotal = 0
|
||||
})
|
||||
},
|
||||
rowClick(row) {
|
||||
if (this.clickRow && row.taskId == this.clickRow.taskId) {
|
||||
return false
|
||||
}
|
||||
this.clickRow = row
|
||||
this.detailQuery = {...detailQuery, taskId: row.taskId}
|
||||
this.getDetailList()
|
||||
},
|
||||
getDetailList() {
|
||||
this.detailLoading = true
|
||||
deviceCheckDetailPage(this.detailQuery).then(res => {
|
||||
this.detailLoading = false
|
||||
if (res.code != 20000) {
|
||||
this.$message.error(res.message)
|
||||
return
|
||||
}
|
||||
this.detailList = res.data.list || []
|
||||
this.detailTotal = res.data.total || 0
|
||||
}).catch(e => {
|
||||
this.detailLoading = false
|
||||
})
|
||||
},
|
||||
search() {
|
||||
this.query.page = 1
|
||||
this.getList()
|
||||
},
|
||||
onReset() {
|
||||
this.query = {...query}
|
||||
this.getList()
|
||||
},
|
||||
getList() {
|
||||
this.loading = true
|
||||
deviceCheckPageByDept(this.query).then(res => {
|
||||
this.loading = false
|
||||
if (res.code != 20000) {
|
||||
this.$message.error(res.message)
|
||||
return
|
||||
}
|
||||
this.list = res.data.list || []
|
||||
this.total = res.data.total || 0
|
||||
|
||||
}).catch(e => {
|
||||
this.list = []
|
||||
this.total = 0
|
||||
this.loading = false
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue