echarts树图实现的组织架构

img

demo: https://d9yb5o.csb.app/

import React, { useEffect, useRef, useState } from "react";
import { treeData, orgLogo } from "./mockdata";
import * as echarts from "echarts";

const WinnerHeight = window.innerHeight;

export default function App() {
  const [treeHeight, setTreeHeight] = useState(WinnerHeight);
  let myChart = null;
  const chart = useRef();

  const formatData = (it, index) => {
    const newObj = { ...it };
    const { title: name, key = 0 } = newObj;
    if (index <= 1) {
      Object.assign(newObj, {
        label: {
          height: 40,
          verticalAlign: "middle",
          align: index === 0 ? "left" : "center",
          color: "#fff",
          formatter: () => `{logo|}{name|${name}(${key})}`,
          backgroundColor: "rgba(79,125,217,1)",
          borderRadius: [20, 5, 5, 20],
          rich: {
            logo: {
              backgroundColor: {
                image: orgLogo
              },
              width: 40,
              height: 40
            },
            name: {
              height: 40,
              color: "#FFF",
              padding: [0, 10],
              align: "center",
              fontSize: 16,
              borderRadius: [5]
            }
          }
        },
        emphasis: {
          label: {
            height: 40,
            verticalAlign: "middle",
            align: index === 0 ? "left" : "center",
            color: "#fff",
            formatter: () => `{logo|}{name|${name}(${key})}`,
            backgroundColor: "rgba(62,101,226,1)",
            borderRadius: [20, 5, 5, 20],
            rich: {
              logo: {
                backgroundColor: {
                  image: orgLogo
                },
                width: 40,
                height: 40
              },
              name: {
                height: 40,
                color: "#FFF",
                padding: [0, 10],
                align: "center",
                fontSize: 16,
                borderRadius: [5]
              }
            }
          }
        }
      });
    }

    if (index > 1) {
      Object.assign(newObj, {
        label: {
          height: 30,
          verticalAlign: "middle",
          align: "center",
          color: "#fff",
          backgroundColor: "rgba(62,101,226,1)",
          borderRadius: [5],
          formatter: () => `{name|${name}(${key})}`,
          rich: {
            name: {
              height: 30,
              color: "#FFF",
              padding: [0, 10],
              align: "center",
              fontSize: 12
            }
          }
        },
        emphasis: {
          label: {
            backgroundColor: "rgba(62,101,226,1)"
          }
        }
      });
    }

    if (newObj.children) {
      const newChildren = [];
      const sourceChildren = [...newObj.children];
      sourceChildren.forEach((el) => {
        newChildren.push(formatData(el, index + 1));
      });
      newObj.children = newChildren;
    }
    return newObj;
  };

  const getTreeLeafnode = (it) => {
    const leafnode = [];
    const getChildren = (children) => {
      if (children && children.children && children.children.length) {
        children.children.forEach((el) => {
          getChildren(el);
        });
      } else {
        leafnode.push(children);
      }
    };

    getChildren(it);
    return leafnode.length;
  };
  const drawSaveTrend = () => {
    myChart.clear();
    const res = treeData.map((el) => formatData(el, 0));
    const leafnode = getTreeLeafnode(treeData[0]);
    const option = {
      series: [
        {
          type: "tree",
          orient: "horizontal",
          name: "机构",
          edgeShape: "polyline",
          data: res,
          top: 20,
          bottom: 20,
          left: 20,
          lineStyle: {
            color: "rgba(207,5,183,1)",
            width: 3
          },
          expandAndCollapse: true,
          animationDuration: 550,
          animationDurationUpdate: 750
        }
      ]
    };
    myChart.setOption(option);
    const newTreeHeight =
      leafnode * 35 > WinnerHeight ? leafnode * 35 : WinnerHeight;
    setTreeHeight(newTreeHeight);
    myChart.resize({ height: newTreeHeight });
  };

  const resize = () => {
    myChart?.resize();
  };
  useEffect(() => {}, []);

  useEffect(() => {
    window.addEventListener("resize", () => resize());
    if (chart.current) {
      echarts.dispose(chart.current);
    }
    myChart = echarts.init(chart.current);
    drawSaveTrend();
  }, []);

  return (
    <div
      ref={chart}
      style={{
        width: "100%",
        height: treeHeight
      }}
    />
  );
}


数据文件mockdata

const treeData = [
  {
    title: "0-0",
    key: "0-0",
    children: [
      {
        title: "0-0-0",
        key: "0-0-0",
        children: [
          {
            title: "0-0-0-0",
            key: "0-0-0-0"
          },
          {
            title: "0-0-0-1",
            key: "0-0-0-1"
          },
          {
            title: "0-0-0-2",
            key: "0-0-0-2"
          }
        ]
      },
      {
        title: "0-0-1",
        key: "0-0-1",
        children: [
          {
            title: "0-0-1-0",
            key: "0-0-1-0"
          },
          {
            title: "0-0-1-1",
            key: "0-0-1-1"
          },
          {
            title: "0-0-1-2",
            key: "0-0-1-2"
          }
        ]
      },
      {
        title: "0-0-2",
        key: "0-0-2"
      }
    ]
  },
  {
    title: "0-1",
    key: "0-1",
    children: [
      {
        title: "0-1-0-0",
        key: "0-1-0-0"
      },
      {
        title: "0-1-0-1",
        key: "0-1-0-1"
      },
      {
        title: "0-1-0-2",
        key: "0-1-0-2"
      }
    ]
  },
  {
    title: "0-2",
    key: "0-2"
  }
];

const orgLogo =
  "";

export { orgLogo, treeData };

// 图片转为Base64格式
// const image2Base64 = img => {
//   const canvas = document.createElement('canvas')
//   canvas.width = img.width
//   canvas.height = img.height
//   const ctx = canvas.getContext('2d')
//   ctx.drawImage(img, 0, 0, img.width, img.height)
//   const dataURL = canvas.toDataURL('image/png')
//   return dataURL
// }

// const img = new Image()
// img.src = 图片来源
// const imgdata = image2Base64(img)
posted @ 2022-10-28 09:49  VictoriaC~  阅读(502)  评论(0编辑  收藏  举报