wyyl/resources/beike/admin/views/pages/plugins/form.blade.php

129 lines
4.8 KiB
PHP

@extends('admin::layouts.master')
@section('title', '插件编辑')
@push('header')
<script src="{{ asset('vendor/tinymce/5.9.1/tinymce.min.js') }}"></script>
{{-- <script src="{{ asset('vendor/tinymce-vue/tinymce-vue.min.js') }}"></script> --}}
@endpush
@section('content')
<div id="plugins-app-form" class="card">
<div class="card-body pt-5">
<el-form :model="form" :rules="rules" ref="form" label-width="110px">
<div v-for="column, index in source.columns">
<el-form-item :label="column.label" v-if="column.type == 'string'" class="form-max-w" :prop="column.required ? column.name : ''">
<el-input v-model="form[column.name]" :placeholder="column.label"></el-input>
<div class="text-muted font-size-12 lh-base" v-if="column.description">@{{ column.description }}</div>
</el-form-item>
<el-form-item :label="column.label" v-if="column.type == 'text'" style="max-width: 900px;" :prop="column.required ? column.name : ''">
<textarea v-model="form[column.name]" :data-key="column.name" id="input-tinymce"></textarea>
<div class="text-muted font-size-12 lh-base" v-if="column.description">@{{ column.description }}</div>
</el-form-item>
<el-form-item :label="column.label" v-if="column.type == 'select'" class="form-max-w">
<el-select v-model="form[column.name]" placeholder="请选择" >
<el-option v-for="option, o_i in column.options" :key="o_i" :label="option.label"
:value="option.value">
</el-option>
</el-select>
<div class="text-muted font-size-12 lh-base" v-if="column.description">@{{ column.description }}</div>
</el-form-item>
<el-form-item :label="column.label" v-if="column.type == 'bool'">
<el-switch v-model="form[column.name]" :active-value="1" :inactive-value="0"></el-switch>
<div class="text-muted font-size-12 lh-base" v-if="column.description">@{{ column.description }}</div>
</el-form-item>
</div>
<el-form-item>
<el-button type="primary" @click="submitForm('form')">提交</el-button>
</el-form-item>
</el-form>
</div>
</div>
@endsection
@push('footer')
<script>
let app = new Vue({
el: '#plugins-app-form',
data: {
customerTab: 'customer',
form: {
status: false
},
source: {
columns: @json($plugin->getColumns())
},
rules: {
// name: [{required: true, message: '请输入用户名', trigger: 'blur'}, ],
},
},
// 在实例创建完成后被立即同步调用
created () {
},
// 在挂载开始之前被调用:相关的 render 函数首次被调用
beforeMount () {
this.source.columns.forEach((e) => {
this.$set(this.form, e.name, e.value)
if (e.required) {
this.rules[e.name] = [{required: true, message: `请输入${e.label}`, trigger: 'blur'}]
}
})
},
// 实例被挂载后调用
mounted () {
},
methods: {
submitForm(form) {
this.$refs[form].validate((valid) => {
if (!valid) {
this.$message.error('请检查表单是否填写正确');
return;
}
$http.put(`/admin/plugins/{{ $plugin->code }}`, this.form).then((res) => {
this.$message.success(res.message);
})
});
},
}
});
</script>
<script>
tinymce.init({
selector: '#input-tinymce',
language: "zh_CN",
branding: false,
height: 400,
plugins: "link lists fullscreen table hr wordcount image imagetools code",
menubar: "",
toolbar: "undo redo | toolbarImageButton | bold italic underline strikethrough | forecolor backcolor | fontselect fontsizeselect formatselect | alignleft aligncenter alignright alignjustify | outdent indent | numlist bullist | formatpainter removeformat | charmap emoticons | preview | template link anchor table toolbarImageUrlButton | fullscreen code",
// contextmenu: "link image imagetools table",
toolbar_items_size: 'small',
image_caption: true,
// imagetools_toolbar: 'imageoptions',
toolbar_mode: 'wrap',
font_formats:
"微软雅黑='Microsoft YaHei';黑体=黑体;Arial=arial,helvetica,sans-serif;Arial Black=arial black,avant garde;Georgia=georgia,palatino;Helvetica=helvetica;Times New Roman=times new roman,times;Verdana=verdana,geneva",
fontsize_formats: "10px 12px 14px 18px 24px 36px",
relative_urls : true,
setup:function(ed) {
ed.on('change', function(e) {
if (e.target.targetElm.dataset.key) {
app.form[e.target.targetElm.dataset.key] = ed.getContent()
}
});
}
});
</script>
@endpush