All files / src/transition SlideTransition.tsx

42.86% Statements 3/7
50% Branches 3/6
100% Functions 1/1
42.86% Lines 3/7

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37                                                  72x     72x       72x        
import React from "react";
import { CSSTransition } from "react-transition-group";
import { TransitionProps } from "react-transition-group/Transition";
import { slide, Position } from "../_util/transition";
 
export interface SlideTransitionProps extends Partial<TransitionProps> {
  /**
   * 从哪个位置进入,相对 DOM 本身的位置 [x, y]。默认为 [0, -30]
   */
  from?: Position;
 
  /**
   * 消失到哪个位置,默认和 from 相等
   */
  to?: Position;
}
 
export function SlideTransition({
  from,
  to,
  timeout,
  ...rest
}: SlideTransitionProps) {
  let enterTimeout: number;
  let exitTimeout: number;
  Iif (typeof timeout === "number") {
    enterTimeout = timeout;
    exitTimeout = timeout;
  } else Iif (timeout && typeof timeout === "object") {
    enterTimeout = timeout.enter;
    exitTimeout = timeout.exit;
  }
  return (
    <CSSTransition {...slide(from, to, enterTimeout, exitTimeout)} {...rest} />
  );
}