You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. var fs = require("fs"),
  2. path = require("path");
  3. function htmlspecialchars(str) {
  4. //Hum, hum... Could do better
  5. if (typeof str !== "string") return "";
  6. return str.replace(/&/g, "&")
  7. .replace(/</g, "&lt;")
  8. .replace(/>/g, "&gt;")
  9. .replace(/"/g, "&quot;")
  10. .replace(/'/g, "&#039;");
  11. }
  12. function renderPath(el, pathstring) {
  13. return '<path ' +
  14. 'id="' + htmlspecialchars(el.id || "l") + '" ' +
  15. 'stroke-width="' + (el.size | 0) + '" ' +
  16. 'stroke="' + htmlspecialchars(el.color || "#000") + '" ' +
  17. 'd="' + pathstring + '" ' +
  18. '/>';
  19. }
  20. var Tools = {
  21. "Text": function (el) {
  22. return '<text ' +
  23. 'id="' + htmlspecialchars(el.id || "t") + '" ' +
  24. 'x="' + (el.x | 0) + '" ' +
  25. 'y="' + (el.y | 0) + '" ' +
  26. 'font-size="' + (el.size | 0) + '" ' +
  27. 'fill="' + htmlspecialchars(el.color || "#000") + '" ' +
  28. '>' + htmlspecialchars(el.txt || "") + '</text>';
  29. },
  30. "Pencil": function (el) {
  31. if (!el._children) return "";
  32. switch (el._children.length) {
  33. case 0: return "";
  34. case 1:
  35. var pathstring = "M" + el._children[0].x + " " + el._children[0].y +
  36. "L" + el._children[0].x + " " + el._children[0].y;
  37. break;
  38. default:
  39. var pathstring = "M" + el._children[0].x + " " + el._children[0].y + "L";
  40. for (var i = 1; i < el._children.length; i++) {
  41. pathstring += (+el._children[i].x) + " " + (+el._children[i].y) + " ";
  42. }
  43. }
  44. return renderPath(el, pathstring);
  45. },
  46. "Rectangle": function (el) {
  47. var pathstring =
  48. "M" + el.x + " " + el.y +
  49. "L" + el.x + " " + el.y2 +
  50. "L" + el.x2 + " " + el.y2 +
  51. "L" + el.x2 + " " + el.y +
  52. "L" + el.x + " " + el.y;
  53. return renderPath(el, pathstring);
  54. },
  55. "Straight line": function (el) {
  56. var pathstring = "M" + el.x + " " + el.y + "L" + el.x2 + " " + el.y2;
  57. return renderPath(el, pathstring);
  58. }
  59. };
  60. function toSVG(obj) {
  61. var margin = 500, maxelems = 1e4;
  62. var elements = "", i = 0, w = 500, h = 500;
  63. var t = Date.now();
  64. var elems = Object.values(obj);
  65. while (elems.length > 0) {
  66. if (++i > maxelems) break;
  67. var elem = elems.pop();
  68. elems = elems.concat(elem._children || []);
  69. if (elem.x && elem.x + margin > w) w = elem.x + margin;
  70. if (elem.y && elem.y + margin > h) h = elem.y + margin;
  71. var renderFun = Tools[elem.tool];
  72. if (renderFun) elements += renderFun(elem);
  73. }
  74. console.error(i + " elements treated in " + (Date.now() - t) + "ms.");
  75. var svg = '<svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="' + w + '" height="' + h + '">' +
  76. '<defs><style type="text/css"><![CDATA[' +
  77. 'text {font-family:"Arial"}' +
  78. 'path {fill:none;stroke-linecap:round;stroke-linejoin:round;}' +
  79. ']]></style></defs>' +
  80. elements +
  81. '</svg>';
  82. return svg;
  83. }
  84. function renderBoard(file, callback) {
  85. var t = Date.now();
  86. fs.readFile(file, function (err, data) {
  87. if (err) return callback(err);
  88. try {
  89. var board = JSON.parse(data);
  90. console.warn("JSON parsed in " + (Date.now() - t) + "ms.");
  91. var svg = toSVG(board);
  92. console.warn("Board rendered in " + (Date.now() - t) + "ms.");
  93. callback(null, svg);
  94. }
  95. catch (err) { return callback(err) }
  96. });
  97. }
  98. if (require.main === module) {
  99. const config = require("./configuration.js")
  100. var HISTORY_FILE = process.argv[2] || path.join(config.HISTORY_DIR, "board-anonymous.json");
  101. renderBoard(HISTORY_FILE, function (err, rendered) {
  102. console.log(rendered);
  103. });
  104. } else {
  105. module.exports = { 'renderBoard': renderBoard };
  106. }