From 5b5f37de365ff84fc231e414a719d1b2ff4ceff6 Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Thu, 01 Jan 2026 22:38:58 +0000
Subject: [PATCH] =further feed block testing

---
 JVBase.php |  137 ++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 116 insertions(+), 21 deletions(-)

diff --git a/JVBase.php b/JVBase.php
index f88c372..0b63b08 100644
--- a/JVBase.php
+++ b/JVBase.php
@@ -1,18 +1,27 @@
 <?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;
 use JVBase\rest\routes\FeedRoutes;
 use JVBase\rest\routes\FavouritesRoutes;
+use JVBase\rest\routes\IntegrationsSquareRoutes;
 use JVBase\rest\routes\NotificationsRoutes;
 use JVBase\rest\routes\ContentRoutes;
 use JVBase\rest\routes\TermRoutes;
@@ -20,10 +29,14 @@
 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;
+use JVBase\rest\routes\LoginRoutes;
 use JVBase\rest\routes\NewsRoutes;
+use JVBase\rest\routes\ReferralRoutes;
+use JVBase\rest\routes\MagicLinkRoutes;
 use JVBase\rest\routes\ResponseRoutes;
 use JVBase\rest\routes\OptionsRoutes;
 use JVBase\rest\routes\VoteRoutes;
@@ -46,6 +59,7 @@
 	protected array $integrations = [];
     protected array $blocks = [];
     protected array $routes = [];
+	protected CustomBlocks $customBlocks;
 
 	protected array $serviceMap = [
 		'maps' => 'JVBase\integrations\GoogleMaps',
@@ -57,6 +71,7 @@
 		'gmb' => 'JVBase\integrations\GoogleMyBusiness',
 		'cloudflare' => 'JVBase\integrations\Cloudflare',
 		'umami' => 'JVBase\integrations\Umami',
+		'postmark' => 'JVBase\integrations\PostMark',
 	];
 
     public static function getInstance():JVB
@@ -70,18 +85,35 @@
 
     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();
 			$this->routes['referral'] = new ReferralRoutes();
@@ -91,24 +123,27 @@
 			$this->managers['dash'] = new DashboardManager();
 		}
 
-        $this->routes = [
-			'integrations'	=> new IntegrationsRoutes(),
-		];
-        if (jvbSiteUsesFeedBlock()) {
+		if (Features::hasIntegration('square')){
+			$this->routes['square'] = new IntegrationsSquareRoutes();
+		}
+
+        if (Features::forSite()->has('feed_block')) {
             $this->routes['feed'] = new FeedRoutes();
         }
         if (jvbSiteHasNotifications()) {
 			$this->managers['notifications'] = new NotificationManager();
             $this->routes['notifications'] = new NotificationsRoutes();
         }
-        if (jvbSiteUsesFeedBlock() || jvbSiteHasDashboard()) {
+        if (Features::forSite()->has('feed_block') || jvbSiteHasDashboard()) {
             $this->routes['term'] = new TermRoutes();
         }
 
+		if (Features::forSite()->has('is_directory')) {
+			$this->managers['directory'] = new DirectoryManager();
+		}
+
+
         if (jvbSiteHasDashboard()) {
-            $this->routes['upload'] = new UploadRoutes();
-            $this->routes['settings']= new SettingsRoutes();
-            $this->routes['queue']  = new QueueRoutes();
             $this->routes['error']  = new ErrorRoutes();
             $this->routes['admin']  = new AdminRoutes();
             $this->routes['content']= new ContentRoutes();
@@ -116,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();
@@ -141,6 +175,8 @@
         }
 
 		$this->setupIntegrations();
+
+		add_action('wp_footer', [$this, 'additionalActions']);
 //        $this->managers['notifications'] = new NotificationManager();
         // Register activation hook
         register_activation_hook(JVB_DIR . '/jvb.php', [$this, 'activate']);
@@ -166,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'];
     }
@@ -178,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'];
     }
@@ -190,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
     {
@@ -201,7 +241,7 @@
         }
         return false;
     }
-    public function roles()
+    public function roles():RoleManager
     {
         return $this->managers['roles'];
     }
@@ -209,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
@@ -246,7 +290,6 @@
 
     public function activate():void
     {
-        error_log('Activate!');
         // Activate roles - will be properly initialized after post types are registered
         $this->roles()->activate();
     }
@@ -256,4 +299,56 @@
 		$this->routes[$slug] = $class;
 	}
 
+	public function email():EmailManager
+	{
+		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
+	{
+		if (LoginManager::isLogin()) {
+			return;
+		}
+		$extras = apply_filters('jvbAdditionalActions', []);
+		$extras = array_filter($extras, function ($extra) {
+			return is_array($extra) && array_key_exists('button', $extra) && array_key_exists('content', $extra);
+		});
+		if (empty ($extras)) {
+			return;
+		}
+		$buttons = array_map(function ($extra) {
+			return $extra['button'];
+		}, $extras);
+		$contents = array_map(function($extra) {
+			return $extra['content'];
+		}, $extras);
+
+		if (!empty ($buttons)) {
+			?>
+			<section class="additional-actions">
+				<div class="buttons col">
+					<?= implode($buttons); ?>
+				</div>
+				<div class="actions">
+					<?= implode($contents); ?>
+				</div>
+			</section>
+			<?php
+		}
+	}
+
+	public function blocks():CustomBlocks|bool
+	{
+		return $this->customBlocks??false;
+	}
 }

--
Gitblit v1.10.0