feat(LOY-63): add promo code badge to campaign redeem
This commit is contained in:
@@ -5,23 +5,17 @@ import { useIntl } from "react-intl"
|
||||
import CopyIcon from "@/components/Icons/Copy"
|
||||
import Button from "@/components/TempDesignSystem/Button"
|
||||
import Body from "@/components/TempDesignSystem/Text/Body"
|
||||
import Caption from "@/components/TempDesignSystem/Text/Caption"
|
||||
import Title from "@/components/TempDesignSystem/Text/Title"
|
||||
import { toast } from "@/components/TempDesignSystem/Toasts"
|
||||
|
||||
import { RewardIcon } from "../../RewardIcon"
|
||||
import MembershipNumberBadge from "../MembershipNumberBadge"
|
||||
|
||||
import styles from "../redeem.module.css"
|
||||
|
||||
import type { RewardWithRedeem } from "@/server/routers/contentstack/reward/output"
|
||||
|
||||
export default function Campaign({
|
||||
reward,
|
||||
membershipNumber,
|
||||
}: {
|
||||
reward: RewardWithRedeem
|
||||
membershipNumber: string
|
||||
}) {
|
||||
export default function Campaign({ reward }: { reward: RewardWithRedeem }) {
|
||||
const intl = useIntl()
|
||||
|
||||
function handleCopy() {
|
||||
@@ -37,9 +31,14 @@ export default function Campaign({
|
||||
{reward.label}
|
||||
</Title>
|
||||
<Body textAlign="center">{reward.description}</Body>
|
||||
{membershipNumber && (
|
||||
<MembershipNumberBadge membershipNumber={membershipNumber} />
|
||||
)}
|
||||
<div className={styles.rewardBadge}>
|
||||
<Caption textAlign="center" color="uiTextHighContrast" type="bold">
|
||||
{intl.formatMessage({ id: "Promo code" })}
|
||||
</Caption>
|
||||
<Caption textAlign="center" color="uiTextHighContrast">
|
||||
{reward.operaRewardId}
|
||||
</Caption>
|
||||
</div>
|
||||
</div>
|
||||
<footer className={styles.modalFooter}>
|
||||
<Button
|
||||
|
||||
@@ -12,7 +12,7 @@ export default function MembershipNumberBadge({
|
||||
const intl = useIntl()
|
||||
|
||||
return (
|
||||
<div className={styles.membershipNumberBadge}>
|
||||
<div className={styles.rewardBadge}>
|
||||
<Caption textAlign="center" color="uiTextHighContrast">
|
||||
{intl.formatMessage({ id: "Membership ID:" })} {membershipNumber}
|
||||
</Caption>
|
||||
|
||||
@@ -120,7 +120,7 @@ const variants = {
|
||||
function getRedeemFlow(reward: RewardWithRedeem, membershipNumber: string) {
|
||||
switch (reward.rewardType) {
|
||||
case "Campaign":
|
||||
return <Campaign reward={reward} membershipNumber={membershipNumber} />
|
||||
return <Campaign reward={reward} />
|
||||
case "Surprise":
|
||||
case "Tier":
|
||||
return <Tier reward={reward} membershipNumber={membershipNumber} />
|
||||
|
||||
@@ -108,8 +108,10 @@
|
||||
color: var(--UI-Semantic-Success);
|
||||
}
|
||||
|
||||
.membershipNumberBadge {
|
||||
.rewardBadge {
|
||||
border-radius: var(--Corner-radius-Small);
|
||||
padding: var(--Spacing-x1) var(--Spacing-x-one-and-half);
|
||||
background: var(--Base-Surface-Secondary-light-Normal);
|
||||
display: grid;
|
||||
gap: var(--Spacing-x-half);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user