interface.d.ts 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. import type { TriggerProps } from '@rc-component/trigger';
  2. import type { PlacementType } from './placements';
  3. import type { CSSProperties, ReactNode } from 'react';
  4. import type { Gap } from './hooks/useTarget';
  5. import { type DefaultPanelProps } from './TourStep/DefaultPanel';
  6. export interface TourStepInfo {
  7. arrow?: boolean | {
  8. pointAtCenter: boolean;
  9. };
  10. target?: HTMLElement | (() => HTMLElement) | null | (() => null);
  11. title: ReactNode;
  12. description?: ReactNode;
  13. placement?: PlacementType;
  14. mask?: boolean | {
  15. style?: React.CSSProperties;
  16. color?: string;
  17. };
  18. className?: string;
  19. style?: CSSProperties;
  20. scrollIntoViewOptions?: boolean | ScrollIntoViewOptions;
  21. closeIcon?: ReactNode;
  22. closable?: boolean | ({
  23. closeIcon?: ReactNode;
  24. } & React.AriaAttributes);
  25. }
  26. export interface TourStepProps extends TourStepInfo {
  27. prefixCls?: string;
  28. total?: number;
  29. current?: number;
  30. onClose?: () => void;
  31. onFinish?: () => void;
  32. renderPanel?: (step: TourStepProps, current: number) => ReactNode;
  33. onPrev?: () => void;
  34. onNext?: () => void;
  35. }
  36. export interface TourProps extends Pick<TriggerProps, 'onPopupAlign'> {
  37. steps?: TourStepInfo[];
  38. open?: boolean;
  39. defaultCurrent?: number;
  40. current?: number;
  41. onChange?: (current: number) => void;
  42. onClose?: (current: number) => void;
  43. onFinish?: () => void;
  44. closeIcon?: TourStepProps['closeIcon'];
  45. closable?: TourStepProps['closable'];
  46. mask?: boolean | {
  47. style?: React.CSSProperties;
  48. color?: string;
  49. };
  50. arrow?: boolean | {
  51. pointAtCenter: boolean;
  52. };
  53. rootClassName?: string;
  54. placement?: PlacementType;
  55. prefixCls?: string;
  56. renderPanel?: (props: DefaultPanelProps, current: number) => ReactNode;
  57. gap?: Gap;
  58. animated?: boolean | {
  59. placeholder: boolean;
  60. };
  61. scrollIntoViewOptions?: boolean | ScrollIntoViewOptions;
  62. zIndex?: number;
  63. getPopupContainer?: TriggerProps['getPopupContainer'];
  64. builtinPlacements?: TriggerProps['builtinPlacements'] | ((config?: {
  65. arrowPointAtCenter?: boolean;
  66. }) => TriggerProps['builtinPlacements']);
  67. disabledInteraction?: boolean;
  68. }