import { CSSProperties, LegacyRef, ReactNode } from 'react' import { COMPILE_MODE_SUB_RENDER_FN } from '@tarojs/shared' export interface StandardProps = ITouchEvent> extends EventProps { /** 组件的唯一标示, 保持整个页面唯一 */ id?: string /** 同 `class`,在 React/Preact 里一般使用 `className` 作为 `class` 的代称 */ className?: string /** 组件的内联样式, 可以动态设置的内联样式 */ style?: string | CSSProperties /** 子节点 */ children?: ReactNode /** 如果列表中项目的位置会动态改变或者有新的项目添加到列表中, * 需要使用 `wx:key` 来指定列表中项目的唯一的标识符。 */ key?: string | number /** 组件是否显示, 所有组件默认显示 */ hidden?: boolean /** 动画属性 */ animation?: { actions: TaroGeneral.IAnyObject[] } | TaroGeneral.IAnyObject /** 引用 */ ref?: LegacyRef /** * 渲染 HTML * @see /docs/html */ dangerouslySetInnerHTML?: { __html: string } /** * 是否开启编译模式 或者 是否是编译模式的子渲染函数 * @supported weapp, harmony */ compileMode?: boolean | string | typeof COMPILE_MODE_SUB_RENDER_FN /** * 自定义容器组件的方向 * @supported harmony */ harmonyDirection?: 'row' | 'column' | 'flex' } export interface FormItemProps { /** 表单数据标识 */ name?: string } export interface EventProps = ITouchEvent> { /** 手指触摸动作开始 */ onTouchStart?: (event: TouchEvent) => void /** 手指触摸后移动 */ onTouchMove?: (event: TouchEvent) => void /** 手指触摸动作被打断,如来电提醒,弹窗 */ onTouchCancel?: (event: TouchEvent) => void /** 手指触摸动作结束 */ onTouchEnd?: (event: TouchEvent) => void /** 手指触摸后马上离开 */ onClick?: (event: ITouchEvent) => void /** 手指触摸后,超过350ms再离开,如果指定了事件回调函数并触发了这个事件,tap事件将不被触发 */ onLongPress?: (event: CommonEvent) => void /** 手指触摸后,超过350ms再离开(推荐使用 longpress 事件代替) */ onLongClick?: (event: CommonEvent) => void /** 会在 WXSS transition 或 Taro.createAnimation 动画结束后触发 */ onTransitionEnd?: (event: CommonEvent) => void /** 会在一个 WXSS animation 动画开始时触发 */ onAnimationStart?: (event: CommonEvent) => void /** 会在一个 WXSS animation 一次迭代结束时触发 */ onAnimationIteration?: (event: CommonEvent) => void /** 会在一个 WXSS animation 动画完成时触发 */ onAnimationEnd?: (event: CommonEvent) => void /** 在支持 3D Touch 的 iPhone 设备,重按时会触发 */ onTouchForceChange?: (event: CommonEvent) => void } export type BaseEventOrigFunction = (event: BaseEventOrig) => void export type TouchEventFunction = (event: ITouchEvent) => void export type CanvasTouchEventFunction = (event: CanvasTouchEvent) => void export type CommonEvent = BaseEventOrig export type CommonEventFunction = BaseEventOrigFunction export interface BaseEventOrig { /** 事件类型 */ type: string /** 事件生成时的时间戳 */ timeStamp: number /** 触发事件的组件的一些属性值集合 */ target: Target /** 当前组件的一些属性值集合 */ currentTarget: currentTarget /** 额外的信息 */ detail: T /** 阻止元素发生默认的行为 */ preventDefault: () => void /** 阻止事件冒泡到父元素,阻止任何父事件处理程序被执行 */ stopPropagation: () => void } interface BaseTouchEvent extends BaseEventOrig { /** 触摸事件,当前停留在屏幕中的触摸点信息的数组 */ touches: Array /** 触摸事件,当前变化的触摸点信息的数组 */ changedTouches: Array } export type CanvasTouchEvent = BaseTouchEvent export type ITouchEvent = BaseTouchEvent export interface CanvasTouch { identifier: number x: number y: number } export interface ITouch extends Touch { /** 触摸点的标识符 */ identifier: number /** 距离文档左上角的距离,文档的左上角为原点 ,横向为X轴,纵向为Y轴 */ pageX: number /** 距离文档左上角的距离,文档的左上角为原点 ,横向为X轴,纵向为Y轴 */ pageY: number /** 距离页面可显示区域(屏幕除去导航条)左上角距离,横向为X轴,纵向为Y轴 */ clientX: number /** 距离页面可显示区域(屏幕除去导航条)左上角距离,横向为X轴,纵向为Y轴 */ clientY: number } export interface Target { /** 事件源组件的id */ id: string /** 当前组件的类型 */ tagName: string /** 事件源组件上由data-开头的自定义属性组成的集合 */ dataset: { [key: string]: any } } export type currentTarget = Target /** 网络状态数据 */ export interface NetStatus { /* 当前视频编/码器输出的比特率,单位 kbps */ videoBitrate?: number /* 当前音频编/码器输出的比特率,单位 kbps */ audioBitrate?: number /* 当前视频帧率 */ videoFPS?: number | string /* 当前视频 GOP,也就是每两个关键帧(I帧)间隔时长,单位 s */ videoGOP?: number /* 当前的发送/接收速度 */ netSpeed?: number /* 网络抖动情况,为 0 时表示没有任何抖动,值越大表明网络抖动越大,网络越不稳定 */ netJitter?: number /* 视频画面的宽度 */ videoWidth?: number | string /* 视频画面的高度 */ videoHeight?: number | string }