import { Dom, Graph, Node } from '@antv/x6'
import {
  conveyor,
  direction,
  one_track,
  pallet,
  rgv,
  stacker,
  storage,
  two_track
} from './images'
import { basicPorts, customPorts } from './ports'

export const SRM = Graph.registerNode('SRM', {
  inherit: 'image',
  width: 40,
  height: 40,
  attrs: {
    image: {
      'xlink:href': stacker,
      height: 40,
      x: 0,
      y: 0,
      preserveAspectRatio: 'none',
      'vector-effect': 'non-scaling-stroke'
    },
    imagePallet: {
      'xlink:href': pallet,
      height: 40,
      width: 40,
      class: 'hide-pallet',
      preserveAspectRatio: 'none',
      'vector-effect': 'non-scaling-stroke'
    },
    body: {
      // stroke: '#5F95FF',
      stroke: '#FF0000',
      strokeWidth: 3,
      fill: 'rgba(95,149,255,0.0001)',
      // fill: 'rgba(255,0,0,1)',
      height: 0,
      width: 0,
      class: 'flash-shrink-animation-close'
    },
    textCode: {
      class: 'animate-text1',
      text: '',
      fontSize: 8,
      fill: '#000000',
      stroke: '#000000',
      strokeWidth: 1,
      x: 0,
      y: -5
    }
    // text: {
    //   stroke: '#FF0000',
    //   strokeWidth: 1,
    //   class: 'animate-text1',
    //   text: '堆垛机',
    //   fontSize: 12,
    //   fill: '#FF0000',
    //   fillOpacity: 0.8,
    //   background: {
    //     fill: '#FFFF00',
    //   }
    // }
  },
  markup: [
    {
      tagName: 'image',
      selector: 'image'
    },
    {
      tagName: 'image',
      selector: 'imagePallet'
    },
    {
      tagName: 'rect',
      selector: 'body'
    },
    {
      tagName: 'text',
      selector: 'textCode'
    }
  ]
})

export const RGV = Graph.registerNode('RGV', {
  inherit: 'image',
  width: 40,
  height: 40,
  attrs: {
    image: {
      'xlink:href': rgv,
      height: 40,
      x: 0,
      y: 0,
      preserveAspectRatio: 'none',
      'vector-effect': 'non-scaling-stroke'
    },
    imagePallet: {
      'xlink:href': pallet,
      height: 40,
      width: 40,
      class: 'hide-pallet',
      preserveAspectRatio: 'none',
      'vector-effect': 'non-scaling-stroke'
    },
    body: {
      stroke: '#FF0000',
      strokeWidth: 3,
      fill: 'rgba(95,149,255,0.0001)',
      height: 0,
      width: 0,
      class: 'flash-shrink-animation-close'
    },
    textCode: {
      class: 'animate-text1',
      text: '',
      fontSize: 8,
      fill: '#000000',
      stroke: '#000000',
      strokeWidth: 1,
      x: 5,
      y: 20
    }
  },
  markup: [
    {
      tagName: 'image',
      selector: 'image'
    },
    {
      tagName: 'image',
      selector: 'imagePallet'
    },
    {
      tagName: 'rect',
      selector: 'body'
    },
    {
      tagName: 'text',
      selector: 'textCode'
    }
  ]
})

export const Station = Graph.registerNode('Station', {
  inherit: 'image',
  width: 60,
  height: 60,
  attrs: {
    image: {
      'xlink:href': conveyor,
      height: 60,
      x: 0,
      y: 0,
      preserveAspectRatio: 'none',
      'vector-effect': 'non-scaling-stroke'
    },
    imagePallet: {
      'xlink:href': pallet,
      height: 40,
      width: 40,
      class: 'hide-pallet',
      preserveAspectRatio: 'none',
      'vector-effect': 'non-scaling-stroke'
    },
    body: {
      stroke: '#FF0000',
      strokeWidth: 3,
      fill: 'rgba(95,149,255,0.0001)',
      height: 0,
      width: 0,
      class: 'flash-shrink-animation-close'
    },
    text: {
      class: 'animate-text1',
      fontSize: 12,
      // fill: '#5F95FF',
      // fill: '#0000FF',
      fill: '#5F95FF'
    },
    textCode: {
      class: 'animate-text1',
      text: '',
      fontSize: 8,
      fill: '#000000',
      stroke: '#000000',
      strokeWidth: 1,
      x: 15,
      y: 20
    }
  },
  markup: [
    {
      tagName: 'image',
      selector: 'image'
    },
    {
      tagName: 'image',
      selector: 'imagePallet'
    },
    {
      tagName: 'rect',
      selector: 'body'
    },
    {
      tagName: 'rect',
      selector: 'textBackground'
    },
    {
      tagName: 'text',
      selector: 'text'
    },
    {
      tagName: 'text',
      selector: 'textCode'
    }
  ]
})

