<script>
/* eslint no-console:0 */
import './draggable.less'
import Tree, { TreeNode } from '../index'
import '../assets/index.less'
import { gData } from './util'
import BaseMixin from '../../_util/BaseMixin'

export default {
  mixins: [BaseMixin],
  data () {
    return {
      gData,
      autoExpandParent: true,
      expandedKeys: ['0-0-key', '0-0-0-key', '0-0-0-0-key'],
    }
  },
  methods: {
    onDragStart  (info) {
      console.log('start', info)
    },
    onDragEnter (info) {
      console.log('enter', info)
      this.setState({
        expandedKeys: info.expandedKeys,
      })
    },
    onDrop (info) {
      console.log('drop', info)
      const dropKey = info.node.eventKey
      const dragKey = info.dragNode.eventKey
      const dropPos = info.node.pos.split('-')
      const dropPosition = info.dropPosition - Number(dropPos[dropPos.length - 1])
      // const dragNodesKeys = info.dragNodesKeys;
      const loop = (data, key, callback) => {
        data.forEach((item, index, arr) => {
          if (item.key === key) {
            return callback(item, index, arr)
          }
          if (item.children) {
            return loop(item.children, key, callback)
          }
        })
      }
      const data = [...this.gData]
      let dragObj
      loop(data, dragKey, (item, index, arr) => {
        arr.splice(index, 1)
        dragObj = item
      })
      if (info.dropToGap) {
        let ar
        let i
        loop(data, dropKey, (item, index, arr) => {
          ar = arr
          i = index
        })
        if (dropPosition === -1) {
          ar.splice(i, 0, dragObj)
        } else {
          ar.splice(i + 1, 0, dragObj)
        }
      } else {
        loop(data, dropKey, (item) => {
          item.children = item.children || []
          // where to insert 示例添加到尾部,可以是随意位置
          item.children.push(dragObj)
        })
      }
      this.setState({
        gData: data,
      })
    },
    onExpand (expandedKeys) {
      console.log('onExpand', arguments)
      this.setState({
        expandedKeys,
        autoExpandParent: false,
      })
    },
  },

  render () {
    const loop = data => {
      return data.map((item) => {
        if (item.children && item.children.length) {
          return <TreeNode key={item.key} title={item.title}>{loop(item.children)}</TreeNode>
        }
        return <TreeNode key={item.key} title={item.title} />
      })
    }
    return (<div class='draggable-demo'>
      <h2>draggable</h2>
      <p>drag a node into another node</p>
      <div class='draggable-container'>
        <Tree
          expandedKeys={this.expandedKeys}
          onExpand={this.onExpand} autoExpandParent={this.autoExpandParent}
          draggable
          onDragstart={this.onDragStart}
          onDragenter={this.onDragEnter}
          onDrop={this.onDrop}
        >
          {loop(this.gData)}
        </Tree>
      </div>
    </div>)
  },
}

</script>