|
|
|
@ -1,4 +1,4 @@ |
|
|
|
import { deepClone } from '@/utils/index' |
|
|
|
import {deepClone} from '@/utils/index' |
|
|
|
|
|
|
|
const componentChild = {} |
|
|
|
/** |
|
|
|
@ -9,96 +9,109 @@ const componentChild = {} |
|
|
|
const slotsFiles = require.context('./slots', false, /\.js$/) |
|
|
|
const keys = slotsFiles.keys() || [] |
|
|
|
keys.forEach(key => { |
|
|
|
const tag = key.replace(/^\.\/(.*)\.\w+$/, '$1') |
|
|
|
const value = slotsFiles(key).default |
|
|
|
componentChild[tag] = value |
|
|
|
const tag = key.replace(/^\.\/(.*)\.\w+$/, '$1') |
|
|
|
const value = slotsFiles(key).default |
|
|
|
componentChild[tag] = value |
|
|
|
}) |
|
|
|
|
|
|
|
function vModel(dataObject, defaultValue) { |
|
|
|
dataObject.props.value = defaultValue |
|
|
|
let config = dataObject.attrs.__config__ |
|
|
|
//表单组件特殊处理
|
|
|
|
if (config.tag === 'el-upload') { |
|
|
|
//增加上传回调事件
|
|
|
|
dataObject.attrs['on-success'] = (response, file, fileList) => { |
|
|
|
this.$emit('upload', response, file, fileList) |
|
|
|
} |
|
|
|
dataObject.attrs['on-remove'] = (file, fileList) => { |
|
|
|
this.$emit('deleteUpload', file, fileList) |
|
|
|
} |
|
|
|
} else { |
|
|
|
dataObject.props.value = defaultValue |
|
|
|
|
|
|
|
dataObject.on.input = val => { |
|
|
|
this.$emit('input', val) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
dataObject.on.input = val => { |
|
|
|
this.$emit('input', val) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
function mountSlotFlies(h, confClone, children) { |
|
|
|
const childObjs = componentChild[confClone.__config__.tag] |
|
|
|
if (childObjs) { |
|
|
|
Object.keys(childObjs).forEach(key => { |
|
|
|
const childFunc = childObjs[key] |
|
|
|
if (confClone.__slot__ && confClone.__slot__[key]) { |
|
|
|
children.push(childFunc(h, confClone, key)) |
|
|
|
} |
|
|
|
}) |
|
|
|
} |
|
|
|
const childObjs = componentChild[confClone.__config__.tag] |
|
|
|
if (childObjs) { |
|
|
|
Object.keys(childObjs).forEach(key => { |
|
|
|
const childFunc = childObjs[key] |
|
|
|
if (confClone.__slot__ && confClone.__slot__[key]) { |
|
|
|
children.push(childFunc(h, confClone, key)) |
|
|
|
} |
|
|
|
}) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
function emitEvents(confClone) { |
|
|
|
['on', 'nativeOn'].forEach(attr => { |
|
|
|
const eventKeyList = Object.keys(confClone[attr] || {}) |
|
|
|
eventKeyList.forEach(key => { |
|
|
|
const val = confClone[attr][key] |
|
|
|
if (typeof val === 'string') { |
|
|
|
confClone[attr][key] = event => this.$emit(val, event) |
|
|
|
} |
|
|
|
['on', 'nativeOn'].forEach(attr => { |
|
|
|
const eventKeyList = Object.keys(confClone[attr] || {}) |
|
|
|
eventKeyList.forEach(key => { |
|
|
|
const val = confClone[attr][key] |
|
|
|
if (typeof val === 'string') { |
|
|
|
confClone[attr][key] = event => this.$emit(val, event) |
|
|
|
} |
|
|
|
}) |
|
|
|
}) |
|
|
|
}) |
|
|
|
} |
|
|
|
|
|
|
|
function buildDataObject(confClone, dataObject) { |
|
|
|
Object.keys(confClone).forEach(key => { |
|
|
|
const val = confClone[key] |
|
|
|
if (key === '__vModel__') { |
|
|
|
vModel.call(this, dataObject, confClone.__config__.defaultValue) |
|
|
|
} else if (dataObject[key]) { |
|
|
|
dataObject[key] = { ...dataObject[key], ...val } |
|
|
|
} else { |
|
|
|
dataObject.attrs[key] = val |
|
|
|
} |
|
|
|
}) |
|
|
|
Object.keys(confClone).forEach(key => { |
|
|
|
const val = confClone[key] |
|
|
|
if (key === '__vModel__') { |
|
|
|
vModel.call(this, dataObject, confClone.__config__.defaultValue) |
|
|
|
} else if (dataObject[key]) { |
|
|
|
dataObject[key] = {...dataObject[key], ...val} |
|
|
|
} else { |
|
|
|
dataObject.attrs[key] = val |
|
|
|
} |
|
|
|
}) |
|
|
|
|
|
|
|
// 清理属性
|
|
|
|
clearAttrs(dataObject) |
|
|
|
// 清理属性
|
|
|
|
clearAttrs(dataObject) |
|
|
|
} |
|
|
|
|
|
|
|
function clearAttrs(dataObject) { |
|
|
|
delete dataObject.attrs.__config__ |
|
|
|
delete dataObject.attrs.__slot__ |
|
|
|
delete dataObject.attrs.__methods__ |
|
|
|
delete dataObject.attrs.__config__ |
|
|
|
delete dataObject.attrs.__slot__ |
|
|
|
delete dataObject.attrs.__methods__ |
|
|
|
} |
|
|
|
|
|
|
|
function makeDataObject() { |
|
|
|
return { |
|
|
|
attrs: {}, |
|
|
|
props: {}, |
|
|
|
nativeOn: {}, |
|
|
|
on: {}, |
|
|
|
style: {} |
|
|
|
} |
|
|
|
return { |
|
|
|
attrs: {}, |
|
|
|
props: {}, |
|
|
|
nativeOn: {}, |
|
|
|
on: {}, |
|
|
|
style: {} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
export default { |
|
|
|
props: { |
|
|
|
conf: { |
|
|
|
type: Object, |
|
|
|
required: true |
|
|
|
} |
|
|
|
}, |
|
|
|
render(h) { |
|
|
|
const dataObject = makeDataObject() |
|
|
|
const confClone = deepClone(this.conf) |
|
|
|
const children = this.$slots.default || [] |
|
|
|
props: { |
|
|
|
conf: { |
|
|
|
type: Object, |
|
|
|
required: true |
|
|
|
} |
|
|
|
}, |
|
|
|
render(h) { |
|
|
|
const dataObject = makeDataObject() |
|
|
|
const confClone = deepClone(this.conf) |
|
|
|
const children = this.$slots.default || [] |
|
|
|
|
|
|
|
// 如果slots文件夹存在与当前tag同名的文件,则执行文件中的代码
|
|
|
|
mountSlotFlies.call(this, h, confClone, children) |
|
|
|
// 如果slots文件夹存在与当前tag同名的文件,则执行文件中的代码
|
|
|
|
mountSlotFlies.call(this, h, confClone, children) |
|
|
|
|
|
|
|
// 将字符串类型的事件,发送为消息
|
|
|
|
emitEvents.call(this, confClone) |
|
|
|
// 将字符串类型的事件,发送为消息
|
|
|
|
emitEvents.call(this, confClone) |
|
|
|
|
|
|
|
// 将json表单配置转化为vue render可以识别的 “数据对象(dataObject)”
|
|
|
|
buildDataObject.call(this, confClone, dataObject) |
|
|
|
// 将json表单配置转化为vue render可以识别的 “数据对象(dataObject)”
|
|
|
|
buildDataObject.call(this, confClone, dataObject) |
|
|
|
|
|
|
|
return h(this.conf.__config__.tag, dataObject, children) |
|
|
|
} |
|
|
|
return h(this.conf.__config__.tag, dataObject, children) |
|
|
|
} |
|
|
|
} |
|
|
|
|