153 lines
3.3 KiB
Vue
153 lines
3.3 KiB
Vue
<template>
|
||
<view class="bz-list">
|
||
<!-- 使用 BasicListLayout 包裹记录列表 -->
|
||
<BasicListLayout @register="register" :fixed="false" class="flex-1">
|
||
<template #default="{ data }">
|
||
<view class="bz-card" @click="goToBz(data)">
|
||
<view class="card-header">
|
||
<view class="card-title">{{ data.bzMc }}</view>
|
||
</view>
|
||
<view class="divider"></view>
|
||
<view class="card-content">
|
||
<view class="info-row">
|
||
<text class="info-label">年级:</text>
|
||
<text class="info-value">{{ data.njmc }}</text>
|
||
</view>
|
||
<view class="info-row">
|
||
<text class="info-label">说明:</text>
|
||
<text class="info-value">{{ data.bzSm }}</text>
|
||
</view>
|
||
</view>
|
||
<view class="card-footer">
|
||
<text class="view-detail">前往点名 →</text>
|
||
</view>
|
||
</view>
|
||
</template>
|
||
</BasicListLayout>
|
||
</view>
|
||
</template>
|
||
|
||
<script setup lang="ts">
|
||
import { useLayout } from "@/components/BasicListLayout/hooks/useLayout";
|
||
import { jcBzFindPageApi } from "@/api/base/jcApi";
|
||
import { useDataStore } from "@/store/modules/data";
|
||
const { setJcBz } = useDataStore();
|
||
|
||
// 响应式数据
|
||
const loading = ref(false);
|
||
const bzList = ref<any>([]);
|
||
const total = ref<any>(0);
|
||
|
||
// 使用 BasicListLayout
|
||
const [register, { reload, setParam }] = useLayout({
|
||
api: async (params: any) => {
|
||
try {
|
||
const res = await jcBzFindPageApi(params);
|
||
console.log("API返回数据:", res); // 调试日志
|
||
|
||
// 确保数据正确赋值
|
||
if (res && res.rows) {
|
||
bzList.value = res.rows;
|
||
total.value = res.records || res.total || 0;
|
||
} else {
|
||
bzList.value = [];
|
||
total.value = 0;
|
||
}
|
||
return res;
|
||
} catch (error) {
|
||
console.error("获取数据失败:", error);
|
||
bzList.value = [];
|
||
total.value = 0;
|
||
return { rows: [], total: 0 };
|
||
}
|
||
},
|
||
componentProps: {
|
||
auto: false,
|
||
},
|
||
});
|
||
|
||
const goToBz = (bz: any) => {
|
||
setJcBz(bz);
|
||
uni.navigateTo({ url: "/pages/view/routine/jc/index"});
|
||
};
|
||
|
||
// 生命周期
|
||
onMounted(() => {
|
||
// 不自动加载数据,等待用户搜索
|
||
reload();
|
||
});
|
||
</script>
|
||
|
||
<style lang="scss" scoped>
|
||
.bz-list {
|
||
min-height: 100vh;
|
||
background-color: #f5f5f5;
|
||
display: flex;
|
||
flex-direction: column;
|
||
}
|
||
|
||
.bz-card {
|
||
border: 1px solid #f0f0f0;
|
||
border-radius: 16rpx;
|
||
padding: 24rpx;
|
||
margin-bottom: 20rpx;
|
||
background-color: #fff;
|
||
box-shadow: 0 2rpx 12rpx rgba(0, 0, 0, 0.08);
|
||
transition: all 0.3s ease;
|
||
|
||
.card-header {
|
||
font-size: 16px;
|
||
font-weight: bold;
|
||
color: #333;
|
||
margin-bottom: 10px;
|
||
|
||
.card-title {
|
||
font-size: 16px;
|
||
font-weight: bold;
|
||
color: #333;
|
||
}
|
||
}
|
||
|
||
.divider {
|
||
height: 1px;
|
||
background-color: #eee;
|
||
margin-bottom: 15px;
|
||
}
|
||
|
||
.card-content {
|
||
margin-bottom: 20rpx;
|
||
padding-bottom: 16rpx;
|
||
border-bottom: 1px solid #f0f0f0;
|
||
}
|
||
|
||
.info-row {
|
||
display: flex;
|
||
align-items: center;
|
||
margin-bottom: 16rpx;
|
||
|
||
&:last-child {
|
||
margin-bottom: 0;
|
||
}
|
||
}
|
||
|
||
.info-label {
|
||
font-size: 28rpx;
|
||
color: #666;
|
||
font-weight: normal;
|
||
flex: 0 0 160rpx;
|
||
}
|
||
|
||
.info-value {
|
||
font-size: 28rpx;
|
||
color: #333;
|
||
font-weight: bold;
|
||
flex: 1;
|
||
}
|
||
|
||
.card-footer {
|
||
text-align: right;
|
||
}
|
||
|
||
}
|
||
</style>
|