feat(SW-2863): Move contentstack router to trpc package * Add exports to packages and lint rule to prevent relative imports * Add env to trpc package * Add eslint to trpc package * Apply lint rules * Use direct imports from trpc package * Add lint-staged config to trpc * Move lang enum to common * Restructure trpc package folder structure * WIP first step * update internal imports in trpc * Fix most errors in scandic-web Just 100 left... * Move Props type out of trpc * Fix CategorizedFilters types * Move more schemas in hotel router * Fix deps * fix getNonContentstackUrls * Fix import error * Fix entry error handling * Fix generateMetadata metrics * Fix alertType enum * Fix duplicated types * lint:fix * Merge branch 'master' into feat/sw-2863-move-contentstack-router-to-trpc-package * Fix broken imports * Merge branch 'master' into feat/sw-2863-move-contentstack-router-to-trpc-package Approved-by: Linus Flood
64 lines
1.8 KiB
TypeScript
64 lines
1.8 KiB
TypeScript
import { z } from "zod"
|
|
|
|
import { nullableNumberValidator } from "@scandic-hotels/common/utils/zod/numberValidator"
|
|
import { nullableStringValidator } from "@scandic-hotels/common/utils/zod/stringValidator"
|
|
|
|
import { PointOfInterestGroupEnum } from "../../../../enums/pointOfInterest"
|
|
import { locationSchema } from "./location"
|
|
|
|
export const pointOfInterestSchema = z
|
|
.object({
|
|
category: z.object({
|
|
name: nullableStringValidator,
|
|
}),
|
|
distance: nullableNumberValidator,
|
|
location: locationSchema,
|
|
name: nullableStringValidator,
|
|
})
|
|
.transform((poi) => ({
|
|
categoryName: poi.category.name,
|
|
coordinates: {
|
|
lat: poi.location.latitude,
|
|
lng: poi.location.longitude,
|
|
},
|
|
distance: poi.distance,
|
|
group: getPoiGroupByCategoryName(poi.category.name),
|
|
name: poi.name,
|
|
}))
|
|
|
|
export const pointOfInterestsSchema = z
|
|
.array(pointOfInterestSchema)
|
|
.nullish()
|
|
.transform((arr) => (arr ? arr.filter(Boolean) : []))
|
|
.transform((pois) =>
|
|
pois.sort((a, b) => (a.distance ?? 0) - (b.distance ?? 0))
|
|
)
|
|
|
|
function getPoiGroupByCategoryName(category: string | undefined) {
|
|
if (!category) return PointOfInterestGroupEnum.LOCATION
|
|
switch (category) {
|
|
case "Airport":
|
|
case "Bus terminal":
|
|
case "Transportations":
|
|
return PointOfInterestGroupEnum.PUBLIC_TRANSPORT
|
|
case "Amusement park":
|
|
case "Museum":
|
|
case "Sports":
|
|
case "Theatre":
|
|
case "Tourist":
|
|
case "Zoo":
|
|
return PointOfInterestGroupEnum.ATTRACTIONS
|
|
case "Nearby companies":
|
|
case "Fair":
|
|
return PointOfInterestGroupEnum.BUSINESS
|
|
case "Parking / Garage":
|
|
return PointOfInterestGroupEnum.PARKING
|
|
case "Shopping":
|
|
case "Restaurant":
|
|
return PointOfInterestGroupEnum.SHOPPING_DINING
|
|
case "Hospital":
|
|
default:
|
|
return PointOfInterestGroupEnum.LOCATION
|
|
}
|
|
}
|