@sunrise-upc/mobile-prod-card 8.5.2 → 8.5.4

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 (60) hide show
  1. package/dist/cjs/Analytics/AnalyticsConstants.d.ts +5 -0
  2. package/dist/cjs/components/Accessories/Accessory-card/AccessoryCard.d.ts +10 -0
  3. package/dist/cjs/components/Accessories/Accessory-card/AccessoryErrorModal.d.ts +18 -0
  4. package/dist/cjs/components/Accessories/AccessoryPreviewCardLoader/AccessoryPreviewCardLoader.d.ts +3 -0
  5. package/dist/cjs/components/Accessories/AccessoryPreviewCardSkeletonBody/AccessoryPreviewCardSkeletonBody.d.ts +3 -0
  6. package/dist/cjs/components/Accessories/DeviceCarouselComponent.d.ts +3 -0
  7. package/dist/cjs/components/Accessories/MultiItemAccessories/MultiItemAccessoriesPage.d.ts +5 -0
  8. package/dist/cjs/components/Accessories/MultiItemAccessories/MultiItemAccessoriesSchema.d.ts +41 -0
  9. package/dist/cjs/components/Accessories/PaymentTypeTabs/PaymentTypeTabs.d.ts +14 -0
  10. package/dist/cjs/components/Accessories/ProgressionBar/progressionBar.d.ts +13 -0
  11. package/dist/cjs/components/Accessories/index.d.ts +1 -0
  12. package/dist/cjs/components/Accessories/multiItemAccessoryStore/MultiAccessoryProvider.d.ts +19 -0
  13. package/dist/cjs/components/Accessories/multiItemAccessoryStore/types.d.ts +71 -0
  14. package/dist/cjs/components/Accessories/multiItemAccessoryStore/useMultiAccessoryActions.d.ts +15 -0
  15. package/dist/cjs/components/Accessories/multiItemAccessoryStore/useMultiAccessoryContext.d.ts +32 -0
  16. package/dist/cjs/components/Accessories/multiItemAccessoryStore/useMultiAccessoryUpdateCartActions.d.ts +11 -0
  17. package/dist/cjs/components/Dotloader/Dotloader.d.ts +1 -1
  18. package/dist/cjs/components/StaticLineTable/OttServiceOptions/OttServiceOptionsSmallPopup.d.ts +1 -1
  19. package/dist/cjs/components/index.d.ts +1 -0
  20. package/dist/cjs/components/types.d.ts +34 -0
  21. package/dist/cjs/index.js +3 -3
  22. package/dist/cjs/services/MultiItemAccessories/multiItemAccessoryService.d.ts +8 -0
  23. package/dist/cjs/services/MultiItemAccessories/multiitemAccessoriesUpdateCartService.d.ts +8 -0
  24. package/dist/cjs/services/MultiItemAccessories/storyBlokService.d.ts +10 -0
  25. package/dist/cjs/services/api-constants.d.ts +4 -0
  26. package/dist/cjs/utils/AnalyticsUtils.d.ts +2 -0
  27. package/dist/cjs/utils/constants.d.ts +16 -0
  28. package/dist/cjs/utils/data-source.d.ts +1 -1
  29. package/dist/cjs/utils/utils.d.ts +12 -0
  30. package/dist/esm/Analytics/AnalyticsConstants.d.ts +5 -0
  31. package/dist/esm/components/Accessories/Accessory-card/AccessoryCard.d.ts +10 -0
  32. package/dist/esm/components/Accessories/Accessory-card/AccessoryErrorModal.d.ts +18 -0
  33. package/dist/esm/components/Accessories/AccessoryPreviewCardLoader/AccessoryPreviewCardLoader.d.ts +3 -0
  34. package/dist/esm/components/Accessories/AccessoryPreviewCardSkeletonBody/AccessoryPreviewCardSkeletonBody.d.ts +3 -0
  35. package/dist/esm/components/Accessories/DeviceCarouselComponent.d.ts +3 -0
  36. package/dist/esm/components/Accessories/MultiItemAccessories/MultiItemAccessoriesPage.d.ts +5 -0
  37. package/dist/esm/components/Accessories/MultiItemAccessories/MultiItemAccessoriesSchema.d.ts +41 -0
  38. package/dist/esm/components/Accessories/PaymentTypeTabs/PaymentTypeTabs.d.ts +14 -0
  39. package/dist/esm/components/Accessories/ProgressionBar/progressionBar.d.ts +13 -0
  40. package/dist/esm/components/Accessories/index.d.ts +1 -0
  41. package/dist/esm/components/Accessories/multiItemAccessoryStore/MultiAccessoryProvider.d.ts +19 -0
  42. package/dist/esm/components/Accessories/multiItemAccessoryStore/types.d.ts +71 -0
  43. package/dist/esm/components/Accessories/multiItemAccessoryStore/useMultiAccessoryActions.d.ts +15 -0
  44. package/dist/esm/components/Accessories/multiItemAccessoryStore/useMultiAccessoryContext.d.ts +32 -0
  45. package/dist/esm/components/Accessories/multiItemAccessoryStore/useMultiAccessoryUpdateCartActions.d.ts +11 -0
  46. package/dist/esm/components/Dotloader/Dotloader.d.ts +1 -1
  47. package/dist/esm/components/StaticLineTable/OttServiceOptions/OttServiceOptionsSmallPopup.d.ts +1 -1
  48. package/dist/esm/components/index.d.ts +1 -0
  49. package/dist/esm/components/types.d.ts +34 -0
  50. package/dist/esm/index.js +3 -3
  51. package/dist/esm/services/MultiItemAccessories/multiItemAccessoryService.d.ts +8 -0
  52. package/dist/esm/services/MultiItemAccessories/multiitemAccessoriesUpdateCartService.d.ts +8 -0
  53. package/dist/esm/services/MultiItemAccessories/storyBlokService.d.ts +10 -0
  54. package/dist/esm/services/api-constants.d.ts +4 -0
  55. package/dist/esm/utils/AnalyticsUtils.d.ts +2 -0
  56. package/dist/esm/utils/constants.d.ts +16 -0
  57. package/dist/esm/utils/data-source.d.ts +1 -1
  58. package/dist/esm/utils/utils.d.ts +12 -0
  59. package/dist/index.d.ts +91 -3
  60. package/package.json +1 -1
