帮扶页面

This commit is contained in:
2025-11-06 15:15:17 +08:00
parent 312a8fcfeb
commit a19458c12d
12 changed files with 1528 additions and 1019 deletions

View File

@@ -1,497 +1,500 @@
<template> <template>
<view class="help-filter-page"> <AppLayout :title="title" :show-bg-image="false" @onScrollBottom="getDataList('add')">
<view class="header"> <!-- <template #headerleft>
<view class="back-btn" @click="goBack"> <view class="btnback">
<uni-icons type="arrowleft" size="24" color="#fff" /> <image src="@/static/icon/back.png" @click="navBack"></image>
</view>
</template> -->
<view class="main-list" :style="getBackgroundStyle('k.png')">
<view class="list-top">
<view class="list-title">
<text>筛选条件</text>
<view class="title-line"></view>
</view>
<view class="title-right button-sp-area">
<button class="mini-btn search-box-btn" type="primary" size="mini" @click="handleSearch">查询</button>
<button class="mini-btn reset-box-btn" type="default" size="mini">重置</button>
</view> </view>
<view class="title">筛选和帮扶</view>
</view> </view>
<!-- 筛选条件区域 --> <view class="search-container">
<view class="filter-section"> <!-- 人员姓名 -->
<view class="filter-item"> <view class="search-item">
<view class="filter-label">人员姓名</view> <text class="label">人员姓名</text>
<input class="filter-input" v-model="filters.personName" placeholder="请输入人员姓名" /> <input
v-model="formData.name"
class="input"
type="text"
placeholder="请输入人员姓名"
/>
</view> </view>
<view class="filter-item"> <!-- 身份证号 -->
<view class="filter-label">身份证号</view> <view class="search-item">
<input class="filter-input" v-model="filters.idCard" placeholder="请输入身份证号" /> <text class="label">身份证号</text>
<input
v-model="formData.idCard"
class="input"
type="text"
placeholder="请输入身份证号"
/>
</view> </view>
<view class="filter-item"> <!-- 帮扶类型下拉选择 -->
<view class="filter-label">帮扶类型</view> <view class="search-item">
<picker class="filter-picker" mode="selector" range="{{helpTypes}}" bindchange="onHelpTypeChange"> <text class="label">帮扶类型</text>
<view class="picker-text">{{filters.helpType || '请选择帮扶类型'}}</view> <picker
mode="selector"
:range="helpTypes"
:value="helpTypeIndex"
@change="onHelpTypeChange"
class="picker"
>
<view class="picker-value">{{ helpTypes[helpTypeIndex] || '请选择帮扶类型' }}</view>
</picker> </picker>
</view> </view>
<view class="filter-item"> <!-- 帮扶人员 -->
<view class="filter-label">帮扶人员</view> <view class="search-item">
<input class="filter-input" v-model="filters.helperName" placeholder="请输入帮扶人员姓名" /> <text class="label">帮扶人员</text>
<input
v-model="formData.helperName"
class="input"
type="text"
placeholder="请输入帮扶人员姓名"
/>
</view> </view>
<view class="filter-item"> <!-- 所属区域下拉选择 -->
<view class="filter-label">所属区域</view> <view class="search-item">
<picker class="filter-picker" mode="selector" range="{{regions}}" bindchange="onRegionChange"> <text class="label">所属区域</text>
<view class="picker-text">{{filters.region || '请选择所属区域'}}</view> <picker
mode="selector"
:range="regions"
:value="regionIndex"
@change="onRegionChange"
class="picker"
>
<view class="picker-value">{{ regions[regionIndex] || '请选择所属区域' }}</view>
</picker> </picker>
</view> </view>
<view class="date-range"> <!-- 开始时间 -->
<view class="filter-label">帮扶时间</view> <view class="search-item">
<view class="date-inputs"> <text class="label">开始时间</text>
<input class="date-input" v-model="filters.startDate" type="date" placeholder="开始日期" /> <picker
<view class="date-separator"></view> mode="date"
<input class="date-input" v-model="filters.endDate" type="date" placeholder="结束日期" /> :value="formData.startTime"
</view> @change="onStartTimeChange"
class="picker"
>
<view class="picker-value">{{ formData.startTime || '请选择开始时间' }}</view>
</picker>
</view> </view>
<view class="filter-buttons"> <!-- 结束时间 -->
<button class="query-btn" type="primary" @click="queryData">查询</button> <view class="search-item">
<button class="reset-btn" @click="resetFilters">重置</button> <text class="label">结束时间</text>
<picker
mode="date"
:value="formData.endTime"
@change="onEndTimeChange"
class="picker"
>
<view class="picker-value">{{ formData.endTime || '请选择结束时间' }}</view>
</picker>
</view> </view>
</view> </view>
<!-- <empty v-else pdTop="200"></empty> -->
<!-- 帮扶记录列表 -->
<view class="list-section">
<view class="list-header">
<view class="list-title">帮扶记录列表</view>
<view class="list-count">{{helpRecords.length}}条记录</view>
</view> </view>
<view class="main-list" :style="getBackgroundStyle('k.png')">
<view class="records-list"> <view class="list-top">
<view class="record-item" v-for="record in helpRecords" :key="record.id"> <view class="list-title">
<view class="record-header"> <text>帮扶记录列表</text>
<view class="person-name">{{record.personName}}</view> <view class="title-line"></view>
<view class="job-tag" @click="showJobRecommend(record)">{{record.jobTag}}</view>
</view> </view>
<view class="title-total">
<view class="record-info"> <text class="total-num">7</text>条记录
<view class="info-row">
<uni-icons type="call" size="14" color="#999" />
<span class="info-label">联系电话</span>
<span class="info-value">{{record.phone}}</span>
</view>
<view class="info-row">
<uni-icons type="card" size="14" color="#999" />
<span class="info-label">身份证号</span>
<span class="info-value">{{record.idCard}}</span>
</view>
<view class="info-row">
<uni-icons type="location" size="14" color="#999" />
<span class="info-label">所属区域</span>
<span class="info-value">{{record.region}}</span>
</view>
<view class="info-row">
<uni-icons type="person" size="14" color="#999" />
<span class="info-label">帮扶人员</span>
<span class="info-value">{{record.helperName}}</span>
</view>
<view class="info-row">
<uni-icons type="briefcase" size="14" color="#999" />
<span class="info-label">帮扶单位</span>
<span class="info-value">{{record.helperUnit}}</span>
</view>
<view class="info-row">
<uni-icons type="calendar" size="14" color="#999" />
<span class="info-label">帮扶日期</span>
<span class="info-value">{{record.helpDate}}</span>
</view>
<view class="info-row">
<uni-icons type="time" size="14" color="#999" />
<span class="info-label">下次联系</span>
<span class="info-value">{{record.nextContactDate}}</span>
</view> </view>
</view> </view>
<!-- v-if="dataList.length>0" -->
<view class="record-actions"> <view class="list-box" >
<button class="detail-btn" @click="showDetail(record)">详情</button> <view class="con-box" v-for="(item,index) in dataList" :key="index">
<button class="follow-btn" @click="followUp(record)">跟进</button> <view class="form-title">
<button class="recommend-btn" @click="showJobRecommend(record)">智能推荐</button> <view class="form-name">
</view> {{item.name}}
</view>
<view class="form-type">
{{item.type}}
</view>
</view>
<view class="form-item">
<view class="item-left">
<image class="item-img" :src="baseUrl+'/dispatch/tele.png'" mode=""></image>
<view class="item-label">
联系电话
</view>
</view>
<view class="item-right">
{{item.phone}}
</view>
</view>
<view class="form-item">
<view class="item-left">
<image class="item-img" :src="baseUrl+'/dispatch/num.png'" mode=""></image>
<view class="item-label">
身份证号
</view>
</view>
<view class="item-right">
{{item.idCard}}
</view>
</view>
<view class="form-item">
<view class="item-left">
<image class="item-img" :src="baseUrl+'/dispatch/base.png'" mode=""></image>
<view class="item-label">
所属区域
</view>
</view>
<view class="item-right">
{{item.region}}
</view>
</view>
<view class="form-item">
<view class="item-left">
<image class="item-img" :src="baseUrl+'/dispatch/person.png'" mode=""></image>
<view class="item-label">
帮扶人员
</view>
</view>
<view class="item-right">
{{item.helperName}}
</view>
</view>
<view class="form-item">
<view class="item-left">
<image class="item-img" :src="baseUrl+'/dispatch/help.png'" mode=""></image>
<view class="item-label">
帮扶单位
</view>
</view>
<view class="item-right">
{{item.unit}}
</view>
</view>
<view class="form-item">
<view class="item-left">
<image class="item-img" :src="baseUrl+'/dispatch/date.png'" mode=""></image>
<view class="item-label">
帮扶日期
</view>
</view>
<view class="item-right">
{{item.assistanceDate}}
</view>
</view>
<view class="form-item">
<view class="item-left">
<image class="item-img" :src="baseUrl+'/dispatch/next.png'" mode=""></image>
<view class="item-label">
下次联系
</view>
</view>
<view class="item-right">
{{item.nextContact}}
</view>
</view>
<view class="form-btns">
<button class="mini-btn form-box-btn detail-btn" size="mini" >详情</button>
<button class="mini-btn form-box-btn follow-btn" size="mini" @click="goFollow(item)">跟进</button>
<button class="mini-btn form-box-btn recommend-btn" size="mini" >智能推荐</button>
</view> </view>
</view> </view>
</view> </view>
<!-- <empty v-else pdTop="200"></empty> -->
</view> </view>
</AppLayout>
</template> </template>
<script> <script setup>
import { ref, reactive, onMounted } from 'vue' import { inject, ref, reactive } from 'vue';
import { useRouter } from 'uni-app' import { onLoad } from '@dcloudio/uni-app';
const { $api, navTo, navBack } = inject('globalFunction');
import config from "@/config.js"
export default { // state
name: 'HelpFilter', const title = ref('');
setup() { const formData = reactive({
const router = useRouter() name: '',
// 筛选条件
const filters = reactive({
personName: '',
idCard: '', idCard: '',
helpType: '',
helperName: '', helperName: '',
region: '', startTime: '',
startDate: '', endTime: ''
endDate: ''
}) })
const searchKeyword = ref('');
const dataList=ref([])
const pageSize=ref(10)
const pageNum=ref(1)
const totalNum=ref(0)
const baseUrl = config.imgBaseUrl
const getBackgroundStyle = (imageName) => ({
backgroundImage: `url(${baseUrl}/dispatch/${imageName})`,
backgroundSize: 'cover', // 覆盖整个容器
backgroundPosition: 'center', // 居中
backgroundRepeat: 'no-repeat'
});
const trainVideoImgUrl=config.trainVideoImgUrl
// 帮扶类型选项 // 帮扶类型选项
const helpTypes = ref(['就业帮扶', '技能培训', '创业支持', '政策咨询']) const helpTypes = ['经济帮扶', '教育帮扶', '医疗帮扶', '就业帮扶']
const helpTypeIndex = ref(0)
// 区域选项 // 所属区域选项(可根据实际替换为动态数据)
const regions = ref(['喀什地区/疏勒县', '喀什地区/疏附县', '喀什地区/伽师县', '喀什地区/岳普湖县']) const regions = ['北京市', '上海市', '广州市', '深圳市', '杭州市']
const regionIndex = ref(0)
// 帮扶记录数据 // 事件处理
const helpRecords = ref([
{
id: 1,
personName: '王小明',
jobTag: '招聘岗位推荐',
phone: '13912345678',
idCard: '371302198801112024',
region: '喀什地区/疏勒县',
helperName: '新兴社区管理员',
helperUnit: '新兴社区',
helpDate: '2023-11-05',
nextContactDate: '2023-11-06'
},
{
id: 2,
personName: '赵小美',
jobTag: '招聘岗位推荐',
phone: '15912345678',
idCard: '371302198801112024',
region: '喀什地区/疏勒县',
helperName: '新兴社区管理员',
helperUnit: '新兴社区',
helpDate: '2023-11-05',
nextContactDate: '2023-11-06'
},
{
id: 3,
personName: '赵小美',
jobTag: '招聘岗位推荐',
phone: '15912345678',
idCard: '371302198801112024',
region: '喀什地区/疏勒县',
helperName: '新兴社区管理员',
helperUnit: '新兴社区',
helpDate: '2023-11-05',
nextContactDate: '2023-11-06'
}
])
// 返回上一页
const goBack = () => {
router.back()
}
// 重置筛选条件
const resetFilters = () => {
Object.keys(filters).forEach(key => {
filters[key] = ''
})
}
// 查询数据
const queryData = () => {
// 这里是模拟查询实际项目中应该调用API
console.log('查询条件:', filters)
// 实际开发中这里应该调用接口获取数据
// fetchHelpRecords(filters)
}
// 显示详情
const showDetail = (record) => {
console.log('查看详情:', record)
// 跳转到详情页面
// router.push({ path: '/detail', query: { id: record.id } })
}
// 跟进
const followUp = (record) => {
console.log('跟进记录:', record)
// 跳转到跟进页面
router.push({ path: '/packageB/priority/helpFollow', query: { personId: record.id, personName: record.personName } })
}
// 智能推荐
const showJobRecommend = (record) => {
console.log('智能推荐:', record)
// 跳转到推荐页面
// router.push({ path: '/recommend', query: { id: record.id } })
}
// 帮扶类型选择变化
const onHelpTypeChange = (e) => { const onHelpTypeChange = (e) => {
filters.helpType = helpTypes.value[e.detail.value] helpTypeIndex.value = e.detail.value
} }
// 区域选择变化
const onRegionChange = (e) => { const onRegionChange = (e) => {
filters.region = regions.value[e.detail.value] regionIndex.value = e.detail.value
} }
onMounted(() => { const onStartTimeChange = (e) => {
// 组件挂载时的初始化逻辑 formData.startTime = e.detail.value
}
const onEndTimeChange = (e) => {
formData.endTime = e.detail.value
}
const handleSearch = () => {
console.log('当前搜索条件:', {
...formData,
helpType: helpTypes[helpTypeIndex.value],
region: regions[regionIndex.value]
}) })
// 在这里调用接口进行搜索
}
onLoad(() => {
getDataList('refresh');
});
return {
filters,
helpTypes, // 获取视频列表
regions, function getDataList(type = 'add') {
helpRecords, // let maxPage=Math.ceil(totalNum.value/pageSize.value)
goBack, // let params={}
resetFilters, // if (type === 'refresh') {
queryData, // pageNum.value = 1;
showDetail, // params={
followUp, // category:'',
showJobRecommend, // hour:'',
onHelpTypeChange, // level:'',
onRegionChange // searchValue:searchKeyword.value,
} // orderStr:'',
// pageSize:pageSize.value,
// pageNum:pageNum.value
// }
// $api.myRequest('/train/public/trainVideo/trainVideoList', params).then((resData) => {
// dataList.value=resData.rows
// totalNum.value=resData.total
// });
// }
// if (type === 'add' && pageNum.value < maxPage) {
// pageNum.value += 1;
// params={
// category:'',
// hour:'',
// level:'',
// searchValue:searchKeyword.value,
// orderStr:'',
// pageSize:pageSize.value,
// pageNum:pageNum.value
// }
// $api.myRequest('/train/public/trainVideo/trainVideoList', params).then((resData) => {
// dataList.value=dataList.value.concat(resData.rows)
// totalNum.value=resData.total
// });
// }
dataList.value=[
{
name: '王小明',
idCard: '370781199107166029',
helperName: '喀什',
startTime: '2025/11/24',
endTime: '2025/11/25',
phone:'18340050862',
region:'喀什地区',
unit:'新生社区',
type:'招聘单位推荐',
assistanceDate:'2025/11/25',
nextContact:'2025/11/30',
id:'1'
},
{
name: '王大明',
idCard: '370781199107166029',
helperName: '喀什',
startTime: '2025/11/24',
endTime: '2025/11/25',
phone:'18340050862',
region:'喀什地区',
unit:'新生社区',
type:'招聘单位推荐',
assistanceDate:'2025/11/25',
nextContact:'2025/11/30',
id:'2'
},
]
} }
// 播放视频
function goFollow(item) {
navTo(`/packageB/priority/helpFollow?id=${item.id}`);
} }
</script> </script>
<style scoped> <style lang="stylus" scoped>
.help-filter-page { .btnback
background-color: #f5f5f5; width: 64rpx
min-height: 100vh; height: 64rpx
}
.header { image
background-color: #1989fa; height: 100%
display: flex; width: 100%
align-items: center;
padding: 20rpx 30rpx;
position: fixed;
top: 0;
left: 0;
right: 0;
z-index: 100;
}
.back-btn { .main-list
padding: 10rpx; background-color: #ffffff
} padding: 20rpx 20rpx 28rpx 20rpx
margin: 30rpx 30rpx
box-shadow: 0px 3px 20px 0px rgba(0,105,234,0.1)
border-radius: 12px
.list-top
display: flex
align-items: center
justify-content: space-between
.list-title
font-weight: bold
font-size: 36rpx
color: #404040
position: relative
.title { .title-line
color: #fff; position: absolute
font-size: 36rpx; bottom: -10rpx
font-weight: bold; left: 36rpx
flex: 1; width: 70rpx
text-align: center; height: 8rpx
margin-right: 60rpx; background: linear-gradient(90deg, #FFAD58 0%, #FF7A5B 100%)
} border-radius: 4rpx
.search-box-btn
border-radius: 32rpx !important
background: #3088FF !important
margin-right: 16rpx
.reset-box-btn
border-radius: 32rpx !important
background: #02B44D
color: #fff
.search-container
padding: 20rpx 0rpx 0rpx 0rpx
.title-total
font-size: 24rpx
color: #999999
.total-num
color: #3088FF
margin-left: 4rpx
margin-right: 4rpx
font-weight: bold
font-size: 26rpx
.search-item
display: flex
align-items: center
margin-bottom: 30rpx
.filter-section { .label
background-color: #fff; width: 160rpx
margin-top: 100rpx; font-size: 28rpx
padding: 30rpx; color: #404040
border-radius: 10rpx;
margin-bottom: 20rpx;
}
.filter-item { .input,
display: flex; .picker
align-items: center; background: #FFFFFF
margin-bottom: 30rpx; flex: 1
} height: 72rpx
padding: 0 20rpx
border: 1px solid #A0A0A0
border-radius: 8rpx
font-size: 28rpx
line-height: 72rpx
.filter-label { .picker-value
font-size: 28rpx; color: #666
color: #333; .list-box
width: 200rpx; margin-top: 40rpx
} .con-box
background: #fff
padding: 20rpx
box-shadow: 0px 0px 6rpx 0px rgba(0,71,200,0.16)
border-radius: 24rpx
border: 1rpx solid #EDF5FF
margin-top: 30rpx
.form-title
display: flex
align-items: center
.filter-input { .form-name
flex: 1; font-weight: bold
height: 80rpx; font-size: 32rpx
border: 1rpx solid #e0e0e0; color: #595959
margin-right:16rpx
.form-type
border-radius: 8rpx; border-radius: 8rpx;
padding: 0 20rpx; border: 2rpx solid #FF7D26;
font-size: 28rpx; font-size: 24rpx
} color: #F1690E
padding: 4rpx 10rpx
.filter-picker { .form-item
flex: 1; display: flex
height: 80rpx; align-items: center
border: 1rpx solid #e0e0e0; justify-content: space-between
border-radius: 8rpx; margin-top: 30rpx
display: flex; .item-left
align-items: center; display: flex
padding: 0 20rpx; align-items: center
} .item-img
width: 26rpx
.picker-text { height: 26rpx
font-size: 28rpx; margin-right: 10rpx
color: #999; .item-label
} font-size: 26rpx
color: #B3B3B3
.date-range { .item-right
display: flex; font-size: 26rpx
align-items: flex-start; color: #737373
margin-bottom: 30rpx; .form-btns
} margin-top:30rpx
.form-box-btn
.date-inputs { border-radius: 50rpx !important
flex: 1; margin-right: 24rpx
display: flex; padding: 0rpx 40rpx
align-items: center; .detail-btn
} background: #EDF5FF
border: 1px solid #3088FF
.date-input { font-size: 28rpx
flex: 1; color: #3088FF
height: 80rpx; .follow-btn
border: 1rpx solid #e0e0e0; background: #EEF9F3
border-radius: 8rpx; border: 1px solid #00933E
padding: 0 20rpx; font-size: 28rpx
font-size: 28rpx; color: #00933E
} .recommend-btn
background: linear-gradient(92deg, #0DCCFF 0%, #4760FF 100%)
.date-separator { font-size: 28rpx
margin: 0 20rpx; color: #FFFFFF
color: #999;
}
.filter-buttons {
display: flex;
gap: 20rpx;
}
.query-btn {
flex: 1;
background-color: #1989fa;
color: #fff;
font-size: 32rpx;
border: none;
height: 88rpx;
line-height: 88rpx;
}
.reset-btn {
flex: 1;
background-color: #fff;
color: #333;
font-size: 32rpx;
border: 1rpx solid #e0e0e0;
height: 88rpx;
line-height: 88rpx;
}
.list-section {
background-color: #fff;
padding: 30rpx;
border-radius: 10rpx;
}
.list-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 30rpx;
}
.list-title {
font-size: 32rpx;
font-weight: bold;
color: #333;
}
.list-count {
font-size: 28rpx;
color: #999;
}
.record-item {
border: 1rpx solid #e0e0e0;
border-radius: 10rpx;
padding: 30rpx;
margin-bottom: 30rpx;
}
.record-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 20rpx;
}
.person-name {
font-size: 36rpx;
font-weight: bold;
color: #333;
}
.job-tag {
font-size: 24rpx;
color: #ff6600;
padding: 5rpx 15rpx;
border: 1rpx solid #ff6600;
border-radius: 15rpx;
}
.record-info {
margin-bottom: 30rpx;
}
.info-row {
display: flex;
align-items: center;
margin-bottom: 15rpx;
font-size: 28rpx;
}
.info-label {
color: #666;
margin-left: 10rpx;
}
.info-value {
color: #333;
margin-left: 10rpx;
}
.record-actions {
display: flex;
gap: 20rpx;
}
.detail-btn {
flex: 1;
background-color: #e8f3ff;
color: #1989fa;
font-size: 28rpx;
border: none;
height: 70rpx;
line-height: 70rpx;
}
.follow-btn {
flex: 1;
background-color: #e6f7ff;
color: #1890ff;
font-size: 28rpx;
border: none;
height: 70rpx;
line-height: 70rpx;
}
.recommend-btn {
flex: 1;
background-color: #f6ffed;
color: #52c41a;
font-size: 28rpx;
border: none;
height: 70rpx;
line-height: 70rpx;
}
</style> </style>

