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
33 lines
838 B
TypeScript
33 lines
838 B
TypeScript
import { mapRewardToIcon } from "./data"
|
|
|
|
import type { LogoAndIllustrationProps } from "@scandic-hotels/design-system/Icons"
|
|
|
|
export interface RewardIconProps extends LogoAndIllustrationProps {
|
|
rewardId: string
|
|
iconSize?: "small" | "medium" | "large"
|
|
}
|
|
|
|
// Original SVG aspect ratio is 358:202 (≈1.77:1)
|
|
const sizeMap = {
|
|
small: { width: 120, height: 68 }, // 40% of card width
|
|
medium: { width: 180, height: 102 }, // 60% of card width
|
|
large: { width: 240, height: 135 }, // 80% of card width
|
|
} as const
|
|
|
|
export function RewardIcon({
|
|
rewardId,
|
|
iconSize = "medium",
|
|
...props
|
|
}: RewardIconProps) {
|
|
const IconComponent = mapRewardToIcon(rewardId)
|
|
if (!IconComponent) return null
|
|
|
|
return (
|
|
<IconComponent
|
|
{...props}
|
|
width={sizeMap[iconSize].width}
|
|
height={sizeMap[iconSize].height}
|
|
/>
|
|
)
|
|
}
|