Group text and use elements

This commit is contained in:
Catalin Constantin Mititiuc 2025-06-16 22:41:31 -07:00
parent df21cd8271
commit 1c397d2cb3

View File

@ -45,6 +45,10 @@ function generateRadialCoords({ q, r, s }, radius) {
return list; return list;
} }
function sameSigns(a, b) {
return a > -1 && b > -1 || a < 0 && b < 0;
}
const hex = { const hex = {
inradius: 8.66, inradius: 8.66,
circumradius: 10, circumradius: 10,
@ -53,7 +57,7 @@ const hex = {
const horzSpacing = hex.inradius; const horzSpacing = hex.inradius;
const vertSpacing = hex.circumradius * 3 / 2; const vertSpacing = hex.circumradius * 3 / 2;
const list = generateRadialCoords({ q: 0, r: 0, s: 0 }, 5); const list = generateRadialCoords({ q: 0, r: 0, s: 0 }, 2);
const svg = document.querySelector('svg'); const svg = document.querySelector('svg');
const xmlns = 'http://www.w3.org/2000/svg'; const xmlns = 'http://www.w3.org/2000/svg';
@ -64,7 +68,7 @@ list.forEach(key => {
if (q === s) if (q === s)
x = 0; x = 0;
else if (q > -1 && s > -1 || q < 0 && s < 0) else if (sameSigns(q, s))
x = Math.abs(q - s); x = Math.abs(q - s);
else else
x = Math.abs(q) + Math.abs(s); x = Math.abs(q) + Math.abs(s);
@ -72,25 +76,27 @@ list.forEach(key => {
x = (q > s ? -1 : 1) * x * horzSpacing; x = (q > s ? -1 : 1) * x * horzSpacing;
y = r * vertSpacing; y = r * vertSpacing;
const g = document.createElementNS(xmlns, 'g');
g.setAttributeNS(null, 'transform', `translate(${x}, ${y})`);
const use = document.createElementNS(xmlns, 'use'); const use = document.createElementNS(xmlns, 'use');
use.setAttributeNS(null, 'href', '#hex'); use.setAttributeNS(null, 'href', '#hex');
use.setAttributeNS(null, 'x', x);
use.setAttributeNS(null, 'y', y);
const qText = document.createElementNS(xmlns, 'text'); const qText = document.createElementNS(xmlns, 'text');
qText.textContent = q; qText.textContent = q;
qText.setAttributeNS(null, 'x', x - 3); qText.setAttributeNS(null, 'x', -3);
qText.setAttributeNS(null, 'y', y - 3); qText.setAttributeNS(null, 'y', -3);
const rText = document.createElementNS(xmlns, 'text'); const rText = document.createElementNS(xmlns, 'text');
rText.textContent = r; rText.textContent = r;
rText.setAttributeNS(null, 'x', x + 5); rText.setAttributeNS(null, 'x', 5);
rText.setAttributeNS(null, 'y', y + 1.5); rText.setAttributeNS(null, 'y', 1.5);
const sText = document.createElementNS(xmlns, 'text'); const sText = document.createElementNS(xmlns, 'text');
sText.textContent = s; sText.textContent = s;
sText.setAttributeNS(null, 'x', x - 3); sText.setAttributeNS(null, 'x', -3);
sText.setAttributeNS(null, 'y', y + 5); sText.setAttributeNS(null, 'y', + 5);
[use, qText, rText, sText].forEach(el => svg.appendChild(el)); [use, qText, rText, sText].forEach(el => g.appendChild(el));
svg.appendChild(g);
}); });