Feat/LOY-400 create spend points modal * feat(LOY-400): Added custom button to my pages overview and skeleton file to custom modal for my points. * feat(LOY-400): Added custom button to my pages overview and components for custom modal for my points. * feat(LOY-400): Changed some style and infogridcardover * feat(LOY-400):Removed custom card components and changed in infoCard: Added imagePosition top, added optional height prop. In Card: Changed Text-wrap styling, added min-width styling to buttons, added optional Icon prop, added optional height prop * feat(LOY-400):Added linkList, LinkListItem component and messageBanner component. Added granola illustration. * feat(LOY-400): Removed background in several illustrations. Added component for illustration. Fixed LinkedList and styling for UsePointsButton. * feat(LOY-400): Added modal to PointsToSpendCard and fixed UsePointsButton. * fix(LOY-400):added some styling * feat(LOY-400): Linked Modal to contentstack and fetch the data in cards with UsePointsModal for now * feat(LOY-400): changed link to aria-component, cleaned up a bit * feat(LOY-400): Changed height for larger modals in mobile, fixed zod schema for no illustration input, cleaned up * fix(LOY-400): fixed graphql after rebase * fix(LOY-400): mini fix * fix(LOY-400): fixed pr-comments * fix(LOY-400): fixed some PR-comments * fix(LOY-400): fixed a PR-comment * feat(LOY-400): added size prop to ilustration in LinkListItem to be able to use illustrations in IllustrationByIconName * fix(LOY-400): fixed pr-comments * Merged in feat/LOY-402-pre-ticked-book-reward-night-in-booking-flow (pull request #3210) Feat/LOY-402 pre ticked book reward night in booking flow * feat(LOY-402): Changed UsePointsModal structure to handle button actions in card. * feat(LOY-402): added functionality for book now button * feat(LOY-400): pr comment fix * feat(LOY-402): transformed the contentstack data * fix(LOY-402): fixed pr comments Approved-by: Chuma Mcphoy (We Ahead) Approved-by: Anton Gunnarsson Approved-by: Matilda Landström * Merged in feat/LOY-404-add-tracking-for-spend-points-modal (pull request #3229) Feat/LOY-404 add tracking for spend points modal * feat(LOY-402): Changed UsePointsModal structure to handle button actions in card. * feat(LOY-402): added functionality for book now button * feat(LOY-400): pr comment fix * feat(LOY-402): transformed the contentstack data * feat(LOY-404): added tracking * fix(LOY-404): fix for session storage removal of bookNowFromPointsModal * feat(LOY-404): added consts * fix(LOY-404): moved foxusWidget const * fix(LOY-404): moved BOOKING_WIDGET_STATE const * fix(LOY-404):fix Approved-by: Matilda Landström * fix(LOY-400): some fixes * feat(LOY-400): created linkList storybook Approved-by: Chuma Mcphoy (We Ahead) Approved-by: Matilda Landström
91 lines
2.2 KiB
TypeScript
91 lines
2.2 KiB
TypeScript
import { createCounter } from "@scandic-hotels/common/telemetry"
|
|
|
|
import { router } from "../../.."
|
|
import { notFound } from "../../../errors"
|
|
import {
|
|
GetUsePointsModal,
|
|
GetUsePointsModalRefs,
|
|
} from "../../../graphql/Query/UsePointsModal.graphql"
|
|
import { request } from "../../../graphql/request"
|
|
import { contentstackBaseProcedure } from "../../../procedures"
|
|
import {
|
|
type UsePointsModalData,
|
|
type UsePointsModalRefsData,
|
|
usePointsModalRefsSchema,
|
|
usePointsModalSchema,
|
|
} from "./output"
|
|
|
|
export const usePointsModalQueryRouter = router({
|
|
get: contentstackBaseProcedure.query(async ({ ctx }) => {
|
|
const { lang, uid } = ctx
|
|
|
|
const getRefsCounter = createCounter(
|
|
"trpc.contentstack",
|
|
"usePointsModal.get.refs"
|
|
)
|
|
const metricsRefs = getRefsCounter.init({
|
|
lang,
|
|
uid,
|
|
})
|
|
|
|
metricsRefs.start()
|
|
const refsResponse = await request<UsePointsModalRefsData>(
|
|
GetUsePointsModalRefs,
|
|
{ locale: lang },
|
|
{
|
|
key: `contentstack:usePointsModal:${lang}:refs`,
|
|
ttl: "max",
|
|
}
|
|
)
|
|
if (!refsResponse.data) {
|
|
const notFoundError = notFound(refsResponse)
|
|
metricsRefs.noDataError()
|
|
throw notFoundError
|
|
}
|
|
|
|
const validatedRefsData = usePointsModalRefsSchema.safeParse(
|
|
refsResponse.data
|
|
)
|
|
|
|
if (!validatedRefsData.success) {
|
|
metricsRefs.validationError(validatedRefsData.error)
|
|
return null
|
|
}
|
|
|
|
metricsRefs.success()
|
|
|
|
const getCounter = createCounter("trpc.contentstack", "usePointsModal.get")
|
|
|
|
const metrics = getCounter.init({
|
|
lang,
|
|
uid,
|
|
})
|
|
metrics.start()
|
|
|
|
const response = await request<UsePointsModalData>(
|
|
GetUsePointsModal,
|
|
{ locale: lang },
|
|
{
|
|
key: `contentstack:usePointsModal:${lang}`,
|
|
ttl: "max",
|
|
}
|
|
)
|
|
|
|
if (!response.data) {
|
|
const notFoundError = notFound(response)
|
|
metrics.noDataError()
|
|
throw notFoundError
|
|
}
|
|
|
|
const validatedResponse = usePointsModalSchema.safeParse(response.data)
|
|
|
|
if (!validatedResponse.success) {
|
|
metrics.validationError(validatedResponse.error)
|
|
return null
|
|
}
|
|
|
|
metrics.success()
|
|
return validatedResponse.data
|
|
}),
|
|
})
|