@@ -76,3 +76,8 @@ export declare const CAPSINTERNET = "INTERNET";
76
76
  export declare const HEROBANNER = "HeroBanner";
77
77
  export declare const STICKYBOTTOMSHEET = "StickyBottomSheet";
78
78
  export declare const TOGGLECLICK = "toggle_click";
79
+ export declare const ACCESSORYCATEGORY = "Accessory";
80
+ export declare const ACCESSORYLISTNAME = "Device Accessories";
81
+ export declare const VIEWITEM = "view_item_list";
82
+ export declare const VIEWEACHITEM = "view_item";
83
+ export declare const REMOVEFROMCART = "remove_from_cart";
@@ -0,0 +1,10 @@
1
+ /// <reference types="react" />
2
+ import { MultiItemAccessoriesSchema } from '../MultiItemAccessories/MultiItemAccessoriesSchema';
3
+ type AccessoryCardProps = {
4
+ content: MultiItemAccessoriesSchema;
5
+ cards: number;
6
+ tabIndex: number;
7
+ checkingviewPort: any;
8
+ };
9
+ declare const AccessoryCard: ({ content, cards, tabIndex, }: AccessoryCardProps) => JSX.Element;
10
+ export default AccessoryCard;
@@ -0,0 +1,18 @@
1
+ import React from 'react';
2
+ interface GenericModalSchema {
3
+ modalState: boolean;
4
+ handler: () => void;
5
+ children: React.ReactNode;
6
+ showFooter: boolean;
7
+ footerNode?: React.ReactNode;
8
+ height?: string;
9
+ width?: string;
10
+ noCloseButton?: boolean;
11
+ backDrop?: boolean;
12
+ fixedWidth?: string;
13
+ bodyPadding?: string;
14
+ id?: string;
15
+ backgroundColor?: string;
16
+ }
17
+ declare const AccessoryErrorModal: ({ modalState, handler, showFooter, footerNode, children, width, height, noCloseButton, backDrop, fixedWidth, bodyPadding, id, backgroundColor }: GenericModalSchema) => JSX.Element;
18
+ export default AccessoryErrorModal;
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ declare const AccessoryPreviewCardLoader: ({ cards }: any) => JSX.Element;
3
+ export default AccessoryPreviewCardLoader;
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ declare const AccessoryPreviewCardSkeletonBody: () => JSX.Element;
3
+ export default AccessoryPreviewCardSkeletonBody;
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ declare const DeviceCarouselComponent: (props: any) => JSX.Element;
3
+ export default DeviceCarouselComponent;
@@ -0,0 +1,5 @@
1
+ /// <reference types="react" />
2
+ import { ComponentWithContentProps } from '../../types';
3
+ import { MultiItemAccessoriesSchema } from './MultiItemAccessoriesSchema';
4
+ declare const MultiItemAccessoriesWithProvider: (props: ComponentWithContentProps<MultiItemAccessoriesSchema>) => JSX.Element;
5
+ export default MultiItemAccessoriesWithProvider;
@@ -0,0 +1,41 @@
1
+ import { GenericSBProps, FalconButtonSchema } from '../../types';
2
+ import { paymentOptionSchema } from '../PaymentTypeTabs/PaymentTypeTabs';
3
+ export interface MultiItemAccessoriesSchema extends GenericSBProps {
4
+ component: '"AccessoriesRecommendationCards"';
5
+ accessoriesLabel: string;
6
+ addCartBtnIcon: any;
7
+ addCartBtntext: string;
8
+ checkoutBtnText: string;
9
+ checkoutLabel: string;
10
+ compatibleText: string;
11
+ customizeDeviceLabel: string;
12
+ monthlyPaymentLabel: string;
13
+ monthlyDownPaymentLabel: string;
14
+ oneTimePaymentLabel: string;
15
+ pickYourDeviceLabel: string;
16
+ recommendationLabel: any;
17
+ removeCartBtnIcon: any;
18
+ removeCartBtnText: string;
19
+ yourSubscriptionLabel: string;
20
+ progressionBar: any;
21
+ addtocartButton: FalconButtonSchema[];
22
+ removefromcartButton: FalconButtonSchema[];
23
+ proceedtocheckoutButton: FalconButtonSchema[];
24
+ parentSlugUrl: string;
25
+ multiItemCheckoutUrl: any;
26
+ accessoriesLimit: number;
27
+ accessoriesColorLabel: string;
28
+ totalText: string;
29
+ monthlyText: string;
30
+ errorModal: any;
31
+ retryButton: any;
32
+ cancelButtonLinkText: any;
33
+ cartLimitWarningText: any;
34
+ cartLimitModal: any;
35
+ cartLimitBtnText: string;
36
+ paymentOptions: paymentOptionSchema[];
37
+ paymentHeadingText: string;
38
+ winAccessoriesLimit: number;
39
+ winLimitWarningText: any;
40
+ winCheckoutUrl: any;
41
+ }
@@ -0,0 +1,14 @@
1
+ /// <reference types="react" />
2
+ export interface paymentOptionSchema {
3
+ paymentSubText: string;
4
+ paymentText: string;
5
+ type: string;
6
+ }
7
+ interface PaymentTypeTabsProps {
8
+ content: {
9
+ paymentHeadingText: string;
10
+ paymentOptions: paymentOptionSchema[];
11
+ };
12
+ }
13
+ declare const PaymentTypeTabs: ({ content }: PaymentTypeTabsProps) => JSX.Element;
14
+ export default PaymentTypeTabs;
@@ -0,0 +1,13 @@
1
+ /// <reference types="react" />
2
+ import { ComponentWithContentProps, GenericSBProps } from '../../types';
3
+ interface ProgressionBarProps extends GenericSBProps {
4
+ pickYourDeviceLabel: string;
5
+ customizeDeviceLabel: string;
6
+ yourSubscriptionLabel: string;
7
+ checkoutLabel: string;
8
+ accessoriesLabel: string;
9
+ selectedStep?: string;
10
+ optionalLabelText: string;
11
+ }
12
+ declare const ProgressionBar: ({ content }: ComponentWithContentProps<ProgressionBarProps>) => JSX.Element;
13
+ export default ProgressionBar;
@@ -0,0 +1 @@
1
+ export { default } from './MultiItemAccessories/MultiItemAccessoriesPage';
@@ -0,0 +1,19 @@
1
+ import React from 'react';
2
+ import { AppProviderSchema, AppContextType } from './types';
3
+ export declare const actionTypes: {
4
+ recommendedAccessories: string;
5
+ multiItemAccessoriessList: string;
6
+ selectedAccessories: string;
7
+ deviceSessionValues: string;
8
+ removeSelectedCartAccessories: string;
9
+ selectedPaymentType: string;
10
+ recommendedAccessoriesStart: string;
11
+ RecommendedAccessoriesSuccess: string;
12
+ recommendedAccessoriesFailure: string;
13
+ updateAccessoryCartSuccess: string;
14
+ updateAccessoryCartFailure: string;
15
+ updateAccessoryCartStart: string;
16
+ };
17
+ export declare const AppContext: React.Context<AppContextType | undefined>;
18
+ declare const MultiAccessoryProvider: ({ children }: AppProviderSchema) => JSX.Element;
19
+ export default MultiAccessoryProvider;
@@ -0,0 +1,71 @@
1
+ import { GenericSBProps } from '../../types';
2
+ import { ReactNode } from 'react';
3
+ export interface AppProviderSchema {
4
+ children: ReactNode;
5
+ }
6
+ export interface ActionSchema {
7
+ type: string;
8
+ payload: any;
9
+ }
10
+ export interface AppContextType {
11
+ store: recommendationSliceStore & UpdateCartSliceStore;
12
+ dispatch: React.Dispatch<ActionSchema>;
13
+ }
14
+ export interface recurringPriceSchema extends GenericSBProps {
15
+ upFront: string;
16
+ monthlyInstallement: string;
17
+ finalInsallement: string;
18
+ marketMonthlyInstallment: string;
19
+ marketFinalInstallement: string;
20
+ }
21
+ export interface oneTimePriceSchema extends GenericSBProps {
22
+ market: string;
23
+ base: string;
24
+ }
25
+ export interface multiAccessoryListSchema extends GenericSBProps {
26
+ id: string;
27
+ name: string;
28
+ inCart: boolean;
29
+ defaultVariantProductCode: string;
30
+ recurringPrice: recurringPriceSchema;
31
+ oneTimePrice: oneTimePriceSchema;
32
+ color: string;
33
+ baseProducts: string;
34
+ }
35
+ export interface recommendationSliceStore {
36
+ isFetchingRecommendedAccessories: boolean;
37
+ recommendedAccessories: multiAccessoryListSchema[];
38
+ multiItemAccessoriessList: any;
39
+ selectedAccessories: any;
40
+ deviceSessionValues: any;
41
+ removeSelectedCartAccessories: any;
42
+ selectedPaymentType: string;
43
+ }
44
+ export interface Note {
45
+ author: string;
46
+ text: string;
47
+ group?: string;
48
+ }
49
+ export interface updateCartItem {
50
+ id: string | number;
51
+ note?: Note[];
52
+ contractTerm?: number;
53
+ action: string;
54
+ }
55
+ export interface updateCartItemList {
56
+ itemType: string;
57
+ items: updateCartItem[];
58
+ }
59
+ export interface updateCart {
60
+ cartItem: updateCartItemList[];
61
+ }
62
+ export interface UpdateCartSliceStore {
63
+ loading: boolean;
64
+ cart: updateCart;
65
+ updateAccessoryCartSuccess: updateCart;
66
+ updateAccessoryCartFailure: any;
67
+ }
68
+ export interface updateCreatecartItemData {
69
+ id: any;
70
+ redirectUrl: string;
71
+ }
@@ -0,0 +1,15 @@
1
+ import { ActionSchema } from './types';
2
+ /**
3
+ * Custom hook that provides action creators for Multi Accessory Context
4
+ * @param dispatch - Dispatch function from the MultiAccessoryContext
5
+ * @returns Object containing all action creator functions
6
+ */
7
+ export declare const useMultiAccessoryActions: (dispatch: React.Dispatch<ActionSchema>) => {
8
+ setRecommendedAccessories: (payload: any) => void;
9
+ setSelectedAccessories: (payload: any) => void;
10
+ setMultiItemAccessoriessList: (payload: any) => void;
11
+ setDeviceSessionValues: (payload: any) => void;
12
+ setRemoveSelectedCartAccessories: (payload: any) => void;
13
+ setSelectedPaymentType: (payload: string) => void;
14
+ getRecommendedAccessory: (cartId: any) => Promise<any>;
15
+ };
@@ -0,0 +1,32 @@
1
+ /// <reference types="react" />
2
+ import { AppContextType } from './types';
3
+ /**
4
+ * Custom hook to consume the MultiAccessoryContext
5
+ * @returns Context value containing store (state) and dispatch
6
+ * @throws Error if used outside of MultiAccessoryProvider
7
+ * @example
8
+ * ```tsx
9
+ * const { store, dispatch } = useMultiAccessoryContext();
10
+ * const { recommendedAccessories, selectedAccessories } = store;
11
+ * ```
12
+ */
13
+ export declare const useMultiAccessoryContext: () => AppContextType;
14
+ /**
15
+ * Custom hook that combines context and actions
16
+ * Provides both state and action creators in one hook for convenience
17
+ * @returns Object containing store (state), dispatch, and all action creators
18
+ * @example
19
+ * ```tsx
20
+ * const { store, actions } = useMultiAccessory();
21
+ * // Access state
22
+ * const { recommendedAccessories, selectedAccessories } = store;
23
+ * // Call actions
24
+ * actions.setSelectedAccessories(data);
25
+ * actions.getRecommendedAccessory(cartId);
26
+ * ```
27
+ */
28
+ export declare const useMultiAccessory: () => {
29
+ store: import("./types").recommendationSliceStore & import("./types").UpdateCartSliceStore;
30
+ dispatch: import("react").Dispatch<import("./types").ActionSchema>;
31
+ actions: any;
32
+ };
@@ -0,0 +1,11 @@
1
+ import { ActionSchema, updateCreatecartItemData } from './types';
2
+ /**
3
+ * Custom hook that provides action creators for Multi Accessory Context
4
+ * @param dispatch - Dispatch function from the MultiAccessoryContext
5
+ * @returns Object containing all action creator functions
6
+ */
7
+ export declare const useMultiAccessoryUpdateCartActions: (dispatch: React.Dispatch<ActionSchema>) => {
8
+ setupdateAccessoryCartSuccess: (payload: any) => void;
9
+ setupdateAccessoryCartFailure: (payload: any) => void;
10
+ multiItemAccessorycreateCartRequest: (updateCreatecartItemData: updateCreatecartItemData, multiAccessoryState: any) => Promise<any>;
11
+ };
@@ -1,7 +1,7 @@
1
1
  import { FC } from "react";
