@jolibox/ui 1.0.0 → 1.3.3-beta.1

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 (44) hide show
  1. package/dist/assets/close.d.ts +1 -0
  2. package/dist/assets/coin.d.ts +3 -0
  3. package/dist/assets/correct.d.ts +1 -0
  4. package/dist/assets/error.d.ts +1 -0
  5. package/dist/assets/success.d.ts +1 -0
  6. package/dist/assets/tips.d.ts +8 -0
  7. package/dist/bridge/coin/components/charge-grid.d.ts +15 -0
  8. package/dist/bridge/coin/components/coin-status.d.ts +22 -0
  9. package/dist/bridge/coin/components/fixed-image.d.ts +11 -0
  10. package/dist/bridge/coin/components/index.d.ts +45 -0
  11. package/dist/bridge/coin/components/toggle.d.ts +4 -0
  12. package/dist/bridge/coin/components/unlogin-modal.d.ts +13 -0
  13. package/dist/bridge/coin/index.d.ts +73 -0
  14. package/dist/bridge/index.d.ts +1 -0
  15. package/dist/bridge/recommend/components/grid/index.d.ts +2 -1
  16. package/dist/bridge/recommend/index.d.ts +1 -1
  17. package/dist/bridge/report/index.d.ts +9 -0
  18. package/dist/components/create-loading.d.ts +18 -0
  19. package/dist/components/create-modal.d.ts +4 -2
  20. package/dist/components/create-toast.d.ts +18 -0
  21. package/dist/components/drawer/index.d.ts +2 -1
  22. package/dist/components/i18n/index.d.ts +8 -0
  23. package/dist/components/pattern-processer/index.d.ts +20 -0
  24. package/dist/components/pattern-processer/patterns/coin.d.ts +1 -0
  25. package/dist/components/pattern-processer/patterns/correct.d.ts +1 -0
  26. package/dist/components/pattern-processer/patterns/error.d.ts +1 -0
  27. package/dist/components/pattern-processer/patterns/i18n-text.d.ts +1 -0
  28. package/dist/components/pattern-processer/patterns/i18n-trans.d.ts +1 -0
  29. package/dist/components/pattern-processer/patterns/index.d.ts +2 -0
  30. package/dist/components/pattern-processer/patterns/mark.d.ts +1 -0
  31. package/dist/components/pattern-processer/patterns/success.d.ts +1 -0
  32. package/dist/components/utils/detect-language.d.ts +10 -0
  33. package/dist/components/utils/singleton-iframe.d.ts +21 -0
  34. package/dist/hooks/useOrientation.d.ts +7 -0
  35. package/dist/hooks/useTransition.d.ts +5 -0
  36. package/dist/index.cjs.js +566 -2
  37. package/dist/index.cjs.js.map +1 -1
  38. package/dist/index.d.ts +4 -0
  39. package/dist/index.es.js +4791 -980
  40. package/dist/index.es.js.map +1 -1
  41. package/dist/lib/i18n/i18n-context.d.ts +7 -0
  42. package/dist/lib/i18n/i18n-provider.d.ts +8 -0
  43. package/dist/lib/i18n/index.d.ts +1034 -0
  44. package/package.json +15 -9
