| | |
| | | |
| | | use DateTime; |
| | | use DOMDocument; |
| | | use JVBase\managers\CacheManager; |
| | | use JVBase\managers\Cache; |
| | | use WP_Block; |
| | | use WP_Query; |
| | | |
| | |
| | | |
| | | 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']); |
| | | } |
| | | |
| | |
| | | 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); |
| | | // } |
| | |
| | | // 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; |
| | | } |
| | | |
| | |
| | | */ |
| | | |
| | | |
| | | 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); |
| | |
| | | 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>', |
| | |
| | | ); |
| | | } |
| | | |
| | | 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'])) ? |
| | |
| | | $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']).'>'. |
| | |
| | | } |
| | | //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.'>'; |
| | | } |
| | |
| | | //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>'; |
| | |
| | | * Media Blocks |
| | | */ |
| | | //core_audio |
| | | protected function render_core_cover(array $block):string |
| | | public function render_core_cover(array $block):string |
| | | { |
| | | |
| | | // Extract block attributes |
| | |
| | | |
| | | // Build classes and styles |
| | | unset($attrs['url']); |
| | | $classes = $this->getClassesAndStyles($attrs, ['cover']); |
| | | $classes = $this->getClassesAndStyles($attrs, ['cover row']); |
| | | |
| | | |
| | | return '<section' . $classes . '>' . |
| | |
| | | |
| | | //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) { |
| | |
| | | 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); |
| | | |
| | |
| | | //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); |
| | |
| | | '</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']; |
| | | |
| | |
| | | $citeHtml. |
| | | '</blockquote>'; |
| | | } |
| | | protected function render_core_pullquote(array $block): string |
| | | public function render_core_pullquote(array $block): string |
| | | { |
| | | $innerHTML = $block['innerHTML']; |
| | | |
| | |
| | | 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. |
| | |
| | | //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 = ''; |
| | | |
| | |
| | | } |
| | | //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; |
| | |
| | | /** |
| | | * 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; |
| | | |
| | |
| | | '</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"'; |
| | |
| | | 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'],'/')) ? |
| | |
| | | $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) { |
| | |
| | | //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'])) ? |
| | |
| | | |
| | | if ($content == '') { |
| | | global $post; |
| | | |
| | | $block['innerBlocks'] = parse_blocks($post->post_content); |
| | | return $this->innerBlocks($block); |
| | | } else { |
| | |
| | | } |
| | | } |
| | | //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); |
| | |
| | | //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 = ''; |
| | |
| | | $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>'; |
| | |
| | | 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'])) { |
| | |
| | | '</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; |
| | |
| | | //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 = ( |
| | |
| | | $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 !== '') { |
| | |
| | | //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']; |
| | |
| | | } |
| | | 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>'; |
| | | } |
| | |
| | | $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 |
| | | { |
| | |
| | | $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'; |
| | |
| | | } |
| | | |
| | | } |
| | | |
| | | new CustomBlocks(); |