From 56a9a1ccf764ff7a6af8f8a2292cb07443cb4aa7 Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Thu, 28 May 2026 18:19:57 +0000
Subject: [PATCH] =New Gitbit setpu

---
 inc/registrar/fields/Field.php |   71 ++++++++++++++++++++++++++++++-----
 1 files changed, 60 insertions(+), 11 deletions(-)

diff --git a/inc/registrar/fields/Field.php b/inc/registrar/fields/Field.php
index add97be..c1d5e33 100644
--- a/inc/registrar/fields/Field.php
+++ b/inc/registrar/fields/Field.php
@@ -19,6 +19,11 @@
 	protected bool $quickEdit = true;	// whether to show in quick edit table
 	protected bool $quill;				// whether to use quill
 	protected int $maxLength;			// of characters
+	protected int $min;
+	protected int $max;
+	protected string $subtype;
+	protected array $condition;
+	protected array $allowedSubtype = ['text', 'url','number','tel','email','number'];
 	/**
 	 * @var ?bool For timeline post types. Indicates whether all posts get this field, or just the parent
 	 */
@@ -50,10 +55,10 @@
 
 		foreach ($config as $key => $value) {
 			if (property_exists($class, $key)) {
-				$method = 'set' . ucfirst($key);
+				$method = 'set'.implode('',array_map('ucfirst',explode('_', $key)));;
 				$class->$method($value);
 			} else {
-				error_log('Instance: '.print_r($class, true));
+//				error_log('Instance: '.print_r($class, true));
 				error_log('[JVBase\registrar\Field] Invalid key for '.$name.': '.$key);
 			}
 		}
@@ -76,7 +81,7 @@
 		return $this->hint;
 	}
 
-	protected function setType(string $type):void{
+	public function setType(string $type):void{
 		$allowed = array_keys(MetaTypeManager::getTypes());
 		if (!in_array($type, $allowed)) {
 			error_log('[JVBase\registrar\Field] Invalid type attempted '.$type);
@@ -85,24 +90,24 @@
 		$this->type = $type;
 	}
 
-	protected function setLabel(string $label):void{
+	public function setLabel(string $label):void{
 		$this->label = $label;
 	}
-	protected function setRequired(bool $required):void{
+	public function setRequired(bool $required):void{
 		$this->required = $required;
 	}
-	protected function setHidden(bool $hidden):void{
+	public function setHidden(bool $hidden):void{
 		$this->hidden = $hidden;
 	}
-	protected function setQuickEdit(bool $quickEdit):void{
+	public function setQuickEdit(bool $quickEdit):void{
 		$this->quickEdit = $quickEdit;
 	}
-	protected function setDefault(mixed $default):void
+	public function setDefault(mixed $default):void
 	{
 		$this->default = $default;
 	}
 
-	protected function setQuill(bool $quill):void
+	public function setQuill(bool $quill):void
 	{
 		$this->quill = $quill;
 	}
@@ -123,8 +128,23 @@
 	{
 		return $this->section??null;
 	}
-
-	protected function setMaxLength(int $maxLength):void
+	public function setMin(int $min):void
+	{
+		$this->min = $min;
+	}
+	public function getMin():?int
+	{
+		return $this->min??null;
+	}
+	public function setMax(int $max):void
+	{
+		$this->max = $max;
+	}
+	public function getMax():?int
+	{
+		return $this->max??null;
+	}
+	public function setMaxLength(int $maxLength):void
 	{
 		$this->maxLength = $maxLength;
 	}
@@ -149,4 +169,33 @@
 			}
 		}, $config);
 	}
+	public function setSubtype(string $subtype):void
+	{
+		if (!in_array($subtype, $this->allowedSubtype)) {
+			error_log('[SelectorField]Attempted subtype not allowed: '.$subtype);
+			return;
+		}
+		$this->subtype = $subtype;
+	}
+	public function getSubtype():string
+	{
+		return $this->subtype;
+	}
+
+	public function setCondition(array $condition):void
+	{
+		$required = ['field', 'operator', 'value'];
+		foreach ($required as $field) {
+			if (!array_key_exists($field, $condition)) {
+				error_log('[Field]::setCondition Required condition '.$field.' not found');
+				return;
+			}
+		}
+
+		$this->condition = $condition;
+	}
+	public function getCondition(array $condition):array
+	{
+		return $this->condition;
+	}
 }

--
Gitblit v1.10.0