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