Spaces:
Running
Running
/* Copyright 2020 Google LLC. All Rights Reserved. | |
Licensed under the Apache License, Version 2.0 (the "License"); | |
you may not use this file except in compliance with the License. | |
You may obtain a copy of the License at | |
http://www.apache.org/licenses/LICENSE-2.0 | |
Unless required by applicable law or agreed to in writing, software | |
distributed under the License is distributed on an "AS IS" BASIS, | |
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
See the License for the specific language governing permissions and | |
limitations under the License. | |
==============================================================================*/ | |
var annotations = | |
[ | |
] | |
function addSwoop(c){ | |
var swoopy = d3.swoopyDrag() | |
.x(d => c.x(d.x)) | |
.y(d => c.y(d.y)) | |
.draggable(0) | |
.annotations(annotations) | |
var swoopySel = c.svg.append('g.annotations').call(swoopy) | |
c.svg.append('marker#arrow') | |
.attr('viewBox', '-10 -10 20 20') | |
.attr('markerWidth', 20) | |
.attr('markerHeight', 20) | |
.attr('orient', 'auto') | |
.append('path').at({d: 'M-6.75,-6.75 L 0,0 L -6.75,6.75'}) | |
swoopySel.selectAll('path').attr('marker-end', 'url(#arrow)') | |
window.annotationSel = swoopySel.selectAll('g') | |
.st({fontSize: 12, opacity: d => d.slide == 0 ? 1 : 0}) | |
swoopySel.selectAll('text') | |
.each(function(d){ | |
d3.select(this) | |
.text('') //clear existing text | |
.tspans(d3.wordwrap(d.text, d.width || 20), 12) //wrap after 20 char | |
}) | |
} | |