From 954bc90ef547bb6ff2b1d41897e9574b340627ab Mon Sep 17 00:00:00 2001 From: Olayinka Azeez Date: Fri, 1 Nov 2024 18:46:13 +0100 Subject: [PATCH] retrieve slug from slugs table if the $slugAttribute field was not changed --- src/Models/Behaviors/HasSlug.php | 27 +++++++++++++++++++++++---- 1 file changed, 23 insertions(+), 4 deletions(-) diff --git a/src/Models/Behaviors/HasSlug.php b/src/Models/Behaviors/HasSlug.php index 64cb7e860..9b91f35cc 100644 --- a/src/Models/Behaviors/HasSlug.php +++ b/src/Models/Behaviors/HasSlug.php @@ -124,10 +124,10 @@ public function restoreSlugs(): void */ public function handleSlugsOnSave(): void { - $this->disableLocaleSlugs(); - $slugParams = $this->twillSlugData !== [] ? $this->twillSlugData : $this->getSlugParams(); + $this->disableLocaleSlugs(); + foreach ($slugParams as $params) { if (in_array($params['locale'], config('twill.slug_utf8_languages', []))) { $params['slug'] = $this->getUtf8Slug($params['slug']); @@ -358,9 +358,13 @@ public function getSlugParams(?string $locale = null): ?array throw new \Exception("You must define the field {$slugAttribute} in your model"); } + $slug = $this->getSlugValue($slugAttribute, $translation->locale) + ?? $translation->$slugAttribute + ?? $this->$slugAttribute; + $slugParam = [ 'active' => $translation->active ?? true, - 'slug' => $translation->$slugAttribute ?? $this->$slugAttribute, + 'slug' => $slug, 'locale' => $translation->locale, ] + $slugDependenciesAttributes; @@ -400,7 +404,7 @@ public function getSingleSlugParams(?string $locale = null): ?array $slugParam = [ 'active' => 1, - 'slug' => $this->$slugAttribute, + 'slug' => $this->getSlugValue($slugAttribute, $appLocale) ?? $this->$slugAttribute, 'locale' => $appLocale, ] + $slugDependenciesAttributes; @@ -415,6 +419,21 @@ public function getSingleSlugParams(?string $locale = null): ?array return $locale === null ? $slugParams : null; } + /** + * Returns changed value of slugAttribute field or previous slug value + * + * @param $slugAttribute + * @param $locale + * @return mixed|null + */ + private function getSlugValue($slugAttribute, $locale): mixed + { + return $this->wasChanged($slugAttribute) + ? $this->$slugAttribute + : $this->slugs()->where('locale', $locale) + ->where('active', true)->value('slug'); + } + /** * Returns the database table name for this model's slugs. */