igloo-d2c-components 1.0.13 → 1.0.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (115) hide show
  1. package/README.md +1151 -321
  2. package/dist/assets/icons/alert.svg +5 -0
  3. package/dist/assets/icons/arrow-down.svg +3 -0
  4. package/dist/assets/icons/arrow.svg +9 -0
  5. package/dist/assets/icons/close.svg +4 -0
  6. package/dist/assets/icons/facebook.svg +3 -0
  7. package/dist/assets/icons/index.ts +26 -0
  8. package/dist/assets/icons/instagram.svg +11 -0
  9. package/dist/assets/icons/youtube.svg +11 -0
  10. package/dist/assets/index.ts +13 -0
  11. package/dist/assets/tenants/ammetlife/logo.svg +10 -0
  12. package/dist/assets/tenants/cimb/logo-white.png +0 -0
  13. package/dist/assets/tenants/cimb/logo.svg +62 -0
  14. package/dist/assets/tenants/igloo/logo.svg +22 -0
  15. package/dist/cjs/index.js +2804 -41
  16. package/dist/cjs/index.js.map +1 -1
  17. package/dist/esm/index.js +2752 -41
  18. package/dist/esm/index.js.map +1 -1
  19. package/dist/types/assets/icons/index.d.ts +21 -0
  20. package/dist/types/assets/index.d.ts +9 -0
  21. package/dist/types/components/BenefitsSummary/BenefitsSummary.d.ts +22 -0
  22. package/dist/types/components/BenefitsSummary/index.d.ts +2 -0
  23. package/dist/types/components/BenefitsSummary/styled.d.ts +29 -0
  24. package/dist/types/components/BenefitsSummary/types.d.ts +58 -0
  25. package/dist/types/components/BillingToggle/BillingToggle.d.ts +34 -0
  26. package/dist/types/components/BillingToggle/index.d.ts +3 -0
  27. package/dist/types/components/BillingToggle/styled.d.ts +12 -0
  28. package/dist/types/components/CheckoutFormButton/CheckoutFormButton.d.ts +39 -0
  29. package/dist/types/components/CheckoutFormButton/index.d.ts +2 -0
  30. package/dist/types/components/CheckoutFormButton/styled.d.ts +9 -0
  31. package/dist/types/components/CheckoutHeader/CheckoutHeader.d.ts +41 -0
  32. package/dist/types/components/CheckoutHeader/index.d.ts +2 -0
  33. package/dist/types/components/CheckoutHeader/styled.d.ts +15 -0
  34. package/dist/types/components/CheckoutProgress/CheckoutProgress.d.ts +35 -0
  35. package/dist/types/components/CheckoutProgress/index.d.ts +2 -0
  36. package/dist/types/components/CheckoutProgress/styled.d.ts +16 -0
  37. package/dist/types/components/ChildInformationForm/ChildInformationForm.d.ts +52 -0
  38. package/dist/types/components/ChildInformationForm/index.d.ts +2 -0
  39. package/dist/types/components/ChildInformationForm/styled.d.ts +4 -0
  40. package/dist/types/components/ContactDetailsForm/ContactDetailsForm.d.ts +63 -0
  41. package/dist/types/components/ContactDetailsForm/index.d.ts +2 -0
  42. package/dist/types/components/ContactDetailsForm/styled.d.ts +10 -0
  43. package/dist/types/components/CoverageAmountSlider/CoverageAmountSlider.d.ts +57 -0
  44. package/dist/types/components/CoverageAmountSlider/index.d.ts +3 -0
  45. package/dist/types/components/CoverageAmountSlider/styled.d.ts +50 -0
  46. package/dist/types/components/FAQAccordion/FAQAccordion.d.ts +22 -0
  47. package/dist/types/components/FAQAccordion/index.d.ts +2 -0
  48. package/dist/types/components/FAQAccordion/styled.d.ts +37 -0
  49. package/dist/types/components/FAQAccordion/types.d.ts +57 -0
  50. package/dist/types/components/Footer/Footer.d.ts +94 -0
  51. package/dist/types/components/Footer/index.d.ts +3 -0
  52. package/dist/types/components/Footer/styled.d.ts +38 -0
  53. package/dist/types/components/Header/Header.d.ts +159 -0
  54. package/dist/types/components/Header/index.d.ts +3 -0
  55. package/dist/types/components/Header/styled.d.ts +80 -0
  56. package/dist/types/components/HealthInformationForm/HealthInformationForm.d.ts +81 -0
  57. package/dist/types/components/HealthInformationForm/index.d.ts +2 -0
  58. package/dist/types/components/HealthInformationForm/styled.d.ts +4 -0
  59. package/dist/types/components/HealthQuestionGroup/HealthQuestionGroup.d.ts +40 -0
  60. package/dist/types/components/HealthQuestionGroup/index.d.ts +2 -0
  61. package/dist/types/components/HealthQuestionGroup/styled.d.ts +20 -0
  62. package/dist/types/components/InfoCallout/InfoCallout.d.ts +34 -0
  63. package/dist/types/components/InfoCallout/index.d.ts +3 -0
  64. package/dist/types/components/InfoCallout/styled.d.ts +16 -0
  65. package/dist/types/components/NewHeader/NewHeader.d.ts +60 -0
  66. package/dist/types/components/NewHeader/index.d.ts +3 -0
  67. package/dist/types/components/NewHeader/styled.d.ts +26 -0
  68. package/dist/types/components/OptionButton/OptionButton.d.ts +59 -0
  69. package/dist/types/components/OptionButton/index.d.ts +3 -0
  70. package/dist/types/components/OptionButton/styled.d.ts +18 -0
  71. package/dist/types/components/PersonalInformationForm/PersonalInformationForm.d.ts +75 -0
  72. package/dist/types/components/PersonalInformationForm/index.d.ts +2 -0
  73. package/dist/types/components/PersonalInformationForm/styled.d.ts +10 -0
  74. package/dist/types/components/ProductCard/ProductCard.d.ts +43 -0
  75. package/dist/types/components/ProductCard/index.d.ts +2 -0
  76. package/dist/types/components/ProductCard/styled.d.ts +27 -0
  77. package/dist/types/components/ProductSelectionDrawer/ProductSelectionDrawer.d.ts +54 -0
  78. package/dist/types/components/ProductSelectionDrawer/index.d.ts +3 -0
  79. package/dist/types/components/ProductSelectionDrawer/styled.d.ts +44 -0
  80. package/dist/types/components/QuestionSection/QuestionSection.d.ts +71 -0
  81. package/dist/types/components/QuestionSection/index.d.ts +3 -0
  82. package/dist/types/components/QuestionSection/styled.d.ts +16 -0
  83. package/dist/types/components/RecommendationsDrawer/RecommendationsDrawer.d.ts +92 -0
  84. package/dist/types/components/RecommendationsDrawer/index.d.ts +3 -0
  85. package/dist/types/components/RecommendationsDrawer/styled.d.ts +35 -0
  86. package/dist/types/components/ToggleGroup/ToggleGroup.d.ts +45 -0
  87. package/dist/types/components/ToggleGroup/index.d.ts +3 -0
  88. package/dist/types/components/ToggleGroup/styled.d.ts +17 -0
  89. package/dist/types/context/TenantThemeContext.d.ts +3 -2
  90. package/dist/types/index.d.ts +52 -4
  91. package/dist/types/{components/Banner → storybook-components}/Banner.stories.d.ts +1 -1
  92. package/dist/types/storybook-components/BenefitsSummary.stories.d.ts +37 -0
  93. package/dist/types/storybook-components/BillingToggle.stories.d.ts +10 -0
  94. package/dist/types/{components/Button → storybook-components}/Button.stories.d.ts +1 -1
  95. package/dist/types/{components/Card → storybook-components}/Card.stories.d.ts +1 -1
  96. package/dist/types/storybook-components/CheckoutProgress.stories.d.ts +9 -0
  97. package/dist/types/storybook-components/CoverageAmountSlider.stories.d.ts +14 -0
  98. package/dist/types/storybook-components/FAQAccordion.stories.d.ts +37 -0
  99. package/dist/types/storybook-components/Footer.stories.d.ts +10 -0
  100. package/dist/types/storybook-components/Header.stories.d.ts +9 -0
  101. package/dist/types/storybook-components/HealthQuestionGroup.stories.d.ts +9 -0
  102. package/dist/types/storybook-components/InfoCallout.stories.d.ts +11 -0
  103. package/dist/types/storybook-components/NewHeader.stories.d.ts +82 -0
  104. package/dist/types/storybook-components/OptionButton.stories.d.ts +12 -0
  105. package/dist/types/storybook-components/ProductCard.stories.d.ts +9 -0
  106. package/dist/types/storybook-components/ProductSelectionDrawer.stories.d.ts +24 -0
  107. package/dist/types/storybook-components/QuestionSection.stories.d.ts +11 -0
  108. package/dist/types/storybook-components/RecommendationsDrawer.stories.d.ts +36 -0
  109. package/dist/types/storybook-components/ToggleGroup.stories.d.ts +10 -0
  110. package/dist/types/themes/index.d.ts +1 -1
  111. package/dist/types/themes/typography.d.ts +69 -0
  112. package/dist/types/types/tenant.d.ts +23 -2
  113. package/dist/types/utils/assets.d.ts +54 -0
  114. package/dist/types/utils/theme.d.ts +3 -2
  115. package/package.json +4 -2
