index.vue 2.67 KB
Newer Older
何虹's avatar
何虹 committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129
<template>
  <div class="hsInputBox" :id='elId'>
    <div class="treeBox">
          <el-tree
          node-key="label"
          :default-checked-keys="defaultCheckedkeys"
          :default-expanded-keys="defaultCheckedkeys"
          :data="sourceData"
          :props="configData.defaultProps"
          @node-click="handleNodeClick"></el-tree>
    </div>
    <jsoneditor v-model='jsoneditorVisible'
                :elInfo='elInfo'
                :layout='layout'
                :jsoneditorData='jsoneditorData'
                :jsoneditorCloseAfter='jsoneditorCloseAfter'
                :jsoneditorOpenAfter='jsoneditorOpenAfter'
                >
    </jsoneditor>
  </div>
</template>
<script>
import ucComponent from '../ucClass/uc_component'
import uuidv1 from 'uuid/v1'
import jsoneditor from '../common/jsoneditor'
export default {
  mixins: [ucComponent],
  components: {
    jsoneditor
  },
  name: 'hsTree',
  props: {
    allSourceData: {
      type: Object,
      default() {
        return {}
      }
    },
    elInfo: {
      type: Object,
      default() {
        return {}
      }
    },
    value: '',
    layout: {},
    jsoneditorCloseAfter: {
      type: Function
    },
    jsoneditorOpenAfter: {
      type: Function
    }
  },
  watch: {
    allSourceData: {
      handler: function(newVal, oldVal) {
        this.initDataConfig(newVal)
      },
      deep: true
    },
    value(val) {
      this.value_inner = val
    },
    value_inner(val) {
      this.$emit('input', val)
    }
  },
  data() {
    return {
      elId: '',
      value_inner: '',
      jsoneditorVisible: false,
      jsoneditorData: {},
      title: '',
      placeholder: '',
      size: 'mini',
      sourceData: [],
      configData: {
        defaultProps: {
          children: 'children',
          label: 'label'
        }
      },
      defaultCheckedkeys: []
    }
  },
  created() {
    this.elId = uuidv1() // 获取随机id
  },
  mounted() {
    this.initDataConfig(this.allSourceData)
  },
  methods: {
    handleNodeClick(data) {
      const obj = {
        elInfo: this.elInfo,
        data
      }
      this.$emit('input', data.label)
      this.$emit('handleNodeClick', obj)
    },
    initDataConfig(data) {
      const { config, sourceData } = data
      this.sourceData = sourceData
      Object.assign(this.configData, config)
      this.defaultCheckedkeys = [this.value_inner]
    },
    submitInput(val) {
      const parm = {}
      parm[this.elInfo.prop] = this.value_inner
      this.$emit('enterInput', parm)
    }
  }
}
</script>
<style scoped>
.hsInputBox{
  padding: 1px;
  width:100%;
  height:100%;
  display: flex;
}
.treeBox{
  width: 100%;
  height: 100%;
  border: 1px solid #ddd;
}

</style>