Merged in feat/membership-information (pull request #233)

Feat(WEB-307) Display correct membership information

* fix: fix typo

* chore: update fetch of user membership

* chore: update components to use api data

* chore: remove lang as static value

* fix: adapt to dev updates

* fix: adapt to code from dev

* fix: break out MembershipLevel into its a React component

* fix: add enum to zod validation

* refactor: rename tier to level

* refactor: remove unnecessary casts

* refactor: change toString() to hideEmpty=false

* refactor: remove toString()

* refactor: remove hideEmpty from title and subtitle

* fix: update currentLevel with data

* fix: fix from rebase


Approved-by: Michael Zetterberg
This commit is contained in:
Matilda Landström
2024-06-18 13:14:09 +00:00
committed by Michael Zetterberg
parent aca9221ea6
commit 9931d9edef
33 changed files with 473 additions and 357 deletions
+20
View File
@@ -0,0 +1,20 @@
import { Lang } from "@/constants/languages"
import {
MembershipLevelEnum,
membershipLevels,
} from "@/constants/membershipLevels"
import levelsData from "@/components/Loyalty/Blocks/DynamicContent/LoyaltyLevels/data"
export function getMembershipLevelObject(
membershipLevel: MembershipLevelEnum,
lang: Lang,
level: "currentLevel" | "nextLevel" = "currentLevel"
) {
let levelNumber = membershipLevels[membershipLevel]
if (level === "nextLevel") {
levelNumber += 1
}
return levelsData[lang].levels.find((level) => level.level === levelNumber)
}
+2 -1
View File
@@ -2,6 +2,7 @@ import { User } from "@/types/user"
export function getMembership(memberships: User["memberships"]) {
return memberships?.find(
(membership) => membership.membershipType.toLowerCase() === "guestpr"
(membership) =>
membership.membershipType.toLowerCase() === "guestpr" || "scandicfriend's"
)
}