<!-- Code adapted from d3-graph-gallery.com, https://observablehq.com/@d3/radial-dendrogram
     as well as from Wan et al. 2020 Neural backed decision trees github repo at 
     https://github.com/alvinwan/neural-backed-decision-trees
     and from https://bl.ocks.org/d3noob/8375092
-->
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>Tree Example</title>
  <style>
.node {
  cursor: pointer;
}

.node circle {
  fill: #fff;
  stroke: steelblue;
  stroke-width: 3px;
}

.node text {
  font: 12px sans-serif;
}

.link {
  fill: none;
  stroke: #ccc;
  stroke-width: 2px;
}
  </style>
</head>
<body>
<!-- Create a div where the graph will take place -->
  <div class="tree-main">
  </div>

</body>

<!-- Load d3.js -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.5.17/d3.min.js"></script>

<!-- Create tree -->
<script>

window.d3_onload_run = false;

var margin = {
        top: 50 * 1,
        right: 120 * 1,
        bottom: 10 * 1,
        left: 100 * 1
    },
    textsize=50,
	width = 750 - margin.right - margin.left,
	height = 400 - textsize - margin.top - margin.bottom;

var i = 0,
	duration = 750,
	root;

var tree = d3.layout.tree().size([height, width]);
var zoom = d3.behavior.zoom()
    .translate([margin.left, margin.top])
    .scale(1);

//var diagonal = d3.svg.diagonal()
//	.projection(function(d) { return [d.y, d.x]; });

// append the svg object to the body of the page
var svg = d3.select("div.tree-main").append("svg")
    .attr("width", width + margin.right + margin.left)
    .attr("height", height + textsize + margin.top + margin.bottom)
  .style("font-size", 10)
  .append("g")
    .attr("transform", "translate(" + margin.left + "," + margin.top + ")")
  .call(zoom)
  .on(".zoom", null);

var diagonal = d3.svg.diagonal()
	.projection(function(d) { return [d.y, d.x]; });

//d3.json("https://raw.githubusercontent.com/holtzy/D3-graph-gallery/master/DATA/data_dendrogram.json", function(data) {
var treeData = [{"name": "vertebrate", "children": [{"name": "bird", "children": [{"name": "brambling", "colname": "level2", "ood": false, "pred": false, "gt": false}, {"name": "goldfinch", "colname": "level2", "ood": false, "pred": false, "gt": true}, {"name": "house finch", "colname": "level2", "ood": false, "pred": false, "gt": false}, {"name": "junco", "colname": "level2", "ood": true, "pred": false, "gt": false}, {"name": "indigo bunting", "colname": "level2", "ood": false, "pred": false, "gt": false}], "colname": "level1", "ood": false, "pred": true, "gt": false}, {"name": "fish", "children": [{"name": "anemone fish", "colname": "level2", "ood": false, "pred": false, "gt": false}, {"name": "sturgeon", "colname": "level2", "ood": false, "pred": false, "gt": false}, {"name": "gar", "colname": "level2", "ood": false, "pred": false, "gt": false}, {"name": "lionfish", "colname": "level2", "ood": false, "pred": false, "gt": false}, {"name": "puffer", "colname": "level2", "ood": false, "pred": false, "gt": false}], "colname": "level1", "ood": false, "pred": false, "gt": false}], "colname": "level0", "ood": false, "pred": false, "gt": false, "image": {"href": "data:image/jpeg;base64,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", "width": 140.625, "height": 187.5}}];

var tree = d3.layout.tree()
	.size([height, width]);

root = treeData[0];
root.x0 = height / 2;
root.y0 = 0;
  
update(root);


svg.append('line')
    .style("stroke", "black")
    .style("stroke-width", 5)
    .attr("x1", -50)
    .attr("y1", height)
    .attr("x2", width)
    .attr("y2", height); 
svg.append('text')
    .attr("x", 0)
    .attr("y", height+20)
    .attr("dy", ".35em")
    .text("Prediction:")
    .style("fill", "purple")
    .style("font-size", "0.9em")
    .style("font-family", "Montserrat-Regular");
svg.append('text')
    .attr("x", -26)
    .attr("y", height+40)
    .attr("dy", ".35em")
    .text("Hierarchy Dist:")
    .style("fill", "purple")
    .style("font-size", "0.9em")
    .style("font-family", "Montserrat-Regular");
svg.append('text')
    .attr("x", 100)
    .attr("y", height+20)
    .attr("dy", ".35em")
    .text("bird")
    .style("font-size", "0.9em")
    .style("font-family", "Montserrat-Regular");
    //.style("font-size", 10);
