road-detail-list.vue 7.2 KB
<template>
  <view class="page-container">
    <!-- 顶部吸顶区域 -->
    <up-sticky>
      <view class="sticky-header">
        <!-- 状态Tabs -->
        <up-tabs
            v-model="activeStatus"
            :list="statusTabs"
            line-width="40rpx"
            active-color="#1989fa"
            inactive-color="#666"
            :scrollable="true"
            class="status-tabs"
            @click="handleStatusChange"
        ></up-tabs>

        <!-- 搜索框 -->
        <up-search
            v-model="searchValue"
            :placeholder="searchPlaceholder"
            bg-color="#f5f5f5"
            shape="round"
            :show-action="true"
            actionText="搜索"
            :animation="true"
            @search="handleSearch"
            @custom="handleSearch"
            :clearabled="false"
            maxlength="50"
            class="search-input"
        ></up-search>
      </view>
    </up-sticky>

    <!-- 分页列表区域 -->
    <z-paging
        ref="pagingRef"
        v-model="planList"
        @query="queryList"
        :auto-show-system-loading="true"
    >
      <!-- 空数据插槽 -->
      <template #empty>
        <empty-view/>
      </template>
      <view class="common-card-list" style=" padding-top: 170rpx;">
        <up-card
            :border="false"
            :foot-border-top="false"
            v-for="(item,index) in planList"
            :key="`${item.planNo}_${index}`"
        >
          <!-- 自定义标题区域 -->
          <template #head>
            <view class="card-header">
              <view class="common-card-title  u-line-1">{{ item.planName || '无计划名称' }}</view>
              <!-- 已失效标识 -->
              <up-text type="error" v-if="item.finishState === '3'"  text="错误" class="invalid-tag"></up-text>
<!--              <view v-if="item.finishState === '3'" class="invalid-tag">已失效</view>-->
            </view>
          </template>

          <template #body>
            <view class="card-body">
              <view class="u-body-item u-flex">
                <view class="u-body-item-title">计划编码:</view>
                <view class="u-line-1 u-body-value">{{ item.planNo || '-' }}</view>
              </view>
              <view class="u-body-item u-flex">
                <view class="u-body-item-title">养护周期:</view>
                <view class="u-line-1 u-body-value">{{ item.rate || '-' }}
                  {{ uni.$dict.getDictLabel('cycle_id_type', item.cycleId) }}
                </view>
              </view>

              <view class="u-body-item u-flex common-item-center common-justify-between">
                <view class="u-body-item-title">计划完成次数: {{ item.planNum || 0 }}</view>
                <view class="u-line-1">
                  <up-button
                      type="primary"
                      size="mini"
                      @click="submitRecord(item)"
                      class="submit-record-btn"

                      :disabled="item.finishState === '3'"
                      :class="{ 'disabled-btn': item.finishState === '3' }"
                  >

                    {{ item.finishState === '3' ? '补交记录' : '提交记录' }}
                  </up-button>
                </view>
              </view>

              <view class="u-body-item u-flex">
                <view class="u-body-item-title">已完成比例:</view>
                <view class="u-line-1 u-body-value">{{ item.finishPercent || 0 }}%</view>
              </view>

              <view class="u-body-item u-flex">
                <view class="u-body-item-title">计划有效期:</view>
                <view class="u-line-1 u-body-value">{{ timeFormat(item.beginTime, 'yyyy-mm-dd') || '-' }} 至
                  {{ timeFormat(item.endTime, 'yyyy-mm-dd') || '-' }}
                </view>
              </view>
            </view>
          </template>
        </up-card>
      </view>
    </z-paging>
  </view>
</template>

<script setup>
import { ref } from 'vue'
import { onLoad, onShow } from '@dcloudio/uni-app'
import { timeFormat } from '@/uni_modules/uview-plus'
import { getRoadDetails } from "@/api/maintain-manage/maintain-manage";
// ========== 基础数据定义 ==========
const statusTabs = ref([
  {name: '待完成', id: '1'},
  {name: '已失效', id: '3'},
  {name: '已完成', id: '2'}
])
const activeStatus = ref('1')
const searchValue = ref('')
const planList = ref([])
const pagingRef = ref(null)
const roadId = ref('')
const finishState = ref('')
// 搜索占位符
const searchPlaceholder = ref('请输入计划名称')
// ========== 方法定义 ==========
const getUrlParams = (options) => {
  if (options?.roadId) {
    roadId.value = options.roadId
    console.log('从URL获取的roadId:', roadId.value)
  }
  if (options?.finish_state) {
    finishState.value = options.finish_state
    activeStatus.value = options.finish_state
    console.log('从URL获取的finish_state:', finishState.value)
  }
}
const handleStatusChange = (item) => {
  console.log('切换状态:', item)
  activeStatus.value = item.id
  finishState.value = item.id
  pagingRef.value?.reload()
}
const handleSearch = () => {
  console.log('搜索关键词:', searchValue.value)
  pagingRef.value?.reload()
}
const submitRecord = (item) => {
  // 已失效状态下直接返回,不执行跳转
  if (item.finishState === '3') {
    return
  }
  console.log('提交记录:', item.finishPercent)
  if (item.finishPercent == 0) {
    uni.navigateTo({
      url: `/pages-sub/daily/maintain-manage/add-record?finishState=${item.finishState}&planNo=${item.planNo}&finishPercent=${item.finishPercent}`
    })
  } else {
    uni.navigateTo({
      url: `/pages-sub/daily/maintain-manage/pending-plan-detail?finishState=${item.finishState}&planNo=${item.planNo}&finishPercent=${item.finishPercent}&planTypeId=${item.planTypeId}`
    })
  }
}
const queryList = async (pageNo, pageSize) => {
  try {
    const paramsData = {
      pageNo: pageNo,
      pageSize: pageSize,
      roadId: roadId.value,
      finishState: finishState.value || activeStatus.value,
      planName: searchValue.value.trim()
    }
    console.log('请求参数:', paramsData)
    const res = await getRoadDetails(paramsData)
    console.log(res)
    const listData = res?.list || res || []
    pagingRef.value?.complete(listData)
  } catch (error) {
    console.error('请求失败:', error)
    uni.showToast({title: '加载失败,请重试', icon: 'none'})
    pagingRef.value?.complete(false)
  }
}
// ========== 生命周期 ==========
onLoad((options) => {
  getUrlParams(options)
})
onShow(() => {
  // if (roadId.value) {
  //   pagingRef.value?.reload()
  // }
  pagingRef.value?.reload()
})

</script>

<style scoped lang="scss">
.page-container {
}
// 顶部吸顶区域样式
.sticky-header {
  background-color: #ffffff;
  padding-bottom: 10rpx;
  border-bottom: 1px solid #eee;

  .search-input {
    margin: 20rpx 20rpx 10rpx !important;
  }
}

// 卡片头部样式
.card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

// 禁用按钮样式
.disabled-btn {
  background-color: #c0c4cc !important;
  border-color: #c0c4cc !important;
  color: #fff !important;
  pointer-events: none; // 防止点击
  opacity: 0.7;
}


</style>