San3yuan | 292794c | 2025-06-08 20:02:46 +0800 | [diff] [blame^] | 1 | |
| 2 | import React, { useState, useCallback, useEffect } from 'react'; |
阳菜,放晴! | 77743f4 | 2025-06-06 23:04:08 +0800 | [diff] [blame] | 3 | import styles from './corner.module.css'; |
| 4 | import { useNavigate } from 'react-router'; |
San3yuan | 30e245f | 2025-06-07 20:04:23 +0800 | [diff] [blame] | 5 | import { useSearchParams } from 'react-router-dom'; |
San3yuan | 292794c | 2025-06-08 20:02:46 +0800 | [diff] [blame^] | 6 | import { MainTag, MainPostTag } from '@/types/common'; |
| 7 | import { Button, Checkbox, Row, Col } from 'antd'; |
| 8 | import { getTagsByMainTag } from '@/utils/common'; |
| 9 | interface CornerProp { |
| 10 | |
| 11 | setTagIds: (tagIds: number[]) => void; |
| 12 | } |
| 13 | |
| 14 | const BottomRightUpload: React.FC<CornerProp> = (props:CornerProp) => { |
San3yuan | 30e245f | 2025-06-07 20:04:23 +0800 | [diff] [blame] | 15 | const [searchParams] = useSearchParams(); |
San3yuan | 292794c | 2025-06-08 20:02:46 +0800 | [diff] [blame^] | 16 | const [tags, setTags] = useState<Map<string, number>>(new Map); |
| 17 | const [selectdTags, setSelectedTags] = useState<number[]>([]) |
| 18 | const setTagIds = props.setTagIds; |
阳菜,放晴! | 77743f4 | 2025-06-06 23:04:08 +0800 | [diff] [blame] | 19 | const navigate = useNavigate(); |
San3yuan | 30e245f | 2025-06-07 20:04:23 +0800 | [diff] [blame] | 20 | const type = searchParams.get('type'); |
San3yuan | 292794c | 2025-06-08 20:02:46 +0800 | [diff] [blame^] | 21 | |
阳菜,放晴! | 77743f4 | 2025-06-06 23:04:08 +0800 | [diff] [blame] | 22 | const handleUploadClick = () => { |
San3yuan | 30e245f | 2025-06-07 20:04:23 +0800 | [diff] [blame] | 23 | navigate('/createPost', { state: { isNewPost: true, type} }); |
阳菜,放晴! | 77743f4 | 2025-06-06 23:04:08 +0800 | [diff] [blame] | 24 | }; |
San3yuan | 292794c | 2025-06-08 20:02:46 +0800 | [diff] [blame^] | 25 | useEffect(()=>{ |
| 26 | setTags(getTagsByMainTag(type as string)) |
| 27 | },[]) |
阳菜,放晴! | 77743f4 | 2025-06-06 23:04:08 +0800 | [diff] [blame] | 28 | |
| 29 | return ( |
| 30 | <div className={styles.container}> |
| 31 | <button className={styles.uploadButton} onClick={handleUploadClick}> |
| 32 | 发布种子 |
| 33 | </button> |
| 34 | |
| 35 | <div className={styles.filterItem}> |
阳菜,放晴! | 77743f4 | 2025-06-06 23:04:08 +0800 | [diff] [blame] | 36 | <label htmlFor="rating">评分:</label> |
| 37 | <select id="rating"> |
| 38 | <option value="all">全部</option> |
| 39 | <option value="high">高评分</option> |
| 40 | <option value="medium">中评分</option> |
| 41 | <option value="low">低评分</option> |
| 42 | </select> |
| 43 | </div> |
| 44 | |
| 45 | <div className={styles.filterItem}> |
| 46 | <label htmlFor="tag">标签:</label> |
San3yuan | 292794c | 2025-06-08 20:02:46 +0800 | [diff] [blame^] | 47 | <Checkbox.Group |
| 48 | value={selectdTags} |
| 49 | onChange={(checkedValues) =>{ |
| 50 | setSelectedTags([...checkedValues]) |
| 51 | }} |
| 52 | > |
| 53 | <Row gutter={[12, 12]}> |
| 54 | {[...tags.entries()].map(([name, id]) => ( |
| 55 | <Col key={id} xs={12} sm={12} md={8} lg={6}> |
| 56 | <Checkbox value={id}>{name}</Checkbox> |
| 57 | </Col> |
| 58 | ))} |
| 59 | </Row> |
| 60 | </Checkbox.Group> |
阳菜,放晴! | 77743f4 | 2025-06-06 23:04:08 +0800 | [diff] [blame] | 61 | </div> |
San3yuan | 292794c | 2025-06-08 20:02:46 +0800 | [diff] [blame^] | 62 | |
| 63 | <Button |
| 64 | color='primary' |
| 65 | variant='outlined' |
| 66 | onClick={()=>{ |
| 67 | console.log(selectdTags) |
| 68 | setTagIds([...selectdTags]) |
| 69 | |
| 70 | }} |
| 71 | > 筛选 </Button> |
| 72 | |
| 73 | <Button |
| 74 | color='danger' |
| 75 | variant='outlined' |
| 76 | onClick={()=>{ |
| 77 | setTagIds([]) |
| 78 | setSelectedTags([]) |
| 79 | }} |
| 80 | >清空筛选 |
| 81 | </Button> |
阳菜,放晴! | 77743f4 | 2025-06-06 23:04:08 +0800 | [diff] [blame] | 82 | </div> |
| 83 | ); |
| 84 | }; |
| 85 | |
| 86 | export default BottomRightUpload; |