fix: remove window
							parent
							
								
									0dd60654c5
								
							
						
					
					
						commit
						65fc82e105
					
				|  | @ -87,7 +87,7 @@ const TransitionEvents = { | ||||||
| 
 | 
 | ||||||
|   addStartEventListener(node, eventListener) { |   addStartEventListener(node, eventListener) { | ||||||
|     if (startEvents.length === 0) { |     if (startEvents.length === 0) { | ||||||
|       window.setTimeout(eventListener, 0); |       setTimeout(eventListener, 0); | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     startEvents.forEach(startEvent => { |     startEvents.forEach(startEvent => { | ||||||
|  | @ -109,7 +109,7 @@ const TransitionEvents = { | ||||||
| 
 | 
 | ||||||
|   addEndEventListener(node, eventListener) { |   addEndEventListener(node, eventListener) { | ||||||
|     if (endEvents.length === 0) { |     if (endEvents.length === 0) { | ||||||
|       window.setTimeout(eventListener, 0); |       setTimeout(eventListener, 0); | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|     endEvents.forEach(endEvent => { |     endEvents.forEach(endEvent => { | ||||||
|  |  | ||||||
|  | @ -3,6 +3,7 @@ | ||||||
| import Event from './Event'; | import Event from './Event'; | ||||||
| import classes from '../component-classes'; | import classes from '../component-classes'; | ||||||
| import { requestAnimationTimeout, cancelAnimationTimeout } from '../requestAnimationTimeout'; | import { requestAnimationTimeout, cancelAnimationTimeout } from '../requestAnimationTimeout'; | ||||||
|  | import { inBrowser } from '../env'; | ||||||
| 
 | 
 | ||||||
| const isCssAnimationSupported = Event.endEvents.length !== 0; | const isCssAnimationSupported = Event.endEvents.length !== 0; | ||||||
| const capitalPrefixes = [ | const capitalPrefixes = [ | ||||||
|  | @ -15,6 +16,7 @@ const capitalPrefixes = [ | ||||||
| const prefixes = ['-webkit-', '-moz-', '-o-', 'ms-', '']; | const prefixes = ['-webkit-', '-moz-', '-o-', 'ms-', '']; | ||||||
| 
 | 
 | ||||||
| function getStyleProperty(node, name) { | function getStyleProperty(node, name) { | ||||||
|  |   if (inBrowser) return ''; | ||||||
|   // old ff need null, https://developer.mozilla.org/en-US/docs/Web/API/Window/getComputedStyle
 |   // old ff need null, https://developer.mozilla.org/en-US/docs/Web/API/Window/getComputedStyle
 | ||||||
|   const style = window.getComputedStyle(node, null); |   const style = window.getComputedStyle(node, null); | ||||||
|   let ret = ''; |   let ret = ''; | ||||||
|  |  | ||||||
|  | @ -1,24 +0,0 @@ | ||||||
| /** |  | ||||||
|  * source by `dom-closest` |  | ||||||
|  * https://github.com/necolas/dom-closest.git
 |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| import matches from './dom-matches'; |  | ||||||
| 
 |  | ||||||
| /** |  | ||||||
|  * @param element {Element} |  | ||||||
|  * @param selector {String} |  | ||||||
|  * @param context {Element=} |  | ||||||
|  * @return {Element} |  | ||||||
|  */ |  | ||||||
| export default function (element, selector, context) { |  | ||||||
|   context = context || document; |  | ||||||
|   // guard against orphans
 |  | ||||||
|   element = { parentNode: element }; |  | ||||||
| 
 |  | ||||||
|   while ((element = element.parentNode) && element !== context) { |  | ||||||
|     if (matches(element, selector)) { |  | ||||||
|       return element; |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  | @ -1,47 +0,0 @@ | ||||||
| /** |  | ||||||
|  * source by `dom-matches` |  | ||||||
|  * https://github.com/necolas/dom-matches.git
 |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| /** |  | ||||||
|  * Determine if a DOM element matches a CSS selector |  | ||||||
|  * |  | ||||||
|  * @param {Element} elem |  | ||||||
|  * @param {String} selector |  | ||||||
|  * @return {Boolean} |  | ||||||
|  * @api public |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| export default function matches(elem, selector) { |  | ||||||
|   // Vendor-specific implementations of `Element.prototype.matches()`.
 |  | ||||||
|   const proto = window.Element.prototype; |  | ||||||
|   const nativeMatches = |  | ||||||
|     proto.matches || |  | ||||||
|     proto.mozMatchesSelector || |  | ||||||
|     proto.msMatchesSelector || |  | ||||||
|     proto.oMatchesSelector || |  | ||||||
|     proto.webkitMatchesSelector; |  | ||||||
| 
 |  | ||||||
|   if (!elem || elem.nodeType !== 1) { |  | ||||||
|     return false; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   const parentElem = elem.parentNode; |  | ||||||
| 
 |  | ||||||
|   // use native 'matches'
 |  | ||||||
|   if (nativeMatches) { |  | ||||||
|     return nativeMatches.call(elem, selector); |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   // native support for `matches` is missing and a fallback is required
 |  | ||||||
|   const nodes = parentElem.querySelectorAll(selector); |  | ||||||
|   const len = nodes.length; |  | ||||||
| 
 |  | ||||||
|   for (let i = 0; i < len; i++) { |  | ||||||
|     if (nodes[i] === elem) { |  | ||||||
|       return true; |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   return false; |  | ||||||
| } |  | ||||||
|  | @ -147,7 +147,7 @@ const collapseMotion = (style: Ref<CSSProperties>, className: Ref<string>): CSSM | ||||||
|       style.value = getCurrentHeight(node); |       style.value = getCurrentHeight(node); | ||||||
|     }, |     }, | ||||||
|     onLeave: node => { |     onLeave: node => { | ||||||
|       window.setTimeout(() => { |       setTimeout(() => { | ||||||
|         style.value = getCollapsedHeight(node); |         style.value = getCollapsedHeight(node); | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -129,7 +129,7 @@ export default defineComponent({ | ||||||
|           getComputedStyle(node).getPropertyValue('border-top-color') || // Firefox Compatible |           getComputedStyle(node).getPropertyValue('border-top-color') || // Firefox Compatible | ||||||
|           getComputedStyle(node).getPropertyValue('border-color') || |           getComputedStyle(node).getPropertyValue('border-color') || | ||||||
|           getComputedStyle(node).getPropertyValue('background-color'); |           getComputedStyle(node).getPropertyValue('background-color'); | ||||||
|         this.clickWaveTimeoutId = window.setTimeout(() => this.onClick(node, waveColor), 0); |         this.clickWaveTimeoutId = setTimeout(() => this.onClick(node, waveColor), 0); | ||||||
|         raf.cancel(this.animationStartId); |         raf.cancel(this.animationStartId); | ||||||
|         this.animationStart = true; |         this.animationStart = true; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -60,7 +60,7 @@ export default defineComponent({ | ||||||
|       val => { |       val => { | ||||||
|         clearTimeout(delayTimeoutRef.value); |         clearTimeout(delayTimeoutRef.value); | ||||||
|         if (typeof loadingOrDelay.value === 'number') { |         if (typeof loadingOrDelay.value === 'number') { | ||||||
|           delayTimeoutRef.value = window.setTimeout(() => { |           delayTimeoutRef.value = setTimeout(() => { | ||||||
|             innerLoading.value = val; |             innerLoading.value = val; | ||||||
|           }, loadingOrDelay.value); |           }, loadingOrDelay.value); | ||||||
|         } else { |         } else { | ||||||
|  |  | ||||||
|  | @ -24,14 +24,14 @@ export default defineComponent({ | ||||||
|     const timeout = ref(); |     const timeout = ref(); | ||||||
|     const cacheErrors = ref([...props.errors]); |     const cacheErrors = ref([...props.errors]); | ||||||
|     watch([() => [...props.errors], () => props.help], newValues => { |     watch([() => [...props.errors], () => props.help], newValues => { | ||||||
|       window.clearTimeout(timeout.value); |       clearTimeout(timeout.value); | ||||||
|       if (props.help) { |       if (props.help) { | ||||||
|         visible.value = !!(props.errors && props.errors.length); |         visible.value = !!(props.errors && props.errors.length); | ||||||
|         if (visible.value) { |         if (visible.value) { | ||||||
|           cacheErrors.value = newValues[0]; |           cacheErrors.value = newValues[0]; | ||||||
|         } |         } | ||||||
|       } else { |       } else { | ||||||
|         timeout.value = window.setTimeout(() => { |         timeout.value = setTimeout(() => { | ||||||
|           visible.value = !!(props.errors && props.errors.length); |           visible.value = !!(props.errors && props.errors.length); | ||||||
|           if (visible.value) { |           if (visible.value) { | ||||||
|             cacheErrors.value = newValues[0]; |             cacheErrors.value = newValues[0]; | ||||||
|  | @ -40,7 +40,7 @@ export default defineComponent({ | ||||||
|       } |       } | ||||||
|     }); |     }); | ||||||
|     onBeforeUnmount(() => { |     onBeforeUnmount(() => { | ||||||
|       window.clearTimeout(timeout.value); |       clearTimeout(timeout.value); | ||||||
|     }); |     }); | ||||||
|     // Memo status in same visible |     // Memo status in same visible | ||||||
|     watch([visible, status], () => { |     watch([visible, status], () => { | ||||||
|  |  | ||||||
|  | @ -214,10 +214,10 @@ export default defineComponent({ | ||||||
|       { immediate: true }, |       { immediate: true }, | ||||||
|     ); |     ); | ||||||
| 
 | 
 | ||||||
|     let timeout: number; |     let timeout: any; | ||||||
|     const changeActiveKeys = (keys: Key[]) => { |     const changeActiveKeys = (keys: Key[]) => { | ||||||
|       window.clearTimeout(timeout); |       clearTimeout(timeout); | ||||||
|       timeout = window.setTimeout(() => { |       timeout = setTimeout(() => { | ||||||
|         if (props.activeKey === undefined) { |         if (props.activeKey === undefined) { | ||||||
|           activeKeys.value = keys; |           activeKeys.value = keys; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  | @ -17,7 +17,7 @@ export default defineComponent({ | ||||||
|   }), |   }), | ||||||
|   emits: ['finish', 'change'], |   emits: ['finish', 'change'], | ||||||
|   setup(props, { emit }) { |   setup(props, { emit }) { | ||||||
|     const countdownId = ref<number>(); |     const countdownId = ref<any>(); | ||||||
|     const statistic = ref(); |     const statistic = ref(); | ||||||
|     const syncTimer = () => { |     const syncTimer = () => { | ||||||
|       const { value } = props; |       const { value } = props; | ||||||
|  | @ -32,7 +32,7 @@ export default defineComponent({ | ||||||
|     const startTimer = () => { |     const startTimer = () => { | ||||||
|       if (countdownId.value) return; |       if (countdownId.value) return; | ||||||
|       const timestamp = getTime(props.value); |       const timestamp = getTime(props.value); | ||||||
|       countdownId.value = window.setInterval(() => { |       countdownId.value = setInterval(() => { | ||||||
|         statistic.value.$forceUpdate(); |         statistic.value.$forceUpdate(); | ||||||
|         if (timestamp > Date.now()) { |         if (timestamp > Date.now()) { | ||||||
|           emit('change', timestamp - Date.now()); |           emit('change', timestamp - Date.now()); | ||||||
|  |  | ||||||
|  | @ -181,16 +181,16 @@ export default defineComponent<FilterDropdownProps<any>>({ | ||||||
|     const openRef = ref(); |     const openRef = ref(); | ||||||
| 
 | 
 | ||||||
|     const onOpenChange = (keys: string[]) => { |     const onOpenChange = (keys: string[]) => { | ||||||
|       openRef.value = window.setTimeout(() => { |       openRef.value = setTimeout(() => { | ||||||
|         openKeys.value = keys; |         openKeys.value = keys; | ||||||
|       }); |       }); | ||||||
|     }; |     }; | ||||||
|     const onMenuClick = () => { |     const onMenuClick = () => { | ||||||
|       window.clearTimeout(openRef.value); |       clearTimeout(openRef.value); | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     onBeforeUnmount(() => { |     onBeforeUnmount(() => { | ||||||
|       window.clearTimeout(openRef.value); |       clearTimeout(openRef.value); | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     // ======================= Submit ======================== |     // ======================= Submit ======================== | ||||||
|  |  | ||||||
|  | @ -129,7 +129,7 @@ export default defineComponent({ | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     // ========================= Mobile ======================== |     // ========================= Mobile ======================== | ||||||
|     const touchMovingRef = ref<number>(); |     const touchMovingRef = ref<any>(); | ||||||
|     const [lockAnimation, setLockAnimation] = useState<number>(); |     const [lockAnimation, setLockAnimation] = useState<number>(); | ||||||
| 
 | 
 | ||||||
|     const doLockAnimation = () => { |     const doLockAnimation = () => { | ||||||
|  | @ -137,7 +137,7 @@ export default defineComponent({ | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     const clearTouchMoving = () => { |     const clearTouchMoving = () => { | ||||||
|       window.clearTimeout(touchMovingRef.value); |       clearTimeout(touchMovingRef.value); | ||||||
|     }; |     }; | ||||||
|     const doMove = (setState: (fn: (val: number) => number) => void, offset: number) => { |     const doMove = (setState: (fn: (val: number) => number) => void, offset: number) => { | ||||||
|       setState((value: number) => { |       setState((value: number) => { | ||||||
|  | @ -171,7 +171,7 @@ export default defineComponent({ | ||||||
|     watch(lockAnimation, () => { |     watch(lockAnimation, () => { | ||||||
|       clearTouchMoving(); |       clearTouchMoving(); | ||||||
|       if (lockAnimation.value) { |       if (lockAnimation.value) { | ||||||
|         touchMovingRef.value = window.setTimeout(() => { |         touchMovingRef.value = setTimeout(() => { | ||||||
|           setLockAnimation(0); |           setLockAnimation(0); | ||||||
|         }, 100); |         }, 100); | ||||||
|       } |       } | ||||||
|  |  | ||||||
|  | @ -18,14 +18,14 @@ export default function useTouchMove( | ||||||
|   const [lastTimestamp, setLastTimestamp] = useState<number>(0); |   const [lastTimestamp, setLastTimestamp] = useState<number>(0); | ||||||
|   const [lastTimeDiff, setLastTimeDiff] = useState<number>(0); |   const [lastTimeDiff, setLastTimeDiff] = useState<number>(0); | ||||||
|   const [lastOffset, setLastOffset] = useState<{ x: number; y: number }>(); |   const [lastOffset, setLastOffset] = useState<{ x: number; y: number }>(); | ||||||
|   const motionRef = ref<number>(); |   const motionInterval = ref<any>(); | ||||||
| 
 | 
 | ||||||
|   // ========================= Events =========================
 |   // ========================= Events =========================
 | ||||||
|   // >>> Touch events
 |   // >>> Touch events
 | ||||||
|   function onTouchStart(e: TouchEvent) { |   function onTouchStart(e: TouchEvent) { | ||||||
|     const { screenX, screenY } = e.touches[0]; |     const { screenX, screenY } = e.touches[0]; | ||||||
|     setTouchPosition({ x: screenX, y: screenY }); |     setTouchPosition({ x: screenX, y: screenY }); | ||||||
|     window.clearInterval(motionRef.value); |     clearInterval(motionInterval.value); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   function onTouchMove(e: TouchEvent) { |   function onTouchMove(e: TouchEvent) { | ||||||
|  | @ -62,9 +62,9 @@ export default function useTouchMove( | ||||||
|       let currentX = distanceX; |       let currentX = distanceX; | ||||||
|       let currentY = distanceY; |       let currentY = distanceY; | ||||||
| 
 | 
 | ||||||
|       motionRef.value = window.setInterval(() => { |       motionInterval.value = setInterval(() => { | ||||||
|         if (Math.abs(currentX) < STOP_SWIPE_DISTANCE && Math.abs(currentY) < STOP_SWIPE_DISTANCE) { |         if (Math.abs(currentX) < STOP_SWIPE_DISTANCE && Math.abs(currentY) < STOP_SWIPE_DISTANCE) { | ||||||
|           window.clearInterval(motionRef.value); |           clearInterval(motionInterval.value); | ||||||
|           return; |           return; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -139,7 +139,7 @@ const Base = defineComponent<InternalBlockProps>({ | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     onBeforeUnmount(() => { |     onBeforeUnmount(() => { | ||||||
|       window.clearTimeout(state.copyId); |       clearTimeout(state.copyId); | ||||||
|       raf.cancel(state.rafId); |       raf.cancel(state.rafId); | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|  | @ -223,7 +223,7 @@ const Base = defineComponent<InternalBlockProps>({ | ||||||
|           copyConfig.onCopy(); |           copyConfig.onCopy(); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         state.copyId = window.setTimeout(() => { |         state.copyId = setTimeout(() => { | ||||||
|           state.copied = false; |           state.copied = false; | ||||||
|         }, 3000); |         }, 3000); | ||||||
|       }); |       }); | ||||||
|  |  | ||||||
|  | @ -5,7 +5,7 @@ export default (callback: () => boolean, buffer: ComputedRef<number>) => { | ||||||
|   let timeout = null; |   let timeout = null; | ||||||
| 
 | 
 | ||||||
|   function cancelTrigger() { |   function cancelTrigger() { | ||||||
|     window.clearTimeout(timeout); |     clearTimeout(timeout); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   function trigger(force?: boolean) { |   function trigger(force?: boolean) { | ||||||
|  | @ -17,12 +17,12 @@ export default (callback: () => boolean, buffer: ComputedRef<number>) => { | ||||||
| 
 | 
 | ||||||
|       called = true; |       called = true; | ||||||
|       cancelTrigger(); |       cancelTrigger(); | ||||||
|       timeout = window.setTimeout(() => { |       timeout = setTimeout(() => { | ||||||
|         called = false; |         called = false; | ||||||
|       }, buffer.value); |       }, buffer.value); | ||||||
|     } else { |     } else { | ||||||
|       cancelTrigger(); |       cancelTrigger(); | ||||||
|       timeout = window.setTimeout(() => { |       timeout = setTimeout(() => { | ||||||
|         called = false; |         called = false; | ||||||
|         trigger(); |         trigger(); | ||||||
|       }, buffer.value); |       }, buffer.value); | ||||||
|  |  | ||||||
|  | @ -173,7 +173,7 @@ export default defineComponent({ | ||||||
|       onBlur(event); |       onBlur(event); | ||||||
|     }; |     }; | ||||||
|     const onFocus = (event: Event) => { |     const onFocus = (event: Event) => { | ||||||
|       window.clearTimeout(focusId.value); |       clearTimeout(focusId.value); | ||||||
|       const { isFocus } = state; |       const { isFocus } = state; | ||||||
|       if (!isFocus && event) { |       if (!isFocus && event) { | ||||||
|         emit('focus', event); |         emit('focus', event); | ||||||
|  | @ -181,7 +181,7 @@ export default defineComponent({ | ||||||
|       state.isFocus = true; |       state.isFocus = true; | ||||||
|     }; |     }; | ||||||
|     const onBlur = (event: Event) => { |     const onBlur = (event: Event) => { | ||||||
|       focusId.value = window.setTimeout(() => { |       focusId.value = setTimeout(() => { | ||||||
|         state.isFocus = false; |         state.isFocus = false; | ||||||
|         stopMeasure(); |         stopMeasure(); | ||||||
|         emit('blur', event); |         emit('blur', event); | ||||||
|  |  | ||||||
|  | @ -395,7 +395,7 @@ function RangerPicker<DateType>() { | ||||||
|       function triggerOpenAndFocus(index: 0 | 1) { |       function triggerOpenAndFocus(index: 0 | 1) { | ||||||
|         triggerOpen(true, index); |         triggerOpen(true, index); | ||||||
|         // Use setTimeout to make sure panel DOM exists |         // Use setTimeout to make sure panel DOM exists | ||||||
|         window.setTimeout(() => { |         setTimeout(() => { | ||||||
|           const inputRef = [startInputRef, endInputRef][index]; |           const inputRef = [startInputRef, endInputRef][index]; | ||||||
|           if (inputRef.value) { |           if (inputRef.value) { | ||||||
|             inputRef.value.focus(); |             inputRef.value.focus(); | ||||||
|  |  | ||||||
|  | @ -9,10 +9,10 @@ export default function useDelayReset( | ||||||
|   timeout = 10, |   timeout = 10, | ||||||
| ): [Ref<Boolean>, (val: boolean, callback?: () => void) => void, () => void] { | ): [Ref<Boolean>, (val: boolean, callback?: () => void) => void, () => void] { | ||||||
|   const bool = ref(false); |   const bool = ref(false); | ||||||
|   let delay: number; |   let delay: any; | ||||||
| 
 | 
 | ||||||
|   const cancelLatest = () => { |   const cancelLatest = () => { | ||||||
|     window.clearTimeout(delay); |     clearTimeout(delay); | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   onMounted(() => { |   onMounted(() => { | ||||||
|  | @ -20,7 +20,7 @@ export default function useDelayReset( | ||||||
|   }); |   }); | ||||||
|   const delaySetBool = (value: boolean, callback: () => void) => { |   const delaySetBool = (value: boolean, callback: () => void) => { | ||||||
|     cancelLatest(); |     cancelLatest(); | ||||||
|     delay = window.setTimeout(() => { |     delay = setTimeout(() => { | ||||||
|       bool.value = value; |       bool.value = value; | ||||||
|       if (callback) { |       if (callback) { | ||||||
|         callback(); |         callback(); | ||||||
|  |  | ||||||
|  | @ -8,10 +8,10 @@ import { onBeforeUpdate } from 'vue'; | ||||||
|  */ |  */ | ||||||
| export default function useLock(duration = 250): [() => boolean | null, (lock: boolean) => void] { | export default function useLock(duration = 250): [() => boolean | null, (lock: boolean) => void] { | ||||||
|   let lock: boolean | null = null; |   let lock: boolean | null = null; | ||||||
|   let timeout: number; |   let timeout: any; | ||||||
| 
 | 
 | ||||||
|   onBeforeUpdate(() => { |   onBeforeUpdate(() => { | ||||||
|     window.clearTimeout(timeout); |     clearTimeout(timeout); | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|   function doLock(locked: boolean) { |   function doLock(locked: boolean) { | ||||||
|  | @ -19,8 +19,8 @@ export default function useLock(duration = 250): [() => boolean | null, (lock: b | ||||||
|       lock = locked; |       lock = locked; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     window.clearTimeout(timeout); |     clearTimeout(timeout); | ||||||
|     timeout = window.setTimeout(() => { |     timeout = setTimeout(() => { | ||||||
|       lock = null; |       lock = null; | ||||||
|     }, duration); |     }, duration); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  | @ -35,17 +35,17 @@ export function useTimeoutLock<State>( | ||||||
|   defaultState?: State, |   defaultState?: State, | ||||||
| ): [(state: UnwrapRef<State>) => void, () => UnwrapRef<State> | null] { | ): [(state: UnwrapRef<State>) => void, () => UnwrapRef<State> | null] { | ||||||
|   const frameRef = ref<State | null>(defaultState || null); |   const frameRef = ref<State | null>(defaultState || null); | ||||||
|   const timeoutRef = ref<number>(); |   const timeoutRef = ref<any>(); | ||||||
| 
 | 
 | ||||||
|   function cleanUp() { |   function cleanUp() { | ||||||
|     window.clearTimeout(timeoutRef.value); |     clearTimeout(timeoutRef.value); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   function setState(newState: UnwrapRef<State>) { |   function setState(newState: UnwrapRef<State>) { | ||||||
|     frameRef.value = newState; |     frameRef.value = newState; | ||||||
|     cleanUp(); |     cleanUp(); | ||||||
| 
 | 
 | ||||||
|     timeoutRef.value = window.setTimeout(() => { |     timeoutRef.value = setTimeout(() => { | ||||||
|       frameRef.value = null; |       frameRef.value = null; | ||||||
|       timeoutRef.value = undefined; |       timeoutRef.value = undefined; | ||||||
|     }, 100); |     }, 100); | ||||||
|  |  | ||||||
|  | @ -78,7 +78,7 @@ | ||||||
|       </div> |       </div> | ||||||
|     </section> |     </section> | ||||||
|     <section :class="highlightClass"> |     <section :class="highlightClass"> | ||||||
|       <div class="highlight" ref="codeRef"> |       <div ref="codeRef" class="highlight"> | ||||||
|         <slot v-if="type === 'TS'" name="htmlCode" /> |         <slot v-if="type === 'TS'" name="htmlCode" /> | ||||||
|         <slot v-else name="jsVersionHtml" /> |         <slot v-else name="jsVersionHtml" /> | ||||||
|       </div> |       </div> | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 tangjinzhou
						tangjinzhou