export const Station_D = Graph.registerNode('Station-D', {
  inherit: 'image',
  width: 60,
  height: 60,
  attrs: {
    image: {
      'xlink:href': direction,
      height: 60,
      x: 0,
      y: 0,
      preserveAspectRatio: 'none',
      'vector-effect': 'non-scaling-stroke'
    },
    imagePallet: {
      'xlink:href': pallet,
      height: 40,
      width: 40,
      class: 'hide-pallet',
      preserveAspectRatio: 'none',
      'vector-effect': 'non-scaling-stroke'
    },
    body: {
      stroke: '#FF0000',
      strokeWidth: 3,
      fill: 'rgba(95,149,255,0.0001)',
      height: 0,
      width: 0,
      class: 'flash-shrink-animation-close'
    },
    text: {
      class: 'animate-text1',
      text: '',
      fontSize: 12,
      // fill: '#5F95FF',
      // fill: '#0000FF',
      fill: '#5F95FF'
    },
    textCode: {
      class: 'animate-text1',
      text: '',
      fontSize: 8,
      fill: '#000000',
      stroke: '#000000',
      strokeWidth: 1,
      x: 2,
      y: 20
    }
  },
  markup: [
    {
      tagName: 'image',
      selector: 'image'
    },
    {
      tagName: 'image',
      selector: 'imagePallet'
    },
    {
      tagName: 'rect',
      selector: 'body'
    },
    {
      tagName: 'text',
      selector: 'text'
    },
    {
      tagName: 'text',
      selector: 'textCode'
    }
  ]
})

export const Storage = Graph.registerNode('Storage', {
  inherit: 'image',
  width: 60,
  height: 60,
  attrs: {
    image: {
      'xlink:href': storage,
      height: 60,
      x: 0,
      y: 0,
      preserveAspectRatio: 'none',
      'vector-effect': 'non-scaling-stroke'
    },
    body: {
      stroke: '#5F95FF',
      strokeWidth: 1,
      fill: 'rgba(95,149,255,0.05)',
      height: 30,
      width: 30
    },
    text: {
      class: 'animate-text1',
      text: '1',
      fontSize: 12,
      fill: '#5F95FF'
      // fill: '#0000FF',
    }
  },
  markup: [
    {
      tagName: 'image',
      selector: 'image'
    },
    {
      tagName: 'rect',
      selector: 'body'
    },
    {
      tagName: 'text',
      selector: 'text'
    }
  ]
})

export const OneTrack = Graph.registerNode('OneTrack', {
  inherit: 'image',
  width: 40,
  height: 40,
  attrs: {
    image: {
      'xlink:href': one_track,
      height: 40,
      x: 0,
      y: 0,
      preserveAspectRatio: 'none',
      'vector-effect': 'non-scaling-stroke'
    }
  },
  markup: [
    {
      tagName: 'image',
      selector: 'image'
    }
  ]
})

export const TwoTrack = Graph.registerNode('TwoTrack', {
  inherit: 'image',
  width: 40,
  height: 40,
  attrs: {
    image: {
      'xlink:href': two_track,
      height: 40,
      x: 0,
      y: 0,
      preserveAspectRatio: 'none',
      'vector-effect': 'non-scaling-stroke'
    }
  },
  markup: [
    {
      tagName: 'image',
      selector: 'image'
    }
  ]
})

