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/ui/CRUDSkeleton.php |  109 ++++++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 80 insertions(+), 29 deletions(-)

diff --git a/inc/ui/CRUDSkeleton.php b/inc/ui/CRUDSkeleton.php
index de191ce..d1d4834 100644
--- a/inc/ui/CRUDSkeleton.php
+++ b/inc/ui/CRUDSkeleton.php
@@ -578,7 +578,7 @@
 	protected function renderUploader(): void {
 		?>
 		<details open class="uploader">
-			<summary class="row btw"><?= esc_html($this->uploaderConfig['label'] ?? 'Upload Files') ?></summary>
+			<summary class="row x-btw"><?= esc_html($this->uploaderConfig['label'] ?? 'Upload Files') ?></summary>
 			<form id="uploader" data-form-id="upload_new_<?=$this->dataType ?>">
 				<?php
 				echo jvbFormRestore();
@@ -624,7 +624,7 @@
 			return;
 		}
 		?>
-		<details class="all-filters col start" data-ignore>
+		<details class="all-filters col top" data-ignore>
 			<summary>Filters</summary>
 			<?php
 
@@ -649,7 +649,7 @@
 			return;
 		}
 		?>
-		<div class="search row start nowrap">
+		<div class="search row left nowrap">
 			<span class="label">Search:</span>
 			<?= jvbSearch() ?>
 		</div>
@@ -662,7 +662,7 @@
 			return;
 		}
 		?>
-		<div class="radio-options view row">
+		<div class="radio-options view row left">
 			<span class="label">View:</span>
 			<?php
 			$views = [
@@ -683,7 +683,7 @@
 				<label for="view-<?=$view?>"
 				   title="<?=$views[$view]['label']?>">
 					<?= jvbDashIcon($views[$view]['icon']) ?>
-					<span class="screen-reader-text"><?=$views[$view]['label']?></span>
+					<span class="label"><?=$views[$view]['label']?></span>
 				</label>
 				<?php
 			}
@@ -698,7 +698,7 @@
 			return;
 		}
 		?>
-		<div class="radio-options status row">
+		<div class="radio-options status row left">
 			<span class="label">Status:</span>
 			<?php
 			$i = 1;
@@ -713,6 +713,7 @@
 				<input type="radio" class="btn" data-filter="status" value="<?=$status?>" name="status" id="<?=$status?>"<?=$checked?>>
 				<label for="<?=$status?>" title="<?=$config['label']?>">
 					<?= jvbDashIcon($config['icon']) ?>
+					<span class="label"><?= $config['label'] ?></span>
 				</label>
 				<?php
 				$i++;
