From 7a9054bb3f033c98067b3196378311dae54c5fbf Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Tue, 20 Jan 2026 01:31:53 +0000
Subject: [PATCH] =OperationQueue refactor to the JVBase/managers/queue namespace

---
 inc/rest/routes/FeedRoutes.php |   97 ++++++++++++++++++++++++++++--------------------
 1 files changed, 57 insertions(+), 40 deletions(-)

diff --git a/inc/rest/routes/FeedRoutes.php b/inc/rest/routes/FeedRoutes.php
index d37feea..05a97a7 100644
--- a/inc/rest/routes/FeedRoutes.php
+++ b/inc/rest/routes/FeedRoutes.php
@@ -40,7 +40,7 @@
 		$this->cache->clear();
 		$this->checker = Checker::getInstance();
 
-		if (jvbSiteUsesUmami()) {
+		if (Features::hasIntegration('umami')) {
 			$this->tracker = JVB()->connect('umami');
 		}
 		$this->setupCacheConnections();
@@ -146,33 +146,7 @@
 				];
 
 				//Format Taxonomies
-				$temp = array_filter($fields, function($field) {
-					return $field['type'] === 'taxonomy';
-				});
-				foreach ($temp as $key => $config) {
-					if (array_key_exists($key, $out['fields']) && $out['fields'][$key] !== '') {
-						$IDs = array_map('absint', explode(',', $out['fields'][$key]));
-						$data = [];
-						$icon = JVB_TAXONOMY[$config['taxonomy']]['icon']??jvbDefaultIcon();
-						foreach ($IDs as $ID) {
-							$term = get_term($ID, jvbCheckBase($config['taxonomy']));
-							if ($term && !is_wp_error($term)) {
-								$data[$ID] = [
-									'id' 	=> $ID,
-									'icon'	=> $icon,
-									'name'	=> $term->name,
-									'url'	=> get_term_link($ID, jvbCheckBase($config['taxonomy'])),
-								];
-								if ($this->tracker) {
-									$data[$ID]['umami_click'] = $this->tracker->trackClick($ID, $config['taxonomy'], ['from' => $type.'_'.$postID]);
-								}
-							}
-						}
-						if (!empty($data)) {
-							$out['fields'][$key] = $data;
-						}
-					}
-				}
+				$out['taxonomies'] = $this->extractTaxonomies($values, $postID, $type);
 
 				//Add images
 				$imgIDs = [];
@@ -263,6 +237,8 @@
 		$children = get_children(['post_parent' => $post->ID, 'orderby' => 'date', 'order' => 'ASC', 'post_status' => ['publish'], 'fields'=> 'ids']);
 		array_unshift($children, $post->ID);
 
+		$item['taxonomies'] = $this->extractTaxonomies($item['fields'], $postID, jvbNoBase($post->post_type));
+
 		$subFields = [];
 		$images = [];
 		foreach ($children as $child) {
@@ -270,25 +246,67 @@
 			$f = $meta->getAll($this->timelineUniqueFields);
 			$f =  ['id' => $child] + $f;
 			$subFields[] = $f;
-
+			$item['taxonomies'] = array_merge($item['taxonomies'], $this->extractTaxonomies($f, $postID, jvbNoBase($post->post_type)));
 			$images[$f['post_thumbnail']] = jvbImageData((int) $f['post_thumbnail']);
 		}
+		$item['fields']['number'] = count($children);
+		$item['fields']['before'] = get_post_thumbnail_id($children[0]);
+		$item['fields']['after'] = get_post_thumbnail_id($children[array_key_last($children)]);
+
 		$item['fields']['timeline'] = $subFields;
 		$item['images'] = $item['images'] + $images;
 
 		return $item;
 	}
+	protected function extractTaxonomies(array $fields, int $postID, string $content):array {
+		$taxonomies = [];
+		foreach ($fields as $key => $value) {
+			if (empty($value)) {
+				continue;
+			}
+			if (!array_key_exists($key, JVB_TAXONOMY)) {
+				continue;
+			}
 
-	protected function formatTaxonomy(WP_Term $term, int $postID, string $type)
+			$taxConfig = JVB_TAXONOMY[$key];
+			if (isset($taxConfig['public']) && $taxConfig['public'] === false) {
+				continue;
+			}
+			$terms = array_map('absint', explode(',', $value));
+			$terms = array_filter($terms); // Remove 0 values
+
+			if (empty($terms)) {
+				continue;
+			}
+			foreach($terms as $termID) {
+				$term = get_term($termID, jvbCheckBase($key));
+				if ($term && !is_wp_error($term)) {
+					$taxonomies[$key][$termID] = $this->formatTaxonomy($term, $postID, $content);
+				}
+			}
+		}
+		return $taxonomies;
+	}
+
+	protected function formatTaxonomy(WP_Term|int $term, int $postID, string $type)
 	{
-		return [
-			'ID' => $term->term_id,
-			'title' => htmlspecialchars_decode($term->name),
-			'url' => get_term_link($term->term_id, $term->taxonomy),
-			'umami_click' => $this->tracker->trackTaxonomyClick($term->term_id, $term->taxonomy, [
-				'from' => $type . '_' . $postID
-			])
-		];
+		$cache = CacheManager::for(jvbNoBase($term->taxonomy));
+		return $cache->remember(
+			'feed_link_'.$term->term_id,
+			function () use ($term, $postID, $type) {
+				$base = [
+					'ID' => $term->term_id,
+					'title' => htmlspecialchars_decode($term->name),
+					'url' => get_term_link($term->term_id, $term->taxonomy),
+				];
+				if ($this->tracker) {
+					$base['umami_click'] =$this->tracker->trackTaxonomyClick($term->term_id, $term->taxonomy, [
+						'from' => $type . '_' . $postID
+					]);
+				}
+				return $base;
+			}
+		);
 	}
 
 	protected function getAuthorData(WP_Post $post)
@@ -363,8 +381,7 @@
 		$args = $this->applyOrderFilters($args, $data);
 		$args = $this->applyDateFilters($args, $data);
 
-		$args = $this->applyFavouritesFilter($args, $data);
-		return $args;
+		return $this->applyFavouritesFilter($args, $data);
 	}
 
 	protected function applyTaxonomyFilters(array $args, array $data): array

--
Gitblit v1.10.0