From c32ed859f4abd1591c882f4f2a6ee16b1ec275e2 Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Tue, 12 May 2026 14:03:27 +0000
Subject: [PATCH] =A little form recovery magic

---
 inc/managers/SEO/BreadcrumbManager.php |   52 ++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 36 insertions(+), 16 deletions(-)

diff --git a/inc/managers/SEO/BreadcrumbManager.php b/inc/managers/SEO/BreadcrumbManager.php
index 72929a2..bb33a3d 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;
 
@@ -117,10 +117,20 @@
 				$content = is_array($registrar->registrar->for) ? $registrar->registrar->for[0] : $registrar->registrar->for;
 				$contentRegistrar = Registrar::getInstance($content);
 
-				$crumbs[] = [
-					'name' => $contentRegistrar->getConfig('breadcrumbs')['title']??$contentRegistrar->getPlural(),
-					'url'  => get_post_type_archive_link(jvbCheckBase($content)),
-				];
+				if($contentRegistrar && $contentRegistrar->hasFeature('show_directory')) {
+					$directory = JVB()->directories();
+					if ($directory && !empty($directory->directories($content)??[])){
+						$crumbs[] = [
+							'name'	=> $directory->directories($content)['title'],
+							'url'	=>$directory->directories($content)['url']
+						];
+					}
+				} else {
+					$crumbs[] = [
+						'name' => $contentRegistrar->getConfig('breadcrumbs')['title']??$contentRegistrar->getPlural(),
+						'url'  => get_post_type_archive_link(jvbCheckBase($content)),
+					];
+				}
 //				$crumbs[] = [
 //					'name' => 'By ' . $registrar->getSingular(),
 //					'url'  => false,
@@ -131,11 +141,13 @@
 
 		// 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
@@ -156,11 +168,11 @@
 		}
 
 		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']
 				];
 			}
 		}
@@ -173,7 +185,7 @@
 				if ($pos['title'] == 'Map') {
 					$crumbs[] = [
 						'name' => 'Tattoo Shops',
-						'url'  => JVB()->directories()?->directories(BASE.'shop')['url']
+						'url'  => JVB()->directories()->directories(BASE.'shop')['url']
 					];
 				}
 
@@ -203,7 +215,15 @@
 		$name = jvbNoBase($type);
 
 		$registrar = Registrar::getInstance($name);
-		if (Features::forSite()->has('is_directory') && $name === 'directory') {
+		if($registrar && $registrar->hasFeature('show_directory')) {
+			$directory = JVB()->directories();
+			if ($directory && !empty($directory->directories($name)??[])){
+				$crumbs[] = [
+					'name'	=> $directory->directories($name)['title'],
+					'url'	=>$directory->directories($name)['url']
+				];
+			}
+		} elseif (Site::has('is_directory') && $name === 'directory') {
 			$crumbs[] = [
 				'name'	=> JVB()->directories()->referAs(true),
 				'url'	=> get_post_type_archive_link($type)

--
Gitblit v1.10.0