48 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			Vue
		
	
	
| 
 | |
| import PropTypes from './vue-types'
 | |
| import { getOptionProps } from './props-util'
 | |
| 
 | |
| function getDisplayName (WrappedComponent) {
 | |
|   return WrappedComponent.name || 'Component'
 | |
| }
 | |
| export default function wrapWithConnect (WrappedComponent) {
 | |
|   const tempProps = WrappedComponent.props || {}
 | |
|   const methods = WrappedComponent.methods || {}
 | |
|   const props = {}
 | |
|   Object.keys(tempProps).forEach(k => { props[k] = PropTypes.any })
 | |
|   WrappedComponent.props.__propsSymbol__ = PropTypes.any
 | |
|   WrappedComponent.props.children = PropTypes.array.def([])
 | |
|   const ProxyWrappedComponent = {
 | |
|     props,
 | |
|     model: WrappedComponent.model,
 | |
|     name: `Proxy_${getDisplayName(WrappedComponent)}`,
 | |
|     methods: {
 | |
|       getProxyWrappedInstance () {
 | |
|         return this.$refs.wrappedInstance
 | |
|       },
 | |
|     },
 | |
|     render () {
 | |
|       const { $listeners, $slots = {}, $attrs } = this
 | |
|       const props = getOptionProps(this)
 | |
|       const wrapProps = {
 | |
|         props: {
 | |
|           ...props,
 | |
|           __propsSymbol__: Symbol(),
 | |
|           children: $slots.default || [],
 | |
|         },
 | |
|         on: $listeners,
 | |
|         attrs: $attrs,
 | |
|       }
 | |
|       return (
 | |
|         <WrappedComponent {...wrapProps} ref='wrappedInstance'/>
 | |
|       )
 | |
|     },
 | |
|   }
 | |
|   Object.keys(methods).map(m => {
 | |
|     ProxyWrappedComponent.methods[m] = function () {
 | |
|       this.getProxyWrappedInstance()[m](...arguments)
 | |
|     }
 | |
|   })
 | |
|   return ProxyWrappedComponent
 | |
| }
 |