View File

@@ -1,442 +1,503 @@
<template> <template>
<view class="help-follow-page"> <AppLayout :title="title" :show-bg-image="false" @onScrollBottom="getDataList('add')">
<view class="header"> <!-- <template #headerleft>
<view class="back-btn" @click="goBack"> <view class="btnback">
<uni-icons type="arrowleft" size="24" color="#fff" /> <image src="@/static/icon/back.png" @click="navBack"></image>
</view> </view>
<view class="title">跟进</view> </template> -->
<view class="info-box">
<view class="info-item info-line">
<image class="info-img" :src="baseUrl+'/dispatch/person-icon.png'" mode=""></image>
<view class="info-label">
人员姓名
</view>
<view class="info-value">
王小美
</view> </view>
<!-- 人员信息卡片 -->
<view class="person-info-card">
<view class="info-item">
<uni-icons type="person" size="20" color="#1989fa" />
<span class="info-label">人员姓名</span>
<span class="info-value">{{personInfo.personName}}</span>
</view> </view>
<view class="info-item"> <view class="info-item">
<uni-icons type="briefcase" size="20" color="#1989fa" /> <image class="info-img" :src="baseUrl+'/dispatch/help-icon.png'" mode=""></image>
<span class="info-label">帮扶类型</span> <view class="info-label">
<span class="info-value">{{personInfo.helpType}}</span> 帮扶类型
</view>
<view class="info-value">
招聘岗位推荐
</view>
</view>
</view>
<view class="main-list" :style="getBackgroundStyle('k.png')">
<view class="list-top">
<view class="list-title">
<text>新增跟进记录</text>
<view class="title-line"></view>
</view> </view>
</view> </view>
<!-- 新增跟进记录 --> <view class="form-container">
<view class="follow-form-section"> <uni-forms ref="formRef" v-model="formData" :rules="rules" validate-trigger="submit">
<view class="section-title">新增跟进记录</view> <!-- 跟进日期 -->
<uni-forms-item label="跟进日期:" name="followDate" required>
<view class="form-item"> <picker mode="date" :value="formData.followDate" @change="onDateChange('followDate', $event)">
<view class="form-label required">跟进日期</view> <view class="picker-value">{{ formData.followDate || '请选择跟进日期' }}</view>
<input class="form-input date-input" v-model="followData.followDate" type="date" placeholder="请选择跟进日期" />
</view>
<view class="form-item">
<view class="form-label required">跟进方式</view>
<picker class="form-picker" mode="selector" range="{{followMethods}}" @change="onFollowMethodChange">
<view class="picker-text">{{followData.followMethod || '请选择跟进方式'}}</view>
</picker> </picker>
</view> </uni-forms-item>
<view class="form-item"> <!-- 跟进方式 -->
<view class="form-label required">跟进内容</view> <uni-forms-item label="跟进方式:" name="followMethod" required>
<textarea class="form-textarea" v-model="followData.followContent" placeholder="请输入跟进内容" rows="4"></textarea> <picker mode="selector" :range="followMethods" :value="methodIndex" @change="onMethodChange">
</view> <view class="picker-value">{{ followMethods[methodIndex] || '请选择跟进方式' }}</view>
</picker>
</uni-forms-item>
<view class="form-item"> <!-- 跟进内容 -->
<view class="form-label required">跟进结果</view> <uni-forms-item label="跟进内容:" name="followContent" required>
<textarea class="form-textarea" v-model="followData.followResult" placeholder="请输入跟进结果" rows="3"></textarea> <textarea
</view> v-model="formData.followContent"
class="textarea"
placeholder="请输入跟进内容"
:maxlength="500"
/>
</uni-forms-item>
<view class="form-item"> <!-- 跟进结果 -->
<view class="form-label">下一步计划</view> <uni-forms-item label="跟进结果:" name="followResult" required>
<textarea class="form-textarea" v-model="followData.nextPlan" placeholder="请输入下一步计划" rows="3"></textarea> <textarea
</view> v-model="formData.followResult"
class="textarea"
placeholder="请输入跟进结果"
:maxlength="500"
/>
</uni-forms-item>
<view class="form-item"> <!-- 下一步计划 -->
<view class="form-label">下次联系</view> <uni-forms-item label="下一步计划:" name="nextPlan">
<input class="form-input date-input" v-model="followData.nextContactDate" type="date" placeholder="请选择下次联系日期" /> <textarea
</view> v-model="formData.nextPlan"
class="textarea"
placeholder="请输入下一步计划(可选)"
:maxlength="500"
/>
</uni-forms-item>
<view class="form-buttons"> <!-- 下次联系时间 -->
<button class="save-btn" type="primary" @click="saveFollowRecord">保存跟进</button> <uni-forms-item label="下次联系:" name="nextContactDate">
<button class="reset-btn" @click="resetForm">重置</button> <picker mode="date" :value="formData.nextContactDate" @change="onDateChange('nextContactDate', $event)">
</view> <view class="picker-value">{{ formData.nextContactDate || '请选择下次联系时间' }}</view>
</view> </picker>
</uni-forms-item>
</uni-forms>
<!-- 跟进历史记录 --> <!-- 按钮组 -->
<view class="history-section"> <view class="button-group">
<view class="section-header"> <button class="btn submit-btn" @click="handleSubmit">保存跟进</button>
<view class="section-title">跟进历史记录</view> <button class="btn reset-btn" @click="handleReset">重置</button>
<view class="record-count">{{historyRecords.length}}条记录</view>
</view>
<view class="history-list">
<view class="history-item" v-for="record in historyRecords" :key="record.id">
<view class="history-header">
<uni-icons type="time" size="16" color="#1989fa" />
<span class="history-date">{{record.date}}</span>
</view>
<view class="history-content">
<view class="history-row">
<span class="history-label">跟进方式</span>
<span class="history-value">{{record.method}}</span>
</view>
<view class="history-row">
<span class="history-label">跟进人</span>
<span class="history-value">{{record.follower}}</span>
</view>
<view class="history-row">
<span class="history-label">跟进内容</span>
<span class="history-value">{{record.content}}</span>
</view> </view>
</view> </view>
</view> </view>
<view class="main-list" :style="getBackgroundStyle('k.png')">
<view class="list-top">
<view class="list-title">
<text>跟进历史记录</text>
<view class="title-line"></view>
</view>
<view class="title-total">
<text class="total-num">7</text>条记录
</view> </view>
</view> </view>
<!-- v-if="dataList.length>0" -->
<view class="list-box" >
<uni-steps :options="list2" active-color="#007AFF" :active="active" direction="column" />
</view> </view>
<!-- <empty v-else pdTop="200"></empty> -->
</view>
</AppLayout>
</template> </template>
<script> <script setup>
import { ref, reactive, onMounted } from 'vue' import { inject, ref, reactive } from 'vue';
import { useRouter, useRoute } from 'uni-app' import { onLoad } from '@dcloudio/uni-app';
const { $api, navTo, navBack } = inject('globalFunction');
import config from "@/config.js"
export default { // state
name: 'HelpFollow', const title = ref('');
setup() { const formData = reactive({
const router = useRouter() followDate: null,
const route = useRoute() followMethod: null,
followContent: null,
// 人员信息 followResult: null,
const personInfo = reactive({ nextPlan: null,
personName: '王小美', nextContactDate: null
helpType: '招聘岗位推荐'
}) })
const followMethods = ['电话', '面谈', '微信', '邮件', '其他']
const methodIndex = ref(0)
const list2=[{
title: '买家下单',
desc: '跟进方式:电话\n跟进人新生社区管理员\n跟进内容内容内容内容'
}, {
title: '卖家发货',
desc: '跟进方式:电话\n跟进人新生社区管理员\n跟进内容内容内容内容'
}, {
title: '买家签收',
desc: '跟进方式:电话\n跟进人新生社区管理员\n跟进内容内容内容内容'
}, {
title: '交易完成',
desc: '跟进方式:电话\n跟进人新生社区管理员\n跟进内容内容内容内容'
}]
const active=ref(null)
// 表单引用
const formRef = ref(null)
// 跟进方式选项 // 校验规则
const followMethods = ref(['电话', '微信', '邮件', '上门拜访', '视频会议', '其他']) const rules = {
followDate: {
// 跟进表单数据 required: true,
const followData = reactive({ message: '请选择跟进日期'
followDate: '',
followMethod: '',
followContent: '',
followResult: '',
nextPlan: '',
nextContactDate: ''
})
// 历史记录数据
const historyRecords = ref([
{
id: 1,
date: '2025-11-05',
method: '电话',
follower: '新兴社区管理员',
content: '内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容。'
}, },
{ followMethod: {
id: 2, required: true,
date: '2025-11-05', message: '请选择跟进方式'
method: '电话', },
follower: '新兴社区管理员', followContent: {
content: '内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容内容。' required: true,
message: '请填写跟进内容'
},
followResult: {
required: true,
message: '请填写跟进结果'
} }
])
// 返回上一页
const goBack = () => {
router.back()
} }
// 重置表单 const searchKeyword = ref('');
const resetForm = () => { const dataList=ref([])
Object.keys(followData).forEach(key => { const pageSize=ref(10)
followData[key] = '' const pageNum=ref(1)
const totalNum=ref(0)
const baseUrl = config.imgBaseUrl
const getBackgroundStyle = (imageName) => ({
backgroundImage: `url(${baseUrl}/dispatch/${imageName})`,
backgroundSize: 'cover', // 覆盖整个容器
backgroundPosition: 'center', // 居中
backgroundRepeat: 'no-repeat'
});
const trainVideoImgUrl=config.trainVideoImgUrl
// 所属区域选项(可根据实际替换为动态数据)
const regions = ['北京市', '上海市', '广州市', '深圳市', '杭州市']
const regionIndex = ref(0)
// 事件处理
const onDateChange = (field, e) => {
formData[field] = e.detail.value
}
const onMethodChange = (e) => {
const idx = e.detail.value
methodIndex.value = idx
formData.followMethod = followMethods[idx]
}
const handleSubmit = () => {
formRef.value?.validate()
.then(() => {
uni.showToast({ title: '校验通过', icon: 'success' });
}) })
} .catch((errors) => {
console.log('校验失败:', errors);
uni.showToast({ title: '请填写必填项', icon: 'none' });
});
};
// 保存跟进记录 const handleReset = () => {
const saveFollowRecord = () => { Object.keys(formData).forEach(key => {
// 表单验证 formData[key] = ''
if (!followData.followDate) {
uni.showToast({ title: '请选择跟进日期', icon: 'none' })
return
}
if (!followData.followMethod) {
uni.showToast({ title: '请选择跟进方式', icon: 'none' })
return
}
if (!followData.followContent) {
uni.showToast({ title: '请输入跟进内容', icon: 'none' })
return
}
if (!followData.followResult) {
uni.showToast({ title: '请输入跟进结果', icon: 'none' })
return
}
// 这里是模拟保存实际项目中应该调用API
console.log('保存跟进记录:', followData)
// 保存成功后添加到历史记录列表
const newRecord = {
id: historyRecords.value.length + 1,
date: followData.followDate,
method: followData.followMethod,
follower: '当前登录用户', // 实际应该从登录信息中获取
content: followData.followContent
}
historyRecords.value.unshift(newRecord)
// 清空表单
resetForm()
uni.showToast({ title: '保存成功', icon: 'success' })
}
// 跟进方式选择变化
const onFollowMethodChange = (e) => {
followData.followMethod = followMethods.value[e.detail.value]
}
onMounted(() => {
// 组件挂载时的初始化逻辑
// 可以从路由参数中获取人员ID等信息
console.log('路由参数:', route.query)
// 实际项目中应该根据ID加载人员信息和历史记录
// loadPersonInfo(route.query.personId)
// loadHistoryRecords(route.query.personId)
}) })
methodIndex.value = 0
uni.showToast({ title: '已重置', icon: 'none' })
}
onLoad(() => {
// getDataList('refresh');
});
return {
personInfo,
followMethods, // 获取视频列表
followData, function getDataList(type = 'add') {
historyRecords, // let maxPage=Math.ceil(totalNum.value/pageSize.value)
goBack, // let params={}
resetForm, // if (type === 'refresh') {
saveFollowRecord, // pageNum.value = 1;
onFollowMethodChange // params={
} // category:'',
// hour:'',
// level:'',
// searchValue:searchKeyword.value,
// orderStr:'',
// pageSize:pageSize.value,
// pageNum:pageNum.value
// }
// $api.myRequest('/train/public/trainVideo/trainVideoList', params).then((resData) => {
// dataList.value=resData.rows
// totalNum.value=resData.total
// });
// }
// if (type === 'add' && pageNum.value < maxPage) {
// pageNum.value += 1;
// params={
// category:'',
// hour:'',
// level:'',
// searchValue:searchKeyword.value,
// orderStr:'',
// pageSize:pageSize.value,
// pageNum:pageNum.value
// }
// $api.myRequest('/train/public/trainVideo/trainVideoList', params).then((resData) => {
// dataList.value=dataList.value.concat(resData.rows)
// totalNum.value=resData.total
// });
// }
} }
// 播放视频
function playVideo(video) {
navTo(`/packageB/train/video/videoDetail?id=${video.videoId}`);
} }
</script> </script>
<style scoped> <style lang="stylus" scoped>
.help-follow-page { .btnback
background-color: #f5f5f5; width: 64rpx
min-height: 100vh; height: 64rpx
}
.header { image
background-color: #1989fa; height: 100%
display: flex; width: 100%
align-items: center; .info-box
padding: 20rpx 30rpx; margin: 30rpx 30rpx
position: fixed; background: linear-gradient(0deg, #D9ECFF 0%, #F0F7FF 100%)
top: 0; border-radius: 20rpx
left: 0; padding: 40rpx 0
right: 0; display: flex
z-index: 100; align-items: center
} .info-img
width: 40rpx
height: 40rpx
margin-bottom: 20rpx
.info-line
border-right: 2rpx solid #B7D6FF
.info-item
display: flex
flex-direction: column
align-items: center
justify-content: center
width: 50%
.info-label
font-size: 26rpx
color: #6E7E9B
margin-bottom: 20rpx
.info-value
font-weight: bold
font-size: 28rpx
color: #3D61AC
.main-list
background-color: #ffffff
padding: 20rpx 20rpx 28rpx 20rpx
margin: 30rpx 30rpx
box-shadow: 0px 3px 20px 0px rgba(0,105,234,0.1)
border-radius: 12px
.list-top
display: flex
align-items: center
justify-content: space-between
.list-title
font-weight: bold
font-size: 36rpx
color: #404040
position: relative
.back-btn { .title-line
padding: 10rpx; position: absolute
} bottom: -10rpx
left: 70rpx
width: 70rpx
height: 8rpx
background: linear-gradient(90deg, #FFAD58 0%, #FF7A5B 100%)
border-radius: 4rpx
.search-box-btn
border-radius: 32rpx !important
background: #3088FF !important
margin-right: 16rpx
.reset-box-btn
border-radius: 32rpx !important
background: #02B44D
color: #fff
.search-container
padding: 20rpx 0rpx 0rpx 0rpx
.title-total
font-size: 24rpx
color: #999999
.total-num
color: #3088FF
margin-left: 4rpx
margin-right: 4rpx
font-weight: bold
font-size: 26rpx
.search-item
display: flex
align-items: center
margin-bottom: 20rpx
.title { .label
color: #fff; width: 160rpx
font-size: 36rpx; font-size: 28rpx
font-weight: bold; color: #404040
flex: 1;
text-align: center;
margin-right: 60rpx;
}
.person-info-card { .input,
background-color: #fff; .picker
margin-top: 100rpx; background: #FFFFFF
padding: 30rpx; flex: 1
display: flex; height: 72rpx
justify-content: space-around; padding: 0 20rpx
border-radius: 10rpx; border: 1px solid #A0A0A0
margin-bottom: 20rpx; border-radius: 8rpx
} font-size: 28rpx
line-height: 72rpx
.info-item { .picker-value
display: flex; color: #666
flex-direction: column; .list-box
align-items: center; margin-top: 40rpx
gap: 10rpx; .con-box
} background: #fff
padding: 20rpx
box-shadow: 0px 0px 6rpx 0px rgba(0,71,200,0.16)
border-radius: 24rpx
border: 1rpx solid #EDF5FF
margin-top: 30rpx
.form-title
display: flex
align-items: center
.info-label { .form-name
font-size: 26rpx; font-weight: bold
color: #666; font-size: 32rpx
} color: #595959
margin-right:16rpx
.info-value { .form-type
font-size: 28rpx;
color: #333;
font-weight: 500;
}
.follow-form-section {
background-color: #fff;
padding: 30rpx;
border-radius: 10rpx;
margin-bottom: 20rpx;
}
.history-section {
background-color: #fff;
padding: 30rpx;
border-radius: 10rpx;
margin-bottom: 30rpx;
}
.section-title {
font-size: 32rpx;
font-weight: bold;
color: #333;
margin-bottom: 30rpx;
}
.section-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 30rpx;
}
.record-count {
font-size: 28rpx;
color: #999;
}
.form-item {
margin-bottom: 30rpx;
}
.form-label {
font-size: 28rpx;
color: #333;
margin-bottom: 10rpx;
display: inline-block;
}
.required::before {
content: '*';
color: #ff4d4f;
margin-right: 5rpx;
}
.form-input {
width: 100%;
height: 80rpx;
border: 1rpx solid #e0e0e0;
border-radius: 8rpx; border-radius: 8rpx;
padding: 0 20rpx; border: 2rpx solid #FF7D26;
font-size: 24rpx
color: #F1690E
padding: 4rpx 10rpx
.form-item
display: flex
align-items: center
justify-content: space-between
margin-top: 20rpx
.item-left
display: flex
align-items: center
.item-img
width: 26rpx
height: 26rpx
margin-right: 10rpx
.item-label
font-size: 26rpx
color: #B3B3B3
.item-right
font-size: 26rpx
color: #737373
.form-btns
margin-top:30rpx
.form-box-btn
border-radius: 50rpx !important
margin-right: 24rpx
padding: 0rpx 40rpx
.detail-btn
background: #EDF5FF
border: 1px solid #3088FF
font-size: 28rpx
color: #3088FF
.follow-btn
background: #EEF9F3
border: 1px solid #00933E
font-size: 28rpx
color: #00933E
.recommend-btn
background: linear-gradient(92deg, #0DCCFF 0%, #4760FF 100%)
font-size: 28rpx
color: #FFFFFF
.form-container
margin-top: 30rpx
:deep(.uni-forms-item__label)
width: 194rpx !important
font-size: 28rpx; font-size: 28rpx;
} color: #404040;
/* 统一 picker 和 textarea 样式 */
.date-input { .picker-value,
background-color: #fafafa; .textarea {
}
.form-picker {
width: 100%; width: 100%;
height: 80rpx; min-height: 60rpx;
border: 1rpx solid #e0e0e0;
border-radius: 8rpx;
display: flex;
align-items: center;
padding: 0 20rpx;
background-color: #fafafa;
}
.picker-text {
font-size: 28rpx;
color: #999;
}
.form-textarea {
width: 100%;
border: 1rpx solid #e0e0e0;
border-radius: 8rpx;
padding: 20rpx; padding: 20rpx;
border: 1px solid #ddd;
border-radius: 8rpx;
font-size: 28rpx; font-size: 28rpx;
min-height: 150rpx; box-sizing: border-box;
}
.textarea {
height: 120rpx;
resize: none; resize: none;
} }
.form-buttons { .button-group {
display: flex; display: flex;
gap: 20rpx; justify-content: space-between;
margin-top: 40rpx; padding: 40rpx 20rpx 20rpx;
} }
.save-btn { .btn {
flex: 1; width: 45%;
background-color: #1989fa; height: 80rpx;
color: #fff; font-size: 30rpx;
font-size: 32rpx; border-radius: 8rpx;
border: none;
height: 88rpx;
line-height: 88rpx;
} }
.reset-btn { .reset-btn {
flex: 1; background-color: #D8E9FF;
background-color: #fff; color: #1176FF;
color: #333;
font-size: 32rpx;
border: 1rpx solid #e0e0e0;
height: 88rpx;
line-height: 88rpx;
} }
.history-list { .submit-btn {
display: flex; background-color: #368BFF;
flex-direction: column; color: white;
gap: 20rpx;
}
.history-item {
border: 1rpx solid #e0e0e0;
border-radius: 10rpx;
padding: 20rpx;
}
.history-header {
display: flex;
align-items: center;
margin-bottom: 15rpx;
gap: 10rpx;
}
.history-date {
font-size: 28rpx;
color: #1989fa;
font-weight: 500;
}
.history-content {
padding-left: 30rpx;
}
.history-row {
margin-bottom: 10rpx;
font-size: 28rpx;
}
.history-label {
color: #666;
margin-right: 10rpx;
}
.history-value {
color: #333;
} }
:deep(.uni-steps__column-circle )
width: 24rpx !important
height: 24rpx !important
background: radial-gradient(circle,
#00C0FA 0%,
#015EEA 50%,
#FFFFFF 51%,
#FFFFFF 100%) !important
border-radius: 50%
border: 2rpx solid #015EEA
:deep(.uni-steps__column-title)
font-size: 28rpx !important
color: #006CFF !important
margin-bottom: 24rpx
:deep(.uni-steps__column-desc)
font-size: 28rpx
color: #898989 !important
line-height: 1.5
:deep(.uni-steps__column-text )
padding: 16rpx 0 !important
border: none
:deep(.uni-steps__column-line)
background-color: #368BFF !important
:deep(.uni-steps__column-line--before)
background-color:rgba(0,0,0,0) !important
</style> </style>

View File

@@ -369,6 +369,20 @@
"navigationBarTitleText": "查看成绩", "navigationBarTitleText": "查看成绩",
"navigationBarTitleTextSize": "30rpx" "navigationBarTitleTextSize": "30rpx"
} }
},
{
"path": "priority/helpFilter",
"style": {
"navigationBarTitleText": "筛选和帮扶",
"navigationBarTitleTextSize": "30rpx"
}
},
{
"path": "priority/helpFollow",
"style": {
"navigationBarTitleText": "跟进",
"navigationBarTitleTextSize": "30rpx"
}
} }
] ]
}, },

