drawdown-svg-render
Version:
Svg renderer for drawdown diagrams
369 lines (321 loc) • 41.6 kB
JavaScript
;
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"]}