Error 500 Internal Server Error

GET https://sylius-cuisinstore.preprod.eu/fr_FR/taxons/accessoires-de-cuisson-gant-de-cuisine-pour-four-983

Exceptions

An error occurred during rendering the "products" hook in the "sylius_shop.product.index.content.body.main" hookable. An exception has been thrown during the rendering of a template ("Product has no variants") in @SyliusShop/product/index/content/body/main/products.html.twig at line 8 in @SyliusShop/product/index/content/body/main/products.html.twig at line 8.

Exceptions 3

Sylius\TwigHooks\Hookable\Renderer\Exception\ HookRenderException

Show exception properties
Sylius\TwigHooks\Hookable\Renderer\Exception\HookRenderException {#27647
  -lineno: 8
  -rawMessage: "An error occurred during rendering the "products" hook in the "sylius_shop.product.index.content.body.main" hookable. An exception has been thrown during the rendering of a template ("Product has no variants") in "@SyliusShop/product/index/content/body/main/products.html.twig" at line 8."
  -source: Twig\Source {#30313
    -code: """
      {% import '@SyliusShop/shared/messages.html.twig' as messages %}\n
      \n
      {% set resources = hookable_metadata.context.resources %}\n
      \n
      {% if resources.data|length > 0 %}\n
          <div class="products-grid" {{ sylius_test_html_attribute('products') }}>\n
              {% for product in resources.data %}\n
                  {{ component('sylius_shop:product:card', { product: product, template: hookable_metadata.configuration.product_template|default('@SyliusShop/product/common/card.html.twig'), hookableMetadata: hookable_metadata }) }}\n
              {% endfor %}\n
          </div>\n
      {% else %}\n
          {{ messages.info('sylius.ui.no_results_to_display') }}\n
      {% endif %}\n
      """
    -name: "@SyliusShop/product/index/content/body/main/products.html.twig"
    -path: "/www/wwwroot/sylius-cuisinstore/vendor/sylius/sylius/src/Sylius/Bundle/ShopBundle/templates/product/index/content/body/main/products.html.twig"
  }
  -phpFile: "/www/wwwroot/sylius-cuisinstore/vendor/sylius/twig-hooks/src/Hookable/Renderer/HookableTemplateRenderer.php"
  -phpLine: 54
}
  1. {% set resources = hookable_metadata.context.resources %}
  2. {% if resources.data|length > 0 %}
  3. <div class="products-grid" {{ sylius_test_html_attribute('products') }}>
  4. {% for product in resources.data %}
  5. {{ component('sylius_shop:product:card', { product: product, template: hookable_metadata.configuration.product_template|default('@SyliusShop/product/common/card.html.twig'), hookableMetadata: hookable_metadata }) }}
  6. {% endfor %}
  7. </div>
  8. {% else %}
  9. {{ messages.info('sylius.ui.no_results_to_display') }}
  10. {% endif %}
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. foreach ($this->renderers as $renderer) {
  4. if ($renderer->supports($hookable)) {
  5. return $renderer->render($hookable, $metadata);
  6. }
  7. }
  8. throw new NoSupportedRendererException($hookable->hookName, $hookable->name);
  9. }
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. $this->profile?->registerHookableRenderStart($hookable);
  4. $this->stopwatch?->start($hookable->id);
  5. $rendered = $this->innerRenderer->render($hookable, $metadata);
  6. $this->profile?->registerHookableRenderEnd(
  7. $this->stopwatch?->stop($hookable->id)->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookable,
  3. $metadata,
  4. '%s BEGIN HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookable, $metadata));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookable,
  9. $metadata,
  10. '%s END HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  11. );
  1. new DataBag($context),
  2. new ScalarDataBag($configuration),
  3. $hookNames,
  4. );
  5. $renderedHookables[] = $this->compositeHookableRenderer->render($hookable, $hookableMetadata);
  6. }
  7. return implode(\PHP_EOL, $renderedHookables);
  8. }
  9. }
  1. public function render(array $hookNames, array $hookContext = []): string
  2. {
  3. $this->profile?->registerHookStart($hookNames);
  4. $this->stopwatch?->start(md5(serialize($hookNames)));
  5. $rendered = $this->innerRenderer->render($hookNames, $hookContext);
  6. $this->profile?->registerHookEnd(
  7. $this->stopwatch?->stop(md5(serialize($hookNames)))->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookNames,
  3. $hookContext,
  4. '%s BEGIN HOOK | name: "%s" %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookNames, $hookContext));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookNames,
  9. $hookContext,
  10. '%s END HOOK | name: "%s" %s',
  11. );
  1. $format = str_starts_with($hookName, '#') ? '%s%s' : '%s.%s';
  2. $prefixedHookNames[] = sprintf($format, $prefix, $hookName);
  3. }
  4. }
  5. return $this->hookRenderer->render($prefixedHookNames, $context);
  6. }
  7. /**
  8. * @param array<string, mixed> $hookContext
  9. *
  1. // line 1
  2. yield "<div class=\"col-12 col-lg-9\">
  3. ";
  4. // line 2
  5. $hooksRuntime = $this->env->getRuntime('Sylius\TwigHooks\Twig\Runtime\HooksRuntime');
  6. echo $hooksRuntime->renderHook("main", [], $context, false);
  7. // line 3
  8. yield "</div>
  9. ";
  10. $__internal_5a27a8ba21ca79b61932376b2fa922d2->leave($__internal_5a27a8ba21ca79b61932376b2fa922d2_prof);
in vendor/twig/twig/src/Template.php -> doDisplay (line 402)
  1. {
  2. $context += $this->env->getGlobals();
  3. $blocks = array_merge($this->blocks, $blocks);
  4. try {
  5. yield from $this->doDisplay($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($this->getSourceContext());
  9. }
  1. return $this->blocks;
  2. }
  3. public function display(array $context, array $blocks = []): void
  4. {
  5. foreach ($this->yield($context, $blocks) as $data) {
  6. echo $data;
  7. }
  8. }
  9. public function render(array $context): string
in vendor/twig/twig/src/Template.php -> display (line 373)
  1. ob_start();
  2. } else {
  3. ob_start(function () { return ''; });
  4. }
  5. try {
  6. $this->display($context);
  7. } catch (\Throwable $e) {
  8. while (ob_get_level() > $level) {
  9. ob_end_clean();
  10. }
  1. yield from $this->template->yieldBlock($name, $context);
  2. }
  3. public function render(array $context = []): string
  4. {
  5. return $this->template->render($context);
  6. }
  7. /**
  8. * @return void
  9. */
  1. * @throws SyntaxError When an error occurred during compilation
  2. * @throws RuntimeError When an error occurred during rendering
  3. */
  4. public function render($name, array $context = []): string
  5. {
  6. return $this->load($name)->render($context);
  7. }
  8. /**
  9. * Displays a template.
  10. *
  1. try {
  2. $configuration = $this->configurationProvider->provide($hookable, $metadata);
  3. $metadata = $metadata->withConfiguration(new ScalarDataBag($configuration));
  4. return $this->twig->render($hookable->template, [
  5. HooksRuntime::HOOKABLE_METADATA => $metadata,
  6. ]);
  7. } catch (HookRenderException $exception) {
  8. throw $exception;
  9. } catch (\Throwable $exception) {
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. foreach ($this->renderers as $renderer) {
  4. if ($renderer->supports($hookable)) {
  5. return $renderer->render($hookable, $metadata);
  6. }
  7. }
  8. throw new NoSupportedRendererException($hookable->hookName, $hookable->name);
  9. }
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. $this->profile?->registerHookableRenderStart($hookable);
  4. $this->stopwatch?->start($hookable->id);
  5. $rendered = $this->innerRenderer->render($hookable, $metadata);
  6. $this->profile?->registerHookableRenderEnd(
  7. $this->stopwatch?->stop($hookable->id)->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookable,
  3. $metadata,
  4. '%s BEGIN HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookable, $metadata));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookable,
  9. $metadata,
  10. '%s END HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  11. );
  1. new DataBag($context),
  2. new ScalarDataBag($configuration),
  3. $hookNames,
  4. );
  5. $renderedHookables[] = $this->compositeHookableRenderer->render($hookable, $hookableMetadata);
  6. }
  7. return implode(\PHP_EOL, $renderedHookables);
  8. }
  9. }
  1. public function render(array $hookNames, array $hookContext = []): string
  2. {
  3. $this->profile?->registerHookStart($hookNames);
  4. $this->stopwatch?->start(md5(serialize($hookNames)));
  5. $rendered = $this->innerRenderer->render($hookNames, $hookContext);
  6. $this->profile?->registerHookEnd(
  7. $this->stopwatch?->stop(md5(serialize($hookNames)))->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookNames,
  3. $hookContext,
  4. '%s BEGIN HOOK | name: "%s" %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookNames, $hookContext));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookNames,
  9. $hookContext,
  10. '%s END HOOK | name: "%s" %s',
  11. );
  1. $format = str_starts_with($hookName, '#') ? '%s%s' : '%s.%s';
  2. $prefixedHookNames[] = sprintf($format, $prefix, $hookName);
  3. }
  4. }
  5. return $this->hookRenderer->render($prefixedHookNames, $context);
  6. }
  7. /**
  8. * @param array<string, mixed> $hookContext
  9. *
  1. // line 1
  2. yield "<div class=\"row mt-5\">
  3. ";
  4. // line 2
  5. $hooksRuntime = $this->env->getRuntime('Sylius\TwigHooks\Twig\Runtime\HooksRuntime');
  6. echo $hooksRuntime->renderHook("body", [], $context, false);
  7. // line 3
  8. yield "</div>
  9. ";
  10. $__internal_5a27a8ba21ca79b61932376b2fa922d2->leave($__internal_5a27a8ba21ca79b61932376b2fa922d2_prof);
in vendor/twig/twig/src/Template.php -> doDisplay (line 402)
  1. {
  2. $context += $this->env->getGlobals();
  3. $blocks = array_merge($this->blocks, $blocks);
  4. try {
  5. yield from $this->doDisplay($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($this->getSourceContext());
  9. }
  1. return $this->blocks;
  2. }
  3. public function display(array $context, array $blocks = []): void
  4. {
  5. foreach ($this->yield($context, $blocks) as $data) {
  6. echo $data;
  7. }
  8. }
  9. public function render(array $context): string
in vendor/twig/twig/src/Template.php -> display (line 373)
  1. ob_start();
  2. } else {
  3. ob_start(function () { return ''; });
  4. }
  5. try {
  6. $this->display($context);
  7. } catch (\Throwable $e) {
  8. while (ob_get_level() > $level) {
  9. ob_end_clean();
  10. }
  1. yield from $this->template->yieldBlock($name, $context);
  2. }
  3. public function render(array $context = []): string
  4. {
  5. return $this->template->render($context);
  6. }
  7. /**
  8. * @return void
  9. */
  1. * @throws SyntaxError When an error occurred during compilation
  2. * @throws RuntimeError When an error occurred during rendering
  3. */
  4. public function render($name, array $context = []): string
  5. {
  6. return $this->load($name)->render($context);
  7. }
  8. /**
  9. * Displays a template.
  10. *
  1. try {
  2. $configuration = $this->configurationProvider->provide($hookable, $metadata);
  3. $metadata = $metadata->withConfiguration(new ScalarDataBag($configuration));
  4. return $this->twig->render($hookable->template, [
  5. HooksRuntime::HOOKABLE_METADATA => $metadata,
  6. ]);
  7. } catch (HookRenderException $exception) {
  8. throw $exception;
  9. } catch (\Throwable $exception) {
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. foreach ($this->renderers as $renderer) {
  4. if ($renderer->supports($hookable)) {
  5. return $renderer->render($hookable, $metadata);
  6. }
  7. }
  8. throw new NoSupportedRendererException($hookable->hookName, $hookable->name);
  9. }
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. $this->profile?->registerHookableRenderStart($hookable);
  4. $this->stopwatch?->start($hookable->id);
  5. $rendered = $this->innerRenderer->render($hookable, $metadata);
  6. $this->profile?->registerHookableRenderEnd(
  7. $this->stopwatch?->stop($hookable->id)->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookable,
  3. $metadata,
  4. '%s BEGIN HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookable, $metadata));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookable,
  9. $metadata,
  10. '%s END HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  11. );
  1. new DataBag($context),
  2. new ScalarDataBag($configuration),
  3. $hookNames,
  4. );
  5. $renderedHookables[] = $this->compositeHookableRenderer->render($hookable, $hookableMetadata);
  6. }
  7. return implode(\PHP_EOL, $renderedHookables);
  8. }
  9. }
  1. public function render(array $hookNames, array $hookContext = []): string
  2. {
  3. $this->profile?->registerHookStart($hookNames);
  4. $this->stopwatch?->start(md5(serialize($hookNames)));
  5. $rendered = $this->innerRenderer->render($hookNames, $hookContext);
  6. $this->profile?->registerHookEnd(
  7. $this->stopwatch?->stop(md5(serialize($hookNames)))->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookNames,
  3. $hookContext,
  4. '%s BEGIN HOOK | name: "%s" %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookNames, $hookContext));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookNames,
  9. $hookContext,
  10. '%s END HOOK | name: "%s" %s',
  11. );
  1. $format = str_starts_with($hookName, '#') ? '%s%s' : '%s.%s';
  2. $prefixedHookNames[] = sprintf($format, $prefix, $hookName);
  3. }
  4. }
  5. return $this->hookRenderer->render($prefixedHookNames, $context);
  6. }
  7. /**
  8. * @param array<string, mixed> $hookContext
  9. *
  1. // line 1
  2. yield "<div class=\"container mt-4 mb-5\">
  3. ";
  4. // line 2
  5. $hooksRuntime = $this->env->getRuntime('Sylius\TwigHooks\Twig\Runtime\HooksRuntime');
  6. echo $hooksRuntime->renderHook("content", [], $context, false);
  7. // line 3
  8. yield "</div>
  9. ";
  10. $__internal_5a27a8ba21ca79b61932376b2fa922d2->leave($__internal_5a27a8ba21ca79b61932376b2fa922d2_prof);
in vendor/twig/twig/src/Template.php -> doDisplay (line 402)
  1. {
  2. $context += $this->env->getGlobals();
  3. $blocks = array_merge($this->blocks, $blocks);
  4. try {
  5. yield from $this->doDisplay($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($this->getSourceContext());
  9. }
  1. return $this->blocks;
  2. }
  3. public function display(array $context, array $blocks = []): void
  4. {
  5. foreach ($this->yield($context, $blocks) as $data) {
  6. echo $data;
  7. }
  8. }
  9. public function render(array $context): string
in vendor/twig/twig/src/Template.php -> display (line 373)
  1. ob_start();
  2. } else {
  3. ob_start(function () { return ''; });
  4. }
  5. try {
  6. $this->display($context);
  7. } catch (\Throwable $e) {
  8. while (ob_get_level() > $level) {
  9. ob_end_clean();
  10. }
  1. yield from $this->template->yieldBlock($name, $context);
  2. }
  3. public function render(array $context = []): string
  4. {
  5. return $this->template->render($context);
  6. }
  7. /**
  8. * @return void
  9. */
  1. * @throws SyntaxError When an error occurred during compilation
  2. * @throws RuntimeError When an error occurred during rendering
  3. */
  4. public function render($name, array $context = []): string
  5. {
  6. return $this->load($name)->render($context);
  7. }
  8. /**
  9. * Displays a template.
  10. *
  1. try {
  2. $configuration = $this->configurationProvider->provide($hookable, $metadata);
  3. $metadata = $metadata->withConfiguration(new ScalarDataBag($configuration));
  4. return $this->twig->render($hookable->template, [
  5. HooksRuntime::HOOKABLE_METADATA => $metadata,
  6. ]);
  7. } catch (HookRenderException $exception) {
  8. throw $exception;
  9. } catch (\Throwable $exception) {
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. foreach ($this->renderers as $renderer) {
  4. if ($renderer->supports($hookable)) {
  5. return $renderer->render($hookable, $metadata);
  6. }
  7. }
  8. throw new NoSupportedRendererException($hookable->hookName, $hookable->name);
  9. }
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. $this->profile?->registerHookableRenderStart($hookable);
  4. $this->stopwatch?->start($hookable->id);
  5. $rendered = $this->innerRenderer->render($hookable, $metadata);
  6. $this->profile?->registerHookableRenderEnd(
  7. $this->stopwatch?->stop($hookable->id)->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookable,
  3. $metadata,
  4. '%s BEGIN HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookable, $metadata));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookable,
  9. $metadata,
  10. '%s END HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  11. );
  1. new DataBag($context),
  2. new ScalarDataBag($configuration),
  3. $hookNames,
  4. );
  5. $renderedHookables[] = $this->compositeHookableRenderer->render($hookable, $hookableMetadata);
  6. }
  7. return implode(\PHP_EOL, $renderedHookables);
  8. }
  9. }
  1. public function render(array $hookNames, array $hookContext = []): string
  2. {
  3. $this->profile?->registerHookStart($hookNames);
  4. $this->stopwatch?->start(md5(serialize($hookNames)));
  5. $rendered = $this->innerRenderer->render($hookNames, $hookContext);
  6. $this->profile?->registerHookEnd(
  7. $this->stopwatch?->stop(md5(serialize($hookNames)))->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookNames,
  3. $hookContext,
  4. '%s BEGIN HOOK | name: "%s" %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookNames, $hookContext));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookNames,
  9. $hookContext,
  10. '%s END HOOK | name: "%s" %s',
  11. );
  1. $context = $this->getContext($hookContext, $twigVars, $hookableMetadata, $only);
  2. $prefixes = $this->getPrefixes($hookContext, $hookableMetadata);
  3. if (false === $this->enableAutoprefixing || [] === $prefixes) {
  4. return $this->hookRenderer->render($hookNames, $context);
  5. }
  6. $prefixedHookNames = [];
  7. foreach ($hookNames as $hookName) {
  1. $__internal_6f47bbe9983af81f1e7450e9a3e3768f->enter($__internal_6f47bbe9983af81f1e7450e9a3e3768f_prof = new \Twig\Profiler\Profile($this->getTemplateName(), "block", "content"));
  2. // line 4
  3. yield " ";
  4. $hooksRuntime = $this->env->getRuntime('Sylius\TwigHooks\Twig\Runtime\HooksRuntime');
  5. echo $hooksRuntime->renderHook("sylius_shop.product.index", ["products" => (isset($context["products"]) || array_key_exists("products", $context) ? $context["products"] : (function () { throw new RuntimeError('Variable "products" does not exist.', 4, $this->source); })()), "resources" => (isset($context["resources"]) || array_key_exists("resources", $context) ? $context["resources"] : (function () { throw new RuntimeError('Variable "resources" does not exist.', 4, $this->source); })())], $context, false);
  6. $__internal_6f47bbe9983af81f1e7450e9a3e3768f->leave($__internal_6f47bbe9983af81f1e7450e9a3e3768f_prof);
  7. $__internal_5a27a8ba21ca79b61932376b2fa922d2->leave($__internal_5a27a8ba21ca79b61932376b2fa922d2_prof);
in vendor/twig/twig/src/Template.php -> block_content (line 446)
  1. throw new \LogicException('A block must be a method on a \Twig\Template instance.');
  2. }
  3. if (null !== $template) {
  4. try {
  5. yield from $template->$block($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($template->getSourceContext());
  9. }
  1. yield from $this->unwrap()->yieldBlock('header', $context, $blocks);
  2. // line 30
  3. yield "
  4. ";
  5. // line 31
  6. yield from $this->unwrap()->yieldBlock('content', $context, $blocks);
  7. // line 32
  8. yield "
  9. ";
  10. // line 33
  11. yield from $this->unwrap()->yieldBlock('footer', $context, $blocks);
in vendor/twig/twig/src/Template.php -> block_body (line 446)
  1. throw new \LogicException('A block must be a method on a \Twig\Template instance.');
  2. }
  3. if (null !== $template) {
  4. try {
  5. yield from $template->$block($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($template->getSourceContext());
  9. }
  1. // line 23
  2. yield $this->env->getRuntime('Twig\Runtime\EscaperRuntime')->escape(CoreExtension::getAttribute($this->env, $this->source, CoreExtension::getAttribute($this->env, $this->source, (isset($context["app"]) || array_key_exists("app", $context) ? $context["app"] : (function () { throw new RuntimeError('Variable "app" does not exist.', 23, $this->source); })()), "request", [], "any", false, false, false, 23), "get", ["_route"], "method", false, false, false, 23), "html", null, true);
  3. yield "\">
  4. ";
  5. // line 24
  6. yield from $this->unwrap()->yieldBlock('body', $context, $blocks);
  7. // line 39
  8. yield "
  9. ";
  10. // line 40
  11. yield from $this->unwrap()->yieldBlock('javascripts', $context, $blocks);
in vendor/twig/twig/src/Template.php -> doDisplay (line 402)
  1. {
  2. $context += $this->env->getGlobals();
  3. $blocks = array_merge($this->blocks, $blocks);
  4. try {
  5. yield from $this->doDisplay($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($this->getSourceContext());
  9. }
  1. $__internal_6f47bbe9983af81f1e7450e9a3e3768f = $this->extensions["Symfony\\Bridge\\Twig\\Extension\\ProfilerExtension"];
  2. $__internal_6f47bbe9983af81f1e7450e9a3e3768f->enter($__internal_6f47bbe9983af81f1e7450e9a3e3768f_prof = new \Twig\Profiler\Profile($this->getTemplateName(), "template", "@SyliusShop/product/index.html.twig"));
  3. $this->parent = $this->load("@SyliusShop/shared/layout/base.html.twig", 1);
  4. yield from $this->parent->unwrap()->yield($context, array_merge($this->blocks, $blocks));
  5. $__internal_5a27a8ba21ca79b61932376b2fa922d2->leave($__internal_5a27a8ba21ca79b61932376b2fa922d2_prof);
  6. $__internal_6f47bbe9983af81f1e7450e9a3e3768f->leave($__internal_6f47bbe9983af81f1e7450e9a3e3768f_prof);
in vendor/twig/twig/src/Template.php -> doDisplay (line 402)
  1. {
  2. $context += $this->env->getGlobals();
  3. $blocks = array_merge($this->blocks, $blocks);
  4. try {
  5. yield from $this->doDisplay($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($this->getSourceContext());
  9. }
  1. return $this->blocks;
  2. }
  3. public function display(array $context, array $blocks = []): void
  4. {
  5. foreach ($this->yield($context, $blocks) as $data) {
  6. echo $data;
  7. }
  8. }
  9. public function render(array $context): string
in vendor/twig/twig/src/Template.php -> display (line 373)
  1. ob_start();
  2. } else {
  3. ob_start(function () { return ''; });
  4. }
  5. try {
  6. $this->display($context);
  7. } catch (\Throwable $e) {
  8. while (ob_get_level() > $level) {
  9. ob_end_clean();
  10. }
  1. yield from $this->template->yieldBlock($name, $context);
  2. }
  3. public function render(array $context = []): string
  4. {
  5. return $this->template->render($context);
  6. }
  7. /**
  8. * @return void
  9. */
  1. * @throws SyntaxError When an error occurred during compilation
  2. * @throws RuntimeError When an error occurred during rendering
  3. */
  4. public function render($name, array $context = []): string
  5. {
  6. return $this->load($name)->render($context);
  7. }
  8. /**
  9. * Displays a template.
  10. *
  1. if ($this->container->has('templating')) {
  2. @trigger_error('Using the "templating" service is deprecated since Symfony 4.3 and will be removed in 5.0; use Twig instead.', \E_USER_DEPRECATED);
  3. $content = $this->container->get('templating')->render($view, $parameters);
  4. } elseif ($this->container->has('twig')) {
  5. $content = $this->container->get('twig')->render($view, $parameters);
  6. } else {
  7. throw new \LogicException('You can not use the "render" method if the Templating Component or the Twig Bundle are not available. Try running "composer require symfony/twig-bundle".');
  8. }
  9. if (null === $response) {
  1. if (null !== $eventResponse) {
  2. return $eventResponse;
  3. }
  4. if ($configuration->isHtmlRequest()) {
  5. return $this->render($configuration->getTemplate(ResourceActions::INDEX . '.html'), [
  6. 'configuration' => $configuration,
  7. 'metadata' => $this->metadata,
  8. 'resources' => $resources,
  9. $this->metadata->getPluralName() => $resources,
  10. ]);
in vendor/symfony/http-kernel/HttpKernel.php -> indexAction (line 183)
  1. $this->dispatcher->dispatch($event, KernelEvents::CONTROLLER_ARGUMENTS);
  2. $controller = $event->getController();
  3. $arguments = $event->getArguments();
  4. // call controller
  5. $response = $controller(...$arguments);
  6. // view
  7. if (!$response instanceof Response) {
  8. $event = new ViewEvent($this, $request, $type, $response, $event);
  9. $this->dispatcher->dispatch($event, KernelEvents::VIEW);
  1. $request->headers->set('X-Php-Ob-Level', (string) ob_get_level());
  2. $this->requestStack->push($request);
  3. $response = null;
  4. try {
  5. return $response = $this->handleRaw($request, $type);
  6. } catch (\Throwable $e) {
  7. if ($e instanceof \Error && !$this->handleAllThrowables) {
  8. throw $e;
  9. }
  1. $this->boot();
  2. ++$this->requestStackSize;
  3. $this->resetServices = true;
  4. try {
  5. return $this->getHttpKernel()->handle($request, $type, $catch);
  6. } finally {
  7. --$this->requestStackSize;
  8. }
  9. }
  1. ) {
  2. }
  3. public function run(): int
  4. {
  5. $response = $this->kernel->handle($this->request);
  6. if (Kernel::VERSION_ID >= 60400) {
  7. $response->send(false);
  8. if (\function_exists('fastcgi_finish_request') && !$this->debug) {
in vendor/autoload_runtime.php -> run (line 29)
  1. $app = $app(...$args);
  2. exit(
  3. $runtime
  4. ->getRunner($app)
  5. ->run()
  6. );
require_once('/www/wwwroot/sylius-cuisinstore/vendor/autoload_runtime.php') in public/index.php (line 5)
  1. <?php
  2. use App\Kernel;
  3. require_once dirname(__DIR__).'/vendor/autoload_runtime.php';
  4. return function (array $context) {
  5. return new Kernel($context['APP_ENV'], (bool) $context['APP_DEBUG']);
  6. };

Twig\Error\ RuntimeError

An exception has been thrown during the rendering of a template ("Product has no variants") in "@SyliusShop/product/index/content/body/main/products.html.twig" at line 8.

  1. {% set resources = hookable_metadata.context.resources %}
  2. {% if resources.data|length > 0 %}
  3. <div class="products-grid" {{ sylius_test_html_attribute('products') }}>
  4. {% for product in resources.data %}
  5. {{ component('sylius_shop:product:card', { product: product, template: hookable_metadata.configuration.product_template|default('@SyliusShop/product/common/card.html.twig'), hookableMetadata: hookable_metadata }) }}
  6. {% endfor %}
  7. </div>
  8. {% else %}
  9. {{ messages.info('sylius.ui.no_results_to_display') }}
  10. {% endif %}
  1. return $this->blocks;
  2. }
  3. public function display(array $context, array $blocks = []): void
  4. {
  5. foreach ($this->yield($context, $blocks) as $data) {
  6. echo $data;
  7. }
  8. }
  9. public function render(array $context): string
in vendor/twig/twig/src/Template.php -> display (line 373)
  1. ob_start();
  2. } else {
  3. ob_start(function () { return ''; });
  4. }
  5. try {
  6. $this->display($context);
  7. } catch (\Throwable $e) {
  8. while (ob_get_level() > $level) {
  9. ob_end_clean();
  10. }
  1. yield from $this->template->yieldBlock($name, $context);
  2. }
  3. public function render(array $context = []): string
  4. {
  5. return $this->template->render($context);
  6. }
  7. /**
  8. * @return void
  9. */
  1. * @throws SyntaxError When an error occurred during compilation
  2. * @throws RuntimeError When an error occurred during rendering
  3. */
  4. public function render($name, array $context = []): string
  5. {
  6. return $this->load($name)->render($context);
  7. }
  8. /**
  9. * Displays a template.
  10. *
  1. try {
  2. $configuration = $this->configurationProvider->provide($hookable, $metadata);
  3. $metadata = $metadata->withConfiguration(new ScalarDataBag($configuration));
  4. return $this->twig->render($hookable->template, [
  5. HooksRuntime::HOOKABLE_METADATA => $metadata,
  6. ]);
  7. } catch (HookRenderException $exception) {
  8. throw $exception;
  9. } catch (\Throwable $exception) {
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. foreach ($this->renderers as $renderer) {
  4. if ($renderer->supports($hookable)) {
  5. return $renderer->render($hookable, $metadata);
  6. }
  7. }
  8. throw new NoSupportedRendererException($hookable->hookName, $hookable->name);
  9. }
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. $this->profile?->registerHookableRenderStart($hookable);
  4. $this->stopwatch?->start($hookable->id);
  5. $rendered = $this->innerRenderer->render($hookable, $metadata);
  6. $this->profile?->registerHookableRenderEnd(
  7. $this->stopwatch?->stop($hookable->id)->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookable,
  3. $metadata,
  4. '%s BEGIN HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookable, $metadata));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookable,
  9. $metadata,
  10. '%s END HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  11. );
  1. new DataBag($context),
  2. new ScalarDataBag($configuration),
  3. $hookNames,
  4. );
  5. $renderedHookables[] = $this->compositeHookableRenderer->render($hookable, $hookableMetadata);
  6. }
  7. return implode(\PHP_EOL, $renderedHookables);
  8. }
  9. }
  1. public function render(array $hookNames, array $hookContext = []): string
  2. {
  3. $this->profile?->registerHookStart($hookNames);
  4. $this->stopwatch?->start(md5(serialize($hookNames)));
  5. $rendered = $this->innerRenderer->render($hookNames, $hookContext);
  6. $this->profile?->registerHookEnd(
  7. $this->stopwatch?->stop(md5(serialize($hookNames)))->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookNames,
  3. $hookContext,
  4. '%s BEGIN HOOK | name: "%s" %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookNames, $hookContext));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookNames,
  9. $hookContext,
  10. '%s END HOOK | name: "%s" %s',
  11. );
  1. $format = str_starts_with($hookName, '#') ? '%s%s' : '%s.%s';
  2. $prefixedHookNames[] = sprintf($format, $prefix, $hookName);
  3. }
  4. }
  5. return $this->hookRenderer->render($prefixedHookNames, $context);
  6. }
  7. /**
  8. * @param array<string, mixed> $hookContext
  9. *
  1. // line 1
  2. yield "<div class=\"col-12 col-lg-9\">
  3. ";
  4. // line 2
  5. $hooksRuntime = $this->env->getRuntime('Sylius\TwigHooks\Twig\Runtime\HooksRuntime');
  6. echo $hooksRuntime->renderHook("main", [], $context, false);
  7. // line 3
  8. yield "</div>
  9. ";
  10. $__internal_5a27a8ba21ca79b61932376b2fa922d2->leave($__internal_5a27a8ba21ca79b61932376b2fa922d2_prof);
in vendor/twig/twig/src/Template.php -> doDisplay (line 402)
  1. {
  2. $context += $this->env->getGlobals();
  3. $blocks = array_merge($this->blocks, $blocks);
  4. try {
  5. yield from $this->doDisplay($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($this->getSourceContext());
  9. }
  1. return $this->blocks;
  2. }
  3. public function display(array $context, array $blocks = []): void
  4. {
  5. foreach ($this->yield($context, $blocks) as $data) {
  6. echo $data;
  7. }
  8. }
  9. public function render(array $context): string
in vendor/twig/twig/src/Template.php -> display (line 373)
  1. ob_start();
  2. } else {
  3. ob_start(function () { return ''; });
  4. }
  5. try {
  6. $this->display($context);
  7. } catch (\Throwable $e) {
  8. while (ob_get_level() > $level) {
  9. ob_end_clean();
  10. }
  1. yield from $this->template->yieldBlock($name, $context);
  2. }
  3. public function render(array $context = []): string
  4. {
  5. return $this->template->render($context);
  6. }
  7. /**
  8. * @return void
  9. */
  1. * @throws SyntaxError When an error occurred during compilation
  2. * @throws RuntimeError When an error occurred during rendering
  3. */
  4. public function render($name, array $context = []): string
  5. {
  6. return $this->load($name)->render($context);
  7. }
  8. /**
  9. * Displays a template.
  10. *
  1. try {
  2. $configuration = $this->configurationProvider->provide($hookable, $metadata);
  3. $metadata = $metadata->withConfiguration(new ScalarDataBag($configuration));
  4. return $this->twig->render($hookable->template, [
  5. HooksRuntime::HOOKABLE_METADATA => $metadata,
  6. ]);
  7. } catch (HookRenderException $exception) {
  8. throw $exception;
  9. } catch (\Throwable $exception) {
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. foreach ($this->renderers as $renderer) {
  4. if ($renderer->supports($hookable)) {
  5. return $renderer->render($hookable, $metadata);
  6. }
  7. }
  8. throw new NoSupportedRendererException($hookable->hookName, $hookable->name);
  9. }
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. $this->profile?->registerHookableRenderStart($hookable);
  4. $this->stopwatch?->start($hookable->id);
  5. $rendered = $this->innerRenderer->render($hookable, $metadata);
  6. $this->profile?->registerHookableRenderEnd(
  7. $this->stopwatch?->stop($hookable->id)->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookable,
  3. $metadata,
  4. '%s BEGIN HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookable, $metadata));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookable,
  9. $metadata,
  10. '%s END HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  11. );
  1. new DataBag($context),
  2. new ScalarDataBag($configuration),
  3. $hookNames,
  4. );
  5. $renderedHookables[] = $this->compositeHookableRenderer->render($hookable, $hookableMetadata);
  6. }
  7. return implode(\PHP_EOL, $renderedHookables);
  8. }
  9. }
  1. public function render(array $hookNames, array $hookContext = []): string
  2. {
  3. $this->profile?->registerHookStart($hookNames);
  4. $this->stopwatch?->start(md5(serialize($hookNames)));
  5. $rendered = $this->innerRenderer->render($hookNames, $hookContext);
  6. $this->profile?->registerHookEnd(
  7. $this->stopwatch?->stop(md5(serialize($hookNames)))->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookNames,
  3. $hookContext,
  4. '%s BEGIN HOOK | name: "%s" %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookNames, $hookContext));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookNames,
  9. $hookContext,
  10. '%s END HOOK | name: "%s" %s',
  11. );
  1. $format = str_starts_with($hookName, '#') ? '%s%s' : '%s.%s';
  2. $prefixedHookNames[] = sprintf($format, $prefix, $hookName);
  3. }
  4. }
  5. return $this->hookRenderer->render($prefixedHookNames, $context);
  6. }
  7. /**
  8. * @param array<string, mixed> $hookContext
  9. *
  1. // line 1
  2. yield "<div class=\"row mt-5\">
  3. ";
  4. // line 2
  5. $hooksRuntime = $this->env->getRuntime('Sylius\TwigHooks\Twig\Runtime\HooksRuntime');
  6. echo $hooksRuntime->renderHook("body", [], $context, false);
  7. // line 3
  8. yield "</div>
  9. ";
  10. $__internal_5a27a8ba21ca79b61932376b2fa922d2->leave($__internal_5a27a8ba21ca79b61932376b2fa922d2_prof);
in vendor/twig/twig/src/Template.php -> doDisplay (line 402)
  1. {
  2. $context += $this->env->getGlobals();
  3. $blocks = array_merge($this->blocks, $blocks);
  4. try {
  5. yield from $this->doDisplay($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($this->getSourceContext());
  9. }
  1. return $this->blocks;
  2. }
  3. public function display(array $context, array $blocks = []): void
  4. {
  5. foreach ($this->yield($context, $blocks) as $data) {
  6. echo $data;
  7. }
  8. }
  9. public function render(array $context): string
in vendor/twig/twig/src/Template.php -> display (line 373)
  1. ob_start();
  2. } else {
  3. ob_start(function () { return ''; });
  4. }
  5. try {
  6. $this->display($context);
  7. } catch (\Throwable $e) {
  8. while (ob_get_level() > $level) {
  9. ob_end_clean();
  10. }
  1. yield from $this->template->yieldBlock($name, $context);
  2. }
  3. public function render(array $context = []): string
  4. {
  5. return $this->template->render($context);
  6. }
  7. /**
  8. * @return void
  9. */
  1. * @throws SyntaxError When an error occurred during compilation
  2. * @throws RuntimeError When an error occurred during rendering
  3. */
  4. public function render($name, array $context = []): string
  5. {
  6. return $this->load($name)->render($context);
  7. }
  8. /**
  9. * Displays a template.
  10. *
  1. try {
  2. $configuration = $this->configurationProvider->provide($hookable, $metadata);
  3. $metadata = $metadata->withConfiguration(new ScalarDataBag($configuration));
  4. return $this->twig->render($hookable->template, [
  5. HooksRuntime::HOOKABLE_METADATA => $metadata,
  6. ]);
  7. } catch (HookRenderException $exception) {
  8. throw $exception;
  9. } catch (\Throwable $exception) {
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. foreach ($this->renderers as $renderer) {
  4. if ($renderer->supports($hookable)) {
  5. return $renderer->render($hookable, $metadata);
  6. }
  7. }
  8. throw new NoSupportedRendererException($hookable->hookName, $hookable->name);
  9. }
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. $this->profile?->registerHookableRenderStart($hookable);
  4. $this->stopwatch?->start($hookable->id);
  5. $rendered = $this->innerRenderer->render($hookable, $metadata);
  6. $this->profile?->registerHookableRenderEnd(
  7. $this->stopwatch?->stop($hookable->id)->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookable,
  3. $metadata,
  4. '%s BEGIN HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookable, $metadata));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookable,
  9. $metadata,
  10. '%s END HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  11. );
  1. new DataBag($context),
  2. new ScalarDataBag($configuration),
  3. $hookNames,
  4. );
  5. $renderedHookables[] = $this->compositeHookableRenderer->render($hookable, $hookableMetadata);
  6. }
  7. return implode(\PHP_EOL, $renderedHookables);
  8. }
  9. }
  1. public function render(array $hookNames, array $hookContext = []): string
  2. {
  3. $this->profile?->registerHookStart($hookNames);
  4. $this->stopwatch?->start(md5(serialize($hookNames)));
  5. $rendered = $this->innerRenderer->render($hookNames, $hookContext);
  6. $this->profile?->registerHookEnd(
  7. $this->stopwatch?->stop(md5(serialize($hookNames)))->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookNames,
  3. $hookContext,
  4. '%s BEGIN HOOK | name: "%s" %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookNames, $hookContext));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookNames,
  9. $hookContext,
  10. '%s END HOOK | name: "%s" %s',
  11. );
  1. $format = str_starts_with($hookName, '#') ? '%s%s' : '%s.%s';
  2. $prefixedHookNames[] = sprintf($format, $prefix, $hookName);
  3. }
  4. }
  5. return $this->hookRenderer->render($prefixedHookNames, $context);
  6. }
  7. /**
  8. * @param array<string, mixed> $hookContext
  9. *
  1. // line 1
  2. yield "<div class=\"container mt-4 mb-5\">
  3. ";
  4. // line 2
  5. $hooksRuntime = $this->env->getRuntime('Sylius\TwigHooks\Twig\Runtime\HooksRuntime');
  6. echo $hooksRuntime->renderHook("content", [], $context, false);
  7. // line 3
  8. yield "</div>
  9. ";
  10. $__internal_5a27a8ba21ca79b61932376b2fa922d2->leave($__internal_5a27a8ba21ca79b61932376b2fa922d2_prof);
in vendor/twig/twig/src/Template.php -> doDisplay (line 402)
  1. {
  2. $context += $this->env->getGlobals();
  3. $blocks = array_merge($this->blocks, $blocks);
  4. try {
  5. yield from $this->doDisplay($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($this->getSourceContext());
  9. }
  1. return $this->blocks;
  2. }
  3. public function display(array $context, array $blocks = []): void
  4. {
  5. foreach ($this->yield($context, $blocks) as $data) {
  6. echo $data;
  7. }
  8. }
  9. public function render(array $context): string
in vendor/twig/twig/src/Template.php -> display (line 373)
  1. ob_start();
  2. } else {
  3. ob_start(function () { return ''; });
  4. }
  5. try {
  6. $this->display($context);
  7. } catch (\Throwable $e) {
  8. while (ob_get_level() > $level) {
  9. ob_end_clean();
  10. }
  1. yield from $this->template->yieldBlock($name, $context);
  2. }
  3. public function render(array $context = []): string
  4. {
  5. return $this->template->render($context);
  6. }
  7. /**
  8. * @return void
  9. */
  1. * @throws SyntaxError When an error occurred during compilation
  2. * @throws RuntimeError When an error occurred during rendering
  3. */
  4. public function render($name, array $context = []): string
  5. {
  6. return $this->load($name)->render($context);
  7. }
  8. /**
  9. * Displays a template.
  10. *
  1. try {
  2. $configuration = $this->configurationProvider->provide($hookable, $metadata);
  3. $metadata = $metadata->withConfiguration(new ScalarDataBag($configuration));
  4. return $this->twig->render($hookable->template, [
  5. HooksRuntime::HOOKABLE_METADATA => $metadata,
  6. ]);
  7. } catch (HookRenderException $exception) {
  8. throw $exception;
  9. } catch (\Throwable $exception) {
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. foreach ($this->renderers as $renderer) {
  4. if ($renderer->supports($hookable)) {
  5. return $renderer->render($hookable, $metadata);
  6. }
  7. }
  8. throw new NoSupportedRendererException($hookable->hookName, $hookable->name);
  9. }
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. $this->profile?->registerHookableRenderStart($hookable);
  4. $this->stopwatch?->start($hookable->id);
  5. $rendered = $this->innerRenderer->render($hookable, $metadata);
  6. $this->profile?->registerHookableRenderEnd(
  7. $this->stopwatch?->stop($hookable->id)->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookable,
  3. $metadata,
  4. '%s BEGIN HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookable, $metadata));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookable,
  9. $metadata,
  10. '%s END HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  11. );
  1. new DataBag($context),
  2. new ScalarDataBag($configuration),
  3. $hookNames,
  4. );
  5. $renderedHookables[] = $this->compositeHookableRenderer->render($hookable, $hookableMetadata);
  6. }
  7. return implode(\PHP_EOL, $renderedHookables);
  8. }
  9. }
  1. public function render(array $hookNames, array $hookContext = []): string
  2. {
  3. $this->profile?->registerHookStart($hookNames);
  4. $this->stopwatch?->start(md5(serialize($hookNames)));
  5. $rendered = $this->innerRenderer->render($hookNames, $hookContext);
  6. $this->profile?->registerHookEnd(
  7. $this->stopwatch?->stop(md5(serialize($hookNames)))->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookNames,
  3. $hookContext,
  4. '%s BEGIN HOOK | name: "%s" %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookNames, $hookContext));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookNames,
  9. $hookContext,
  10. '%s END HOOK | name: "%s" %s',
  11. );
  1. $context = $this->getContext($hookContext, $twigVars, $hookableMetadata, $only);
  2. $prefixes = $this->getPrefixes($hookContext, $hookableMetadata);
  3. if (false === $this->enableAutoprefixing || [] === $prefixes) {
  4. return $this->hookRenderer->render($hookNames, $context);
  5. }
  6. $prefixedHookNames = [];
  7. foreach ($hookNames as $hookName) {
  1. $__internal_6f47bbe9983af81f1e7450e9a3e3768f->enter($__internal_6f47bbe9983af81f1e7450e9a3e3768f_prof = new \Twig\Profiler\Profile($this->getTemplateName(), "block", "content"));
  2. // line 4
  3. yield " ";
  4. $hooksRuntime = $this->env->getRuntime('Sylius\TwigHooks\Twig\Runtime\HooksRuntime');
  5. echo $hooksRuntime->renderHook("sylius_shop.product.index", ["products" => (isset($context["products"]) || array_key_exists("products", $context) ? $context["products"] : (function () { throw new RuntimeError('Variable "products" does not exist.', 4, $this->source); })()), "resources" => (isset($context["resources"]) || array_key_exists("resources", $context) ? $context["resources"] : (function () { throw new RuntimeError('Variable "resources" does not exist.', 4, $this->source); })())], $context, false);
  6. $__internal_6f47bbe9983af81f1e7450e9a3e3768f->leave($__internal_6f47bbe9983af81f1e7450e9a3e3768f_prof);
  7. $__internal_5a27a8ba21ca79b61932376b2fa922d2->leave($__internal_5a27a8ba21ca79b61932376b2fa922d2_prof);
in vendor/twig/twig/src/Template.php -> block_content (line 446)
  1. throw new \LogicException('A block must be a method on a \Twig\Template instance.');
  2. }
  3. if (null !== $template) {
  4. try {
  5. yield from $template->$block($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($template->getSourceContext());
  9. }
  1. yield from $this->unwrap()->yieldBlock('header', $context, $blocks);
  2. // line 30
  3. yield "
  4. ";
  5. // line 31
  6. yield from $this->unwrap()->yieldBlock('content', $context, $blocks);
  7. // line 32
  8. yield "
  9. ";
  10. // line 33
  11. yield from $this->unwrap()->yieldBlock('footer', $context, $blocks);
in vendor/twig/twig/src/Template.php -> block_body (line 446)
  1. throw new \LogicException('A block must be a method on a \Twig\Template instance.');
  2. }
  3. if (null !== $template) {
  4. try {
  5. yield from $template->$block($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($template->getSourceContext());
  9. }
  1. // line 23
  2. yield $this->env->getRuntime('Twig\Runtime\EscaperRuntime')->escape(CoreExtension::getAttribute($this->env, $this->source, CoreExtension::getAttribute($this->env, $this->source, (isset($context["app"]) || array_key_exists("app", $context) ? $context["app"] : (function () { throw new RuntimeError('Variable "app" does not exist.', 23, $this->source); })()), "request", [], "any", false, false, false, 23), "get", ["_route"], "method", false, false, false, 23), "html", null, true);
  3. yield "\">
  4. ";
  5. // line 24
  6. yield from $this->unwrap()->yieldBlock('body', $context, $blocks);
  7. // line 39
  8. yield "
  9. ";
  10. // line 40
  11. yield from $this->unwrap()->yieldBlock('javascripts', $context, $blocks);
in vendor/twig/twig/src/Template.php -> doDisplay (line 402)
  1. {
  2. $context += $this->env->getGlobals();
  3. $blocks = array_merge($this->blocks, $blocks);
  4. try {
  5. yield from $this->doDisplay($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($this->getSourceContext());
  9. }
  1. $__internal_6f47bbe9983af81f1e7450e9a3e3768f = $this->extensions["Symfony\\Bridge\\Twig\\Extension\\ProfilerExtension"];
  2. $__internal_6f47bbe9983af81f1e7450e9a3e3768f->enter($__internal_6f47bbe9983af81f1e7450e9a3e3768f_prof = new \Twig\Profiler\Profile($this->getTemplateName(), "template", "@SyliusShop/product/index.html.twig"));
  3. $this->parent = $this->load("@SyliusShop/shared/layout/base.html.twig", 1);
  4. yield from $this->parent->unwrap()->yield($context, array_merge($this->blocks, $blocks));
  5. $__internal_5a27a8ba21ca79b61932376b2fa922d2->leave($__internal_5a27a8ba21ca79b61932376b2fa922d2_prof);
  6. $__internal_6f47bbe9983af81f1e7450e9a3e3768f->leave($__internal_6f47bbe9983af81f1e7450e9a3e3768f_prof);
in vendor/twig/twig/src/Template.php -> doDisplay (line 402)
  1. {
  2. $context += $this->env->getGlobals();
  3. $blocks = array_merge($this->blocks, $blocks);
  4. try {
  5. yield from $this->doDisplay($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($this->getSourceContext());
  9. }
  1. return $this->blocks;
  2. }
  3. public function display(array $context, array $blocks = []): void
  4. {
  5. foreach ($this->yield($context, $blocks) as $data) {
  6. echo $data;
  7. }
  8. }
  9. public function render(array $context): string
in vendor/twig/twig/src/Template.php -> display (line 373)
  1. ob_start();
  2. } else {
  3. ob_start(function () { return ''; });
  4. }
  5. try {
  6. $this->display($context);
  7. } catch (\Throwable $e) {
  8. while (ob_get_level() > $level) {
  9. ob_end_clean();
  10. }
  1. yield from $this->template->yieldBlock($name, $context);
  2. }
  3. public function render(array $context = []): string
  4. {
  5. return $this->template->render($context);
  6. }
  7. /**
  8. * @return void
  9. */
  1. * @throws SyntaxError When an error occurred during compilation
  2. * @throws RuntimeError When an error occurred during rendering
  3. */
  4. public function render($name, array $context = []): string
  5. {
  6. return $this->load($name)->render($context);
  7. }
  8. /**
  9. * Displays a template.
  10. *
  1. if ($this->container->has('templating')) {
  2. @trigger_error('Using the "templating" service is deprecated since Symfony 4.3 and will be removed in 5.0; use Twig instead.', \E_USER_DEPRECATED);
  3. $content = $this->container->get('templating')->render($view, $parameters);
  4. } elseif ($this->container->has('twig')) {
  5. $content = $this->container->get('twig')->render($view, $parameters);
  6. } else {
  7. throw new \LogicException('You can not use the "render" method if the Templating Component or the Twig Bundle are not available. Try running "composer require symfony/twig-bundle".');
  8. }
  9. if (null === $response) {
  1. if (null !== $eventResponse) {
  2. return $eventResponse;
  3. }
  4. if ($configuration->isHtmlRequest()) {
  5. return $this->render($configuration->getTemplate(ResourceActions::INDEX . '.html'), [
  6. 'configuration' => $configuration,
  7. 'metadata' => $this->metadata,
  8. 'resources' => $resources,
  9. $this->metadata->getPluralName() => $resources,
  10. ]);
in vendor/symfony/http-kernel/HttpKernel.php -> indexAction (line 183)
  1. $this->dispatcher->dispatch($event, KernelEvents::CONTROLLER_ARGUMENTS);
  2. $controller = $event->getController();
  3. $arguments = $event->getArguments();
  4. // call controller
  5. $response = $controller(...$arguments);
  6. // view
  7. if (!$response instanceof Response) {
  8. $event = new ViewEvent($this, $request, $type, $response, $event);
  9. $this->dispatcher->dispatch($event, KernelEvents::VIEW);
  1. $request->headers->set('X-Php-Ob-Level', (string) ob_get_level());
  2. $this->requestStack->push($request);
  3. $response = null;
  4. try {
  5. return $response = $this->handleRaw($request, $type);
  6. } catch (\Throwable $e) {
  7. if ($e instanceof \Error && !$this->handleAllThrowables) {
  8. throw $e;
  9. }
  1. $this->boot();
  2. ++$this->requestStackSize;
  3. $this->resetServices = true;
  4. try {
  5. return $this->getHttpKernel()->handle($request, $type, $catch);
  6. } finally {
  7. --$this->requestStackSize;
  8. }
  9. }
  1. ) {
  2. }
  3. public function run(): int
  4. {
  5. $response = $this->kernel->handle($this->request);
  6. if (Kernel::VERSION_ID >= 60400) {
  7. $response->send(false);
  8. if (\function_exists('fastcgi_finish_request') && !$this->debug) {
in vendor/autoload_runtime.php -> run (line 29)
  1. $app = $app(...$args);
  2. exit(
  3. $runtime
  4. ->getRunner($app)
  5. ->run()
  6. );
require_once('/www/wwwroot/sylius-cuisinstore/vendor/autoload_runtime.php') in public/index.php (line 5)
  1. <?php
  2. use App\Kernel;
  3. require_once dirname(__DIR__).'/vendor/autoload_runtime.php';
  4. return function (array $context) {
  5. return new Kernel($context['APP_ENV'], (bool) $context['APP_DEBUG']);
  6. };

InvalidArgumentException

Product has no variants

  1. if (!$variant instanceof ProductVariantInterface) {
  2. $variant = $this->product->getVariants()->first();
  3. }
  4. if (!$variant instanceof ProductVariantInterface) {
  5. throw new \InvalidArgumentException('Product has no variants');
  6. }
  7. $this->variant = $variant;
  8. return $this->variant;
  1. foreach ($metadata['methods'] as $methodName => $method) {
  2. if ($method['destruct'] ?? false) {
  3. yield from $component->{$methodName}();
  4. } else {
  5. yield $method['name'] => $component->{$methodName}();
  6. }
  7. }
  8. }
  9. /**
ComponentProperties->extractProperties()
  1. /**
  2. * @return array<string, mixed>
  3. */
  4. public function getProperties(object $component, bool $publicProps = false): array
  5. {
  6. return iterator_to_array($this->extractProperties($component, $publicProps));
  7. }
  8. public function warmup(): void
  9. {
  10. if (!$this->cache) {
  1. $component = $mounted->getComponent();
  2. $metadata = $this->factory->metadataFor($mounted->getName());
  3. $classProps = [];
  4. if (!$metadata->isAnonymous()) {
  5. $classProps = $this->componentProperties->getProperties($component, $metadata->isPublicPropsExposed());
  6. }
  7. // expose public properties and properties marked with ExposeInTemplate attribute
  8. $props = [...$mounted->getInputProps(), ...$classProps];
  9. $event = new PreRenderEvent($mounted, $metadata, [
  1. public function render(MountedComponent $mounted): string
  2. {
  3. $this->componentStack->push($mounted);
  4. $event = $this->preRender($mounted);
  5. $variables = $event->getVariables();
  6. // see ComponentNode. When rendering an individual embedded component,
  7. // *not* through its parent, we need to set the parent template.
  8. if ($templateIndex = $event->getTemplateIndex()) {
  1. {
  2. if ($preRendered = $this->preCreateForRender($name, $props)) {
  3. return $preRendered;
  4. }
  5. return $this->render($this->factory->create($name, $props));
  6. }
  7. public function render(MountedComponent $mounted): string
  8. {
  9. $this->componentStack->push($mounted);
  1. {
  2. if ($this->renderers->has($normalized = strtolower($name))) {
  3. return $this->renderers->get($normalized)->render($props);
  4. }
  5. return $this->renderer->createAndRender($name, $props);
  6. }
  7. /**
  8. * @param array<string, mixed> $props
  9. * @param array<string, mixed> $context
  1. $context['_parent'] = $context;
  2. $context['_seq'] = CoreExtension::ensureTraversable(CoreExtension::getAttribute($this->env, $this->source, (isset($context["resources"]) || array_key_exists("resources", $context) ? $context["resources"] : (function () { throw new RuntimeError('Variable "resources" does not exist.', 7, $this->source); })()), "data", [], "any", false, false, false, 7));
  3. foreach ($context['_seq'] as $context["_key"] => $context["product"]) {
  4. // line 8
  5. yield " ";
  6. yield $this->env->getRuntime('Symfony\UX\TwigComponent\Twig\ComponentRuntime')->render("sylius_shop:product:card", ["product" => $context["product"], "template" => ((CoreExtension::getAttribute($this->env, $this->source, CoreExtension::getAttribute($this->env, $this->source, ($context["hookable_metadata"] ?? null), "configuration", [], "any", false, true, false, 8), "product_template", [], "any", true, true, false, 8)) ? (Twig\Extension\CoreExtension::default(CoreExtension::getAttribute($this->env, $this->source, CoreExtension::getAttribute($this->env, $this->source, (isset($context["hookable_metadata"]) || array_key_exists("hookable_metadata", $context) ? $context["hookable_metadata"] : (function () { throw new RuntimeError('Variable "hookable_metadata" does not exist.', 8, $this->source); })()), "configuration", [], "any", false, false, false, 8), "product_template", [], "any", false, false, false, 8), "@SyliusShop/product/common/card.html.twig")) : ("@SyliusShop/product/common/card.html.twig")), "hookableMetadata" => (isset($context["hookable_metadata"]) || array_key_exists("hookable_metadata", $context) ? $context["hookable_metadata"] : (function () { throw new RuntimeError('Variable "hookable_metadata" does not exist.', 8, $this->source); })())]);
  7. yield "
  8. ";
  9. }
  10. $_parent = $context['_parent'];
  11. unset($context['_seq'], $context['_key'], $context['product'], $context['_parent']);
in vendor/twig/twig/src/Template.php -> doDisplay (line 402)
  1. {
  2. $context += $this->env->getGlobals();
  3. $blocks = array_merge($this->blocks, $blocks);
  4. try {
  5. yield from $this->doDisplay($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($this->getSourceContext());
  9. }
  1. return $this->blocks;
  2. }
  3. public function display(array $context, array $blocks = []): void
  4. {
  5. foreach ($this->yield($context, $blocks) as $data) {
  6. echo $data;
  7. }
  8. }
  9. public function render(array $context): string
in vendor/twig/twig/src/Template.php -> display (line 373)
  1. ob_start();
  2. } else {
  3. ob_start(function () { return ''; });
  4. }
  5. try {
  6. $this->display($context);
  7. } catch (\Throwable $e) {
  8. while (ob_get_level() > $level) {
  9. ob_end_clean();
  10. }
  1. yield from $this->template->yieldBlock($name, $context);
  2. }
  3. public function render(array $context = []): string
  4. {
  5. return $this->template->render($context);
  6. }
  7. /**
  8. * @return void
  9. */
  1. * @throws SyntaxError When an error occurred during compilation
  2. * @throws RuntimeError When an error occurred during rendering
  3. */
  4. public function render($name, array $context = []): string
  5. {
  6. return $this->load($name)->render($context);
  7. }
  8. /**
  9. * Displays a template.
  10. *
  1. try {
  2. $configuration = $this->configurationProvider->provide($hookable, $metadata);
  3. $metadata = $metadata->withConfiguration(new ScalarDataBag($configuration));
  4. return $this->twig->render($hookable->template, [
  5. HooksRuntime::HOOKABLE_METADATA => $metadata,
  6. ]);
  7. } catch (HookRenderException $exception) {
  8. throw $exception;
  9. } catch (\Throwable $exception) {
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. foreach ($this->renderers as $renderer) {
  4. if ($renderer->supports($hookable)) {
  5. return $renderer->render($hookable, $metadata);
  6. }
  7. }
  8. throw new NoSupportedRendererException($hookable->hookName, $hookable->name);
  9. }
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. $this->profile?->registerHookableRenderStart($hookable);
  4. $this->stopwatch?->start($hookable->id);
  5. $rendered = $this->innerRenderer->render($hookable, $metadata);
  6. $this->profile?->registerHookableRenderEnd(
  7. $this->stopwatch?->stop($hookable->id)->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookable,
  3. $metadata,
  4. '%s BEGIN HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookable, $metadata));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookable,
  9. $metadata,
  10. '%s END HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  11. );
  1. new DataBag($context),
  2. new ScalarDataBag($configuration),
  3. $hookNames,
  4. );
  5. $renderedHookables[] = $this->compositeHookableRenderer->render($hookable, $hookableMetadata);
  6. }
  7. return implode(\PHP_EOL, $renderedHookables);
  8. }
  9. }
  1. public function render(array $hookNames, array $hookContext = []): string
  2. {
  3. $this->profile?->registerHookStart($hookNames);
  4. $this->stopwatch?->start(md5(serialize($hookNames)));
  5. $rendered = $this->innerRenderer->render($hookNames, $hookContext);
  6. $this->profile?->registerHookEnd(
  7. $this->stopwatch?->stop(md5(serialize($hookNames)))->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookNames,
  3. $hookContext,
  4. '%s BEGIN HOOK | name: "%s" %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookNames, $hookContext));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookNames,
  9. $hookContext,
  10. '%s END HOOK | name: "%s" %s',
  11. );
  1. $format = str_starts_with($hookName, '#') ? '%s%s' : '%s.%s';
  2. $prefixedHookNames[] = sprintf($format, $prefix, $hookName);
  3. }
  4. }
  5. return $this->hookRenderer->render($prefixedHookNames, $context);
  6. }
  7. /**
  8. * @param array<string, mixed> $hookContext
  9. *
  1. // line 1
  2. yield "<div class=\"col-12 col-lg-9\">
  3. ";
  4. // line 2
  5. $hooksRuntime = $this->env->getRuntime('Sylius\TwigHooks\Twig\Runtime\HooksRuntime');
  6. echo $hooksRuntime->renderHook("main", [], $context, false);
  7. // line 3
  8. yield "</div>
  9. ";
  10. $__internal_5a27a8ba21ca79b61932376b2fa922d2->leave($__internal_5a27a8ba21ca79b61932376b2fa922d2_prof);
in vendor/twig/twig/src/Template.php -> doDisplay (line 402)
  1. {
  2. $context += $this->env->getGlobals();
  3. $blocks = array_merge($this->blocks, $blocks);
  4. try {
  5. yield from $this->doDisplay($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($this->getSourceContext());
  9. }
  1. return $this->blocks;
  2. }
  3. public function display(array $context, array $blocks = []): void
  4. {
  5. foreach ($this->yield($context, $blocks) as $data) {
  6. echo $data;
  7. }
  8. }
  9. public function render(array $context): string
in vendor/twig/twig/src/Template.php -> display (line 373)
  1. ob_start();
  2. } else {
  3. ob_start(function () { return ''; });
  4. }
  5. try {
  6. $this->display($context);
  7. } catch (\Throwable $e) {
  8. while (ob_get_level() > $level) {
  9. ob_end_clean();
  10. }
  1. yield from $this->template->yieldBlock($name, $context);
  2. }
  3. public function render(array $context = []): string
  4. {
  5. return $this->template->render($context);
  6. }
  7. /**
  8. * @return void
  9. */
  1. * @throws SyntaxError When an error occurred during compilation
  2. * @throws RuntimeError When an error occurred during rendering
  3. */
  4. public function render($name, array $context = []): string
  5. {
  6. return $this->load($name)->render($context);
  7. }
  8. /**
  9. * Displays a template.
  10. *
  1. try {
  2. $configuration = $this->configurationProvider->provide($hookable, $metadata);
  3. $metadata = $metadata->withConfiguration(new ScalarDataBag($configuration));
  4. return $this->twig->render($hookable->template, [
  5. HooksRuntime::HOOKABLE_METADATA => $metadata,
  6. ]);
  7. } catch (HookRenderException $exception) {
  8. throw $exception;
  9. } catch (\Throwable $exception) {
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. foreach ($this->renderers as $renderer) {
  4. if ($renderer->supports($hookable)) {
  5. return $renderer->render($hookable, $metadata);
  6. }
  7. }
  8. throw new NoSupportedRendererException($hookable->hookName, $hookable->name);
  9. }
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. $this->profile?->registerHookableRenderStart($hookable);
  4. $this->stopwatch?->start($hookable->id);
  5. $rendered = $this->innerRenderer->render($hookable, $metadata);
  6. $this->profile?->registerHookableRenderEnd(
  7. $this->stopwatch?->stop($hookable->id)->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookable,
  3. $metadata,
  4. '%s BEGIN HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookable, $metadata));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookable,
  9. $metadata,
  10. '%s END HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  11. );
  1. new DataBag($context),
  2. new ScalarDataBag($configuration),
  3. $hookNames,
  4. );
  5. $renderedHookables[] = $this->compositeHookableRenderer->render($hookable, $hookableMetadata);
  6. }
  7. return implode(\PHP_EOL, $renderedHookables);
  8. }
  9. }
  1. public function render(array $hookNames, array $hookContext = []): string
  2. {
  3. $this->profile?->registerHookStart($hookNames);
  4. $this->stopwatch?->start(md5(serialize($hookNames)));
  5. $rendered = $this->innerRenderer->render($hookNames, $hookContext);
  6. $this->profile?->registerHookEnd(
  7. $this->stopwatch?->stop(md5(serialize($hookNames)))->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookNames,
  3. $hookContext,
  4. '%s BEGIN HOOK | name: "%s" %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookNames, $hookContext));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookNames,
  9. $hookContext,
  10. '%s END HOOK | name: "%s" %s',
  11. );
  1. $format = str_starts_with($hookName, '#') ? '%s%s' : '%s.%s';
  2. $prefixedHookNames[] = sprintf($format, $prefix, $hookName);
  3. }
  4. }
  5. return $this->hookRenderer->render($prefixedHookNames, $context);
  6. }
  7. /**
  8. * @param array<string, mixed> $hookContext
  9. *
  1. // line 1
  2. yield "<div class=\"row mt-5\">
  3. ";
  4. // line 2
  5. $hooksRuntime = $this->env->getRuntime('Sylius\TwigHooks\Twig\Runtime\HooksRuntime');
  6. echo $hooksRuntime->renderHook("body", [], $context, false);
  7. // line 3
  8. yield "</div>
  9. ";
  10. $__internal_5a27a8ba21ca79b61932376b2fa922d2->leave($__internal_5a27a8ba21ca79b61932376b2fa922d2_prof);
in vendor/twig/twig/src/Template.php -> doDisplay (line 402)
  1. {
  2. $context += $this->env->getGlobals();
  3. $blocks = array_merge($this->blocks, $blocks);
  4. try {
  5. yield from $this->doDisplay($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($this->getSourceContext());
  9. }
  1. return $this->blocks;
  2. }
  3. public function display(array $context, array $blocks = []): void
  4. {
  5. foreach ($this->yield($context, $blocks) as $data) {
  6. echo $data;
  7. }
  8. }
  9. public function render(array $context): string
in vendor/twig/twig/src/Template.php -> display (line 373)
  1. ob_start();
  2. } else {
  3. ob_start(function () { return ''; });
  4. }
  5. try {
  6. $this->display($context);
  7. } catch (\Throwable $e) {
  8. while (ob_get_level() > $level) {
  9. ob_end_clean();
  10. }
  1. yield from $this->template->yieldBlock($name, $context);
  2. }
  3. public function render(array $context = []): string
  4. {
  5. return $this->template->render($context);
  6. }
  7. /**
  8. * @return void
  9. */
  1. * @throws SyntaxError When an error occurred during compilation
  2. * @throws RuntimeError When an error occurred during rendering
  3. */
  4. public function render($name, array $context = []): string
  5. {
  6. return $this->load($name)->render($context);
  7. }
  8. /**
  9. * Displays a template.
  10. *
  1. try {
  2. $configuration = $this->configurationProvider->provide($hookable, $metadata);
  3. $metadata = $metadata->withConfiguration(new ScalarDataBag($configuration));
  4. return $this->twig->render($hookable->template, [
  5. HooksRuntime::HOOKABLE_METADATA => $metadata,
  6. ]);
  7. } catch (HookRenderException $exception) {
  8. throw $exception;
  9. } catch (\Throwable $exception) {
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. foreach ($this->renderers as $renderer) {
  4. if ($renderer->supports($hookable)) {
  5. return $renderer->render($hookable, $metadata);
  6. }
  7. }
  8. throw new NoSupportedRendererException($hookable->hookName, $hookable->name);
  9. }
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. $this->profile?->registerHookableRenderStart($hookable);
  4. $this->stopwatch?->start($hookable->id);
  5. $rendered = $this->innerRenderer->render($hookable, $metadata);
  6. $this->profile?->registerHookableRenderEnd(
  7. $this->stopwatch?->stop($hookable->id)->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookable,
  3. $metadata,
  4. '%s BEGIN HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookable, $metadata));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookable,
  9. $metadata,
  10. '%s END HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  11. );
  1. new DataBag($context),
  2. new ScalarDataBag($configuration),
  3. $hookNames,
  4. );
  5. $renderedHookables[] = $this->compositeHookableRenderer->render($hookable, $hookableMetadata);
  6. }
  7. return implode(\PHP_EOL, $renderedHookables);
  8. }
  9. }
  1. public function render(array $hookNames, array $hookContext = []): string
  2. {
  3. $this->profile?->registerHookStart($hookNames);
  4. $this->stopwatch?->start(md5(serialize($hookNames)));
  5. $rendered = $this->innerRenderer->render($hookNames, $hookContext);
  6. $this->profile?->registerHookEnd(
  7. $this->stopwatch?->stop(md5(serialize($hookNames)))->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookNames,
  3. $hookContext,
  4. '%s BEGIN HOOK | name: "%s" %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookNames, $hookContext));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookNames,
  9. $hookContext,
  10. '%s END HOOK | name: "%s" %s',
  11. );
  1. $format = str_starts_with($hookName, '#') ? '%s%s' : '%s.%s';
  2. $prefixedHookNames[] = sprintf($format, $prefix, $hookName);
  3. }
  4. }
  5. return $this->hookRenderer->render($prefixedHookNames, $context);
  6. }
  7. /**
  8. * @param array<string, mixed> $hookContext
  9. *
  1. // line 1
  2. yield "<div class=\"container mt-4 mb-5\">
  3. ";
  4. // line 2
  5. $hooksRuntime = $this->env->getRuntime('Sylius\TwigHooks\Twig\Runtime\HooksRuntime');
  6. echo $hooksRuntime->renderHook("content", [], $context, false);
  7. // line 3
  8. yield "</div>
  9. ";
  10. $__internal_5a27a8ba21ca79b61932376b2fa922d2->leave($__internal_5a27a8ba21ca79b61932376b2fa922d2_prof);
in vendor/twig/twig/src/Template.php -> doDisplay (line 402)
  1. {
  2. $context += $this->env->getGlobals();
  3. $blocks = array_merge($this->blocks, $blocks);
  4. try {
  5. yield from $this->doDisplay($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($this->getSourceContext());
  9. }
  1. return $this->blocks;
  2. }
  3. public function display(array $context, array $blocks = []): void
  4. {
  5. foreach ($this->yield($context, $blocks) as $data) {
  6. echo $data;
  7. }
  8. }
  9. public function render(array $context): string
in vendor/twig/twig/src/Template.php -> display (line 373)
  1. ob_start();
  2. } else {
  3. ob_start(function () { return ''; });
  4. }
  5. try {
  6. $this->display($context);
  7. } catch (\Throwable $e) {
  8. while (ob_get_level() > $level) {
  9. ob_end_clean();
  10. }
  1. yield from $this->template->yieldBlock($name, $context);
  2. }
  3. public function render(array $context = []): string
  4. {
  5. return $this->template->render($context);
  6. }
  7. /**
  8. * @return void
  9. */
  1. * @throws SyntaxError When an error occurred during compilation
  2. * @throws RuntimeError When an error occurred during rendering
  3. */
  4. public function render($name, array $context = []): string
  5. {
  6. return $this->load($name)->render($context);
  7. }
  8. /**
  9. * Displays a template.
  10. *
  1. try {
  2. $configuration = $this->configurationProvider->provide($hookable, $metadata);
  3. $metadata = $metadata->withConfiguration(new ScalarDataBag($configuration));
  4. return $this->twig->render($hookable->template, [
  5. HooksRuntime::HOOKABLE_METADATA => $metadata,
  6. ]);
  7. } catch (HookRenderException $exception) {
  8. throw $exception;
  9. } catch (\Throwable $exception) {
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. foreach ($this->renderers as $renderer) {
  4. if ($renderer->supports($hookable)) {
  5. return $renderer->render($hookable, $metadata);
  6. }
  7. }
  8. throw new NoSupportedRendererException($hookable->hookName, $hookable->name);
  9. }
  1. public function render(AbstractHookable $hookable, HookableMetadata $metadata): string
  2. {
  3. $this->profile?->registerHookableRenderStart($hookable);
  4. $this->stopwatch?->start($hookable->id);
  5. $rendered = $this->innerRenderer->render($hookable, $metadata);
  6. $this->profile?->registerHookableRenderEnd(
  7. $this->stopwatch?->stop($hookable->id)->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookable,
  3. $metadata,
  4. '%s BEGIN HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookable, $metadata));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookable,
  9. $metadata,
  10. '%s END HOOKABLE | hook: "%s", name: "%s", %s: "%s", priority: %d %s',
  11. );
  1. new DataBag($context),
  2. new ScalarDataBag($configuration),
  3. $hookNames,
  4. );
  5. $renderedHookables[] = $this->compositeHookableRenderer->render($hookable, $hookableMetadata);
  6. }
  7. return implode(\PHP_EOL, $renderedHookables);
  8. }
  9. }
  1. public function render(array $hookNames, array $hookContext = []): string
  2. {
  3. $this->profile?->registerHookStart($hookNames);
  4. $this->stopwatch?->start(md5(serialize($hookNames)));
  5. $rendered = $this->innerRenderer->render($hookNames, $hookContext);
  6. $this->profile?->registerHookEnd(
  7. $this->stopwatch?->stop(md5(serialize($hookNames)))->getDuration(),
  8. );
  1. $renderedParts[] = $this->getDebugComment(
  2. $hookNames,
  3. $hookContext,
  4. '%s BEGIN HOOK | name: "%s" %s',
  5. );
  6. $renderedParts[] = trim($this->innerRenderer->render($hookNames, $hookContext));
  7. $renderedParts[] = $this->getDebugComment(
  8. $hookNames,
  9. $hookContext,
  10. '%s END HOOK | name: "%s" %s',
  11. );
  1. $context = $this->getContext($hookContext, $twigVars, $hookableMetadata, $only);
  2. $prefixes = $this->getPrefixes($hookContext, $hookableMetadata);
  3. if (false === $this->enableAutoprefixing || [] === $prefixes) {
  4. return $this->hookRenderer->render($hookNames, $context);
  5. }
  6. $prefixedHookNames = [];
  7. foreach ($hookNames as $hookName) {
  1. $__internal_6f47bbe9983af81f1e7450e9a3e3768f->enter($__internal_6f47bbe9983af81f1e7450e9a3e3768f_prof = new \Twig\Profiler\Profile($this->getTemplateName(), "block", "content"));
  2. // line 4
  3. yield " ";
  4. $hooksRuntime = $this->env->getRuntime('Sylius\TwigHooks\Twig\Runtime\HooksRuntime');
  5. echo $hooksRuntime->renderHook("sylius_shop.product.index", ["products" => (isset($context["products"]) || array_key_exists("products", $context) ? $context["products"] : (function () { throw new RuntimeError('Variable "products" does not exist.', 4, $this->source); })()), "resources" => (isset($context["resources"]) || array_key_exists("resources", $context) ? $context["resources"] : (function () { throw new RuntimeError('Variable "resources" does not exist.', 4, $this->source); })())], $context, false);
  6. $__internal_6f47bbe9983af81f1e7450e9a3e3768f->leave($__internal_6f47bbe9983af81f1e7450e9a3e3768f_prof);
  7. $__internal_5a27a8ba21ca79b61932376b2fa922d2->leave($__internal_5a27a8ba21ca79b61932376b2fa922d2_prof);
in vendor/twig/twig/src/Template.php -> block_content (line 446)
  1. throw new \LogicException('A block must be a method on a \Twig\Template instance.');
  2. }
  3. if (null !== $template) {
  4. try {
  5. yield from $template->$block($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($template->getSourceContext());
  9. }
  1. yield from $this->unwrap()->yieldBlock('header', $context, $blocks);
  2. // line 30
  3. yield "
  4. ";
  5. // line 31
  6. yield from $this->unwrap()->yieldBlock('content', $context, $blocks);
  7. // line 32
  8. yield "
  9. ";
  10. // line 33
  11. yield from $this->unwrap()->yieldBlock('footer', $context, $blocks);
in vendor/twig/twig/src/Template.php -> block_body (line 446)
  1. throw new \LogicException('A block must be a method on a \Twig\Template instance.');
  2. }
  3. if (null !== $template) {
  4. try {
  5. yield from $template->$block($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($template->getSourceContext());
  9. }
  1. // line 23
  2. yield $this->env->getRuntime('Twig\Runtime\EscaperRuntime')->escape(CoreExtension::getAttribute($this->env, $this->source, CoreExtension::getAttribute($this->env, $this->source, (isset($context["app"]) || array_key_exists("app", $context) ? $context["app"] : (function () { throw new RuntimeError('Variable "app" does not exist.', 23, $this->source); })()), "request", [], "any", false, false, false, 23), "get", ["_route"], "method", false, false, false, 23), "html", null, true);
  3. yield "\">
  4. ";
  5. // line 24
  6. yield from $this->unwrap()->yieldBlock('body', $context, $blocks);
  7. // line 39
  8. yield "
  9. ";
  10. // line 40
  11. yield from $this->unwrap()->yieldBlock('javascripts', $context, $blocks);
in vendor/twig/twig/src/Template.php -> doDisplay (line 402)
  1. {
  2. $context += $this->env->getGlobals();
  3. $blocks = array_merge($this->blocks, $blocks);
  4. try {
  5. yield from $this->doDisplay($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($this->getSourceContext());
  9. }
  1. $__internal_6f47bbe9983af81f1e7450e9a3e3768f = $this->extensions["Symfony\\Bridge\\Twig\\Extension\\ProfilerExtension"];
  2. $__internal_6f47bbe9983af81f1e7450e9a3e3768f->enter($__internal_6f47bbe9983af81f1e7450e9a3e3768f_prof = new \Twig\Profiler\Profile($this->getTemplateName(), "template", "@SyliusShop/product/index.html.twig"));
  3. $this->parent = $this->load("@SyliusShop/shared/layout/base.html.twig", 1);
  4. yield from $this->parent->unwrap()->yield($context, array_merge($this->blocks, $blocks));
  5. $__internal_5a27a8ba21ca79b61932376b2fa922d2->leave($__internal_5a27a8ba21ca79b61932376b2fa922d2_prof);
  6. $__internal_6f47bbe9983af81f1e7450e9a3e3768f->leave($__internal_6f47bbe9983af81f1e7450e9a3e3768f_prof);
in vendor/twig/twig/src/Template.php -> doDisplay (line 402)
  1. {
  2. $context += $this->env->getGlobals();
  3. $blocks = array_merge($this->blocks, $blocks);
  4. try {
  5. yield from $this->doDisplay($context, $blocks);
  6. } catch (Error $e) {
  7. if (!$e->getSourceContext()) {
  8. $e->setSourceContext($this->getSourceContext());
  9. }
  1. return $this->blocks;
  2. }
  3. public function display(array $context, array $blocks = []): void
  4. {
  5. foreach ($this->yield($context, $blocks) as $data) {
  6. echo $data;
  7. }
  8. }
  9. public function render(array $context): string
in vendor/twig/twig/src/Template.php -> display (line 373)
  1. ob_start();
  2. } else {
  3. ob_start(function () { return ''; });
  4. }
  5. try {
  6. $this->display($context);
  7. } catch (\Throwable $e) {
  8. while (ob_get_level() > $level) {
  9. ob_end_clean();
  10. }
  1. yield from $this->template->yieldBlock($name, $context);
  2. }
  3. public function render(array $context = []): string
  4. {
  5. return $this->template->render($context);
  6. }
  7. /**
  8. * @return void
  9. */
  1. * @throws SyntaxError When an error occurred during compilation
  2. * @throws RuntimeError When an error occurred during rendering
  3. */
  4. public function render($name, array $context = []): string
  5. {
  6. return $this->load($name)->render($context);
  7. }
  8. /**
  9. * Displays a template.
  10. *
  1. if ($this->container->has('templating')) {
  2. @trigger_error('Using the "templating" service is deprecated since Symfony 4.3 and will be removed in 5.0; use Twig instead.', \E_USER_DEPRECATED);
  3. $content = $this->container->get('templating')->render($view, $parameters);
  4. } elseif ($this->container->has('twig')) {
  5. $content = $this->container->get('twig')->render($view, $parameters);
  6. } else {
  7. throw new \LogicException('You can not use the "render" method if the Templating Component or the Twig Bundle are not available. Try running "composer require symfony/twig-bundle".');
  8. }
  9. if (null === $response) {
  1. if (null !== $eventResponse) {
  2. return $eventResponse;
  3. }
  4. if ($configuration->isHtmlRequest()) {
  5. return $this->render($configuration->getTemplate(ResourceActions::INDEX . '.html'), [
  6. 'configuration' => $configuration,
  7. 'metadata' => $this->metadata,
  8. 'resources' => $resources,
  9. $this->metadata->getPluralName() => $resources,
  10. ]);
in vendor/symfony/http-kernel/HttpKernel.php -> indexAction (line 183)
  1. $this->dispatcher->dispatch($event, KernelEvents::CONTROLLER_ARGUMENTS);
  2. $controller = $event->getController();
  3. $arguments = $event->getArguments();
  4. // call controller
  5. $response = $controller(...$arguments);
  6. // view
  7. if (!$response instanceof Response) {
  8. $event = new ViewEvent($this, $request, $type, $response, $event);
  9. $this->dispatcher->dispatch($event, KernelEvents::VIEW);
  1. $request->headers->set('X-Php-Ob-Level', (string) ob_get_level());
  2. $this->requestStack->push($request);
  3. $response = null;
  4. try {
  5. return $response = $this->handleRaw($request, $type);
  6. } catch (\Throwable $e) {
  7. if ($e instanceof \Error && !$this->handleAllThrowables) {
  8. throw $e;
  9. }
  1. $this->boot();
  2. ++$this->requestStackSize;
  3. $this->resetServices = true;
  4. try {
  5. return $this->getHttpKernel()->handle($request, $type, $catch);
  6. } finally {
  7. --$this->requestStackSize;
  8. }
  9. }
  1. ) {
  2. }
  3. public function run(): int
  4. {
  5. $response = $this->kernel->handle($this->request);
  6. if (Kernel::VERSION_ID >= 60400) {
  7. $response->send(false);
  8. if (\function_exists('fastcgi_finish_request') && !$this->debug) {
in vendor/autoload_runtime.php -> run (line 29)
  1. $app = $app(...$args);
  2. exit(
  3. $runtime
  4. ->getRunner($app)
  5. ->run()
  6. );
require_once('/www/wwwroot/sylius-cuisinstore/vendor/autoload_runtime.php') in public/index.php (line 5)
  1. <?php
  2. use App\Kernel;
  3. require_once dirname(__DIR__).'/vendor/autoload_runtime.php';
  4. return function (array $context) {
  5. return new Kernel($context['APP_ENV'], (bool) $context['APP_DEBUG']);
  6. };

Logs

Level Channel Message
INFO 21:00:01 deprecation User Deprecated: The Liip\ImagineBundle\Templating\FilterTrait trait is deprecated since version 2.7 and will be removed in 3.0; use Twig instead.
{
    "exception": {}
}
INFO 21:00:01 deprecation User Deprecated: The Liip\ImagineBundle\Templating\FilterExtension class is deprecated since version 2.7 and will be removed in 3.0; configure "liip_imagine.twig.mode" to "lazy" instead.
{
    "exception": {}
}
INFO 21:00:01 deprecation User Deprecated: Version detection logic for MySQL will change in DBAL 4. Please specify the version as the server reports it, e.g. "8.0.31" instead of "8". (AbstractMySQLDriver.php:94 called by AbstractDriverMiddleware.php:68, https://github.com/doctrine/dbal/pull/5779, package doctrine/orm)
{
    "exception": {}
}
INFO 21:00:01 request Matched route "_profiler".
{
    "route": "_profiler",
    "route_parameters": {
        "_route": "_profiler",
        "_controller": "web_profiler.controller.profiler::panelAction",
        "token": "d9eef0"
    },
    "request_uri": "https://sylius-cuisinstore.preprod.eu/_profiler/d9eef0",
    "method": "GET"
}
DEBUG 21:00:01 security Checking for authenticator support.
{
    "firewall_name": "shop",
    "authenticators": 3
}
DEBUG 21:00:01 security Checking support on authenticator.
{
    "firewall_name": "shop",
    "authenticator": "Symfony\\Component\\Security\\Http\\Authenticator\\Debug\\TraceableAuthenticator"
}
DEBUG 21:00:01 security Authenticator does not support the request.
{
    "firewall_name": "shop",
    "authenticator": "Symfony\\Component\\Security\\Http\\Authenticator\\Debug\\TraceableAuthenticator"
}
DEBUG 21:00:01 security Checking support on authenticator.
{
    "firewall_name": "shop",
    "authenticator": "Symfony\\Component\\Security\\Http\\Authenticator\\Debug\\TraceableAuthenticator"
}
DEBUG 21:00:01 security Authenticator does not support the request.
{
    "firewall_name": "shop",
    "authenticator": "Symfony\\Component\\Security\\Http\\Authenticator\\Debug\\TraceableAuthenticator"
}
DEBUG 21:00:01 security Checking support on authenticator.
{
    "firewall_name": "shop",
    "authenticator": "Symfony\\Component\\Security\\Http\\Authenticator\\Debug\\TraceableAuthenticator"
}
DEBUG 21:00:01 security Authenticator does not support the request.
{
    "firewall_name": "shop",
    "authenticator": "Symfony\\Component\\Security\\Http\\Authenticator\\Debug\\TraceableAuthenticator"
}
INFO 21:00:01 doctrine Connecting with parameters {params}
{
    "params": {
        "driver": "pdo_mysql",
        "idle_connection_ttl": 600,
        "host": "127.0.0.1",
        "port": null,
        "user": "sylius_cuisinstore_prod",
        "password": "<redacted>",
        "driverOptions": [],
        "defaultTableOptions": [],
        "dbname": "sylius_cuisinstore_prod",
        "serverVersion": "8",
        "charset": "utf8mb4"
    }
}
DEBUG 21:00:01 doctrine Executing statement: SELECT t0.code AS code_1, t0.name AS name_2, t0.color AS color_3, t0.description AS description_4, t0.enabled AS enabled_5, t0.hostname AS hostname_6, t0.created_at AS created_at_7, t0.updated_at AS updated_at_8, t0.id AS id_9, t0.theme_name AS theme_name_10, t0.tax_calculation_strategy AS tax_calculation_strategy_11, t0.contact_email AS contact_email_12, t0.contact_phone_number AS contact_phone_number_13, t0.skipping_shipping_step_allowed AS skipping_shipping_step_allowed_14, t0.skipping_payment_step_allowed AS skipping_payment_step_allowed_15, t0.account_verification_required AS account_verification_required_16, t0.shipping_address_in_checkout_required AS shipping_address_in_checkout_required_17, t0.default_locale_id AS default_locale_id_18, t19.code AS code_20, t19.created_at AS created_at_21, t19.updated_at AS updated_at_22, t19.id AS id_23, t0.base_currency_id AS base_currency_id_24, t25.code AS code_26, t25.created_at AS created_at_27, t25.updated_at AS updated_at_28, t25.id AS id_29, t0.default_tax_zone_id AS default_tax_zone_id_30, t0.menu_taxon_id AS menu_taxon_id_31, t0.shop_billing_data_id AS shop_billing_data_id_32, t0.channel_price_history_config_id AS channel_price_history_config_id_33 FROM sylius_channel t0 INNER JOIN sylius_locale t19 ON t0.default_locale_id = t19.id INNER JOIN sylius_currency t25 ON t0.base_currency_id = t25.id WHERE t0.hostname = ? AND t0.enabled = ? ORDER BY t0.id ASC LIMIT 1 (parameters: {params}, types: {types})
{
    "sql": "SELECT t0.code AS code_1, t0.name AS name_2, t0.color AS color_3, t0.description AS description_4, t0.enabled AS enabled_5, t0.hostname AS hostname_6, t0.created_at AS created_at_7, t0.updated_at AS updated_at_8, t0.id AS id_9, t0.theme_name AS theme_name_10, t0.tax_calculation_strategy AS tax_calculation_strategy_11, t0.contact_email AS contact_email_12, t0.contact_phone_number AS contact_phone_number_13, t0.skipping_shipping_step_allowed AS skipping_shipping_step_allowed_14, t0.skipping_payment_step_allowed AS skipping_payment_step_allowed_15, t0.account_verification_required AS account_verification_required_16, t0.shipping_address_in_checkout_required AS shipping_address_in_checkout_required_17, t0.default_locale_id AS default_locale_id_18, t19.code AS code_20, t19.created_at AS created_at_21, t19.updated_at AS updated_at_22, t19.id AS id_23, t0.base_currency_id AS base_currency_id_24, t25.code AS code_26, t25.created_at AS created_at_27, t25.updated_at AS updated_at_28, t25.id AS id_29, t0.default_tax_zone_id AS default_tax_zone_id_30, t0.menu_taxon_id AS menu_taxon_id_31, t0.shop_billing_data_id AS shop_billing_data_id_32, t0.channel_price_history_config_id AS channel_price_history_config_id_33 FROM sylius_channel t0 INNER JOIN sylius_locale t19 ON t0.default_locale_id = t19.id INNER JOIN sylius_currency t25 ON t0.base_currency_id = t25.id WHERE t0.hostname = ? AND t0.enabled = ? ORDER BY t0.id ASC LIMIT 1",
    "params": {
        "1": "sylius-cuisinstore.preprod.eu",
        "2": 1
    },
    "types": {
        "1": 2,
        "2": 5
    }
}
DEBUG 21:00:01 doctrine Executing statement: SELECT t0.code AS code_1, t0.created_at AS created_at_2, t0.updated_at AS updated_at_3, t0.id AS id_4 FROM sylius_locale t0 INNER JOIN sylius_channel_locales ON t0.id = sylius_channel_locales.locale_id WHERE sylius_channel_locales.channel_id = ? (parameters: {params}, types: {types})
{
    "sql": "SELECT t0.code AS code_1, t0.created_at AS created_at_2, t0.updated_at AS updated_at_3, t0.id AS id_4 FROM sylius_locale t0 INNER JOIN sylius_channel_locales ON t0.id = sylius_channel_locales.locale_id WHERE sylius_channel_locales.channel_id = ?",
    "params": {
        "1": 4
    },
    "types": {
        "1": 1
    }
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "Symfony\Component\HttpKernel\EventListener\DebugHandlersListener::configure".
{
    "event": "kernel.request",
    "listener": "Symfony\\Component\\HttpKernel\\EventListener\\DebugHandlersListener::configure"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "Sylius\Bundle\ResourceBundle\Storage\CookieStorage::onKernelRequest".
{
    "event": "kernel.request",
    "listener": "Sylius\\Bundle\\ResourceBundle\\Storage\\CookieStorage::onKernelRequest"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "Symfony\Component\HttpKernel\EventListener\ValidateRequestListener::onKernelRequest".
{
    "event": "kernel.request",
    "listener": "Symfony\\Component\\HttpKernel\\EventListener\\ValidateRequestListener::onKernelRequest"
}
DEBUG 21:00:01 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 21:00:01 event Notified event "kernel.request" to listener "Symfony\Component\HttpKernel\EventListener\SessionListener::onKernelRequest".
{
    "event": "kernel.request",
    "listener": "Symfony\\Component\\HttpKernel\\EventListener\\SessionListener::onKernelRequest"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "Symfony\Component\HttpKernel\EventListener\LocaleListener::setDefaultLocale".
{
    "event": "kernel.request",
    "listener": "Symfony\\Component\\HttpKernel\\EventListener\\LocaleListener::setDefaultLocale"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "Sylius\Bundle\ApiBundle\EventSubscriber\KernelRequestEventSubscriber::validateApi".
{
    "event": "kernel.request",
    "listener": "Sylius\\Bundle\\ApiBundle\\EventSubscriber\\KernelRequestEventSubscriber::validateApi"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "Symfony\Component\HttpKernel\EventListener\RouterListener::onKernelRequest".
{
    "event": "kernel.request",
    "listener": "Symfony\\Component\\HttpKernel\\EventListener\\RouterListener::onKernelRequest"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "Sylius\Resource\Symfony\EventListener\AddFormatListener::onKernelRequest".
{
    "event": "kernel.request",
    "listener": "Sylius\\Resource\\Symfony\\EventListener\\AddFormatListener::onKernelRequest"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "ApiPlatform\Symfony\EventListener\AddFormatListener::onKernelRequest".
{
    "event": "kernel.request",
    "listener": "ApiPlatform\\Symfony\\EventListener\\AddFormatListener::onKernelRequest"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "Symfony\Component\HttpKernel\EventListener\LocaleListener::onKernelRequest".
{
    "event": "kernel.request",
    "listener": "Symfony\\Component\\HttpKernel\\EventListener\\LocaleListener::onKernelRequest"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "Sylius\Bundle\ShopBundle\EventListener\NonChannelLocaleListener::restrictRequestLocale".
{
    "event": "kernel.request",
    "listener": "Sylius\\Bundle\\ShopBundle\\EventListener\\NonChannelLocaleListener::restrictRequestLocale"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "FOS\RestBundle\EventListener\BodyListener::onKernelRequest".
{
    "event": "kernel.request",
    "listener": "FOS\\RestBundle\\EventListener\\BodyListener::onKernelRequest"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "Symfony\Bundle\SecurityBundle\Debug\TraceableFirewallListener::configureLogoutUrlGenerator".
{
    "event": "kernel.request",
    "listener": "Symfony\\Bundle\\SecurityBundle\\Debug\\TraceableFirewallListener::configureLogoutUrlGenerator"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "Symfony\Bundle\SecurityBundle\Debug\TraceableFirewallListener::onKernelRequest".
{
    "event": "kernel.request",
    "listener": "Symfony\\Bundle\\SecurityBundle\\Debug\\TraceableFirewallListener::onKernelRequest"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "Sylius\Bundle\LocaleBundle\Listener\RequestLocaleSetter::onKernelRequest".
{
    "event": "kernel.request",
    "listener": "Sylius\\Bundle\\LocaleBundle\\Listener\\RequestLocaleSetter::onKernelRequest"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "ApiPlatform\Symfony\EventListener\ReadListener::onKernelRequest".
{
    "event": "kernel.request",
    "listener": "ApiPlatform\\Symfony\\EventListener\\ReadListener::onKernelRequest"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "Sylius\Bundle\CoreBundle\EventListener\LocaleAwareListener::onKernelRequest".
{
    "event": "kernel.request",
    "listener": "Sylius\\Bundle\\CoreBundle\\EventListener\\LocaleAwareListener::onKernelRequest"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "ApiPlatform\Symfony\EventListener\DeserializeListener::onKernelRequest".
{
    "event": "kernel.request",
    "listener": "ApiPlatform\\Symfony\\EventListener\\DeserializeListener::onKernelRequest"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "Sylius\Bundle\AdminBundle\EventListener\AdminFilterSubscriber::onKernelRequest".
{
    "event": "kernel.request",
    "listener": "Sylius\\Bundle\\AdminBundle\\EventListener\\AdminFilterSubscriber::onKernelRequest"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "Sylius\Bundle\CoreBundle\Checkout\CheckoutResolver::onKernelRequest".
{
    "event": "kernel.request",
    "listener": "Sylius\\Bundle\\CoreBundle\\Checkout\\CheckoutResolver::onKernelRequest"
}
DEBUG 21:00:01 event Notified event "kernel.request" to listener "Symfony\UX\LiveComponent\EventListener\LiveComponentSubscriber::onKernelRequest".
{
    "event": "kernel.request",
    "listener": "Symfony\\UX\\LiveComponent\\EventListener\\LiveComponentSubscriber::onKernelRequest"
}
DEBUG 21:00:01 event Notified event "kernel.controller" to listener "Symfony\UX\LiveComponent\EventListener\LiveComponentSubscriber::onKernelController".
{
    "event": "kernel.controller",
    "listener": "Symfony\\UX\\LiveComponent\\EventListener\\LiveComponentSubscriber::onKernelController"
}
DEBUG 21:00:01 event Notified event "kernel.controller" to listener "Symfony\Bundle\FrameworkBundle\DataCollector\RouterDataCollector::onKernelController".
{
    "event": "kernel.controller",
    "listener": "Symfony\\Bundle\\FrameworkBundle\\DataCollector\\RouterDataCollector::onKernelController"
}
DEBUG 21:00:01 event Notified event "kernel.controller" to listener "Symfony\Component\HttpKernel\DataCollector\RequestDataCollector::onKernelController".
{
    "event": "kernel.controller",
    "listener": "Symfony\\Component\\HttpKernel\\DataCollector\\RequestDataCollector::onKernelController"
}
DEBUG 21:00:01 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 21:00:01 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 21:00:01 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 21:00:01 event Notified event "kernel.controller_arguments" to listener "ContainerX4JY5xp\RequestPayloadValueResolverGhost01ca9cc::onKernelControllerArguments".
{
    "event": "kernel.controller_arguments",
    "listener": "ContainerX4JY5xp\\RequestPayloadValueResolverGhost01ca9cc::onKernelControllerArguments"
}
DEBUG 21:00:01 event Notified event "kernel.controller_arguments" to listener "Sylius\Bundle\CoreBundle\EventListener\CircularDependencyBreakingErrorListener::onControllerArguments".
{
    "event": "kernel.controller_arguments",
    "listener": "Sylius\\Bundle\\CoreBundle\\EventListener\\CircularDependencyBreakingErrorListener::onControllerArguments"
}

Stack Traces 3

[3/3] HookRenderException
Sylius\TwigHooks\Hookable\Renderer\Exception\HookRenderException:
An error occurred during rendering the "products" hook in the "sylius_shop.product.index.content.body.main" hookable. An exception has been thrown during the rendering of a template ("Product has no variants") in "@SyliusShop/product/index/content/body/main/products.html.twig" at line 8 in "@SyliusShop/product/index/content/body/main/products.html.twig" at line 8.

  at vendor/sylius/sylius/src/Sylius/Bundle/ShopBundle/templates/product/index/content/body/main/products.html.twig:8
  at Sylius\TwigHooks\Hookable\Renderer\HookableTemplateRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/CompositeHookableRenderer.php:45)
  at Sylius\TwigHooks\Hookable\Renderer\CompositeHookableRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableProfilerRenderer.php:36)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableDebugCommentRenderer.php:37)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/HookRenderer.php:58)
  at Sylius\TwigHooks\Hook\Renderer\HookRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookProfilerRenderer.php:34)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookDebugCommentRenderer.php:33)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Twig/Runtime/HooksRuntime.php:116)
  at Sylius\TwigHooks\Twig\Runtime\HooksRuntime->renderHook()
     (var/cache/dev/twig/f2/f21d4103552c418fe1001b100fd329da.php:52)
  at __TwigTemplate_55b6e31d1e8766e31aa38a2b4d94de04->doDisplay()
     (vendor/twig/twig/src/Template.php:402)
  at Twig\Template->yield()
     (vendor/twig/twig/src/Template.php:358)
  at Twig\Template->display()
     (vendor/twig/twig/src/Template.php:373)
  at Twig\Template->render()
     (vendor/twig/twig/src/TemplateWrapper.php:51)
  at Twig\TemplateWrapper->render()
     (vendor/twig/twig/src/Environment.php:333)
  at Twig\Environment->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/HookableTemplateRenderer.php:48)
  at Sylius\TwigHooks\Hookable\Renderer\HookableTemplateRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/CompositeHookableRenderer.php:45)
  at Sylius\TwigHooks\Hookable\Renderer\CompositeHookableRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableProfilerRenderer.php:36)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableDebugCommentRenderer.php:37)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/HookRenderer.php:58)
  at Sylius\TwigHooks\Hook\Renderer\HookRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookProfilerRenderer.php:34)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookDebugCommentRenderer.php:33)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Twig/Runtime/HooksRuntime.php:116)
  at Sylius\TwigHooks\Twig\Runtime\HooksRuntime->renderHook()
     (var/cache/dev/twig/c3/c3e5030a78e45887b8a806b0ee93d868.php:52)
  at __TwigTemplate_98361157b846a668bd1f2b28d4217319->doDisplay()
     (vendor/twig/twig/src/Template.php:402)
  at Twig\Template->yield()
     (vendor/twig/twig/src/Template.php:358)
  at Twig\Template->display()
     (vendor/twig/twig/src/Template.php:373)
  at Twig\Template->render()
     (vendor/twig/twig/src/TemplateWrapper.php:51)
  at Twig\TemplateWrapper->render()
     (vendor/twig/twig/src/Environment.php:333)
  at Twig\Environment->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/HookableTemplateRenderer.php:48)
  at Sylius\TwigHooks\Hookable\Renderer\HookableTemplateRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/CompositeHookableRenderer.php:45)
  at Sylius\TwigHooks\Hookable\Renderer\CompositeHookableRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableProfilerRenderer.php:36)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableDebugCommentRenderer.php:37)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/HookRenderer.php:58)
  at Sylius\TwigHooks\Hook\Renderer\HookRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookProfilerRenderer.php:34)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookDebugCommentRenderer.php:33)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Twig/Runtime/HooksRuntime.php:116)
  at Sylius\TwigHooks\Twig\Runtime\HooksRuntime->renderHook()
     (var/cache/dev/twig/fd/fd216abbb7556895a9eadc058d3a7b9d.php:52)
  at __TwigTemplate_46859a0140cf0782f158b2bb3b4ea39b->doDisplay()
     (vendor/twig/twig/src/Template.php:402)
  at Twig\Template->yield()
     (vendor/twig/twig/src/Template.php:358)
  at Twig\Template->display()
     (vendor/twig/twig/src/Template.php:373)
  at Twig\Template->render()
     (vendor/twig/twig/src/TemplateWrapper.php:51)
  at Twig\TemplateWrapper->render()
     (vendor/twig/twig/src/Environment.php:333)
  at Twig\Environment->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/HookableTemplateRenderer.php:48)
  at Sylius\TwigHooks\Hookable\Renderer\HookableTemplateRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/CompositeHookableRenderer.php:45)
  at Sylius\TwigHooks\Hookable\Renderer\CompositeHookableRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableProfilerRenderer.php:36)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableDebugCommentRenderer.php:37)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/HookRenderer.php:58)
  at Sylius\TwigHooks\Hook\Renderer\HookRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookProfilerRenderer.php:34)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookDebugCommentRenderer.php:33)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Twig/Runtime/HooksRuntime.php:104)
  at Sylius\TwigHooks\Twig\Runtime\HooksRuntime->renderHook()
     (var/cache/dev/twig/a5/a5fc340032c2cf97e977c1925ac39db2.php:78)
  at __TwigTemplate_0f5c7de71c397874f0d499267b2c9d53->block_content()
     (vendor/twig/twig/src/Template.php:446)
  at Twig\Template->yieldBlock()
     (var/cache/dev/twig/1b/1b0cad522de84ff2ba13fd7f2a6e9e90.php:234)
  at __TwigTemplate_e0c2d450114fe7b06a941c04476e5edd->block_body()
     (vendor/twig/twig/src/Template.php:446)
  at Twig\Template->yieldBlock()
     (var/cache/dev/twig/1b/1b0cad522de84ff2ba13fd7f2a6e9e90.php:103)
  at __TwigTemplate_e0c2d450114fe7b06a941c04476e5edd->doDisplay()
     (vendor/twig/twig/src/Template.php:402)
  at Twig\Template->yield()
     (var/cache/dev/twig/a5/a5fc340032c2cf97e977c1925ac39db2.php:53)
  at __TwigTemplate_0f5c7de71c397874f0d499267b2c9d53->doDisplay()
     (vendor/twig/twig/src/Template.php:402)
  at Twig\Template->yield()
     (vendor/twig/twig/src/Template.php:358)
  at Twig\Template->display()
     (vendor/twig/twig/src/Template.php:373)
  at Twig\Template->render()
     (vendor/twig/twig/src/TemplateWrapper.php:51)
  at Twig\TemplateWrapper->render()
     (vendor/twig/twig/src/Environment.php:333)
  at Twig\Environment->render()
     (vendor/sylius/resource-bundle/src/Bundle/Controller/ControllerTrait.php:247)
  at Sylius\Bundle\ResourceBundle\Controller\ResourceController->render()
     (vendor/sylius/resource-bundle/src/Bundle/Controller/ResourceController.php:150)
  at Sylius\Bundle\ResourceBundle\Controller\ResourceController->indexAction()
     (vendor/symfony/http-kernel/HttpKernel.php:183)
  at Symfony\Component\HttpKernel\HttpKernel->handleRaw()
     (vendor/symfony/http-kernel/HttpKernel.php:76)
  at Symfony\Component\HttpKernel\HttpKernel->handle()
     (vendor/symfony/http-kernel/Kernel.php:182)
  at Symfony\Component\HttpKernel\Kernel->handle()
     (vendor/symfony/runtime/Runner/Symfony/HttpKernelRunner.php:35)
  at Symfony\Component\Runtime\Runner\Symfony\HttpKernelRunner->run()
     (vendor/autoload_runtime.php:29)
  at require_once('/www/wwwroot/sylius-cuisinstore/vendor/autoload_runtime.php')
     (public/index.php:5)                
[2/3] RuntimeError
Twig\Error\RuntimeError:
An exception has been thrown during the rendering of a template ("Product has no variants") in "@SyliusShop/product/index/content/body/main/products.html.twig" at line 8.

  at vendor/sylius/sylius/src/Sylius/Bundle/ShopBundle/templates/product/index/content/body/main/products.html.twig:8
  at Twig\Template->yield()
     (vendor/twig/twig/src/Template.php:358)
  at Twig\Template->display()
     (vendor/twig/twig/src/Template.php:373)
  at Twig\Template->render()
     (vendor/twig/twig/src/TemplateWrapper.php:51)
  at Twig\TemplateWrapper->render()
     (vendor/twig/twig/src/Environment.php:333)
  at Twig\Environment->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/HookableTemplateRenderer.php:48)
  at Sylius\TwigHooks\Hookable\Renderer\HookableTemplateRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/CompositeHookableRenderer.php:45)
  at Sylius\TwigHooks\Hookable\Renderer\CompositeHookableRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableProfilerRenderer.php:36)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableDebugCommentRenderer.php:37)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/HookRenderer.php:58)
  at Sylius\TwigHooks\Hook\Renderer\HookRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookProfilerRenderer.php:34)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookDebugCommentRenderer.php:33)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Twig/Runtime/HooksRuntime.php:116)
  at Sylius\TwigHooks\Twig\Runtime\HooksRuntime->renderHook()
     (var/cache/dev/twig/f2/f21d4103552c418fe1001b100fd329da.php:52)
  at __TwigTemplate_55b6e31d1e8766e31aa38a2b4d94de04->doDisplay()
     (vendor/twig/twig/src/Template.php:402)
  at Twig\Template->yield()
     (vendor/twig/twig/src/Template.php:358)
  at Twig\Template->display()
     (vendor/twig/twig/src/Template.php:373)
  at Twig\Template->render()
     (vendor/twig/twig/src/TemplateWrapper.php:51)
  at Twig\TemplateWrapper->render()
     (vendor/twig/twig/src/Environment.php:333)
  at Twig\Environment->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/HookableTemplateRenderer.php:48)
  at Sylius\TwigHooks\Hookable\Renderer\HookableTemplateRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/CompositeHookableRenderer.php:45)
  at Sylius\TwigHooks\Hookable\Renderer\CompositeHookableRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableProfilerRenderer.php:36)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableDebugCommentRenderer.php:37)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/HookRenderer.php:58)
  at Sylius\TwigHooks\Hook\Renderer\HookRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookProfilerRenderer.php:34)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookDebugCommentRenderer.php:33)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Twig/Runtime/HooksRuntime.php:116)
  at Sylius\TwigHooks\Twig\Runtime\HooksRuntime->renderHook()
     (var/cache/dev/twig/c3/c3e5030a78e45887b8a806b0ee93d868.php:52)
  at __TwigTemplate_98361157b846a668bd1f2b28d4217319->doDisplay()
     (vendor/twig/twig/src/Template.php:402)
  at Twig\Template->yield()
     (vendor/twig/twig/src/Template.php:358)
  at Twig\Template->display()
     (vendor/twig/twig/src/Template.php:373)
  at Twig\Template->render()
     (vendor/twig/twig/src/TemplateWrapper.php:51)
  at Twig\TemplateWrapper->render()
     (vendor/twig/twig/src/Environment.php:333)
  at Twig\Environment->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/HookableTemplateRenderer.php:48)
  at Sylius\TwigHooks\Hookable\Renderer\HookableTemplateRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/CompositeHookableRenderer.php:45)
  at Sylius\TwigHooks\Hookable\Renderer\CompositeHookableRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableProfilerRenderer.php:36)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableDebugCommentRenderer.php:37)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/HookRenderer.php:58)
  at Sylius\TwigHooks\Hook\Renderer\HookRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookProfilerRenderer.php:34)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookDebugCommentRenderer.php:33)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Twig/Runtime/HooksRuntime.php:116)
  at Sylius\TwigHooks\Twig\Runtime\HooksRuntime->renderHook()
     (var/cache/dev/twig/fd/fd216abbb7556895a9eadc058d3a7b9d.php:52)
  at __TwigTemplate_46859a0140cf0782f158b2bb3b4ea39b->doDisplay()
     (vendor/twig/twig/src/Template.php:402)
  at Twig\Template->yield()
     (vendor/twig/twig/src/Template.php:358)
  at Twig\Template->display()
     (vendor/twig/twig/src/Template.php:373)
  at Twig\Template->render()
     (vendor/twig/twig/src/TemplateWrapper.php:51)
  at Twig\TemplateWrapper->render()
     (vendor/twig/twig/src/Environment.php:333)
  at Twig\Environment->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/HookableTemplateRenderer.php:48)
  at Sylius\TwigHooks\Hookable\Renderer\HookableTemplateRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/CompositeHookableRenderer.php:45)
  at Sylius\TwigHooks\Hookable\Renderer\CompositeHookableRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableProfilerRenderer.php:36)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableDebugCommentRenderer.php:37)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/HookRenderer.php:58)
  at Sylius\TwigHooks\Hook\Renderer\HookRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookProfilerRenderer.php:34)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookDebugCommentRenderer.php:33)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Twig/Runtime/HooksRuntime.php:104)
  at Sylius\TwigHooks\Twig\Runtime\HooksRuntime->renderHook()
     (var/cache/dev/twig/a5/a5fc340032c2cf97e977c1925ac39db2.php:78)
  at __TwigTemplate_0f5c7de71c397874f0d499267b2c9d53->block_content()
     (vendor/twig/twig/src/Template.php:446)
  at Twig\Template->yieldBlock()
     (var/cache/dev/twig/1b/1b0cad522de84ff2ba13fd7f2a6e9e90.php:234)
  at __TwigTemplate_e0c2d450114fe7b06a941c04476e5edd->block_body()
     (vendor/twig/twig/src/Template.php:446)
  at Twig\Template->yieldBlock()
     (var/cache/dev/twig/1b/1b0cad522de84ff2ba13fd7f2a6e9e90.php:103)
  at __TwigTemplate_e0c2d450114fe7b06a941c04476e5edd->doDisplay()
     (vendor/twig/twig/src/Template.php:402)
  at Twig\Template->yield()
     (var/cache/dev/twig/a5/a5fc340032c2cf97e977c1925ac39db2.php:53)
  at __TwigTemplate_0f5c7de71c397874f0d499267b2c9d53->doDisplay()
     (vendor/twig/twig/src/Template.php:402)
  at Twig\Template->yield()
     (vendor/twig/twig/src/Template.php:358)
  at Twig\Template->display()
     (vendor/twig/twig/src/Template.php:373)
  at Twig\Template->render()
     (vendor/twig/twig/src/TemplateWrapper.php:51)
  at Twig\TemplateWrapper->render()
     (vendor/twig/twig/src/Environment.php:333)
  at Twig\Environment->render()
     (vendor/sylius/resource-bundle/src/Bundle/Controller/ControllerTrait.php:247)
  at Sylius\Bundle\ResourceBundle\Controller\ResourceController->render()
     (vendor/sylius/resource-bundle/src/Bundle/Controller/ResourceController.php:150)
  at Sylius\Bundle\ResourceBundle\Controller\ResourceController->indexAction()
     (vendor/symfony/http-kernel/HttpKernel.php:183)
  at Symfony\Component\HttpKernel\HttpKernel->handleRaw()
     (vendor/symfony/http-kernel/HttpKernel.php:76)
  at Symfony\Component\HttpKernel\HttpKernel->handle()
     (vendor/symfony/http-kernel/Kernel.php:182)
  at Symfony\Component\HttpKernel\Kernel->handle()
     (vendor/symfony/runtime/Runner/Symfony/HttpKernelRunner.php:35)
  at Symfony\Component\Runtime\Runner\Symfony\HttpKernelRunner->run()
     (vendor/autoload_runtime.php:29)
  at require_once('/www/wwwroot/sylius-cuisinstore/vendor/autoload_runtime.php')
     (public/index.php:5)                
[1/3] InvalidArgumentException
InvalidArgumentException:
Product has no variants

  at vendor/sylius/sylius/src/Sylius/Bundle/ShopBundle/Twig/Component/Product/CardComponent.php:73
  at Sylius\Bundle\ShopBundle\Twig\Component\Product\CardComponent->getProductVariant()
     (vendor/symfony/ux-twig-component/src/ComponentProperties.php:90)
  at Symfony\UX\TwigComponent\ComponentProperties->extractProperties()
  at iterator_to_array()
     (vendor/symfony/ux-twig-component/src/ComponentProperties.php:50)
  at Symfony\UX\TwigComponent\ComponentProperties->getProperties()
     (vendor/symfony/ux-twig-component/src/ComponentRenderer.php:114)
  at Symfony\UX\TwigComponent\ComponentRenderer->preRender()
     (vendor/symfony/ux-twig-component/src/ComponentRenderer.php:63)
  at Symfony\UX\TwigComponent\ComponentRenderer->render()
     (vendor/symfony/ux-twig-component/src/ComponentRenderer.php:56)
  at Symfony\UX\TwigComponent\ComponentRenderer->createAndRender()
     (vendor/symfony/ux-twig-component/src/Twig/ComponentRuntime.php:51)
  at Symfony\UX\TwigComponent\Twig\ComponentRuntime->render()
     (var/cache/dev/twig/64/648f8d7f42909be8c9aef1e3f8dac8bb.php:70)
  at __TwigTemplate_92085a69acc8986e32dbc735b446ac2f->doDisplay()
     (vendor/twig/twig/src/Template.php:402)
  at Twig\Template->yield()
     (vendor/twig/twig/src/Template.php:358)
  at Twig\Template->display()
     (vendor/twig/twig/src/Template.php:373)
  at Twig\Template->render()
     (vendor/twig/twig/src/TemplateWrapper.php:51)
  at Twig\TemplateWrapper->render()
     (vendor/twig/twig/src/Environment.php:333)
  at Twig\Environment->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/HookableTemplateRenderer.php:48)
  at Sylius\TwigHooks\Hookable\Renderer\HookableTemplateRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/CompositeHookableRenderer.php:45)
  at Sylius\TwigHooks\Hookable\Renderer\CompositeHookableRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableProfilerRenderer.php:36)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableDebugCommentRenderer.php:37)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/HookRenderer.php:58)
  at Sylius\TwigHooks\Hook\Renderer\HookRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookProfilerRenderer.php:34)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookDebugCommentRenderer.php:33)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Twig/Runtime/HooksRuntime.php:116)
  at Sylius\TwigHooks\Twig\Runtime\HooksRuntime->renderHook()
     (var/cache/dev/twig/f2/f21d4103552c418fe1001b100fd329da.php:52)
  at __TwigTemplate_55b6e31d1e8766e31aa38a2b4d94de04->doDisplay()
     (vendor/twig/twig/src/Template.php:402)
  at Twig\Template->yield()
     (vendor/twig/twig/src/Template.php:358)
  at Twig\Template->display()
     (vendor/twig/twig/src/Template.php:373)
  at Twig\Template->render()
     (vendor/twig/twig/src/TemplateWrapper.php:51)
  at Twig\TemplateWrapper->render()
     (vendor/twig/twig/src/Environment.php:333)
  at Twig\Environment->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/HookableTemplateRenderer.php:48)
  at Sylius\TwigHooks\Hookable\Renderer\HookableTemplateRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/CompositeHookableRenderer.php:45)
  at Sylius\TwigHooks\Hookable\Renderer\CompositeHookableRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableProfilerRenderer.php:36)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableDebugCommentRenderer.php:37)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/HookRenderer.php:58)
  at Sylius\TwigHooks\Hook\Renderer\HookRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookProfilerRenderer.php:34)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookDebugCommentRenderer.php:33)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Twig/Runtime/HooksRuntime.php:116)
  at Sylius\TwigHooks\Twig\Runtime\HooksRuntime->renderHook()
     (var/cache/dev/twig/c3/c3e5030a78e45887b8a806b0ee93d868.php:52)
  at __TwigTemplate_98361157b846a668bd1f2b28d4217319->doDisplay()
     (vendor/twig/twig/src/Template.php:402)
  at Twig\Template->yield()
     (vendor/twig/twig/src/Template.php:358)
  at Twig\Template->display()
     (vendor/twig/twig/src/Template.php:373)
  at Twig\Template->render()
     (vendor/twig/twig/src/TemplateWrapper.php:51)
  at Twig\TemplateWrapper->render()
     (vendor/twig/twig/src/Environment.php:333)
  at Twig\Environment->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/HookableTemplateRenderer.php:48)
  at Sylius\TwigHooks\Hookable\Renderer\HookableTemplateRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/CompositeHookableRenderer.php:45)
  at Sylius\TwigHooks\Hookable\Renderer\CompositeHookableRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableProfilerRenderer.php:36)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableDebugCommentRenderer.php:37)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/HookRenderer.php:58)
  at Sylius\TwigHooks\Hook\Renderer\HookRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookProfilerRenderer.php:34)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookDebugCommentRenderer.php:33)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Twig/Runtime/HooksRuntime.php:116)
  at Sylius\TwigHooks\Twig\Runtime\HooksRuntime->renderHook()
     (var/cache/dev/twig/fd/fd216abbb7556895a9eadc058d3a7b9d.php:52)
  at __TwigTemplate_46859a0140cf0782f158b2bb3b4ea39b->doDisplay()
     (vendor/twig/twig/src/Template.php:402)
  at Twig\Template->yield()
     (vendor/twig/twig/src/Template.php:358)
  at Twig\Template->display()
     (vendor/twig/twig/src/Template.php:373)
  at Twig\Template->render()
     (vendor/twig/twig/src/TemplateWrapper.php:51)
  at Twig\TemplateWrapper->render()
     (vendor/twig/twig/src/Environment.php:333)
  at Twig\Environment->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/HookableTemplateRenderer.php:48)
  at Sylius\TwigHooks\Hookable\Renderer\HookableTemplateRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/CompositeHookableRenderer.php:45)
  at Sylius\TwigHooks\Hookable\Renderer\CompositeHookableRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableProfilerRenderer.php:36)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hookable/Renderer/Debug/HookableDebugCommentRenderer.php:37)
  at Sylius\TwigHooks\Hookable\Renderer\Debug\HookableDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/HookRenderer.php:58)
  at Sylius\TwigHooks\Hook\Renderer\HookRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookProfilerRenderer.php:34)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookProfilerRenderer->render()
     (vendor/sylius/twig-hooks/src/Hook/Renderer/Debug/HookDebugCommentRenderer.php:33)
  at Sylius\TwigHooks\Hook\Renderer\Debug\HookDebugCommentRenderer->render()
     (vendor/sylius/twig-hooks/src/Twig/Runtime/HooksRuntime.php:104)
  at Sylius\TwigHooks\Twig\Runtime\HooksRuntime->renderHook()
     (var/cache/dev/twig/a5/a5fc340032c2cf97e977c1925ac39db2.php:78)
  at __TwigTemplate_0f5c7de71c397874f0d499267b2c9d53->block_content()
     (vendor/twig/twig/src/Template.php:446)
  at Twig\Template->yieldBlock()
     (var/cache/dev/twig/1b/1b0cad522de84ff2ba13fd7f2a6e9e90.php:234)
  at __TwigTemplate_e0c2d450114fe7b06a941c04476e5edd->block_body()
     (vendor/twig/twig/src/Template.php:446)
  at Twig\Template->yieldBlock()
     (var/cache/dev/twig/1b/1b0cad522de84ff2ba13fd7f2a6e9e90.php:103)
  at __TwigTemplate_e0c2d450114fe7b06a941c04476e5edd->doDisplay()
     (vendor/twig/twig/src/Template.php:402)
  at Twig\Template->yield()
     (var/cache/dev/twig/a5/a5fc340032c2cf97e977c1925ac39db2.php:53)
  at __TwigTemplate_0f5c7de71c397874f0d499267b2c9d53->doDisplay()
     (vendor/twig/twig/src/Template.php:402)
  at Twig\Template->yield()
     (vendor/twig/twig/src/Template.php:358)
  at Twig\Template->display()
     (vendor/twig/twig/src/Template.php:373)
  at Twig\Template->render()
     (vendor/twig/twig/src/TemplateWrapper.php:51)
  at Twig\TemplateWrapper->render()
     (vendor/twig/twig/src/Environment.php:333)
  at Twig\Environment->render()
     (vendor/sylius/resource-bundle/src/Bundle/Controller/ControllerTrait.php:247)
  at Sylius\Bundle\ResourceBundle\Controller\ResourceController->render()
     (vendor/sylius/resource-bundle/src/Bundle/Controller/ResourceController.php:150)
  at Sylius\Bundle\ResourceBundle\Controller\ResourceController->indexAction()
     (vendor/symfony/http-kernel/HttpKernel.php:183)
  at Symfony\Component\HttpKernel\HttpKernel->handleRaw()
     (vendor/symfony/http-kernel/HttpKernel.php:76)
  at Symfony\Component\HttpKernel\HttpKernel->handle()
     (vendor/symfony/http-kernel/Kernel.php:182)
  at Symfony\Component\HttpKernel\Kernel->handle()
     (vendor/symfony/runtime/Runner/Symfony/HttpKernelRunner.php:35)
  at Symfony\Component\Runtime\Runner\Symfony\HttpKernelRunner->run()
     (vendor/autoload_runtime.php:29)
  at require_once('/www/wwwroot/sylius-cuisinstore/vendor/autoload_runtime.php')
     (public/index.php:5)