diff --git a/src/api/system/deptUser.js b/src/api/system/deptUser.js
index 97112a67..fbd1866b 100644
--- a/src/api/system/deptUser.js
+++ b/src/api/system/deptUser.js
@@ -10,6 +10,15 @@ export function listDeptUser(query) {
})
}
+// 查询部门列表
+export function filterListByDeptCode(query) {
+ return request({
+ url: '/udi/auth/dept/user/list',
+ method: 'get',
+ params: query
+ })
+}
+
export function removeUser(data) {
return axios({
url: "/udi/auth/dept/user/delete",
diff --git a/src/views/components/deptSelect/index.js b/src/views/components/deptSelect/index.js
index d71d0898..7b8c9cba 100644
--- a/src/views/components/deptSelect/index.js
+++ b/src/views/components/deptSelect/index.js
@@ -2,8 +2,9 @@ import {filterList} from "@/api/system/invWarehouse";
export default {
- name: "deptSelect",
- props: {value: {required: true},notCode:null},
+ name: 'deptSelect',
+ props: { value: { required: true }, notCode: null,maintenance: null,
+ },
data() {
return {
val: '',
@@ -24,7 +25,11 @@ export default {
},
methods: {
getList() {
- filterList({enable: true}).then(res => {
+ let data =
+ {enable: true,
+ }
+ if (this.maintenance != null) data.maintenance = true
+ filterList(data).then(res => {
if (res.code == 20000) {
this.list = res.data.list || []
if(this.notCode!=null) {
diff --git a/src/views/dev/deviceInfo.vue b/src/views/dev/deviceInfo.vue
index 0446fac4..7d5561d5 100644
--- a/src/views/dev/deviceInfo.vue
+++ b/src/views/dev/deviceInfo.vue
@@ -2,21 +2,21 @@
-
+
-
+
-
+
-
查询
+ 选入
+
-
-
-
-
-
-
-
-
- {{ scope.row.statusName }}
-
-
-
-
- {{ scope.row.checkLock ? '是' : '否' }}
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
-
-
-
- {{
- `设备详情 ${clickRow ? '——' + clickRow.productName + '(' + clickRow.ggxh + ')' : ''}`
- }}
-
-
- 刷新
-
-
-
-
-
-
-
-
- 查询
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
@@ -161,11 +177,11 @@
>设备码
- 选择
-
+
+
+
+
+
+
+
+
+
+
+
+ 设备号:
+
+ {{ item.deviceCode }}
+
+
+
+
+
+ {{ item.productName }}
+
+
+ {{ item.ggxh }}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/views/dev/deviceRepair.vue b/src/views/dev/deviceRepair.vue
index 333d2ece..6415b831 100644
--- a/src/views/dev/deviceRepair.vue
+++ b/src/views/dev/deviceRepair.vue
@@ -75,7 +75,7 @@
- 完成维修
+ 完成维修
@@ -87,6 +87,57 @@
@pagination="getList"
/>
+
+
+
+
+
+ {{ `设备号:${currentRow.deviceCode}` }}
+
+
+ 完成维修
+
+
+
+ {{ currentRow.id }}
+ {{
+ currentRow.finishFlag ? '已完成' : '未完成'
+ }}
+ {{ currentRow.productName }}
+ {{ currentRow.ggxh }}
+ {{ currentRow.nameCode }}
+ {{ currentRow.zczbhhzbapzbh }}
+ {{ currentRow.manufactory }}
+ {{ currentRow.supName }}
+ {{ currentRow.batchNo }}
+ {{ currentRow.serialNo }}
+ {{ currentRow.udi }}
+ {{ currentRow.productionDate }}
+ {{ currentRow.expireDate }}
+
+ {{ currentRow.innerFlag ? '内部维修' : '外部维修' }}
+
+
+ {{ currentRow.repairUserName }}
+
+
+ {{ currentRow.repairUserPhone }}
+
+
+ {{ currentRow.description }}
+
+
+ {{ currentRow.diagnosisInfo }}
+
+
+
+
diff --git a/src/views/dev/deviceRepairApply.vue b/src/views/dev/deviceRepairApply.vue
index a697186e..ddce12e6 100644
--- a/src/views/dev/deviceRepairApply.vue
+++ b/src/views/dev/deviceRepairApply.vue
@@ -5,15 +5,20 @@
-
-
-
-
+
+
-
-
+
+
+
+
+
+
+
+
+
@@ -145,24 +150,29 @@
-
-
-
- {{ user.locDeptName }}
-
-
-
-
- {{ user.employeeName }}
+
+
+
+
-
+
+
+
+
+
+
+
+
+
+
+
-
+
-
-
+
+
设备号:{{ item.deviceCode }}
-
-
+
- {{ item.productName }}
- {{ item.ggxh }}
-
+ {{ item.productName }}
+ {{ item.ggxh }}
+
diff --git a/src/views/dev/deviceRepairApplyHall.vue b/src/views/dev/deviceRepairApplyHall.vue
index 28cce17a..bf239155 100644
--- a/src/views/dev/deviceRepairApplyHall.vue
+++ b/src/views/dev/deviceRepairApplyHall.vue
@@ -1,11 +1,11 @@
-
-
-
-
-
+
+
+
+
+
@@ -80,7 +80,8 @@
/>
-
+
+
{{ `报修单详情 ${clickRow ? '——' + clickRow.id : ''}` }}
@@ -141,8 +142,8 @@
-
-
+
+
+
+
+
+
+
+
-
+
+
+
+
+
+
diff --git a/src/views/dev/deviceRepairApplyMy.vue b/src/views/dev/deviceRepairApplyMy.vue
new file mode 100644
index 00000000..585507d6
--- /dev/null
+++ b/src/views/dev/deviceRepairApplyMy.vue
@@ -0,0 +1,266 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 显示/隐藏搜索栏
+
+ 重置
+
+ 查询
+
+
+
+
+
+
+
+
+
+
+ {{ scope.row.statusName }}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 受理
+
+
+
+
+
+
+
+
+
+ {{ `报修单详情 ${clickRow ? '——' + clickRow.id : ''}` }}
+
+
+ 刷新
+
+
+
+
+
+
+
+
+
+
+ {{
+ scope.row.statusName
+ }}
+
+
+
+
+
+ {{
+ scope.row.repairFlag==null?"":scope.row.repairFlag ? "维修" : "不维修(报废/销毁)"
+ }}
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 诊断
+
+ 查看维修单
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 设备号:{{ detailData.deviceCode }}
+
+
+ 取消
+ 提交
+
+
+
+
+ {{ detailData.productName }}
+ {{ detailData.ggxh }}
+ {{ detailData.nameCode }}
+ {{ detailData.zczbhhzbapzbh }}
+ {{ detailData.manufactory }}
+ {{ detailData.supName }}
+ {{ detailData.batchNo }}
+ {{ detailData.serialNo }}
+ {{ detailData.udi }}
+ {{ detailData.productionDate }}
+ {{ detailData.expireDate }}
+
+
+ {{ detailData.description }}
+
+
+
+
+ 维修
+ 不维修(报废/销毁)
+
+
+
+
+
+
+ 内部维修
+ 外部维修
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/src/views/dev/js/deviceInfo.js b/src/views/dev/js/deviceInfo.js
index d00f4002..369e584d 100644
--- a/src/views/dev/js/deviceInfo.js
+++ b/src/views/dev/js/deviceInfo.js
@@ -17,6 +17,9 @@ let detailQuery = {
deviceCode: null,
deptCode: null,
productId: null,
+ productName: null,
+ status: deviceStatus.NORMAL.key,
+ checkLock: 0
}
export default {
@@ -51,14 +54,36 @@ export default {
productRow: null,
//===================================================
logList: [],
+ radioCheck : null,
+ currentRow : null,
+ multipleSelection: null,
+ item:null,
}
},
created() {
this.locDeptCode = this.$store.getters.locDeptCode
- this.getList()
+ this.detailQuery.deptCode = this.locDeptCode
+ this.getDetailList()
},
methods: {
downloadBase64Image,
+ tableRowClassName({row}) {
+ if (row.checked) return "warning-row";
+ return "";
+ },
+ push(){
+ if (this.item == null){
+ this.$message.error("请选择一个设备!")
+ return
+ }
+ this.chooseFunc(this.item)
+ },
+ handleChange(val) {
+ this.radioCheck = val.deviceCode;
+ this.currentRow = val;
+ this.item = val;
+ this.multipleSelection = val
+ },
genQR(row) {
genDeviceQR(row.deviceCode).then(res => {
if (res.code != 20000) {
@@ -109,12 +134,14 @@ export default {
})
},
search() {
- this.query.page = 1
- this.getList()
+ this.detailQuery.page = 1
+ this.detailQuery.deptCode = this.locDeptCode
+ this.getDetailList()
},
onReset() {
- this.query = {...query}
- this.getList()
+ this.detailQuery = {...detailQuery}
+ this.detailQuery.deptCode = this.locDeptCode
+ this.getDetailList()
},
getList() {
this.loading = true
diff --git a/src/views/dev/js/deviceRepair.js b/src/views/dev/js/deviceRepair.js
index 4b07a438..2dff21dd 100644
--- a/src/views/dev/js/deviceRepair.js
+++ b/src/views/dev/js/deviceRepair.js
@@ -18,6 +18,8 @@ export default {
return {
showSearch: true,
loading: false,
+ finishFlag: false,
+ currentRow: {},
total: .0,
list: [],
query: {...query},
@@ -29,7 +31,16 @@ export default {
this.getList()
},
methods: {
- finishFunc(row) {
+ finishFuncFlag(row){
+ this.finishFlag = true
+ this.currentRow = row
+ },
+ finishFuncFlagClose(){
+ this.finishFlag = false
+ this.currentRow = {}
+ },
+ finishFunc() {
+ let row = this.currentRow
this.$confirm("确定完成维修吗", "提示", {
confirmButtonText: '完成维修',
cancelButtonText: "取消"
@@ -42,6 +53,7 @@ export default {
return
}
this.getList()
+ this.finishFuncFlagClose()
}).catch(e=>{
loading.close()
})
diff --git a/src/views/dev/js/deviceRepairApply.js b/src/views/dev/js/deviceRepairApply.js
index 0d3ad52b..3a26c8fa 100644
--- a/src/views/dev/js/deviceRepairApply.js
+++ b/src/views/dev/js/deviceRepairApply.js
@@ -46,6 +46,7 @@ export default {
saveData: _.cloneDeep(detailQuery),
user: null,
formRule: {
+ applyDeptCode: [{required: true, message: "报修部门不能为空", trigger: ["change", "blur"]}],
applyUserPhone: [{required: true, message: "报修人联系方式不能为空", trigger: ["change", "blur"]}],
details: [{
required: true,
@@ -96,14 +97,14 @@ export default {
this.saveData.details.splice(i, 1)
},
chooseDevice(row) {
- let data = {...row, description: ""}
- let i = this.saveData.details.findIndex(i => i.deviceCode == data.deviceCode)
+ // let data = {...row, description: ""}
+ let i = this.saveData.details.findIndex(i => i.deviceCode == row.deviceCode)
if (i != -1) {
this.$message.error("该设备已被选入,无法再次选择")
return
}
- this.saveData.details.push(data)
+ this.saveData.details.push(row)
this.chooseDeviceFlag = false
},
validToDetails(rule, value, callback) {
diff --git a/src/views/dev/js/deviceRepairApplyHall.js b/src/views/dev/js/deviceRepairApplyHall.js
index 01ef0051..d4ef91cd 100644
--- a/src/views/dev/js/deviceRepairApplyHall.js
+++ b/src/views/dev/js/deviceRepairApplyHall.js
@@ -7,6 +7,7 @@ import {
import {deviceRepairApplyDetailStatus, deviceRepairApplyStatus} from "@/utils/enum";
import {deviceRepairApplyDetailDiagnosis, deviceRepairApplyDetailPage} from "@/api/dev/deviceRepairApplyDetailApi";
import {deviceRepairInfo} from "@/api/dev/deviceRepairApi";
+import {filterListByDeptCode} from "@/api/system/deptUser";
let query = {
page: 1,
@@ -27,6 +28,7 @@ let diagnosisData = {
deviceCode: null,
repairFlag: true,
innerFlag: true,
+ repairDeptCode: null,
repairUserName: '',
repairUserPhone: '',
diagnosisInfo: '',
@@ -44,11 +46,12 @@ export default {
},
data() {
return {
- tabActive: 2,
+ tabActive: 1,
showSearch: true,
loading: false,
total: 0,
list: [],
+ userlist: [],
query: {...query},
user: null,
chooseDeviceFlag: false,
@@ -72,6 +75,12 @@ export default {
message: "请选择维修方式",
trigger: ["change", "blur"]
}],
+ repairDeptCode: [{
+ required: true,
+ validator: this.repairDeptCodeValid,
+ message: "维修部门不能为空",
+ trigger: ["change", "blur"]
+ }],
repairUserName: [{
required: true,
validator: this.repairUserNameValid,
@@ -88,6 +97,16 @@ export default {
},
//========detailDialog--end===============================
}
+ }
+ ,
+ watch: {
+ 'diagnosisData.repairDeptCode': {
+ handler (newV, oldV) {
+ this.getUerList()
+ },
+ // deep: true,
+ // immediate: true,
+ }
},
created() {
this.user = this.$store.getters.user
@@ -129,6 +148,14 @@ export default {
}
callback()
},
+ repairDeptCodeValid(rule, value, callback) {
+ if (this.diagnosisData?.repairFlag) {
+ if (!this.diagnosisData.repairDeptCode) {
+ callback(new Error("维修部门不能为空"))
+ }
+ }
+ callback()
+ },
innerFlagValid(rule, value, callback) {
if (this.diagnosisData?.repairFlag) {
if (this.diagnosisData.innerFlag == null) {
@@ -235,6 +262,24 @@ export default {
this.total = res.data.total || 0
})
}
+ },
+ getUerList() {
+ if (this.diagnosisData.repairDeptCode != null){
+ let userQuery = {
+ deptCode: this.diagnosisData.repairDeptCode,
+ }
+ filterListByDeptCode(userQuery).then((response) => {
+ // this.loading = false;
+ this.userlist = response.data.list || [];
+ // this.userTotal = response.data.total;
+ })
+ .catch(() => {
+ // this.loading = false;
+ this.userlist = [];
+ // this.userTotal = 0;
+ });
+ }
}
+
}
}
diff --git a/src/views/dev/js/deviceRepairApplyMy.js b/src/views/dev/js/deviceRepairApplyMy.js
new file mode 100644
index 00000000..99c5d8a7
--- /dev/null
+++ b/src/views/dev/js/deviceRepairApplyMy.js
@@ -0,0 +1,285 @@
+import {getLoading, copyProperties} from "@/utils"
+import {
+ deviceRepairApplyHallPage,
+ deviceRepairApplyConfirmByUserPage,
+ confirmDeviceRepairApply
+} from "@/api/dev/deviceRepairApplyApi";
+import {deviceRepairApplyDetailStatus, deviceRepairApplyStatus} from "@/utils/enum";
+import {deviceRepairApplyDetailDiagnosis, deviceRepairApplyDetailPage} from "@/api/dev/deviceRepairApplyDetailApi";
+import {deviceRepairInfo} from "@/api/dev/deviceRepairApi";
+import {filterListByDeptCode} from "@/api/system/deptUser";
+
+let query = {
+ page: 1,
+ limit: 10,
+ applyId: null,
+ status: null,
+ applyDeptCode: null,
+}
+
+let detailQuery = {
+ page: 1,
+ limit: 10,
+ applyId: null,
+}
+
+let diagnosisData = {
+ applyId: null,
+ deviceCode: null,
+ repairFlag: true,
+ innerFlag: true,
+ repairDeptCode: null,
+ repairUserName: '',
+ repairUserPhone: '',
+ diagnosisInfo: '',
+}
+
+export default {
+ name: "deviceRepairApply",
+ computed: {
+ deviceRepairApplyDetailStatus() {
+ return deviceRepairApplyDetailStatus
+ },
+ deviceRepairApplyStatus() {
+ return deviceRepairApplyStatus
+ }
+ },
+ data() {
+ return {
+ tabActive: 2,
+ showSearch: true,
+ loading: false,
+ total: 0,
+ list: [],
+ userlist: [],
+ query: {...query},
+ user: null,
+ chooseDeviceFlag: false,
+ //========detail===============================
+ clickRow: null,
+ detailQuery: _.cloneDeep(detailQuery),
+ detailLoading: false,
+ detailList: [],
+ detailTotal: 0,
+ //========detail--end===============================
+ repairId: null,
+ //========detailDialog===============================
+ detailFlag: false,
+ detailData: null,
+ diagnosisData: _.cloneDeep(diagnosisData),
+ detailRules: {
+ repairFlag: [{required: true, message: "请选择是否维修", trigger: ["change", "blur"]}],
+ innerFlag: [{
+ required: true,
+ validator: this.innerFlagValid,
+ message: "请选择维修方式",
+ trigger: ["change", "blur"]
+ }],
+ repairDeptCode: [{
+ required: true,
+ validator: this.repairDeptCodeValid,
+ message: "维修部门不能为空",
+ trigger: ["change", "blur"]
+ }],
+ repairUserName: [{
+ required: true,
+ validator: this.repairUserNameValid,
+ message: "维修人姓名不能为空",
+ trigger: ["change", "blur"]
+ }],
+ repairUserPhone: [{
+ required: true,
+ validator: this.repairUserPhoneValid,
+ message: "维修人电话不能为空",
+ trigger: ["change", "blur"]
+ }],
+ diagnosisInfo: [{required: true, message: "诊断信息不能为空", trigger: ["change", "blur"]}],
+ },
+ //========detailDialog--end===============================
+ }
+ }
+ ,
+ watch: {
+ 'diagnosisData.repairDeptCode': {
+ handler (newV, oldV) {
+ this.getUerList()
+ },
+ // deep: true,
+ // immediate: true,
+ }
+ },
+ created() {
+ this.user = this.$store.getters.user
+ this.getList()
+ },
+ methods: {
+ repairInfo(row) {
+ this.repairId = row.repairId
+ },
+ commitFunc() {
+ this.$refs.saveForm.validate(b => {
+ if (!b) {
+ return
+ }
+ deviceRepairApplyDetailDiagnosis(this.diagnosisData).then(res => {
+ if (res.code != 20000) {
+ this.$message.error(res.message)
+ return
+ }
+ this.$message.success(res.message)
+ this.detailFlag = false
+ this.getList()
+ })
+ })
+ },
+ repairUserPhoneValid(rule, value, callback) {
+ if (this.diagnosisData?.repairFlag) {
+ if (!this.diagnosisData.repairUserPhone) {
+ callback(new Error("维修人电话不能为空"))
+ }
+ }
+ callback()
+ },
+ repairUserNameValid(rule, value, callback) {
+ if (this.diagnosisData?.repairFlag) {
+ if (!this.diagnosisData.repairUserName) {
+ callback(new Error("维修人姓名不能为空"))
+ }
+ }
+ callback()
+ },
+ repairDeptCodeValid(rule, value, callback) {
+ if (this.diagnosisData?.repairFlag) {
+ if (!this.diagnosisData.repairDeptCode) {
+ callback(new Error("维修部门不能为空"))
+ }
+ }
+ callback()
+ },
+ innerFlagValid(rule, value, callback) {
+ if (this.diagnosisData?.repairFlag) {
+ if (this.diagnosisData.innerFlag == null) {
+ callback(new Error("请选择维修方式"))
+ }
+ }
+ callback()
+ },
+ openDiagnosisDialog(row) {
+ this.detailFlag = true
+ this.detailData = _.cloneDeep(row)
+ this.diagnosisData = _.cloneDeep({...diagnosisData, applyId: row.applyId, deviceCode: row.deviceCode})
+ },
+ confirm(row) {
+ this.$prompt("请输入受理人电话", "提示", {
+ closeOnClickModal: false,
+ confirmButtonText: '确定',
+ cancelButtonText: '取消',
+ inputType: String,
+ inputPlaceholder: '请输入受理人电话',
+ }).then(({value}) => {
+ let data = {
+ applyId: row.id,
+ confirmUserPhone: value
+ }
+ confirmDeviceRepairApply(data).then(res => {
+ if (res.code != 20000) {
+ this.$message.error(res.message)
+ return
+ }
+ this.$message.success(res.message)
+ this.getList()
+ })
+ })
+ },
+ tabClick(v, ov) {
+ if (v == ov) {
+ return
+ }
+ this.tabActive = v
+ this.query = _.cloneDeep(query)
+ this.getList()
+ },
+ rowClick(row) {
+ this.clickRow = row
+ this.detailQuery = _.cloneDeep({...detailQuery, applyId: row.id})
+ this.getDetailList()
+ },
+ getDetailList() {
+ this.detailLoading = true
+ deviceRepairApplyDetailPage(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
+ this.clickRow = null
+ this.detailList = []
+ this.detailTotal = 0
+ if (this.tabActive == 1) {
+ deviceRepairApplyHallPage(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.loading = false
+ this.list = res.data.list || []
+ this.total = res.data.total || 0
+ })
+ } else {
+ deviceRepairApplyConfirmByUserPage(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.loading = false
+ this.list = res.data.list || []
+ this.total = res.data.total || 0
+ })
+ }
+ },
+ getUerList() {
+ if (this.diagnosisData.repairDeptCode != null){
+ let userQuery = {
+ deptCode: this.diagnosisData.repairDeptCode,
+ }
+ filterListByDeptCode(userQuery).then((response) => {
+ // this.loading = false;
+ this.userlist = response.data.list || [];
+ // this.userTotal = response.data.total;
+ })
+ .catch(() => {
+ // this.loading = false;
+ this.userlist = [];
+ // this.userTotal = 0;
+ });
+ }
+ }
+
+ }
+}
diff --git a/src/views/system/dept/authDept.vue b/src/views/system/dept/authDept.vue
index c5076ed1..f664cf80 100644
--- a/src/views/system/dept/authDept.vue
+++ b/src/views/system/dept/authDept.vue
@@ -80,6 +80,13 @@
+
+
+ {{ scope.row.maintenance | maintenanceFilterName }}
+
+
+
@@ -158,6 +165,17 @@
否
+
+
+
+ 是
+ 否
+
+
{