mirror of
https://github.com/vform666/variant-form3-vite.git
synced 2025-01-10 16:19:13 +08:00
Merge pull request #15 from oleksandr-belovol/widgets-preview
Added base logic
This commit is contained in:
commit
0bd93fe9fd
@ -50,7 +50,7 @@
|
|||||||
:fullscreen="(layoutType === 'H5') || (layoutType === 'Pad')">
|
:fullscreen="(layoutType === 'H5') || (layoutType === 'Pad')">
|
||||||
<div>
|
<div>
|
||||||
<div class="form-render-wrapper" :class="[layoutType === 'H5' ? 'h5-layout' : (layoutType === 'Pad' ? 'pad-layout' : '')]">
|
<div class="form-render-wrapper" :class="[layoutType === 'H5' ? 'h5-layout' : (layoutType === 'Pad' ? 'pad-layout' : '')]">
|
||||||
<VFormRender ref="preForm" :form-json="formJson" :form-data="testFormData" :preview-state="true"
|
<VFormRender ref="preForm" :form-json="previewFormJson" :form-data="testFormData" :preview-state="true"
|
||||||
:option-data="testOptionData" @myEmitTest="onMyEmitTest"
|
:option-data="testOptionData" @myEmitTest="onMyEmitTest"
|
||||||
@appendButtonClick="testOnAppendButtonClick" @buttonClick="testOnButtonClick"
|
@appendButtonClick="testOnAppendButtonClick" @buttonClick="testOnButtonClick"
|
||||||
@formChange="handleFormChange">
|
@formChange="handleFormChange">
|
||||||
@ -201,7 +201,8 @@
|
|||||||
import loadBeautifier from "@/utils/beautifierLoader"
|
import loadBeautifier from "@/utils/beautifierLoader"
|
||||||
import { saveAs } from 'file-saver'
|
import { saveAs } from 'file-saver'
|
||||||
import axios from 'axios'
|
import axios from 'axios'
|
||||||
import SvgIcon from "@/components/svg-icon/index";
|
import SvgIcon from "@/components/svg-icon/index"
|
||||||
|
import { fillUnfilledWidgetPropsForPreview, unfilledWidgetPropsDefaultData } from "@/utils/widgets-preview"
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "ToolbarPanel",
|
name: "ToolbarPanel",
|
||||||
@ -273,6 +274,12 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
|
previewFormJson() {
|
||||||
|
return {
|
||||||
|
widgetList: fillUnfilledWidgetPropsForPreview(this.designer.widgetList, unfilledWidgetPropsDefaultData),
|
||||||
|
formConfig: deepClone(this.designer.formConfig)
|
||||||
|
}
|
||||||
|
},
|
||||||
formJson() {
|
formJson() {
|
||||||
return {
|
return {
|
||||||
// widgetList: this.designer.widgetList,
|
// widgetList: this.designer.widgetList,
|
||||||
|
47
src/utils/widgets-preview.js
Normal file
47
src/utils/widgets-preview.js
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
import { deepClone } from "@/utils/util"
|
||||||
|
|
||||||
|
const widgetPropsForDetectChanges = {
|
||||||
|
input: { defaultValue: '' },
|
||||||
|
textarea: { defaultValue: '' },
|
||||||
|
number: { defaultValue: 0 },
|
||||||
|
radio: { defaultValue: null },
|
||||||
|
checkbox: { defaultValue: [] },
|
||||||
|
select: { defaultValue: '' },
|
||||||
|
time: { defaultValue: null },
|
||||||
|
'time-range': { defaultValue: null },
|
||||||
|
date: { defaultValue: null },
|
||||||
|
'date-range': { defaultValue: null },
|
||||||
|
switch: { defaultValue: null },
|
||||||
|
rate: { defaultValue: null },
|
||||||
|
color: { defaultValue: null },
|
||||||
|
slider: {},
|
||||||
|
'static-text': { textContent: 'static text' },
|
||||||
|
'html-text': { htmlContent: '<b>html text</b>' },
|
||||||
|
button: { label: 'button', type: '' },
|
||||||
|
divider: { label: '' },
|
||||||
|
'picture-upload': { uploadURL: '' },
|
||||||
|
'file-upload': { uploadURL: '' },
|
||||||
|
'rich-editor': {},
|
||||||
|
'cascader': { defaultValue: '' }
|
||||||
|
}
|
||||||
|
export const unfilledWidgetPropsDefaultData = {
|
||||||
|
input: { defaultValue: 'test text' },
|
||||||
|
checkbox: { defaultValue: [1] },
|
||||||
|
button: { label: 'custom label', type: 'success' },
|
||||||
|
time: { defaultValue: '16:04:48' },
|
||||||
|
}
|
||||||
|
export function fillUnfilledWidgetPropsForPreview(widgets, unfilledWidgetPropsData) {
|
||||||
|
return deepClone(widgets).map((widget) => {
|
||||||
|
const widgetPropsForDetect = widgetPropsForDetectChanges[widget.type]
|
||||||
|
Object.keys(widgetPropsForDetect).forEach((widgetProp) => {
|
||||||
|
if(
|
||||||
|
unfilledWidgetPropsData[widget.type]
|
||||||
|
&&
|
||||||
|
JSON.stringify(widget.options[widgetProp]) === JSON.stringify(widgetPropsForDetect[widgetProp])
|
||||||
|
) {
|
||||||
|
widget.options[widgetProp] = unfilledWidgetPropsData[widget.type][widgetProp]
|
||||||
|
}
|
||||||
|
})
|
||||||
|
return widget
|
||||||
|
});
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user