From a17c578433ef543e220697813a9367a260df83e1 Mon Sep 17 00:00:00 2001
From: Jake Vanderwerf <get@jakevanderwerf.ca>
Date: Thu, 28 May 2026 19:14:31 +0000
Subject: [PATCH] =new gitblit setup

---
 content/art.php |   78 +++++++++++++++++++++++++++-----------
 1 files changed, 55 insertions(+), 23 deletions(-)

diff --git a/content/art.php b/content/art.php
index af748ee..b5dff8e 100644
--- a/content/art.php
+++ b/content/art.php
@@ -2,6 +2,7 @@
 // /content/art.php
 use JVBase\meta\Meta;
 use JVBase\registrar\Registrar;
+use JVBase\utility\Image;
 
 if (!defined('ABSPATH')) {
     exit;
@@ -11,16 +12,19 @@
 add_action('plugins_loaded', 'ajv_art',1);
 //Add fields later so we can verify taxonomies/post types exist
 add_action('plugins_loaded', 'ajv_art_fields', 2);
+//add_action('init', 'ajv_art_extra_schema', 10);
 
 add_filter('ajv_ArtSchemaDefault', 'ajv_art_schema');
 add_filter('ajv_ArtMetaDefault', 'ajv_art_meta');
 add_filter('ajv_ArtArchiveDefault', 'ajv_art_archive');
+add_filter('ajv_ArtExtras', 'ajv_art_extras');
 
 function ajv_art(){
     if (!class_exists('JVBase\registrar\Registrar')) {
         return;
     }
     $art = Registrar::forPost('art', 'Art', 'Art')
+//        ->setIcon('palette')
         ->setIcon('palette')
         ->make([
             'rewrite'   => [
@@ -43,7 +47,6 @@
         ]);
 
 //$directory = $art->getConfig('directory');
-
 }
 
 function ajv_art_fields():void
@@ -145,6 +148,23 @@
     ]);
 }
 
+function ajv_art_extras(array $extras):array
+{
+    return [[
+        'type'          => 'JVBase\managers\SEO\render\Thing\Intangible\Service',
+        'id'            => get_post_type_archive_link(BASE.'art').'#service',
+        'name'          => 'Art Created in Edmonton, Alberta',
+        'description'   => 'Handmade art by Canadian artist Jake Vanderwerf.',
+        'url'           => get_post_type_archive_link(BASE.'art'),
+        'provider'      => ['id' => get_home_url(null, '#localbusiness')],
+        'areaServed'    => [
+            '@type' => 'JVBase\managers\SEO\render\Thing\Place\AdministrativeArea\Country',
+            'name'  => 'Canada'
+        ],
+    ]];
+
+}
+
 
 //function ajv_art():array
 //{
@@ -328,7 +348,7 @@
 //    ];
 //}
 
-function ajv_render_art_content(array $block, string $content):string
+function ajv_prerender_art_content(array $block, ?string $content, ?WP_Block $parent):?string
 {
     $out = '';
     $ID = get_the_ID();
@@ -336,42 +356,53 @@
 
     $fields = $meta->getAll();
 
+
+
     $bits = [];
-    if (array_key_exists('post_excerpt', $fields) && !empty($fields['post_excerpt'])) {
-        $bits[] = sprintf(
-            '<section id="excerpt"><h2>At a Glance</h2>%s</section>',
-            jvb_filter_content($fields['post_excerpt'])
+    $excerpt = '';
+
+    $rows = [];
+    foreach (['project', 'form', 'city', 'media', 'style', 'theme'] as $type) {
+
+        if (!empty($fields[$type])) {
+            $rows[] = jvbMetaTermList($fields[$type], $type);
+        }
+
+    }
+    if (!empty($rows)) {
+        $excerpt .= sprintf(
+            '<ul class="summary">%s</ul>',
+            implode('', array_map(function ($row) {
+                return '<li>'.$row.'</li>';
+            }, $rows))
         );
     }
 
-    if (array_key_exists('gallery', $fields) && !empty($fields['gallery'])) {
-        $gallery = explode(',',$fields['gallery']);
-        $gallery = array_map(function ($imgID) {
-            $out = '<figure>'.jvbFormatImage($imgID,'tiny','medium');
-            $caption = wp_get_attachment_caption($imgID);
-            $out .= ($caption && $caption !== '') ? '<figcaption>'.jvb_filter_content($caption).'</figcaption>' : '';
-            $out .= '</figure>';
-            return $out;
+    if (!empty($fields['post_excerpt']??'')) {
+        $excerpt .= wpautop($fields['post_excerpt']);
+    }
+    if (!empty($excerpt)) {
+        $bits[] = sprintf('<section id="summary"><h3>At a Glance</h3>%s</section>',$excerpt);
+    }
 
-        }, $gallery);
-        $gallery = implode('',$gallery);
+    if (!empty($fields['gallery']??'')) {
         $bits[] = sprintf(
-            '<section id="gallery"><h2>Gallery</h2><div>%s</div></section>',
-            $gallery
+            '<section id="gallery"><h2>Gallery</h2>%s</section>',
+            Image::gallery($fields['gallery'])
         );
     }
 
-    if (array_key_exists('post_content', $fields) && !empty($fields['post_content'])) {
+    if (!empty($fields['post_content']??'')) {
         $bits[] = sprintf(
             '<section id="content">%s</section>',
             $fields['post_content']
         );
     }
 
-    if (array_key_exists('needs', $fields) && !empty($fields['needs'])) {
+    if (!empty($fields['needs']??'')) {
         $bits[] = ajvb_format_needs($fields['needs']);
     }
-    if (array_key_exists('wants', $fields) && !empty($fields['wants'])) {
+    if (!empty($fields['wants']??'')) {
         $bits[] = ajvb_format_wants($fields['wants']);
     }
 
@@ -395,7 +426,7 @@
         'dateCreated'       => '{{post_date}}',
         'dateModified'      => '{{post_modified}}',
         'artform'           => '{{form.name}}',
-        'artMedium'         => '{{medium.name}}',
+        'artMedium'         => '{{media.name}}',
         'keywords'          => '{{style.name}}',
     ];
 }
@@ -411,7 +442,8 @@
 {
     return array_merge($defaults, [
         'name' => 'Canadian Art. Made in Edmonton, Alberta.',
-        'description' => 'Handmade sculpture, jewellery, and more from Edmonton, Alberta.'
+        'description' => 'Handmade sculpture, jewellery, and more from Edmonton, Alberta.',
+        'about' => ['id' => get_post_type_archive_link(BASE.'art').'#service'],
     ]);
 }
 

--
Gitblit v1.10.0