Jake Vanderwerf
2026-05-01 48721c85ebcfa973ee81719d2467ca80e4253dc9
inc/ui/CRUDSkeleton.php
@@ -1,8 +1,10 @@
<?php
namespace JVBase\ui;
use JVBase\base\Site;
use JVBase\managers\UserTermsManager;
use JVBase\meta\Form;
use JVBase\registrar\Registrar;
use WP_User;
if (!defined('ABSPATH')) {
@@ -128,6 +130,7 @@
   protected array $customDateRanges = [];
   protected array $additionalClasses = [];
   protected Registrar $registrar;
   public function __construct() {
      $this->icon = jvbDefaultIcon();
      $this->user = wp_get_current_user();
@@ -148,6 +151,7 @@
    */
   public function content(string $type, string $singular, string $plural): self {
      $this->dataType = $type;
      $this->registrar = Registrar::getInstance($type);
      $this->singular = $singular;
      $this->plural = $plural;
      return $this;
@@ -213,13 +217,17 @@
    */
   public function addTaxonomyFilter(array $taxonomies, ?string $limit = null): self {
      foreach($taxonomies as $taxonomy) {
         $this->taxonomies[$taxonomy] = [
            'type'   => 'taxonomy',
            'taxonomy'=> $taxonomy,
            'limit'  => $limit,
            'label'  => JVB_TAXONOMY[$taxonomy]['plural']??'',
            'icon'   => JVB_TAXONOMY[$taxonomy]['icon']??''
         ];
         $registrar = Registrar::getInstance($taxonomy);
         if ($registrar) {
            $this->taxonomies[$taxonomy] = [
               'type'   => 'taxonomy',
               'taxonomy'=> $taxonomy,
               'limit'  => $limit,
               'label'  => $registrar->getPlural(),
               'icon'   => $registrar->getIcon()
            ];
         }
      }
      return $this;
@@ -227,8 +235,8 @@
   protected function taxConfig(string $taxonomy, string $label = ''):array
   {
      $isVerified = jvbUserIsVerified();
      $label = ($label === '') ? JVB_TAXONOMY[$taxonomy]['plural'] : $label;
      $isVerified = $this->userIsVerified();
      $label = ($label === '') ? Registrar::getInstance($taxonomy)->getPlural() : $label;
      return [
         'type'      => 'taxonomy',
         'label'     => $label,
@@ -239,6 +247,13 @@
      ];
   }
   protected function userIsVerified():bool
   {
      $membership = Site::membership();
      return !($membership && $membership->has('member_verified')) || current_user_can('skip_moderation');
   }
   public function addSearch():self
   {
      $this->hasSearch = true;
@@ -894,7 +909,7 @@
      if ($limit) {
         if ($limit === 'user') {
            $manager = new UserTermsManager();
            return $manager->getUserTerms($this->user_id, $taxonomy);
            return $manager->fetchUserTerms($this->user_id, $taxonomy);
         } else {
            $limit = (int)$limit;
         }
@@ -973,9 +988,12 @@
               <option value="<?=$control?>"<?=$disabled?>><?=$label?></option>
               <?php
            }
            foreach ($this->taxonomies as $taxonomy => $config) {
            foreach ($this->taxonomies as $taxonomy =>$config) {
               $registrar = Registrar::getInstance($taxonomy);
               if (!$registrar) continue;
               ?>
               <option value="tax-<?=$taxonomy?>" data-type="selector" data-single="<?=JVB_TAXONOMY[$taxonomy]['singular']?>" data-plural="<?=JVB_TAXONOMY[$taxonomy]['plural']?>" data-taxonomy="<?=$taxonomy?>">Add to <?= JVB_TAXONOMY[$taxonomy]['singular']??$config['label'] ?></option>
               <option value="tax-<?=$taxonomy?>" data-type="selector" data-single="<?=$registrar->getSingular()?>" data-plural="<?=$registrar->getPlural()?>" data-taxonomy="<?=$taxonomy?>">Add to <?= $registrar->getSingular() ?></option>
               <?php
            }
            ?>
@@ -1543,19 +1561,17 @@
         <input type="hidden" name="form-id" value="<?=uniqid('new-')?>" />
         <input type="hidden" name="content" value="<?=$this->dataType?>" />
         <div class="fields">
            <div class="field-group radio-options row" data-field="post_status" data-field-type="radio">
               <span>Status:</span>
               <?php
               $this->getApplicableStatuses('edit');
               ?>
            </div>
            <?php if (!$this->userCanPublish) { ?>
               <p class="description">Your account needs to be verified before you can publish content.</p>
            <?php }
            <?php
            if (!empty($this->statuses)) {
               echo Form::render('post_status', '', $this->getStatusFieldConfig('edit-'));
            }
            if (!empty($this->sections)) {
               $tabs = [];
               foreach ($this->sections as $slug => $config) {
               foreach ($this->sections as $config) {
                  $slug = $config['slug'];
                  $section = [];
                  if (array_key_exists('icon', $config)) {
                     $section = [
@@ -1567,10 +1583,6 @@
                     'content' => '',
                     'description' => $config['description']??'',
                  ], $section);
                  $icon = jvbSectionIcon($slug);
                  if ($icon !== '') {
                     $tabs[$slug]['icon'] = $icon;
                  }
               }
            } else {
               $tabs = false;
@@ -1620,13 +1632,13 @@
               $fields = $this->nonTimelineFields;
            }
            foreach ($fields as $n => $config) {
               if (in_array($config['type'], ['taxonomy', 'selector'])) {
                  $config = array_merge($config, $this->taxConfig($config['taxonomy'], $config['label']));
               }
               if ($tabs) {
                  $section = (array_key_exists('section', $config)) ? $config['section'] : 'basic';
                  $tabs[$section]['content'] .= Form::render($n,'', $config);
                  $tabs[$section]['content'] .= Form::render($n, '', $config);
               } else {
                  if (in_array($config['type'], ['taxonomy', 'selector'])) {
                     $config = array_merge($config, $this->taxConfig($config['taxonomy'], $config['label']));
                  }
                  echo Form::render($n, '', $config);
               }
            }
@@ -1662,12 +1674,9 @@
         <p class="description">You can unselect items by clicking the image here.</p>
         <p class="hint"><strong>IMPORTANT: </strong> Whatever changes you make here will be applied to all selected <?=$this->plural?>.</p>
         <div class="fields">
            <div class="field-group radio-options row">
               <?php
               $this->getApplicableStatuses('bulk-');
               ?>
            </div>
            <?php
            echo Form::render('post_status', '', $this->getStatusFieldConfig('bulk-'));
            if (!empty($this->taxonomies)) {
               ?>
               <div class="taxonomies">
@@ -1704,6 +1713,44 @@
      );
   }
   protected function getStatusFieldConfig(string $prefix): array
   {
      $options = [];
      foreach ($this->statuses as $status) {
         if ($status === 'all' || !array_key_exists($status, $this->allowedStatuses)) {
            continue;
         }
         $config = $this->allowedStatuses[$status];
         if (in_array($status, ['future', 'past'])) {
            if ($status === 'future') {
               $status = 'publish';
               $config = ['icon' => 'eye', 'label' => 'Live'];
            } else {
               continue;
            }
         }
         $options[$status] = [
            'label'    => $config['label'],
            'icon'     => $config['icon'],
            'disabled' => ($status === 'publish' && !$this->userCanPublish),
         ];
      }
      return [
         'type'       => 'radio',
         'label'      => 'Status',
         'options'    => $options,
         'inputClass' => 'btn',
         'idPrefix'   => $prefix,
         'class'      => 'radio-options row',
         'hint'       => !$this->userCanPublish
            ? 'Your account needs to be verified before you can publish content.'
            : '',
      ];
   }
   protected function getApplicableStatuses(string $prefix) {
      ob_start();
      foreach ($this->statuses as $status) {
@@ -1736,6 +1783,6 @@
         <?php
      }
      $out = ob_get_clean();
      echo Form::buildInput($out);
      echo Form::fieldWrap('post_status', $out, ['type'=>'group']);
   }
}