Jake Vanderwerf
2026-02-17 a24a06002081ad71a78ffeff9072725ba39cf121
inc/blocks/CustomBlocks.php
@@ -3,7 +3,7 @@
use DateTime;
use DOMDocument;
use JVBase\managers\CacheManager;
use JVBase\managers\Cache;
use WP_Block;
use WP_Query;
@@ -13,13 +13,13 @@
class CustomBlocks
{
    protected CacheManager $cache;
    protected Cache $cache;
    public function __construct()
    {
        $this->cache = CacheManager::for('blocks', WEEK_IN_SECONDS);
        $this->cache = Cache::for('blocks', WEEK_IN_SECONDS);
      $this->cache->connect('post')->connect('taxonomy');
      add_filter('render_block', [$this, 'render'], 999, 3);
        add_action('init', [$this, 'registerBlockStyles']);
    }
@@ -73,16 +73,16 @@
      if (function_exists($function)) {
         return $function($block, $content);
//       return $this->cache->remember(
//          $block,
//          get_the_ID(),
//          function () use ($function, $block, $content) {
//             return $function($block, $content);
//          }
//       );
      } else if (method_exists($this, $method)) {
         return $this->$method($block, $content);
//
//       return $this->cache->remember(
//          $block,
//          get_the_ID(),
//          function () use ($method, $block, $content) {
//             return $this->$method($block, $content);
//          }
@@ -104,6 +104,9 @@
            // Enqueue the feed block script (it will automatically load dependencies)
            $this->localize_feedblock();
        }
      if ($block['blockName'] === 'jvb/forms') {
         wp_enqueue_style('jvb-form');
      }
        return $content;
    }
