mirror of
https://github.com/vform666/variant-form3-vite.git
synced 2025-01-11 00:29:13 +08:00
2022.07.20更新:
1. 优化图片、文件上传组件交互逻辑; 2. 图片组件增加预览功能。
This commit is contained in:
parent
a4c5e20703
commit
8d6c3d7fbc
@ -38,7 +38,7 @@ export function createDesigner(vueInstance) {
|
|||||||
this.formConfig = deepClone(defaultFormConfig)
|
this.formConfig = deepClone(defaultFormConfig)
|
||||||
|
|
||||||
//输出版本信息和语雀链接
|
//输出版本信息和语雀链接
|
||||||
console.info(`%cVariantForm %cVer${VARIANT_FORM_VERSION} %chttps://www.yuque.com/variantdev/vform`,
|
console.info(`%cVariantForm %cVer${VARIANT_FORM_VERSION} %chttps://www.yuque.com/visualdev/vform3`,
|
||||||
"color:#409EFF;font-size: 22px;font-weight:bolder",
|
"color:#409EFF;font-size: 22px;font-weight:bolder",
|
||||||
"color:#999;font-size: 12px",
|
"color:#999;font-size: 12px",
|
||||||
"color:#333"
|
"color:#333"
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
:multiple="field.options.multipleSelect" :file-list="fileList"
|
:multiple="field.options.multipleSelect" :file-list="fileList"
|
||||||
:show-file-list="field.options.showFileList" :class="{'hideUploadDiv': uploadBtnHidden}"
|
:show-file-list="field.options.showFileList" :class="{'hideUploadDiv': uploadBtnHidden}"
|
||||||
:limit="field.options.limit" :on-exceed="handleFileExceed" :before-upload="beforeFileUpload"
|
:limit="field.options.limit" :on-exceed="handleFileExceed" :before-upload="beforeFileUpload"
|
||||||
:on-success="handleFileUpload" :on-error="handelUploadError" :on-remove="handleFileRemove">
|
:on-success="handleFileUpload" :on-error="handleUploadError">
|
||||||
<template #tip>
|
<template #tip>
|
||||||
<div class="el-upload__tip"
|
<div class="el-upload__tip"
|
||||||
v-if="!!field.options.uploadTip">{{field.options.uploadTip}}</div>
|
v-if="!!field.options.uploadTip">{{field.options.uploadTip}}</div>
|
||||||
@ -21,12 +21,12 @@
|
|||||||
<template #file="{ file }">
|
<template #file="{ file }">
|
||||||
<div class="upload-file-list">
|
<div class="upload-file-list">
|
||||||
<span class="upload-file-name" :title="file.name">{{file.name}}</span>
|
<span class="upload-file-name" :title="file.name">{{file.name}}</span>
|
||||||
<a :href="file.url" download="">
|
<a :href="file.url" download="" target="_blank">
|
||||||
<span class="el-icon-download file-action" :title="i18nt('render.hint.downloadFile')">
|
<span class="el-icon-download file-action" :title="i18nt('render.hint.downloadFile')">
|
||||||
<svg-icon icon-class="el-download" />
|
<svg-icon icon-class="el-download" />
|
||||||
</span></a>
|
</span></a>
|
||||||
<span class="file-action" :title="i18nt('render.hint.removeFile')" v-if="!field.options.disabled"
|
<span class="file-action" :title="i18nt('render.hint.removeFile')" v-if="!field.options.disabled"
|
||||||
@click="removeUploadFile(file.name)"><svg-icon icon-class="el-delete" /></span>
|
@click="removeUploadFile(file.name, file.url, file.uid)"><svg-icon icon-class="el-delete" /></span>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
</el-upload>
|
</el-upload>
|
||||||
@ -80,7 +80,7 @@
|
|||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
oldFieldValue: null, //field组件change之前的值
|
oldFieldValue: null, //field组件change之前的值
|
||||||
fieldModel: null,
|
fieldModel: [],
|
||||||
rules: [],
|
rules: [],
|
||||||
|
|
||||||
uploadHeaders: {},
|
uploadHeaders: {},
|
||||||
@ -127,17 +127,10 @@
|
|||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
handleFileExceed() {
|
handleFileExceed() {
|
||||||
let uploadLimit = this.field.options.limit /* 此行不能注释,下一行ES6模板字符串需要用到!! */
|
let uploadLimit = this.field.options.limit
|
||||||
this.$message.warning( this.i18nt('render.hint.uploadExceed').replace('${uploadLimit}', uploadLimit) )
|
this.$message.warning( this.i18nt('render.hint.uploadExceed').replace('${uploadLimit}', uploadLimit) )
|
||||||
},
|
},
|
||||||
|
|
||||||
updateUploadFieldModelAndEmitDataChange(fileList) {
|
|
||||||
let oldValue = deepClone(this.fieldModel)
|
|
||||||
this.fieldModel = deepClone(fileList)
|
|
||||||
this.syncUpdateFormModel(this.fieldModel)
|
|
||||||
this.emitFieldDataChange(this.fieldModel, oldValue)
|
|
||||||
},
|
|
||||||
|
|
||||||
beforeFileUpload(file) {
|
beforeFileUpload(file) {
|
||||||
let fileTypeCheckResult = false
|
let fileTypeCheckResult = false
|
||||||
let extFileName = file.name.substring(file.name.lastIndexOf('.') + 1)
|
let extFileName = file.name.substring(file.name.lastIndexOf('.') + 1)
|
||||||
@ -183,36 +176,63 @@
|
|||||||
return true
|
return true
|
||||||
},
|
},
|
||||||
|
|
||||||
|
updateFieldModelAndEmitDataChangeForUpload(fileList, customResult, defaultResult) {
|
||||||
|
let oldValue = deepClone(this.fieldModel)
|
||||||
|
if (!!customResult && !!customResult.name && !!customResult.url) {
|
||||||
|
this.fieldModel.push({
|
||||||
|
name: customResult.name,
|
||||||
|
url: customResult.url
|
||||||
|
})
|
||||||
|
} else if (!!defaultResult && !!defaultResult.name && !!defaultResult.url) {
|
||||||
|
this.fieldModel.push({
|
||||||
|
name: defaultResult.name,
|
||||||
|
url: defaultResult.url
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
this.fieldModel = deepClone(fileList)
|
||||||
|
}
|
||||||
|
|
||||||
|
this.syncUpdateFormModel(this.fieldModel)
|
||||||
|
this.emitFieldDataChange(this.fieldModel, oldValue)
|
||||||
|
},
|
||||||
|
|
||||||
handleFileUpload(res, file, fileList) {
|
handleFileUpload(res, file, fileList) {
|
||||||
if (file.status === 'success') {
|
if (file.status === 'success') {
|
||||||
//this.fileList.push(file) /* 上传过程中,this.fileList是只读的,不能修改赋值!! */
|
let customResult = null
|
||||||
this.updateUploadFieldModelAndEmitDataChange(fileList)
|
|
||||||
this.fileList = deepClone(fileList)
|
|
||||||
this.uploadBtnHidden = fileList.length >= this.field.options.limit
|
|
||||||
|
|
||||||
if (!!this.field.options.onUploadSuccess) {
|
if (!!this.field.options.onUploadSuccess) {
|
||||||
let mountFunc = new Function('result', 'file', 'fileList', this.field.options.onUploadSuccess)
|
let mountFunc = new Function('result', 'file', 'fileList', this.field.options.onUploadSuccess)
|
||||||
mountFunc.call(this, res, file, fileList)
|
customResult = mountFunc.call(this, res, file, fileList)
|
||||||
}
|
}
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
handleFileRemove(file, fileList) {
|
this.updateFieldModelAndEmitDataChangeForUpload(fileList, customResult, res)
|
||||||
this.fileList = deepClone(fileList) //this.fileList = fileList
|
this.fileList = deepClone(fileList)
|
||||||
this.updateUploadFieldModelAndEmitDataChange(fileList)
|
|
||||||
this.uploadBtnHidden = fileList.length >= this.field.options.limit
|
this.uploadBtnHidden = fileList.length >= this.field.options.limit
|
||||||
|
|
||||||
if (!!this.field.options.onFileRemove) {
|
|
||||||
let customFn = new Function('file', 'fileList', this.field.options.onFileRemove)
|
|
||||||
customFn.call(this, file, fileList)
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
removeUploadFile(fileName) {
|
// handleFileRemove(file, fileList) {
|
||||||
|
// this.fileList = deepClone(fileList) //this.fileList = fileList
|
||||||
|
// this.updateUploadFieldModelAndEmitDataChange(fileList)
|
||||||
|
// this.uploadBtnHidden = fileList.length >= this.field.options.limit
|
||||||
|
//
|
||||||
|
// if (!!this.field.options.onFileRemove) {
|
||||||
|
// let customFn = new Function('file', 'fileList', this.field.options.onFileRemove)
|
||||||
|
// customFn.call(this, file, fileList)
|
||||||
|
// }
|
||||||
|
// },
|
||||||
|
|
||||||
|
updateFieldModelAndEmitDataChangeForRemove(deletedFileIdx, fileList) {
|
||||||
|
let oldValue = deepClone(this.fieldModel)
|
||||||
|
this.fieldModel.splice(deletedFileIdx, 1)
|
||||||
|
this.syncUpdateFormModel(this.fieldModel)
|
||||||
|
this.emitFieldDataChange(this.fieldModel, oldValue)
|
||||||
|
},
|
||||||
|
|
||||||
|
removeUploadFile(fileName, fileUrl, fileUid) {
|
||||||
let foundIdx = -1
|
let foundIdx = -1
|
||||||
let foundFile = null
|
let foundFile = null
|
||||||
this.fileList.forEach((file, idx) => {
|
this.fileList.forEach((file, idx) => {
|
||||||
if (file.name === fileName) {
|
if ((file.name === fileName) && ((file.url === fileUrl) || (!!fileUid && file.uid === fileUid))) {
|
||||||
foundIdx = idx
|
foundIdx = idx
|
||||||
foundFile = file
|
foundFile = file
|
||||||
}
|
}
|
||||||
@ -220,7 +240,7 @@
|
|||||||
|
|
||||||
if (foundIdx >= 0) {
|
if (foundIdx >= 0) {
|
||||||
this.fileList.splice(foundIdx, 1)
|
this.fileList.splice(foundIdx, 1)
|
||||||
this.updateUploadFieldModelAndEmitDataChange(this.fileList)
|
this.updateFieldModelAndEmitDataChangeForRemove(foundIdx, this.fileList)
|
||||||
this.uploadBtnHidden = this.fileList.length >= this.field.options.limit
|
this.uploadBtnHidden = this.fileList.length >= this.field.options.limit
|
||||||
|
|
||||||
if (!!this.field.options.onFileRemove) {
|
if (!!this.field.options.onFileRemove) {
|
||||||
@ -230,7 +250,7 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
handelUploadError(err, file, fileList) {
|
handleUploadError(err, file, fileList) {
|
||||||
if (!!this.field.options.onUploadError) {
|
if (!!this.field.options.onUploadError) {
|
||||||
let customFn = new Function('error', 'file', 'fileList', this.field.options.onUploadError)
|
let customFn = new Function('error', 'file', 'fileList', this.field.options.onUploadError)
|
||||||
customFn.call(this, err, file, fileList)
|
customFn.call(this, err, file, fileList)
|
||||||
|
@ -10,9 +10,9 @@
|
|||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div class="field-wrapper" :class="{'design-time-bottom-margin': !!this.designer}">
|
<div class="field-wrapper" :class="{'design-time-bottom-margin': !!this.designer}">
|
||||||
<el-form-item v-if="!!field.formItemFlag" :label="label" :label-width="labelWidth + 'px'"
|
<el-form-item v-if="!!field.formItemFlag && (!field.options.hidden || (designState === true))"
|
||||||
|
:label="label" :label-width="labelWidth + 'px'"
|
||||||
:title="field.options.labelTooltip"
|
:title="field.options.labelTooltip"
|
||||||
v-show="!field.options.hidden || (designState === true)"
|
|
||||||
:rules="rules" :prop="getPropName()"
|
:rules="rules" :prop="getPropName()"
|
||||||
:class="[selected ? 'selected' : '', labelAlign, customClass, field.options.required ? 'required' : '']"
|
:class="[selected ? 'selected' : '', labelAlign, customClass, field.options.required ? 'required' : '']"
|
||||||
@click.stop="selectField(field)">
|
@click.stop="selectField(field)">
|
||||||
@ -333,14 +333,17 @@
|
|||||||
|
|
||||||
:deep(.label-left-align) .el-form-item__label {
|
:deep(.label-left-align) .el-form-item__label {
|
||||||
text-align: left;
|
text-align: left;
|
||||||
|
justify-content: flex-start !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
:deep(.label-center-align) .el-form-item__label {
|
:deep(.label-center-align) .el-form-item__label {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
|
justify-content: center !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
:deep(.label-right-align) .el-form-item__label {
|
:deep(.label-right-align) .el-form-item__label {
|
||||||
text-align: right;
|
text-align: right;
|
||||||
|
justify-content: flex-end !important;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -10,13 +10,23 @@
|
|||||||
list-type="picture-card" :class="{'hideUploadDiv': uploadBtnHidden}"
|
list-type="picture-card" :class="{'hideUploadDiv': uploadBtnHidden}"
|
||||||
:limit="field.options.limit" :on-exceed="handlePictureExceed"
|
:limit="field.options.limit" :on-exceed="handlePictureExceed"
|
||||||
:before-upload="beforePictureUpload"
|
:before-upload="beforePictureUpload"
|
||||||
:on-success="handlePictureUpload" :on-error="handelUploadError" :on-remove="handlePictureRemove">
|
:on-success="handlePictureUpload" :on-error="handleUploadError"
|
||||||
|
:before-remove="handleBeforeRemove" :on-remove="handlePictureRemove">
|
||||||
<template #tip>
|
<template #tip>
|
||||||
<div class="el-upload__tip"
|
<div class="el-upload__tip"
|
||||||
v-if="!!field.options.uploadTip">{{field.options.uploadTip}}</div>
|
v-if="!!field.options.uploadTip">{{field.options.uploadTip}}</div>
|
||||||
</template>
|
</template>
|
||||||
<div class="uploader-icon"><svg-icon icon-class="el-plus" /></div>
|
<div class="uploader-icon"><svg-icon icon-class="el-plus" /></div>
|
||||||
</el-upload>
|
</el-upload>
|
||||||
|
|
||||||
|
<div v-if="showPreviewDialogFlag" v-drag="['.drag-dialog.el-dialog', '.drag-dialog .el-dialog__header']">
|
||||||
|
<el-dialog title="" v-model="showPreviewDialogFlag"
|
||||||
|
append-to-body width="60%"
|
||||||
|
:show-close="true" custom-class="drag-dialog small-padding-dialog"
|
||||||
|
:close-on-click-modal="true" :close-on-press-escape="true" :destroy-on-close="true">
|
||||||
|
<img :src="previewUrl" style="width: 100%" alt="" />
|
||||||
|
</el-dialog>
|
||||||
|
</div>
|
||||||
</form-item-wrapper>
|
</form-item-wrapper>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@ -63,7 +73,7 @@
|
|||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
oldFieldValue: null, //field组件change之前的值
|
oldFieldValue: null, //field组件change之前的值
|
||||||
fieldModel: null,
|
fieldModel: [],
|
||||||
rules: [],
|
rules: [],
|
||||||
|
|
||||||
uploadHeaders: {},
|
uploadHeaders: {},
|
||||||
@ -75,8 +85,11 @@
|
|||||||
//authorization: '', //又拍云上传签名
|
//authorization: '', //又拍云上传签名
|
||||||
},
|
},
|
||||||
fileList: [], //上传文件列表
|
fileList: [], //上传文件列表
|
||||||
|
fileListBeforeRemove: [], //删除前的文件列表
|
||||||
uploadBtnHidden: false,
|
uploadBtnHidden: false,
|
||||||
|
|
||||||
|
previewUrl: '',
|
||||||
|
showPreviewDialogFlag: false,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
@ -107,17 +120,10 @@
|
|||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
handlePictureExceed() {
|
handlePictureExceed() {
|
||||||
let uploadLimit = this.field.options.limit /* 此行不能注释,下一行ES6模板字符串需要用到!! */
|
let uploadLimit = this.field.options.limit
|
||||||
this.$message.warning( this.i18nt('render.hint.uploadExceed').replace('${uploadLimit}', uploadLimit) )
|
this.$message.warning( this.i18nt('render.hint.uploadExceed').replace('${uploadLimit}', uploadLimit) )
|
||||||
},
|
},
|
||||||
|
|
||||||
updateUploadFieldModelAndEmitDataChange(fileList) {
|
|
||||||
let oldValue = deepClone(this.fieldModel)
|
|
||||||
this.fieldModel = deepClone(fileList)
|
|
||||||
this.syncUpdateFormModel(this.fieldModel)
|
|
||||||
this.emitFieldDataChange(this.fieldModel, oldValue)
|
|
||||||
},
|
|
||||||
|
|
||||||
beforePictureUpload(file) {
|
beforePictureUpload(file) {
|
||||||
let fileTypeCheckResult = false
|
let fileTypeCheckResult = false
|
||||||
if (!!this.field.options && !!this.field.options.fileTypes) {
|
if (!!this.field.options && !!this.field.options.fileTypes) {
|
||||||
@ -162,23 +168,64 @@
|
|||||||
return true
|
return true
|
||||||
},
|
},
|
||||||
|
|
||||||
|
updateFieldModelAndEmitDataChangeForUpload(fileList, customResult, defaultResult) {
|
||||||
|
let oldValue = deepClone(this.fieldModel)
|
||||||
|
if (!!customResult && !!customResult.name && !!customResult.url) {
|
||||||
|
this.fieldModel.push({
|
||||||
|
name: customResult.name,
|
||||||
|
url: customResult.url
|
||||||
|
})
|
||||||
|
} else if (!!defaultResult && !!defaultResult.name && !!defaultResult.url) {
|
||||||
|
this.fieldModel.push({
|
||||||
|
name: defaultResult.name,
|
||||||
|
url: defaultResult.url
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
this.fieldModel = deepClone(fileList)
|
||||||
|
}
|
||||||
|
|
||||||
|
this.syncUpdateFormModel(this.fieldModel)
|
||||||
|
this.emitFieldDataChange(this.fieldModel, oldValue)
|
||||||
|
},
|
||||||
|
|
||||||
handlePictureUpload(res, file, fileList) {
|
handlePictureUpload(res, file, fileList) {
|
||||||
if (file.status === 'success') {
|
if (file.status === 'success') {
|
||||||
//this.fileList.push(file) /* 上传过程中,this.fileList是只读的,不能修改赋值!! */
|
let customResult = null
|
||||||
this.updateUploadFieldModelAndEmitDataChange(fileList)
|
|
||||||
this.fileList = deepClone(fileList)
|
|
||||||
this.uploadBtnHidden = fileList.length >= this.field.options.limit
|
|
||||||
|
|
||||||
if (!!this.field.options.onUploadSuccess) {
|
if (!!this.field.options.onUploadSuccess) {
|
||||||
let customFn = new Function('result', 'file', 'fileList', this.field.options.onUploadSuccess)
|
let customFn = new Function('result', 'file', 'fileList', this.field.options.onUploadSuccess)
|
||||||
customFn.call(this, res, file, fileList)
|
customResult = customFn.call(this, res, file, fileList)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.updateFieldModelAndEmitDataChangeForUpload(fileList, customResult, res)
|
||||||
|
this.fileList = deepClone(fileList)
|
||||||
|
this.uploadBtnHidden = fileList.length >= this.field.options.limit
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
updateFieldModelAndEmitDataChangeForRemove(file, fileList) {
|
||||||
|
let oldValue = deepClone(this.fieldModel)
|
||||||
|
let foundFileIdx = -1
|
||||||
|
this.fileListBeforeRemove.map((fi, idx) => { /* 跟element-ui不同,element-plus删除文件时this.fileList数组对应元素已被删除!! */
|
||||||
|
if ((fi.name === file.name) && ((fi.url === file.url) || (!!fi.uid && fi.uid === file.uid))) { /* 这个判断有问题?? */
|
||||||
|
foundFileIdx = idx
|
||||||
|
}
|
||||||
|
})
|
||||||
|
if (foundFileIdx > -1) {
|
||||||
|
this.fieldModel.splice(foundFileIdx, 1)
|
||||||
|
}
|
||||||
|
|
||||||
|
this.syncUpdateFormModel(this.fieldModel)
|
||||||
|
this.emitFieldDataChange(this.fieldModel, oldValue)
|
||||||
|
},
|
||||||
|
|
||||||
|
handleBeforeRemove(file, fileList) {
|
||||||
|
/* 保留删除之前的文件列表!! */
|
||||||
|
this.fileListBeforeRemove = deepClone(fileList)
|
||||||
|
},
|
||||||
|
|
||||||
handlePictureRemove(file, fileList) {
|
handlePictureRemove(file, fileList) {
|
||||||
|
this.updateFieldModelAndEmitDataChangeForRemove(file, fileList)
|
||||||
this.fileList = deepClone(fileList) //this.fileList = fileList
|
this.fileList = deepClone(fileList) //this.fileList = fileList
|
||||||
this.updateUploadFieldModelAndEmitDataChange(fileList)
|
|
||||||
this.uploadBtnHidden = fileList.length >= this.field.options.limit
|
this.uploadBtnHidden = fileList.length >= this.field.options.limit
|
||||||
|
|
||||||
if (!!this.field.options.onFileRemove) {
|
if (!!this.field.options.onFileRemove) {
|
||||||
@ -187,7 +234,7 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
handelUploadError(err, file, fileList) {
|
handleUploadError(err, file, fileList) {
|
||||||
if (!!this.field.options.onUploadError) {
|
if (!!this.field.options.onUploadError) {
|
||||||
let customFn = new Function('error', 'file', 'fileList', this.field.options.onUploadError)
|
let customFn = new Function('error', 'file', 'fileList', this.field.options.onUploadError)
|
||||||
customFn.call(this, err, file, fileList)
|
customFn.call(this, err, file, fileList)
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
<template>
|
<template>
|
||||||
<el-form-item :label="i18nt('designer.setting.defaultValue')">
|
<el-form-item v-if="!hasConfig('optionItems')" :label="i18nt('designer.setting.defaultValue')">
|
||||||
<el-input v-if="!hasConfig('optionItems')" type="text" v-model="optionModel.defaultValue"
|
<el-input type="text" v-model="optionModel.defaultValue"
|
||||||
@change="emitDefaultValueChange"></el-input>
|
@change="emitDefaultValueChange"></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</template>
|
</template>
|
||||||
|
@ -269,7 +269,7 @@
|
|||||||
this.deleteFromRowIdData(formRowIndex)
|
this.deleteFromRowIdData(formRowIndex)
|
||||||
this.deleteFromFieldSchemaData(formRowIndex)
|
this.deleteFromFieldSchemaData(formRowIndex)
|
||||||
|
|
||||||
this.handelSubFormRowDelete(oldSubFormData, deletedDataRow)
|
this.handleSubFormRowDelete(oldSubFormData, deletedDataRow)
|
||||||
this.handleSubFormRowChange(oldSubFormData)
|
this.handleSubFormRowChange(oldSubFormData)
|
||||||
}).catch(() => {
|
}).catch(() => {
|
||||||
//
|
//
|
||||||
@ -297,7 +297,7 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
handelSubFormRowDelete(subFormData, deletedDataRow) {
|
handleSubFormRowDelete(subFormData, deletedDataRow) {
|
||||||
if (!!this.widget.options.onSubFormRowDelete) {
|
if (!!this.widget.options.onSubFormRowDelete) {
|
||||||
let customFunc = new Function('subFormData', 'deletedDataRow', this.widget.options.onSubFormRowDelete)
|
let customFunc = new Function('subFormData', 'deletedDataRow', this.widget.options.onSubFormRowDelete)
|
||||||
customFunc.call(this, subFormData, deletedDataRow)
|
customFunc.call(this, subFormData, deletedDataRow)
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
<el-alert ref="fieldEditor" :title="field.options.title" :type="field.options.type"
|
<el-alert ref="fieldEditor" :title="field.options.title" :type="field.options.type"
|
||||||
:description="field.options.description" :closable="field.options.closable"
|
:description="field.options.description" :closable="field.options.closable"
|
||||||
:center="field.options.center" :close-text="field.options.closeText"
|
:center="field.options.center" :close-text="field.options.closeText"
|
||||||
:show-icon="field.options.showIcon" :effect="field.options.effect" @close="handelCloseCustomEvent"></el-alert>
|
:show-icon="field.options.showIcon" :effect="field.options.effect" @close="handleCloseCustomEvent"></el-alert>
|
||||||
</static-content-wrapper>
|
</static-content-wrapper>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
@ -56,7 +56,7 @@
|
|||||||
this.unregisterFromRefList()
|
this.unregisterFromRefList()
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
handelCloseCustomEvent() {
|
handleCloseCustomEvent() {
|
||||||
if (!!this.field.options.onClose) {
|
if (!!this.field.options.onClose) {
|
||||||
let changeFn = new Function(this.field.options.onClose)
|
let changeFn = new Function(this.field.options.onClose)
|
||||||
changeFn.call(this)
|
changeFn.call(this)
|
||||||
|
Loading…
Reference in New Issue
Block a user