From afdc1b396e3e88146006cd707a15b9da4843e1c2 Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Sun, 04 Jan 2026 18:34:21 +0000
Subject: [PATCH] Merge branch 'main' of https://github.com/jakevdwerf/jvb
---
assets/js/concise/PopulateForm.js | 21 +++++++++++++++------
1 files changed, 15 insertions(+), 6 deletions(-)
diff --git a/assets/js/concise/PopulateForm.js b/assets/js/concise/PopulateForm.js
index 8cef082..f9335db 100644
--- a/assets/js/concise/PopulateForm.js
+++ b/assets/js/concise/PopulateForm.js
@@ -391,7 +391,8 @@
} else if (typeof fieldValue === 'string') {
try {
const parsed = JSON.parse(fieldValue);
- termIds = Array.isArray(parsed) ? parsed.map(v => String(v)) : [String(parsed)];
+ termIds = Array.isArray(parsed) ?
+ parsed.map(v => String(v)) : [String(parsed)];
} catch (e) {
termIds = fieldValue.split(',').map(v => v.trim());
}
@@ -407,6 +408,12 @@
const hiddenInput = fieldWrapper.querySelector(`input[type="hidden"][name="${fieldName}"]`);
if (hiddenInput) {
hiddenInput.value = termIds.join(',');
+
+ // Trigger TaxonomySelector to update visual display
+ const toggle = fieldWrapper.querySelector('.taxonomy-toggle');
+ if (toggle && toggle.dataset.fieldId && window.jvbTaxonomy) {
+ window.jvbTaxonomy.updateFieldFromInput(toggle.dataset.fieldId);
+ }
}
}
@@ -450,11 +457,14 @@
const grid = fieldWrapper.querySelector('.item-grid');
const uploadContainer = fieldWrapper.querySelector('.file-upload-container');
+ // Clear existing items first
+ if (grid) {
+ window.removeChildren(grid);
+ }
fieldWrapper.querySelector('.progress')?.remove();
if (grid) {
- window.removeChildren(grid);
itemIds.forEach(itemId => {
const template = window.getTemplate('uploadItem');
@@ -465,15 +475,14 @@
let input = template.querySelector('input[name="select-item"]');
let label = template.querySelector('label[for="select-item"]');
+
template.dataset.id = itemId;
input.name = input.name + `-${itemId}`;
input.id = input.name;
label.htmlFor = input.name;
-
const img = template.querySelector('img');
-
- template.querySelector('video').remove();
+ template.querySelector('video')?.remove();
const details = template.querySelector('details');
// Populate with data
@@ -493,7 +502,7 @@
if (altInput) altInput.value = data['image-alt-text'] || data.alt || '';
if (captionInput) captionInput.value = data['image-caption'] || data.caption || '';
} else {
- console.warn('No image data found for ID:', itemId);
+ console.warn('No image data found for ID:', itemId, 'Available data:', Object.keys(imagesData));
}
// Remove hint if present
--
Gitblit v1.10.0