Merged in feat/sw-2863-move-contentstack-router-to-trpc-package (pull request #2389)
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
This commit is contained in:
@@ -1,29 +1,26 @@
|
||||
import { RESTAURANT_REWARD_IDS, REWARD_IDS } from "@/constants/rewards"
|
||||
import { dt } from "@/lib/dt"
|
||||
import { dt } from "@scandic-hotels/common/dt"
|
||||
import { getReedemableCoupons } from "@scandic-hotels/trpc/routers/contentstack/reward/helpers"
|
||||
import {
|
||||
RESTAURANT_REWARD_IDS,
|
||||
type RestaurantRewardId,
|
||||
REWARD_IDS,
|
||||
type RewardId,
|
||||
} from "@scandic-hotels/trpc/types/rewards"
|
||||
|
||||
import type { Dayjs } from "dayjs"
|
||||
|
||||
import type {
|
||||
RestaurantRewardId,
|
||||
RewardId,
|
||||
} from "@/types/components/myPages/rewards"
|
||||
import type {
|
||||
ApiReward,
|
||||
RedeemableCoupon,
|
||||
RedeemLocation,
|
||||
SurpriseReward,
|
||||
} from "@/types/trpc/routers/contentstack/reward"
|
||||
} from "@scandic-hotels/trpc/types/reward"
|
||||
import type { Dayjs } from "dayjs"
|
||||
|
||||
export {
|
||||
getEarliestExpirationDate,
|
||||
getFirstRedeemableCoupon,
|
||||
getRedeemableRewards,
|
||||
getReedemableCoupons,
|
||||
getUnwrappedSurpriseRewards,
|
||||
isOnSiteTierReward,
|
||||
isRestaurantOnSiteTierReward,
|
||||
isRestaurantReward,
|
||||
isSurpriseReward,
|
||||
isTierType,
|
||||
isValidRewardId,
|
||||
redeemLocationIsOnSite,
|
||||
@@ -58,15 +55,6 @@ function isRestaurantOnSiteTierReward(reward: ApiReward): boolean {
|
||||
return isOnSiteTierReward(reward) && isRestaurantReward(reward.rewardId)
|
||||
}
|
||||
|
||||
function getReedemableCoupons(reward: ApiReward): RedeemableCoupon[] {
|
||||
if ("coupon" in reward) {
|
||||
return reward.coupon.filter(
|
||||
(coupon): coupon is RedeemableCoupon => coupon.state !== "redeemed"
|
||||
)
|
||||
}
|
||||
return []
|
||||
}
|
||||
|
||||
function getFirstRedeemableCoupon(reward: ApiReward): RedeemableCoupon {
|
||||
const sortedCoupons = getReedemableCoupons(reward).sort((a, b) => {
|
||||
// null values used instead of undefined, otherwise it will return current time
|
||||
@@ -88,37 +76,3 @@ function getEarliestExpirationDate(reward: ApiReward) {
|
||||
return earliestDate.isBefore(expiresAtDate) ? earliestDate : expiresAtDate
|
||||
}, null)
|
||||
}
|
||||
|
||||
function isSurpriseReward(reward: ApiReward): reward is SurpriseReward {
|
||||
return reward.rewardType === "Surprise"
|
||||
}
|
||||
|
||||
function getUnwrappedSurpriseRewards(rewards: ApiReward[]) {
|
||||
return rewards
|
||||
.filter(isSurpriseReward)
|
||||
.filter((reward) => getReedemableCoupons(reward).length)
|
||||
.filter((reward) => {
|
||||
const unwrappedCoupons =
|
||||
reward.coupon.filter((coupon) => !coupon.unwrapped) || []
|
||||
|
||||
return unwrappedCoupons.length
|
||||
})
|
||||
}
|
||||
|
||||
function getRedeemableRewards(rewards: ApiReward[]) {
|
||||
return rewards
|
||||
.filter((reward) => {
|
||||
if ("coupon" in reward && reward.coupon.length > 0) {
|
||||
if (reward.coupon.every((coupon) => coupon.state === "redeemed")) {
|
||||
return false
|
||||
}
|
||||
}
|
||||
return true
|
||||
})
|
||||
.filter((reward) => {
|
||||
if (isSurpriseReward(reward)) {
|
||||
return !reward.coupon.some(({ unwrapped }) => !unwrapped)
|
||||
}
|
||||
return true
|
||||
})
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user