// 基础节点
export const FlowChartRect = Graph.registerNode('flow-chart-rect', {
  inherit: 'rect',
  width: 80,
  height: 42,
  attrs: {
    body: {
      stroke: '#5F95FF',
      strokeWidth: 1,
      fill: '#ffffff'
    },
    fo: {
      refWidth: '100%',
      refHeight: '100%'
    },
    foBody: {
      xmlns: Dom.ns.xhtml,
      style: {
        width: '100%',
        height: '100%',
        display: 'flex',
        justifyContent: 'center',
        alignItems: 'center'
      }
    },
    'edit-text': {
      contenteditable: 'true',
      class: 'x6-edit-text',
      style: {
        width: '100%',
        textAlign: 'center',
        fontSize: 12,
        color: 'rgba(0,0,0,0.85)'
      }
    },
    text: {
      fontSize: 12,
      fill: '#080808'
    }
  },
  markup: [
    {
      tagName: 'rect',
      selector: 'body'
    },
    {
      tagName: 'text',
      selector: 'text'
    }
    // 不让双击编辑文本
    // {
    //   tagName: 'foreignObject',
    //   selector: 'fo',
    //   children: [
    //     {
    //       ns: Dom.ns.xhtml,
    //       tagName: 'body',
    //       selector: 'foBody',
    //       children: [
    //         {
    //           tagName: 'div',
    //           selector: 'edit-text'
    //         }
    //       ]
    //     }
    //   ]
    // }
  ],
  ports: { ...basicPorts }
})
// 组合节点
export const FlowChartImageRect = Graph.registerNode('flow-chart-image-rect', {
  inherit: 'rect',
  width: 200,
  height: 60,
  attrs: {
    body: {
      stroke: '#5F95FF',
      strokeWidth: 1,
      fill: 'rgba(95,149,255,0.05)'
    },
    image: {
      'xlink:href':
        'https://gw.alipayobjects.com/zos/antfincdn/FLrTNDvlna/antv.png',
      width: 16,
      height: 16,
      x: 12,
      y: 12
    },
    title: {
      text: 'Node',
      refX: 40,
      refY: 14,
      fill: 'rgba(0,0,0,0.85)',
      fontSize: 12,
      'text-anchor': 'start'
    },
    text: {
      text: 'this is content text',
      refX: 40,
      refY: 38,
      fontSize: 12,
      fill: 'rgba(0,0,0,0.6)',
      'text-anchor': 'start'
    }
  },
  markup: [
    {
      tagName: 'rect',
      selector: 'body'
    },
    {
      tagName: 'image',
      selector: 'image'
    },
    {
      tagName: 'text',
      selector: 'title'
    },
    {
      tagName: 'text',
      selector: 'text'
    }
  ],
  ports: { ...basicPorts }
})

export const FlowChartTitleRect = Graph.registerNode('flow-chart-title-rect', {
  inherit: 'rect',
  width: 200,
  height: 68,
  attrs: {
    body: {
      stroke: '#5F95FF',
      strokeWidth: 1,
      fill: 'rgba(95,149,255,0.05)'
    },
    head: {
      refWidth: '100%',
      stroke: 'transparent',
      height: 28,
      fill: 'rgb(95,149,255)'
    },
    image: {
      'xlink:href':
        '',
      height: 16,
      x: 6,
      y: 6
    },
    title: {
      text: 'Node',
      refX: 30,
      refY: 9,
      fill: '#ffffff',
      fontSize: 12,
      'text-anchor': 'start'
    },
    text: {
      text: 'this is content text',
      refX: 8,
      refY: 45,
      fontSize: 12,
      fill: 'rgba(0,0,0,0.6)',
      'text-anchor': 'start'
    }
  },
  markup: [
    {
      tagName: 'rect',
      selector: 'body'
    },
    {
      tagName: 'rect',
      selector: 'head'
    },
    {
      tagName: 'image',
      selector: 'image'
    },
    {
      tagName: 'text',
      selector: 'title'
    },
    {
      tagName: 'text',
      selector: 'text'
    }
  ],
  ports: { ...basicPorts }
})