@@ -725,34 +726,52 @@
 	protected function renderOrderControls():void
 	{
 		?>
-		<div class="radio-options order row btw w-full">
+		<div class="radio-options order row x-btw w-full">
 			<?php
 			$order = [
 				'orderby' => [
-					'date' => 'Order by date created',
-					'alphabetical' => 'Order alphabetically'
+					[
+						'slug'	=> 'date',
+						'label'	=> 'Date Created',
+						'icon'	=> 'calendar'
+					],
+					[
+						'slug'	=> 'alphabetical',
+						'label'	=> 'Alphabetically',
+						'icon'	=> 'alphabetical',
+					],
+					[
+						'slug'	=> 'date_modified',
+						'icon'	=> 'clock-clockwise',
+						'label'	=> 'Date Modified',
+					],
 				],
 				'order' => [
-					'sort-ascending' => 'In ascending order (Z-A, oldest to newest)',
-					'sort-descending' => 'In descending order (A-Z, newest to oldest)'
+					[
+						'slug'	=> 'desc',
+						'icon'	=> 'sort-descending',
+						'label'	=> 'Descending (A-Z, 1-10)'
+					],
+					[
+						'slug'	=> 'asc',
+						'icon'	=> 'sort-ascending',
+						'label'	=> 'Ascending (Z-A, 10-1)'
+					]
 				]
 			];
 
 			foreach ($order as $o => $option) {
 				?>
-				<div class="row start">
+				<div class="row left">
 					<span class="label"><?= ucfirst($o)?>:</span>
 					<?php
+					$title = $o === 'orderby' ? 'Order by ' : 'Sort ';
 					$i = 0;
-					foreach ($option as $opt => $label) {
-						$icon = $opt === 'date' ? 'calendar' : $opt;
-						$value = $opt;
-						$value = ($value === 'sort-ascending') ? 'asc' : $value;
-						$value = ($value === 'sort-descending') ? 'desc' : $value;
+					foreach ($option as $conf) {
 						?>
-						<input id="<?=$opt?>" class="btn" type="radio" name="<?=$o?>" data-filter="<?=$o?>" value="<?=$value?>"<?=$i===0 ? ' checked':''?>>
+						<input id="<?=$o.'-'.$conf['slug'] ?>" class="btn" type="radio" name="<?=$o?>" data-filter="<?=$o?>" value="<?=$conf['slug']?>"<?=$i===0 ? ' checked':''?>>
 
-						<label for="<?=$opt?>" title="<?=$label?>"><?=jvbDashIcon($icon)?></label>
+						<label for="<?=$o.'-'.$conf['slug']?>" title="<?=$title.' '.$conf['label']?>"><?=jvbDashIcon($conf['icon'])?><span class="label"><?= $conf['label'] ?></span></label>
 						<?php
 						$i++;
 					}
@@ -770,7 +789,7 @@
 			return;
 		}
 		?>
-		<div class="filters row start">
+		<div class="filters row left">
 			<span class="label">Filters:</span>
 			<?php
 			foreach ($this->filters as $key => $config) {
@@ -928,7 +947,7 @@
 		ob_start();
 		?>
 		<details class="multi-select" title="Select columns" hidden>
-			<summary class="row start nowrap">
+			<summary class="row left nowrap">
 				<?= jvbDashIcon('columns') ?>
 				<span class="labels">Toggle Columns</span>
 			</summary>
@@ -961,7 +980,7 @@
 			return;
 		}
 		?>
-		<div class="bulk-controls row nowrap btw">
+		<div class="bulk-controls row nowrap x-btw">
 			<div class="bulk-select">
 				<input type="checkbox" id="select-all" class="select-all">
 				<label for="select-all" class="row"><span>Select All</span><span class="selected-count" hidden></span></label>
@@ -1132,7 +1151,7 @@
 		}
 		ob_start();
 		?>
-		<div class="item-actions row btw abs">
+		<div class="item-actions row x-btw abs">
 			<?php
 			foreach ($this->itemActions as $action) {
 				$config = $this->defaultItemActions[$action];
@@ -1173,7 +1192,7 @@
 			<div class="item <?=esc_attr($this->dataType)?> row nowrap">
 				<?= $this->renderItemSelect()?>
 				<?=$this->renderImage() ?>
-				<div class="col start w-full">
+				<div class="col top w-full">
 					<h3 data-field="post_title"></h3>
 					<p data-attr="date"></p>
 					<p data-field="price"></p>
@@ -1260,7 +1279,7 @@
 					<td class="field show-<?= esc_attr($name) ?>" data-field="<?= esc_attr($name) ?>" data-field-type="<?=$config['type']?>"<?=(in_array($name, $this->stuck)) ? ' data-stuck':''?>>
 						<?php
 						if (in_array('edit', $this->caps)) {
-							echo $makeThisDetailed ? '<details><summary class="row btw">See Value</summary>' : '';
+							echo $makeThisDetailed ? '<details><summary class="row x-btw">See Value</summary>' : '';
 							if (in_array($config['type'], ['selector', 'taxonomy', 'post'])) {
 								$config['autocomplete'] = true;
 							}
@@ -1342,7 +1361,7 @@
 					$makeThisDetailed = (in_array($config['type'], $makeDetails));
 					?>
 					<td class="field show-<?= esc_attr($name) ?>" data-field="<?= esc_attr($name) ?>" data-field-type="<?=$config['type']?>"<?=(in_array($name, $this->stuck)) ? ' data-stuck':''?>>
-						<?= $makeThisDetailed ? '<details><summary class="row btw">See Value</summary>' : '' ?>
+						<?= $makeThisDetailed ? '<details><summary class="row x-btw">See Value</summary>' : '' ?>
 						<?php
 						if (in_array($config['type'], ['selector', 'taxonomy', 'post'])) {
 							$config['autocomplete'] = true;
@@ -1375,7 +1394,7 @@
 					$makeThisDetailed = (in_array($config['type'], $makeDetails));
 					?>
 					<td class="field show-<?= esc_attr($name) ?>" data-field="<?= esc_attr($name) ?>" data-field-type="<?=$config['type']?>"<?=(in_array($name, $this->stuck)) ? ' data-stuck':''?>>
-						<?= $makeThisDetailed ? '<details><summary class="row btw">See Value</summary>' : '' ?>
+						<?= $makeThisDetailed ? '<details><summary class="row x-btw">See Value</summary>' : '' ?>
 						<?= Form::render($name, '', $config); ?>
 						<?= $makeThisDetailed ? '</details>' : '' ?>
 					</td>
@@ -1458,7 +1477,7 @@
 	protected function renderTableActions(): string {
 		ob_start();
 		?>
-		<div class="table-actions row btw nowrap">
+		<div class="table-actions row x-btw nowrap">
 			<?php if (count(array_intersect(['create', 'edit'], $this->caps)) > 0) { ?>
 				<?= jvbRenderToggleTextField(
 					'vertical',
@@ -1585,8 +1604,13 @@
 				}
 
 				$fields = $this->fields;
+
 				if (!$this->isTimeline) {
-					$first = ['post_thumbnail', 'post_title', 'price'];
+					$first = $this->registrar->getType() === 'post' ?
+						['post_thumbnail', 'post_title', 'price'] :
+						( $this->registrar->getType() === 'term' ?
+							['name', 'thumbnail', 'description'] :
+							['username', 'display_name', 'description']);
 
 					foreach ($first as $f) {
 						if (array_key_exists($f, $fields)) {
@@ -1790,4 +1814,31 @@
 		$out = ob_get_clean();
 		echo Form::fieldWrap('post_status', $out, ['type'=>'group']);
 	}
+
+
+	public static function searchFilter():string
+	{
+		$self = new self();
+		$self->hasSearch = true;
+		ob_start();
+		$self->renderSearch();
+		return ob_get_clean();
+	}
+
+	public static function viewFilter(array $views):string
+	{
+		$self = new self();
+		$self->views = $views;
+		ob_start();
+		$self->renderViewControls();
+		return ob_get_clean();
+	}
+
+	public static function orderFilter(bool $random = false):string
+	{
+		$self = new self();
+		ob_start();
+		$self->renderOrderControls();
+		return ob_get_clean();
+	}
 }

--
Gitblit v1.10.0