@@ -0,0 +1 @@
1
+ export declare const Close: () => import("preact").JSX.Element;
@@ -0,0 +1,3 @@
1
+ export declare const defaultCoinImage = "";
2
+ export declare const defaultCoinUrl = "https://fe-oss.jolibox.com/static/coin/jolicoin.png";
3
+ export declare const defaultGemImage = "https://fe-oss.jolibox.com/static/coin/gem.png";
@@ -0,0 +1 @@
1
+ export declare const defaultCorrectImg = "";
@@ -0,0 +1 @@
1
+ export declare const defaultErrorImg = "";
@@ -0,0 +1 @@
1
+ export declare const defaultSuccessImg = "";
@@ -0,0 +1,8 @@
1
+ import { ComponentChildren, h } from 'preact';
2
+ export declare const Triangle: ({ style }: {
3
+ style?: preact.JSX.CSSProperties;
4
+ }) => h.JSX.Element;
5
+ export declare function TipsBubble({ children, style }: {
6
+ children: ComponentChildren;
7
+ style?: preact.JSX.CSSProperties;
8
+ }): h.JSX.Element;
@@ -0,0 +1,15 @@
1
+ interface RechargeOption {
2
+ coins: number;
3
+ price: string;
4
+ id: string;
5
+ defaultSelected?: boolean;
6
+ }
7
+ interface RechargeGridProps {
8
+ options: RechargeOption[];
9
+ selectedId: string;
10
+ currency: 'JOLI_COIN' | 'JOLI_GEM';
11
+ onSelect?: (option: RechargeOption) => void;
12
+ coinImageSrc?: string;
13
+ }
14
+ export declare const ChargeGrid: import("preact").FunctionComponent<RechargeGridProps>;
15
+ export {};
@@ -0,0 +1,22 @@
1
+ interface CoinInfoProps {
2
+ unlockNeedsAmount?: number;
3
+ balanceAmount?: number;
4
+ coinImage?: string;
5
+ formatter?: (amount: number) => string;
6
+ hideNeeds?: boolean;
7
+ hideBalance?: boolean;
8
+ className?: string;
9
+ currency?: 'JOLI_COIN' | 'JOLI_GEM';
10
+ }
11
+ /**
12
+ *
13
+ * @param unlockNeedsAmount
14
+ * @param balanceAmount
15
+ * @param coinImage
16
+ * @param formatter
17
+ * @param hideNeeds
18
+ * @param hideBalance
19
+ * @param className
20
+ */
21
+ export declare const CoinInfoDisplay: React.FC<CoinInfoProps>;
22
+ export {};
@@ -0,0 +1,11 @@
1
+ import { h } from 'preact';
2
+ interface FixedImageProps {
3
+ src: string;
4
+ alt?: string;
5
+ width?: number | string;
6
+ height?: number | string;
7
+ top?: number | string;
8
+ style?: preact.JSX.CSSProperties;
9
+ }
10
+ export declare function FixedImage({ src, alt, width, height, top, style }: FixedImageProps): h.JSX.Element | null;
11
+ export {};
@@ -0,0 +1,45 @@
1
+ import { IPaymentChoice } from '@/index';
2
+ interface CoinConfirmProps {
3
+ currency: 'JOLI_COIN' | 'JOLI_GEM';
4
+ unlockNeedsAmount: number;
5
+ balanceAmount: number;
6
+ defaultEnableAutoDeduct: boolean;
7
+ confirmButtonKey: string;
8
+ cancelButtonKey: string;
9
+ onConfirm: (enableAutoDeduct: boolean) => void;
10
+ onClose: (params: {
11
+ type?: 'CANCEL' | 'FAILED' | 'CONFIRM';
12
+ }) => void;
13
+ onEnableDeductChanged: (enableAutoDeduct: boolean) => void;
14
+ }
15
+ export declare const styles: {
16
+ modal: import("@emotion/react").SerializedStyles;
17
+ header: import("@emotion/react").SerializedStyles;
18
+ closeButton: import("@emotion/react").SerializedStyles;
19
+ content: import("@emotion/react").SerializedStyles;
20
+ title: import("@emotion/react").SerializedStyles;
21
+ autoDeductOption: import("@emotion/react").SerializedStyles;
22
+ buttonContainer: import("@emotion/react").SerializedStyles;
23
+ buttonFlex: import("@emotion/react").SerializedStyles;
24
+ confirmButton: import("@emotion/react").SerializedStyles;
25
+ cancelButton: import("@emotion/react").SerializedStyles;
26
+ bottomIndicator: import("@emotion/react").SerializedStyles;
27
+ };
28
+ export declare const CoinConfirmContent: React.FC<CoinConfirmProps>;
29
+ interface CoinPaymentProps {
30
+ currency: 'JOLI_COIN' | 'JOLI_GEM';
31
+ balanceAmount: number;
32
+ unlockNeedsAmount: number;
33
+ defaultEnableAutoDeduct: boolean;
34
+ paymentChoices: IPaymentChoice[];
35
+ onConfirm: (productId: string) => void;
36
+ onClose: (params: {
37
+ type?: 'CANCEL' | 'FAILED' | 'CONFIRM';
38
+ }) => void;
39
+ onEnableDeductChanged: (enalbed: boolean) => void;
40
+ confirmButtonKey: string;
41
+ cancelButtonKey: string;
42
+ onSelect: (productId: string) => void;
43
+ }
44
+ export declare const CoinPaymentContent: React.FC<CoinPaymentProps>;
45
+ export {};
@@ -0,0 +1,4 @@
1
+ export declare const Toggle: ({ enableAutoDeduct, toggleEnableAutoDeduct }: {
2
+ enableAutoDeduct: boolean;
3
+ toggleEnableAutoDeduct: () => void;
4
+ }) => import("@emotion/react/jsx-runtime").JSX.Element;
@@ -0,0 +1,13 @@
1
+ interface CoinUnloginContentProps {
2
+ rewardType: 'JOLI_COIN' | 'ADS-JOLI_COIN' | 'JOLI_GEM' | 'ADS-JOLI_GEM';
3
+ currency: 'JOLI_COIN' | 'JOLI_GEM';
4
+ rewardValue: number;
5
+ confirmButtonKey: string;
6
+ cancelButtonKey: string;
7
+ onClose: (params: {
8
+ type?: 'CANCEL' | 'FAILED' | 'CONFIRM';
9
+ }) => void;
10
+ onConfirm: () => void;
11
+ }
12
+ export declare const CoinUnloginContent: ({ currency, rewardType, rewardValue, confirmButtonKey, cancelButtonKey, onClose, onConfirm }: CoinUnloginContentProps) => import("preact").JSX.Element;
13
+ export {};
@@ -0,0 +1,73 @@
1
+ export interface IJoliCoin {
2
+ balance: number;
3
+ enableAutoDeduct: boolean;
4
+ }
5
+ export interface IGem {
6
+ balance: number;
7
+ enableAutoDeduct: boolean;
8
+ }
9
+ export interface IPaymentChoice {
10
+ productId: string;
11
+ totalAmountStr: string;
12
+ quantity: number;
13
+ defaultSelected?: boolean;
14
+ }
15
+ interface IButton {
16
+ text: string;
17
+ onPress: (...args: any[]) => void;
18
+ }
19
+ export declare const createConfirmJolicoinModal: (params: {
20
+ data: {
21
+ userCurrency: IJoliCoin | IGem;
22
+ enableAutoDeduct: boolean;
23
+ quantity: number;
24
+ currency: "JOLI_COIN" | "JOLI_GEM";
25
+ };
26
+ buttons: {
27
+ confirm: IButton;
28
+ cancel: IButton;
29
+ onEnableDeductChanged: (enalbed: boolean) => void;
30
+ };
31
+ }) => {
32
+ show: () => void;
33
+ hide: () => void;
34
+ isOpen: () => boolean;
35
+ destroy: () => void;
36
+ };
37
+ export declare const createPaymentJolicoinModal: (params: {
38
+ data: {
39
+ userCurrency: IJoliCoin | IGem;
40
+ paymentChoices: IPaymentChoice[];
41
+ enableAutoDeduct: boolean;
42
+ quantity: number;
43
+ currency: "JOLI_COIN" | "JOLI_GEM";
44
+ };
45
+ buttons: {
46
+ confirm: IButton;
47
+ cancel: IButton;
48
+ onEnableDeductChanged: (enalbed: boolean) => void;
49
+ };
50
+ onSelect: (productId: string) => void;
51
+ }) => {
52
+ show: () => void;
53
+ hide: () => void;
54
+ isOpen: () => boolean;
55
+ destroy: () => void;
56
+ };
57
+ export declare const createUnloginJolicoinModal: (params: {
58
+ data: {
59
+ rewardType: "JOLI_COIN" | "ADS-JOLI_COIN" | "JOLI_GEM" | "ADS-JOLI_GEM";
60
+ rewardValue: number;
61
+ currency: "JOLI_COIN" | "JOLI_GEM";
62
+ };
63
+ buttons: {
64
+ confirm: IButton;
65
+ cancel: IButton;
66
+ };
67
+ }) => {
68
+ show: () => void;
69
+ hide: () => void;
70
+ isOpen: () => boolean;
71
+ destroy: () => void;
72
+ };
73
+ export {};
@@ -1 +1,2 @@
1
1
  export { createRecommendModal } from './recommend';