svg.append('text')
    .attr("x", 100)
    .attr("y", height+40)
    .attr("dy", ".35em")
    .text("0")
    .style("font-size", "0.9em")
    .style("font-family", "Montserrat-Regular");
    //.style("font-size", 10);
svg.append('text')
    .attr("x", 250)
    .attr("y", height+20)
    .attr("dy", ".35em")
    .text("Groundtruth:")
    .style("fill", "green")
    .style("font-size", "0.9em")
    .style("font-family", "Montserrat-Regular");
svg.append('text')
    .attr("x", 239)
    .attr("y", height+40)
    .attr("dy", ".35em")
    .text("Hierarchy Dist:")
    .style("fill", "green")
    .style("font-size", "0.9em")
    .style("font-family", "Montserrat-Regular");
svg.append('text')
    .attr("x", 350)
    .attr("y", height+20)
    .attr("dy", ".35em")
    .text("goldfinch")
    .style("font-size", "0.9em")
    .style("font-family", "Montserrat-Regular");
    //.style("font-size", 10);
svg.append('text')
    .attr("x", 350)
    .attr("y", height+40)
    .attr("dy", ".35em")
    .text("1")
    .style("font-size", "0.9em")
    .style("font-family", "Montserrat-Regular");
    //.style("font-size", 10);

d3.select(self.frameElement).style("height", "500px");

function update(source) {

  // Compute the new tree layout.
  var nodes = tree.nodes(root).reverse(),
	  links = tree.links(nodes);

  // Normalize for fixed-depth.
  nodes.forEach(function(d) { d.y = 200 + d.depth * 100; });

  // Update the nodes…
  var node = svg.selectAll("g.node")
	  .data(nodes, function(d) { return d.id || (d.id = ++i); });

  // Enter any new nodes at the parent's previous position.
  var nodeEnter = node.enter().append("g")
	  .attr("class", "node")
	  .attr("transform", function(d) { return "translate(" + source.y0 + "," + source.x0 + ")"; })
	  .on("click", click);



  nodeEnter.append("circle")
	  .attr("r", 2.5)
    .style("stroke", function(d) {
        if (d._children) return "#555";
        return "#999";
      })
	  .style("fill", function(d) {
          if (d._children) return "#555";
          return "#999";
      });

  nodeEnter.append("text")
	  .attr("x", function(d) { return d.children || d._children ? -13 : 13; })
	  .attr("dy", ".35em")
	  .attr("text-anchor", function(d) { return d.children || d._children ? "end" : "start"; })
	  .text(function(d) { return d.name; })
	  .style("fill-opacity", 1e-6);

  // Handle image 
  nodeEnter.append("svg:image")
    .attr("xlink:href", function(d) { return d.image ? d.image.href : '' })
    .attr("x", -225)
    .attr("y", function(d) { return d.image ? -d.image.height/ 2 : 0 })
    .attr("height", function(d) { return d.image ? d.image.height : 0 })
    .attr("width", function(d) { return d.image ? d.image.width : 0 })

  nodeEnter.append("text")
    .attr("x", function(d) {return d.image ? -185 : 0})
    .attr("y", function(d) { return d.image ? -d.image.height+110 : 0 })
	  .attr("dy", ".35em")
    .text(function(d) {return d.image ? "Goldfinch" : ""})
    .style("font-size", "0.9em")
    .style("font-family", "Montserrat-Regular");

  // Transition nodes to their new position.
  var nodeUpdate = node.transition()
	  .duration(duration)
	  .attr("transform", function(d) { return "translate(" + d.y + "," + d.x + ")"; });

  nodeUpdate.select("circle")
    .attr("r", function(d) {
        if (d.pred || d.gt) return 6;
        return 2.5;
      })
    .style("stroke", function(d) {
        if (d.pred) return "purple"
        if (d.gt) return "green"
        if (d._children) return "#555";
        return "#999";
       })
    .style("fill", function(d) {
        if (d.pred) return "purple"
        if (d.gt) return "green"
        if (d._children) return "#555";
        return "#999";
      });

  nodeUpdate.select("text")
	  .style("fill-opacity", 1);

  // Transition exiting nodes to the parent's new position.
  var nodeExit = node.exit().transition()
	  .duration(duration)
	  .attr("transform", function(d) { return "translate(" + source.y + "," + source.x + ")"; })
	  .remove();

  nodeExit.select("circle")
	  .attr("r", 1e-6);

  nodeExit.select("text")
	  .style("fill-opacity", 1e-6);

  // Update the links…
  var link = svg.selectAll("path.link")
	  .data(links, function(d) { return d.target.id; });

  // Enter any new links at the parent's previous position.
  link.enter().insert("path", "g")
	  .attr("class", "link")
    .style("stroke", function(d) {
      if (d.target.ood) return "red";
      return "steelblue";
      })
    .style("stroke-opacity", function(d) {
        if (d.target.ood) return 0.8;
        return 0.8;
      })
    .style("stroke-width", function(d) {
        if (d.target.ood) return 2;
        return 2;
      })
	  .attr("d", function(d) {
		var o = {x: source.x0, y: source.y0};
		return diagonal({source: o, target: o});
	  });

  // Transition links to their new position.
  link.transition()
	  .duration(duration)
	  .attr("d", diagonal);

  // Transition exiting nodes to the parent's new position.
  link.exit().transition()
	  .duration(duration)
	  .attr("d", function(d) {
		var o = {x: source.x, y: source.y};
		return diagonal({source: o, target: o});
	  })
	  .remove();

  // Stash the old positions for transition.
  nodes.forEach(function(d) {
	d.x0 = d.x;
	d.y0 = d.y;
  });
  nodeEnter.selectAll("text")
   .style("font-size", "0.9em")
   .style("font-family", "Montserrat-Regular")

  d3_onload();
}