@@ -123,7 +126,7 @@
     */
    protected function render_core_button(array $block):string
    public function render_core_button(array $block):string
    {
      preg_match('/href="([^"]*)"/', $block['innerHTML'], $url);
      preg_match('/>([^<]*)<\/a>/', $block['innerHTML'], $label);
@@ -138,6 +141,7 @@
      if (str_contains($url[1], 'maps.apple.com')) {
         $icon = 'apple-logo';
      }
      if ($icon !== '') {
         return sprintf(
            '<li%s><a href="%s" title="Find Us On %s">%s Maps</a></li>',
@@ -156,13 +160,13 @@
      );
    }
    protected function render_core_buttons(array $block):string
    public function render_core_buttons(array $block):string
    {
        return '<ul'.$this->getClassesAndStyles($block['attrs'], ['buttons','row']).'>'.
               $this->innerBlocks($block).'</ul>';
    }
    protected function render_core_column(array $block):string
    public function render_core_column(array $block):string
    {
        $styles = (array_key_exists('attrs', $block) &&
                   array_key_exists('width', $block['attrs'])) ?
@@ -173,7 +177,7 @@
               $this->innerBlocks($block).'</div>';
    }
    protected function render_core_columns(array $block):string
    public function render_core_columns(array $block):string
    {
        return '<section'.
               $this->getClassesAndStyles($block['attrs'], ['columns']).'>'.
@@ -181,11 +185,12 @@
    }
    //core_comment_template
    protected function render_core_group(array $block):string
    public function render_core_group(array $block):string
    {
        $tag = (array_key_exists('tagName', $block['attrs'])) ? $block['attrs']['tagName'] : 'div';
        $classes = ($tag === 'main') ?
            $this->getClassesAndStyles($block['attrs']) :
            '' :
            $this->getClassesAndStyles($block['attrs'], ['group']);
        return '<'.$tag.$classes.'>'.$this->innerBlocks($block).'</'.$tag.'>';
    }
@@ -193,12 +198,12 @@
    //core_more
    //core_nextpage
    protected function render_core_separator(array $block):string
    public function render_core_separator(array $block):string
    {
        return '<hr'.$this->getClassesAndStyles($block['attrs']).'>';
    }
    protected function render_core_spacer(array $block):string
    public function render_core_spacer(array $block):string
    {
        return '<div'.$this->getClassesAndStyles($block['attrs'], ['spacer'], ['height:2rem']).
               ' aria-hidden="true"></div>';
@@ -214,7 +219,7 @@
     * Media Blocks
     */
    //core_audio
    protected function render_core_cover(array $block):string
    public function render_core_cover(array $block):string
    {
        // Extract block attributes
@@ -249,7 +254,7 @@
      // Build classes and styles
      unset($attrs['url']);
      $classes = $this->getClassesAndStyles($attrs, ['cover']);
      $classes = $this->getClassesAndStyles($attrs, ['cover row']);
      return '<section' . $classes . '>' .
@@ -261,14 +266,14 @@
    //core_file
    protected function render_core_gallery(array $block):string
    public function render_core_gallery(array $block):string
    {
        return '<ul'.$this->getClassesAndStyles($block['attrs'], ['gallery']).'>'.
               $this->innerBlocks($block,'<li>', '</li>').
               '</ul>';
    }
    protected function render_core_image(array $block):string
    public function render_core_image(array $block):string
    {
        $ID = $this->imageID('', $block);
        if (!$ID) {
@@ -282,18 +287,20 @@
                wp_get_attachment_caption($ID) .
            '</figcaption>' :
            '<figcaption>' . $title . '</figcaption>';
      $size = array_key_exists('sizeSlug', $block['attrs']) ? $block['attrs']['sizeSlug'] : 'large';
        return '<figure'.
               $this->getClassesAndStyles($block['attrs']).'>'.
               $this->imageLink(true, $ID) .
               $this->imageLink(true, $ID, 'tiny', $size) .
               $caption.'</figure>';
    }
    protected function render_core_media_text(array $block):string
    public function render_core_media_text(array $block):string
    {
        $ID = $this->imageID('', $block);
        $imgLink = ($ID) ? $this->imageLink(true, $ID) : '';
      $size = array_key_exists('mediaSizeSlug', $block['attrs']) ? $block['attrs']['mediaSizeSlug'] : 'large';
        $imgLink = ($ID) ? $this->imageLink(true, $ID, 'tiny', $size) : '';
        $inner = $this->innerBlocks($block);
@@ -327,7 +334,7 @@
    //render_core_details
    //render_core_footnotes
    //render_core_classic
    protected function render_core_heading(array $block):string
    public function render_core_heading(array $block):string
    {
        $level = (array_key_exists('level', $block['attrs'])) ? $block['attrs']['level'] : '2';
      $content = $this->inside($block);
@@ -337,25 +344,25 @@
               '</h'.$level.'>';
    }
   protected function render_core_list(array $block):string
   public function render_core_list(array $block):string
   {
      $tag = (array_key_exists('ordered', $block['attrs'])) ? 'ol' : 'ul';
      return '<'.$tag.$this->getClassesAndStyles($block['attrs']).'>'.$this->innerBlocks($block).'</'.$tag.'>';
   }
// protected function render_core_list_item(array $block):string
// public function render_core_list_item(array $block):string
// {
//    return '<li'.$this->getClassesAndStyles($block['attrs']).'>'.$this->inside($block).'</li>';
// }
    //render_core_missing
    protected function render_core_paragraph(array $block):string
    public function render_core_paragraph(array $block):string
    {
        return '<p'.$this->getClassesAndStyles($block['attrs']).'>'.
               $this->inside($block, 'p').
               '</p>';
    }
   protected function render_core_quote(array $block): string
   public function render_core_quote(array $block): string
   {
      $innerHTML = $block['innerHTML'];
@@ -376,7 +383,7 @@
         $citeHtml.
         '</blockquote>';
   }
   protected function render_core_pullquote(array $block): string
   public function render_core_pullquote(array $block): string
   {
      $innerHTML = $block['innerHTML'];
@@ -391,7 +398,7 @@
      if ($cite !== '') {
         $content = $this->stripTagContents('cite', $content);
      }
      $content = apply_filters('the_content', $content);
      $content = jvb_filter_content( $content);
      return '<blockquote'.$this->getClassesAndStyles($block['attrs'], ['pull']).'>'.
         $content.
@@ -408,7 +415,7 @@
    //core_loginout
    //core_pattern
    protected function render_core_site_logo(array $block, string $content):string
    public function render_core_site_logo(array $block, string $content):string
    {
        $open = $close = '';
@@ -423,7 +430,7 @@
    }
    //core_site_title_tagline
    protected function render_core_site_title(array $block, string $content):string
    public function render_core_site_title(array $block, string $content):string
    {
        $tag = (array_key_exists('level', $block['attrs'])) ? $block['attrs']['level'] : 1;
        $tag = ($tag == 0) ? 'p' : 'h'.$tag;
@@ -465,7 +472,7 @@
    /**
     * Theme Navigation Blocks
     */
    protected function render_core_navigation(array $block, string $content):string
    public function render_core_navigation(array $block, string $content):string
    {
        $ID = (array_key_exists('ref', $block['attrs'])) ? $block['attrs']['ref'] : false;
@@ -506,17 +513,18 @@
         '</nav>'.$helpmenu;
    }
    protected function render_core_navigation_link(array $block):string
    public function render_core_navigation_link(array $block):string
    {
        global $wp;
        $url = (str_starts_with($block['attrs']['url'],'/')) ?
            home_url($block['attrs']['url']) :
            $block['attrs']['url'];
        $current = (home_url($wp->request.'/') == $url);
      $temp = $block['attrs'];
      unset($temp['url']);
        $classes = ($current) ?
            $this->getClassesAndStyles($block['attrs'], ['current']):
            $this->getClassesAndStyles($block['attrs']);
            $this->getClassesAndStyles($temp, ['current']):
            $this->getClassesAndStyles($temp);
        $aria = '';
        if ($current) {
            $aria = ' aria-current="page"';
@@ -527,7 +535,7 @@
        return '<li'.$classes.'>'.$linkOpen.$block['attrs']['label'].'</a></li>';
    }
    protected function render_core_navigation_submenu(array $block):string
    public function render_core_navigation_submenu(array $block):string
    {
        global $wp;
        $url = (str_starts_with($block['attrs']['url'],'/')) ?
@@ -535,9 +543,11 @@
            $block['attrs']['url'];
        $current = (home_url($wp->request) == $url);
      $temp = $block['attrs'];
      unset($temp['url']);
        $classes = ($current) ?
            $this->getClassesAndStyles($block['attrs'], ['has-submenu', 'current']):
            $this->getClassesAndStyles($block['attrs'], ['has-submenu']);
            $this->getClassesAndStyles($temp, ['has-submenu', 'current']):
            $this->getClassesAndStyles($temp, ['has-submenu']);
        $aria = '';
        if ($current) {
@@ -595,7 +605,7 @@
    //core_post_author
    //core_post_author_biography
    //core_post_author_name
    protected function render_core_post_content(array $block, string $content = ''):string
    public function render_core_post_content(array $block, string $content = ''):string
    {
        $tag = (array_key_exists('tagName', $block['attrs'])) ?
@@ -604,6 +614,7 @@
        if ($content == '') {
         global $post;
         $block['innerBlocks'] = parse_blocks($post->post_content);
         return $this->innerBlocks($block);
        } else {
@@ -611,13 +622,13 @@
        }
    }
    //core_post_date
   protected function render_core_post_date(array $block):string
   public function render_core_post_date(array $block):string
   {
      $postDate = get_the_date('c');
      return '<time datetime="'.$postDate.'" itemprop="datePublished"'.$this->getClassesAndStyles($block['attrs']).'>'.get_the_date().'</time>';
   }
    //core_post_excerpt
    protected function render_core_post_featured_image(array $block):string
    public function render_core_post_featured_image(array $block):string
    {
      global $post;
      $ID = get_post_thumbnail_id($post->ID);
@@ -634,7 +645,7 @@
    //core_post_navigation_link
    //core_post_template
    //core_post_terms
   protected function render_core_post_terms(array $block):string
   public function render_core_post_terms(array $block):string
   {
      $terms = get_the_terms(get_the_ID(), $block['attrs']['term']);
      $out = '';
@@ -644,7 +655,7 @@
               $out .= '<li>'.$block['attrs']['prefix'].'</li>';
            }
            foreach($terms as $term) {
               $out .= '<li><a href="'.get_term_link($term).'" rel="tag">'.$term->name.'</a></li>';
               $out .= '<li><a href="'.get_term_link($term).'" rel="tag">'.html_entity_decode($term->name).'</a></li>';
            }
         if (array_key_exists('suffix', $block['attrs'])) {
            $out .= '<li>'.$block['attrs']['suffix'].'</li>';
@@ -654,7 +665,7 @@
      return $out;
   }
    //core_post_time_to_read
    protected function render_core_post_title(array $block):string
    public function render_core_post_title(array $block):string
    {
        $open = $close = '';
        if (array_key_exists('isLink', $block['attrs'])) {
@@ -679,9 +690,8 @@
               '</h'.$level.'>';
    }
   protected function render_core_query(array $block, string $content):string
   public function render_core_query(array $block, string $content):string
   {
      $queryID = $block['attrs']['queryId'];
      $args = [];
      $inherit = $block['attrs']['inherit']??false;
@@ -788,7 +798,7 @@
    //core_query_pagination_previous
    //core_query_title
    //core_read_more
    protected function render_core_template_part(array $block, string $content):string
    public function render_core_template_part(array $block, string $content):string
    {
      $isHeaderTemplate = (
@@ -816,15 +826,18 @@
                $title = ($checked == '') ? 'Toggle Dark Mode' : 'Toggle Light Mode';
            $showThemeSwitch = (bool)apply_filters('jvb_show_theme_switch', true);
                $themeSwitch = ($showThemeSwitch) ? '<label title="'.$title.'" id="theme-switch" class="toggle-switch" for="theme-switcher">
                    <input class="theme-switch row" id="theme-switcher" type="checkbox"'.$checked.' data-setting="theme" data-theme role="switch" name="dark-mode"><span class="slider">'.
                    <input class="theme-switch row" id="theme-switcher" name="theme-switcher" type="checkbox"'.$checked.' data-setting="theme" data-theme role="switch" name="dark-mode" aria-label="Toggle dark mode"><span class="slider">'.
               jvbIcon('sun-dim', ['title'=> 'Light Mode']).
               jvbIcon('moon', ['title'=>'Dark Mode']).
               '</span></label>' : '';
                $breadcrumbs = jvbBuildBreadcrumbs();
            $afterHeader = apply_filters('jvbBelowHeader', $afterHeader);
            if ($afterHeader !== '') {
               $afterHeader = '<aside class="sub-header">'.$afterHeader.'</aside>';
            }
            $footerText = '<div class="scroll-progress"><div class="bar"></div>
</div>';
            } elseif ($isFooterTemplate) {
            $beforeHeader = apply_filters('jvbBeforeFooter', '');
            if ($beforeHeader !== '') {
@@ -864,7 +877,7 @@
    //core_rss
    //core_search
    //core_shortcode
   protected function render_core_social_link(array $block, string $content):string
   public function render_core_social_link(array $block, string $content):string
   {
      $url = $block['attrs']['url'];
      $service = $block['attrs']['service'];
@@ -875,7 +888,7 @@
      }
      return '<li><a href="'.$url.'" target="_blank" rel="nofollow" title="Find us on '.ucfirst($service).'">'.$icon.'<span class="screen-reader-text">Find us on '.ucfirst($service).'</span></a></li>';
   }
   protected function render_core_social_links(array $block, string $content):string
   public function render_core_social_links(array $block, string $content):string
   {
      return '<ul class="socials">'.$this->innerBlocks($block).'</ul>';
   }
@@ -1153,11 +1166,9 @@
                $classes[] = $class;
            }
        }
        $classes =  array_filter($classes, function ($class) {
            return $class!=='' && !str_starts_with($class, 'wp');
        });
        return $classes;
      return array_filter($classes, function ($class) {
         return $class!=='' && !str_starts_with($class, 'wp');
      });
    }
    protected function getClass(string $key, string|bool|array|int $value, array $attrs):string|array
    {
@@ -1196,9 +1207,9 @@
            $type = 'row';
                if (array_key_exists('type', $value)) {
               $type = 'col';
                    if ($value['type'] === 'constrained') {
                        $classes[] = 'container col';
                    }
//                    if ($value['type'] === 'constrained') {
//                        $classes[] = 'container col';
//                    }
                }
            if (array_key_exists('orientation', $value)) {
               $type = 'col';
@@ -1736,5 +1747,3 @@
    }
}
new CustomBlocks();