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/forms/TaxonomySelector.php |   46 ++++++++++++++++++++++++++++------------------
 1 files changed, 28 insertions(+), 18 deletions(-)

diff --git a/inc/forms/TaxonomySelector.php b/inc/forms/TaxonomySelector.php
index 9409b61..8e4d0c1 100644
--- a/inc/forms/TaxonomySelector.php
+++ b/inc/forms/TaxonomySelector.php
@@ -1,6 +1,7 @@
 <?php
 namespace JVBase\forms;
 
+use JVBase\registrar\Registrar;
 use WP_Term;
 
 if (!defined('ABSPATH')) {
@@ -27,13 +28,19 @@
 	protected string $base;
 	protected string $title;
 	protected array $config;
+	protected Registrar $registrar;
 
 	public function __construct(string $id, string $taxonomy, array $config = []) {
 		$this->id = sanitize_key($id);
 		$this->taxonomy = jvbCheckBase($taxonomy);
 		$this->name = jvbNoBase($taxonomy);
 
-		$this->title = JVB_TAXONOMY[$this->name]['plural'];
+		$registrar = Registrar::getInstance($this->name);
+		if ($registrar) {
+			$this->registrar = $registrar;
+		}
+
+		$this->title = $registrar->getPlural();
 		$this->base = $config['base']??'';
 		$this->config = wp_parse_args($config, [
 			'types'		=> false, // for feed block implementation
@@ -50,8 +57,9 @@
 			'update'	=> true,   // Whether to update on close
 		]);
 
-		$this->plural = JVB_TAXONOMY[$taxonomy]['plural'];
-		$this->singular = JVB_TAXONOMY[$taxonomy]['singular'];
+
+		$this->plural = $registrar->getPlural();
+		$this->singular = $registrar->getSingular();
 	}
 
 
@@ -64,14 +72,14 @@
 	 */
 	public static function getTermPath(WP_Term $term, bool $returnArray = false): string|array {
 		if (!is_taxonomy_hierarchical($term->taxonomy)) {
-			return $term->name;
+			return html_entity_decode($term->name);
 		}
 
 		$path = [];
 		$currentTerm = $term;
 
 		while ($currentTerm) {
-			array_unshift($path, $currentTerm->name);
+			array_unshift($path, html_entity_decode($currentTerm->name));
 
 			if ($currentTerm->parent) {
 				$currentTerm = get_term($currentTerm->parent);
@@ -94,7 +102,7 @@
 		?>
 		<dialog id="jvb-selector" aria-labelledby="modal-title" aria-modal="true">
 			<div class="wrap col">
-				<header class="modal-header">
+				<header class="row">
 					<h3 id="modal-title">Select Taxonomy</h3>
 				</header>
 
@@ -104,8 +112,8 @@
 				<div class="items-wrap">
 					<!-- Common/Favorite terms section -->
 					<details class="favourite-terms" hidden>
-						<summary class="title row btw">Your Go Tos:</summary>
-						<ul class="favourite-list row btw"></ul>
+						<summary class="title row x-btw">Your Go Tos:</summary>
+						<ul class="favourite-list row x-btw"></ul>
 					</details>
 
 					<!-- Pagination info -->
@@ -123,7 +131,7 @@
 						{ <span>loading items</span> }
 					</p>
 					<!-- Terms list -->
-					<ul class="items-container col start" role="listbox" aria-label="Available terms">
+					<ul class="items-container col top" role="listbox" aria-label="Available terms">
 						<!-- Terms will be populated here -->
 					</ul>
 
@@ -136,13 +144,13 @@
 				<!-- Search section -->
 				<div class="search-wrapper">
 					<div class="search-bar">
-						<?= jvbSearch('Search terms', 'search-terms') ?>
+						<?= str_replace('class="search-container', 'class="open search-container', jvbSearch('Search terms', 'search-terms')) ?>
 					</div>
 				</div>
 
 				<!-- Create new term section -->
 				<details class="create-term" hidden>
-					<summary class="row btw">Add New Term</summary>
+					<summary class="row x-btw">Add New Term</summary>
 					<div class="create-new-term-section">
 						<form class="create-term" data-nocache data-form-id="create-term" data-save="terms">
 							<div class="form-group">
@@ -188,7 +196,7 @@
 		<template class="selectedTerm">
 			<div class="selected-item row">
 				<span class="item-name"></span>
-				<button type="button" class="remove-term row"><?=jvbIcon('x')?></button>
+				<button type="button" class="remove-term"><?=jvbIcon('x')?></button>
 			</div>
 		</template>
 		<template class="termBreadcrumb">
@@ -222,7 +230,7 @@
 		?>
 		<div class="jvb-selector <?= esc_attr($this->name) ?>"
 			 id="<?= esc_attr($this->id) ?>"<?= $hidden ?>>
-			<div class="field-group-header row btw">
+			<div class="field-group-header row x-btw">
 				<label for="<?= $this->base ?><?= esc_attr($this->config['name']) ?>-autocomplete">
 					<?= ($this->config['icon']) ? jvbIcon($this->config['icon']) : '' ?>
 					<span><?= $this->config['label'] ?></span>
@@ -261,7 +269,7 @@
 				$selectedItems = ob_get_clean();
 			endif;
 			?>
-			<div class="selected-items row" role="region" aria-label="Selected <?= esc_attr($this->plural) ?>"><?=$selectedItems?></div>
+			<div class="selected-items row left" role="region" aria-label="Selected <?= esc_attr($this->plural) ?>"><?=$selectedItems?></div>
 			<?= $extra ?>
 		</div>
 		<?php
@@ -270,14 +278,16 @@
 
 	protected function renderTaxonomyToggle(array $selected = [], string $extra = ''): string
 	{
+
 		return sprintf(
-			'<button type="button" data-icon="%s" data-filter="taxonomy" data-taxonomy="%s" data-type="selector" data-single="%s" data-plural="%s" title="Filter by %s">%s<span class="label">%s</span></button>',
-			JVB_TAXONOMY[$this->name]['icon'],
+			'<button type="button" data-icon="%s" data-filter="taxonomy" data-taxonomy="%s" data-type="selector" data-single="%s" data-plural="%s" %stitle="Filter by %s">%s<span class="label">%s</span></button>',
+			$this->registrar->getIcon(),
 			$this->name,
 			$this->singular,
 			$this->plural,
+			$this->buildDataAttributes([]),
 			$this->singular,
-			jvbIcon($this->config['icon']),
+			jvbIcon($this->registrar->getIcon()),
 			$this->singular
 		);
 	}
@@ -342,7 +352,7 @@
 			<span><?= esc_html($termPath) ?></span>
 			<button type="button"
 					class="remove-term row"
-					aria-label="Remove <?= esc_attr($term->name) ?>">
+					aria-label="Remove <?= html_entity_decode($term->name) ?>">
 				<?= jvbIcon('x') ?>
 			</button>
 		</div>

--
Gitblit v1.10.0