Jake Vanderwerf
2026-01-02 e6287fd606e6e3220261fd68c394989e6ade0f90
JVBase.php
@@ -1,14 +1,21 @@
<?php
namespace JVBase;
use JVBase\blocks\CustomBlocks;
use JVBase\integrations\BlueSky;
use JVBase\managers\CacheManager;
use JVBase\managers\EmailManager;
use JVBase\managers\ErrorHandler;
use JVBase\managers\LoginManager;
use JVBase\managers\MagicLinkManager;
use JVBase\managers\OperationQueue;
use JVBase\managers\DashboardManager;
use JVBase\managers\DirectoryManager;
use JVBase\managers\ReferralManager;
use JVBase\managers\RoleManager;
use JVBase\managers\SchemaManager;
//use JVBase\managers\SchemaManager;
use JVBase\managers\SEO\SchemaOutputManager;
use JVBase\managers\SEO\SEOAdminPage;
use JVBase\managers\AdminPages;
use JVBase\managers\NotificationManager;
use JVBase\managers\UserTermsManager;
@@ -22,6 +29,7 @@
use JVBase\rest\routes\BioRoutes;
use JVBase\rest\routes\SettingsRoutes;
use JVBase\rest\routes\ShopRoutes;
use JVBase\rest\routes\SEORoutes;
use JVBase\rest\routes\QueueRoutes;
use JVBase\rest\routes\ErrorRoutes;
use JVBase\rest\routes\FormRoutes;
@@ -51,6 +59,7 @@
   protected array $integrations = [];
    protected array $blocks = [];
    protected array $routes = [];
   protected CustomBlocks $customBlocks;
   protected array $serviceMap = [
      'maps' => 'JVBase\integrations\GoogleMaps',
@@ -76,21 +85,34 @@
    public function __construct()
    {
      $this->customBlocks = new CustomBlocks();
        $this->managers = [
            'errors'        => new ErrorHandler(),
            'queue'         => new OperationQueue(),
//            'dash'          => new DashboardManager(),
            'roles'         => new RoleManager(),
//            'forms'         => new FormManager(),
            'schema'        => new SchemaManager(),
            'schema'        => new SchemaOutputManager(),
            'admin'         => new AdminPages(),
         'seoAdmin'     => new SEOAdminPage(),
//       'uploads'      => new UploadManager(),
         'userTerms'    => new UserTermsManager(),
         'email'        => new EmailManager(),
        ];
      $this->routes = [
         'login'        => new LoginRoutes(),
         'integrations' => new IntegrationsRoutes(),
         'seo'          => new SEORoutes(),
         'queue'        => new QueueRoutes(),
         'settings'     => new SettingsRoutes(),
         'upload'       => new UploadRoutes(),
         'forms'        => new FormRoutes()
      ];
      if (Features::forSite()->has('magicLink')) {
         $this->routes['magicLink'] = new MagicLinkRoutes();
         $this->managers['magicLink'] = new MagicLinkManager();
      }
      if (Features::forSite()->has('referrals')) {
         $this->managers['referral'] = new ReferralManager();
@@ -105,10 +127,6 @@
         $this->routes['square'] = new IntegrationsSquareRoutes();
      }
        $this->routes = [
         'login'        => new LoginRoutes(),
         'integrations' => new IntegrationsRoutes(),
      ];
        if (Features::forSite()->has('feed_block')) {
            $this->routes['feed'] = new FeedRoutes();
        }
@@ -120,9 +138,11 @@
            $this->routes['term'] = new TermRoutes();
        }
      $this->routes['queue']  = new QueueRoutes();
      $this->routes['settings']= new SettingsRoutes();
      $this->routes['upload'] = new UploadRoutes();
      if (Features::forSite()->has('is_directory')) {
         $this->managers['directory'] = new DirectoryManager();
      }
        if (jvbSiteHasDashboard()) {
            $this->routes['error']  = new ErrorRoutes();
            $this->routes['admin']  = new AdminRoutes();
@@ -131,7 +151,6 @@
            $this->routes['shop']   = new ShopRoutes();
            $this->routes['options']= new OptionsRoutes();
        }
      $this->routes['forms']= new FormRoutes();
        if (jvbSiteHasFavourites()) {
            $this->routes['favourites'] = new FavouritesRoutes();
@@ -183,11 +202,15 @@
    {
        return array_merge(array_keys($this->content), array_keys($this->taxonomies));
    }
    public function dashboard()
    public function dashboard():DashboardManager|false
    {
        return $this->managers['dash'];
        return $this->managers['dash']??false;
    }
    public function error()
   public function directories():DirectoryManager|false
   {
      return $this->managers['directory']??false;
   }
    public function error():ErrorHandler
    {
        return $this->managers['errors'];
    }
@@ -195,11 +218,11 @@
    {
        return $this->managers['file'];
    }
    public function cache()
    public function cache():CacheManager
    {
        return $this->managers['cache'];
    }
    public function queue()
    public function queue():OperationQueue
    {
        return $this->managers['queue'];
    }
@@ -207,9 +230,9 @@
//    {
//        return $this->managers['forms'];
//    }
    public function notification()
    public function notification():NotificationManager|false
    {
        return $this->managers['notifications'];
        return $this->managers['notifications']??false;
    }
    public function routes($route):mixed
    {
@@ -218,7 +241,7 @@
        }
        return false;
    }
    public function roles()
    public function roles():RoleManager
    {
        return $this->managers['roles'];
    }
@@ -226,10 +249,14 @@
    {
        return $this->managers['admin'];
    }
   public function seoAdmin()
   {
      return $this->managers['seoAdmin'];
   }
    public function getFields($type):array
    {
        $content = JVB_CONTENT[$type]??JVB_TAXONOMY[$type]??JVB_USER[$type]??null;
        $content = JVB_CONTENT[$type]??JVB_TAXONOMY[$type]??JVB_USER[$type]??[];
        return $content['fields']??[];
    }
    public function getContent($type):mixed
@@ -272,9 +299,19 @@
      $this->routes[$slug] = $class;
   }
   public function referrals():ReferralManager
   public function email():EmailManager
   {
      return $this->managers['referral'];
      return $this->managers['email'];
   }
   public function referrals():ReferralManager|false
   {
      return $this->managers['referral']??false;
   }
   public function magicLink():MagicLinkManager|false
   {
      return $this->managers['magicLink']??false;
   }
   public function additionalActions():void
@@ -309,4 +346,9 @@
         <?php
      }
   }
   public function blocks():CustomBlocks|bool
   {
      return $this->customBlocks??false;
   }
}