import type { TurningMode } from '@/types/slides' export const ANIMATION_DEFAULT_DURATION = 1000 export const ANIMATION_DEFAULT_TRIGGER = 'click' export const ANIMATION_CLASS_PREFIX = 'animate__' export const ENTER_ANIMATIONS = [ { type: 'bounce', name: '弹跳', children: [ { name: '弹入', value: 'bounceIn' }, { name: '向右弹入', value: 'bounceInLeft' }, { name: '向左弹入', value: 'bounceInRight' }, { name: '向上弹入', value: 'bounceInUp' }, { name: '向下弹入', value: 'bounceInDown' }, ], }, { type: 'fade', name: '浮现', children: [ { name: '浮入', value: 'fadeIn' }, { name: '向下浮入', value: 'fadeInDown' }, { name: '向下长距浮入', value: 'fadeInDownBig' }, { name: '向右浮入', value: 'fadeInLeft' }, { name: '向右长距浮入', value: 'fadeInLeftBig' }, { name: '向左浮入', value: 'fadeInRight' }, { name: '向左长距浮入', value: 'fadeInRightBig' }, { name: '向上浮入', value: 'fadeInUp' }, { name: '向上长距浮入', value: 'fadeInUpBig' }, { name: '从左上浮入', value: 'fadeInTopLeft' }, { name: '从右上浮入', value: 'fadeInTopRight' }, { name: '从左下浮入', value: 'fadeInBottomLeft' }, { name: '从右下浮入', value: 'fadeInBottomRight' }, ], }, { type: 'rotate', name: '旋转', children: [ { name: '旋转进入', value: 'rotateIn' }, { name: '绕左下进入', value: 'rotateInDownLeft' }, { name: '绕右下进入', value: 'rotateInDownRight' }, { name: '绕左上进入', value: 'rotateInUpLeft' }, { name: '绕右上进入', value: 'rotateInUpRight' }, ], }, { type: 'zoom', name: '缩放', children: [ { name: '放大进入', value: 'zoomIn' }, { name: '向下放大进入', value: 'zoomInDown' }, { name: '从左放大进入', value: 'zoomInLeft' }, { name: '从右放大进入', value: 'zoomInRight' }, { name: '向上放大进入', value: 'zoomInUp' }, ], }, { type: 'slide', name: '滑入', children: [ { name: '向下滑入', value: 'slideInDown' }, { name: '从右滑入', value: 'slideInLeft' }, { name: '从左滑入', value: 'slideInRight' }, { name: '向上滑入', value: 'slideInUp' }, ], }, { type: 'flip', name: '翻转', children: [ { name: 'X轴翻转进入', value: 'flipInX' }, { name: 'Y轴翻转进入', value: 'flipInY' }, ], }, { type: 'back', name: '放大滑入', children: [ { name: '向下放大滑入', value: 'backInDown' }, { name: '从左放大滑入', value: 'backInLeft' }, { name: '从右放大滑入', value: 'backInRight' }, { name: '向上放大滑入', value: 'backInUp' }, ], }, { type: 'lightSpeed', name: '飞入', children: [ { name: '从右飞入', value: 'lightSpeedInRight' }, { name: '从左飞入', value: 'lightSpeedInLeft' }, ], }, ] export const EXIT_ANIMATIONS = [ { type: 'bounce', name: '弹跳', children: [ { name: '弹出', value: 'bounceOut' }, { name: '向左弹出', value: 'bounceOutLeft' }, { name: '向右弹出', value: 'bounceOutRight' }, { name: '向上弹出', value: 'bounceOutUp' }, { name: '向下弹出', value: 'bounceOutDown' }, ], }, { type: 'fade', name: '浮现', children: [ { name: '浮出', value: 'fadeOut' }, { name: '向下浮出', value: 'fadeOutDown' }, { name: '向下长距浮出', value: 'fadeOutDownBig' }, { name: '向左浮出', value: 'fadeOutLeft' }, { name: '向左长距浮出', value: 'fadeOutLeftBig' }, { name: '向右浮出', value: 'fadeOutRight' }, { name: '向右长距浮出', value: 'fadeOutRightBig' }, { name: '向上浮出', value: 'fadeOutUp' }, { name: '向上长距浮出', value: 'fadeOutUpBig' }, { name: '从左上浮出', value: 'fadeOutTopLeft' }, { name: '从右上浮出', value: 'fadeOutTopRight' }, { name: '从左下浮出', value: 'fadeOutBottomLeft' }, { name: '从右下浮出', value: 'fadeOutBottomRight' }, ], }, { type: 'rotate', name: '旋转', children: [ { name: '旋转退出', value: 'rotateOut' }, { name: '绕左下退出', value: 'rotateOutDownLeft' }, { name: '绕右下退出', value: 'rotateOutDownRight' }, { name: '绕左上退出', value: 'rotateOutUpLeft' }, { name: '绕右上退出', value: 'rotateOutUpRight' }, ], }, { type: 'zoom', name: '缩放', children: [ { name: '缩小退出', value: 'zoomOut' }, { name: '向下缩小退出', value: 'zoomOutDown' }, { name: '从左缩小退出', value: 'zoomOutLeft' }, { name: '从右缩小退出', value: 'zoomOutRight' }, { name: '向上缩小退出', value: 'zoomOutUp' }, ], }, { type: 'slide', name: '滑出', children: [ { name: '向下滑出', value: 'slideOutDown' }, { name: '从左滑出', value: 'slideOutLeft' }, { name: '从右滑出', value: 'slideOutRight' }, { name: '向上滑出', value: 'slideOutUp' }, ], }, { type: 'flip', name: '翻转', children: [ { name: 'X轴翻转退出', value: 'flipOutX' }, { name: 'Y轴翻转退出', value: 'flipOutY' }, ], }, { type: 'back', name: '缩小滑出', children: [ { name: '向下缩小滑出', value: 'backOutDown' }, { name: '从左缩小滑出', value: 'backOutLeft' }, { name: '从右缩小滑出', value: 'backOutRight' }, { name: '向上缩小滑出', value: 'backOutUp' }, ], }, { type: 'lightSpeed', name: '飞出', children: [ { name: '从右飞出', value: 'lightSpeedOutRight' }, { name: '从左飞出', value: 'lightSpeedOutLeft' }, ], }, ] export const ATTENTION_ANIMATIONS = [ { type: 'shake', name: '晃动', children: [ { name: '左右摇晃', value: 'shakeX' }, { name: '上下摇晃', value: 'shakeY' }, { name: '摇头', value: 'headShake' }, { name: '摆动', value: 'swing' }, { name: '晃动', value: 'wobble' }, { name: '惊恐', value: 'tada' }, { name: '果冻', value: 'jello' }, ], }, { type: 'other', name: '其他', children: [ { name: '弹跳', value: 'bounce' }, { name: '闪烁', value: 'flash' }, { name: '脉搏', value: 'pulse' }, { name: '橡皮筋', value: 'rubberBand' }, { name: '心跳(快)', value: 'heartBeat' }, ], }, ] interface SlideAnimation { label: string value: TurningMode } export const SLIDE_ANIMATIONS: SlideAnimation[] = [ { label: '无', value: 'no' }, { label: '随机', value: 'random' }, { label: '左右推移', value: 'slideX' }, { label: '上下推移', value: 'slideY' }, { label: '左右推移(3D)', value: 'slideX3D' }, { label: '上下推移(3D)', value: 'slideY3D' }, { label: '淡入淡出', value: 'fade' }, { label: '旋转', value: 'rotate' }, { label: '上下展开', value: 'scaleY' }, { label: '左右展开', value: 'scaleX' }, { label: '放大', value: 'scale' }, { label: '缩小', value: 'scaleReverse' }, ]