增加开启自动候补

This commit is contained in:
筱野
2025-08-18 23:34:24 +08:00
parent 4dea0f7b29
commit 3c91ee0e88
19 changed files with 629 additions and 190 deletions

View File

@@ -4,27 +4,12 @@ import Taro from '@tarojs/taro'
import ActivityTypeSwitch, { type ActivityType } from '../../components/ActivityTypeSwitch'
import PublishForm from './publishForm'
import { publishBallFormSchema } from '../../config/formSchema/publishBallFormSchema';
import { PublishBallFormData } from '../../../types/publishBall';
import './index.scss'
interface FormData {
activityType: ActivityType
title: string
timeRange: TimeRange
fee: string
location: string
gameplay: string
minParticipants: number
maxParticipants: number
ntpLevel: NTRPRange
additionalRequirements: string
autoDegrade: boolean
}
const PublishBall: React.FC = () => {
const [coverImages, setCoverImages] = useState<CoverImage[]>([])
const [showStadiumSelector, setShowStadiumSelector] = useState(false)
const [selectedStadium, setSelectedStadium] = useState<Stadium | null>(null)
const [formData, setFormData] = useState<FormData>({
const [formData, setFormData] = useState<PublishBallFormData>({
activityType: 'individual', // 默认值
title: '',
timeRange: {
@@ -37,15 +22,12 @@ const PublishBall: React.FC = () => {
gameplay: '',
minParticipants: 1,
maxParticipants: 4,
ntpLevel: { min: 2.0, max: 4.0 },
ntpLevel: [2.0, 4.0],
additionalRequirements: '',
autoDegrade: false
})
// 处理封面图片变化
const handleCoverImagesChange = (images: CoverImage[]) => {
setCoverImages(images)
}
// 更新表单数据
const updateFormData = (key: keyof FormData, value: any) => {
@@ -57,35 +39,6 @@ const PublishBall: React.FC = () => {
// 获取人数要求显示文本
const getParticipantsText = () => {
return `最少${formData.minParticipants}人,最多${formData.maxParticipants}`
}
// 处理NTRP范围变化
const handleNTRPChange = (range: NTRPRange) => {
updateFormData('ntpLevel', range)
}
// 处理时间范围变化
const handleTimeRangeChange = (timeRange: TimeRange) => {
updateFormData('timeRange', timeRange)
}
// 处理补充要求变化
const handleAdditionalRequirementsChange = (value: string) => {
updateFormData('additionalRequirements', value)
}
// 处理场馆选择
const handleStadiumSelect = (stadium: Stadium | null) => {
setSelectedStadium(stadium)
if (stadium) {
updateFormData('location', stadium.name)
}
setShowStadiumSelector(false)
}
// 处理活动类型变化
const handleActivityTypeChange = (type: ActivityType) => {
updateFormData('activityType', type)
@@ -104,17 +57,7 @@ const PublishBall: React.FC = () => {
})
return
}
if (coverImages.length === 0) {
Taro.showToast({
title: '请至少上传一张活动封面',
icon: 'none'
})
return
}
// TODO: 实现提交逻辑
console.log('提交数据:', { coverImages, formData })
Taro.showToast({
title: '发布成功',