2
+ export { createConfirmJolicoinModal } from './coin';
@@ -6,6 +6,7 @@ interface IGameListProps extends PropsWithChildren {
6
6
  layerName: string;
7
7
  routeMode: 'REDIRECT' | 'NAVIGATE';
8
8
  onGameClick?: (game: IGame) => void;
9
+ orientation: 'portrait' | 'landscape';
9
10
  }
10
- export declare const GamesGrid: ({ list, routeMode, layerName, onGameClick, ...restProps }: IGameListProps) => h.JSX.Element;
11
+ export declare const GamesGrid: ({ list, routeMode, layerName, onGameClick, orientation, ...restProps }: IGameListProps) => h.JSX.Element;
11
12
  export {};
@@ -1,6 +1,6 @@
1
1
  import { IGame, IRecommendationButton } from './types';
2
2
  export type RecommendModalOnCloseParams = {
3
- type: 'dismiss' | 'quit' | 'navigate';
3
+ type: 'dismiss' | 'quit' | 'navigate' | 'back';
4
4
  data?: {
5
5
  game: IGame;
6
6
  };
@@ -0,0 +1,9 @@
1
+ export declare const createReportModal: (params: {
2
+ onClose?: () => void;
3
+ onOpen?: () => void;
4
+ }) => {
5
+ show: () => void;
6
+ hide: () => void;
7
+ isOpen: () => boolean;
8
+ destroy: () => void;
9
+ };
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Creates a loading manager instance that interacts with the singleton iframe.
3
+ * @returns An object with show, hide, and isLoading properties.
4
+ */
5
+ export declare function createLoading(): {
6
+ show: (options?: {
7
+ duration?: number;
8
+ }) => Promise<void>;
9
+ hide: () => void;
10
+ readonly isLoading: boolean;
11
+ };
12
+ export declare const loadingManager: {
13
+ show: (options?: {
14
+ duration?: number;
15
+ }) => Promise<void>;
16
+ hide: () => void;
17
+ readonly isLoading: boolean;
18
+ };
@@ -1,13 +1,15 @@
1
1
  import { h } from 'preact';
2
- export type ModalPlacement = 'top' | 'end' | 'bottom' | 'start';
2
+ export type ModalPlacement = 'top' | 'end' | 'bottom' | 'start' | 'center';
3
3
  export interface ModalOptions {
4
4
  title: string;
5
5
  content: h.JSX.Element | HTMLElement;
6
+ height?: number | string;
6
7
  placement?: ModalPlacement;
7
8
  noHeader?: boolean;
8
9
  padding?: string;
9
10
  onClose?: (...args: any[]) => void;
10
11
  onOpen?: (...args: any[]) => void;
12
+ preventCloseOnBackdropClick?: boolean;
11
13
  backdropColor?: string;
12
14
  footerButtons?: Array<{
13
15
  text: string;
@@ -17,7 +19,7 @@ export interface ModalOptions {
17
19
  }) => void;
18
20
  }>;
19
21
  }
