From df6c00db050e188a6bd5707e72c4f1f331ced923 Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Sun, 08 Feb 2026 20:46:43 +0000
Subject: [PATCH] =Port over to jakevan 2

---
 assets/js/concise/PopulateForm.js |   57 +++++++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 49 insertions(+), 8 deletions(-)

diff --git a/assets/js/concise/PopulateForm.js b/assets/js/concise/PopulateForm.js
index 64b3f65..2bd02b8 100644
--- a/assets/js/concise/PopulateForm.js
+++ b/assets/js/concise/PopulateForm.js
@@ -91,7 +91,7 @@
 		if (!value || !Array.isArray(value)) return;
 
 		const container = field.querySelector('.repeater-items');
-		let template = field.querySelector('template')?.className??false;
+		let template = field.querySelector('template')?.className ?? false;
 		if (!container || !template) return;
 
 		window.removeChildren(container);
@@ -99,8 +99,16 @@
 		value.forEach((data, index) => {
 			data.index = index;
 			const row = this.templates.create(template, data);
-			let fields = row.querySelectorAll('.field');
-			this.populate(fields, data);
+			if (!row) return;
+
+			for (let [fieldName, fieldValue] of Object.entries(data)) {
+				if (fieldName === 'index') continue;
+				let subField = row.querySelector(`[data-field="${fieldName}"]`);
+				if (subField) {
+					this.populateField(subField, fieldName, fieldValue);
+				}
+			}
+
 			container.append(row);
 		});
 	}
@@ -108,19 +116,52 @@
 		if (!value || !Array.isArray(value)) return;
 
 		const container = field.querySelector('.tag-items');
-		let template = field.querySelector('template')?.className??false;
+		let template = field.querySelector('template')?.className ?? false;
 		if (!container || !template) return;
 
 		window.removeChildren(container);
 
 		value.forEach((data, index) => {
-			data.index = index;
-			const row = this.templates.create(template, data);
-			let fields = row.querySelectorAll('.field');
-			this.populate(fields, data);
+			const row = this.templates.create(template, {
+				label: this.getTagLabel(data, field.dataset.tagFormat ?? 'first_field'),
+				fieldName: name,
+				...data
+			});
+			if (!row) return;
+
+			// Set hidden input values directly
+			row.querySelectorAll('input[type="hidden"]').forEach(input => {
+				const key = input.dataset.field;
+				if (key && data[key] !== undefined) {
+					input.value = data[key];
+				}
+			});
+
 			container.append(row);
 		});
 	}
+	/**
+	 * Build tag label from data - mirrors addTagListItem logic
+	 */
+	getTagLabel(data, format) {
+		const values = Object.values(data).filter(v => !this.isEmptyValue(v));
+		switch (format) {
+			case 'first_field':
+				return values[0] ?? 'New Item';
+			case 'all_fields':
+				return values.join(', ') || 'New Item';
+			default:
+				if (format.includes('{')) {
+					let label = format;
+					for (const [key, value] of Object.entries(data)) {
+						label = label.replace(`{${key}}`, value);
+					}
+					return label;
+				}
+				return data[format] ?? values[0] ?? 'New Item';
+		}
+	}
+
 	populateLocation(field, name, value) {
 		const subFields = ['address', 'lat', 'lng', 'street', 'city', 'province', 'postal_code', 'country'];
 		subFields.forEach(subField => {

--
Gitblit v1.10.0