Merged in feat/sw-2857-refactor-booking-flow-url-updates (pull request #2302)
feat(SW-2857): Refactor booking flow url updates * Add support for removing parameters when using initial values in serializeSearchParams * Don't manually write search params in rate store * Booking is already from live search params so no need * Fix input type in serializeBookingSearchParams Approved-by: Linus Flood
This commit is contained in:
@@ -450,6 +450,53 @@ describe("Serialize search params", () => {
|
||||
"city=stockholm&hotel=456&filter[0]=1831&filter[1]=1383&packages=ABC"
|
||||
)
|
||||
})
|
||||
|
||||
test("with initial search params and removing existing parameter", () => {
|
||||
const initialSearchParams = new URLSearchParams(
|
||||
"city=stockholm&hotel=123&filters=123,456,789"
|
||||
)
|
||||
const obj = {
|
||||
hotel: null,
|
||||
filters: ["123", "789"],
|
||||
}
|
||||
const result = serializeSearchParams(obj, {
|
||||
initialSearchParams,
|
||||
typeHints: {
|
||||
filters: "COMMA_SEPARATED_ARRAY",
|
||||
},
|
||||
})
|
||||
|
||||
expect(decodeURIComponent(result.toString())).toEqual(
|
||||
"city=stockholm&filters=123,789"
|
||||
)
|
||||
})
|
||||
|
||||
test("with initial search params and removing values in array", () => {
|
||||
const initialSearchParams = new URLSearchParams(
|
||||
"room[0].adults=1&room[0].rateCode=ABC&room[1].adults=2&room[2].adults=3&room[3].adults=4"
|
||||
)
|
||||
const obj = {
|
||||
room: [
|
||||
{
|
||||
adults: 1,
|
||||
rateCode: null,
|
||||
},
|
||||
{
|
||||
adults: 3,
|
||||
},
|
||||
{
|
||||
adults: 4,
|
||||
},
|
||||
],
|
||||
}
|
||||
const result = serializeSearchParams(obj, {
|
||||
initialSearchParams,
|
||||
})
|
||||
|
||||
expect(decodeURIComponent(result.toString())).toEqual(
|
||||
"room[0].adults=1&room[1].adults=3&room[2].adults=4"
|
||||
)
|
||||
})
|
||||
})
|
||||
|
||||
describe("Parse serialized search params", () => {
|
||||
|
||||
Reference in New Issue
Block a user