174 lines
4.3 KiB
JavaScript
174 lines
4.3 KiB
JavaScript
import {translate} from "@/utils/i18n"
|
|
import emitter from 'element-ui/lib/mixins/emitter'
|
|
|
|
export const createInputTextEditor = function (propName, propLabelKey) {
|
|
return {
|
|
props: {
|
|
optionModel: Object,
|
|
},
|
|
render(h) {
|
|
return (
|
|
<el-form-item label={translate(propLabelKey)}>
|
|
<el-input type="text" v-model={this.optionModel[propName]} />
|
|
</el-form-item>
|
|
)
|
|
}
|
|
}
|
|
}
|
|
|
|
export const createInputNumberEditor = function (propName, propLabelKey) {
|
|
return {
|
|
props: {
|
|
optionModel: Object,
|
|
},
|
|
methods: {
|
|
updateValue(newValue) {
|
|
if ((newValue === undefined) || (newValue === null) || isNaN(newValue)) {
|
|
this.optionModel[propName] = null
|
|
} else {
|
|
this.optionModel[propName] = Number(newValue)
|
|
}
|
|
},
|
|
},
|
|
render(h) {
|
|
return (
|
|
<el-form-item label={translate(propLabelKey)}>
|
|
<el-input-number type="text" v-model={this.optionModel[propName]}
|
|
onChange={this.updateValue} style="width: 100%" />
|
|
</el-form-item>
|
|
)
|
|
}
|
|
}
|
|
}
|
|
|
|
export const createBooleanEditor = function (propName, propLabelKey) {
|
|
return {
|
|
props: {
|
|
optionModel: Object,
|
|
},
|
|
render(h) {
|
|
return (
|
|
<el-form-item label={translate(propLabelKey)}>
|
|
<el-switch v-model={this.optionModel[propName]} />
|
|
</el-form-item>
|
|
)
|
|
}
|
|
}
|
|
}
|
|
|
|
export const createCheckboxGroupEditor = function (propName, propLabelKey, configs) {
|
|
return {
|
|
props: {
|
|
optionModel: Object,
|
|
},
|
|
render(h) {
|
|
return (
|
|
<el-form-item label={translate(propLabelKey)}>
|
|
<el-checkbox-group v-model={this.optionModel[propName]}>
|
|
{
|
|
configs.optionItems.map(item => {
|
|
return <el-checkbox label={item.value}>{item.label}</el-checkbox>
|
|
})
|
|
}
|
|
</el-checkbox-group>
|
|
</el-form-item>
|
|
)
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
export const createRadioGroupEditor = function (propName, propLabelKey, configs) {
|
|
return {
|
|
props: {
|
|
optionModel: Object,
|
|
},
|
|
render(h) {
|
|
return (
|
|
<el-form-item label={translate(propLabelKey)}>
|
|
<el-radio-group v-model={this.optionModel[propName]}>
|
|
{
|
|
configs.optionItems.map(item => {
|
|
return <el-radio label={item.value}>{item.label}</el-radio>
|
|
})
|
|
}
|
|
</el-radio-group>
|
|
</el-form-item>
|
|
)
|
|
}
|
|
}
|
|
}
|
|
|
|
export const createRadioButtonGroupEditor = function (propName, propLabelKey, configs) {
|
|
return {
|
|
props: {
|
|
optionModel: Object,
|
|
},
|
|
render(h) {
|
|
return (
|
|
<el-form-item label={translate(propLabelKey)}>
|
|
<el-radio-group v-model={this.optionModel[propName]}>
|
|
{
|
|
configs.optionItems.map(item => {
|
|
return <el-radio-button label={item.value}>{item.label}</el-radio-button>
|
|
})
|
|
}
|
|
</el-radio-group>
|
|
</el-form-item>
|
|
)
|
|
}
|
|
}
|
|
}
|
|
|
|
export const createSelectEditor = function (propName, propLabelKey, configs) {
|
|
return {
|
|
props: {
|
|
optionModel: Object,
|
|
},
|
|
render(h) {
|
|
return (
|
|
<el-form-item label={translate(propLabelKey)}>
|
|
<el-select v-model={this.optionModel[propName]}>
|
|
{
|
|
configs.optionItems.map(item => {
|
|
return <el-option label={item.label} value={item.value} />
|
|
})
|
|
}
|
|
</el-select>
|
|
</el-form-item>
|
|
)
|
|
}
|
|
}
|
|
}
|
|
|
|
export const createEventHandlerEditor = function (eventPropName, eventParams) {
|
|
return {
|
|
props: {
|
|
optionModel: Object,
|
|
},
|
|
mixins: [emitter],
|
|
methods: {
|
|
editEventHandler() {
|
|
this.dispatch('SettingPanel', 'editEventHandler', [eventPropName, [...eventParams]])
|
|
},
|
|
},
|
|
render(h) {
|
|
return (
|
|
<el-form-item label={eventPropName} label-width="150px">
|
|
<el-button type="info" icon="el-icon-edit" plain round onClick={this.editEventHandler}>
|
|
{translate('designer.setting.addEventHandler')}</el-button>
|
|
</el-form-item>
|
|
)
|
|
}
|
|
}
|
|
}
|
|
|
|
export const createEmptyEditor = function () {
|
|
return {
|
|
render() {
|
|
return <div style="display: none" />
|
|
}
|
|
}
|
|
}
|
|
|