Jake Vanderwerf
2026-05-12 16cb63b05910055c31dca821c86f2eb815da99e3
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)