summaryrefslogtreecommitdiff
path: root/src/SvgCollection.php
diff options
context:
space:
mode:
Diffstat (limited to 'src/SvgCollection.php')
-rw-r--r--src/SvgCollection.php18
1 files changed, 16 insertions, 2 deletions
diff --git a/src/SvgCollection.php b/src/SvgCollection.php
index 63d7508..fdf0664 100644
--- a/src/SvgCollection.php
+++ b/src/SvgCollection.php
@@ -27,8 +27,13 @@ class SvgCollection
public function getSvgUrl(string $svg): string
{
- $this->getState()->addSvg($svg);
- return route('laralight-svg.serve-svg', $this->getName()) . "#{$svg}";
+ $state = $this->getState();
+ $state->addSvg($svg);
+ $hash = $state->getHash();
+ return route(
+ 'laralight-svg.serve-svg',
+ ['collection' => $this->getName(), 'v' => $hash]
+ ) . "#{$svg}";
}
protected function getState(): SvgCollectionState
@@ -70,11 +75,15 @@ class SvgCollection
if ($file !== null && $compiler->addSvg($pendingSvg, $file)) {
$added[] = $pendingSvg;
}
+ else {
+ \Log::error("Failed to add {$pendingSvg} to svg sprite");
+ }
}
$state->clearPending(false);
$state->concatExisting($added, false);
$state->setFullSvg($compiler->getSvg(), false);
+ $state->updateHash();
$state->push();
}
@@ -87,4 +96,9 @@ class SvgCollection
return null;
}
+ public function clearState(): void
+ {
+ $this->getState()->clear();
+ }
+
}