Skip to content

Commit

Permalink
Merge branch 'dev' into FE-95--feat/Share
Browse files Browse the repository at this point in the history
  • Loading branch information
LeHiHo authored Jan 21, 2024
2 parents 191b514 + c4b7935 commit 4dbaea7
Show file tree
Hide file tree
Showing 39 changed files with 562 additions and 330 deletions.
15 changes: 15 additions & 0 deletions src/@types/tours.types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -37,3 +37,18 @@ export interface TourType {
longitude?: string;
latitude?: string;
}

export interface LikedListType {
tripLikedItemId: number;
tourItemId: number;
contentTypeId: number;
title: string;
ratingAverage: number;
reviewCount: number;
smallThumbnailUrl: string;
tourAddress: string;
prefer: boolean;
notPrefer: boolean;
preferTotalCount: number;
notPreferTotalCount: number;
}
4 changes: 1 addition & 3 deletions src/api/socket.ts
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,7 @@ export const pubAddTripItem = (
destination: `/pub/trips/${tripId}/addTripItems`,
body: JSON.stringify(pubAddTripItem),
});
console.log(pubAddTripItem);
};

// 여행 아이템 예상 가격 업데이트 이벤트 발생시
Expand All @@ -101,8 +102,6 @@ export const pubUpdateTripItem = (
destination: `/pub/trips/${tripId}/updateTripItemOrder`,
body: JSON.stringify(pubUpdateTripItem),
});

console.log('데이터', pubUpdateTripItem);
};

// 여행 날짜별 교통 수단 변경 이벤트 발생시 (01/16 업데이트)
Expand Down Expand Up @@ -136,7 +135,6 @@ export const pubDeleteItem = (
destination: `/pub/tripItems/${tripItemId}/deleteItem`,
body: JSON.stringify(pubDeleteItem),
});
console.log(pubDeleteItem);
};

// 멤버 여정 페이지로 입장 이벤트 발생시
Expand Down
14 changes: 11 additions & 3 deletions src/api/trips.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,16 @@ export const getTrips = async (tripId: number) => {
};