@@ -0,0 +1,45 @@
1
+ /**
2
+ * ToggleGroup Component
3
+ * Toggle button group for selecting between options (e.g., Domestic/International)
4
+ */
5
+ export interface ToggleOption {
6
+ value: string;
7
+ label: string;
8
+ icon?: string;
9
+ }
10
+ export interface ToggleGroupProps {
11
+ /**
12
+ * Available options
13
+ */
14
+ options: ToggleOption[];
15
+ /**
16
+ * Currently selected value
17
+ */
18
+ value: string;
19
+ /**
20
+ * Callback when value changes
21
+ */
22
+ onChange: (value: string) => void;
23
+ /**
24
+ * Format message function for i18n
25
+ */
26
+ formatMessage?: (descriptor: {
27
+ id: string;
28
+ }) => string;
29
+ }
30
+ /**
31
+ * ToggleGroup - Segmented control for switching between options
32
+ *
33
+ * @example
34
+ * ```tsx
35
+ * <ToggleGroup
36
+ * options={[
37
+ * { value: 'domestic', label: 'Domestic', icon: '🏠' },
38
+ * { value: 'international', label: 'International', icon: '✈️' }
39
+ * ]}
40
+ * value={selectedType}
41
+ * onChange={setSelectedType}
42
+ * />
43
+ * ```
44
+ */
45
+ export declare function ToggleGroup({ options, value, onChange, formatMessage, }: ToggleGroupProps): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,3 @@
1
+ export { ToggleGroup } from './ToggleGroup';
2
+ export type { ToggleGroupProps, ToggleOption } from './ToggleGroup';
3
+ export * from './styled';
@@ -0,0 +1,17 @@
1
+ /// <reference types="react" />
2
+ export declare const ToggleContainer: import("@emotion/styled").StyledComponent<import("@mui/system").BoxOwnProps<import("@mui/material").Theme> & Omit<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
3
+ ref?: ((instance: HTMLDivElement | null) => void) | import("react").RefObject<HTMLDivElement> | null | undefined;
4
+ }, keyof import("@mui/system").BoxOwnProps<import("@mui/material").Theme>> & import("@mui/system").MUIStyledCommonProps<import("@mui/material").Theme>, {}, {}>;
5
+ export declare const ToggleButton: import("@emotion/styled").StyledComponent<import("@mui/material").ButtonBaseOwnProps & Omit<import("@mui/material").ButtonBaseOwnProps, "classes"> & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, "ref"> & {
6
+ ref?: ((instance: HTMLButtonElement | null) => void) | import("react").RefObject<HTMLButtonElement> | null | undefined;
7
+ }, "children" | "style" | "className" | "classes" | "action" | "centerRipple" | "disabled" | "disableRipple" | "disableTouchRipple" | "focusRipple" | "focusVisibleClassName" | "LinkComponent" | "onFocusVisible" | "sx" | "tabIndex" | "TouchRippleProps" | "touchRippleRef"> & import("@mui/system").MUIStyledCommonProps<import("@mui/material").Theme> & {
8
+ selected?: boolean | undefined;
9
+ }, {}, {}>;
10
+ export declare const ToggleIcon: import("@emotion/styled").StyledComponent<import("@mui/system").BoxOwnProps<import("@mui/material").Theme> & Omit<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
11
+ ref?: ((instance: HTMLDivElement | null) => void) | import("react").RefObject<HTMLDivElement> | null | undefined;
12
+ }, keyof import("@mui/system").BoxOwnProps<import("@mui/material").Theme>> & import("@mui/system").MUIStyledCommonProps<import("@mui/material").Theme>, {}, {}>;
13
+ export declare const ToggleLabel: import("@emotion/styled").StyledComponent<import("@mui/material").TypographyOwnProps & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, "ref"> & {
14
+ ref?: ((instance: HTMLSpanElement | null) => void) | import("react").RefObject<HTMLSpanElement> | null | undefined;
15
+ }, "fontFamily" | "children" | "p" | "style" | "fontSize" | "fontStyle" | "fontWeight" | "lineHeight" | "border" | "className" | "classes" | "sx" | "boxShadow" | "zIndex" | "alignContent" | "alignItems" | "alignSelf" | "bottom" | "boxSizing" | "color" | "columnGap" | "display" | "flexBasis" | "flexDirection" | "flexGrow" | "flexShrink" | "flexWrap" | "gridAutoColumns" | "gridAutoFlow" | "gridAutoRows" | "gridTemplateAreas" | "gridTemplateColumns" | "gridTemplateRows" | "height" | "justifyContent" | "justifyItems" | "justifySelf" | "left" | "letterSpacing" | "marginBlockEnd" | "marginBlockStart" | "marginBottom" | "marginInlineEnd" | "marginInlineStart" | "marginLeft" | "marginRight" | "marginTop" | "maxHeight" | "maxWidth" | "minHeight" | "minWidth" | "order" | "paddingBlockEnd" | "paddingBlockStart" | "paddingBottom" | "paddingInlineEnd" | "paddingInlineStart" | "paddingLeft" | "paddingRight" | "paddingTop" | "position" | "right" | "rowGap" | "textAlign" | "textOverflow" | "textTransform" | "top" | "visibility" | "whiteSpace" | "width" | "borderBottom" | "borderColor" | "borderLeft" | "borderRadius" | "borderRight" | "borderTop" | "flex" | "gap" | "gridArea" | "gridColumn" | "gridRow" | "margin" | "marginBlock" | "marginInline" | "overflow" | "padding" | "paddingBlock" | "paddingInline" | "bgcolor" | "m" | "mt" | "mr" | "mb" | "ml" | "mx" | "marginX" | "my" | "marginY" | "pt" | "pr" | "pb" | "pl" | "px" | "paddingX" | "py" | "paddingY" | "typography" | "displayPrint" | "variant" | "align" | "gutterBottom" | "noWrap" | "paragraph" | "variantMapping"> & import("@mui/system").MUIStyledCommonProps<import("@mui/material").Theme> & {
16
+ selected?: boolean | undefined;
17
+ }, {}, {}>;
@@ -26,9 +26,10 @@ export interface TenantThemeProviderProps {
26
26
  export declare function TenantThemeProvider({ children, tenantId, theme, }: TenantThemeProviderProps): import("react/jsx-runtime").JSX.Element;
27
27
  /**
28
28
  * Hook to access tenant theme configuration
29
- * @throws Error if used outside TenantThemeProvider
29
+ * Returns undefined during SSR if context is not available
30
+ * @returns TenantContextValue or undefined during SSR
30
31
  */
31
- export declare function useTenantTheme(): TenantContextValue;
32
+ export declare function useTenantTheme(): TenantContextValue | undefined;
32
33
  /**
33
34
  * Hook to get tenant ID
34
35
  */
@@ -2,14 +2,62 @@
2
2
  * D2C Component Library
3
3
  * Reusable components with tenant-aware theming
4
4
  */
5
- export { TenantThemeProvider, useTenantTheme, useTenantId, useIsTenant, } from './context/TenantThemeContext';
5
+ export { TenantThemeProvider, useIsTenant, useTenantId, useTenantTheme } from './context/TenantThemeContext';
6
6
  export type { TenantThemeProviderProps } from './context/TenantThemeContext';
7
- export type { ColorShade, TenantPalette, TenantTypography, TenantThemeConfig, TenantContextValue, TenantId, } from './types/tenant';
8
- export { iglooTheme, cimbTheme, ammetlifeTheme, tenantThemes, getTenantTheme, isValidTenantId, getAvailableTenants, } from './themes';
7
+ export type { ColorShade, TenantContextValue, TenantId, TenantPalette, TenantThemeConfig, TenantTypography } from './types/tenant';
8
+ export { ammetlifeTheme, cimbTheme, getAvailableTenants, getTenantTheme, iglooTheme, isValidTenantId, tenantThemes } from './themes';
9
+ export { ammetlifeTypography, cimbTypography, getTenantTypography, iglooTypography, tenantTypography, } from './themes/typography';
10
+ export type { TenantTypographyConfig, TypographyVariant, } from './themes/typography';
9
11
  export { Button } from './components/Button';
10
12
  export type { ButtonProps } from './components/Button';
11
13
  export { Card } from './components/Card';
12
14
  export type { CardProps } from './components/Card';
13
15
  export { Banner } from './components/Banner';
14
16
  export type { BannerProps } from './components/Banner';
15
- export { getThemeColor, mergeTenantTheme, createThemeCSSVariables } from './utils/theme';
17
+ export { Header } from './components/Header';
18
+ export type { HeaderProps, LanguageOption, NavigationLink } from './components/Header';
19
+ export { NewHeader } from './components/NewHeader';
20
+ export type { NewHeaderNavigationLink, NewHeaderProps } from './components/NewHeader';
21
+ export { Footer } from './components/Footer';
22
+ export type { FooterLicenseImage, FooterNavigationLink, FooterProps, SocialLink } from './components/Footer';
23
+ export { RecommendationsDrawer } from './components/RecommendationsDrawer';
24
+ export type { RecommendationsDrawerProps } from './components/RecommendationsDrawer';
25
+ export { ProductSelectionDrawer } from './components/ProductSelectionDrawer';
26
+ export type { Product, ProductSelectionDrawerProps } from './components/ProductSelectionDrawer';
27
+ export { QuestionSection } from './components/QuestionSection';
28
+ export type { QuestionOption, QuestionSectionProps } from './components/QuestionSection';
29
+ export { OptionButton } from './components/OptionButton';
30
+ export type { OptionButtonProps } from './components/OptionButton';
31
+ export { ToggleGroup } from './components/ToggleGroup';
32
+ export type { ToggleGroupProps, ToggleOption } from './components/ToggleGroup';
33
+ export { BillingToggle } from './components/BillingToggle';
34
+ export type { BillingToggleProps } from './components/BillingToggle';
35
+ export { InfoCallout } from './components/InfoCallout';
36
+ export type { InfoCalloutProps } from './components/InfoCallout';
37
+ export { CoverageAmountSlider } from './components/CoverageAmountSlider';
38
+ export type { CoverageAmountSliderProps } from './components/CoverageAmountSlider';
39
+ export { CheckoutProgress } from './components/CheckoutProgress';
40
+ export type { CheckoutProgressProps } from './components/CheckoutProgress';
41
+ export { ProductCard } from './components/ProductCard';
42
+ export type { ProductCardProps } from './components/ProductCard';
43
+ export { CheckoutHeader } from './components/CheckoutHeader';
44
+ export type { CheckoutHeaderProps } from './components/CheckoutHeader';
45
+ export { CheckoutFormButton } from './components/CheckoutFormButton';
46
+ export type { CheckoutFormButtonProps } from './components/CheckoutFormButton';
47
+ export { HealthQuestionGroup } from './components/HealthQuestionGroup';
48
+ export type { HealthQuestionGroupProps } from './components/HealthQuestionGroup';
49
+ export { PersonalInformationForm } from './components/PersonalInformationForm';
50
+ export type { PersonalInformationField, PersonalInformationFormProps } from './components/PersonalInformationForm';
51
+ export { ContactDetailsForm } from './components/ContactDetailsForm';
52
+ export type { ContactDetailsField, ContactDetailsFormProps } from './components/ContactDetailsForm';
53
+ export { HealthInformationForm } from './components/HealthInformationForm';
54
+ export type { HealthInformationField, HealthInformationFormProps, HealthQuestion } from './components/HealthInformationForm';
55
+ export { ChildInformationForm } from './components/ChildInformationForm';
56
+ export type { ChildInformationField, ChildInformationFormProps } from './components/ChildInformationForm';
57
+ export { FAQAccordion } from './components/FAQAccordion';
58
+ export type { FAQAccordionProps, FAQItem } from './components/FAQAccordion';
59
+ export { BenefitsSummary } from './components/BenefitsSummary';
60
+ export type { BenefitItem, BenefitsSummaryProps } from './components/BenefitsSummary';
61
+ export { getTenantAssetPath, getTenantLogoPath, useTenantAsset, useTenantFavicon, useTenantLogo } from './utils/assets';
62
+ export { createThemeCSSVariables, getThemeColor, mergeTenantTheme } from './utils/theme';
63
+ export * from './assets';
@@ -1,5 +1,5 @@
1
1
  import { ComponentStory, ComponentMeta } from '@storybook/react';
2
- import { Banner } from './Banner';
2
+ import { Banner } from '../components/Banner';
3
3
  declare const _default: ComponentMeta<typeof Banner>;
4
4
  export default _default;
5
5
  export declare const Default: ComponentStory<typeof Banner>;
@@ -0,0 +1,37 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { BenefitsSummary } from '../components/BenefitsSummary';
3
+ declare const meta: Meta<typeof BenefitsSummary>;
4
+ export default meta;
5
+ type Story = StoryObj<typeof BenefitsSummary>;
6
+ /**
7
+ * Default Benefits Summary with sample data
8
+ */
9
+ export declare const Default: Story;
10
+ /**
11
+ * Benefits Summary with custom title
12
+ */
13
+ export declare const CustomTitle: Story;
14
+ /**
15
+ * Benefits Summary with custom background color
16
+ */
17
+ export declare const CustomBackground: Story;
18
+ /**
19
+ * Benefits Summary with larger icons
20
+ */
21
+ export declare const LargeIcons: Story;
22
+ /**
23
+ * Benefits Summary with minimal benefits
24
+ */
25
+ export declare const MinimalBenefits: Story;
26
+ /**
27
+ * Benefits Summary with AmMetLife theme
28
+ */
29
+ export declare const AmMetLifeTheme: Story;
30
+ /**
31
+ * Benefits Summary with CIMB theme
32
+ */
33
+ export declare const CIMBTheme: Story;
34
+ /**
35
+ * Benefits Summary with Igloo theme
36
+ */
37
+ export declare const IglooTheme: Story;
@@ -0,0 +1,10 @@
1
+ import { ComponentStory, ComponentMeta } from '@storybook/react';
2
+ import { BillingToggle } from '../components/BillingToggle';
3
+ declare const _default: ComponentMeta<typeof BillingToggle>;
4
+ export default _default;
5
+ export declare const Default: ComponentStory<typeof BillingToggle>;
6
+ export declare const AnnuallySelected: ComponentStory<typeof BillingToggle>;
7
+ export declare const Interactive: () => import("react/jsx-runtime").JSX.Element;
8
+ export declare const WithCustomFormatMessage: ComponentStory<typeof BillingToggle>;
9
+ export declare const WithCIMBTheme: ComponentStory<typeof BillingToggle>;
10
+ export declare const WithAmmetLifeTheme: ComponentStory<typeof BillingToggle>;
@@ -1,5 +1,5 @@
1
1
  import { ComponentStory, ComponentMeta } from '@storybook/react';
2
- import { Button } from './Button';
2
+ import { Button } from '../components/Button';
3
3
  declare const _default: ComponentMeta<typeof Button>;
4
4
  export default _default;
5
5
  export declare const Default: ComponentStory<typeof Button>;
@@ -1,5 +1,5 @@
1
1
  import { ComponentStory, ComponentMeta } from '@storybook/react';
2
- import { Card } from './Card';
2
+ import { Card } from '../components/Card';
3
3
  declare const _default: ComponentMeta<typeof Card>;
4
4
  export default _default;
5
5
  export declare const Default: ComponentStory<typeof Card>;
@@ -0,0 +1,9 @@
1
+ /// <reference types="react" />
2
+ import { ComponentMeta, ComponentStory } from '@storybook/react';
3
+ declare const _default: ComponentMeta<import("react").FC<import("../components/CheckoutProgress").CheckoutProgressProps>>;
4
+ export default _default;
5
+ export declare const Step1: ComponentStory<import("react").FC<import("../components/CheckoutProgress").CheckoutProgressProps>>;
6
+ export declare const Step2: ComponentStory<import("react").FC<import("../components/CheckoutProgress").CheckoutProgressProps>>;
7
+ export declare const Step3: ComponentStory<import("react").FC<import("../components/CheckoutProgress").CheckoutProgressProps>>;
8
+ export declare const WithoutBackButton: ComponentStory<import("react").FC<import("../components/CheckoutProgress").CheckoutProgressProps>>;
9
+ export declare const FiveSteps: ComponentStory<import("react").FC<import("../components/CheckoutProgress").CheckoutProgressProps>>;
@@ -0,0 +1,14 @@
1
+ import { ComponentStory, ComponentMeta } from '@storybook/react';
2
+ import { CoverageAmountSlider } from '../components/CoverageAmountSlider';
3
+ declare const _default: ComponentMeta<typeof CoverageAmountSlider>;
4
+ export default _default;
5
+ export declare const Default: ComponentStory<typeof CoverageAmountSlider>;
6
+ export declare const MidRange: ComponentStory<typeof CoverageAmountSlider>;
7
+ export declare const Maximum: ComponentStory<typeof CoverageAmountSlider>;
8
+ export declare const CustomSteps: ComponentStory<typeof CoverageAmountSlider>;
9
+ export declare const CustomCurrency: ComponentStory<typeof CoverageAmountSlider>;
10
+ export declare const LargeRange: ComponentStory<typeof CoverageAmountSlider>;
11
+ export declare const SmallRange: ComponentStory<typeof CoverageAmountSlider>;
12
+ export declare const WithCIMBTheme: ComponentStory<typeof CoverageAmountSlider>;
13
+ export declare const WithAmmetLifeTheme: ComponentStory<typeof CoverageAmountSlider>;
14
+ export declare const Interactive: () => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,37 @@
1
+ import type { Meta, StoryObj } from '@storybook/react';
2
+ import { FAQAccordion } from '../components/FAQAccordion';
3
+ declare const meta: Meta<typeof FAQAccordion>;
4
+ export default meta;
5
+ type Story = StoryObj<typeof FAQAccordion>;
6
+ /**
7
+ * Default FAQ Accordion with sample data
8
+ */
9
+ export declare const Default: Story;
10
+ /**
11
+ * FAQ Accordion with custom title
12
+ */
13
+ export declare const CustomTitle: Story;
14
+ /**
15
+ * FAQ Accordion with custom background color
16
+ */
17
+ export declare const CustomBackground: Story;
18
+ /**
19
+ * FAQ Accordion with a default expanded item
20
+ */
21
+ export declare const DefaultExpanded: Story;
22
+ /**
23
+ * FAQ Accordion with minimal FAQs
24
+ */
25
+ export declare const MinimalFAQs: Story;
26
+ /**
27
+ * FAQ Accordion with AmMetLife theme
28
+ */
29
+ export declare const AmMetLifeTheme: Story;
30
+ /**
31
+ * FAQ Accordion with CIMB theme
32
+ */
33
+ export declare const CIMBTheme: Story;
34
+ /**
35
+ * FAQ Accordion with Igloo theme
36
+ */
37
+ export declare const IglooTheme: Story;
@@ -0,0 +1,10 @@
1
+ import { ComponentStory, ComponentMeta } from '@storybook/react';
2
+ import { Footer } from '../components/Footer';
3
+ declare const _default: ComponentMeta<typeof Footer>;
4
+ export default _default;
5
+ export declare const Default: ComponentStory<typeof Footer>;
6
+ export declare const SimplifiedLayout: ComponentStory<typeof Footer>;
7
+ export declare const MobileView: ComponentStory<typeof Footer>;
8
+ export declare const WithPoweredBy: ComponentStory<typeof Footer>;
9
+ export declare const WithCIMBTheme: ComponentStory<typeof Footer>;
10
+ export declare const WithAmmetLifeTheme: ComponentStory<typeof Footer>;
@@ -0,0 +1,9 @@
1
+ import { ComponentStory, ComponentMeta } from '@storybook/react';
2
+ import { Header } from '../components/Header';
3
+ declare const _default: ComponentMeta<typeof Header>;
4
+ export default _default;
5
+ export declare const Default: ComponentStory<typeof Header>;
6
+ export declare const WithUser: ComponentStory<typeof Header>;
7
+ export declare const MobileView: ComponentStory<typeof Header>;
8
+ export declare const WithCIMBTheme: ComponentStory<typeof Header>;
9
+ export declare const WithAmmetLifeTheme: ComponentStory<typeof Header>;
@@ -0,0 +1,9 @@
1
+ /// <reference types="react" />
2
+ import { ComponentMeta, ComponentStory } from '@storybook/react';
3
+ declare const _default: ComponentMeta<import("react").FC<import("../components/HealthQuestionGroup").HealthQuestionGroupProps>>;
4
+ export default _default;
5
+ export declare const Default: ComponentStory<import("react").FC<import("../components/HealthQuestionGroup").HealthQuestionGroupProps>>;
6
+ export declare const WithYesSelected: ComponentStory<import("react").FC<import("../components/HealthQuestionGroup").HealthQuestionGroupProps>>;
7
+ export declare const WithError: ComponentStory<import("react").FC<import("../components/HealthQuestionGroup").HealthQuestionGroupProps>>;
8
+ export declare const PregnancyQuestion: ComponentStory<import("react").FC<import("../components/HealthQuestionGroup").HealthQuestionGroupProps>>;
9
+ export declare const MultilineQuestion: ComponentStory<import("react").FC<import("../components/HealthQuestionGroup").HealthQuestionGroupProps>>;
@@ -0,0 +1,11 @@
1
+ import { ComponentStory, ComponentMeta } from '@storybook/react';
2
+ import { InfoCallout } from '../components/InfoCallout';
3
+ declare const _default: ComponentMeta<typeof InfoCallout>;
4
+ export default _default;
5
+ export declare const Default: ComponentStory<typeof InfoCallout>;
6
+ export declare const CustomTitle: ComponentStory<typeof InfoCallout>;
7
+ export declare const LongContent: ComponentStory<typeof InfoCallout>;
8
+ export declare const ShortContent: ComponentStory<typeof InfoCallout>;
9
+ export declare const WithCustomFormatMessage: ComponentStory<typeof InfoCallout>;
10
+ export declare const WithCIMBTheme: ComponentStory<typeof InfoCallout>;
11
+ export declare const WithAmmetLifeTheme: ComponentStory<typeof InfoCallout>;
@@ -0,0 +1,82 @@
1
+ /**
2
+ * NewHeader Storybook Stories
3
+ * Interactive documentation and testing for the NewHeader component
4
+ */
5
+ import { ComponentMeta, ComponentStory } from '@storybook/react';
6
+ import { NewHeader } from '../components/NewHeader';
7
+ declare const _default: ComponentMeta<typeof NewHeader>;
8
+ export default _default;
9
+ /**
10
+ * Default story - Basic header with Igloo branding
11
+ */
12
+ export declare const Default: ComponentStory<typeof NewHeader>;
13
+ /**
14
+ * Authenticated User story
15
+ */
16
+ export declare const AuthenticatedUser: ComponentStory<typeof NewHeader>;
17
+ /**
18
+ * Mobile View story
19
+ */
20
+ export declare const MobileView: ComponentStory<typeof NewHeader>;
21
+ /**
22
+ * CIMB Tenant story
23
+ */
24
+ export declare const CIMBTenant: ComponentStory<typeof NewHeader>;
25
+ /**
26
+ * AmMetLife Tenant story
27
+ */
28
+ export declare const AmMetLifeTenant: ComponentStory<typeof NewHeader>;
29
+ /**
30
+ * Minimal story - No navigation links
31
+ */
32
+ export declare const MinimalHeader: ComponentStory<typeof NewHeader>;
33
+ /**
34
+ * Custom Drawer Content story
35
+ */
36
+ export declare const CustomDrawerContent: ComponentStory<typeof NewHeader>;
37
+ /**
38
+ * Many Menu Items story - Testing overflow
39
+ */
40
+ export declare const ManyMenuItems: ComponentStory<typeof NewHeader>;
41
+ /**
42
+ * Without Logo story - Edge case testing
43
+ */
44
+ export declare const WithoutLogo: ComponentStory<typeof NewHeader>;
45
+ /**
46
+ * Internationalization story
47
+ */
48
+ export declare const WithInternationalization: ComponentStory<typeof NewHeader>;
49
+ /**
50
+ * Interactive Demo story
51
+ */
52
+ export declare const InteractiveDemo: ComponentStory<typeof NewHeader>;
53
+ /**
54
+ * All Tenants Comparison
55
+ */
56
+ export declare const AllTenants: {
57
+ (): import("react/jsx-runtime").JSX.Element;
58
+ parameters: {
59
+ docs: {
60
+ description: {
61
+ story: string;
62
+ };
63
+ };
64
+ };
65
+ };
66
+ /**
67
+ * Responsive Demo story
68
+ */
69
+ export declare const ResponsiveDemo: {
70
+ (): import("react/jsx-runtime").JSX.Element;
71
+ parameters: {
72
+ docs: {
73
+ description: {
74
+ story: string;
75
+ };
76
+ };
77
+ };
78
+ };
79
+ /**
80
+ * Kitchen Sink story - All features
81
+ */
82
+ export declare const KitchenSink: ComponentStory<typeof NewHeader>;
@@ -0,0 +1,12 @@
1
+ import { ComponentStory, ComponentMeta } from '@storybook/react';
2
+ import { OptionButton } from '../components/OptionButton';
3
+ declare const _default: ComponentMeta<typeof OptionButton>;
4
+ export default _default;
5
+ export declare const Default: ComponentStory<typeof OptionButton>;
6
+ export declare const Selected: ComponentStory<typeof OptionButton>;
7
+ export declare const WithIcon: ComponentStory<typeof OptionButton>;
8
+ export declare const Disabled: ComponentStory<typeof OptionButton>;
9
+ export declare const Sizes: () => import("react/jsx-runtime").JSX.Element;
10
+ export declare const Interactive: () => import("react/jsx-runtime").JSX.Element;
11
+ export declare const MultipleOptions: () => import("react/jsx-runtime").JSX.Element;
12
+ export declare const WithCIMBTheme: ComponentStory<typeof OptionButton>;
@@ -0,0 +1,9 @@
1
+ /// <reference types="react" />
2
+ import { ComponentMeta, ComponentStory } from '@storybook/react';
3
+ declare const _default: ComponentMeta<import("react").FC<import("../components/ProductCard").ProductCardProps>>;
4
+ export default _default;
5
+ export declare const Default: ComponentStory<import("react").FC<import("../components/ProductCard").ProductCardProps>>;
6
+ export declare const WithLogo: ComponentStory<import("react").FC<import("../components/ProductCard").ProductCardProps>>;
7
+ export declare const WithoutIndicator: ComponentStory<import("react").FC<import("../components/ProductCard").ProductCardProps>>;
8
+ export declare const AnnualBilling: ComponentStory<import("react").FC<import("../components/ProductCard").ProductCardProps>>;
9
+ export declare const NoPlan: ComponentStory<import("react").FC<import("../components/ProductCard").ProductCardProps>>;
@@ -0,0 +1,24 @@
1
+ /**
2
+ * Product Selection Drawer Stories
3
+ */
4
+ import type { Meta, StoryObj } from '@storybook/react';
5
+ import { ProductSelectionDrawer } from '../components/ProductSelectionDrawer';
6
+ declare const meta: Meta<typeof ProductSelectionDrawer>;
7
+ export default meta;
8
+ type Story = StoryObj<typeof ProductSelectionDrawer>;
9
+ /**
10
+ * Default story showing the product selection drawer
11
+ */
12
+ export declare const Default: Story;
13
+ /**
14
+ * Story with custom text
15
+ */
16
+ export declare const CustomText: Story;
17
+ /**
18
+ * Story with fewer products
19
+ */
20
+ export declare const TwoProducts: Story;
21
+ /**
22
+ * Interactive story with button to open drawer
23
+ */
24
+ export declare const Interactive: Story;
@@ -0,0 +1,11 @@
1
+ import { ComponentStory, ComponentMeta } from '@storybook/react';
2
+ import { QuestionSection } from '../components/QuestionSection';
3
+ declare const _default: ComponentMeta<typeof QuestionSection>;
4
+ export default _default;
5
+ export declare const Default: ComponentStory<typeof QuestionSection>;
6
+ export declare const WithSelection: ComponentStory<typeof QuestionSection>;
7
+ export declare const WithoutNumber: ComponentStory<typeof QuestionSection>;
8
+ export declare const MultipleSelection: () => import("react/jsx-runtime").JSX.Element;
9
+ export declare const WithCustomRenderer: ComponentStory<typeof QuestionSection>;
10
+ export declare const LongQuestion: ComponentStory<typeof QuestionSection>;
11
+ export declare const WithCIMBTheme: ComponentStory<typeof QuestionSection>;
@@ -0,0 +1,36 @@
1
+ /**
2
+ * RecommendationsDrawer Storybook Stories
3
+ * Interactive testing for recommendations drawer and form components
4
+ */
5
+ import { ComponentMeta, ComponentStory } from '@storybook/react';
6
+ import { RecommendationsDrawer } from '../components/RecommendationsDrawer';
7
+ declare const _default: ComponentMeta<typeof RecommendationsDrawer>;
8
+ export default _default;
9
+ export declare const Default: ComponentStory<typeof RecommendationsDrawer>;
10
+ export declare const CompleteQuestionnaire: {
11
+ (): import("react/jsx-runtime").JSX.Element;
12
+ parameters: {
13
+ docs: {
14
+ description: {
15
+ story: string;
16
+ };
17
+ };
18
+ };
19
+ };
20
+ export declare const SingleQuestion: () => import("react/jsx-runtime").JSX.Element;
21
+ export declare const WithBackButton: () => import("react/jsx-runtime").JSX.Element;
22
+ export declare const WithToggleGroup: () => import("react/jsx-runtime").JSX.Element;
23
+ export declare const OptionButtonsShowcase: () => import("react/jsx-runtime").JSX.Element;
24
+ export declare const CustomFooter: () => import("react/jsx-runtime").JSX.Element;
25
+ export declare const WithoutFooter: () => import("react/jsx-runtime").JSX.Element;
26
+ export declare const TravelInsuranceExample: {
27
+ (): import("react/jsx-runtime").JSX.Element;
28
+ parameters: {
29
+ docs: {
30
+ description: {
31
+ story: string;
32
+ };
33
+ };
34
+ };
35
+ };
36
+ export declare const MobileViewport: ComponentStory<typeof RecommendationsDrawer>;
@@ -0,0 +1,10 @@
1
+ import { ComponentStory, ComponentMeta } from '@storybook/react';
2
+ import { ToggleGroup } from '../components/ToggleGroup';
3
+ declare const _default: ComponentMeta<typeof ToggleGroup>;
4
+ export default _default;
5
+ export declare const Default: ComponentStory<typeof ToggleGroup>;
6
+ export declare const ThreeOptions: ComponentStory<typeof ToggleGroup>;
7
+ export declare const WithoutIcons: ComponentStory<typeof ToggleGroup>;
8
+ export declare const WithImageIcons: ComponentStory<typeof ToggleGroup>;
9
+ export declare const Interactive: () => import("react/jsx-runtime").JSX.Element;
10
+ export declare const WithCIMBTheme: ComponentStory<typeof ToggleGroup>;
@@ -2,7 +2,7 @@
2
2
  * Tenant Theme Configurations
3
3
  * Centralized theme definitions for all tenants
4
4
  */
5
- import { TenantThemeConfig, TenantId } from '../types/tenant';
5
+ import { TenantId, TenantThemeConfig } from '../types/tenant';
6
6
  /**
7
7
  * Igloo Theme Configuration
8
8
  */
@@ -0,0 +1,69 @@
1
+ /**
2
+ * Tenant Typography Configurations
3
+ * Centralized typography definitions for all tenants
4
+ * Based on b2c-web-demo typography structure
5
+ */
6
+ import { TenantId } from '../types/tenant';
7
+ export interface TypographyVariant {
8
+ fontSize: string;
9
+ fontStyle?: string;
10
+ fontWeight: number | string;
11
+ lineHeight: string;
12
+ '@media (max-width:600px)'?: {
13
+ fontSize: string;
14
+ fontStyle?: string;
15
+ fontWeight: number | string;
16
+ lineHeight: string;
17
+ };
18
+ '@media (min-width:600px)'?: {
19
+ fontSize?: string;
20
+ fontStyle?: string;
21
+ fontWeight?: number | string;
22
+ lineHeight?: string;
23
+ };
24
+ }
25
+ export interface TenantTypographyConfig {
26
+ fontFamily: string;
27
+ fontWeightRegular: number;
28
+ fontWeightMedium: number;
29
+ fontWeightSemiBold: number;
30
+ fontWeightBold: number;
31
+ fontWeightExtraBold: number;
32
+ fontWeightExtraBlack: number;
33
+ H1?: TypographyVariant;
34
+ h1?: TypographyVariant;
35
+ h2?: TypographyVariant;
36
+ h3?: TypographyVariant;
37
+ h4?: TypographyVariant;
38
+ bodyStrongLarge?: TypographyVariant;
39
+ bodyStrongMedium?: TypographyVariant;
40
+ bodyStrongSmall?: TypographyVariant;
41
+ bodyLarge?: TypographyVariant;
42
+ bodyMedium?: TypographyVariant;
43
+ bodySmall?: TypographyVariant;
44
+ smallText?: TypographyVariant;
45
+ [key: string]: any;
46
+ }
47
+ /**
48
+ * Igloo Typography Configuration
49
+ */
50
+ export declare const iglooTypography: TenantTypographyConfig;
51
+ /**
52
+ * CIMB Typography Configuration
53
+ */
54
+ export declare const cimbTypography: TenantTypographyConfig;
55
+ /**
56
+ * AmmetLife Typography Configuration
57
+ */
58
+ export declare const ammetlifeTypography: TenantTypographyConfig;
59
+ /**
60
+ * Typography Registry
61
+ * Map of tenant IDs to their typography configurations
62
+ */
63
+ export declare const tenantTypography: Record<TenantId, TenantTypographyConfig>;
64
+ /**
65
+ * Get typography configuration by tenant ID
66
+ * @param tenantId - The tenant identifier
67
+ * @returns Typography configuration for the specified tenant
68
+ */
69
+ export declare function getTenantTypography(tenantId: TenantId): TenantTypographyConfig;