From 2127b1bdd73ecd2423e443992da4b442f5a3c1a3 Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Wed, 04 Feb 2026 21:19:25 +0000
Subject: [PATCH] =Major overhaul of MetaManager.php -> Meta.php and RestRouteManager.php -> Rest.php. Seems to work for JakeVan
---
assets/js/concise/PopulateForm.js | 74 ++++++++++++++++++++++++++++++++++--
1 files changed, 69 insertions(+), 5 deletions(-)
diff --git a/assets/js/concise/PopulateForm.js b/assets/js/concise/PopulateForm.js
index 373a61c..64b3f65 100644
--- a/assets/js/concise/PopulateForm.js
+++ b/assets/js/concise/PopulateForm.js
@@ -20,6 +20,7 @@
populate (form, data = {})
{
this.data = data;
+ this.mergeRootData();
this.form = form;
if (!this.formHelper) {
this.formHelper = window.jvbForm;
@@ -42,6 +43,13 @@
}
}
+ mergeRootData(){
+ let check = ['status','date','modified'];
+ check.forEach(ch =>{
+ this.data.fields[`post_${ch}`] = this.data[ch];
+ });
+ }
+
/**
*
* @param {HTMLElement} field
@@ -137,7 +145,7 @@
}
}
populateUser(field, name, value) {
- this.populateTaxonomyField(field, name, value);
+ this.populateTaxonomy(field, name, value);
}
populateUpload(field, name, value) {
if (name === 'timeline' || field.dataset.subtype && field.dataset.subtype === 'timeline') {
@@ -161,11 +169,43 @@
window.removeChildren(grid);
ids.forEach(id => {
let data = this.data.images[id]??{};
+ data.field = {
+ config: {
+ showMeta: true
+ }
+ };
data.id = id;
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 +346,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',
@@ -314,7 +358,8 @@
el.dataset.itemId = data.id;
if (refs.select) {
- window.prefixInput(refs.select, `${data.id}-`);
+ let wrapper = refs.select.closest('.preview');
+ window.prefixInput(refs.select, `${data.id}-`, wrapper);
}
if (refs.video) refs.video.remove();
if (refs.file) refs.file.remove();
@@ -326,18 +371,37 @@
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)) {
p.populateField(field, name, value);
}
- const input = field.querySelector('input:not([type="file"]), textarea');
+ const input = field.querySelector('input:not([type="file"])');
if (!input) continue;
- window.prefixInput(input, `[${data.id}]`);
+ window.prefixInput(input, `[${data.id}]`, field);
}
}
--
Gitblit v1.10.0