vexip-ui
Version:
A Vue 3 UI library, Highly customizability, full TypeScript, performance pretty good
1 lines • 3.75 kB
Source Map (JSON)
{"version":3,"file":"props.mjs","sources":["../../../components/video/props.ts"],"sourcesContent":["import { booleanProp, buildProps, eventProp, iconProp } from '@vexip-ui/config'\n\nimport type { ExtractPropTypes, PropType } from 'vue'\nimport type { FullScreenType } from '@/components/full-screen'\nimport type { IconEffect } from '@/components/icon'\nimport type { ClassType, ConfigurableProps } from '@vexip-ui/config'\nimport type {\n VideoControlLayout,\n VideoControlOption,\n VideoControlType,\n // VideoKernel,\n VideoPlaybackRate,\n VideoSegment,\n VideoShortcutOptions,\n VideoSlots,\n} from './symbol'\n\nexport const videoProps = buildProps({\n src: String,\n srcList: Array as PropType<string[]>,\n noControls: booleanProp,\n videoAttrs: Object,\n time: Number,\n volume: Number,\n playbackRate: Number,\n playbackRates: Array as PropType<(number | VideoPlaybackRate)[]>,\n // kernel: Object as PropType<VideoKernel>,\n controlLayout: Object as PropType<VideoControlLayout>,\n poster: String,\n video: Object as PropType<HTMLVideoElement>,\n segments: Array as PropType<(number | VideoSegment)[]>,\n loading: booleanProp,\n loadingIcon: iconProp,\n loadingEffect: String as PropType<IconEffect>,\n shortcuts: Object as PropType<VideoShortcutOptions>,\n slots: Object as PropType<VideoSlots>,\n onPlay: eventProp(),\n onPause: eventProp(),\n onEnded: eventProp(),\n onTimeChange: eventProp<(time: number) => void>(),\n onVolumeChange: eventProp<(volume: number) => void>(),\n onRateChange: eventProp<(rate: number) => void>(),\n onToggleFlip: eventProp<(flip: boolean) => void>(),\n onTogglePip: eventProp<(pip: boolean) => void>(),\n onToggleFull: eventProp<(full: false | FullScreenType) => void>(),\n onPrev: eventProp(),\n onNext: eventProp(),\n onRefresh: eventProp(),\n})\n\nexport type VideoProps = ExtractPropTypes<typeof videoProps>\nexport type VideoCProps = ConfigurableProps<ExtractPropTypes<typeof videoProps>>\n\nexport const videoControlProps = buildProps({\n type: String as PropType<VideoControlType>,\n label: String,\n tipClass: [String, Array, Object] as PropType<ClassType>,\n disabled: booleanProp,\n shortcut: String,\n focusable: booleanProp,\n value: [Number, String],\n options: Array as PropType<(string | VideoControlOption)[]>,\n onClick: eventProp(),\n onEnter: eventProp(),\n onLeave: eventProp(),\n onFocus: eventProp<(event: FocusEvent) => void>(),\n onBlur: eventProp<(event: FocusEvent) => void>(),\n onSelect: eventProp<(option: VideoControlOption) => void>(),\n})\n\nexport type VideoControlProps = ExtractPropTypes<typeof videoControlProps>\nexport type VideoControlCProps = ConfigurableProps<ExtractPropTypes<typeof videoControlProps>>\n"],"names":["videoProps","buildProps","booleanProp","iconProp","eventProp","videoControlProps"],"mappings":";AAiBO,MAAMA,IAAaC,EAAW;AAAA,EACnC,KAAK;AAAA,EACL,SAAS;AAAA,EACT,YAAYC;AAAA,EACZ,YAAY;AAAA,EACZ,MAAM;AAAA,EACN,QAAQ;AAAA,EACR,cAAc;AAAA,EACd,eAAe;AAAA;AAAA,EAEf,eAAe;AAAA,EACf,QAAQ;AAAA,EACR,OAAO;AAAA,EACP,UAAU;AAAA,EACV,SAASA;AAAA,EACT,aAAaC;AAAA,EACb,eAAe;AAAA,EACf,WAAW;AAAA,EACX,OAAO;AAAA,EACP,QAAQC,EAAU;AAAA,EAClB,SAASA,EAAU;AAAA,EACnB,SAASA,EAAU;AAAA,EACnB,cAAcA,EAAkC;AAAA,EAChD,gBAAgBA,EAAoC;AAAA,EACpD,cAAcA,EAAkC;AAAA,EAChD,cAAcA,EAAmC;AAAA,EACjD,aAAaA,EAAkC;AAAA,EAC/C,cAAcA,EAAkD;AAAA,EAChE,QAAQA,EAAU;AAAA,EAClB,QAAQA,EAAU;AAAA,EAClB,WAAWA,EAAU;AACvB,CAAC,GAKYC,IAAoBJ,EAAW;AAAA,EAC1C,MAAM;AAAA,EACN,OAAO;AAAA,EACP,UAAU,CAAC,QAAQ,OAAO,MAAM;AAAA,EAChC,UAAUC;AAAA,EACV,UAAU;AAAA,EACV,WAAWA;AAAA,EACX,OAAO,CAAC,QAAQ,MAAM;AAAA,EACtB,SAAS;AAAA,EACT,SAASE,EAAU;AAAA,EACnB,SAASA,EAAU;AAAA,EACnB,SAASA,EAAU;AAAA,EACnB,SAASA,EAAuC;AAAA,EAChD,QAAQA,EAAuC;AAAA,EAC/C,UAAUA,EAAgD;AAC5D,CAAC;"}