From ac444cba221832c012c0435fdc8339fe9f37febb Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Mon, 11 May 2026 18:35:04 +0000
Subject: [PATCH] =Some changes to the CRUD.js editing, timeline post configuration

---
 inc/managers/SEO/BreadcrumbManager.php |   78 +++++++++++++++++++++-----------------
 1 files changed, 43 insertions(+), 35 deletions(-)

diff --git a/inc/managers/SEO/BreadcrumbManager.php b/inc/managers/SEO/BreadcrumbManager.php
index 8d3288e..5f7f0c6 100644
--- a/inc/managers/SEO/BreadcrumbManager.php
+++ b/inc/managers/SEO/BreadcrumbManager.php
@@ -3,7 +3,7 @@
 
 use JVBase\managers\Cache;
 use JVBase\registrar\Registrar;
-use JVBase\utility\Features;
+use JVBase\base\Site;
 use WP_Post;
 use WP_Term;
 
@@ -121,21 +121,23 @@
 					'name' => $contentRegistrar->getConfig('breadcrumbs')['title']??$contentRegistrar->getPlural(),
 					'url'  => get_post_type_archive_link(jvbCheckBase($content)),
 				];
-				$crumbs[] = [
-					'name' => 'By ' . $registrar->getSingular(),
-					'url'  => false,
-				];
+//				$crumbs[] = [
+//					'name' => 'By ' . $registrar->getSingular(),
+//					'url'  => false,
+//				];
 			}
 		}
 
 
 		// Add directory if exists
 		if ($registrar && $registrar->hasFeature('directory')) {
-			$directory = JVB()->directories()?->directories($tax);
-			$crumbs[] = [
-				'name' => $directory['title'],
-				'url'  => $directory['url']
-			];
+			$directory = JVB()->directories();
+			if ($directory && !empty($directory->directories($tax))) {
+				$crumbs[] = [
+					'name' => $directory['title'],
+					'url'  => $directory['url']
+				];
+			}
 		}
 
 		// Add term hierarchy
@@ -150,15 +152,17 @@
 		// Add directory if exists
 		$content = jvbNoBase($post->post_type);
 		$registrar = Registrar::getInstance($content);
+		$crumbConfig = false;
 		if ($registrar){
 			$crumbConfig = $registrar->getConfig('breadcrumbs');
 		}
+
 		if($registrar && $registrar->hasFeature('show_directory')) {
-			$directory = JVB()->directories()?->directories($content)??[];
-			if (!empty($directory)) {
+			$directory = JVB()->directories();
+			if ($directory && !empty($directory->directories($content)??[])){
 				$crumbs[] = [
-					'name'	=> $directory['title'],
-					'url'	=>$directory['url']
+					'name'	=> $directory->directories($content)['title'],
+					'url'	=>$directory->directories($content)['url']
 				];
 			}
 		}
@@ -171,7 +175,7 @@
 				if ($pos['title'] == 'Map') {
 					$crumbs[] = [
 						'name' => 'Tattoo Shops',
-						'url'  => JVB()->directories()?->directories(BASE.'shop')['url']
+						'url'  => JVB()->directories()->directories(BASE.'shop')['url']
 					];
 				}
 
@@ -201,7 +205,7 @@
 		$name = jvbNoBase($type);
 
 		$registrar = Registrar::getInstance($name);
-		if (Features::forSite()->has('is_directory') && $name === 'directory') {
+		if (Site::has('is_directory') && $name === 'directory') {
 			$crumbs[] = [
 				'name'	=> JVB()->directories()->referAs(true),
 				'url'	=> get_post_type_archive_link($type)
@@ -209,7 +213,7 @@
 		} elseif (is_post_type_archive() && $registrar && $registrar->hasFeature('show_directory')) {
 
 			$crumbs[] = [
-				'name' => $registrar->getConfig('breadcrumb')['title'] ?? $registrar->getPlural(),
+				'name' => $registrar->getConfig('breadcrumbs')['title'] ?? $registrar->getPlural(),
 				'url'  => get_post_type_archive_link($type)
 			];
 		}
@@ -366,29 +370,33 @@
 		}
 	}
 
-	public function addTaxToCrumbs(array $crumbs, string $taxonomy):array
+	public function addTaxToCrumbs(array $crumbs, string|array $taxonomy):array
 	{
 		$ID = get_the_ID();
-		$taxonomy = jvbCheckBase($taxonomy);
-		$terms = get_the_terms($ID, $taxonomy);
-		if ($terms && !is_wp_error($terms)) {
-			$term = $terms[0];
-			$ancestors = get_ancestors($term->term_id, $taxonomy, 'taxonomy');
-			$ancestors = array_reverse($ancestors);
-			foreach ($ancestors as $ancestor) {
-				$aTerm = get_term($ancestor, $taxonomy);
-				if ($aTerm && !is_wp_error($aTerm)) {
-					$crumbs[] = [
-						'name' => $aTerm->name,
-						'url'   => get_term_link($ancestor, $taxonomy)
-					];
+		$taxonomies = is_string($taxonomy) ? [$taxonomy] : $taxonomy;
+		foreach ($taxonomies as $tax) {
+			$taxonomy = jvbCheckBase($tax);
+			$terms = get_the_terms($ID, $taxonomy);
+			if ($terms && !is_wp_error($terms)) {
+				$term = $terms[0];
+				$ancestors = get_ancestors($term->term_id, $taxonomy, 'taxonomy');
+				$ancestors = array_reverse($ancestors);
+				foreach ($ancestors as $ancestor) {
+					$aTerm = get_term($ancestor, $taxonomy);
+					if ($aTerm && !is_wp_error($aTerm)) {
+						$crumbs[] = [
+							'name' => $aTerm->name,
+							'url'   => get_term_link($ancestor, $taxonomy)
+						];
+					}
 				}
+				$crumbs[] = [
+					'name' => html_entity_decode($term->name),
+					'url'   => get_term_link($term, $taxonomy)
+				];
 			}
-			$crumbs[] = [
-				'name' => html_entity_decode($term->name),
-				'url'   => get_term_link($term, $taxonomy)
-			];
 		}
+
 		return $crumbs;
 	}
 }

--
Gitblit v1.10.0