<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>