From 453f63fd6cd6466222304df619e62b3a5667ca68 Mon Sep 17 00:00:00 2001
From: zhuguifei <zhuguifei@zhuguifeideiMac.local>
Date: 星期二, 05 八月 2025 13:56:47 +0800
Subject: [PATCH] 修复0730测试问题
---
eims-ui-mobile/src/pages/maint/maint-st.vue | 101 ++++++++++++++++++++++++++++++++++++++++++++------
1 files changed, 89 insertions(+), 12 deletions(-)
diff --git a/eims-ui-mobile/src/pages/maint/maint-st.vue b/eims-ui-mobile/src/pages/maint/maint-st.vue
index 836d79d..85851df 100644
--- a/eims-ui-mobile/src/pages/maint/maint-st.vue
+++ b/eims-ui-mobile/src/pages/maint/maint-st.vue
@@ -11,6 +11,12 @@
<template>
<z-paging ref="paging" v-model="dataList" @query="queryList" show-refresher-update-time>
<template #top>
+ <!-- 澧炲姞涓�涓悳绱㈡爮 -->
+ <wd-search v-model="searchValue" @search="handleSearch">
+ <template #right-icon>
+ <wd-icon name="scan" size="34rpx"></wd-icon>
+ </template>
+ </wd-search>
<wd-tabs v-model="activeTab" @change="handleTabChange">
<wd-tab title="寰呬繚鍏�"></wd-tab>
<wd-tab title="寰呯‘璁�"></wd-tab>
@@ -47,9 +53,15 @@
<view class="text-color-gray text-sm mt-1 flex">
<text class="mr-3">鎬绘暟: {{ item.orderCount }}</text>
|
- <text class="mx-3">宸插畬鎴�: {{ item.dyzCount }}</text>
- |
- <text class="mx-3">寰呬繚鍏�: {{ item.dbyCount }}</text>
+ <template v-if="activeTab === 0">
+ <text class="mx-3">寰呬繚鍏�: {{ item.dbyCount }}</text>
+ |
+ </template>
+ <template v-else>
+ <text class="mx-3">寰呴獙璇�: {{ item.dyzCount }}</text>
+ |
+ </template>
+ <text class="mx-3">宸插畬鎴�: {{ item.wcCount }}</text>
</view>
<!-- <view class="text-color-gray text-sm mt-2 flex">-->
<!-- <text class="mr-3">寰呬繚鍏�: {{ item.dbyCount }}</text>-->
@@ -61,12 +73,12 @@
<view class="text-color-gray text-sm mt-2 flex">
<text>鐘舵�侊細</text>
<template v-if="item.status === '1'">
- <wd-icon class="icon-color-success" name="check-outline" size="34rpx"></wd-icon>
- <text class="ml-1">宸插畬鎴�</text>
+ <wd-icon class="icon-color-warning" name="check-outline" size="34rpx"></wd-icon>
+ <text class="ml-1">寰呯‘璁�</text>
</template>
<template v-else-if="item.status === '2'">
- <wd-icon class="icon-color-warning" name="check-outline" size="34rpx"></wd-icon>
- <text class="ml-1">宸茬‘璁�</text>
+ <wd-icon class="icon-color-success" name="check-outline" size="34rpx"></wd-icon>
+ <text class="ml-1">宸插畬鎴�</text>
</template>
<template v-else>
<wd-icon class="icon-color-base" name="detection" size="40rpx"></wd-icon>
@@ -79,6 +91,17 @@
</view>
</wd-card>
</view>
+
+ <wd-fab
+ v-if="status === '1' && isLeader()"
+ :draggable="true"
+ type="success"
+ position="left-bottom"
+ :expandable="false"
+ inactiveIcon="check"
+ @click="handleBatchComplete"
+ direction="top"
+ />
</z-paging>
</template>
@@ -86,7 +109,12 @@
import { ref, computed } from 'vue'
import { getMaintStList } from '@/service/maint'
import dayjs from 'dayjs'
+import { updateMaintSt } from '@/service/maint'
+import { useUserStore } from "@/store";
+import { isLeader } from '@/utils/RoleUtils'
+import { useToast } from 'wot-design-uni'
+const searchValue = ref<string>('')
/**
* 鍏朵粬椤甸潰浼犺繃鏉ョ殑鏁版嵁
* assetNo: 璧勪骇缂栧彿
@@ -112,13 +140,21 @@
const now = dayjs()
const planDate = dayjs(planTime)
- const diffDays = planDate.diff(now, 'day')
+
+ // 鑾峰彇璁″垝鏃ユ湡鎵�鍦ㄦ湀浠界殑鏈�鍚庝竴澶�
+ const planMonthEnd = planDate.endOf('month')
+
+ // 璁$畻褰撳墠鏃ユ湡涓庤鍒掓湀鏈堝簳鐨勫樊鍊硷紙澶╂暟锛�
+ const diffDays = planMonthEnd.diff(now, 'day')
if (diffDays < 0) {
- // 瓒呰繃璁″垝鏃堕棿锛岀孩鑹茶儗鏅�
+ // 宸茬粡杩囦簡璁″垝鏈堢殑鏈堝簳锛岀孩鑹茶儗鏅�
return 'card-overdue'
} else if (diffDays <= 3) {
- // 璺濈璁″垝鏃堕棿涓夊ぉ浠ュ唴锛岄粍鑹茶儗鏅�
+ // 璺濈璁″垝鏈堟湀搴�3澶╀互鍐咃紝绾㈣壊鑳屾櫙
+ return 'card-overdue'
+ } else if (diffDays <= 10) {
+ // 璺濈璁″垝鏈堟湀搴�10澶╀互鍐咃紝榛勮壊鑳屾櫙
return 'card-urgent'
} else {
// 姝e父鐘舵�侊紝鑳屾櫙棰滆壊涓嶅彉
@@ -191,6 +227,7 @@
pageSize,
equName: equName.value,
status: status.value,
+ params: {},
}
if (filterDate.value === '1') {
// 鑾峰彇褰撳墠鏃ユ湡
@@ -200,7 +237,7 @@
endPlanTime: now.endOf('month').format('YYYY-MM-DD 23:59:59'),
}
} else {
- delete queryParams.params
+ queryParams.params = {}
}
if (equName.value === '-1') {
@@ -213,7 +250,7 @@
if (option?.from === 'scan') {
queryParams.assetNo = option.assetNo
}
-
+ queryParams.params.searchValue = searchValue.value
getMaintStList(queryParams)
.then((res: any) => {
// 璇峰嬁鍦ㄧ綉缁滆姹傚洖璋冧腑缁檇ataList璧嬪�硷紒锛佸彧闇�瑕佽皟鐢╟omplete灏卞彲浠ヤ簡
@@ -233,10 +270,50 @@
})
}
+function handleSearch () {
+ console.log('handleSearch')
+ paging.value.reload()
+}
+
function reloadData() {
paging.value.reload()
}
+const userStore = useUserStore()
+const toast = useToast()
+
+async function handleBatchComplete() {
+ console.log('handleBatchComplete', dataList.value.length)
+ if (!isLeader()) {
+ toast.info('鏃犳潈闄愭搷浣�')
+ return
+ }
+ // 濡傛灉寰呯‘璁ゅ伐鍗曞垪琛ㄤ负绌猴紝鍒欐彁绀虹敤鎴锋棤寰呯‘璁ゅ伐鍗�
+ if (dataList.value.length < 1) {
+ toast.info('鏃犲緟纭宸ュ崟')
+ return
+ }
+ const now = new Date()
+ const verifyTime = `${now.getFullYear()}-${String(now.getMonth() + 1).padStart(2, '0')}-${String(now.getDate()).padStart(2, '0')} ${String(now.getHours()).padStart(2, '0')}:${String(now.getMinutes()).padStart(2, '0')}:${String(now.getSeconds()).padStart(2, '0')}`
+
+ // 鍋囪 dataList 鏄綋鍓嶅緟纭鐨勫伐鍗曞垪琛�
+ const promises = dataList.value.map(item => {
+ return updateMaintSt({
+ id: item.id,
+ status: '2',
+ verifyUser: userStore?.userInfo?.userId,
+ verifyTime
+ })
+ })
+
+ try {
+ await Promise.all(promises)
+ toast.success('涓�閿‘璁ゅ畬鎴�')
+ reloadData() // 鍒锋柊鍒楄〃
+ } catch (e) {
+ toast.error('閮ㄥ垎宸ュ崟纭澶辫触锛岃閲嶈瘯')
+ }
+}
onLoad((options) => {
Object.assign(option, options)
--
Gitblit v1.9.3