View File

@@ -130,6 +130,12 @@
</view> </view>
<view class="service-title">测试页面</view> <view class="service-title">测试页面</view>
</view> </view>
<view class="service-item press-button" @click="navToPage">
<view class="service-icon service-icon-10">
<uni-icons type="gear-filled" size="32" color="#FFFFFF"></uni-icons>
</view>
<view class="service-title">帮扶</view>
</view>
</view> </view>
</view> </view>
@@ -742,6 +748,9 @@ const handleLiveClick = () => {
const navToTestPage = () => { const navToTestPage = () => {
navTo('/pages/test/homepage-test'); navTo('/pages/test/homepage-test');
}; };
const navToPage = () =>{
navTo('/packageB/priority/helpFilter');
}
async function loadData() { async function loadData() {
try { try {

View File

@@ -1,5 +1,7 @@
## 2.0.102024-06-07 ## 2.0.122025-08-26
- 优化 uni-app x 中,size 属性的类型 - 优化 uni-app x size 类型问题
## 2.0.112025-08-18
- 修复 图标点击事件返回
## 2.0.92024-01-12 ## 2.0.92024-01-12
fix: 修复图标大小默认值错误的问题 fix: 修复图标大小默认值错误的问题
## 2.0.82023-12-14 ## 2.0.82023-12-14

View File

@@ -11,7 +11,7 @@
* Icons 图标 * Icons 图标
* @description 用于展示 icon 图标 * @description 用于展示 icon 图标
* @tutorial https://ext.dcloud.net.cn/plugin?id=28 * @tutorial https://ext.dcloud.net.cn/plugin?id=28
* @property {Number,String} size 图标大小 * @property {Number} size 图标大小
* @property {String} type 图标图案,参考示例 * @property {String} type 图标图案,参考示例
* @property {String} color 图标颜色 * @property {String} color 图标颜色
* @property {String} customPrefix 自定义图标 * @property {String} customPrefix 自定义图标

View File

@@ -85,8 +85,8 @@
} }
}, },
methods: { methods: {
_onClick() { _onClick(e) {
this.$emit('click') this.$emit('click', e)
} }
} }
} }

