83 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			JavaScript
		
	
	
| const EVENT_NAME_MAP = {
 | |
|   transitionend: {
 | |
|     transition: 'transitionend',
 | |
|     WebkitTransition: 'webkitTransitionEnd',
 | |
|     MozTransition: 'mozTransitionEnd',
 | |
|     OTransition: 'oTransitionEnd',
 | |
|     msTransition: 'MSTransitionEnd',
 | |
|   },
 | |
| 
 | |
|   animationend: {
 | |
|     animation: 'animationend',
 | |
|     WebkitAnimation: 'webkitAnimationEnd',
 | |
|     MozAnimation: 'mozAnimationEnd',
 | |
|     OAnimation: 'oAnimationEnd',
 | |
|     msAnimation: 'MSAnimationEnd',
 | |
|   },
 | |
| }
 | |
| 
 | |
| const endEvents = []
 | |
| 
 | |
| function detectEvents () {
 | |
|   const testEl = document.createElement('div')
 | |
|   const style = testEl.style
 | |
| 
 | |
|   if (!('AnimationEvent' in window)) {
 | |
|     delete EVENT_NAME_MAP.animationend.animation
 | |
|   }
 | |
| 
 | |
|   if (!('TransitionEvent' in window)) {
 | |
|     delete EVENT_NAME_MAP.transitionend.transition
 | |
|   }
 | |
| 
 | |
|   for (const baseEventName in EVENT_NAME_MAP) {
 | |
|     if (EVENT_NAME_MAP.hasOwnProperty(baseEventName)) {
 | |
|       const baseEvents = EVENT_NAME_MAP[baseEventName]
 | |
|       for (const styleName in baseEvents) {
 | |
|         if (styleName in style) {
 | |
|           endEvents.push(baseEvents[styleName])
 | |
|           break
 | |
|         }
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| if (typeof window !== 'undefined' && typeof document !== 'undefined') {
 | |
|   detectEvents()
 | |
| }
 | |
| 
 | |
| function addEventListener (node, eventName, eventListener) {
 | |
|   node.addEventListener(eventName, eventListener, false)
 | |
| }
 | |
| 
 | |
| function removeEventListener (node, eventName, eventListener) {
 | |
|   node.removeEventListener(eventName, eventListener, false)
 | |
| }
 | |
| 
 | |
| const TransitionEvents = {
 | |
|   addEndEventListener (node, eventListener) {
 | |
|     if (endEvents.length === 0) {
 | |
|       window.setTimeout(eventListener, 0)
 | |
|       return
 | |
|     }
 | |
|     endEvents.forEach((endEvent) => {
 | |
|       addEventListener(node, endEvent, eventListener)
 | |
|     })
 | |
|   },
 | |
| 
 | |
|   endEvents,
 | |
| 
 | |
|   removeEndEventListener (node, eventListener) {
 | |
|     if (endEvents.length === 0) {
 | |
|       return
 | |
|     }
 | |
|     endEvents.forEach((endEvent) => {
 | |
|       removeEventListener(node, endEvent, eventListener)
 | |
|     })
 | |
|   },
 | |
| }
 | |
| 
 | |
| export default TransitionEvents
 | |
| 
 |