mirror of
				https://github.com/task-17-lct/frontend.git
				synced 2025-10-26 22:01:02 +03:00 
			
		
		
		
	add tinder
This commit is contained in:
		
							parent
							
								
									f4aa746dc9
								
							
						
					
					
						commit
						c6e547f4d6
					
				|  | @ -58,3 +58,46 @@ export const swipe = async (itemId: string, type: string) => { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | export const dailySelectionGenerate = async () => { | ||||||
|  |     var data = await axios.get( | ||||||
|  |         origin + 'api/recommendations/get_daily_selection/', | ||||||
|  |         { | ||||||
|  |             headers: { | ||||||
|  |                 'Authorization': 'Bearer ' + localStorage.getItem('token') | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     ); | ||||||
|  |     return data.data; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | export const dailySelectionBuild = async (buildData: any) => { | ||||||
|  |     var data = await axios.post( | ||||||
|  |         origin + 'api/recommendations/generate_daily_selection/', | ||||||
|  |         {nodes: buildData}, | ||||||
|  |         { | ||||||
|  |             headers: { | ||||||
|  |                 'Authorization': 'Bearer ' + localStorage.getItem('token') | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     ); | ||||||
|  |     return data.data; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | export const saveTinderPath = async (tinderData: any) => { | ||||||
|  |     await axios.post( | ||||||
|  |         origin + 'api/route/save', { | ||||||
|  |             "points": [{ | ||||||
|  |                 date: '2000-01-01', | ||||||
|  |                 paths: tinderData | ||||||
|  |             },] | ||||||
|  |         }, | ||||||
|  |          | ||||||
|  |         { | ||||||
|  |             headers: { | ||||||
|  |                 'Authorization': 'Bearer ' + localStorage.getItem('token') | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     ) | ||||||
|  | } | ||||||
|  | @ -1,11 +1,12 @@ | ||||||
| import react, { useRef } from 'react' | import react, { useRef, useState } from 'react' | ||||||
| import TinderCard from 'react-tinder-card' | import TinderCard from 'react-tinder-card' | ||||||
| import './style.css' | import './style.css' | ||||||
| import { Block } from '../../elements/Block' | import { Block } from '../../elements/Block' | ||||||
| import { Card, TinderCardContent } from '../../elements/Card' | import { Card, TinderCardContent } from '../../elements/Card' | ||||||
| import { Button } from '../../elements/Button' | import { Button } from '../../elements/Button' | ||||||
| import { startTinder, swipe, } from '../../client' | import { dailySelectionBuild, dailySelectionGenerate, saveTinderPath, startTinder, swipe, } from '../../client' | ||||||
| import {useNavigate} from 'react-router-dom'; | import {useNavigate} from 'react-router-dom'; | ||||||
|  | import { MyMap } from '../../elements/map' | ||||||
| 
 | 
 | ||||||
| interface IEventData{ | interface IEventData{ | ||||||
|     title: string; |     title: string; | ||||||
|  | @ -18,76 +19,93 @@ export const EventMatch: react.FC = () => { | ||||||
|     const ref = useRef(null); |     const ref = useRef(null); | ||||||
|     const navigate = useNavigate(); |     const navigate = useNavigate(); | ||||||
|     const started = useRef(false); |     const started = useRef(false); | ||||||
|     const swiping = useRef(false); |     const [dailyData, setDailyData] = useState([]); | ||||||
|     const [cardData, setCardData] = react.useState({title: "", description: "", id: ''} as IEventData); |     const [resData, setResData] = useState<any[]>([]); | ||||||
|     const data  = react.useRef({title: "", description: "", id: ''} as IEventData) |     const queried = useRef(false); | ||||||
| 
 |     const [answerData, setAnswerData] = useState([]); | ||||||
| 
 | 
 | ||||||
|     if (!started.current) { |     if (!started.current) { | ||||||
|         started.current = true; |         started.current = true; | ||||||
|         startTinder().then((e) => { |         dailySelectionGenerate().then((e) => { | ||||||
|              |             console.log(e) | ||||||
|             data.current = { |             setDailyData(e.events); | ||||||
|                 title: e.title, |  | ||||||
|                 description: e.description.split(' ').slice(0, 10).join(' '), |  | ||||||
|                 id: e.oid |  | ||||||
|             }; |  | ||||||
|             setCardData({ |  | ||||||
|                 title: e.title, |  | ||||||
|                 description: e.description.split(' ').slice(0, 10).join(' '), |  | ||||||
|                 id: e.oid |  | ||||||
|             }); |  | ||||||
|         }) |         }) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|     return <div className='centered tin'> |     return <div className='centered tin'> | ||||||
|     <Block className='tinder-block'> |     <Block className='tinder-block'> | ||||||
|         <TinderCard ref={ref} onSwipe={(type) => { |  | ||||||
|             console.log("swipe"); |  | ||||||
|             if (swiping.current) return; |  | ||||||
|             swiping.current = true; |  | ||||||
|             swipe(data.current.id, type).then((e) => { |  | ||||||
|                 if (!e) { |  | ||||||
|                     navigate('/'); |  | ||||||
|                     return; |  | ||||||
|                 } |  | ||||||
|                 data.current = { |  | ||||||
|                     title: e.event.title, |  | ||||||
|                     description: e.event.description.split(' ').slice(0, 10).join(' '), |  | ||||||
|                     id: e.event.oid |  | ||||||
|                 }; |  | ||||||
|                 setCardData( |  | ||||||
|         { |         { | ||||||
|                         title: e.event.title, |             dailyData.map((e) => { | ||||||
|                         description: e.event.description.split(' ').slice(0, 10).join(' '), |                 return <TinderCard  | ||||||
|                         id: e.event.oid |                     ref={ref}  | ||||||
|  |                     className='card' | ||||||
|  |                     onSwipe={(type) => { | ||||||
|  |                         console.log(dailyData.indexOf(e)) | ||||||
|  |                         if (dailyData.indexOf(e) == 0) { | ||||||
|  |                             if (!resData.length) return; | ||||||
|  |                             if (!queried.current) { | ||||||
|  |                                 dailySelectionBuild(resData).then((e) => { | ||||||
|  |                                     setAnswerData(e.path); | ||||||
|  |                                 }); | ||||||
|  |                                 queried.current = true; | ||||||
|  |                             } | ||||||
|                         } |                         } | ||||||
|                 ); |  | ||||||
|                 setTimeout(() => { |  | ||||||
|                     (ref.current as any).restoreCard(); |  | ||||||
|                     swiping.current = false; |  | ||||||
|                 }, 2000); |  | ||||||
|             }) |  | ||||||
|                          |                          | ||||||
|         }}> |                         if (type == 'right') { | ||||||
|  |                             setResData(resData.concat([ | ||||||
|  |                                 { | ||||||
|  |                                     'action': 'right', | ||||||
|  |                                     'oid': (e as any).oid | ||||||
|  |                                 } as any | ||||||
|  |                             ])) | ||||||
|  |                         } | ||||||
|  |                          | ||||||
|  |                     }} | ||||||
|  |                 > | ||||||
|  |          | ||||||
|                     <Card className=''> |                     <Card className=''> | ||||||
|                         <TinderCardContent |                         <TinderCardContent | ||||||
|                     title={data.current.title} |                             title={dailyData.length ? (e as any).title : ""} | ||||||
|                     description={data.current.description} |                             description={dailyData.length ? (e as any).description.slice(0, 70) : ""} | ||||||
|                         ></TinderCardContent> |                         ></TinderCardContent> | ||||||
|                     </Card> |                     </Card> | ||||||
|                 </TinderCard> |                 </TinderCard> | ||||||
|     </Block> |             }) | ||||||
|  |         } | ||||||
|  |         <div className='cont-span'> | ||||||
|  |         { | ||||||
|  |             dailyData.length && !answerData.length ? | ||||||
|  |             (!queried.current ?  | ||||||
|  |             <div className='span-cont'><span className='span-er'>Вы не выбрали ни одного события, Мы не можем сгенерировать вам маршрут. Возвращяйтесь к нам завтра. <a  | ||||||
|  |             href="" onClick={() => { | ||||||
|  |                 navigate('/'); | ||||||
|  |             }} | ||||||
|  |             >Вернуться на главную</a></span></div> : <span>Подождите немного, мы генерируем для вас ежедневный маршрут</span>) : answerData.length ? <MyMap points={ | ||||||
|  |                 answerData.filter((e: any) => e.type == 'point').map((e: any) => {return { | ||||||
|  |                     cords: [e.point.lat, e.point.lon], | ||||||
|  |                     title: e.point.title, | ||||||
|  |                     description: "" | ||||||
|  |                 }}) | ||||||
|  |                  | ||||||
|  |             }></MyMap> : <></> | ||||||
|  |         } | ||||||
|  |         { | ||||||
|  |             answerData.length ? <div className='btns'> | ||||||
|  |             <Button onClick={() => { | ||||||
|  |                 saveTinderPath(answerData); | ||||||
|  |                 navigate('/'); | ||||||
|  |             }} className=''> | ||||||
|  |                 Сохранить | ||||||
|  |             </Button> | ||||||
|  |             <Button onClick={() => { | ||||||
|  |                 navigate('/'); | ||||||
|  |             }} className=''> | ||||||
|  |                 На главную | ||||||
|  |             </Button> | ||||||
|  |             </div> : <></> | ||||||
|  |         } | ||||||
|  |         </div> | ||||||
|          |          | ||||||
|     <Block className='tin-dir'> |  | ||||||
|         <Button className='' onClick={() => { |  | ||||||
|             (ref.current as any).swipe('left') |  | ||||||
|         }}>Не нравится</Button> |  | ||||||
|         <Button className='main-btn'>На главную</Button> |  | ||||||
|         <Button className='' onClick={() => { |  | ||||||
|             (ref.current as any).swipe('right') |  | ||||||
|         }}>Нравится</Button> |  | ||||||
|     </Block> |     </Block> | ||||||
|    </div> |    </div> | ||||||
| } | } | ||||||
|  | @ -7,3 +7,41 @@ | ||||||
| .main-btn{ | .main-btn{ | ||||||
|     background-color: #FFCF08; |     background-color: #FFCF08; | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | .tinder-block{ | ||||||
|  |     height: 600px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .card{ | ||||||
|  |     position: absolute; | ||||||
|  | } | ||||||
|  | .span-er{ | ||||||
|  |     width: 250px; | ||||||
|  |     text-align: center; | ||||||
|  | } | ||||||
|  | a{ | ||||||
|  |     color: black; | ||||||
|  | } | ||||||
|  | a:visited{ | ||||||
|  |     color: black; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .btns{ | ||||||
|  |     display: flex; | ||||||
|  |     flex-direction: column; | ||||||
|  |     gap: 10px; | ||||||
|  |     margin-top: 20px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .cont-span{ | ||||||
|  |     display: flex; | ||||||
|  |     justify-content: center; | ||||||
|  |     flex-direction: column; | ||||||
|  |     width: 500px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .span-cont{ | ||||||
|  |     display: flex; | ||||||
|  |     justify-content: center; | ||||||
|  |      | ||||||
|  | } | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user