From 58e8ae0759ccfa97c478ccae4e0778bdce70966f Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Thu, 22 Jan 2026 22:40:02 +0000
Subject: [PATCH] =DirectoryManager.php updates, some javascript tweaks for CRUD.js, and minor style changes

---
 assets/js/concise/PopulateForm.js |   52 +++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 51 insertions(+), 1 deletions(-)

diff --git a/assets/js/concise/PopulateForm.js b/assets/js/concise/PopulateForm.js
index 373a61c..16d3460 100644
--- a/assets/js/concise/PopulateForm.js
+++ b/assets/js/concise/PopulateForm.js
@@ -165,7 +165,34 @@
 				grid.append(this.templates.create('uploadItem', data));
 			});
 		}
+
+		this.populateUploadMeta(field, name, value);
 	}
+		populateUploadMeta(element, name, id) {
+			// Find the image_data field group
+			const imageDataField = element.querySelector('[data-field="image_data"]');
+			if (!imageDataField) return;
+			let data = this.data.images[id]??false;
+			if (!data) return;
+
+			// Set upload ID or attachment ID
+			imageDataField.dataset.attachmentId = data.id;
+			imageDataField.setAttribute('data-ignore', '');
+
+			// Populate the metadata fields
+			const meta = [
+				'image-title',
+				'image-alt-text',
+				'image-caption'
+			];
+
+			for (const m of meta) {
+				const input = imageDataField.querySelector(`[data-field="${m}"] input, [data-field="${m}"] textarea`);
+				if (input && data[m]!=='') {
+					input.value = data[m];
+				}
+			}
+		}
 		populateTimelineGallery(field,name, value) {
 			if (!value || !Array.isArray(value) || value.length === 0) return;
 
@@ -306,6 +333,10 @@
 				video: 'video',
 				file: '.select-item span',
 				img: 'img',
+				details: 'details[data-field]',
+				imgAlt: '[name="image-alt-text"]',
+				imgTitle: '[name="image-title"]',
+				imgDesc: '[name="image-caption"]',
 			},
 			manyRefs: {
 				fields: '.field',
@@ -326,10 +357,29 @@
 					refs.img.alt = imgData['image-alt-text']??'';
 				}
 
+				if (refs.details) {
+					let imgData = p.data.images[data.post_thumbnail];
+
+					refs.details.setAttribute('data-ignore', '');
+					refs.details.dataset.attachmentId = data.post_thumbnail;
+					if (Object.hasOwn(imgData, 'image-alt-text') && refs.alt) {
+						refs.alt.value = imgData['image-alt-text'];
+					}
+					if ((Object.hasOwn(imgData, 'image-title') || Object.hasOwn(data, 'file')) && refs.title) {
+						refs.title.value = imgData['image-title']||data.file.name;
+					}
+					if (Object.hasOwn(imgData, 'image-caption') && refs.description) {
+						refs.description.value = imgData['image-caption'];
+					}
+				}
+
 				if (manyRefs.fields) {
 					for (let field of manyRefs.fields) {
 						if (field.dataset.fieldType === 'group') continue;
-
+						if (field.dataset.field === 'post_thumbnail') {
+							field.remove();
+							continue;
+						}
 						let name = field.dataset.field;
 						let value = data[name]??'';
 						if (!p.isEmptyValue(value)) {

--
Gitblit v1.10.0