修改发布球局
This commit is contained in:
@@ -6,6 +6,7 @@ import styles from './index.module.scss'
|
||||
import uploadFiles from '@/services/uploadFiles'
|
||||
import publishService from '@/services/publishService'
|
||||
import { usePublishBallActions } from '@/store/publishBallStore'
|
||||
import { useKeyboardHeight } from '@/store/keyboardStore'
|
||||
import images from '@/config/images'
|
||||
|
||||
export interface AiImportPopupProps {
|
||||
@@ -23,13 +24,14 @@ const AiImportPopup: React.FC<AiImportPopupProps> = ({
|
||||
const [uploadFailCount, setUploadFailCount] = useState(0)
|
||||
const [loading, setLoading] = useState(false)
|
||||
const [uploadLoading, setUploadLoading] = useState(false)
|
||||
const [keyboardHeight, setKeyboardHeight] = useState(0)
|
||||
const [isKeyboardVisible, setIsKeyboardVisible] = useState(false)
|
||||
const maxFailCount = 3
|
||||
|
||||
// 获取 actions(在组件顶层调用 Hook)
|
||||
const { setPublishData } = usePublishBallActions()
|
||||
|
||||
// 使用全局键盘状态
|
||||
const { keyboardHeight, isKeyboardVisible, addListener, initializeKeyboardListener } = useKeyboardHeight()
|
||||
|
||||
const textIdentification = async (text: string) => {
|
||||
setLoading(true)
|
||||
const res = await publishService.extract_tennis_activity({text})
|
||||
@@ -51,8 +53,6 @@ const AiImportPopup: React.FC<AiImportPopupProps> = ({
|
||||
setUploadFailCount(0)
|
||||
setLoading(false)
|
||||
setUploadLoading(false)
|
||||
setKeyboardHeight(0)
|
||||
setIsKeyboardVisible(false)
|
||||
}
|
||||
const handlePasteAndRecognize = async () => {
|
||||
if (text) {
|
||||
@@ -109,31 +109,20 @@ const AiImportPopup: React.FC<AiImportPopupProps> = ({
|
||||
setText(e.detail.value)
|
||||
}
|
||||
|
||||
// 监听键盘高度变化,保持弹窗贴合底部
|
||||
// 使用全局键盘状态监听
|
||||
useEffect(() => {
|
||||
Taro.onKeyboardHeightChange?.((res: any) => {
|
||||
const height = Number(res?.height || 0)
|
||||
if (height > 0) {
|
||||
setIsKeyboardVisible(true)
|
||||
setKeyboardHeight(height)
|
||||
} else {
|
||||
setIsKeyboardVisible(false)
|
||||
setKeyboardHeight(0)
|
||||
}
|
||||
// 初始化全局键盘监听器
|
||||
initializeKeyboardListener()
|
||||
|
||||
// 添加本地监听器
|
||||
const removeListener = addListener((height, visible) => {
|
||||
console.log('AiImportPopup 收到键盘变化:', height, visible)
|
||||
})
|
||||
|
||||
return () => {
|
||||
// Taro 里 onKeyboardHeightChange 返回的不是取消函数,这里通过置零兜底
|
||||
setIsKeyboardVisible(false)
|
||||
setKeyboardHeight(0)
|
||||
// 微信小程序环境可调用 offKeyboardHeightChange,如存在则尝试注销
|
||||
// @ts-ignore
|
||||
if (typeof Taro.offKeyboardHeightChange === 'function') {
|
||||
// @ts-ignore
|
||||
Taro.offKeyboardHeightChange()
|
||||
}
|
||||
removeListener()
|
||||
}
|
||||
}, [])
|
||||
}, [initializeKeyboardListener, addListener])
|
||||
|
||||
const handleImageRecognition = async () => {
|
||||
try {
|
||||
@@ -217,8 +206,8 @@ const AiImportPopup: React.FC<AiImportPopupProps> = ({
|
||||
className={styles.textArea}
|
||||
value={text}
|
||||
onInput={handleTextChange}
|
||||
onFocus={() => setIsKeyboardVisible(true)}
|
||||
onBlur={() => setIsKeyboardVisible(false)}
|
||||
onFocus={() => {}}
|
||||
onBlur={() => {}}
|
||||
placeholder="在此「粘贴识别」或输入文本,智能拆分球局时间、费用、地点和其他信息,并帮你智能生成球局标题"
|
||||
maxlength={100}
|
||||
showConfirmBar={false}
|
||||
|
||||
@@ -50,9 +50,9 @@ const FormBasicInfo: React.FC<FormBasicInfoProps> = ({
|
||||
// 处理场馆选择
|
||||
const handleStadiumSelect = (stadium: Stadium | null) => {
|
||||
console.log(stadium,'stadiumstadium');
|
||||
const { address, name, latitude, longitude, court_type, court_surface, description, description_tag, venue_image_list} = stadium || {};
|
||||
const { address, name, venue_id, latitude, longitude, court_type, court_surface, description, description_tag, venue_image_list} = stadium || {};
|
||||
onChange({...value,
|
||||
venue_id: stadium?.id,
|
||||
venue_id,
|
||||
location_name: name,
|
||||
location: address,
|
||||
latitude,
|
||||
|
||||
@@ -10,6 +10,7 @@ import './StadiumDetail.scss'
|
||||
|
||||
export interface Stadium {
|
||||
id?: string
|
||||
venue_id?: string
|
||||
name: string
|
||||
address?: string
|
||||
longitude?: number
|
||||
|
||||
Reference in New Issue
Block a user