mirror of
https://github.com/Azgaar/Fantasy-Map-Generator.git
synced 2026-02-04 09:31:23 +01:00
* chore: add npm + vite for progressive enhancement * fix: update Dockerfile to copy only the dist folder contents * fix: update Dockerfile to use multi-stage build for optimized production image * fix: correct nginx config file copy command in Dockerfile * chore: add netlify configuration for build and redirects * fix: add NODE_VERSION to environment in Netlify configuration * remove wrong dist folder * Update package.json Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * chore: split public and src * migrating all util files from js to ts * feat: Implement HeightmapGenerator and Voronoi module - Added HeightmapGenerator class for generating heightmaps with various tools (Hill, Pit, Range, Trough, Strait, etc.). - Introduced Voronoi class for creating Voronoi diagrams using Delaunator. - Updated index.html to include new modules. - Created index.ts to manage module imports. - Enhanced arrayUtils and graphUtils with type definitions and improved functionality. - Added utility functions for generating grids and calculating Voronoi cells. * chore: add GitHub Actions workflow for deploying to GitHub Pages * fix: update branch name in GitHub Actions workflow from 'main' to 'master' * chore: update package.json to specify Node.js engine version and remove unused launch.json * Initial plan * Update copilot guidelines to reflect NPM/Vite/TypeScript migration Co-authored-by: Azgaar <26469650+Azgaar@users.noreply.github.com> * Update src/modules/heightmap-generator.ts Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/utils/graphUtils.ts Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/modules/heightmap-generator.ts Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * feat: Add TIME and ERROR variables to global scope in HeightmapGenerator * fix: Update base path in vite.config.ts for Netlify deployment * fix: Update Node.js version in Dockerfile to 24-alpine --------- Co-authored-by: Marc Emmanuel <marc.emmanuel@tado.com> Co-authored-by: Marc Emmanuel <marcwissler@gmail.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: Azgaar <26469650+Azgaar@users.noreply.github.com>
84 lines
2.4 KiB
JavaScript
84 lines
2.4 KiB
JavaScript
"use strict";
|
|
|
|
function drawBurgLabels() {
|
|
TIME && console.time("drawBurgLabels");
|
|
createLabelGroups();
|
|
|
|
for (const {name} of options.burgs.groups) {
|
|
const burgsInGroup = pack.burgs.filter(b => b.group === name && !b.removed);
|
|
if (!burgsInGroup.length) continue;
|
|
|
|
const labelGroup = burgLabels.select("#" + name);
|
|
if (labelGroup.empty()) continue;
|
|
|
|
const dx = labelGroup.attr("data-dx") || 0;
|
|
const dy = labelGroup.attr("data-dy") || 0;
|
|
|
|
labelGroup
|
|
.selectAll("text")
|
|
.data(burgsInGroup)
|
|
.enter()
|
|
.append("text")
|
|
.attr("text-rendering", "optimizeSpeed")
|
|
.attr("id", d => "burgLabel" + d.i)
|
|
.attr("data-id", d => d.i)
|
|
.attr("x", d => d.x)
|
|
.attr("y", d => d.y)
|
|
.attr("dx", dx + "em")
|
|
.attr("dy", dy + "em")
|
|
.text(d => d.name);
|
|
}
|
|
|
|
TIME && console.timeEnd("drawBurgLabels");
|
|
}
|
|
|
|
function drawBurgLabel(burg) {
|
|
const labelGroup = burgLabels.select("#" + burg.group);
|
|
if (labelGroup.empty()) {
|
|
drawBurgLabels();
|
|
return; // redraw all labels if group is missing
|
|
}
|
|
|
|
const dx = labelGroup.attr("data-dx") || 0;
|
|
const dy = labelGroup.attr("data-dy") || 0;
|
|
|
|
removeBurgLabel(burg.i);
|
|
labelGroup
|
|
.append("text")
|
|
.attr("text-rendering", "optimizeSpeed")
|
|
.attr("id", "burgLabel" + burg.i)
|
|
.attr("data-id", burg.i)
|
|
.attr("x", burg.x)
|
|
.attr("y", burg.y)
|
|
.attr("dx", dx + "em")
|
|
.attr("dy", dy + "em")
|
|
.text(burg.name);
|
|
}
|
|
|
|
function removeBurgLabel(burgId) {
|
|
const existingLabel = document.getElementById("burgLabel" + burgId);
|
|
if (existingLabel) existingLabel.remove();
|
|
}
|
|
|
|
function createLabelGroups() {
|
|
// save existing styles and remove all groups
|
|
document.querySelectorAll("g#burgLabels > g").forEach(group => {
|
|
style.burgLabels[group.id] = Array.from(group.attributes).reduce((acc, attribute) => {
|
|
acc[attribute.name] = attribute.value;
|
|
return acc;
|
|
}, {});
|
|
group.remove();
|
|
});
|
|
|
|
// create groups for each burg group and apply stored or default style
|
|
const defaultStyle = style.burgLabels.town || Object.values(style.burgLabels)[0] || {};
|
|
const sortedGroups = [...options.burgs.groups].sort((a, b) => a.order - b.order);
|
|
for (const {name} of sortedGroups) {
|
|
const group = burgLabels.append("g");
|
|
const styles = style.burgLabels[name] || defaultStyle;
|
|
Object.entries(styles).forEach(([key, value]) => {
|
|
group.attr(key, value);
|
|
});
|
|
group.attr("id", name);
|
|
}
|
|
}
|