2
2
  import "./Dotloader.css";
3
3
  interface DotLoaderSchema {
4
- keyParams: string;
4
+ keyParams?: string;
5
5
  }
6
6
  declare const Dotloader: FC<DotLoaderSchema>;
7
7
  export default Dotloader;
@@ -7,7 +7,7 @@ interface OttServiceOptionsSmallPopupProps {
7
7
  mainContent: any;
8
8
  preSelectedOptions: any[];
9
9
  optionsResponse: any[];
10
- updateResponseList: (list: any) => void;
10
+ updateResponseList?: (list: any) => void;
11
11
  showPrice?: any;
12
12
  productData?: any;
13
13
  offeringData?: any;
@@ -19,3 +19,4 @@ export { default as StickyBottomSheet } from './StickyBottomSheet';
19
19
  export { default as ProgressionBar } from './ProgressionBar';
20
20
  export { default as OttServiceOptionsSmallPopup } from './StaticLineTable/OttServiceOptions/OttServiceOptionsSmallPopup';
21
21
  export { default as NotificationToast } from './NotificationToast/NotificationToast';
22
+ export { default as MultiItemAccessoriesWithProvider } from './Accessories';
@@ -1,3 +1,4 @@
1
+ import { FalconButtonTypes } from '../utils/data-source';
1
2
  export interface Link {
2
3
  id: number;
3
4
  slug: string;
@@ -58,3 +59,36 @@ export interface ComponentWithContentProps<T extends GenericSBProps = GenericSBP
58
59
  content: T;
59
60
  metadata?: ComponentMetadata | undefined;
60
61
  }
62
+ export interface FalconButtonSchema extends GenericSBProps {
63
+ buttonLabel?: string;
64
+ buttonIcon?: Asset;
65
+ buttonHoverIcon?: Asset;
66
+ buttonClickedIcon?: Asset;
67
+ buttonDisabledIcon?: Asset;
68
+ buttonLink: MultiLink;
69
+ linkTarget: LinkTarget;
70
+ buttonType: FalconButtonTypes;
71
+ iconPosition: string;
72
+ buttonAlignment: Alignment;
73
+ asset?: Asset;
74
+ id?: string;
75
+ bloks?: any;
76
+ minWidth: number;
77
+ enableScroll: boolean;
78
+ targetElement: componentsInStory;
79
+ blackFridayThemeIcon: Asset;
80
+ fromTallhero?: boolean;
81
+ }
82
+ export interface MultiLink {
83
+ id: string;
84
+ url: string;
85
+ linktype: 'url' | 'story';
86
+ fieldtype: 'multilink';
87
+ cached_url: string;
88
+ }
89
+ export type LinkTarget = '_self' | '_blank' | null;
90
+ export interface componentsInStory {
91
+ _uid: string;
92
+ plugin: string;
93
+ blockIdentifier: string;
94
+ }