From a9b3b28d001941921aa70d37fdc87c758a163a44 Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Fri, 05 Jun 2026 16:47:03 +0000
Subject: [PATCH] =Some hefty changes to FeedBlock. Transitioning to loading first page in php to save on extra requests. Got a bit to do yet, but I have to work on Northeh for a bit here.

---
 inc/integrations/Square.php |   61 +++++++++++++++++++++++-------
 1 files changed, 46 insertions(+), 15 deletions(-)

diff --git a/inc/integrations/Square.php b/inc/integrations/Square.php
index 8c0f234..fda4da4 100644
--- a/inc/integrations/Square.php
+++ b/inc/integrations/Square.php
@@ -4,6 +4,7 @@
 use JVBase\meta\Form;
 use JVBase\meta\Meta;
 use Exception;
+use JVBase\registrar\Registrar;
 use JVBase\registry\PostTypeRegistrar;
 use WP_Error;
 use JVBase\ui\Checkout;
@@ -1384,7 +1385,12 @@
 	 */
 	protected function getVariationMapping(string $post_type): array
 	{
-		$product_type = JVB_CONTENT[jvbNoBase($post_type)]['integrations']['square']['content_type'] ?? 'REGULAR';
+		$registrar = Registrar::getInstance($post_type);
+		if (!$registrar) {
+			return [];
+		}
+		$config = $registrar->getIntegrationConfig($this->service_name);
+		$product_type = $config['content_type']??'REGULAR';
 		$valid_fields = $this->getValidFieldsForProductType($product_type);
 
 		$defaults = [
@@ -1453,7 +1459,12 @@
 	 */
 	protected function getFieldMapping(string $post_type): array
 	{
-		$product_type = JVB_CONTENT[jvbNoBase($post_type)]['integrations']['square']['content_type'] ?? 'REGULAR';
+		$registrar = Registrar::getInstance($post_type);
+		if (!$registrar) {
+			return [];
+		}
+		$config = $registrar->getIntegrationConfig($this->service_name);
+		$product_type = $config['content_type']??'REGULAR';
 		$valid_fields = $this->getValidFieldsForProductType($product_type);
 
 		$defaults = [
@@ -1649,7 +1660,7 @@
 
 		// Set user role (assuming you have a customer role defined)
 		$user = new \WP_User($user_id);
-		$user->set_role(BASE.'foodie'); // Or whatever role from JVB_USER
+		$user->set_role(BASE.'foodie'); // Or whatever role
 
 		// Generate password reset key
 		$reset_key = get_password_reset_key($user);
@@ -1733,11 +1744,11 @@
 	public function trackUserLogin(string $user_login, \WP_User $user): void
 	{
 		// Check if user has Square integration
-		$roles = array_keys(JVB_USER);
-		$user_roles = $user->roles;
-
-		foreach ($user_roles as $role) {
-			if (isset(JVB_USER[$role]['integrations']['square']['is_customer'])) {
+		$role = jvbUserRole($user->ID);
+		$registrar = Registrar::getInstance($role);
+		if ($registrar) {
+			$config = $registrar->getIntegration($this->service_name);
+			if ($config->isCustomer()) {
 				$login_count = (int)get_user_meta($user->ID, BASE . '_square_login_count', true);
 				$login_count++;
 
@@ -1748,8 +1759,6 @@
 				if ($login_count % self::PASSWORD_RESET_INTERVAL === 0) {
 					$this->schedulePasswordReset($user->ID);
 				}
-
-				break;
 			}
 		}
 	}
@@ -1996,7 +2005,7 @@
 		wp_enqueue_script('jvb-square-checkout');
 
 		wp_localize_script('jvb-square-checkout', 'squareConfig', [
-			'isOpen'         => jvbIsOpen(),
+//TODO			'isOpen'         => jvbIsOpen(),
 			'application_id' => $this->credentials['client_id'] ?? '',
 			'location_id'    => $this->locationId,
 			'environment'    => $this->environment,
@@ -2235,16 +2244,21 @@
 	 */
 	private function importSquareItem(array $item): bool|int
 	{
+		//TODO: We need to add the post type to custom meta for Square, this is not good if we have multiple post types with the same product type
 		// Find matching content type
 		$product_type = $item['item_data']['product_type'] ?? 'REGULAR';
 		$post_type = null;
 
-		foreach (JVB_CONTENT as $key => $config) {
-			if (isset($config['integrations']['square']['content_type']) &&
-				$config['integrations']['square']['content_type'] === $product_type) {
-				$post_type = jvbCheckBase($key);
+		foreach (Registrar::getRegistered() as $registrar) {
+			if (!$registrar->hasIntegration($this->service_name)) {
+				continue;
+			}
+			$config = $registrar->getIntegration($this->service_name);
+			if ($config->getContent_type() && $config->getContent_type() === $product_type) {
+				$post_type = jvbCheckBase($registrar->getSlug());
 				break;
 			}
+
 		}
 
 		if (!$post_type) {
@@ -2744,6 +2758,23 @@
 			'GIFT_CARD'	=> array_merge($this->setGiftCardFields())
 		];
 	}
+	public function getAdditionalFields(?string $content_type = null):array {
+		if ($content_type && array_key_exists($content_type, $this->contentTypes)){
+			$array = $this->contentTypes[$content_type];
+			return array_combine(
+				array_map(fn($k) => 'sq_' . $k, array_keys($array)),
+				$array
+			);
+		} else if ($content_type && !array_key_exists($content_type, $this->contentTypes)) {
+			error_log('Could not get default fields for '.$this->service_name.' content type: '.$content_type);
+			return [];
+		}
+		$array = $this->setBaseFields();
+		return array_combine(
+			array_map(fn($k) => 'sq_' . $k, array_keys($array)),
+			$array
+		);
+	}
 	protected function setBaseFields():array
 	{
 		return [

--
Gitblit v1.10.0