| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 |
- <template>
- <div>
- <el-form-item class="widget-view "
- v-if="element && element.key && element.type != 'divider'"
- :class="{active: selectWidget.key == element.key, 'is_req': element.options.required, 'is_hidden': element.options.hidden}"
- :label="element.name"
- :label-width="element.options.isLabelWidth ? element.options.labelWidth + 'px' : ''"
- @click.native.stop="handleSelectWidget(index)"
- >
- <widget-element-item :element="element" :is-table="false" :key="element.key"></widget-element-item>
- <div class="widget-view-action" v-if="selectWidget.key == element.key">
- <i class="iconfont icon-icon_clone" @click.stop="handleWidgetClone(index)"></i>
- <i class="iconfont icon-trash" @click.stop="handleWidgetDelete(index)"></i>
- </div>
- <div class="widget-view-drag" v-if="selectWidget.key == element.key">
- <i class="iconfont icon-drag drag-widget"></i>
- </div>
- <!-- <div class="widget-view-model" v-if="element.options.dataBind">
- <span>{{element.model}}</span>
- </div> -->
-
- </el-form-item>
- <div class="widget-view no-put"
- v-if="element && element.key && element.type == 'divider'"
- :class="{active: selectWidget.key == element.key, 'is_hidden': element.options.hidden}"
- @click.stop="handleSelectWidget(index)"
- style="padding-bottom: 0;"
- >
- <el-divider :content-position="element.options.contentPosition">
- {{element.name}}
- </el-divider>
- <div class="widget-view-action" v-if="selectWidget.key == element.key">
- <i class="iconfont icon-icon_clone" @click.stop="handleWidgetClone(index)"></i>
- <i class="iconfont icon-trash" @click.stop="handleWidgetDelete(index)"></i>
- </div>
- <div class="widget-view-drag" v-if="selectWidget.key == element.key">
- <i class="iconfont icon-drag drag-widget"></i>
- </div>
- <div class="widget-view-model" v-if="element.options.dataBind">
- <span>{{element.model}}</span>
- </div>
- </div>
- </div>
- </template>
- <script>
- import WidgetElementItem from './WidgetElementItem'
- import _ from 'lodash'
- import { EventBus } from '../util/event-bus.js'
- export default {
- props: ['element', 'select', 'index', 'data'],
- components: {
- WidgetElementItem
- },
- data () {
- return {
- selectWidget: this.select
- }
- },
- mounted () {
-
- },
- methods: {
- handleSelectWidget (index) {
- this.selectWidget = this.data.list[index]
- },
- handleWidgetDelete (index) {
- if (this.data.list.length == 1) {
- this.$emit('select-change', -1)
- } else {
- if (this.data.list.length - 1 == index) {
- this.$emit('select-change', index - 1)
- } else {
- this.$emit('select-change', index)
- }
- }
- this.$nextTick(() => {
- this.data.list.splice(index, 1)
- setTimeout(() => {
- EventBus.$emit('on-history-add')
- }, 20)
- })
- },
- handleWidgetClone (index) {
- const key = new Date().getTime() + ''
- let cloneData = {
- ..._.cloneDeep(this.data.list[index]),
- key,
- model: this.data.list[index].type + key,
- }
- this.data.list.splice(index + 1, 0, cloneData)
- this.$nextTick(() => {
- this.selectWidget = this.data.list[index + 1]
- this.$nextTick(() => { EventBus.$emit('on-history-add') })
- })
- }
- },
- watch: {
- select (val) {
- this.selectWidget = val
- },
- selectWidget: {
- handler (val) {
- this.$emit('update:select', val)
- },
- deep: true
- }
- }
- }
- </script>
|