in toolkit/jb/svg.js [31:58]
first: function(bodyElm) {
var hiddenLink = d3.select(document.createElement('a'))
.attr('download', 'jetbrains-art.png');
var saveButton =
d3.select(bodyElm).append('text')
.style('font-size', '24px')
.style('text-anchor', 'middle')
.text('💾');
Kefir.fromEvents(saveButton.node(), 'mousemove').onValue(function() {
saveButton.style('font-size', '27px');
});
Kefir.fromEvents(saveButton.node(), 'mouseout').onValue(function() {
saveButton.style('font-size', '24px');
});
Kefir.fromEvents(saveButton.node(), 'click').onValue(function() {
var canvas = d3.select('#rpd-jb-preview-target .sketch-canvas').node();
if (!canvas) return;
//hiddenLink.attr('href', canvas.toDataURL('image/png'));
var blob = canvas.toBlob(function(blob) {
var url = URL.createObjectURL(blob);
hiddenLink.attr('href', url);
hiddenLink.node().click();
//URL.revokeObjectURL(url);
});
});
}