From ba1e1ccf869b818f7a7a897264dfea05563a7796 Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Sun, 07 Jun 2026 20:10:20 +0000
Subject: [PATCH] =Major overhaul of Integrations. Playing around with adding fields to post types through Registrar from an integrations' class file.
---
inc/registrar/helpers/AddIntegrationFields.php | 20 +++++++++++---------
1 files changed, 11 insertions(+), 9 deletions(-)
diff --git a/inc/registrar/helpers/AddIntegrationFields.php b/inc/registrar/helpers/AddIntegrationFields.php
index fde540d..1f3fd11 100644
--- a/inc/registrar/helpers/AddIntegrationFields.php
+++ b/inc/registrar/helpers/AddIntegrationFields.php
@@ -3,7 +3,7 @@
use JVBase\registrar\config\Integration;
use JVBase\registrar\Registrar;
-use JVBase\utility\Features;
+use JVBase\base\Site;
if (!defined('ABSPATH')) {
exit;
@@ -11,13 +11,13 @@
class AddIntegrationFields {
protected string $service_name;
- protected Registrar $registrar;
+ private Registrar $registrar;
protected Integration $config;
protected array $allowed;
public function __construct(string $service_name, ?Registrar $registrar = null) {
$this->initAllowed();
- if (!in_array($service_name, $this->allowed)) {
+ if (!array_key_exists($service_name, $this->allowed)) {
return;
}
@@ -28,26 +28,27 @@
$this->config = $registrar->getIntegration($service_name);
+ add_action('jvb_define_integrations', [$this, 'addIntegrationFields'],20);
}
protected function initAllowed():void
{
$allowed = [];
- if (Features::hasIntegration('gmb')) {
+ if (Site::hasIntegration('gmb')) {
$allowed['gmb'] = 'Google My Business';
}
- if (Features::hasIntegration('facebook')) {
+ if (Site::hasIntegration('facebook')) {
$allowed['facebook'] = 'Facebook';
}
- if (Features::hasIntegration('square')) {
+ if (Site::hasIntegration('square')) {
$allowed['square'] = 'Square';
}
- if (Features::hasIntegration('instagram')) {
+ if (Site::hasIntegration('instagram')) {
$allowed['instagram'] = 'Instagram';
}
- if (Features::hasIntegration('bluesky')) {
+ if (Site::hasIntegration('bluesky')) {
$allowed['bluesky'] = 'BlueSky';
}
- if (Features::hasIntegration('helcim')) {
+ if (Site::hasIntegration('helcim')) {
$allowed['helcim'] = 'Helcim';
}
$this->allowed = $allowed;
@@ -56,6 +57,7 @@
public function addIntegrationFields():void
{
$fields = $this->getIntegrationFields();
+// error_log('[AddIntegrationFields] adding fields for '.$this->service_name.': '.print_r($fields, true));
foreach ($fields as $fieldName => $fieldConfig) {
$this->registrar->fields()->addField($fieldName, $fieldConfig);
}
--
Gitblit v1.10.0