From 119535239d817d51c129750d6818240db0a2567c Mon Sep 17 00:00:00 2001 From: Jonathan Carey Date: Fri, 26 Jan 2024 17:12:38 +0000 Subject: [PATCH] Ensure view data compatibility across Statamic Antlers versions Update the view rendering logic to handle different Statamic Antlers versions. For "regex" versions, use the Laravel view helper with a check to convert $data to an array if it is a collection. For other versions, consistently use the Statamic View facade with $data->all() to ensure $data is always passed as an array. This change guarantees that view data is correctly formatted regardless of the Antlers version or the data type. --- src/Parsers/PageDataParser.php | 2 +- src/Tags/AardvarkSeoTags.php | 114 +++++++++++++++++++++++++++++---- 2 files changed, 104 insertions(+), 12 deletions(-) diff --git a/src/Parsers/PageDataParser.php b/src/Parsers/PageDataParser.php index f0d14f4..82e2fbd 100644 --- a/src/Parsers/PageDataParser.php +++ b/src/Parsers/PageDataParser.php @@ -159,7 +159,7 @@ public static function getSettingsBlueprintWithValues($ctx, $type, $blueprint_cl public static function generatePageTitle($data, $ctx) { if ($data->get('meta_title') && $data->get('meta_title')->raw()) { - return Parse::template($data->get('meta_title'), $ctx); + return Parse::template($data->get('meta_title'), [], $ctx); } if ($data->get('response_code') === 404) { diff --git a/src/Tags/AardvarkSeoTags.php b/src/Tags/AardvarkSeoTags.php index bde5833..fd230a3 100644 --- a/src/Tags/AardvarkSeoTags.php +++ b/src/Tags/AardvarkSeoTags.php @@ -14,6 +14,14 @@ class AardvarkSeoTags extends Tags { protected static $handle = 'aardvark-seo'; + // The $ctx property is used to store the context as a collection. + // It's initialised and set on the first method call to avoid subsequent calls. + protected $ctx = null; + + // The $ctxParsed property holds the processed data obtained from the PageDataParser. + // It's initialised and set on the first method call to avoid subsequent calls. + protected $ctxParsed = null; + /** * Return the tag content required for on-page SEO * @@ -21,10 +29,26 @@ class AardvarkSeoTags extends Tags */ public function head() { - $data = PageDataParser::getData(collect($this->context)); + // Check if $this->ctx is not set. If not, initialise it with the current context. + if (!$this->ctx) { + $this->ctx = $this->context; + } + + // Check if $this->ctxParsed is not set. If not, parse $this->ctx using PageDataParser + // and store the result in $this->ctxParsed for reuse. + if (!$this->ctxParsed) { + $this->ctxParsed = PageDataParser::getData($this->ctx); + } + + $data = $this->ctxParsed; + + // Check the version of Statamic Antlers. If it's 'regex', use the Laravel view helper, + // else use the Statamic View facade. Also, ensure $data is an array when passing it to the view. if (config('statamic.antlers.version') == 'regex') { - $view = view('aardvark-seo::tags.head', $data); + $view = $data instanceof \Illuminate\Support\Collection ? + view('aardvark-seo::tags.head', $data->all()) : + view('aardvark-seo::tags.head', $data); } else { $view = View::make('aardvark-seo::tags.head', $data->all()); } @@ -51,10 +75,26 @@ public function head() */ public function body() { - $data = PageDataParser::getData(collect($this->context)); + // Check if $this->ctx is not set. If not, initialise it with the current context. + if (!$this->ctx) { + $this->ctx = collect($this->context); + } + + // Check if $this->ctxParsed is not set. If not, parse $this->ctx using PageDataParser + // and store the result in $this->ctxParsed for reuse. + if (!$this->ctxParsed) { + $this->ctxParsed = PageDataParser::getData($this->ctx); + } + + $data = $this->ctxParsed; + + // Check the version of Statamic Antlers. If it's 'regex', use the Laravel view helper, + // else use the Statamic View facade. Also, ensure $data is an array when passing it to the view. if (config('statamic.antlers.version') == 'regex') { - $view = view('aardvark-seo::tags.body', $data); + $view = $data instanceof \Illuminate\Support\Collection ? + view('aardvark-seo::tags.body', $data->all()) : + view('aardvark-seo::tags.body', $data); } else { $view = View::make('aardvark-seo::tags.body', $data->all()); } @@ -67,10 +107,26 @@ public function body() */ public function footer() { - $data = PageDataParser::getData(collect($this->context)); + // Check if $this->ctx is not set. If not, initialise it with the current context. + if (!$this->ctx) { + $this->ctx = collect($this->context); + } + + // Check if $this->ctxParsed is not set. If not, parse $this->ctx using PageDataParser + // and store the result in $this->ctxParsed for reuse. + if (!$this->ctxParsed) { + $this->ctxParsed = PageDataParser::getData($this->ctx); + } + + $data = $this->ctxParsed; + + // Check the version of Statamic Antlers. If it's 'regex', use the Laravel view helper, + // else use the Statamic View facade. Also, ensure $data is an array when passing it to the view. if (config('statamic.antlers.version') == 'regex') { - $view = view('aardvark-seo::tags.footer', $data); + $view = $data instanceof \Illuminate\Support\Collection ? + view('aardvark-seo::tags.footer', $data->all()) : + view('aardvark-seo::tags.footer', $data); } else { $view = View::make('aardvark-seo::tags.footer', $data->all()); } @@ -83,7 +139,13 @@ public function footer() */ public function hreflang() { - $ctx = collect($this->context); + + // Check if $this->ctx is not set. If not, initialise it with the current context. + if (!$this->ctx) { + $this->ctx = collect($this->context); + } + + $ctx = $this->ctx; $id = $ctx->get('id'); @@ -134,7 +196,13 @@ public function hreflang() */ public function graph() { - $ctx = collect($this->context); + + // Check if $this->ctx is not set. If not, initialise it with the current context. + if (!$this->ctx) { + $this->ctx = collect($this->context); + } + + $ctx = $this->ctx; $graph = new SchemaGraph($ctx); return $graph->build(); } @@ -146,7 +214,19 @@ public function graph() */ public function socials() { - $data = PageDataParser::getData(collect($this->context)); + + // Check if $this->ctx is not set. If not, initialise it with the current context. + if (!$this->ctx) { + $this->ctx = collect($this->context); + } + + // Check if $this->ctxParsed is not set. If not, parse $this->ctx using PageDataParser + // and store the result in $this->ctxParsed for reuse. + if (!$this->ctxParsed) { + $this->ctxParsed = PageDataParser::getData($this->ctx); + } + + $data = $this->ctxParsed; $socials = $data->get('aardvark_social_settings')->get('social_links'); if ($socials->raw()) { return $this->parseLoop($socials->raw()); @@ -162,7 +242,13 @@ public function socials() */ public function robotsTag() { - $ctx = collect($this->context); + + // Check if $this->ctx is not set. If not, initialise it with the current context. + if (!$this->ctx) { + $this->ctx = collect($this->context); + } + + $ctx = $this->ctx; $attrs = []; $global_no_index = $ctx->get('aardvark_general_settings')['no_index_site']; @@ -191,7 +277,13 @@ public function robotsTag() */ public function generatedCanonical() { - $data = collect($this->context); + + // Check if $this->ctx is not set. If not, initialise it with the current context. + if (!$this->ctx) { + $this->ctx = collect($this->context); + } + + $data = $this->ctx; $vars = $data->get('get'); $current_url = $data->get('permalink'); if ($vars && $page = collect($vars)->get('page')) {