general category trip
This commit is contained in:
@@ -192,6 +192,13 @@ export type EnumVerificationStatusWithAggregatesFilter<$PrismaModel = never> = {
|
||||
_max?: Prisma.NestedEnumVerificationStatusFilter<$PrismaModel>
|
||||
}
|
||||
|
||||
export type EnumActivityCategoryFilter<$PrismaModel = never> = {
|
||||
equals?: $Enums.ActivityCategory | Prisma.EnumActivityCategoryFieldRefInput<$PrismaModel>
|
||||
in?: $Enums.ActivityCategory[] | Prisma.ListEnumActivityCategoryFieldRefInput<$PrismaModel>
|
||||
notIn?: $Enums.ActivityCategory[] | Prisma.ListEnumActivityCategoryFieldRefInput<$PrismaModel>
|
||||
not?: Prisma.NestedEnumActivityCategoryFilter<$PrismaModel> | $Enums.ActivityCategory
|
||||
}
|
||||
|
||||
export type IntFilter<$PrismaModel = never> = {
|
||||
equals?: number | Prisma.IntFieldRefInput<$PrismaModel>
|
||||
in?: number[] | Prisma.ListIntFieldRefInput<$PrismaModel>
|
||||
@@ -210,6 +217,16 @@ export type EnumTripStatusFilter<$PrismaModel = never> = {
|
||||
not?: Prisma.NestedEnumTripStatusFilter<$PrismaModel> | $Enums.TripStatus
|
||||
}
|
||||
|
||||
export type EnumActivityCategoryWithAggregatesFilter<$PrismaModel = never> = {
|
||||
equals?: $Enums.ActivityCategory | Prisma.EnumActivityCategoryFieldRefInput<$PrismaModel>
|
||||
in?: $Enums.ActivityCategory[] | Prisma.ListEnumActivityCategoryFieldRefInput<$PrismaModel>
|
||||
notIn?: $Enums.ActivityCategory[] | Prisma.ListEnumActivityCategoryFieldRefInput<$PrismaModel>
|
||||
not?: Prisma.NestedEnumActivityCategoryWithAggregatesFilter<$PrismaModel> | $Enums.ActivityCategory
|
||||
_count?: Prisma.NestedIntFilter<$PrismaModel>
|
||||
_min?: Prisma.NestedEnumActivityCategoryFilter<$PrismaModel>
|
||||
_max?: Prisma.NestedEnumActivityCategoryFilter<$PrismaModel>
|
||||
}
|
||||
|
||||
export type IntWithAggregatesFilter<$PrismaModel = never> = {
|
||||
equals?: number | Prisma.IntFieldRefInput<$PrismaModel>
|
||||
in?: number[] | Prisma.ListIntFieldRefInput<$PrismaModel>
|
||||
@@ -444,6 +461,13 @@ export type NestedEnumVerificationStatusWithAggregatesFilter<$PrismaModel = neve
|
||||
_max?: Prisma.NestedEnumVerificationStatusFilter<$PrismaModel>
|
||||
}
|
||||
|
||||
export type NestedEnumActivityCategoryFilter<$PrismaModel = never> = {
|
||||
equals?: $Enums.ActivityCategory | Prisma.EnumActivityCategoryFieldRefInput<$PrismaModel>
|
||||
in?: $Enums.ActivityCategory[] | Prisma.ListEnumActivityCategoryFieldRefInput<$PrismaModel>
|
||||
notIn?: $Enums.ActivityCategory[] | Prisma.ListEnumActivityCategoryFieldRefInput<$PrismaModel>
|
||||
not?: Prisma.NestedEnumActivityCategoryFilter<$PrismaModel> | $Enums.ActivityCategory
|
||||
}
|
||||
|
||||
export type NestedEnumTripStatusFilter<$PrismaModel = never> = {
|
||||
equals?: $Enums.TripStatus | Prisma.EnumTripStatusFieldRefInput<$PrismaModel>
|
||||
in?: $Enums.TripStatus[] | Prisma.ListEnumTripStatusFieldRefInput<$PrismaModel>
|
||||
@@ -451,6 +475,16 @@ export type NestedEnumTripStatusFilter<$PrismaModel = never> = {
|
||||
not?: Prisma.NestedEnumTripStatusFilter<$PrismaModel> | $Enums.TripStatus
|
||||
}
|
||||
|
||||
export type NestedEnumActivityCategoryWithAggregatesFilter<$PrismaModel = never> = {
|
||||
equals?: $Enums.ActivityCategory | Prisma.EnumActivityCategoryFieldRefInput<$PrismaModel>
|
||||
in?: $Enums.ActivityCategory[] | Prisma.ListEnumActivityCategoryFieldRefInput<$PrismaModel>
|
||||
notIn?: $Enums.ActivityCategory[] | Prisma.ListEnumActivityCategoryFieldRefInput<$PrismaModel>
|
||||
not?: Prisma.NestedEnumActivityCategoryWithAggregatesFilter<$PrismaModel> | $Enums.ActivityCategory
|
||||
_count?: Prisma.NestedIntFilter<$PrismaModel>
|
||||
_min?: Prisma.NestedEnumActivityCategoryFilter<$PrismaModel>
|
||||
_max?: Prisma.NestedEnumActivityCategoryFilter<$PrismaModel>
|
||||
}
|
||||
|
||||
export type NestedIntWithAggregatesFilter<$PrismaModel = never> = {
|
||||
equals?: number | Prisma.IntFieldRefInput<$PrismaModel>
|
||||
in?: number[] | Prisma.ListIntFieldRefInput<$PrismaModel>
|
||||
|
||||
@@ -28,6 +28,22 @@ export const TripStatus = {
|
||||
export type TripStatus = (typeof TripStatus)[keyof typeof TripStatus]
|
||||
|
||||
|
||||
export const ActivityCategory = {
|
||||
HIKING: 'HIKING',
|
||||
CAMPING: 'CAMPING',
|
||||
SNORKELING: 'SNORKELING',
|
||||
DIVING: 'DIVING',
|
||||
ISLAND_HOPPING: 'ISLAND_HOPPING',
|
||||
CITY_TRIP: 'CITY_TRIP',
|
||||
CULINARY: 'CULINARY',
|
||||
CONCERT: 'CONCERT',
|
||||
WORKSHOP: 'WORKSHOP',
|
||||
RETREAT: 'RETREAT'
|
||||
} as const
|
||||
|
||||
export type ActivityCategory = (typeof ActivityCategory)[keyof typeof ActivityCategory]
|
||||
|
||||
|
||||
export const ParticipantStatus = {
|
||||
PENDING: 'PENDING',
|
||||
CONFIRMED: 'CONFIRMED',
|
||||
|
||||
File diff suppressed because one or more lines are too long
@@ -1030,7 +1030,8 @@ export const TripScalarFieldEnum = {
|
||||
id: 'id',
|
||||
title: 'title',
|
||||
description: 'description',
|
||||
mountain: 'mountain',
|
||||
category: 'category',
|
||||
destination: 'destination',
|
||||
location: 'location',
|
||||
meetingPoint: 'meetingPoint',
|
||||
itinerary: 'itinerary',
|
||||
@@ -1179,6 +1180,20 @@ export type ListEnumVerificationStatusFieldRefInput<$PrismaModel> = FieldRefInpu
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Reference to a field of type 'ActivityCategory'
|
||||
*/
|
||||
export type EnumActivityCategoryFieldRefInput<$PrismaModel> = FieldRefInputType<$PrismaModel, 'ActivityCategory'>
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Reference to a field of type 'ActivityCategory[]'
|
||||
*/
|
||||
export type ListEnumActivityCategoryFieldRefInput<$PrismaModel> = FieldRefInputType<$PrismaModel, 'ActivityCategory[]'>
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Reference to a field of type 'TripStatus'
|
||||
*/
|
||||
|
||||
@@ -139,7 +139,8 @@ export const TripScalarFieldEnum = {
|
||||
id: 'id',
|
||||
title: 'title',
|
||||
description: 'description',
|
||||
mountain: 'mountain',
|
||||
category: 'category',
|
||||
destination: 'destination',
|
||||
location: 'location',
|
||||
meetingPoint: 'meetingPoint',
|
||||
itinerary: 'itinerary',
|
||||
|
||||
@@ -40,7 +40,8 @@ export type TripMinAggregateOutputType = {
|
||||
id: string | null
|
||||
title: string | null
|
||||
description: string | null
|
||||
mountain: string | null
|
||||
category: $Enums.ActivityCategory | null
|
||||
destination: string | null
|
||||
location: string | null
|
||||
meetingPoint: string | null
|
||||
itinerary: string | null
|
||||
@@ -60,7 +61,8 @@ export type TripMaxAggregateOutputType = {
|
||||
id: string | null
|
||||
title: string | null
|
||||
description: string | null
|
||||
mountain: string | null
|
||||
category: $Enums.ActivityCategory | null
|
||||
destination: string | null
|
||||
location: string | null
|
||||
meetingPoint: string | null
|
||||
itinerary: string | null
|
||||
@@ -80,7 +82,8 @@ export type TripCountAggregateOutputType = {
|
||||
id: number
|
||||
title: number
|
||||
description: number
|
||||
mountain: number
|
||||
category: number
|
||||
destination: number
|
||||
location: number
|
||||
meetingPoint: number
|
||||
itinerary: number
|
||||
@@ -112,7 +115,8 @@ export type TripMinAggregateInputType = {
|
||||
id?: true
|
||||
title?: true
|
||||
description?: true
|
||||
mountain?: true
|
||||
category?: true
|
||||
destination?: true
|
||||
location?: true
|
||||
meetingPoint?: true
|
||||
itinerary?: true
|
||||
@@ -132,7 +136,8 @@ export type TripMaxAggregateInputType = {
|
||||
id?: true
|
||||
title?: true
|
||||
description?: true
|
||||
mountain?: true
|
||||
category?: true
|
||||
destination?: true
|
||||
location?: true
|
||||
meetingPoint?: true
|
||||
itinerary?: true
|
||||
@@ -152,7 +157,8 @@ export type TripCountAggregateInputType = {
|
||||
id?: true
|
||||
title?: true
|
||||
description?: true
|
||||
mountain?: true
|
||||
category?: true
|
||||
destination?: true
|
||||
location?: true
|
||||
meetingPoint?: true
|
||||
itinerary?: true
|
||||
@@ -259,7 +265,8 @@ export type TripGroupByOutputType = {
|
||||
id: string
|
||||
title: string
|
||||
description: string | null
|
||||
mountain: string
|
||||
category: $Enums.ActivityCategory
|
||||
destination: string
|
||||
location: string
|
||||
meetingPoint: string | null
|
||||
itinerary: string | null
|
||||
@@ -302,7 +309,8 @@ export type TripWhereInput = {
|
||||
id?: Prisma.StringFilter<"Trip"> | string
|
||||
title?: Prisma.StringFilter<"Trip"> | string
|
||||
description?: Prisma.StringNullableFilter<"Trip"> | string | null
|
||||
mountain?: Prisma.StringFilter<"Trip"> | string
|
||||
category?: Prisma.EnumActivityCategoryFilter<"Trip"> | $Enums.ActivityCategory
|
||||
destination?: Prisma.StringFilter<"Trip"> | string
|
||||
location?: Prisma.StringFilter<"Trip"> | string
|
||||
meetingPoint?: Prisma.StringNullableFilter<"Trip"> | string | null
|
||||
itinerary?: Prisma.StringNullableFilter<"Trip"> | string | null
|
||||
@@ -326,7 +334,8 @@ export type TripOrderByWithRelationInput = {
|
||||
id?: Prisma.SortOrder
|
||||
title?: Prisma.SortOrder
|
||||
description?: Prisma.SortOrderInput | Prisma.SortOrder
|
||||
mountain?: Prisma.SortOrder
|
||||
category?: Prisma.SortOrder
|
||||
destination?: Prisma.SortOrder
|
||||
location?: Prisma.SortOrder
|
||||
meetingPoint?: Prisma.SortOrderInput | Prisma.SortOrder
|
||||
itinerary?: Prisma.SortOrderInput | Prisma.SortOrder
|
||||
@@ -353,7 +362,8 @@ export type TripWhereUniqueInput = Prisma.AtLeast<{
|
||||
NOT?: Prisma.TripWhereInput | Prisma.TripWhereInput[]
|
||||
title?: Prisma.StringFilter<"Trip"> | string
|
||||
description?: Prisma.StringNullableFilter<"Trip"> | string | null
|
||||
mountain?: Prisma.StringFilter<"Trip"> | string
|
||||
category?: Prisma.EnumActivityCategoryFilter<"Trip"> | $Enums.ActivityCategory
|
||||
destination?: Prisma.StringFilter<"Trip"> | string
|
||||
location?: Prisma.StringFilter<"Trip"> | string
|
||||
meetingPoint?: Prisma.StringNullableFilter<"Trip"> | string | null
|
||||
itinerary?: Prisma.StringNullableFilter<"Trip"> | string | null
|
||||
@@ -377,7 +387,8 @@ export type TripOrderByWithAggregationInput = {
|
||||
id?: Prisma.SortOrder
|
||||
title?: Prisma.SortOrder
|
||||
description?: Prisma.SortOrderInput | Prisma.SortOrder
|
||||
mountain?: Prisma.SortOrder
|
||||
category?: Prisma.SortOrder
|
||||
destination?: Prisma.SortOrder
|
||||
location?: Prisma.SortOrder
|
||||
meetingPoint?: Prisma.SortOrderInput | Prisma.SortOrder
|
||||
itinerary?: Prisma.SortOrderInput | Prisma.SortOrder
|
||||
@@ -405,7 +416,8 @@ export type TripScalarWhereWithAggregatesInput = {
|
||||
id?: Prisma.StringWithAggregatesFilter<"Trip"> | string
|
||||
title?: Prisma.StringWithAggregatesFilter<"Trip"> | string
|
||||
description?: Prisma.StringNullableWithAggregatesFilter<"Trip"> | string | null
|
||||
mountain?: Prisma.StringWithAggregatesFilter<"Trip"> | string
|
||||
category?: Prisma.EnumActivityCategoryWithAggregatesFilter<"Trip"> | $Enums.ActivityCategory
|
||||
destination?: Prisma.StringWithAggregatesFilter<"Trip"> | string
|
||||
location?: Prisma.StringWithAggregatesFilter<"Trip"> | string
|
||||
meetingPoint?: Prisma.StringNullableWithAggregatesFilter<"Trip"> | string | null
|
||||
itinerary?: Prisma.StringNullableWithAggregatesFilter<"Trip"> | string | null
|
||||
@@ -425,7 +437,8 @@ export type TripCreateInput = {
|
||||
id?: string
|
||||
title: string
|
||||
description?: string | null
|
||||
mountain: string
|
||||
category?: $Enums.ActivityCategory
|
||||
destination: string
|
||||
location: string
|
||||
meetingPoint?: string | null
|
||||
itinerary?: string | null
|
||||
@@ -448,7 +461,8 @@ export type TripUncheckedCreateInput = {
|
||||
id?: string
|
||||
title: string
|
||||
description?: string | null
|
||||
mountain: string
|
||||
category?: $Enums.ActivityCategory
|
||||
destination: string
|
||||
location: string
|
||||
meetingPoint?: string | null
|
||||
itinerary?: string | null
|
||||
@@ -471,7 +485,8 @@ export type TripUpdateInput = {
|
||||
id?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
title?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
description?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
mountain?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
category?: Prisma.EnumActivityCategoryFieldUpdateOperationsInput | $Enums.ActivityCategory
|
||||
destination?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
location?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
meetingPoint?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
itinerary?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
@@ -494,7 +509,8 @@ export type TripUncheckedUpdateInput = {
|
||||
id?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
title?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
description?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
mountain?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
category?: Prisma.EnumActivityCategoryFieldUpdateOperationsInput | $Enums.ActivityCategory
|
||||
destination?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
location?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
meetingPoint?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
itinerary?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
@@ -517,7 +533,8 @@ export type TripCreateManyInput = {
|
||||
id?: string
|
||||
title: string
|
||||
description?: string | null
|
||||
mountain: string
|
||||
category?: $Enums.ActivityCategory
|
||||
destination: string
|
||||
location: string
|
||||
meetingPoint?: string | null
|
||||
itinerary?: string | null
|
||||
@@ -537,7 +554,8 @@ export type TripUpdateManyMutationInput = {
|
||||
id?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
title?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
description?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
mountain?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
category?: Prisma.EnumActivityCategoryFieldUpdateOperationsInput | $Enums.ActivityCategory
|
||||
destination?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
location?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
meetingPoint?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
itinerary?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
@@ -556,7 +574,8 @@ export type TripUncheckedUpdateManyInput = {
|
||||
id?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
title?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
description?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
mountain?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
category?: Prisma.EnumActivityCategoryFieldUpdateOperationsInput | $Enums.ActivityCategory
|
||||
destination?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
location?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
meetingPoint?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
itinerary?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
@@ -586,7 +605,8 @@ export type TripCountOrderByAggregateInput = {
|
||||
id?: Prisma.SortOrder
|
||||
title?: Prisma.SortOrder
|
||||
description?: Prisma.SortOrder
|
||||
mountain?: Prisma.SortOrder
|
||||
category?: Prisma.SortOrder
|
||||
destination?: Prisma.SortOrder
|
||||
location?: Prisma.SortOrder
|
||||
meetingPoint?: Prisma.SortOrder
|
||||
itinerary?: Prisma.SortOrder
|
||||
@@ -611,7 +631,8 @@ export type TripMaxOrderByAggregateInput = {
|
||||
id?: Prisma.SortOrder
|
||||
title?: Prisma.SortOrder
|
||||
description?: Prisma.SortOrder
|
||||
mountain?: Prisma.SortOrder
|
||||
category?: Prisma.SortOrder
|
||||
destination?: Prisma.SortOrder
|
||||
location?: Prisma.SortOrder
|
||||
meetingPoint?: Prisma.SortOrder
|
||||
itinerary?: Prisma.SortOrder
|
||||
@@ -631,7 +652,8 @@ export type TripMinOrderByAggregateInput = {
|
||||
id?: Prisma.SortOrder
|
||||
title?: Prisma.SortOrder
|
||||
description?: Prisma.SortOrder
|
||||
mountain?: Prisma.SortOrder
|
||||
category?: Prisma.SortOrder
|
||||
destination?: Prisma.SortOrder
|
||||
location?: Prisma.SortOrder
|
||||
meetingPoint?: Prisma.SortOrder
|
||||
itinerary?: Prisma.SortOrder
|
||||
@@ -699,6 +721,10 @@ export type TripUncheckedUpdateManyWithoutOrganizerNestedInput = {
|
||||
deleteMany?: Prisma.TripScalarWhereInput | Prisma.TripScalarWhereInput[]
|
||||
}
|
||||
|
||||
export type EnumActivityCategoryFieldUpdateOperationsInput = {
|
||||
set?: $Enums.ActivityCategory
|
||||
}
|
||||
|
||||
export type IntFieldUpdateOperationsInput = {
|
||||
set?: number
|
||||
increment?: number
|
||||
@@ -757,7 +783,8 @@ export type TripCreateWithoutOrganizerInput = {
|
||||
id?: string
|
||||
title: string
|
||||
description?: string | null
|
||||
mountain: string
|
||||
category?: $Enums.ActivityCategory
|
||||
destination: string
|
||||
location: string
|
||||
meetingPoint?: string | null
|
||||
itinerary?: string | null
|
||||
@@ -779,7 +806,8 @@ export type TripUncheckedCreateWithoutOrganizerInput = {
|
||||
id?: string
|
||||
title: string
|
||||
description?: string | null
|
||||
mountain: string
|
||||
category?: $Enums.ActivityCategory
|
||||
destination: string
|
||||
location: string
|
||||
meetingPoint?: string | null
|
||||
itinerary?: string | null
|
||||
@@ -830,7 +858,8 @@ export type TripScalarWhereInput = {
|
||||
id?: Prisma.StringFilter<"Trip"> | string
|
||||
title?: Prisma.StringFilter<"Trip"> | string
|
||||
description?: Prisma.StringNullableFilter<"Trip"> | string | null
|
||||
mountain?: Prisma.StringFilter<"Trip"> | string
|
||||
category?: Prisma.EnumActivityCategoryFilter<"Trip"> | $Enums.ActivityCategory
|
||||
destination?: Prisma.StringFilter<"Trip"> | string
|
||||
location?: Prisma.StringFilter<"Trip"> | string
|
||||
meetingPoint?: Prisma.StringNullableFilter<"Trip"> | string | null
|
||||
itinerary?: Prisma.StringNullableFilter<"Trip"> | string | null
|
||||
@@ -850,7 +879,8 @@ export type TripCreateWithoutReviewsInput = {
|
||||
id?: string
|
||||
title: string
|
||||
description?: string | null
|
||||
mountain: string
|
||||
category?: $Enums.ActivityCategory
|
||||
destination: string
|
||||
location: string
|
||||
meetingPoint?: string | null
|
||||
itinerary?: string | null
|
||||
@@ -872,7 +902,8 @@ export type TripUncheckedCreateWithoutReviewsInput = {
|
||||
id?: string
|
||||
title: string
|
||||
description?: string | null
|
||||
mountain: string
|
||||
category?: $Enums.ActivityCategory
|
||||
destination: string
|
||||
location: string
|
||||
meetingPoint?: string | null
|
||||
itinerary?: string | null
|
||||
@@ -910,7 +941,8 @@ export type TripUpdateWithoutReviewsInput = {
|
||||
id?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
title?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
description?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
mountain?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
category?: Prisma.EnumActivityCategoryFieldUpdateOperationsInput | $Enums.ActivityCategory
|
||||
destination?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
location?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
meetingPoint?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
itinerary?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
@@ -932,7 +964,8 @@ export type TripUncheckedUpdateWithoutReviewsInput = {
|
||||
id?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
title?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
description?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
mountain?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
category?: Prisma.EnumActivityCategoryFieldUpdateOperationsInput | $Enums.ActivityCategory
|
||||
destination?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
location?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
meetingPoint?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
itinerary?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
@@ -954,7 +987,8 @@ export type TripCreateWithoutImagesInput = {
|
||||
id?: string
|
||||
title: string
|
||||
description?: string | null
|
||||
mountain: string
|
||||
category?: $Enums.ActivityCategory
|
||||
destination: string
|
||||
location: string
|
||||
meetingPoint?: string | null
|
||||
itinerary?: string | null
|
||||
@@ -976,7 +1010,8 @@ export type TripUncheckedCreateWithoutImagesInput = {
|
||||
id?: string
|
||||
title: string
|
||||
description?: string | null
|
||||
mountain: string
|
||||
category?: $Enums.ActivityCategory
|
||||
destination: string
|
||||
location: string
|
||||
meetingPoint?: string | null
|
||||
itinerary?: string | null
|
||||
@@ -1014,7 +1049,8 @@ export type TripUpdateWithoutImagesInput = {
|
||||
id?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
title?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
description?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
mountain?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
category?: Prisma.EnumActivityCategoryFieldUpdateOperationsInput | $Enums.ActivityCategory
|
||||
destination?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
location?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
meetingPoint?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
itinerary?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
@@ -1036,7 +1072,8 @@ export type TripUncheckedUpdateWithoutImagesInput = {
|
||||
id?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
title?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
description?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
mountain?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
category?: Prisma.EnumActivityCategoryFieldUpdateOperationsInput | $Enums.ActivityCategory
|
||||
destination?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
location?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
meetingPoint?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
itinerary?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
@@ -1058,7 +1095,8 @@ export type TripCreateWithoutParticipantsInput = {
|
||||
id?: string
|
||||
title: string
|
||||
description?: string | null
|
||||
mountain: string
|
||||
category?: $Enums.ActivityCategory
|
||||
destination: string
|
||||
location: string
|
||||
meetingPoint?: string | null
|
||||
itinerary?: string | null
|
||||
@@ -1080,7 +1118,8 @@ export type TripUncheckedCreateWithoutParticipantsInput = {
|
||||
id?: string
|
||||
title: string
|
||||
description?: string | null
|
||||
mountain: string
|
||||
category?: $Enums.ActivityCategory
|
||||
destination: string
|
||||
location: string
|
||||
meetingPoint?: string | null
|
||||
itinerary?: string | null
|
||||
@@ -1118,7 +1157,8 @@ export type TripUpdateWithoutParticipantsInput = {
|
||||
id?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
title?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
description?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
mountain?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
category?: Prisma.EnumActivityCategoryFieldUpdateOperationsInput | $Enums.ActivityCategory
|
||||
destination?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
location?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
meetingPoint?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
itinerary?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
@@ -1140,7 +1180,8 @@ export type TripUncheckedUpdateWithoutParticipantsInput = {
|
||||
id?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
title?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
description?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
mountain?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
category?: Prisma.EnumActivityCategoryFieldUpdateOperationsInput | $Enums.ActivityCategory
|
||||
destination?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
location?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
meetingPoint?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
itinerary?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
@@ -1162,7 +1203,8 @@ export type TripCreateManyOrganizerInput = {
|
||||
id?: string
|
||||
title: string
|
||||
description?: string | null
|
||||
mountain: string
|
||||
category?: $Enums.ActivityCategory
|
||||
destination: string
|
||||
location: string
|
||||
meetingPoint?: string | null
|
||||
itinerary?: string | null
|
||||
@@ -1181,7 +1223,8 @@ export type TripUpdateWithoutOrganizerInput = {
|
||||
id?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
title?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
description?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
mountain?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
category?: Prisma.EnumActivityCategoryFieldUpdateOperationsInput | $Enums.ActivityCategory
|
||||
destination?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
location?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
meetingPoint?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
itinerary?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
@@ -1203,7 +1246,8 @@ export type TripUncheckedUpdateWithoutOrganizerInput = {
|
||||
id?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
title?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
description?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
mountain?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
category?: Prisma.EnumActivityCategoryFieldUpdateOperationsInput | $Enums.ActivityCategory
|
||||
destination?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
location?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
meetingPoint?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
itinerary?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
@@ -1225,7 +1269,8 @@ export type TripUncheckedUpdateManyWithoutOrganizerInput = {
|
||||
id?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
title?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
description?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
mountain?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
category?: Prisma.EnumActivityCategoryFieldUpdateOperationsInput | $Enums.ActivityCategory
|
||||
destination?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
location?: Prisma.StringFieldUpdateOperationsInput | string
|
||||
meetingPoint?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
itinerary?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
|
||||
@@ -1293,7 +1338,8 @@ export type TripSelect<ExtArgs extends runtime.Types.Extensions.InternalArgs = r
|
||||
id?: boolean
|
||||
title?: boolean
|
||||
description?: boolean
|
||||
mountain?: boolean
|
||||
category?: boolean
|
||||
destination?: boolean
|
||||
location?: boolean
|
||||
meetingPoint?: boolean
|
||||
itinerary?: boolean
|
||||
@@ -1318,7 +1364,8 @@ export type TripSelectCreateManyAndReturn<ExtArgs extends runtime.Types.Extensio
|
||||
id?: boolean
|
||||
title?: boolean
|
||||
description?: boolean
|
||||
mountain?: boolean
|
||||
category?: boolean
|
||||
destination?: boolean
|
||||
location?: boolean
|
||||
meetingPoint?: boolean
|
||||
itinerary?: boolean
|
||||
@@ -1339,7 +1386,8 @@ export type TripSelectUpdateManyAndReturn<ExtArgs extends runtime.Types.Extensio
|
||||
id?: boolean
|
||||
title?: boolean
|
||||
description?: boolean
|
||||
mountain?: boolean
|
||||
category?: boolean
|
||||
destination?: boolean
|
||||
location?: boolean
|
||||
meetingPoint?: boolean
|
||||
itinerary?: boolean
|
||||
@@ -1360,7 +1408,8 @@ export type TripSelectScalar = {
|
||||
id?: boolean
|
||||
title?: boolean
|
||||
description?: boolean
|
||||
mountain?: boolean
|
||||
category?: boolean
|
||||
destination?: boolean
|
||||
location?: boolean
|
||||
meetingPoint?: boolean
|
||||
itinerary?: boolean
|
||||
@@ -1376,7 +1425,7 @@ export type TripSelectScalar = {
|
||||
organizerId?: boolean
|
||||
}
|
||||
|
||||
export type TripOmit<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = runtime.Types.Extensions.GetOmit<"id" | "title" | "description" | "mountain" | "location" | "meetingPoint" | "itinerary" | "whatsIncluded" | "whatsExcluded" | "date" | "endDate" | "maxParticipants" | "price" | "status" | "createdAt" | "updatedAt" | "organizerId", ExtArgs["result"]["trip"]>
|
||||
export type TripOmit<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = runtime.Types.Extensions.GetOmit<"id" | "title" | "description" | "category" | "destination" | "location" | "meetingPoint" | "itinerary" | "whatsIncluded" | "whatsExcluded" | "date" | "endDate" | "maxParticipants" | "price" | "status" | "createdAt" | "updatedAt" | "organizerId", ExtArgs["result"]["trip"]>
|
||||
export type TripInclude<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
|
||||
organizer?: boolean | Prisma.UserDefaultArgs<ExtArgs>
|
||||
participants?: boolean | Prisma.Trip$participantsArgs<ExtArgs>
|
||||
@@ -1403,7 +1452,14 @@ export type $TripPayload<ExtArgs extends runtime.Types.Extensions.InternalArgs =
|
||||
id: string
|
||||
title: string
|
||||
description: string | null
|
||||
mountain: string
|
||||
/**
|
||||
* Kategori aktivitas.
|
||||
*/
|
||||
category: $Enums.ActivityCategory
|
||||
/**
|
||||
* Destinasi/subjek aktivitas — interpretasinya tergantung kategori (gunung untuk HIKING, spot untuk DIVING, venue untuk CONCERT, tema untuk WORKSHOP, dst).
|
||||
*/
|
||||
destination: string
|
||||
location: string
|
||||
/**
|
||||
* Titik kumpul / meeting point (teks bebas)
|
||||
@@ -1859,7 +1915,8 @@ export interface TripFieldRefs {
|
||||
readonly id: Prisma.FieldRef<"Trip", 'String'>
|
||||
readonly title: Prisma.FieldRef<"Trip", 'String'>
|
||||
readonly description: Prisma.FieldRef<"Trip", 'String'>
|
||||
readonly mountain: Prisma.FieldRef<"Trip", 'String'>
|
||||
readonly category: Prisma.FieldRef<"Trip", 'ActivityCategory'>
|
||||
readonly destination: Prisma.FieldRef<"Trip", 'String'>
|
||||
readonly location: Prisma.FieldRef<"Trip", 'String'>
|
||||
readonly meetingPoint: Prisma.FieldRef<"Trip", 'String'>
|
||||
readonly itinerary: Prisma.FieldRef<"Trip", 'String'>
|
||||
|
||||
+39
-3
@@ -4,6 +4,7 @@ import Image from "next/image";
|
||||
import { tripService } from "@/server/services/trip.service";
|
||||
import { TripCard } from "@/features/trip/components/trip-card";
|
||||
import { siteConfig, siteUrl, absoluteUrl } from "@/lib/site";
|
||||
import { ACTIVITY_CATEGORIES, categoryMeta } from "@/lib/activity-category";
|
||||
|
||||
export const metadata: Metadata = {
|
||||
title: "Cari Teman Trip & Aktivitas — Pergi Bareng, Bukan Sendiri",
|
||||
@@ -135,6 +136,38 @@ export default async function HomePage() {
|
||||
|
||||
{/* ========== CONTENT ========== */}
|
||||
<div className="mx-auto max-w-6xl px-4 py-6 space-y-8 sm:py-8 sm:space-y-10 lg:py-10 lg:space-y-12">
|
||||
{/* Jelajah per kategori */}
|
||||
<section>
|
||||
<div className="mb-4 flex items-center gap-3 sm:mb-5">
|
||||
<div className="flex h-8 w-8 items-center justify-center rounded-lg bg-secondary-100 text-base sm:h-9 sm:w-9 sm:text-lg">
|
||||
✨
|
||||
</div>
|
||||
<div>
|
||||
<h2 className="text-base font-bold text-neutral-800 sm:text-lg">
|
||||
Jelajah per Kategori
|
||||
</h2>
|
||||
<p className="text-[11px] text-neutral-500 sm:text-xs">
|
||||
Hiking, diving, konser, sampai retreat
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
||||
<div className="flex flex-wrap gap-2">
|
||||
{ACTIVITY_CATEGORIES.map((c) => {
|
||||
const m = categoryMeta(c);
|
||||
return (
|
||||
<Link
|
||||
key={c}
|
||||
href={`/trips?category=${c}`}
|
||||
className="inline-flex items-center gap-1.5 rounded-full border border-neutral-200 bg-white px-3 py-1.5 text-xs font-medium text-neutral-700 transition-colors hover:border-primary-300 hover:bg-primary-50 hover:text-primary-700"
|
||||
>
|
||||
<span>{m.icon}</span>
|
||||
<span>{m.label}</span>
|
||||
</Link>
|
||||
);
|
||||
})}
|
||||
</div>
|
||||
</section>
|
||||
|
||||
{/* Trip Terdekat */}
|
||||
{upcomingTrips.length > 0 && (
|
||||
<section>
|
||||
@@ -157,7 +190,8 @@ export default async function HomePage() {
|
||||
key={trip.id}
|
||||
id={trip.id}
|
||||
title={trip.title}
|
||||
mountain={trip.mountain}
|
||||
category={trip.category}
|
||||
destination={trip.destination}
|
||||
location={trip.location}
|
||||
date={trip.date}
|
||||
endDate={trip.endDate}
|
||||
@@ -226,7 +260,8 @@ export default async function HomePage() {
|
||||
key={trip.id}
|
||||
id={trip.id}
|
||||
title={trip.title}
|
||||
mountain={trip.mountain}
|
||||
category={trip.category}
|
||||
destination={trip.destination}
|
||||
location={trip.location}
|
||||
date={trip.date}
|
||||
endDate={trip.endDate}
|
||||
@@ -267,7 +302,8 @@ export default async function HomePage() {
|
||||
key={trip.id}
|
||||
id={trip.id}
|
||||
title={trip.title}
|
||||
mountain={trip.mountain}
|
||||
category={trip.category}
|
||||
destination={trip.destination}
|
||||
location={trip.location}
|
||||
date={trip.date}
|
||||
endDate={trip.endDate}
|
||||
|
||||
@@ -100,7 +100,7 @@ export default async function ProfilePage() {
|
||||
<ProfileTripRow
|
||||
href={`/trips/${t.id}`}
|
||||
title={t.title}
|
||||
mountain={t.mountain}
|
||||
destination={t.destination}
|
||||
date={t.date}
|
||||
endDate={t.endDate}
|
||||
rightSlot={
|
||||
@@ -147,7 +147,8 @@ export default async function ProfilePage() {
|
||||
key={trip.id}
|
||||
id={trip.id}
|
||||
title={trip.title}
|
||||
mountain={trip.mountain}
|
||||
category={trip.category}
|
||||
destination={trip.destination}
|
||||
location={trip.location}
|
||||
date={trip.date}
|
||||
endDate={trip.endDate}
|
||||
@@ -187,7 +188,7 @@ export default async function ProfilePage() {
|
||||
<ProfileTripRow
|
||||
href={`/trips/${t.id}`}
|
||||
title={t.title}
|
||||
mountain={t.mountain}
|
||||
destination={t.destination}
|
||||
date={t.date}
|
||||
endDate={t.endDate}
|
||||
rightSlot={
|
||||
@@ -225,7 +226,7 @@ export default async function ProfilePage() {
|
||||
<ProfileTripRow
|
||||
href={`/trips/${t.id}`}
|
||||
title={t.title}
|
||||
mountain={t.mountain}
|
||||
destination={t.destination}
|
||||
date={t.date}
|
||||
endDate={t.endDate}
|
||||
rightSlot={
|
||||
|
||||
@@ -121,7 +121,7 @@ export default async function TripOgImage({
|
||||
</div>
|
||||
</div>
|
||||
|
||||
{/* Middle: title + mountain */}
|
||||
{/* Middle: title + destination */}
|
||||
<div style={{ display: "flex", flexDirection: "column", gap: 16 }}>
|
||||
<div
|
||||
style={{
|
||||
@@ -146,7 +146,7 @@ export default async function TripOgImage({
|
||||
>
|
||||
<span>📍</span>
|
||||
<span>
|
||||
{trip.mountain} · {trip.location}
|
||||
{trip.destination} · {trip.location}
|
||||
</span>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
@@ -36,8 +36,8 @@ export async function generateMetadata({
|
||||
};
|
||||
}
|
||||
|
||||
const title = `${trip.title} — ${trip.mountain}`;
|
||||
const fallbackDescription = `Open trip ${trip.mountain} di ${trip.location}, ${formatTripCalendarDateRangeLong(trip.date, trip.endDate)}. Harga ${formatRupiah(trip.price)}/orang, max ${trip.maxParticipants} peserta. Gabung di ${siteConfig.name}.`;
|
||||
const title = `${trip.title} — ${trip.destination}`;
|
||||
const fallbackDescription = `Open trip ${trip.destination} di ${trip.location}, ${formatTripCalendarDateRangeLong(trip.date, trip.endDate)}. Harga ${formatRupiah(trip.price)}/orang, max ${trip.maxParticipants} peserta. Gabung di ${siteConfig.name}.`;
|
||||
const description =
|
||||
trip.description?.replace(/\s+/g, " ").trim().slice(0, 160) ||
|
||||
fallbackDescription;
|
||||
@@ -155,7 +155,7 @@ export default async function TripDetailPage({
|
||||
eventAttendanceMode: "https://schema.org/OfflineEventAttendanceMode",
|
||||
location: {
|
||||
"@type": "Place",
|
||||
name: trip.mountain,
|
||||
name: trip.destination,
|
||||
address: {
|
||||
"@type": "PostalAddress",
|
||||
addressLocality: trip.location,
|
||||
@@ -206,7 +206,7 @@ export default async function TripDetailPage({
|
||||
{
|
||||
"@type": "ListItem",
|
||||
position: 3,
|
||||
name: trip.mountain,
|
||||
name: trip.destination,
|
||||
item: tripUrl,
|
||||
},
|
||||
],
|
||||
@@ -226,7 +226,7 @@ export default async function TripDetailPage({
|
||||
Open Trip
|
||||
</Link>
|
||||
<span>/</span>
|
||||
<span className="truncate text-neutral-700">{trip.mountain}</span>
|
||||
<span className="truncate text-neutral-700">{trip.destination}</span>
|
||||
</div>
|
||||
|
||||
<div className="overflow-hidden rounded-2xl border border-neutral-200 bg-white shadow-sm">
|
||||
@@ -241,7 +241,7 @@ export default async function TripDetailPage({
|
||||
{trip.title}
|
||||
</h1>
|
||||
<p className="mt-0.5 flex items-center gap-1.5 text-sm text-neutral-500">
|
||||
🏔️ {trip.mountain}
|
||||
🏔️ {trip.destination}
|
||||
</p>
|
||||
</div>
|
||||
<span
|
||||
|
||||
+25
-7
@@ -5,21 +5,34 @@ import { tripService } from "@/server/services/trip.service";
|
||||
import { TripCard } from "@/features/trip/components/trip-card";
|
||||
import { TripFilter } from "@/features/trip/components/trip-filter";
|
||||
import { siteConfig } from "@/lib/site";
|
||||
import { categoryLabel, isActivityCategory } from "@/lib/activity-category";
|
||||
|
||||
interface TripsPageProps {
|
||||
searchParams: Promise<{ q?: string; from?: string; to?: string }>;
|
||||
searchParams: Promise<{
|
||||
q?: string;
|
||||
from?: string;
|
||||
to?: string;
|
||||
category?: string;
|
||||
}>;
|
||||
}
|
||||
|
||||
export async function generateMetadata({
|
||||
searchParams,
|
||||
}: TripsPageProps): Promise<Metadata> {
|
||||
const { q } = await searchParams;
|
||||
const { q, category: categoryParam } = await searchParams;
|
||||
const category = isActivityCategory(categoryParam) ? categoryParam : undefined;
|
||||
const categoryName = category ? categoryLabel(category) : null;
|
||||
|
||||
const title = q
|
||||
? `Cari Teman Trip "${q}" — Gabung Bareng`
|
||||
: "Cari Teman Trip & Aktivitas — Daftar Open Trip Aktif";
|
||||
: categoryName
|
||||
? `Cari Teman ${categoryName} — Daftar Open Trip Aktif`
|
||||
: "Cari Teman Trip & Aktivitas — Daftar Open Trip Aktif";
|
||||
const description = q
|
||||
? `Hasil pencarian "${q}" di ${siteConfig.name}. Temukan teman seperjalanan, lihat trip & organizer terverifikasi, langsung gabung.`
|
||||
: `Daftar open trip aktif di ${siteConfig.name} — hiking, camping, snorkeling, city trip, dan aktivitas bareng lainnya. Pilih trip, kenal calon teman seperjalanan, dan gabung bareng — grup kecil & organizer terverifikasi.`;
|
||||
: categoryName
|
||||
? `Daftar open trip ${categoryName.toLowerCase()} di ${siteConfig.name}. Pilih trip, kenal calon teman seperjalanan, dan gabung bareng — grup kecil & organizer terverifikasi.`
|
||||
: `Daftar open trip aktif di ${siteConfig.name} — hiking, camping, snorkeling, city trip, dan aktivitas bareng lainnya. Pilih trip, kenal calon teman seperjalanan, dan gabung bareng — grup kecil & organizer terverifikasi.`;
|
||||
return {
|
||||
title,
|
||||
description,
|
||||
@@ -30,11 +43,13 @@ export async function generateMetadata({
|
||||
|
||||
export default async function TripsPage({ searchParams }: TripsPageProps) {
|
||||
const params = await searchParams;
|
||||
const hasFilters = params.q || params.from || params.to;
|
||||
const category = isActivityCategory(params.category) ? params.category : undefined;
|
||||
const hasFilters = Boolean(params.q || params.from || params.to || category);
|
||||
const filters = {
|
||||
q: params.q,
|
||||
from: params.from,
|
||||
to: params.to,
|
||||
category,
|
||||
};
|
||||
|
||||
const [trips, allTrips] = await Promise.all([
|
||||
@@ -48,7 +63,9 @@ export default async function TripsPage({ searchParams }: TripsPageProps) {
|
||||
<div className="mb-6 flex flex-col gap-3 sm:mb-8 sm:flex-row sm:items-center sm:justify-between">
|
||||
<div>
|
||||
<h1 className="text-xl font-bold text-neutral-800 sm:text-2xl">
|
||||
Cari Teman Trip & Aktivitas
|
||||
{category
|
||||
? `Cari Teman ${categoryLabel(category)}`
|
||||
: "Cari Teman Trip & Aktivitas"}
|
||||
</h1>
|
||||
<p className="mt-0.5 text-sm text-neutral-500">
|
||||
{hasFilters
|
||||
@@ -102,7 +119,8 @@ export default async function TripsPage({ searchParams }: TripsPageProps) {
|
||||
key={trip.id}
|
||||
id={trip.id}
|
||||
title={trip.title}
|
||||
mountain={trip.mountain}
|
||||
category={trip.category}
|
||||
destination={trip.destination}
|
||||
location={trip.location}
|
||||
date={trip.date}
|
||||
endDate={trip.endDate}
|
||||
|
||||
Reference in New Issue
Block a user