From 474109a5df0a06f5343ab184838fe2d80e3872a8 Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Sun, 11 Jan 2026 19:23:20 +0000
Subject: [PATCH] =Fixed timeline CRUD.js issue where this.activeItem was set null when we still needed it

---
 inc/meta/MetaForm.php |  127 +++++++++++++++++++++---------------------
 1 files changed, 64 insertions(+), 63 deletions(-)

diff --git a/inc/meta/MetaForm.php b/inc/meta/MetaForm.php
index aa537c0..2324496 100644
--- a/inc/meta/MetaForm.php
+++ b/inc/meta/MetaForm.php
@@ -1100,71 +1100,72 @@
 		$dataID = ($id) ? ['id' => $id] : '';
 		?>
 		<div class="item upload"<?= ($id) ? ' data-id="'.$id.'"' : '' ?>>
-				<div class="preview">
-					<?php jvbRenderProgressBar('',true) ?>
-					<input type="checkbox" class="upload-select" name="select-item" id="select-item<?=$addID?>">
-					<label for="select-item<?=$addID?>" aria-label="Select image">
-						<?= ($attachment) ?: '<img>
-						<video></video>
-						<span></span>' ?>
-					</label>
-					<div class="item-actions row btw">
-						<div class="radio-button">
-							<input type="radio" class="featured btn" name="featured" id="featured" hidden>
-							<label for="featured">
-								<?=jvbIcon('star')?>
-								<?=jvbIcon('star', ['style' => 'fill'])?>
-								<span class="screen-reader-text">Set as featured image</span>
-							</label>
-						</div>
-
-						<button type="button" data-action="delete-upload" title="Remove from Group">
-							<?=jvbIcon('trash')?>
-						</button>
+			<div class="preview">
+				<?php jvbRenderProgressBar('',true) ?>
+				<input type="checkbox" class="upload-select" name="select-item" id="select-item<?=$addID?>">
+				<label for="select-item<?=$addID?>" aria-label="Select image">
+					<?= ($attachment) ?: '<img>
+                <video></video>
+                <span></span>' ?>
+				</label>
+				<div class="item-actions row btw">
+					<div class="radio-button">
+						<input type="radio" class="featured btn" name="featured" id="featured" hidden>
+						<label for="featured">
+							<?=jvbIcon('star')?>
+							<?=jvbIcon('star', ['style' => 'fill'])?>
+							<span class="screen-reader-text">Set as featured image</span>
+						</label>
 					</div>
+
+					<button type="button" data-action="delete-upload" title="Remove from Group">
+						<?=jvbIcon('trash')?>
+					</button>
 				</div>
-				<details>
-					<summary class="row btw"><?=jvbIcon('pencil-simple')?><span>Edit Info</span></summary>
+			</div>
+			<details>
+				<summary class="row btw"><?=jvbIcon('pencil-simple')?><span>Edit Info</span></summary>
 
-		<?php
+				<?php
+				$fields = array_key_exists('fields', $config) ? $config['fields'] : [];
 
-		$fields = array_key_exists('fields', $config) ? $config['fields'] : [];
-		$fields = array_merge([
-			'upload_data'	=> [
-				'type'	=> 'group',
-				'wrap'	=> 'details',
-				'label'	=> 'Image Info',
-				'hint'	=> 'These will be automatically generated if left blank.',
-				'fields'	=> [
-					'image-title'.$addID => [
-						'type'	=> 'text',
-						'label'	=> 'Image Title',
-						'value'	=> $title,
-						'data'	=> $dataID
-					],
-					'image-alt-text'.$addID => [
-						'type'	=> 'text',
-						'label'	=> 'Alt Text',
-						'value'	=> $alt,
-						'hint'	=> 'Alt text helps the visually impaired, as well as some benefits for SEO.',
-						'data'	=> $dataID
-					],
-					'image-caption'.$addID => [
-						'type'	=> 'textarea',
-						'value'	=> $caption,
-						'label'	=> 'Image Caption',
-						'data'	=> $dataID
-					]
-				]
-			]
-		], $fields);
+				// Only add image_data if not already provided
+				if (!array_key_exists('image_data', $fields)) {
+					$fields['image_data'] = [
+						'type'   => 'group',
+						'wrap'   => 'details',
+						'label'  => 'Image Info',
+						'hint'   => 'These will be automatically generated if left blank.',
+						'fields' => [
+							'image-title'.$addID => [
+								'type'  => 'text',
+								'label' => 'Image Title',
+								'value' => $title,
+								'data'  => $dataID
+							],
+							'image-alt-text'.$addID => [
+								'type'  => 'text',
+								'label' => 'Alt Text',
+								'value' => $alt,
+								'hint'  => 'Alt text helps the visually impaired, as well as some benefits for SEO.',
+								'data'  => $dataID
+							],
+							'image-caption'.$addID => [
+								'type'  => 'textarea',
+								'value' => $caption,
+								'label' => 'Image Caption',
+								'data'  => $dataID
+							]
+						]
+					];
+				}
 
-		$meta = new MetaManager($id);
-		foreach ($fields as $field => $config) {
-			$meta->render('form', $field, $config);
-		}
-		?>
-				</details>
+				$meta = new MetaManager($id);
+				foreach ($fields as $field => $config) {
+					$meta->render('form', $field, $config);
+				}
+				?>
+			</details>
 		</div>
 		<?php
 	}
@@ -1351,13 +1352,12 @@
 	 * Generic selector field renderer
 	 * Handles both taxonomy and post selectors with consistent structure
 	 */
-	private function renderSelectorField(string $name, mixed $value, array $field, string $type): void
+	public function renderSelectorField(string $name, mixed $value, array $field, string $type): void
 	{
 		$conditional = $this->handleConditionalField($field);
 		$validationAttrs = $this->buildValidationAttributes($field);
 		$describedBy = (!empty($field['description'])) ? ' aria-describedby="' . $name . '-help"' : '';
 
-		$isSimple = (array_key_exists('mode', $field) && $field['mode']==='simple');
 		// Parse selected values
 		$value = (is_array($value)) ? array_filter(array_map('absint', $value)): $value;
 		$selected = ($value === '') ? [] : (is_array($value) ? $value : explode(',', $value));
@@ -1408,9 +1408,10 @@
 		}
 
 		?>
-		<div class="field <?= esc_attr($type) ?> <?= esc_attr($name) ?>"
+		<div class="field selector <?= esc_attr($type) ?> <?= esc_attr($name) ?>"
 			<?= $conditional ?>
 			 data-field="<?= esc_attr($name) ?>"
+			 data-type="selector" data-subtype="<?= esc_attr($type)?>"
 			<?= $validationAttrs ?>
 			<?= $describedBy ?>>
 

--
Gitblit v1.10.0