20
- export declare const createModal: (options: ModalOptions) => {
22
+ export declare const createModal: (options: Omit<ModalOptions, "dynamicCss">) => {
21
23
  show: () => void;
22
24
  hide: () => void;
23
25
  isOpen: () => boolean;
@@ -0,0 +1,18 @@
1
+ export interface IToastOptions {
2
+ type?: 'success' | 'error' | 'info' | 'warning';
3
+ duration?: number;
4
+ checkmarkImage?: string;
5
+ coinImage?: string;
6
+ gemImage?: string;
7
+ customStyle?: {
8
+ mark?: React.CSSProperties;
9
+ coin?: React.CSSProperties;
10
+ gem?: React.CSSProperties;
11
+ base?: React.CSSProperties;
12
+ correct?: React.CSSProperties;
13
+ span?: React.CSSProperties;
14
+ };
15
+ i18nParams?: Record<string, string | number>;
16
+ position?: 'top' | 'center';
17
+ }
18
+ export declare const createToast: (pattern: string, options?: IToastOptions) => Promise<void>;
@@ -3,9 +3,10 @@ interface DrawerProps {
3
3
  children: ComponentChildren;
4
4
  isOpen?: boolean;
5
5
  onClose?: () => void;
6
- height?: string | number;
7
6
  className?: string;
7
+ placement?: 'top' | 'end' | 'bottom' | 'start' | 'center';
8
8
  backdropColor?: string;
9
+ preventCloseOnBackdropClick?: boolean;
9
10
  }
10
11
  interface DrawerRef {
11
12
  show: () => void;
@@ -0,0 +1,8 @@
1
+ import { h } from 'preact';
2
+ interface TransProps {
3
+ children: string;
4
+ values?: Record<string, preact.ComponentChildren>;
5
+ style?: preact.JSX.CSSProperties;
6
+ }
7
+ export declare function Trans({ children, values, style }: TransProps): h.JSX.Element;
8
+ export {};
@@ -0,0 +1,20 @@
1
+ import './patterns/mark';
2
+ import './patterns/coin';
3
+ import './patterns/i18n-text';
4
+ import './patterns/i18n-trans';
5
+ import './patterns/success';
6
+ import './patterns/error';
7
+ import './patterns/correct';
8
+ export declare const processPattern: (pattern: string, options?: {
9
+ coinImage?: string;
10
+ i18nParams?: Record<string, string | number>;
11
+ customStyle?: {
12
+ mark?: React.CSSProperties;
13
+ coin?: React.CSSProperties;
14
+ base?: React.CSSProperties;
15
+ correct?: React.CSSProperties;
16
+ span?: React.CSSProperties;
17
+ [key: string]: any;
18
+ };
19
+ [key: string]: any;
20
+ }) => string | preact.VNode;
@@ -0,0 +1,2 @@
1
+ export declare const patternDecoders: Map<RegExp, (match: RegExpMatchArray, options?: any) => string | preact.VNode>;
2
+ export declare const registerPatternDecoder: (pattern: RegExp, decoder: (match: RegExpMatchArray, options?: any) => string | preact.VNode) => void;
@@ -0,0 +1,10 @@
1
+ /**
2
+ * registerLanguageHandler is global function to register language handler.
3
+ * @param handler a function that returns the original language string.
4
+ */
5
+ export declare const registerLanguageHandler: (handler: () => string) => void;
6
+ /**
7
+ * getDetectedLanguage is global function to get detected and normalized language.
8
+ * @returns normalized language code (e.g. "en", "zh", "zh-Hant"), default to "en" if not registered or error occurs.
9
+ */
10
+ export declare const getDetectedLanguage: () => string;
@@ -0,0 +1,21 @@
1
+ import createCache from '@emotion/cache';
2
+ declare class SingletonIframeManager {
3
+ private zIndex;
4
+ private pointerEvents;
5
+ private persistentIframe;
6
+ iframeEmotionCache: ReturnType<typeof createCache> | null;
7
+ iframeLoadPromise: Promise<void> | null;
8
+ private iframeLoadResolver;
9
+ private removeGlobalTransformSync;
10
+ private referenceCount;
11
+ constructor(zIndex: number, pointerEvents: string);
12
+ private create;
13
+ acquire(): Promise<{
14
+ iframe: HTMLIFrameElement;
15
+ emotionCache: NonNullable<ReturnType<typeof createCache>>;
16
+ }>;
17
+ release(): void;
18
+ }
19
+ export declare const modalIframeManager: SingletonIframeManager;
20
+ export declare const toastIframeManager: SingletonIframeManager;
21
+ export {};
@@ -0,0 +1,7 @@
1
+ type OrientationType = 'portrait' | 'landscape';
2
+ /**
3
+ * Hook check current device orientation
4
+ * @returns current device orientation, 'portrait'(portrait) or 'landscape'(landscape)
5
+ */
6
+ export declare function useOrientation(): OrientationType;
7
+ export {};
@@ -0,0 +1,5 @@
1
+ import { Translations } from '../lib/i18n/i18n-context';
2
+ export declare const useTranslation: () => {
3
+ t: (key: string, params?: Record<string, string | number>) => string;
4
+ translations: Translations;
5
+ };