UNPKG

drawdown-svg-render

Version:
369 lines (321 loc) 41.6 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); exports.tailGenerator = tailGenerator; exports.simpleRightHead = simpleRightHead; exports.simpleLeftHead = simpleLeftHead; exports.leftHead = leftHead; exports.rightHead = rightHead; function tailGenerator(style, opts) { switch (style) { case '-': case 'STRAIGHT': return straightTail; case '~': case 'CURVED': return curvedTail; case 'MESSAGE': return function (d) { return messageTail(d, opts); }; case 'LINE': return lineTail; default: throw 'Unknown link style "' + style + '"'; } } var _180OVER_PI = 180 / Math.PI; function lineTail(d) { var sl = d.source.layout; var tl = d.target.layout; d.pathMeta = { start: { x: sl.pos.x, y: sl.pos.y }, end: { x: tl.pos.x, y: tl.pos.y }, dir: 'E' }; var start = d.pathMeta.start; var end = d.pathMeta.end; var angle = Math.atan2(end.y - start.y, end.x - start.x) * _180OVER_PI; var length = Math.sqrt((end.x - start.x) * (end.x - start.x) + (end.y - start.y) * (end.y - start.y)); d.pathMeta.length = length; d.pathMeta.transform = 'translate(' + start.x + ' ' + start.y + ') rotate(' + angle + ')'; d.textMeta = { pos: { x: start.x + length / 2, y: start.y }, baseLine: 'text-after-edge', textAnchor: 'start' }; return 'M' + 0 + ' ' + 0 + 'L' + length + ' ' + 0; } function messageTail(d, opts) { var yOffset = opts.yStart + opts.ySeparation * d.index; var sl = d.source.layout; var tl = d.target.layout; if (d.source == d.target) { d.pathMeta = { start: { x: sl.pos.x, y: yOffset - opts.ySeparation }, end: { x: sl.pos.x, y: yOffset }, dir: 'W' }; var start = d.pathMeta.start; d.textMeta = { pos: { x: start.x + opts.ySeparation * 0.8, y: start.y + opts.ySeparation / 2 }, baseLine: 'text-after-edge', textAnchor: 'start' }; return 'M' + start.x + ' ' + start.y + '\n C ' + (start.x + opts.ySeparation) + ' ' + start.y + '\n ' + (start.x + opts.ySeparation) + ' ' + (start.y + opts.ySeparation) + '\n ' + start.x + ' ' + (start.y + opts.ySeparation); } else { d.pathMeta = { start: { x: sl.pos.x, y: yOffset }, end: { x: tl.pos.x, y: yOffset }, dir: tl.pos.x > sl.pos.x ? 'E' : 'W' }; d.textMeta = { pos: { x: d.pathMeta.start.x + (d.pathMeta.end.x - d.pathMeta.start.x) / 2, y: yOffset - 5 }, baseLine: 'text-after-edge', textAnchor: 'middle' }; return 'M' + d.source.layout.pos.x + ' ' + yOffset + ' H ' + d.target.layout.pos.x; } } function straightTail(d) { var _tail = tail(d, true), _tail2 = _slicedToArray(_tail, 2), pathMeta = _tail2[0], script = _tail2[1]; d.pathMeta = pathMeta; return script; } function curvedTail(d) { var _tail3 = tail(d, false), _tail4 = _slicedToArray(_tail3, 2), pathMeta = _tail4[0], script = _tail4[1]; d.pathMeta = pathMeta; return script; } function tail(d, isStraight) { var sl = d.source.layout; var tl = d.target.layout; var dir = d.source.id == d.target.id ? 'SELF' : getApparentDir(sl, tl); var start = { x: 0, y: 0 }; var end = { x: 0, y: 0 }; var middle = 0; var script = ''; switch (true) { case ['NNE', 'SSE', 'SSW', 'NNW'].indexOf(dir) >= 0: start.x = sl.pos.x + sl.bbw / 2; start.y = sl.pos.y; end.x = tl.pos.x; end.y = tl.pos.y + tl.bbh / 2; if (['NNW', 'SSW'].indexOf(dir) >= 0) { start.x = sl.pos.x - sl.bbw / 2; } if (['SSE', 'SSW'].indexOf(dir) >= 0) { end.y = tl.pos.y - tl.bbh / 2; } if (isStraight) { script = 'M' + start.x + ' ' + start.y + ' H' + end.x + ' V' + end.y; } else { script = 'M' + start.x + ' ' + start.y + ' Q' + end.x + ' ' + start.y + ' ' + end.x + ' ' + end.y; } break; case ['ENE', 'ESE', 'WNW', 'WSW'].indexOf(dir) >= 0: start.x = sl.pos.x; start.y = sl.pos.y - sl.bbh / 2; end.x = tl.pos.x - tl.bbw / 2; end.y = tl.pos.y; if (['ESE', 'WSW'].indexOf(dir) >= 0) { start.y = sl.pos.y + sl.bbh / 2; } if (['WNW', 'WSW'].indexOf(dir) >= 0) { end.x = tl.pos.x + tl.bbw / 2; } if (isStraight) { script = 'M' + start.x + ' ' + start.y + 'V' + end.y + 'H' + end.x; } else { script = 'M' + start.x + ' ' + start.y + 'Q' + start.x + ' ' + end.y + ' ' + end.x + ' ' + end.y; } break; case ['E', 'W'].indexOf(dir) >= 0: start.x = sl.pos.x + sl.bbw / 2; start.y = sl.pos.y; end.x = tl.pos.x - tl.bbw / 2; end.y = tl.pos.y; if (dir == 'W') { start.x = sl.pos.x - sl.bbw / 2; end.x = tl.pos.x + tl.bbw / 2; } middle = start.x + (end.x - start.x) / 2; if (isStraight) { script = 'M' + start.x + ' ' + start.y + 'H' + middle + 'V' + end.y + 'H' + end.x; } else { script = 'M' + start.x + ' ' + start.y + 'C' + middle + ' ' + start.y + ' ' + middle + ' ' + end.y + ' ' + end.x + ' ' + end.y; } break; case ['N', 'S'].indexOf(dir) >= 0: start.x = sl.pos.x; start.y = sl.pos.y - sl.bbh / 2; end.x = tl.pos.x; end.y = tl.pos.y + tl.bbh / 2; if (dir == 'S') { start.y = sl.pos.y + sl.bbh / 2; end.y = tl.pos.y - tl.bbh / 2; } middle = start.y + (end.y - start.y) / 2; if (isStraight) { script = 'M' + start.x + ' ' + start.y + 'V' + middle + 'H' + end.x + 'V' + end.y; } else { script = 'M' + start.x + ' ' + start.y + 'C' + start.x + ' ' + middle + ' ' + end.x + ' ' + middle + ' ' + end.x + ' ' + end.y; } break; case 'SELF' == dir: start.x = sl.pos.x; start.y = sl.pos.y - sl.bbh / 2; end.x = sl.pos.x + sl.bbw / 2; end.y = sl.pos.y; var r = Math.sqrt(sl.bbw * sl.bbw + sl.bbh * sl.bbh) / 4; if (isStraight) { script = 'M' + start.x + ' ' + start.y + 'V' + (start.y - r) + 'H' + (end.x + r) + 'V' + end.y + 'H' + end.x; } else { script = 'M' + start.x + ' ' + start.y + 'C ' + (start.x + r) + ' ' + (start.y - 3 * r) + ' ' + (end.x + 3 * r) + ' ' + end.y + ' ' + end.x + ' ' + end.y; } break; } return [{ start: start, end: end, dir: dir }, script]; return script; } function simpleRightHead(d) { return simpleHead(d, true); } function simpleLeftHead(d) { return simpleHead(d, true); } function simpleHead(d, isRight) { if (!d.pathMeta) { return; } var w = 14; var h = 8; var bbw = d.source.layout.bbw; var length = d.pathMeta.length; if (isRight) { return 'M' + (length - bbw / 2) + ' 0l' + -w + ' ' + -h / 2 + 'v' + h + 'Z'; } else { return 'M' + bbw / 2 + ' 0l' + w + ' ' + -h / 2 + 'v' + h + 'Z'; } } function leftHead(d) { return head(d, false); } function rightHead(d) { return head(d, true); } function head(d, isRight) { if (!d.pathMeta) { return; } var end = void 0; if (isRight) { end = d.pathMeta.end; } else { end = d.pathMeta.start; } var dir = d.pathMeta.dir; var w = 14; var h = 8; var directions = void 0; if (isRight) { directions = { easts: ['ENE', 'E', 'ESE'], wests: ['WNW', 'W', 'WSW', "SELF"], norts: ['NNW', 'N', 'NNE'], souths: ['SSW', 'S', 'SSE'] }; } else { directions = { easts: ['NNW', 'W', 'SSW'], wests: ['NNE', 'E', 'SSE'], norts: ['WSW', 'S', 'ESE'], souths: ['WNW', 'N', 'ENE', "SELF"] }; } switch (true) { case directions.easts.indexOf(dir) >= 0: return 'M' + end.x + ' ' + end.y + 'L' + (end.x - w) + ' ' + (end.y - h / 2) + 'V' + (end.y + h / 2) + 'Z'; case directions.wests.indexOf(dir) >= 0: return 'M' + end.x + ' ' + end.y + 'L' + (end.x + w) + ' ' + (end.y - h / 2) + 'V' + (end.y + h / 2) + 'Z'; case directions.norts.indexOf(dir) >= 0: return 'M' + end.x + ' ' + end.y + 'L' + (end.x - h / 2) + ' ' + (end.y + w) + 'H' + (end.x + h / 2) + 'Z'; case directions.souths.indexOf(dir) >= 0: return 'M' + end.x + ' ' + end.y + 'L' + (end.x - h / 2) + ' ' + (end.y - w) + 'H' + (end.x + h / 2) + 'Z'; } } function getApparentDir(sl, tl) { var vDir = 'SAME'; var hDir = 'SAME'; var dir = '?'; if (tl.pos.y + tl.bbh / 2 < sl.pos.y - sl.bbh / 2) { vDir = 'TOP'; } else if (tl.pos.y - tl.bbh / 2 > sl.pos.y + sl.bbh / 2) { vDir = 'BOTTOM'; } if (tl.pos.x + tl.bbw / 2 < sl.pos.x - sl.bbw / 2) { hDir = 'LEFT'; } else if (sl.pos.x + sl.bbw / 2 < tl.pos.x - tl.bbw / 2) { hDir = 'RIGHT'; } switch (true) { case hDir == 'SAME' && vDir == 'TOP': dir = 'N'; break; case hDir == 'SAME' && vDir == 'BOTTOM': dir = 'S'; break; case hDir == 'RIGHT' && vDir == 'SAME': dir = 'E'; break; case hDir == 'LEFT' && vDir == 'SAME': dir = 'W'; break; case hDir == 'RIGHT' && vDir == 'TOP': dir = 'NE'; if (tl.pos.x - tl.bbw / 2 - sl.pos.x - sl.bbw / 2 > sl.pos.y - sl.bbh / 2 - tl.pos.y - tl.bbh / 2) { dir = 'ENE'; } else { dir = 'NNE'; } break; case hDir == 'RIGHT' && vDir == 'BOTTOM': dir = 'SE'; if (tl.pos.x - tl.bbw / 2 - sl.pos.x - sl.bbw / 2 > tl.pos.y - tl.bbh / 2 - sl.pos.y - sl.bbh / 2) { dir = 'ESE'; } else { dir = 'SSE'; } break; case hDir == 'LEFT' && vDir == 'TOP': dir = 'NW'; if (sl.pos.x - sl.bbw / 2 - tl.pos.x - tl.bbw / 2 > sl.pos.y - sl.bbh / 2 - tl.pos.y - tl.bbh / 2) { dir = 'WNW'; } else { dir = 'NNW'; } break; case hDir == 'LEFT' && vDir == 'BOTTOM': dir = 'SW'; if (sl.pos.x - sl.bbw / 2 - tl.pos.x - tl.bbw / 2 > tl.pos.y - tl.bbh / 2 - sl.pos.y - sl.bbh / 2) { dir = 'WSW'; } else { dir = 'SSW'; } break; } return dir; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/helpers/link.js"],"names":["tailGenerator","simpleRightHead","simpleLeftHead","leftHead","rightHead","style","opts","straightTail","curvedTail","d","messageTail","lineTail","_180OVER_PI","Math","PI","sl","source","layout","tl","target","pathMeta","start","x","pos","y","end","dir","angle","atan2","length","sqrt","transform","textMeta","baseLine","textAnchor","yOffset","yStart","ySeparation","index","tail","script","isStraight","id","getApparentDir","middle","indexOf","bbw","bbh","r","simpleHead","isRight","w","h","head","directions","easts","wests","norts","souths","vDir","hDir"],"mappings":"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","file":"link.js","sourcesContent":["\n\nexport function tailGenerator(style, opts) {\n  switch ( style ) {\n\n    case '-':\n    case 'STRAIGHT': return straightTail;\n\n    case '~':\n    case 'CURVED': return curvedTail;\n\n    case 'MESSAGE': return (d) => messageTail(d, opts);\n\n    case 'LINE': return lineTail;\n\n    default:\n      throw `Unknown link style \"${style}\"`;\n  }\n}\n\nconst _180OVER_PI = 180 / Math.PI;\n\nfunction lineTail(d) {\n  const sl = d.source.layout;\n  const tl = d.target.layout\n\n  d.pathMeta = {\n    start: {x: sl.pos.x, y: sl.pos.y},\n    end: {x: tl.pos.x, y: tl.pos.y},\n    dir: 'E',\n  }\n\n  const start = d.pathMeta.start;\n  const end = d.pathMeta.end;\n  const angle = Math.atan2(end.y - start.y, end.x - start.x)*_180OVER_PI;\n  const length = Math.sqrt((end.x - start.x)*(end.x - start.x) + (end.y - start.y)*(end.y - start.y));\n\n  d.pathMeta.length = length;\n\n  d.pathMeta.transform = `translate(${start.x} ${start.y}) rotate(${angle})`;\n\n  d.textMeta = {\n    pos: {x: start.x + length/2 , y: start.y},\n    baseLine: 'text-after-edge',\n    textAnchor: 'start'\n\n  }\n  return `M${0} ${0}L${length} ${0}`;\n}\n\nfunction messageTail(d, opts) {\n  let yOffset = opts.yStart+ opts.ySeparation * d.index\n  let sl = d.source.layout;\n  let tl = d.target.layout\n\n\n  if (d.source == d.target) {\n\n    d.pathMeta = {\n      start: {x: sl.pos.x, y: yOffset - opts.ySeparation},\n      end: {x: sl.pos.x, y: yOffset},\n      dir: 'W'\n    }\n    let start = d.pathMeta.start;\n\n    d.textMeta = {\n      pos: {x: start.x + opts.ySeparation*0.8, y: start.y + opts.ySeparation/2},\n      baseLine: 'text-after-edge',\n      textAnchor: 'start'\n\n    }\n    return `M${start.x} ${start.y}\n          C ${start.x + opts.ySeparation} ${start.y}\n            ${start.x + opts.ySeparation} ${start.y + opts.ySeparation}\n            ${start.x} ${start.y + opts.ySeparation}`\n\n  } else {\n\n    d.pathMeta = {\n      start: {x: sl.pos.x, y: yOffset},\n      end: {x: tl.pos.x, y: yOffset},\n      dir: tl.pos.x > sl.pos.x ? 'E': 'W'\n    }\n\n    d.textMeta = {\n      pos: {x: d.pathMeta.start.x + (d.pathMeta.end.x - d.pathMeta.start.x) / 2, y: yOffset - 5 },\n      baseLine: 'text-after-edge',\n      textAnchor: 'middle'\n    }\n    return `M${d.source.layout.pos.x} ${yOffset} H ${d.target.layout.pos.x}`;\n  }\n}\n\nfunction straightTail(d) {\n  const [pathMeta, script] =  tail(d, true);\n  d.pathMeta = pathMeta;\n  return script;\n}\n\nfunction curvedTail(d) {\n  const [pathMeta, script] =  tail(d, false);\n  d.pathMeta = pathMeta;\n  return script;\n}\n\nfunction tail(d, isStraight) {\n\n  let sl = d.source.layout;\n  let tl = d.target.layout;\n\n\n  let dir = d.source.id == d.target.id ? 'SELF' : getApparentDir(sl, tl);\n\n  let start =  {x: 0, y:0};\n  let end =  {x: 0, y:0};\n  let middle = 0;\n  let script = '';\n\n  switch (true) {\n    case ['NNE', 'SSE', 'SSW', 'NNW'].indexOf(dir) >= 0:\n      start.x = sl.pos.x + sl.bbw/2;\n      start.y = sl.pos.y;\n      end.x = tl.pos.x;\n      end.y = tl.pos.y + tl.bbh/2;\n      if (['NNW', 'SSW'].indexOf(dir) >= 0) {\n        start.x = sl.pos.x - sl.bbw/2;\n      }\n      if (['SSE', 'SSW'].indexOf(dir) >= 0) {\n        end.y = tl.pos.y - tl.bbh/2;\n      }\n      if (isStraight) {\n        script =  `M${start.x} ${start.y} H${end.x} V${end.y}`;\n      } else {\n        script =  `M${start.x} ${start.y} Q${end.x} ${start.y} ${end.x} ${end.y}`;\n      }\n      break;\n    case (['ENE', 'ESE', 'WNW', 'WSW'].indexOf(dir) >= 0):\n      start.x = sl.pos.x;\n      start.y = sl.pos.y - sl.bbh/2;\n      end.x = tl.pos.x - tl.bbw/2;\n      end.y = tl.pos.y;\n      if (['ESE', 'WSW'].indexOf(dir) >= 0) {\n        start.y = sl.pos.y + sl.bbh/2;\n      }\n      if (['WNW', 'WSW'].indexOf(dir) >= 0) {\n        end.x = tl.pos.x + tl.bbw/2;\n      }\n      if (isStraight) {\n        script =  `M${start.x} ${start.y}V${end.y}H${end.x}`;\n      } else {\n        script =  `M${start.x} ${start.y}Q${start.x} ${end.y} ${end.x} ${end.y}`;\n      }\n      break;\n\n    case ['E', 'W'].indexOf(dir) >= 0:\n      start.x = sl.pos.x + sl.bbw/2;\n      start.y = sl.pos.y;\n      end.x = tl.pos.x - tl.bbw/2;\n      end.y = tl.pos.y;\n      if (dir == 'W') {\n        start.x = sl.pos.x - sl.bbw/2;\n        end.x = tl.pos.x + tl.bbw/2;\n      }\n      middle = start.x + (end.x - start.x)/2;\n      if (isStraight) {\n        script =  `M${start.x} ${start.y}H${middle}V${end.y}H${end.x}`;\n      } else {\n        script =  `M${start.x} ${start.y}C${middle} ${start.y} ${middle} ${end.y} ${end.x} ${end.y}`;\n      }\n      break;\n    case ['N', 'S'].indexOf(dir) >= 0:\n      start.x = sl.pos.x;\n      start.y = sl.pos.y - sl.bbh/2;\n      end.x = tl.pos.x;\n      end.y = tl.pos.y + tl.bbh/2;\n      if (dir == 'S') {\n        start.y = sl.pos.y + sl.bbh/2;\n        end.y = tl.pos.y - tl.bbh/2;\n      }\n      middle = start.y + (end.y - start.y)/2;\n      if (isStraight) {\n        script =  `M${start.x} ${start.y}V${middle}H${end.x}V${end.y}`;\n      } else {\n        script =  `M${start.x} ${start.y}C${start.x} ${middle} ${end.x} ${middle} ${end.x} ${end.y}`;\n      }\n      break;\n    case 'SELF' == dir:\n      start.x = sl.pos.x;\n      start.y = sl.pos.y - sl.bbh/2;\n      end.x = sl.pos.x + sl.bbw/2;\n      end.y = sl.pos.y;\n      let r = Math.sqrt(sl.bbw*sl.bbw + sl.bbh*sl.bbh)/4;\n      if (isStraight) {\n        script =  `M${start.x} ${start.y}V${start.y - r}H${end.x + r}V${end.y}H${end.x}`;\n      } else {\n        script =  `M${start.x} ${start.y}C ${start.x+r} ${start.y-3*r} ${end.x + 3*r} ${end.y} ${end.x} ${end.y}`;\n      }\n\n      break;\n  }\n\n  return [\n    {\n      start: start,\n      end: end,\n      dir: dir\n    },\n    script\n  ]\n  return script;\n}\n\nexport function  simpleRightHead(d) {\n  return simpleHead(d, true);\n}\nexport function  simpleLeftHead(d) {\n  return simpleHead(d, true);\n}\n\nfunction simpleHead(d, isRight) {\n\n  if (!d.pathMeta) {\n    return;\n  }\n  const w = 14;\n  const h = 8;\n  const bbw = d.source.layout.bbw;\n  const length = d.pathMeta.length;\n  if (isRight) {\n    return `M${length-bbw/2} 0l${-w} ${-h/2}v${h}Z`;\n  } else {\n    return `M${bbw/2} 0l${w} ${-h/2}v${h}Z`;\n  }\n}\n\n\nexport function leftHead(d) {\n  return head(d, false)\n}\nexport function rightHead(d) {\n  return head(d, true)\n}\nfunction head(d, isRight) {\n  if (!d.pathMeta) {\n    return;\n  }\n  let end;\n  if (isRight) {\n    end = d.pathMeta.end;\n  } else {\n    end = d.pathMeta.start;\n  }\n\n  const dir = d.pathMeta.dir;\n  const w = 14;\n  const h = 8;\n\n  let directions;\n  if (isRight) {\n    directions = {\n      easts: ['ENE', 'E', 'ESE'],\n      wests: ['WNW', 'W', 'WSW', \"SELF\"],\n      norts: ['NNW', 'N', 'NNE'],\n      souths: ['SSW', 'S', 'SSE']\n    }\n  } else {\n    directions = {\n      easts: ['NNW', 'W', 'SSW'],\n      wests: ['NNE', 'E', 'SSE'],\n      norts: ['WSW', 'S', 'ESE'],\n      souths: ['WNW', 'N', 'ENE', \"SELF\"]\n    }\n  }\n\n  switch (true) {\n    case directions.easts.indexOf(dir) >= 0:\n      return `M${end.x} ${end.y}L${end.x - w} ${end.y - h/2}V${end.y + h/2}Z`;\n    case directions.wests.indexOf(dir) >= 0:\n      return `M${end.x} ${end.y}L${end.x + w} ${end.y - h/2}V${end.y + h/2}Z`;\n    case directions.norts.indexOf(dir) >= 0:\n      return `M${end.x} ${end.y}L${end.x - h/2} ${end.y + w}H${end.x + h/2}Z`;\n    case directions.souths.indexOf(dir) >= 0:\n      return `M${end.x} ${end.y}L${end.x - h/2} ${end.y - w}H${end.x + h/2}Z`;\n\n  }\n}\n\nfunction getApparentDir(sl, tl) {\n\n\n  let vDir = 'SAME';\n  let hDir = 'SAME';\n  let dir = '?';\n\n  if (tl.pos.y + tl.bbh/2 < sl.pos.y - sl.bbh/2 ) {\n    vDir = 'TOP';\n  } else if (tl.pos.y - tl.bbh/2 > sl.pos.y + sl.bbh/2) {\n    vDir = 'BOTTOM';\n  }\n\n  if (tl.pos.x + tl.bbw /2  < sl.pos.x - sl.bbw/2) {\n    hDir = 'LEFT'\n  } else if (sl.pos.x + sl.bbw/2 < tl.pos.x - tl.bbw/2) {\n    hDir = 'RIGHT'\n  }\n\n  switch (true) {\n    case hDir == 'SAME' && vDir == 'TOP':\n      dir = 'N';\n      break;\n    case hDir == 'SAME' && vDir == 'BOTTOM':\n      dir = 'S';\n      break;\n    case hDir == 'RIGHT' && vDir == 'SAME':\n      dir = 'E';\n      break;\n    case hDir == 'LEFT' && vDir == 'SAME':\n      dir = 'W';\n      break;\n    case hDir == 'RIGHT' && vDir == 'TOP':\n      dir = 'NE';\n      if (tl.pos.x - tl.bbw/2 - sl.pos.x - sl.bbw/2 > sl.pos.y - sl.bbh/2 - tl.pos.y - tl.bbh/2) {\n        dir = 'ENE'\n      } else {\n        dir = 'NNE'\n      }\n      break;\n    case hDir == 'RIGHT' && vDir == 'BOTTOM':\n      dir = 'SE';\n      if (tl.pos.x - tl.bbw/2- sl.pos.x - sl.bbw/2 > tl.pos.y - tl.bbh /2 - sl.pos.y - sl.bbh/2) {\n        dir = 'ESE'\n      } else {\n        dir = 'SSE'\n      }\n      break;\n    case hDir == 'LEFT' && vDir == 'TOP':\n      dir = 'NW';\n      if (sl.pos.x - sl.bbw/2 - tl.pos.x - tl.bbw/2 > sl.pos.y - sl.bbh/2- tl.pos.y - tl.bbh/2) {\n        dir = 'WNW'\n      } else {\n        dir = 'NNW'\n      }\n      break;\n    case hDir == 'LEFT' && vDir == 'BOTTOM':\n      dir = 'SW';\n      if (sl.pos.x - sl.bbw/2 - tl.pos.x - tl.bbw/2 > tl.pos.y - tl.bbh/2 - sl.pos.y - sl.bbh/2) {\n        dir = 'WSW'\n      } else {\n        dir = 'SSW'\n      }\n      break;\n  }\n  return dir;\n\n}\n"]}