export const FlowChartAnimateText = Graph.registerNode(
  'flow-chart-animate-text',
  {
    inherit: 'rect',
    width: 200,
    height: 60,
    attrs: {
      body: {
        stroke: '#5F95FF',
        strokeWidth: 1,
        fill: 'rgba(95,149,255,0.05)'
      },
      text1: {
        class: 'animate-text1',
        text: '|||||||||||||',
        fontSize: 50,
        fill: '#5F95FF'
      }
      // text2: {
      //   class: 'animate-text2',
      //   text: 'AntV X6',
      //   fontSize: 32
      // }
    },
    markup: [
      {
        tagName: 'rect',
        selector: 'body'
      },
      {
        tagName: 'text',
        selector: 'text1'
      }
      // {
      //   tagName: 'text',
      //   selector: 'text2'
      // }
    ]
  }
)

// 自定义 系统设计图
export const FlowChartImageRectCustom = Graph.registerNode(
  'flow-chart-image-rect-custom',
  {
    inherit: 'rect',
    width: 80,
    height: 80,
    markup: [
      {
        tagName: 'rect',
        selector: 'body'
      },
      {
        tagName: 'image'
      },
      {
        tagName: 'text',
        selector: 'label'
      }
    ],
    attrs: {
      body: {
        // 节点线的颜色
        stroke: 'transparent',
        // 背景填充色
        fill: 'transparent'
      },
      // 自定义图片
      image: {
        width: 60,
        height: 60,
        refX: 0,
        refY: 0
      },
      label: {
        refX: 3,
        refY: 2,
        textAnchor: 'left',
        textVerticalAnchor: 'top',
        fontSize: 12,
        fill: 'black'
      },
      'edit-text': {
        contenteditable: 'true',
        class: 'x6-edit-text',
        style: {
          width: '100%',
          textAlign: 'center',
          fontSize: 12,
          color: 'rgba(0,0,0,0.85)'
        }
      },
      text: {
        fontSize: 12,
        fill: '#080808'
      }
    },
    ports: { ...customPorts }
  }
)

// 节点组
export class NodeGroup extends Node {
  collapsed = true;

  postprocess() {
    this.toggleCollapse(true)
  }

  isCollapsed() {
    return this.collapsed
  }

  toggleCollapse(collapsed) {
    const target = collapsed == null ? !this.collapsed : collapsed
    if (target) {
      this.attr('buttonSign', { d: 'M 1 5 9 5 M 5 1 5 9' })
      this.resize(200, 40)
    } else {
      this.attr('buttonSign', { d: 'M 2 5 8 5' })
      this.resize(240, 240)
    }
    this.collapsed = target
  }
}

NodeGroup.config({
  shape: 'rect',
  markup: [
    {
      tagName: 'rect',
      selector: 'body'
    },
    {
      tagName: 'image',
      selector: 'image'
    },
    {
      tagName: 'text',
      selector: 'text'
    },
    {
      tagName: 'g',
      selector: 'buttonGroup',
      children: [
        {
          tagName: 'rect',
          selector: 'button',
          attrs: {
            'pointer-events': 'visiblePainted'
          }
        },
        {
          tagName: 'path',
          selector: 'buttonSign',
          attrs: {
            fill: 'none',
            'pointer-events': 'none'
          }
        }
      ]
    }
  ],
  attrs: {
    body: {
      refWidth: '100%',
      refHeight: '100%',
      strokeWidth: 1,
      fill: 'rgba(95,149,255,0.05)',
      stroke: '#5F95FF'
    },
    image: {
      'xlink:href':
        'https://gw.alipayobjects.com/mdn/rms_0b51a4/afts/img/A*X4e0TrDsEiIAAAAAAAAAAAAAARQnAQ',
      width: 16,
      height: 16,
      x: 8,
      y: 12
    },
    text: {
      fontSize: 12,
      fill: 'rgba(0,0,0,0.85)',
      refX: 30,
      refY: 15
    },
    buttonGroup: {
      refX: '100%',
      refX2: -25,
      refY: 13
    },
    button: {
      height: 14,
      width: 16,
      rx: 2,
      ry: 2,
      fill: '#f5f5f5',
      stroke: '#ccc',
      cursor: 'pointer',
      event: 'node:collapse'
    },
    buttonSign: {
      refX: 3,
      refY: 2,
      stroke: '#808080'
    }
  }
})

Graph.registerNode('groupNode', NodeGroup)