View File

@@ -1,7 +1,7 @@
{ {
"id": "uni-icons", "id": "uni-icons",
"displayName": "uni-icons 图标", "displayName": "uni-icons 图标",
"version": "2.0.10", "version": "2.0.12",
"description": "图标组件,用于展示移动端常见的图标,可自定义颜色、大小。", "description": "图标组件,用于展示移动端常见的图标,可自定义颜色、大小。",
"keywords": [ "keywords": [
"uni-ui", "uni-ui",
@@ -11,7 +11,9 @@
], ],
"repository": "https://github.com/dcloudio/uni-ui", "repository": "https://github.com/dcloudio/uni-ui",
"engines": { "engines": {
"HBuilderX": "^3.2.14" "HBuilderX": "^3.2.14",
"uni-app": "^4.08",
"uni-app-x": "^4.61"
}, },
"directories": { "directories": {
"example": "../../temps/example_temps" "example": "../../temps/example_temps"
@@ -34,54 +36,74 @@
"permissions": "无" "permissions": "无"
}, },
"npmurl": "https://www.npmjs.com/package/@dcloudio/uni-ui", "npmurl": "https://www.npmjs.com/package/@dcloudio/uni-ui",
"type": "component-vue" "type": "component-vue",
"darkmode": "x",
"i18n": "x",
"widescreen": "x"
}, },
"uni_modules": { "uni_modules": {
"dependencies": ["uni-scss"], "dependencies": [
"uni-scss"
],
"encrypt": [], "encrypt": [],
"platforms": { "platforms": {
"cloud": { "cloud": {
"tcb": "y", "tcb": "x",
"aliyun": "y", "aliyun": "x",
"alipay": "n" "alipay": "x"
}, },
"client": { "client": {
"App": { "uni-app": {
"app-vue": "y", "vue": {
"app-nvue": "y", "vue2": "",
"app-uvue": "y" "vue3": ""
}, },
"H5-mobile": { "web": {
"Safari": "y", "safari": "",
"Android Browser": "y", "chrome": ""
"微信浏览器(Android)": "y",
"QQ浏览器(Android)": "y"
}, },
"H5-pc": { "app": {
"Chrome": "y", "vue": "",
"IE": "y", "nvue": "-",
"Edge": "y", "android": {
"Firefox": "y", "extVersion": "",
"Safari": "y" "minVersion": "29"
}, },
"小程序": { "ios": "√",
"微信": "y", "harmony": ""
"阿里": "y",
"百度": "y",
"字节跳动": "y",
"QQ": "y",
"钉钉": "y",
"快手": "y",
"飞书": "y",
"京东": "y"
}, },
"快应用": { "mp": {
"华为": "y", "weixin": "",
"联盟": "y" "alipay": "",
"toutiao": "√",
"baidu": "√",
"kuaishou": "-",
"jd": "-",
"harmony": "-",
"qq": "√",
"lark": "-"
}, },
"Vue": { "quickapp": {
"vue2": "y", "huawei": "",
"vue3": "y" "union": ""
}
},
"uni-app-x": {
"web": {
"safari": "√",
"chrome": "√"
},
"app": {
"android": {
"extVersion": "",
"minVersion": "29"
},
"ios": "√",
"harmony": "√"
},
"mp": {
"weixin": "√"
}
} }
} }
} }

View File

@@ -0,0 +1,18 @@
## 1.1.22024-03-28
- 修复 uni-steps为竖排列时文本长度过长引起点错乱的bug
## 1.1.12021-11-22
- 修复 vue3中某些scss变量无法找到的问题
## 1.1.02021-11-19
- 优化 组件UI并提供设计资源详见:[https://uniapp.dcloud.io/component/uniui/resource](https://uniapp.dcloud.io/component/uniui/resource)
- 文档迁移,详见:[https://uniapp.dcloud.io/component/uniui/uni-steps](https://uniapp.dcloud.io/component/uniui/uni-steps)
## 1.0.82021-05-12
- 新增 项目示例地址
## 1.0.72021-05-06
- 修复 uni-steps 横向布局时,多行文字高度不合理的 bug
## 1.0.62021-04-21
- 优化 添加依赖 uni-icons, 导入后自动下载依赖
## 1.0.52021-02-05
- 优化 组件引用关系通过uni_modules引用组件
## 1.0.42021-02-05
- 调整为uni_modules目录规范

View File

@@ -0,0 +1,280 @@
<template>
<view class="uni-steps">
<view :class="[direction==='column'?'uni-steps__column':'uni-steps__row']">
<view :class="[direction==='column'?'uni-steps__column-text-container':'uni-steps__row-text-container']">
<view v-for="(item,index) in options" :key="index"
:class="[direction==='column'?'uni-steps__column-text':'uni-steps__row-text']">
<text :style="{color:index === active?activeColor:deactiveColor}"
:class="[direction==='column'?'uni-steps__column-title':'uni-steps__row-title']">{{item.title}}</text>
<text :style="{color: deactiveColor}"
:class="[direction==='column'?'uni-steps__column-desc':'uni-steps__row-desc']">{{item.desc}}</text>
</view>
</view>
<view :class="[direction==='column'?'uni-steps__column-container':'uni-steps__row-container']">
<view :class="[direction==='column'?'uni-steps__column-line-item':'uni-steps__row-line-item']"
v-for="(item,index) in options" :key="index" :style="{height: direction === 'column'?heightArr[index]+'px':'14px'}">
<view
:class="[direction==='column'?'uni-steps__column-line':'uni-steps__row-line',direction==='column'?'uni-steps__column-line--before':'uni-steps__row-line--before']"
:style="{backgroundColor:index<=active&&index!==0?activeColor:index===0?'transparent':deactiveColor}">
</view>
<view :class="[direction==='column'?'uni-steps__column-check':'uni-steps__row-check']"
v-if="index === active">
<uni-icons :color="activeColor" :type="activeIcon" size="14" />
</view>
<view v-else :class="[direction==='column'?'uni-steps__column-circle':'uni-steps__row-circle']"
:style="{backgroundColor:index<active?activeColor:deactiveColor}" />
<view
:class="[direction==='column'?'uni-steps__column-line':'uni-steps__row-line',direction==='column'?'uni-steps__column-line--after':'uni-steps__row-line--after']"
:style="{backgroundColor:index<active&&index!==options.length-1?activeColor:index===options.length-1?'transparent':deactiveColor}" />
</view>
</view>
</view>
</view>
</template>
<script>
/**
* Steps 步骤条
* @description 评分组件
* @tutorial https://ext.dcloud.net.cn/plugin?id=34
* @property {Number} active 当前步骤
* @property {String} direction = [row|column] 当前步骤
* @value row 横向
* @value column 纵向
* @property {String} activeColor 选中状态的颜色
* @property {Array} options 数据源,格式为:[{title:'xxx',desc:'xxx'},{title:'xxx',desc:'xxx'}]
*/
export default {
name: 'UniSteps',
props: {
direction: {
// 排列方向 row column
type: String,
default: 'row'
},
activeColor: {
// 激活状态颜色
type: String,
default: '#2979FF'
},
deactiveColor: {
// 未激活状态颜色
type: String,
default: '#B7BDC6'
},
active: {
// 当前步骤
type: Number,
default: 0
},
activeIcon: {
// 当前步骤
type: String,
default: 'checkbox-filled'
},
options: {
type: Array,
default () {
return []
}
} // 数据
},
data() {
return {
heightArr: [],
}
},
mounted() {
//根据内容设置步骤条的长度
if (this.direction === 'column') {
let that = this;
//只能用类选择器用id选择器所获取的元素信息不准确
uni.createSelectorQuery().in(this).selectAll('.uni-steps__column-text').boundingClientRect(data => {
that.heightArr = data.map(item => item.height + 1);
}).exec()
}
},
}
</script>
<style lang="scss">
$uni-primary: #2979ff !default;
$uni-border-color: #EDEDED;
.uni-steps {
/* #ifndef APP-NVUE */
display: flex;
width: 100%;
/* #endif */
/* #ifdef APP-NVUE */
flex: 1;
/* #endif */
flex-direction: column;
}
.uni-steps__row {
/* #ifndef APP-NVUE */
display: flex;
/* #endif */
flex-direction: column;
}
.uni-steps__column {
/* #ifndef APP-NVUE */
display: flex;
/* #endif */
flex-direction: row-reverse;
}
.uni-steps__row-text-container {
/* #ifndef APP-NVUE */
display: flex;
/* #endif */
flex-direction: row;
align-items: flex-end;
margin-bottom: 8px;
}
.uni-steps__column-text-container {
/* #ifndef APP-NVUE */
display: flex;
/* #endif */
flex-direction: column;
flex: 1;
}
.uni-steps__row-text {
/* #ifndef APP-NVUE */
display: inline-flex;
/* #endif */
flex: 1;
flex-direction: column;
}
.uni-steps__column-text {
padding: 6px 0px;
border-bottom-style: solid;
border-bottom-width: 1px;
border-bottom-color: $uni-border-color;
/* #ifndef APP-NVUE */
display: flex;
/* #endif */
flex-direction: column;
}
.uni-steps__row-title {
font-size: 14px;
line-height: 16px;
text-align: center;
}
.uni-steps__column-title {
font-size: 14px;
text-align: left;
line-height: 18px;
}
.uni-steps__row-desc {
font-size: 12px;
line-height: 14px;
text-align: center;
}
.uni-steps__column-desc {
font-size: 12px;
text-align: left;
line-height: 18px;
}
.uni-steps__row-container {
/* #ifndef APP-NVUE */
display: flex;
/* #endif */
flex-direction: row;
}
.uni-steps__column-container {
/* #ifndef APP-NVUE */
display: inline-flex;
/* #endif */
width: 30px;
flex-direction: column;
}
.uni-steps__row-line-item {
/* #ifndef APP-NVUE */
display: inline-flex;
/* #endif */
flex-direction: row;
flex: 1;
height: 14px;
line-height: 14px;
align-items: center;
justify-content: center;
}
.uni-steps__column-line-item {
/* #ifndef APP-NVUE */
display: flex;
/* #endif */
flex-direction: column;
align-items: center;
justify-content: center;
}
.uni-steps__row-line {
flex: 1;
height: 1px;
background-color: #B7BDC6;
}
.uni-steps__column-line {
width: 1px;
background-color: #B7BDC6;
}
.uni-steps__row-line--after {
transform: translateX(1px);
}
.uni-steps__column-line--after {
flex: 1;
transform: translate(0px, 1px);
}
.uni-steps__row-line--before {
transform: translateX(-1px);
}
.uni-steps__column-line--before {
height: 6px;
transform: translate(0px, -13px);
}
.uni-steps__row-circle {
width: 5px;
height: 5px;
border-radius: 50%;
background-color: #B7BDC6;
margin: 0px 3px;
}
.uni-steps__column-circle {
width: 5px;
height: 5px;
border-radius: 50%;
background-color: #B7BDC6;
margin: 4px 0px 5px 0px;
}
.uni-steps__row-check {
margin: 0px 6px;
}
.uni-steps__column-check {
height: 14px;
line-height: 14px;
margin: 2px 0px;
}
</style>

View File

@@ -0,0 +1,87 @@
{
"id": "uni-steps",
"displayName": "uni-steps 步骤条",
"version": "1.1.2",
"description": "步骤条组件,提供横向和纵向两种布局格式。",
"keywords": [
"uni-ui",
"uniui",
"步骤条",
"时间轴"
],
"repository": "https://github.com/dcloudio/uni-ui",
"engines": {
"HBuilderX": ""
},
"directories": {
"example": "../../temps/example_temps"
},
"dcloudext": {
"sale": {
"regular": {
"price": "0.00"
},
"sourcecode": {
"price": "0.00"
}
},
"contact": {
"qq": ""
},
"declaration": {
"ads": "无",
"data": "无",
"permissions": "无"
},
"npmurl": "https://www.npmjs.com/package/@dcloudio/uni-ui",
"type": "component-vue"
},
"uni_modules": {
"dependencies": [
"uni-scss",
"uni-icons"
],
"encrypt": [],
"platforms": {
"cloud": {
"tcb": "y",
"aliyun": "y",
"alipay": "n"
},
"client": {
"App": {
"app-vue": "y",
"app-nvue": "y"
},
"H5-mobile": {
"Safari": "y",
"Android Browser": "y",
"微信浏览器(Android)": "y",
"QQ浏览器(Android)": "y"
},
"H5-pc": {
"Chrome": "y",
"IE": "y",
"Edge": "y",
"Firefox": "y",
"Safari": "y"
},
"小程序": {
"微信": "y",
"阿里": "y",
"百度": "y",
"字节跳动": "y",
"QQ": "y"
},
"快应用": {
"华为": "u",
"联盟": "u"
},
"Vue": {
"vue2": "y",
"vue3": "y"
}
}
}
}
}

View File

@@ -0,0 +1,13 @@
## Steps 步骤条
> **组件名uni-steps**
> 代码块: `uSteps`
步骤条,常用于显示进度
### [查看文档](https://uniapp.dcloud.io/component/uniui/uni-steps)
#### 如使用过程中有任何问题或者您对uni-ui有一些好的建议欢迎加入 uni-ui 交流群871950839