Exceptions
Exception
Twig\Error\ RuntimeError
Show exception properties
Twig\Error\RuntimeError {#2760 -lineno: 5 -rawMessage: "Variable "productVariant" does not exist." -source: Twig\Source {#2779 -code: """ {# Show notification #}\n <turbo-stream action="append" target="notification-container">\n <template>\n {{ component('ProductAddedNotification', {\n productVariant: productVariant,\n quantity: quantity\n }) }}\n </template>\n </turbo-stream>\n \n {% if cartItemCount is defined %}\n {# Update cart count in navbar #}\n <turbo-stream action="replace" target="navbar-cart-count">\n <template>\n <span id="navbar-cart-count" class="ml-2 text-sm font-medium text-gray-700 group-hover:text-gray-800">{{ cartItemCount }}</span>\n </template>\n </turbo-stream>\n {% endif %}\n """ -name: "frontoffice/pages/cart/_add_to_cart_response.turbo_stream.twig" -path: "/app/templates/frontoffice/pages/cart/_add_to_cart_response.turbo_stream.twig" } -phpFile: "/app/var/cache/dev/twig/7f/7f4ab4829f25ad51a2497a0aa7edd2b2.php" -phpLine: 53 }
{# Show notification #}<turbo-stream action="append" target="notification-container"><template>{{ component('ProductAddedNotification', {productVariant: productVariant,quantity: quantity}) }}</template></turbo-stream>
in
var/cache/dev/twig/7f/7f4ab4829f25ad51a2497a0aa7edd2b2.php
->
{closure:__TwigTemplate_45ff9f02c7c82d4a2d110388bcfc7fb9::doDisplay():53}
(line 53)
yield "<turbo-stream action=\"append\" target=\"notification-container\"><template>";// line 4yield $this->env->getRuntime('Symfony\UX\TwigComponent\Twig\ComponentRuntime')->render("ProductAddedNotification", ["productVariant" => // line 5(isset($context["productVariant"]) || array_key_exists("productVariant", $context) ? $context["productVariant"] : (function () { throw new RuntimeError('Variable "productVariant" does not exist.', 5, $this->source); })()), "quantity" => // line 6(isset($context["quantity"]) || array_key_exists("quantity", $context) ? $context["quantity"] : (function () { throw new RuntimeError('Variable "quantity" does not exist.', 6, $this->source); })())]);// line 7yield "</template></turbo-stream>
in
vendor/twig/twig/src/Template.php
->
doDisplay
(line 402)
{$context += $this->env->getGlobals();$blocks = array_merge($this->blocks, $blocks);try {yield from $this->doDisplay($context, $blocks);} catch (Error $e) {if (!$e->getSourceContext()) {$e->setSourceContext($this->getSourceContext());}
in
vendor/twig/twig/src/Template.php
->
yield
(line 358)
return $this->blocks;}public function display(array $context, array $blocks = []): void{foreach ($this->yield($context, $blocks) as $data) {echo $data;}}public function render(array $context): string
in
vendor/twig/twig/src/Template.php
->
display
(line 373)
ob_start();} else {ob_start(function () { return ''; });}try {$this->display($context);} catch (\Throwable $e) {while (ob_get_level() > $level) {ob_end_clean();}
in
vendor/twig/twig/src/TemplateWrapper.php
->
render
(line 51)
yield from $this->template->yieldBlock($name, $context);}public function render(array $context = []): string{return $this->template->render($context);}/*** @return void*/
in
vendor/twig/twig/src/Environment.php
->
render
(line 333)
* @throws SyntaxError When an error occurred during compilation* @throws RuntimeError When an error occurred during rendering*/public function render($name, array $context = []): string{return $this->load($name)->render($context);}/*** Displays a template.*
in
vendor/symfony/framework-bundle/Controller/AbstractController.php
->
render
(line 459)
if (null !== $block) {return $this->container->get('twig')->load($view)->renderBlock($block, $parameters);}return $this->container->get('twig')->render($view, $parameters);}private function doRender(string $view, ?string $block, array $parameters, ?Response $response, string $method): Response{$content = $this->doRenderView($view, $block, $parameters, $method);
in
vendor/symfony/framework-bundle/Controller/AbstractController.php
->
doRenderView
(line 464)
return $this->container->get('twig')->render($view, $parameters);}private function doRender(string $view, ?string $block, array $parameters, ?Response $response, string $method): Response{$content = $this->doRenderView($view, $block, $parameters, $method);$response ??= new Response();if (200 === $response->getStatusCode()) {foreach ($parameters as $v) {if ($v instanceof FormInterface && $v->isSubmitted() && !$v->isValid()) {
in
vendor/symfony/framework-bundle/Controller/AbstractController.php
->
doRender
(line 278)
* If an invalid form is found in the list of parameters, a 422 status code is returned.* Forms found in parameters are auto-cast to form views.*/protected function render(string $view, array $parameters = [], ?Response $response = null): Response{return $this->doRender($view, null, $parameters, $response, __FUNCTION__);}/*** Renders a block in a view.*
AbstractController->render('frontoffice/pages/cart/_add_to_cart_response.turbo_stream.twig', array('notificationMessage' => 'Produkt se nepodařilo přidat do košíku', 'type' => 'error'))
in
project/Frontoffice/App/Ui/Cart/AddToCartController.php
(line 86)
$notificationMessage = $this->flashMessageProducer->produceError(translation: 'cart.product_add_error',domain: 'frontoffice',);$response = $this->render('frontoffice/pages/cart/_add_to_cart_response.turbo_stream.twig', ['notificationMessage' => $notificationMessage,'type' => 'error',]);$response->headers->set('Content-Type', 'text/vnd.turbo-stream.html');
AddToCartController->renderTurboStreamError()
in
project/Frontoffice/App/Ui/Cart/AddToCartController.php
(line 38)
$requestData = $this->validateData($request);if ($requestData === null) {if ($isAjax) {return $this->renderTurboStreamError();}return $this->redirectToRoute('frontoffice_product_detail', ['product' => $product->id,]);
in
vendor/symfony/http-kernel/HttpKernel.php
->
addToCart
(line 183)
$this->dispatcher->dispatch($event, KernelEvents::CONTROLLER_ARGUMENTS);$controller = $event->getController();$arguments = $event->getArguments();// call controller$response = $controller(...$arguments);// viewif (!$response instanceof Response) {$event = new ViewEvent($this, $request, $type, $response, $event);$this->dispatcher->dispatch($event, KernelEvents::VIEW);
in
vendor/symfony/http-kernel/HttpKernel.php
->
handleRaw
(line 76)
$request->headers->set('X-Php-Ob-Level', (string) ob_get_level());$this->requestStack->push($request);$response = null;try {return $response = $this->handleRaw($request, $type);} catch (\Throwable $e) {if ($e instanceof \Error && !$this->handleAllThrowables) {throw $e;}
in
vendor/symfony/http-kernel/Kernel.php
->
handle
(line 182)
$this->boot();++$this->requestStackSize;$this->resetServices = true;try {return $this->getHttpKernel()->handle($request, $type, $catch);} finally {--$this->requestStackSize;}}
in
vendor/symfony/runtime/Runner/Symfony/HttpKernelRunner.php
->
handle
(line 35)
) {}public function run(): int{$response = $this->kernel->handle($this->request);if (Kernel::VERSION_ID >= 60400) {$response->send(false);if (\function_exists('fastcgi_finish_request') && !$this->debug) {
in
vendor/autoload_runtime.php
->
run
(line 29)
$app = $app(...$args);exit($runtime->getRunner($app)->run());
<?phpuse App\Infrastructure\Symfony\Kernel;require_once dirname(__DIR__).'/vendor/autoload_runtime.php';if (! defined("PROJECT_DIR")) {define('PROJECT_DIR', __DIR__ . '/../project');}
Logs
| Level | Channel | Message |
|---|---|---|
| INFO 19:18:14 | deprecation |
User Deprecated: Class "Doctrine\ORM\Proxy\Autoloader" is deprecated. Use native lazy objects instead. (Autoloader.php:74 called by DoctrineBundle.php:136, https://github.com/doctrine/orm/pull/12005, package doctrine/orm) {
"exception": {}
}
|
| INFO 19:18:14 | request |
Matched route "_profiler". {
"route": "_profiler",
"route_parameters": {
"_route": "_profiler",
"_controller": "web_profiler.controller.profiler::panelAction",
"token": "88c749"
},
"request_uri": "https://dev.slave.scapp.cz/_profiler/88c749",
"method": "GET"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.request" to listener "Symfony\Component\HttpKernel\EventListener\DebugHandlersListener::configure". {
"event": "kernel.request",
"listener": "Symfony\\Component\\HttpKernel\\EventListener\\DebugHandlersListener::configure"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.request" to listener "Symfony\UX\Turbo\Request\RequestListener::__invoke". {
"event": "kernel.request",
"listener": "Symfony\\UX\\Turbo\\Request\\RequestListener::__invoke"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.request" to listener "Symfony\Component\HttpKernel\EventListener\ValidateRequestListener::onKernelRequest". {
"event": "kernel.request",
"listener": "Symfony\\Component\\HttpKernel\\EventListener\\ValidateRequestListener::onKernelRequest"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.request" to listener "Symfony\Bridge\Doctrine\Middleware\IdleConnection\Listener::onKernelRequest". {
"event": "kernel.request",
"listener": "Symfony\\Bridge\\Doctrine\\Middleware\\IdleConnection\\Listener::onKernelRequest"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.request" to listener "Symfony\Component\HttpKernel\EventListener\SessionListener::onKernelRequest". {
"event": "kernel.request",
"listener": "Symfony\\Component\\HttpKernel\\EventListener\\SessionListener::onKernelRequest"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.request" to listener "Symfony\Component\HttpKernel\EventListener\LocaleListener::setDefaultLocale". {
"event": "kernel.request",
"listener": "Symfony\\Component\\HttpKernel\\EventListener\\LocaleListener::setDefaultLocale"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.request" to listener "Symfony\Component\AssetMapper\AssetMapperDevServerSubscriber::onKernelRequest". {
"event": "kernel.request",
"listener": "Symfony\\Component\\AssetMapper\\AssetMapperDevServerSubscriber::onKernelRequest"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.request" to listener "Symfony\Component\HttpKernel\EventListener\RouterListener::onKernelRequest". {
"event": "kernel.request",
"listener": "Symfony\\Component\\HttpKernel\\EventListener\\RouterListener::onKernelRequest"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.request" to listener "Symfony\Component\HttpKernel\EventListener\LocaleListener::onKernelRequest". {
"event": "kernel.request",
"listener": "Symfony\\Component\\HttpKernel\\EventListener\\LocaleListener::onKernelRequest"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.request" to listener "Symfony\Component\HttpKernel\EventListener\LocaleAwareListener::onKernelRequest". {
"event": "kernel.request",
"listener": "Symfony\\Component\\HttpKernel\\EventListener\\LocaleAwareListener::onKernelRequest"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.request" to listener "Symfony\Bundle\SecurityBundle\Debug\TraceableFirewallListener::configureLogoutUrlGenerator". {
"event": "kernel.request",
"listener": "Symfony\\Bundle\\SecurityBundle\\Debug\\TraceableFirewallListener::configureLogoutUrlGenerator"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.request" to listener "Symfony\Bundle\SecurityBundle\Debug\TraceableFirewallListener::onKernelRequest". {
"event": "kernel.request",
"listener": "Symfony\\Bundle\\SecurityBundle\\Debug\\TraceableFirewallListener::onKernelRequest"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.request" to listener "Symfony\UX\LiveComponent\EventListener\LiveComponentSubscriber::onKernelRequest". {
"event": "kernel.request",
"listener": "Symfony\\UX\\LiveComponent\\EventListener\\LiveComponentSubscriber::onKernelRequest"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.controller" to listener "Symfony\UX\LiveComponent\EventListener\LiveComponentSubscriber::onKernelController". {
"event": "kernel.controller",
"listener": "Symfony\\UX\\LiveComponent\\EventListener\\LiveComponentSubscriber::onKernelController"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.controller" to listener "Symfony\Bundle\FrameworkBundle\DataCollector\RouterDataCollector::onKernelController". {
"event": "kernel.controller",
"listener": "Symfony\\Bundle\\FrameworkBundle\\DataCollector\\RouterDataCollector::onKernelController"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.controller" to listener "App\Frontoffice\Domain\EventSubscriber\CartGlobalSubscriber::onKernelController". {
"event": "kernel.controller",
"listener": "App\\Frontoffice\\Domain\\EventSubscriber\\CartGlobalSubscriber::onKernelController"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.controller" to listener "Symfony\Component\HttpKernel\DataCollector\RequestDataCollector::onKernelController". {
"event": "kernel.controller",
"listener": "Symfony\\Component\\HttpKernel\\DataCollector\\RequestDataCollector::onKernelController"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.controller_arguments" to listener "Symfony\Component\Security\Http\EventListener\IsCsrfTokenValidAttributeListener::onKernelControllerArguments". {
"event": "kernel.controller_arguments",
"listener": "Symfony\\Component\\Security\\Http\\EventListener\\IsCsrfTokenValidAttributeListener::onKernelControllerArguments"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.controller_arguments" to listener "Symfony\Component\Security\Http\EventListener\IsGrantedAttributeListener::onKernelControllerArguments". {
"event": "kernel.controller_arguments",
"listener": "Symfony\\Component\\Security\\Http\\EventListener\\IsGrantedAttributeListener::onKernelControllerArguments"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.controller_arguments" to listener "Symfony\Component\HttpKernel\EventListener\CacheAttributeListener::onKernelControllerArguments". {
"event": "kernel.controller_arguments",
"listener": "Symfony\\Component\\HttpKernel\\EventListener\\CacheAttributeListener::onKernelControllerArguments"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.controller_arguments" to listener "Symfony\Component\HttpKernel\Controller\ArgumentResolver\RequestPayloadValueResolver::onKernelControllerArguments". {
"event": "kernel.controller_arguments",
"listener": "Symfony\\Component\\HttpKernel\\Controller\\ArgumentResolver\\RequestPayloadValueResolver::onKernelControllerArguments"
}
|
| DEBUG 19:18:14 | event |
Notified event "kernel.controller_arguments" to listener "Symfony\Component\HttpKernel\EventListener\ErrorListener::onControllerArguments". {
"event": "kernel.controller_arguments",
"listener": "Symfony\\Component\\HttpKernel\\EventListener\\ErrorListener::onControllerArguments"
}
|
Stack Trace
|
RuntimeError
|
|---|
Twig\Error\RuntimeError:
Variable "productVariant" does not exist in "frontoffice/pages/cart/_add_to_cart_response.turbo_stream.twig" at line 5.
at templates/frontoffice/pages/cart/_add_to_cart_response.turbo_stream.twig:5
at __TwigTemplate_45ff9f02c7c82d4a2d110388bcfc7fb9->{closure:__TwigTemplate_45ff9f02c7c82d4a2d110388bcfc7fb9::doDisplay():53}()
(var/cache/dev/twig/7f/7f4ab4829f25ad51a2497a0aa7edd2b2.php:53)
at __TwigTemplate_45ff9f02c7c82d4a2d110388bcfc7fb9->doDisplay(array('notificationMessage' => 'Produkt se nepodařilo přidat do košíku', 'type' => 'error', 'app' => object(AppVariable), 'config' => object(ConfigurationProvider), 'backoffice' => object(BackofficeNavigationConfigurationProvider)), array())
(vendor/twig/twig/src/Template.php:402)
at Twig\Template->yield(array('notificationMessage' => 'Produkt se nepodařilo přidat do košíku', 'type' => 'error', 'app' => object(AppVariable), 'config' => object(ConfigurationProvider), 'backoffice' => object(BackofficeNavigationConfigurationProvider)), array())
(vendor/twig/twig/src/Template.php:358)
at Twig\Template->display(array('notificationMessage' => 'Produkt se nepodařilo přidat do košíku', 'type' => 'error'))
(vendor/twig/twig/src/Template.php:373)
at Twig\Template->render(array('notificationMessage' => 'Produkt se nepodařilo přidat do košíku', 'type' => 'error'))
(vendor/twig/twig/src/TemplateWrapper.php:51)
at Twig\TemplateWrapper->render(array('notificationMessage' => 'Produkt se nepodařilo přidat do košíku', 'type' => 'error'))
(vendor/twig/twig/src/Environment.php:333)
at Twig\Environment->render('frontoffice/pages/cart/_add_to_cart_response.turbo_stream.twig', array('notificationMessage' => 'Produkt se nepodařilo přidat do košíku', 'type' => 'error'))
(vendor/symfony/framework-bundle/Controller/AbstractController.php:459)
at Symfony\Bundle\FrameworkBundle\Controller\AbstractController->doRenderView('frontoffice/pages/cart/_add_to_cart_response.turbo_stream.twig', null, array('notificationMessage' => 'Produkt se nepodařilo přidat do košíku', 'type' => 'error'), 'render')
(vendor/symfony/framework-bundle/Controller/AbstractController.php:464)
at Symfony\Bundle\FrameworkBundle\Controller\AbstractController->doRender('frontoffice/pages/cart/_add_to_cart_response.turbo_stream.twig', null, array('notificationMessage' => 'Produkt se nepodařilo přidat do košíku', 'type' => 'error'), null, 'render')
(vendor/symfony/framework-bundle/Controller/AbstractController.php:278)
at Symfony\Bundle\FrameworkBundle\Controller\AbstractController->render('frontoffice/pages/cart/_add_to_cart_response.turbo_stream.twig', array('notificationMessage' => 'Produkt se nepodařilo přidat do košíku', 'type' => 'error'))
(project/Frontoffice/App/Ui/Cart/AddToCartController.php:86)
at App\Frontoffice\App\Ui\Cart\AddToCartController->renderTurboStreamError()
(project/Frontoffice/App/Ui/Cart/AddToCartController.php:38)
at App\Frontoffice\App\Ui\Cart\AddToCartController->addToCart(object(Product), object(Request))
(vendor/symfony/http-kernel/HttpKernel.php:183)
at Symfony\Component\HttpKernel\HttpKernel->handleRaw(object(Request), 1)
(vendor/symfony/http-kernel/HttpKernel.php:76)
at Symfony\Component\HttpKernel\HttpKernel->handle(object(Request), 1, true)
(vendor/symfony/http-kernel/Kernel.php:182)
at Symfony\Component\HttpKernel\Kernel->handle(object(Request))
(vendor/symfony/runtime/Runner/Symfony/HttpKernelRunner.php:35)
at Symfony\Component\Runtime\Runner\Symfony\HttpKernelRunner->run()
(vendor/autoload_runtime.php:29)
at require_once('/app/vendor/autoload_runtime.php')
(public/index.php:5)
|