mirror of
				https://github.com/PlayEdu/backend
				synced 2025-10-26 13:05:06 +08:00 
			
		
		
		
	Compare commits
	
		
			3 Commits
		
	
	
		
			895385c4d7
			...
			fbf95bbb66
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | fbf95bbb66 | ||
|  | 9534877350 | ||
|  | 7820448c0d | 
| @@ -13,10 +13,5 @@ | ||||
|   <body> | ||||
|     <div id="root"></div> | ||||
|     <script type="module" src="/src/main.tsx"></script> | ||||
|     <script | ||||
|       crossorigin="anonymous" | ||||
|       integrity="sha512-oHrfR/z2wkuRuaHrdZ9NhoT/o/1kteub+QvmQgVzOKK7NTvIKQMvnY9+/RR0+eW311o4lAE/YzzLXXmP2XUvig==" | ||||
|       src="https://lib.baomitu.com/hls.js/1.1.4/hls.min.js" | ||||
|     ></script> | ||||
|   </body> | ||||
| </html> | ||||
|   | ||||
							
								
								
									
										
											BIN
										
									
								
								src/assets/images/commen/upload.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/assets/images/commen/upload.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 919 B | 
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 86 KiB After Width: | Height: | Size: 64 KiB | 
| @@ -17,12 +17,26 @@ export const Footer: React.FC<PropInterface> = ({ type }) => { | ||||
|         textAlign: "center", | ||||
|       }} | ||||
|     > | ||||
|       <Link to="https://playedu.xyz/" target="blank"> | ||||
|       <Link | ||||
|         to="https://playedu.xyz/" | ||||
|         style={{ | ||||
|           display: "flex", | ||||
|           alignItems: "center", | ||||
|           justifyContent: "center", | ||||
|         }} | ||||
|         target="blank" | ||||
|       > | ||||
|         <i | ||||
|           style={{ fontSize: 30, color: "#cccccc" }} | ||||
|           className="iconfont icon-waterprint footer-icon" | ||||
|           onClick={() => {}} | ||||
|         ></i> | ||||
|         <span | ||||
|           className="ml-5" | ||||
|           style={{ color: "#D7D7D7", fontSize: 12, marginTop: -5 }} | ||||
|         > | ||||
|           Version 1.5 | ||||
|         </span> | ||||
|       </Link> | ||||
|     </Layout.Footer> | ||||
|   ); | ||||
|   | ||||
| @@ -1,20 +1,8 @@ | ||||
| import { InboxOutlined } from "@ant-design/icons"; | ||||
| import { | ||||
|   Button, | ||||
|   Col, | ||||
|   message, | ||||
|   Modal, | ||||
|   Progress, | ||||
|   Row, | ||||
|   Table, | ||||
|   Tag, | ||||
|   Upload, | ||||
| } from "antd"; | ||||
| import Dragger from "antd/es/upload/Dragger"; | ||||
| import { useRef, useState } from "react"; | ||||
| import { generateUUID, parseVideo } from "../../utils"; | ||||
| import { minioMergeVideo, minioUploadId } from "../../api/upload"; | ||||
| import { UploadChunk } from "../../js/minio-upload-chunk"; | ||||
| import { useEffect, useRef, useState } from "react"; | ||||
| import { useSelector } from "react-redux"; | ||||
| import { Button } from "antd"; | ||||
| import { useDispatch } from "react-redux"; | ||||
| import { uploadAction } from "../../store/user/loginUserSlice"; | ||||
|  | ||||
| interface PropsInterface { | ||||
|   categoryIds: number[]; | ||||
| @@ -22,200 +10,32 @@ interface PropsInterface { | ||||
| } | ||||
|  | ||||
| export const UploadVideoButton = (props: PropsInterface) => { | ||||
|   const [showModal, setShowModal] = useState(false); | ||||
|   const localFileList = useRef<FileItem[]>([]); | ||||
|   const [fileList, setFileList] = useState<FileItem[]>([]); | ||||
|   const dispatch = useDispatch(); | ||||
|   const uploadStatus = useSelector( | ||||
|     (state: any) => state.loginUser.value.uploadStatus | ||||
|   ); | ||||
|  | ||||
|   const getMinioUploadId = async () => { | ||||
|     let resp: any = await minioUploadId("mp4"); | ||||
|     return resp.data; | ||||
|   }; | ||||
|  | ||||
|   const uploadProps = { | ||||
|     multiple: true, | ||||
|     beforeUpload: async (file: File) => { | ||||
|       if (file.type === "video/mp4") { | ||||
|         // 视频封面解析 || 视频时长解析 | ||||
|         let videoInfo = await parseVideo(file); | ||||
|         // 添加到本地待上传 | ||||
|         let data = await getMinioUploadId(); | ||||
|         let run = new UploadChunk(file, data["upload_id"], data["filename"]); | ||||
|         let item: FileItem = { | ||||
|           id: generateUUID(), | ||||
|           file: file, | ||||
|           upload: { | ||||
|             handler: run, | ||||
|             progress: 0, | ||||
|             status: 0, | ||||
|             remark: "", | ||||
|           }, | ||||
|           video: { | ||||
|             duration: videoInfo.duration, | ||||
|             poster: videoInfo.poster, | ||||
|           }, | ||||
|         }; | ||||
|         item.upload.handler.on("success", () => { | ||||
|           minioMergeVideo( | ||||
|             data["filename"], | ||||
|             data["upload_id"], | ||||
|             props.categoryIds.join(","), | ||||
|             item.file.name, | ||||
|             "mp4", | ||||
|             item.file.size, | ||||
|             item.video?.duration || 0, | ||||
|             item.video?.poster || "" | ||||
|           ).then(() => { | ||||
|             item.upload.progress = 100; | ||||
|             item.upload.status = item.upload.handler.getUploadStatus(); | ||||
|             setFileList([...localFileList.current]); | ||||
|           }); | ||||
|         }); | ||||
|         item.upload.handler.on("progress", (p: number) => { | ||||
|           item.upload.status = item.upload.handler.getUploadStatus(); | ||||
|           item.upload.progress = p >= 100 ? 99 : p; | ||||
|           setFileList([...localFileList.current]); | ||||
|         }); | ||||
|         item.upload.handler.on("error", (msg: string) => { | ||||
|           item.upload.status = item.upload.handler.getUploadStatus(); | ||||
|           item.upload.remark = msg; | ||||
|           setFileList([...localFileList.current]); | ||||
|         }); | ||||
|         item.upload.handler.start(); | ||||
|         // 先插入到ref | ||||
|         localFileList.current.push(item); | ||||
|         // 再更新list | ||||
|         setFileList([...localFileList.current]); | ||||
|       } else { | ||||
|         message.error(`${file.name} 并不是 mp4 视频文件`); | ||||
|       } | ||||
|       return Upload.LIST_IGNORE; | ||||
|     }, | ||||
|   }; | ||||
|  | ||||
|   const closeWin = () => { | ||||
|     if (fileList.length > 0) { | ||||
|       fileList.forEach((item) => { | ||||
|         if (item.upload.status !== 5 && item.upload.status !== 7) { | ||||
|           item.upload.handler.cancel(); | ||||
|         } | ||||
|       }); | ||||
|   useEffect(() => { | ||||
|     if (!uploadStatus) { | ||||
|       props.onUpdate(); | ||||
|     } | ||||
|     props.onUpdate(); | ||||
|     localFileList.current = []; | ||||
|     setFileList([]); | ||||
|     setShowModal(false); | ||||
|   }; | ||||
|   }, [uploadStatus]); | ||||
|  | ||||
|   return ( | ||||
|     <> | ||||
|       <Button | ||||
|         type="primary" | ||||
|         onClick={() => { | ||||
|           setShowModal(true); | ||||
|           dispatch( | ||||
|             uploadAction({ | ||||
|               uploadStatus: true, | ||||
|               uploadCateIds: props.categoryIds, | ||||
|             }) | ||||
|           ); | ||||
|         }} | ||||
|       > | ||||
|         上传视频 | ||||
|       </Button> | ||||
|  | ||||
|       {showModal ? ( | ||||
|         <Modal | ||||
|           width={800} | ||||
|           title="上传视频" | ||||
|           open={true} | ||||
|           onCancel={() => { | ||||
|             closeWin(); | ||||
|           }} | ||||
|           maskClosable={false} | ||||
|           closable={false} | ||||
|           onOk={() => { | ||||
|             closeWin(); | ||||
|           }} | ||||
|           okText="完成" | ||||
|         > | ||||
|           <Row gutter={[0, 10]}> | ||||
|             <Col span={24}> | ||||
|               <Dragger {...uploadProps}> | ||||
|                 <p className="ant-upload-drag-icon"> | ||||
|                   <InboxOutlined /> | ||||
|                 </p> | ||||
|                 <p className="ant-upload-text">请将视频拖拽到此处上传</p> | ||||
|                 <p className="ant-upload-hint"> | ||||
|                   支持一次上传多个 / 支持 mp4 格式视频 | ||||
|                 </p> | ||||
|               </Dragger> | ||||
|             </Col> | ||||
|             <Col span={24}> | ||||
|               <Table | ||||
|                 pagination={false} | ||||
|                 rowKey="id" | ||||
|                 columns={[ | ||||
|                   { | ||||
|                     title: "视频", | ||||
|                     dataIndex: "name", | ||||
|                     key: "name", | ||||
|                     render: (_, record) => <span>{record.file.name}</span>, | ||||
|                   }, | ||||
|                   { | ||||
|                     title: "大小", | ||||
|                     dataIndex: "size", | ||||
|                     key: "size", | ||||
|                     render: (_, record) => ( | ||||
|                       <span> | ||||
|                         {(record.file.size / 1024 / 1024).toFixed(2)}M | ||||
|                       </span> | ||||
|                     ), | ||||
|                   }, | ||||
|                   { | ||||
|                     title: "进度", | ||||
|                     dataIndex: "progress", | ||||
|                     key: "progress", | ||||
|                     render: (_, record: FileItem) => ( | ||||
|                       <> | ||||
|                         {record.upload.status === 0 ? ( | ||||
|                           "等待上传" | ||||
|                         ) : ( | ||||
|                           <Progress | ||||
|                             size="small" | ||||
|                             steps={20} | ||||
|                             percent={record.upload.progress} | ||||
|                           /> | ||||
|                         )} | ||||
|                       </> | ||||
|                     ), | ||||
|                   }, | ||||
|                   { | ||||
|                     title: "操作", | ||||
|                     key: "action", | ||||
|                     render: (_, record) => ( | ||||
|                       <> | ||||
|                         {record.upload.status === 5 ? ( | ||||
|                           <> | ||||
|                             <Button | ||||
|                               type="link" | ||||
|                               size="small" | ||||
|                               className="b-n-link c-red" | ||||
|                               onClick={() => { | ||||
|                                 record.upload.handler.retry(); | ||||
|                               }} | ||||
|                             > | ||||
|                               失败.重试 | ||||
|                             </Button> | ||||
|                           </> | ||||
|                         ) : null} | ||||
|  | ||||
|                         {record.upload.status === 7 ? ( | ||||
|                           <Tag color="success">上传成功</Tag> | ||||
|                         ) : null} | ||||
|                       </> | ||||
|                     ), | ||||
|                   }, | ||||
|                 ]} | ||||
|                 dataSource={fileList} | ||||
|               /> | ||||
|             </Col> | ||||
|           </Row> | ||||
|         </Modal> | ||||
|       ) : null} | ||||
|     </> | ||||
|   ); | ||||
| }; | ||||
|   | ||||
							
								
								
									
										26
									
								
								src/compenents/upload-video-float-button/index.module.less
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								src/compenents/upload-video-float-button/index.module.less
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
| .float-button { | ||||
|   width: auto; | ||||
|   height: 32px; | ||||
|   background: #ffffff; | ||||
|   box-shadow: 0px 0px 16px 0px rgba(0, 0, 0, 0.1); | ||||
|   border-radius: 16px; | ||||
|   box-sizing: border-box; | ||||
|   padding: 6px 8px; | ||||
|   display: flex; | ||||
|   align-items: center; | ||||
|   position: fixed; | ||||
|   right: 24px; | ||||
|   bottom: 20px; | ||||
|   z-index: 50; | ||||
|   cursor: pointer; | ||||
|   img { | ||||
|     width: 20px; | ||||
|     height: 20px; | ||||
|   } | ||||
|   span { | ||||
|     margin-left: 6px; | ||||
|     font-size: 12px; | ||||
|     font-weight: 400; | ||||
|     color: #ff4d4f; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										278
									
								
								src/compenents/upload-video-float-button/index.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										278
									
								
								src/compenents/upload-video-float-button/index.tsx
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,278 @@ | ||||
| import { InboxOutlined } from "@ant-design/icons"; | ||||
| import { | ||||
|   Button, | ||||
|   Col, | ||||
|   message, | ||||
|   Modal, | ||||
|   Progress, | ||||
|   Row, | ||||
|   Table, | ||||
|   Tag, | ||||
|   Upload, | ||||
| } from "antd"; | ||||
| import Dragger from "antd/es/upload/Dragger"; | ||||
| import { useEffect, useRef, useState } from "react"; | ||||
| import { generateUUID, parseVideo } from "../../utils"; | ||||
| import styles from "./index.module.less"; | ||||
| import { minioMergeVideo, minioUploadId } from "../../api/upload"; | ||||
| import { UploadChunk } from "../../js/minio-upload-chunk"; | ||||
| import { useDispatch } from "react-redux"; | ||||
| import { useSelector } from "react-redux"; | ||||
| import { uploadAction } from "../../store/user/loginUserSlice"; | ||||
| import upIcon from "../../assets/images/commen/upload.png"; | ||||
|  | ||||
| export const UploadVideoFloatButton = () => { | ||||
|   const dispatch = useDispatch(); | ||||
|   const [showModal, setShowModal] = useState(false); | ||||
|   const localFileList = useRef<FileItem[]>([]); | ||||
|   const intervalId = useRef<number>(); | ||||
|   const intervalId2 = useRef<number>(); | ||||
|   const [successNum, setSuccessNum] = useState(0); | ||||
|   const [fileList, setFileList] = useState<FileItem[]>([]); | ||||
|   const uploadStatus = useSelector( | ||||
|     (state: any) => state.loginUser.value.uploadStatus | ||||
|   ); | ||||
|   const categoryIds = useSelector( | ||||
|     (state: any) => state.loginUser.value.uploadCateIds | ||||
|   ); | ||||
|  | ||||
|   const getMinioUploadId = async () => { | ||||
|     let resp: any = await minioUploadId("mp4"); | ||||
|     return resp.data; | ||||
|   }; | ||||
|  | ||||
|   useEffect(() => { | ||||
|     if (uploadStatus) { | ||||
|       setShowModal(true); | ||||
|       intervalId.current = setInterval(() => { | ||||
|         let num = localFileList.current.filter( | ||||
|           (it) => it.upload.status === 7 | ||||
|         ).length; | ||||
|         setSuccessNum(num); | ||||
|       }, 5000); | ||||
|       let timeDiv = document.createElement("div"); | ||||
|       document.body.appendChild(timeDiv); | ||||
|       intervalId2.current = setInterval(() => { | ||||
|         timeDiv && timeDiv.click(); | ||||
|       }, 10000); | ||||
|     } else { | ||||
|       window.clearInterval(intervalId.current); | ||||
|       window.clearInterval(intervalId2.current); | ||||
|       console.log("定时器已销毁"); | ||||
|     } | ||||
|   }, [uploadStatus]); | ||||
|  | ||||
|   const uploadProps = { | ||||
|     multiple: true, | ||||
|     beforeUpload: async (file: File) => { | ||||
|       if (file.type === "video/mp4") { | ||||
|         // 视频封面解析 || 视频时长解析 | ||||
|         let videoInfo = await parseVideo(file); | ||||
|         // 添加到本地待上传 | ||||
|         let data = await getMinioUploadId(); | ||||
|         let run = new UploadChunk(file, data["upload_id"], data["filename"]); | ||||
|         let item: FileItem = { | ||||
|           id: generateUUID(), | ||||
|           file: file, | ||||
|           upload: { | ||||
|             handler: run, | ||||
|             progress: 0, | ||||
|             status: 0, | ||||
|             remark: "", | ||||
|           }, | ||||
|           video: { | ||||
|             duration: videoInfo.duration, | ||||
|             poster: videoInfo.poster, | ||||
|           }, | ||||
|         }; | ||||
|         item.upload.handler.on("success", () => { | ||||
|           minioMergeVideo( | ||||
|             data["filename"], | ||||
|             data["upload_id"], | ||||
|             categoryIds.join(","), | ||||
|             item.file.name, | ||||
|             "mp4", | ||||
|             item.file.size, | ||||
|             item.video?.duration || 0, | ||||
|             item.video?.poster || "" | ||||
|           ).then(() => { | ||||
|             item.upload.progress = 100; | ||||
|             item.upload.status = item.upload.handler.getUploadStatus(); | ||||
|             setFileList([...localFileList.current]); | ||||
|           }); | ||||
|         }); | ||||
|         item.upload.handler.on("progress", (p: number) => { | ||||
|           item.upload.status = item.upload.handler.getUploadStatus(); | ||||
|           item.upload.progress = p >= 100 ? 99 : p; | ||||
|           setFileList([...localFileList.current]); | ||||
|         }); | ||||
|         item.upload.handler.on("error", (msg: string) => { | ||||
|           item.upload.status = item.upload.handler.getUploadStatus(); | ||||
|           item.upload.remark = msg; | ||||
|           setFileList([...localFileList.current]); | ||||
|         }); | ||||
|         item.upload.handler.start(); | ||||
|         // 先插入到ref | ||||
|         localFileList.current.push(item); | ||||
|         // 再更新list | ||||
|         setFileList([...localFileList.current]); | ||||
|       } else { | ||||
|         message.error(`${file.name} 并不是 mp4 视频文件`); | ||||
|       } | ||||
|       return Upload.LIST_IGNORE; | ||||
|     }, | ||||
|   }; | ||||
|  | ||||
|   const closeWin = () => { | ||||
|     if (fileList.length > 0) { | ||||
|       fileList.forEach((item) => { | ||||
|         if (item.upload.status !== 5 && item.upload.status !== 7) { | ||||
|           item.upload.handler.cancel(); | ||||
|         } | ||||
|       }); | ||||
|     } | ||||
|     localFileList.current = []; | ||||
|     setFileList([]); | ||||
|     setSuccessNum(0); | ||||
|     setShowModal(false); | ||||
|     dispatch( | ||||
|       uploadAction({ | ||||
|         uploadStatus: false, | ||||
|         uploadCateIds: [], | ||||
|       }) | ||||
|     ); | ||||
|   }; | ||||
|  | ||||
|   return ( | ||||
|     <> | ||||
|       {uploadStatus ? ( | ||||
|         <> | ||||
|           <div | ||||
|             style={{ display: showModal ? "none" : "flex" }} | ||||
|             className={styles["float-button"]} | ||||
|             onClick={() => setShowModal(true)} | ||||
|           > | ||||
|             <img src={upIcon} /> | ||||
|             <span> | ||||
|               视频上传成功 ({successNum}/{fileList.length}) | ||||
|             </span> | ||||
|           </div> | ||||
|           <Modal | ||||
|             width={800} | ||||
|             title="上传视频" | ||||
|             open={showModal} | ||||
|             maskClosable={false} | ||||
|             footer={null} | ||||
|             onCancel={() => { | ||||
|               closeWin(); | ||||
|             }} | ||||
|           > | ||||
|             <Row gutter={[0, 10]}> | ||||
|               <Col span={24}> | ||||
|                 <Dragger {...uploadProps}> | ||||
|                   <p className="ant-upload-drag-icon"> | ||||
|                     <InboxOutlined /> | ||||
|                   </p> | ||||
|                   <p className="ant-upload-text">请将视频拖拽到此处上传</p> | ||||
|                   <p className="ant-upload-hint"> | ||||
|                     支持一次上传多个 / 支持 mp4 格式视频 | ||||
|                   </p> | ||||
|                 </Dragger> | ||||
|               </Col> | ||||
|               <Col span={24}> | ||||
|                 <Table | ||||
|                   pagination={false} | ||||
|                   rowKey="id" | ||||
|                   columns={[ | ||||
|                     { | ||||
|                       title: "视频", | ||||
|                       dataIndex: "name", | ||||
|                       key: "name", | ||||
|                       render: (_, record) => <span>{record.file.name}</span>, | ||||
|                     }, | ||||
|                     { | ||||
|                       title: "大小", | ||||
|                       dataIndex: "size", | ||||
|                       key: "size", | ||||
|                       render: (_, record) => ( | ||||
|                         <span> | ||||
|                           {(record.file.size / 1024 / 1024).toFixed(2)}M | ||||
|                         </span> | ||||
|                       ), | ||||
|                     }, | ||||
|                     { | ||||
|                       title: "进度", | ||||
|                       dataIndex: "progress", | ||||
|                       key: "progress", | ||||
|                       render: (_, record: FileItem) => ( | ||||
|                         <> | ||||
|                           {record.upload.status === 0 ? ( | ||||
|                             "等待上传" | ||||
|                           ) : ( | ||||
|                             <Progress | ||||
|                               size="small" | ||||
|                               steps={20} | ||||
|                               percent={record.upload.progress} | ||||
|                             /> | ||||
|                           )} | ||||
|                         </> | ||||
|                       ), | ||||
|                     }, | ||||
|                     { | ||||
|                       title: "操作", | ||||
|                       key: "action", | ||||
|                       render: (_, record) => ( | ||||
|                         <> | ||||
|                           {record.upload.status === 5 ? ( | ||||
|                             <> | ||||
|                               <Button | ||||
|                                 type="link" | ||||
|                                 size="small" | ||||
|                                 className="b-n-link c-red" | ||||
|                                 onClick={() => { | ||||
|                                   record.upload.handler.retry(); | ||||
|                                 }} | ||||
|                               > | ||||
|                                 失败.重试 | ||||
|                               </Button> | ||||
|                             </> | ||||
|                           ) : null} | ||||
|  | ||||
|                           {record.upload.status === 7 ? ( | ||||
|                             <Tag color="success">上传成功</Tag> | ||||
|                           ) : null} | ||||
|                         </> | ||||
|                       ), | ||||
|                     }, | ||||
|                   ]} | ||||
|                   dataSource={fileList} | ||||
|                 /> | ||||
|               </Col> | ||||
|               <Col span={24}> | ||||
|                 <div className="r-r-flex"> | ||||
|                   <Button | ||||
|                     type="primary" | ||||
|                     onClick={() => { | ||||
|                       closeWin(); | ||||
|                     }} | ||||
|                   > | ||||
|                     完成 | ||||
|                   </Button> | ||||
|                   <Button | ||||
|                     type="default" | ||||
|                     className="mr-16" | ||||
|                     onClick={() => { | ||||
|                       setShowModal(false); | ||||
|                     }} | ||||
|                   > | ||||
|                     最小化 | ||||
|                   </Button> | ||||
|                 </div> | ||||
|               </Col> | ||||
|             </Row> | ||||
|           </Modal> | ||||
|         </> | ||||
|       ) : null} | ||||
|     </> | ||||
|   ); | ||||
| }; | ||||
| @@ -187,6 +187,11 @@ code { | ||||
|   align-items: center; | ||||
| } | ||||
|  | ||||
| .r-r-flex { | ||||
|   display: flex; | ||||
|   flex-direction: row-reverse; | ||||
| } | ||||
|  | ||||
| .flex-1 { | ||||
|   flex: 1; | ||||
| } | ||||
|   | ||||
| @@ -5,6 +5,7 @@ import { | ||||
|   SystemConfigStoreInterface, | ||||
|   saveConfigAction, | ||||
| } from "../../store/system/systemConfigSlice"; | ||||
| import { UploadVideoFloatButton } from "../../compenents/upload-video-float-button"; | ||||
|  | ||||
| interface Props { | ||||
|   loginData?: any; | ||||
| @@ -36,6 +37,7 @@ const InitPage = (props: Props) => { | ||||
|   return ( | ||||
|     <> | ||||
|       <Outlet /> | ||||
|       <UploadVideoFloatButton></UploadVideoFloatButton> | ||||
|     </> | ||||
|   ); | ||||
| }; | ||||
|   | ||||
| @@ -39,9 +39,11 @@ | ||||
|       height: 100%; | ||||
|       box-sizing: border-box; | ||||
|       padding: 90px 10px 80px 30px; | ||||
|       display: flex; | ||||
|       align-items: center; | ||||
|       .icon { | ||||
|         width: 400px; | ||||
|         height: 400px; | ||||
|         height: auto; | ||||
|       } | ||||
|     } | ||||
|     .right-box { | ||||
|   | ||||
| @@ -1,4 +1,5 @@ | ||||
| import { createSlice } from "@reduxjs/toolkit"; | ||||
| import { message } from "antd"; | ||||
|  | ||||
| type UserInterface = { | ||||
|   id: number; | ||||
| @@ -10,12 +11,16 @@ type UserStoreInterface = { | ||||
|   user: UserInterface | null; | ||||
|   isLogin: boolean; | ||||
|   permissions: string[]; | ||||
|   uploadStatus: boolean; | ||||
|   uploadCateIds: number[]; | ||||
| }; | ||||
|  | ||||
| let defaultValue: UserStoreInterface = { | ||||
|   user: null, | ||||
|   isLogin: false, | ||||
|   permissions: [], | ||||
|   uploadStatus: false, | ||||
|   uploadCateIds: [], | ||||
| }; | ||||
|  | ||||
| const loginUserSlice = createSlice({ | ||||
| @@ -33,10 +38,21 @@ const loginUserSlice = createSlice({ | ||||
|       stage.value.user = null; | ||||
|       stage.value.isLogin = false; | ||||
|     }, | ||||
|     uploadAction(stage, e) { | ||||
|       if ( | ||||
|         stage.value.uploadStatus === true && | ||||
|         e.payload.uploadStatus === true | ||||
|       ) { | ||||
|         message.error("请点击右下角悬浮窗"); | ||||
|       } | ||||
|       stage.value.uploadStatus = e.payload.uploadStatus; | ||||
|       stage.value.uploadCateIds = e.payload.uploadCateIds; | ||||
|     }, | ||||
|   }, | ||||
| }); | ||||
|  | ||||
| export default loginUserSlice.reducer; | ||||
| export const { loginAction, logoutAction } = loginUserSlice.actions; | ||||
| export const { loginAction, logoutAction, uploadAction } = | ||||
|   loginUserSlice.actions; | ||||
|  | ||||
| export type { UserStoreInterface }; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user