// Toggle children on click.
function click(d) {
  if (d.children) {
	d._children = d.children;
	d.children = null;
  } else {
	d.children = d._children;
	d._children = null;
  }
  update(d);
}

function d3_onload() {
  if (window.d3_onload_run) return;
  window.d3_onload_run = true;
  setTimeout(function() {
    var hide = false;
    for (var i = 0; i < hide.length; i++) {
        document.getElementById(hide[i]).dispatchEvent(new Event('click'))
    }

    if (true) {
      setTimeout(print, 1000);
    }

  }, 1000);
}
window.onload =d3_onload;

function saveImage() {
  //get svg element.
  var svg = document.getElementById("svg");

  //get svg source.
  var serializer = new XMLSerializer();
  var source = serializer.serializeToString(svg);

  //add name spaces.
  if(!source.match(/^<svg[^>]+xmlns="http\:\/\/www\.w3\.org\/2000\/svg"/)){
      source = source.replace(/^<svg/, '<svg xmlns="http://www.w3.org/2000/svg"');
  }
  if(!source.match(/^<svg[^>]+"http\:\/\/www\.w3\.org\/1999\/xlink"/)){
      source = source.replace(/^<svg/, '<svg xmlns:xlink="http://www.w3.org/1999/xlink"');
  }

  //add xml declaration
  source = '<?xml version="1.0" standalone="no"?>\r\n' + source;

  //convert svg source to URI data scheme.
  var url = "data:image/svg+xml;charset=utf-8,"+encodeURIComponent(source);

  //set url value to a element's href attribute.
  document.getElementById("link").href = url;
  //you can download svg file by right click menu.
  // var doctype = '<?xml version="1.0" standalone="no"?>'
  // + '<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">';

  // // serialize our SVG XML to a string.
  // var source = (new XMLSerializer()).serializeToString(d3.select('svg').node());

  // // create a file blob of our SVG.
  // var blob = new Blob([ doctype + source], { type: 'image/svg+xml;charset=utf-8' });

  // var url = window.URL.createObjectURL(blob);

  // // Put the svg into an image tag so that the Canvas element can read it in.
  // var img = d3.select('body').append('img')
  //  .attr('width', 100)
  //  .attr('height', 100)
  //  .node();


  // img.onload = function(){
  //   // Now that the image has loaded, put the image into a canvas element.
  //   var canvas = d3.select('body').append('canvas').node();
  //   canvas.width = width;
  //   canvas.height = height;
  //   var ctx = canvas.getContext('2d');
  //   ctx.drawImage(img, 0, 0);
  //   var canvasUrl = canvas.toDataURL("image/png");
  //   var img2 = d3.select('body').append('img')
  //     .attr('width', width)
  //     .attr('height', height)
  //     .node();
  //   // this is now the base54 encoded version of our PNG! you could optionally
  //   // redirect the user to download the PNG by sending them to the url with
  //   // `window.location.href= canvasUrl`.
  //   img2.src = canvasUrl;
  // }
  // // start loading the image.
  // img.src = url;
}

window.onload = function() {
  setTimeout(saveImage, 5000);
}

</script>
