feat(SW-160): update profile

This commit is contained in:
Simon Emanuelsson
2024-07-17 16:12:18 +02:00
committed by Michael Zetterberg
parent b6e22d51a5
commit 2337d37f1a
32 changed files with 459 additions and 244 deletions

View File

@@ -20,16 +20,16 @@ import tempRatesData from "./tempRatesData.json"
export const hotelQueryRouter = router({
getHotel: serviceProcedure
.input(getHotelInputSchema)
.query(async ({ input, ctx }) => {
.query(async ({ ctx, input }) => {
const { hotelId, language, include } = input
const params = new URLSearchParams()
const apiLang = toApiLang(language)
params.set("language", apiLang)
const params: Record<string, string> = {
hotelId,
language: apiLang,
}
if (include) {
params.set("include", include.join(","))
params.include = include.join(",")
}
const apiResponse = await api.get(
@@ -61,16 +61,16 @@ export const hotelQueryRouter = router({
const roomCategories = included
? included
.filter((item) => item.type === "roomcategories")
.map((roomCategory) => {
const validatedRoom = roomSchema.safeParse(roomCategory)
if (!validatedRoom.success) {
console.error(`Get Room Category Data - Verified Data Error`)
console.error(validatedRoom.error)
throw badRequestError()
}
return validatedRoom.data
})
.filter((item) => item.type === "roomcategories")
.map((roomCategory) => {
const validatedRoom = roomSchema.safeParse(roomCategory)
if (!validatedRoom.success) {
console.error(`Get Room Category Data - Verified Data Error`)
console.error(validatedRoom.error)
throw badRequestError()
}
return validatedRoom.data
})
: []
return {

View File

@@ -1,7 +1,6 @@
import { z } from "zod"
import { Lang } from "@/constants/languages"
// Query
export const getUserInputSchema = z
.object({
mask: z.boolean().default(true),
@@ -10,17 +9,27 @@ export const getUserInputSchema = z
export const staysInput = z
.object({
cursor: z.number().optional(),
limit: z.number().min(0).default(6),
cursor: z
.number()
.optional()
.transform((num) => (num ? String(num) : undefined)),
limit: z
.number()
.min(0)
.default(6)
.transform((num) => String(num)),
})
.default({})
export const soonestUpcomingStaysInput = z
export const friendTransactionsInput = z
.object({
limit: z.number().int().positive(),
page: z.number().int().positive(),
})
.default({ limit: 3 })
.default({ limit: 5, page: 1 })
// Mutation
export const addCreditCardInput = z.object({
language: z.string(),
})
@@ -33,9 +42,3 @@ export const saveCreditCardInput = z.object({
transactionId: z.string(),
merchantId: z.string().optional(),
})
export const friendTransactionsInput = z
.object({
limit: z.number().int().positive(),
page: z.number().int().positive(),
})
.default({ limit: 5, page: 1 })

View File

@@ -79,6 +79,7 @@ async function getVerifiedUser({ session }: { session: Session }) {
console.error(verifiedData.error)
return null
}
return verifiedData
}
@@ -335,12 +336,9 @@ export const userQueryRouter = router({
.input(staysInput)
.query(async ({ ctx, input }) => {
const { limit, cursor } = input
const params = new URLSearchParams()
params.set("limit", limit.toString())
const params: Record<string, string> = { limit }
if (cursor) {
params.set("offset", cursor.toString())
params.offset = cursor
}
const apiResponse = await api.get(
@@ -403,11 +401,9 @@ export const userQueryRouter = router({
.query(async ({ ctx, input }) => {
const { limit, cursor } = input
const params = new URLSearchParams()
params.set("limit", limit.toString())
const params: Record<string, string> = { limit }
if (cursor) {
params.set("offset", cursor.toString())
params.offset = cursor
}
const apiResponse = await api.get(