|
| 1 | +import type { Component } from 'vue' |
| 2 | +import { merge } from '@formily/shared' |
| 3 | +import { h } from '@formily/vue' |
| 4 | +import { isVue2, h as hInVue2, defineComponent } from 'vue-demi' |
| 5 | + |
| 6 | +type ListenersTransformRules = Record<string, string> |
| 7 | + |
| 8 | +export const transformComponent = <T extends Record<string, any>>( |
| 9 | + tag: any, |
| 10 | + transformRules?: ListenersTransformRules, |
| 11 | + defaultProps?: Partial<T> |
| 12 | +): Component<T> | any => { |
| 13 | + if (isVue2) { |
| 14 | + return defineComponent({ |
| 15 | + setup(props, { attrs, slots, listeners }) { |
| 16 | + return () => { |
| 17 | + const data = { |
| 18 | + attrs: { |
| 19 | + ...attrs, |
| 20 | + }, |
| 21 | + on: { |
| 22 | + ...listeners, |
| 23 | + }, |
| 24 | + } |
| 25 | + |
| 26 | + if (transformRules) { |
| 27 | + const transformListeners = transformRules |
| 28 | + Object.keys(transformListeners).forEach((extract) => { |
| 29 | + if (data.on !== undefined) { |
| 30 | + data.on[transformListeners[extract]] = listeners[extract] |
| 31 | + } |
| 32 | + }) |
| 33 | + } |
| 34 | + if (defaultProps) { |
| 35 | + data.attrs = merge(defaultProps, data.attrs) |
| 36 | + } |
| 37 | + |
| 38 | + return h(tag, data, slots) |
| 39 | + } |
| 40 | + }, |
| 41 | + }) |
| 42 | + } else { |
| 43 | + return defineComponent({ |
| 44 | + setup(props, { attrs, slots }) { |
| 45 | + return () => { |
| 46 | + let data = { |
| 47 | + ...attrs, |
| 48 | + } |
| 49 | + if (transformRules) { |
| 50 | + const listeners = transformRules |
| 51 | + Object.keys(listeners).forEach((extract) => { |
| 52 | + const event = listeners[extract] |
| 53 | + data[`on${event[0].toUpperCase()}${event.slice(1)}`] = |
| 54 | + attrs[`on${extract[0].toUpperCase()}${extract.slice(1)}`] |
| 55 | + }) |
| 56 | + } |
| 57 | + if (defaultProps) { |
| 58 | + data = merge(defaultProps, data) |
| 59 | + } |
| 60 | + return h(tag, data, slots) |
| 61 | + } |
| 62 | + }, |
| 63 | + }) |
| 64 | + } |
| 65 | +} |
0 commit comments