// 여정 기본정보 수정
export const putTrips = async (tripId: number, tripsData: TripRequest) => {
const res = await client.put(`trips/${tripId}`, tripsData);
export const putTrips = async (
tripId: number,
tourItemId: number,
visitDate: string,
) => {
const requestBody = {
tourItemId: tourItemId,
visitDate: visitDate,
};
const res = await authClient.post(`trips/${tripId}`, requestBody);
return res;
};

Expand Down Expand Up @@ -46,7 +54,7 @@ export const getTripsLike = async (
};

// 우리의 관심 목록 등록
export const postTripsLike = async (tripId: number, tourItemIds: number[]) => {
export const postTripsLike = async (tripId: string, tourItemIds: number[]) => {
const requestBody = {
tourItemIds: tourItemIds,
};
Expand Down
Binary file removed src/assets/images/FifthMarker.png
Binary file not shown.
Binary file removed src/assets/images/FifthSelectedMarker.png
Binary file not shown.
Binary file removed src/assets/images/FirstMarker.png
Binary file not shown.
Binary file removed src/assets/images/FirstSelectedMarker.png
Binary file not shown.
Binary file removed src/assets/images/FourthMarker.png
Binary file not shown.
Binary file removed src/assets/images/FourthSelectedMarker.png
Binary file not shown.
Binary file removed src/assets/images/SecondMarker.png
Binary file not shown.
Binary file removed src/assets/images/SecondSelectedMarker.png
Binary file not shown.
Binary file removed src/assets/images/ThirdMarker.png
Binary file not shown.
Binary file removed src/assets/images/ThirdSelectedMarker.png
Binary file not shown.
29 changes: 29 additions & 0 deletions src/components/Plan/PlanSchedule.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
import { UserIcon } from '@components/common/icons/Icons';
import { socketContext } from '@hooks/useSocket';
import { useContext } from 'react';

const PlanSchedule = () => {
const { tripInfo } = useContext(socketContext);
const trip = tripInfo?.data;

return (
<div className="my-5">
<div className="flex items-center justify-between">
<div className="flex items-center">
<div className="title1 mb-[10px] mr-1">{trip?.tripName}</div>
<div className="flex items-center pb-[10px]">
<UserIcon size={20} fill="#888" color="#888" />
<span className="body4 pt-[1px] text-gray4">
{trip?.numberOfPeople}
</span>
</div>
</div>
</div>
<span className="body1 text-gray4">
{trip?.startDate} ~ {trip?.endDate}
</span>
</div>
);
};

export default PlanSchedule;
4 changes: 2 additions & 2 deletions src/components/Plan/PlanSectionTop.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ import { useRecoilValue, useRecoilState } from 'recoil';
import { dayState, dateState } from '@recoil/plan';
import { tripIdState, memberIdState } from '@recoil/socket';
import { calculateDayAndDate } from '@utils/utils';
import { TripSchedule } from '@components/Trip/TripSchedule';
import PlanSchedule from './PlanSchedule';

const PlanSectionTop = () => {
const navigate = useNavigate();
Expand Down Expand Up @@ -60,7 +60,7 @@ const PlanSectionTop = () => {
}}
/>
<TripRealtimeEditor />
<TripSchedule />
<PlanSchedule />
<TripBudget />
<Tab
lists={DayArr}
Expand Down
110 changes: 58 additions & 52 deletions src/components/Plan/TripBudget.tsx
Original file line number Diff line number Diff line change
@@ -1,13 +1,15 @@
import { pubUpdateBudget } from '@api/socket';
import Alert from '@components/common/alert/Alert';
import { CloseIcon, SettingIcons } from '@components/common/icons/Icons';
import { useGetTripsAuthority } from '@hooks/useGetTripsAuthority';
import { socketContext } from '@hooks/useSocket';
import * as Progress from '@radix-ui/react-progress';
import { tripIdState } from '@recoil/socket';
import { useContext, useState } from 'react';
import { useRecoilValue } from 'recoil';

const TripBudget = () => {
const { tripAuthority } = useGetTripsAuthority();
const { tripBudget } = useContext(socketContext);
const tripId = useRecoilValue(tripIdState);

Expand Down Expand Up @@ -71,63 +73,67 @@ const TripBudget = () => {
<div className="caption2 flex items-center justify-between pt-1">
<div className="flex items-center">
<span className="body5 mr-[4px] text-gray5">목표 경비</span>
<Alert
title={'비용을 입력해주세요'}
message={''}
onConfirm={() => handleSetTargetBudget(inputBudget)}
closeOnConfirm={true}
children={
<button className="text-gray3">
<SettingIcons color="#D9D9D9" />
{!budget?.budget && (
<div className="h-[31.2px] w-[141px]">
<div className="h-[27.16px] w-[141px]">
<div className="relative left-[-80px] top-8 flex h-[27.16px] w-[141px] items-center justify-center gap-[0.8043220639228821px] rounded-lg bg-[#062139] px-3 py-[7px]">
<div className="h-3.5 w-[129.36px]">
<span className="caption1 w-[129.36px] text-center text-white">
목표 경비를 입력해보세요!
</span>
{tripAuthority == 'WRITE' && (
<Alert
title={'비용을 입력해주세요'}
message={''}
onConfirm={() => handleSetTargetBudget(inputBudget)}
closeOnConfirm={true}
children={
<button className="text-gray3">
<SettingIcons color="#D9D9D9" />
{!budget?.budget && (
<div className="h-[31.2px] w-[141px]">
<div className="h-[27.16px] w-[141px]">
<div className="relative left-[-80px] top-8 flex h-[27.16px] w-[141px] items-center justify-center gap-[0.8043220639228821px] rounded-lg bg-[#062139] px-3 py-[7px]">
<div className="h-3.5 w-[129.36px]">
<span className="caption1 w-[129.36px] text-center text-white">
목표 경비를 입력해보세요!
</span>
</div>
</div>
</div>
<svg
width={12}
height={7}
viewBox="0 0 12 7"
fill="none"
xmlns="http://www.w3.org/2000/svg"
className="relative left-[-15.8px] top-0"
preserveAspectRatio="xMidYMid meet">
<path
d="M5.94048 0.136719L11.4521 6.20375L0.428827 6.20375L5.94048 0.136719Z"
fill="#062139"
/>
</svg>
</div>
)}
</button>
}
content={
<div className="mb-6 mt-8 flex w-[80%] items-center justify-between border-b-[1px] border-solid border-gray4">
<div className="flex w-full items-center justify-between">
<input
type="number"
className="title3 text-gray6 placeholder:text-gray4 focus:outline-none"
placeholder="금액"
value={inputBudget}
onChange={(e) => setInputBudget(e.target.value)}
/>
<div
className="cursor-pointer"
onClick={() => setInputBudget('')}>
{showCloseIcon && (
<CloseIcon size={16} fill="#D7D7D7" />
)}
</div>
<svg
width={12}
height={7}
viewBox="0 0 12 7"
fill="none"
xmlns="http://www.w3.org/2000/svg"
className="relative left-[-15.8px] top-0"
preserveAspectRatio="xMidYMid meet">
<path
d="M5.94048 0.136719L11.4521 6.20375L0.428827 6.20375L5.94048 0.136719Z"
fill="#062139"
/>
</svg>
</div>
)}
</button>
}
content={
<div className="mb-6 mt-8 flex w-[80%] items-center justify-between border-b-[1px] border-solid border-gray4">
<div className="flex w-full items-center justify-between">
<input
type="number"
className="title3 text-gray6 placeholder:text-gray4 focus:outline-none"
placeholder="금액"
value={inputBudget}
onChange={(e) => setInputBudget(e.target.value)}
/>
<div
className="cursor-pointer"
onClick={() => setInputBudget('')}>
{showCloseIcon && <CloseIcon size={16} fill="#D7D7D7" />}
</div>
</div>

<span className="title3 pl-[4.5px] text-gray4"></span>
</div>
}
/>
<span className="title3 pl-[4.5px] text-gray4"></span>
</div>
}
/>
)}
</div>
<div>
<span>{budget?.budget.toLocaleString() ?? '- '}</span>
Expand Down
Loading

0 comments on commit 4dbaea7

Please sign in to comment.