From 56a9a1ccf764ff7a6af8f8a2292cb07443cb4aa7 Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Thu, 28 May 2026 18:19:57 +0000
Subject: [PATCH] =New Gitbit setpu

---
 inc/managers/SEO/BreadcrumbManager.php |   37 +++++++++++++++++++------------------
 1 files changed, 19 insertions(+), 18 deletions(-)

diff --git a/inc/managers/SEO/BreadcrumbManager.php b/inc/managers/SEO/BreadcrumbManager.php
index 341debf..225e615 100644
--- a/inc/managers/SEO/BreadcrumbManager.php
+++ b/inc/managers/SEO/BreadcrumbManager.php
@@ -25,7 +25,6 @@
 	private function __construct()
 	{
 		$this->cache = Cache::for('breadcrumbs', MONTH_IN_SECONDS)->connect('post')->connect('taxonomy')->connect('user');
-		$this->cache->flush();
 		if (JVB_TESTING) {
 			$this->cache->flush();
 		}
@@ -50,7 +49,9 @@
 			return [];
 		}
 
+
 		switch (true) {
+
 			case is_singular():
 				$key = get_queried_object_id();
 				break;
@@ -62,6 +63,10 @@
 				$obj = get_queried_object();
 				$key = $obj->taxonomy;
 				break;
+			case is_home():
+				$obj = get_queried_object();
+				$key = $obj->post_type;
+				break;
 			default:
 				$key = 'home';
 				break;
@@ -93,7 +98,7 @@
 		$obj = get_queried_object();
 		if (is_tax()) {
 			$crumbs = $this->addTaxonomyCrumbs($crumbs, $obj);
-		} elseif (is_singular()) {
+		} elseif (is_singular() || is_home()) {
 			$crumbs = $this->addArchiveCrumbs($crumbs, $obj);
 			$hierarchy = $this->addSingularCrumbs($crumbs, $obj);
 			$crumbs = $crumbs + $hierarchy;
@@ -140,12 +145,12 @@
 
 
 		// Add directory if exists
-		if ($registrar && $registrar->hasFeature('directory')) {
+		if ($registrar && $registrar->hasFeature('show_directory')) {
 			$directory = JVB()->directories();
-			if ($directory && !empty($directory->directories($tax))) {
+			if ($directory && !empty($directory->directories($tax)??[])) {
 				$crumbs[] = [
-					'name' => $directory['title'],
-					'url'  => $directory['url']
+					'name'	=> $directory->directories($tax)['title'],
+					'url'	=>$directory->directories($tax)['url']
 				];
 			}
 		}
@@ -167,16 +172,6 @@
 			$crumbConfig = $registrar->getConfig('breadcrumbs');
 		}
 
-		if($registrar && $registrar->hasFeature('show_directory')) {
-			$directory = JVB()->directories();
-			if ($directory && !empty($directory->directories($content)??[])){
-				$crumbs[] = [
-					'name'	=> $directory->directories($content)['title'],
-					'url'	=>$directory->directories($content)['url']
-				];
-			}
-		}
-
 		// Handle directory posts specially
 		if (JVB()->directories() && JVB()->directories()->isDirectory()) {
 			$pos = jvbGetDirectoryInfo();
@@ -211,13 +206,17 @@
 	 */
 	private function addArchiveCrumbs(array $crumbs, object $obj): array
 	{
+		if (is_singular('page') || is_home()) {
+			return $crumbs;
+		}
 		$type = is_singular() ? $obj->post_type : $obj->name;
 		$name = jvbNoBase($type);
 
 		$registrar = Registrar::getInstance($name);
 
-		if($registrar && $registrar->hasFeature('show_directory')) {
+		if($registrar && $registrar->hasFeature('show_directory') && JVB()->directories()) {
 			$directory = JVB()->directories();
+
 			if ($directory && !empty($directory->directories($name)??[])){
 				$crumbs[] = [
 					'name'	=> $directory->directories($name)['title'],
@@ -225,6 +224,7 @@
 				];
 			}
 		} elseif (Site::has('is_directory') && $name === 'directory') {
+
 			$crumbs[] = [
 				'name'	=> JVB()->directories()->referAs(true),
 				'url'	=> get_post_type_archive_link($type)
@@ -235,8 +235,9 @@
 				'url'	=> get_post_type_archive_link($type)
 			];
 		} else {
+			$postTypeObject = get_post_type_object($type);
 			$crumbs[] = [
-				'name'	=> $obj->label,
+				'name'	=> $postTypeObject->label,
 				'url'	=> get_post_type_archive_link($type)
 			];
 		}

--
Gitblit v1.10.0