55b50e73ffe5b5157f98257c7b3908503730bed07141aca09441cb1e6d49193bc5c41093af73ff9343c9d74f5cd683977bd2eee90be90d30303bb0dee59537-exec 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. /* @flow */
  2. import { updateListeners } from 'core/vdom/helpers/update-listeners'
  3. let target: any
  4. function createOnceHandler (event, handler, capture) {
  5. const _target = target // save current target element in closure
  6. return function onceHandler () {
  7. const res = handler.apply(null, arguments)
  8. if (res !== null) {
  9. remove(event, onceHandler, capture, _target)
  10. }
  11. }
  12. }
  13. function add (
  14. event: string,
  15. handler: Function,
  16. capture: boolean,
  17. passive?: boolean,
  18. params?: Array<any>
  19. ) {
  20. if (capture) {
  21. console.log('Weex do not support event in bubble phase.')
  22. return
  23. }
  24. target.addEvent(event, handler, params)
  25. }
  26. function remove (
  27. event: string,
  28. handler: any,
  29. capture: any,
  30. _target?: any
  31. ) {
  32. (_target || target).removeEvent(event)
  33. }
  34. function updateDOMListeners (oldVnode: VNodeWithData, vnode: VNodeWithData) {
  35. if (!oldVnode.data.on && !vnode.data.on) {
  36. return
  37. }
  38. const on = vnode.data.on || {}
  39. const oldOn = oldVnode.data.on || {}
  40. target = vnode.elm
  41. updateListeners(on, oldOn, add, remove, createOnceHandler, vnode.context)
  42. target = undefined
  43. }
  44. export default {
  45. create: updateDOMListeners,
  46. update: updateDOMListeners
  47. }