mirror of
https://github.com/Azgaar/Fantasy-Map-Generator.git
synced 2025-12-17 09:41:24 +01:00
Resources editor - assign cells
This commit is contained in:
parent
f7aad4b658
commit
a6f1fbd5e1
3 changed files with 1065 additions and 574 deletions
11
index.html
11
index.html
|
|
@ -3007,10 +3007,11 @@
|
||||||
<div style="left:2.8em" data-tip="Click to sort by resource name" class="sortable alphabetically" data-sortby="name">Resource </div>
|
<div style="left:2.8em" data-tip="Click to sort by resource name" class="sortable alphabetically" data-sortby="name">Resource </div>
|
||||||
<div style="left:8.8em" data-tip="Click to sort by resource category" class="sortable alphabetically" data-sortby="category">Category </div>
|
<div style="left:8.8em" data-tip="Click to sort by resource category" class="sortable alphabetically" data-sortby="category">Category </div>
|
||||||
<div style="left:15em" data-tip="Click to sort by generation chance" class="sortable" data-sortby="chance">Chance </div>
|
<div style="left:15em" data-tip="Click to sort by generation chance" class="sortable" data-sortby="chance">Chance </div>
|
||||||
<div style="left:20em" data-tip="Click to sort by spread model" class="sortable alphabetically" data-sortby="model">Model </div>
|
<div style="left:19.5em" data-tip="Click to sort by number of cells" class="sortable icon-sort-number-down" data-sortby="cells">Cells </div>
|
||||||
<div style="left:27em" data-tip="Click to sort by number of cells" class="sortable icon-sort-number-down" data-sortby="cells">Cells </div>
|
<div style="left:23.4em" data-tip="Click to sort by spread model" class="sortable alphabetically hide" data-sortby="model">Model </div>
|
||||||
<div style="left:30.8em" data-tip="Click to sort by resource basic value" class="sortable" data-sortby="value">Value </div>
|
<div style="left:30.8em" data-tip="Click to sort by resource basic value" class="sortable hide" data-sortby="value">Value </div>
|
||||||
<div style="left:34.5em" data-tip="Click to sort by bonuses" class="sortable alphabetically" data-sortby="bonuses">Bonuses </div>
|
<div style="left:34.5em" data-tip="Click to sort by bonus" class="sortable alphabetically hide" data-sortby="bonus">Bonus </div>
|
||||||
|
<div style="left:39.8em; cursor: pointer;" data-tip="Click to unpin (show) all resources" class="icon-pin hidden" id="resourcesUnpinAll"></div>
|
||||||
</div>
|
</div>
|
||||||
<div id="resourcesBody" class="table" data-type="absolute"></div>
|
<div id="resourcesBody" class="table" data-type="absolute"></div>
|
||||||
|
|
||||||
|
|
@ -3023,7 +3024,9 @@
|
||||||
<button id="resourcesRegenerate" data-tip="Regenerate resources based on current configuration" class="icon-retweet"></button>
|
<button id="resourcesRegenerate" data-tip="Regenerate resources based on current configuration" class="icon-retweet"></button>
|
||||||
<button id="resourcesLegend" data-tip="Toggle Legend box" class="icon-list-bullet"></button>
|
<button id="resourcesLegend" data-tip="Toggle Legend box" class="icon-list-bullet"></button>
|
||||||
<button id="resourcesPercentage" data-tip="Toggle percentage / absolute values display mode" class="icon-percent"></button>
|
<button id="resourcesPercentage" data-tip="Toggle percentage / absolute values display mode" class="icon-percent"></button>
|
||||||
|
<button id="resourcesAssign" data-tip="Manually assign resources to cells" class="icon-brush"></button>
|
||||||
<button id="resourcesAdd" data-tip="Add a new resource" class="icon-plus"></button>
|
<button id="resourcesAdd" data-tip="Add a new resource" class="icon-plus"></button>
|
||||||
|
<button id="resourcesRestore" data-tip="Restore default list and regenerate resources" class="icon-history"></button>
|
||||||
<button id="resourcesExport" data-tip="Download resources-related data" class="icon-download"></button>
|
<button id="resourcesExport" data-tip="Download resources-related data" class="icon-download"></button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
||||||
1454
modules/ui/layers.js
1454
modules/ui/layers.js
File diff suppressed because it is too large
Load diff
|
|
@ -23,7 +23,11 @@ function editResources() {
|
||||||
document.getElementById('resourcesRegenerate').addEventListener('click', regenerateResources);
|
document.getElementById('resourcesRegenerate').addEventListener('click', regenerateResources);
|
||||||
document.getElementById('resourcesLegend').addEventListener('click', toggleLegend);
|
document.getElementById('resourcesLegend').addEventListener('click', toggleLegend);
|
||||||
document.getElementById('resourcesPercentage').addEventListener('click', togglePercentageMode);
|
document.getElementById('resourcesPercentage').addEventListener('click', togglePercentageMode);
|
||||||
|
document.getElementById('resourcesAssign').addEventListener('click', enterResourceAssignMode);
|
||||||
|
document.getElementById('resourcesAdd').addEventListener('click', resourceAdd);
|
||||||
|
document.getElementById('resourcesRestore').addEventListener('click', resourcesRestoreDefaults);
|
||||||
document.getElementById('resourcesExport').addEventListener('click', downloadResourcesData);
|
document.getElementById('resourcesExport').addEventListener('click', downloadResourcesData);
|
||||||
|
document.getElementById('resourcesUnpinAll').addEventListener('click', unpinAllResources);
|
||||||
|
|
||||||
body.addEventListener('click', function (ev) {
|
body.addEventListener('click', function (ev) {
|
||||||
const el = ev.target,
|
const el = ev.target,
|
||||||
|
|
@ -34,6 +38,8 @@ function editResources() {
|
||||||
if (cl.contains('resourceCategory')) return changeCategory(resource, line, el);
|
if (cl.contains('resourceCategory')) return changeCategory(resource, line, el);
|
||||||
if (cl.contains('resourceModel')) return changeModel(resource, line, el);
|
if (cl.contains('resourceModel')) return changeModel(resource, line, el);
|
||||||
if (cl.contains('resourceBonus')) return changeBonus(resource, line, el);
|
if (cl.contains('resourceBonus')) return changeBonus(resource, line, el);
|
||||||
|
if (cl.contains('icon-pin')) return pinResource(resource, el);
|
||||||
|
if (cl.contains('icon-trash-empty')) return removeResourcePrompt(resource, line);
|
||||||
});
|
});
|
||||||
|
|
||||||
body.addEventListener('change', function (ev) {
|
body.addEventListener('change', function (ev) {
|
||||||
|
|
@ -80,11 +86,13 @@ function editResources() {
|
||||||
<input data-tip="Resource name. Click and category to change" class="resourceName" value="${r.name}" autocorrect="off" spellcheck="false">
|
<input data-tip="Resource name. Click and category to change" class="resourceName" value="${r.name}" autocorrect="off" spellcheck="false">
|
||||||
<div data-tip="Resource category. Select to change" class="resourceCategory">${r.category}</div>
|
<div data-tip="Resource category. Select to change" class="resourceCategory">${r.category}</div>
|
||||||
<input data-tip="Resource generation chance in eligible cell. Click and type to change" class="resourceChance" value="${r.chance}" type="number" min=0 max=100 step=.1 />
|
<input data-tip="Resource generation chance in eligible cell. Click and type to change" class="resourceChance" value="${r.chance}" type="number" min=0 max=100 step=.1 />
|
||||||
<div data-tip="Resource spread model. Click to change" class="resourceModel" ${addTitle(model, 8)}">${model}</div>
|
<div data-tip="Number of cells with resource" class="resourceCells">${r.cells}</div>
|
||||||
<div data-tip="Number of cells with resource" class="cells">${r.cells}</div>
|
|
||||||
|
|
||||||
<input data-tip="Resource basic value. Click and type to change" class="resourceValue" value="${r.value}" type="number" min=0 max=100 step=1 />
|
<div data-tip="Resource spread model. Click to change" class="resourceModel hide" ${addTitle(model, 8)}">${model}</div>
|
||||||
<div data-tip="Resource bonus. Click to change" class="resourceBonus" title="${bonusString}">${bonusHTML}</div>
|
<input data-tip="Resource basic value. Click and type to change" class="resourceValue hide" value="${r.value}" type="number" min=0 max=100 step=1 />
|
||||||
|
<div data-tip="Resource bonus. Click to change" class="resourceBonus hide" title="${bonusString}">${bonusHTML}</div>
|
||||||
|
|
||||||
|
<span data-tip="Toogle resource exclusive visibility (pin)" class="icon-pin inactive hide"></span>
|
||||||
<span data-tip="Remove resource" class="icon-trash-empty hide"></span>
|
<span data-tip="Remove resource" class="icon-trash-empty hide"></span>
|
||||||
</div>`;
|
</div>`;
|
||||||
}
|
}
|
||||||
|
|
@ -96,7 +104,7 @@ function editResources() {
|
||||||
// add listeners
|
// add listeners
|
||||||
// body.querySelectorAll("div.resources").forEach(el => el.addEventListener("mouseenter", ev => resourceHighlightOn(ev)));
|
// body.querySelectorAll("div.resources").forEach(el => el.addEventListener("mouseenter", ev => resourceHighlightOn(ev)));
|
||||||
// body.querySelectorAll("div.resources").forEach(el => el.addEventListener("mouseleave", ev => resourceHighlightOff(ev)));
|
// body.querySelectorAll("div.resources").forEach(el => el.addEventListener("mouseleave", ev => resourceHighlightOff(ev)));
|
||||||
// body.querySelectorAll("div.states").forEach(el => el.addEventListener("click", selectResourceOnLineClick));
|
body.querySelectorAll('div.states').forEach((el) => el.addEventListener('click', selectResourceOnLineClick));
|
||||||
body.querySelectorAll('svg.icon').forEach((el) => el.addEventListener('click', resourceChangeColor));
|
body.querySelectorAll('svg.icon').forEach((el) => el.addEventListener('click', resourceChangeColor));
|
||||||
|
|
||||||
if (body.dataset.type === 'percentage') {
|
if (body.dataset.type === 'percentage') {
|
||||||
|
|
@ -312,6 +320,11 @@ function editResources() {
|
||||||
openPicker(resource.color, callback, {allowHatching: false});
|
openPicker(resource.color, callback, {allowHatching: false});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function resourcesRestoreDefaults() {
|
||||||
|
delete pack.resources;
|
||||||
|
regenerateResources();
|
||||||
|
}
|
||||||
|
|
||||||
function toggleLegend() {
|
function toggleLegend() {
|
||||||
if (legend.selectAll('*').size()) {
|
if (legend.selectAll('*').size()) {
|
||||||
clearLegend();
|
clearLegend();
|
||||||
|
|
@ -339,6 +352,89 @@ function editResources() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function enterResourceAssignMode() {
|
||||||
|
if (this.classList.contains('pressed')) return exitResourceAssignMode();
|
||||||
|
customization = 14;
|
||||||
|
this.classList.add('pressed');
|
||||||
|
if (!layerIsOn('toggleResources')) toggleResources();
|
||||||
|
if (!layerIsOn('toggleCells')) {
|
||||||
|
const toggler = document.getElementById('toggleCells');
|
||||||
|
toggler.dataset.forced = true;
|
||||||
|
toggleCells();
|
||||||
|
}
|
||||||
|
|
||||||
|
document
|
||||||
|
.getElementById('resourcesEditor')
|
||||||
|
.querySelectorAll('.hide')
|
||||||
|
.forEach((el) => el.classList.add('hidden'));
|
||||||
|
document.getElementById('resourcesFooter').style.display = 'none';
|
||||||
|
body.querySelectorAll('.resourceName, .resourceCategory, .resourceChance, .resourceCells, svg').forEach((e) => (e.style.pointerEvents = 'none'));
|
||||||
|
$('#resourcesEditor').dialog({position: {my: 'right top', at: 'right-10 top+10', of: 'svg', collision: 'fit'}});
|
||||||
|
|
||||||
|
tip('Select resource line in editor, click on cells to remove or add a resource', true);
|
||||||
|
viewbox.on('click', changeResourceOnCellClick);
|
||||||
|
|
||||||
|
body.querySelector('div').classList.add('selected');
|
||||||
|
|
||||||
|
const someArePinned = pack.resources.some((resource) => resource.pinned);
|
||||||
|
if (someArePinned) unpinAllResources();
|
||||||
|
}
|
||||||
|
|
||||||
|
function selectResourceOnLineClick() {
|
||||||
|
if (customization !== 14) return;
|
||||||
|
//if (this.parentNode.id !== "statesBodySection") return;
|
||||||
|
body.querySelector('div.selected').classList.remove('selected');
|
||||||
|
this.classList.add('selected');
|
||||||
|
}
|
||||||
|
|
||||||
|
function changeResourceOnCellClick() {
|
||||||
|
const point = d3.mouse(this);
|
||||||
|
const i = findCell(point[0], point[1]);
|
||||||
|
const selected = body.querySelector('div.selected');
|
||||||
|
if (!selected) return;
|
||||||
|
|
||||||
|
if (pack.cells.resource[i]) {
|
||||||
|
const resourceToRemove = Resources.get(pack.cells.resource[i]);
|
||||||
|
if (resourceToRemove) resourceToRemove.cells -= 1;
|
||||||
|
body.querySelector("div.states[data-id='" + resourceToRemove.i + "'] > .resourceCells").innerHTML = resourceToRemove.cells;
|
||||||
|
pack.cells.resource[i] = 0;
|
||||||
|
} else {
|
||||||
|
const resourceId = +selected.dataset.id;
|
||||||
|
const resource = Resources.get(resourceId);
|
||||||
|
resource.cells += 1;
|
||||||
|
body.querySelector("div.states[data-id='" + resourceId + "'] > .resourceCells").innerHTML = resource.cells;
|
||||||
|
pack.cells.resource[i] = resourceId;
|
||||||
|
}
|
||||||
|
|
||||||
|
goods.selectAll('*').remove();
|
||||||
|
drawResources();
|
||||||
|
}
|
||||||
|
|
||||||
|
function exitResourceAssignMode(close) {
|
||||||
|
customization = 0;
|
||||||
|
document.getElementById('resourcesAssign').classList.remove('pressed');
|
||||||
|
|
||||||
|
if (layerIsOn('toggleCells')) {
|
||||||
|
const toggler = document.getElementById('toggleCells');
|
||||||
|
if (toggler.dataset.forced) toggleCells();
|
||||||
|
}
|
||||||
|
|
||||||
|
document
|
||||||
|
.getElementById('resourcesEditor')
|
||||||
|
.querySelectorAll('.hide')
|
||||||
|
.forEach((el) => el.classList.remove('hidden'));
|
||||||
|
document.getElementById('resourcesFooter').style.display = 'block';
|
||||||
|
body.querySelectorAll('.resourceName, .resourceCategory, .resourceChance, .resourceCells, svg').forEach((e) => delete e.style.pointerEvents);
|
||||||
|
!close && $('#resourcesEditor').dialog({position: {my: 'right top', at: 'right-10 top+10', of: 'svg', collision: 'fit'}});
|
||||||
|
|
||||||
|
restoreDefaultEvents();
|
||||||
|
clearMainTip();
|
||||||
|
const selected = body.querySelector('div.selected');
|
||||||
|
if (selected) selected.classList.remove('selected');
|
||||||
|
}
|
||||||
|
|
||||||
|
function resourceAdd() {}
|
||||||
|
|
||||||
function downloadResourcesData() {
|
function downloadResourcesData() {
|
||||||
let data = 'Id,Resource,Color,Category,Value,Bonus,Chance,Model,Cells\n'; // headers
|
let data = 'Id,Resource,Color,Category,Value,Bonus,Chance,Model,Cells\n'; // headers
|
||||||
|
|
||||||
|
|
@ -358,5 +454,67 @@ function editResources() {
|
||||||
downloadFile(data, name);
|
downloadFile(data, name);
|
||||||
}
|
}
|
||||||
|
|
||||||
function closeResourcesEditor() {}
|
function pinResource(resource, el) {
|
||||||
|
const pin = el.classList.contains('inactive');
|
||||||
|
el.classList.toggle('inactive');
|
||||||
|
|
||||||
|
if (pin) resource.pinned = pin;
|
||||||
|
else delete resource.pinned;
|
||||||
|
|
||||||
|
goods.selectAll('*').remove();
|
||||||
|
drawResources();
|
||||||
|
|
||||||
|
// manage top unpin all button state
|
||||||
|
const someArePinned = pack.resources.some((resource) => resource.pinned);
|
||||||
|
const unpinAll = document.getElementById('resourcesUnpinAll');
|
||||||
|
someArePinned ? unpinAll.classList.remove('hidden') : unpinAll.classList.add('hidden');
|
||||||
|
}
|
||||||
|
|
||||||
|
function unpinAllResources() {
|
||||||
|
pack.resources.forEach((resource) => delete resource.pinned);
|
||||||
|
goods.selectAll('*').remove();
|
||||||
|
drawResources();
|
||||||
|
|
||||||
|
document.getElementById('resourcesUnpinAll').classList.add('hidden');
|
||||||
|
body.querySelectorAll(':scope > div > span.icon-pin').forEach((el) => el.classList.add('inactive'));
|
||||||
|
}
|
||||||
|
|
||||||
|
function removeResourcePrompt(resource, line) {
|
||||||
|
if (customization) return;
|
||||||
|
|
||||||
|
alertMessage.innerHTML = 'Are you sure you want to remove the resource? <br>This action cannot be reverted';
|
||||||
|
$('#alert').dialog({
|
||||||
|
resizable: false,
|
||||||
|
title: 'Remove resource',
|
||||||
|
buttons: {
|
||||||
|
Remove: function () {
|
||||||
|
$(this).dialog('close');
|
||||||
|
removeResource(resource, line);
|
||||||
|
},
|
||||||
|
Cancel: function () {
|
||||||
|
$(this).dialog('close');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function removeResource(res, line) {
|
||||||
|
for (const i of pack.cells.i) {
|
||||||
|
if (pack.cells.resource[i] === res.i) {
|
||||||
|
pack.cells.resource[i] = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pack.resources = pack.resources.filter((resource) => resource.i !== res.i);
|
||||||
|
line.remove();
|
||||||
|
|
||||||
|
goods.selectAll('*').remove();
|
||||||
|
drawResources();
|
||||||
|
}
|
||||||
|
|
||||||
|
function closeResourcesEditor() {
|
||||||
|
if (customization === 14) exitResourceAssignMode('close');
|
||||||
|
unpinAllResources();
|
||||||
|
body.innerHTML = '';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue