templates/frontend/category/category.html.twig line 1

Open in your IDE?
  1. {% extends 'base.html.twig' %}
  2. {% trans_default_domain 'store' %}
  3. {% form_theme form 'form/front.html.twig' %}
  4. {% block title %}
  5.     {{ category.metaTitle }}
  6.     {% if app.request.attributes.get('av24h') %}
  7.         {{ 'products_in_24h_delivery'|trans({}, 'store', locale) }}
  8.     {% endif %}
  9.     {% if (app.request.query.get('page') == 1 or app.request.query.get('page') == null) %}
  10.     {% else %}
  11.         - {{ 'page'|trans }} {{ app.request.get('page') }}
  12.     {% endif %}
  13. {% endblock %}
  14. {% block meta_desc_key %}
  15.     {% if category.metaDescription is defined %}
  16.         <meta name="description" content="{{ category.metaDescription|raw }}">
  17.     {% else %}
  18.         <meta name="description" content="Centrum Krzeseł, Sprawdź krzesła i fotele do biura i domu. Niskie ceny, gwarancja oraz dostawa 24h. Kup teraz!">
  19.     {% endif %}
  20.     {% if category.metaKeywords is defined %}
  21.         <meta name="keywords" content="{{ category.metaKeywords|raw }}">
  22.     {% else %}
  23.         <meta name="keywords" content="krzesła, fotele, hokery, meble, sklep internetowy, zakupy, centrum krzeseł">
  24.     {% endif %}
  25.     {% if app.request.locale == 'pl' %}
  26.         {# veltis tag #}
  27.         {#
  28.         <script async src='https://app.veltis.io/uploads/veltis.js'></script><script>window.veltisData = window.veltisData || []; function veltisTag() { veltisData.push(arguments); } veltisTag('js', new Date()); veltisTag('config', '1aadaf84c154d3e3'); </script>
  29.         #}
  30.     {% endif %}
  31. {% endblock %}
  32. {% block facebook %}
  33.     {% if category.imageName %}
  34.         <meta property="og:image" content="{{ language.storeUrl }}/images/category/{{ category.imageName }}"/>
  35.     {% endif %}
  36.     {% autoescape %}
  37.         <meta property="og:title" content="{{ category.name }}"/>
  38.     {% endautoescape %}
  39.     <meta property="og:url" content="{{ language.storeUrl }}{{ path('category', {'slug':category.slug, 'id':category.id}) }}"/>
  40.     <meta property="og:type" content="product.group"/>
  41.     {% if category.metaDescription is defined %}
  42.         <meta property="og:description" content="{{ category.metaDescription|raw }}">
  43.     {% else %}
  44.         <meta property="og:description" content="{{ category.metaTitle|raw }}">
  45.     {% endif %}
  46.     {% if app.request.get('slug') is defined and app.request.get('page') is defined %}
  47.         {#
  48.         {{ linkrel|raw }}
  49.         #}
  50.     {% endif %}
  51.     {% if app.request.locale == 'pl' %}
  52.         {% if category.getCanonical %}
  53.             <link rel="canonical" href="{{ category.getCanonical }}" />
  54.         {% else %}
  55.             {% if app.request.get('search') %}
  56.                 <link rel="canonical" href="https://www.centrumkrzesel.pl{{ path('category', {'id':category.id, 'slug':category.slug}) }}" />
  57.             {% elseif app.request.attributes.get('av24h') %}
  58.                 <link rel="canonical" href="https://www.centrumkrzesel.pl{{ path('category', {'id':category.id, 'slug':category.slug}) }}" />
  59.             {% elseif app.request.get('page') == 1 %}
  60.                 <link rel="canonical" href="https://www.centrumkrzesel.pl{{ path('category', {'slug':category.slug, 'id':category.id}) }}" />
  61.             {% elseif app.request.get('page') >= 2 %}
  62.             {% endif %}
  63.         {% endif %}
  64.     {% endif %}
  65.     {% if app.request.locale == 'cz' %}
  66.         {% if category.getCanonical %}
  67.             <link rel="canonical" href="{{ category.getCanonical }}" />
  68.         {% else %}
  69.             {% if app.request.get('search') %}
  70.                 <link rel="canonical" href="https://www.ezidle.cz{{ path('category', {'id':category.id, 'slug':category.slug}) }}" />
  71.             {% elseif app.request.attributes.get('av24h') %}
  72.                 <link rel="canonical" href="https://www.ezidle.cz{{ path('category', {'id':category.id, 'slug':category.slug}) }}" />
  73.             {% elseif app.request.get('page') == 1 %}
  74.                 <link rel="canonical" href="https://www.ezidle.cz{{ path('category', {'slug':category.slug, 'id':category.id}) }}" />
  75.             {% elseif app.request.get('page') >= 2 %}
  76.             {% endif %}
  77.         {% endif %}
  78.     {% endif %}
  79.     {% if app.request.locale == 'sk' %}
  80.         {% if category.getCanonical %}
  81.             <link rel="canonical" href="{{ category.getCanonical }}" />
  82.         {% else %}
  83.             {% if app.request.get('search') %}
  84.                 <link rel="canonical" href="https://www.stolicky24.sk{{ path('category', {'id':category.id, 'slug':category.slug}) }}" />
  85.             {% elseif app.request.attributes.get('av24h') %}
  86.                 <link rel="canonical" href="https://www.stolicky24.sk{{ path('category', {'id':category.id, 'slug':category.slug}) }}" />
  87.             {% elseif app.request.get('page') == 1 %}
  88.                 <link rel="canonical" href="https://www.stolicky24.sk{{ path('category', {'slug':category.slug, 'id':category.id}) }}" />
  89.             {% elseif app.request.get('page') >= 2 %}
  90.             {% endif %}
  91.         {% endif %}
  92.     {% endif %}
  93.     {% if app.request.locale == 'ro' %}
  94.         {% if category.getCanonical %}
  95.             <link rel="canonical" href="{{ category.getCanonical }}" />
  96.         {% else %}
  97.             {% if app.request.get('search') %}
  98.                 <link rel="canonical" href="https://www.mobila24.ro{{ path('category', {'id':category.id, 'slug':category.slug}) }}" />
  99.             {% elseif app.request.attributes.get('av24h') %}
  100.                 <link rel="canonical" href="https://www.mobila24.ro{{ path('category', {'id':category.id, 'slug':category.slug}) }}" />
  101.             {% elseif app.request.get('page') == 1 %}
  102.                 <link rel="canonical" href="https://www.mobila24.ro{{ path('category', {'slug':category.slug, 'id':category.id}) }}" />
  103.             {% elseif app.request.get('page') >= 2 %}
  104.             {% endif %}
  105.         {% endif %}
  106.     {% endif %}
  107. {% endblock %}
  108. {% block css %}
  109.     {{ parent() }}
  110.     <style>
  111.         /* Kolory w bocznym menu rozwijanym dzialaja, ale problem jest w tym ze input typu checkbox nie ma backgrounda i trzeba z osobna dodawac kazdy background image z kazdym kolorem/tkanina. Checkbox dodaje sie sam. Jezeli tkanina jest jasna, checkbox musi byc czarny*/
  112.         #kolory  label.kolor-czerowny:before {
  113.             background: url(/images/red-bg.png)center center no-repeat;
  114.         }
  115.         #kolory input[type=checkbox]:checked + label.kolor-czerowny:before {
  116.             background:url(/images/check.png)center center no-repeat, url(/images/red-bg.png)center center no-repeat;
  117.         }
  118.         #kolory  label.kolor-zielony:before {
  119.             background: url(/images/zielony-bg.png)center center no-repeat;
  120.         }
  121.         #kolory input[type=checkbox]:checked + label.kolor-zielony:before {
  122.             background:url(/images/check-czarny.png)center center no-repeat, url(/images/zielony-bg.png)center center no-repeat;
  123.         }
  124.         @media (max-width: 1022px) {
  125.             label.checkbox {
  126.                 margin-bottom: 8px!important;
  127.             }
  128.         }
  129.         @media (min-width: 900px) {
  130.             #search_functions, #search_execution {
  131.                 max-height: 470px;
  132.                 overflow-y: auto;
  133.                 overflow-x: hidden;
  134.             }
  135.             .image img {
  136.                 width:auto;
  137.                 margin-left: auto;
  138.                 margin-right: auto;
  139.             }
  140.         }
  141.         @media (max-width: 500px) {
  142.             .with-description {
  143.                 height:auto!important;
  144.             }
  145.         }
  146.         .cat-desc-excerpt {
  147.             overflow: hidden;
  148.             text-overflow: ellipsis;
  149.             height: 110px;
  150.         }
  151.         #cat-desc-excerpt h2 {
  152.             font-size:initial!important;
  153.             font-weight: bold;
  154.         }
  155.         #cat-desc-excerpt h1 {
  156.             font-size:initial!important;
  157.         }
  158.         #cat-desc-excerpt h3 {
  159.             font-size:initial!important;
  160.         }
  161.         #cat-desc-excerpt a {
  162.             color:#ef1b2b!important;
  163.         }
  164.         #cat-desc-excerpt ul {
  165.             list-style: initial!important;
  166.         }
  167.         #cat-desc-excerpt li {
  168.             list-style: initial!important;
  169.             margin-left:30px;
  170.         }
  171.         #search_color .checkbox {
  172.             display: block;
  173.             position: relative;
  174.             padding-left: 35px;
  175.             margin-bottom: 12px;
  176.             cursor: pointer;
  177.             -webkit-user-select: none;
  178.             -moz-user-select: none;
  179.             -ms-user-select: none;
  180.             user-select: none;
  181.         }
  182.         /* Hide the browser's default checkbox */
  183.         #search_color .checkbox input {
  184.             position: absolute;
  185.             opacity: 0;
  186.             cursor: pointer;
  187.             height: 0;
  188.             width: 0;
  189.         }
  190.         /* Create a custom checkbox */
  191.         #search_color .checkmark {
  192.             position: absolute;
  193.             top: 0;
  194.             left: 0;
  195.             height: 22px;
  196.             width: 22px;
  197.             background-color: #ebebeb;
  198.         }
  199.         /* Create the checkmark/indicator (hidden when not checked) */
  200.         #search_color .checkmark:after {
  201.             content: "";
  202.             position: absolute;
  203.             display: none;
  204.         }
  205.         /* Show the checkmark when checked */
  206.         #search_color .checkbox input:checked ~ .checkmark:after {
  207.             display: block;
  208.         }
  209.         /* Style the checkmark/indicator */
  210.         #search_color .checkbox .checkmark:after {
  211.             left: 9px;
  212.             top: 5px;
  213.             width: 5px;
  214.             height: 10px;
  215.             border: solid white;
  216.             border-width: 0 3px 3px 0;
  217.             -webkit-transform: rotate(45deg);
  218.             -ms-transform: rotate(45deg);
  219.             transform: rotate(45deg);
  220.         }
  221.         /* MOBILE COLORS */
  222.         #search_colorMobile .checkbox {
  223.             display: block;
  224.             position: relative;
  225.             padding-left: 35px;
  226.             margin-bottom: 12px;
  227.             cursor: pointer;
  228.             -webkit-user-select: none;
  229.             -moz-user-select: none;
  230.             -ms-user-select: none;
  231.             user-select: none;
  232.         }
  233.         /* Hide the browser's default checkbox */
  234.         #search_colorMobile .checkbox input {
  235.             position: absolute;
  236.             opacity: 0;
  237.             cursor: pointer;
  238.             height: 0;
  239.             width: 0;
  240.         }
  241.         /* Create a custom checkbox */
  242.         #search_colorMobile .checkmark {
  243.             position: absolute;
  244.             top: 0;
  245.             left: 0;
  246.             height: 22px;
  247.             width: 22px;
  248.             background-color: #ebebeb;
  249.         }
  250.         /* Create the checkmark/indicator (hidden when not checked) */
  251.         #search_colorMobile .checkmark:after {
  252.             content: "";
  253.             position: absolute;
  254.             display: none;
  255.         }
  256.         /* Show the checkmark when checked */
  257.         #search_colorMobile .checkbox input:checked ~ .checkmark:after {
  258.             display: block;
  259.         }
  260.         /* Style the checkmark/indicator */
  261.         #search_colorMobile .checkbox .checkmark:after {
  262.             left: 9px;
  263.             top: 5px;
  264.             width: 5px;
  265.             height: 10px;
  266.             border: solid white;
  267.             border-width: 0 3px 3px 0;
  268.             -webkit-transform: rotate(45deg);
  269.             -ms-transform: rotate(45deg);
  270.             transform: rotate(45deg);
  271.         }
  272.     </style>
  273.     <style>
  274.         #search_availability .checkbox {
  275.             float:left;
  276.         }
  277.     </style>
  278. {% endblock %}
  279. {% block javascripts %}
  280.     {{ parent() }}
  281.     <script>
  282.         $(document).ready(function () {
  283.             $('#search_sorting').on("change", function() {
  284.                 $('#submitButton').trigger("click");
  285.             });
  286.             $('.wiecej-pomieszczen').trigger("click");
  287.             {% if app.request.attributes.get('av24h') %}
  288.                 $('#search_availability_5').on("click", function() {
  289.                     if (!$(this).is(":selected")) {
  290.                         var url = $('#current_url').val();
  291.                         window.location.href = url;
  292.                         return;
  293.                     } else {
  294.                         var url = $('#current_url_24h').val();
  295.                         window.location.href = url;
  296.                         return;
  297.                     }
  298.                 });
  299.             {% else %}
  300.                 $('#search_availability_5').on("click", function() {
  301.                     if (!$(this).is(":selected")) {
  302.                         var url = $('#current_url_24h').val();
  303.                         window.location.href = url;
  304.                         return;
  305.                     } else {
  306.                         var url = $('#current_url').val();
  307.                         window.location.href = url;
  308.                         return;
  309.                     }
  310.                 });
  311.             {% endif %}
  312.             {% if app.request.attributes.get('av24h') %}
  313.                 $('#search_availability_5').prop("checked", true);
  314.             {% else %}
  315.             {% endif %}
  316.             $('.productsPerPage').on("change", function() {
  317.                 var productsPerPage = $(this).val();
  318.                 var url = $('#change_products_per_page_url').val();
  319.                 $.ajax({
  320.                     type: "POST",
  321.                     url: url,
  322.                     data: {'productsPerPage':productsPerPage},
  323.                     success: function (data) {
  324.                         window.location.reload();
  325.                     }
  326.                 });
  327.             });
  328.             $('#search_color label input').each(function() {
  329.                 var color = $(this).attr('color');
  330.                 $(this).parent().css("padding-top", "2px");
  331.                 if (color === '#ffffff' || color === '#FFFFFF') {
  332.                     $(this).next('span').css("border", '1px solid black');
  333.                 } else {
  334.                     $(this).next('span').css("background-color", color);
  335.                 }
  336.             });
  337.             $(document).on('click','.is-mobile',function(){
  338.                 $('#search_colorMobile label input').each(function() {
  339.                     var color = $(this).attr('color');
  340.                     $(this).parent().css("padding-top", "2px");
  341.                     if (color === '#ffffff' || color === '#FFFFFF') {
  342.                         $(this).next('span').css("border", '1px solid black');
  343.                     } else {
  344.                         $(this).next('span').css("background-color", color);
  345.                     }
  346.                 });
  347.             });
  348.         });
  349.     </script>
  350. {% endblock %}
  351. {% block content %}
  352.     <input type="hidden" id="current_url" value="{{ path('category', {'id':category.id, 'slug':category.slug}) }}"/>
  353.     <input type="hidden" id="current_url_24h" value="{{ path('category', {'id':category.id, 'av24h':'24h', 'slug':category.slug}) }}"/>
  354.     <input type="hidden" id="change_products_per_page_url" value="{{ path('change_products_per_page') }}"/>
  355.     <!-- START OF CATEGORY NAME SECTION -->
  356.     <section class="section topSection">
  357.         <div class="container">
  358.             <div class="columns is-multiline">
  359.                 <div class="column is-full">
  360.                     <h1 style="display: inline-block" class="is-size-2">
  361.                         {%  if category.getCustomH1 %}
  362.                             {{ category.getCustomH1 }}
  363.                         {% else %}
  364.                             {{ category.name }}
  365.                         {% endif %}
  366.                         {% if app.request.attributes.get('av24h') %}
  367.                                 {{ 'sending_in_24h'|trans }}
  368.                             </span>
  369.                         {% endif %}
  370.                     </h1>
  371.                     <span style="display: inline-block; color:#d0d0d0!important;" class="is-size-2">({{ products.getTotalItemCount() }})</span>
  372.                 </div>
  373.                 <!-- START OF BREADCRUMBS -->
  374.                 <div class="no-top-padding column is-full" style="margin-top:-10px;">
  375.                     <nav class="breadcrumb has-arrow-separator is-hidden-mobile" aria-label="breadcrumb">
  376.                         <ul vocab="https://schema.org/" typeof="BreadcrumbList">
  377.                             <li property="itemListElement" typeof="ListItem">
  378.                                 <a id="0" property="item" typeof="WebPage" href="{{ path('homepage') }}"><span property="name">{{ language.shopName }}</span></a>
  379.                                 <meta property="position" content="1">
  380.                             </li>
  381.                             {% set c = 1 %}
  382.                             {% if category.parent is defined and category.parent %}
  383.                                 {% set c = c + 1 %}
  384.                                 <li property="itemListElement" typeof="ListItem" style="margin-top:-2px;">
  385.                                     <a id="{{ category.id }}" property="item" typeof="WebPage"  href="{{ path('category', {'id':category.parent.id, 'slug':category.parent.slug}) }}">
  386.                                         <span property="name">{{ category.parent.name }}</span>
  387.                                         {% if app.request.attributes.get('av24h') %}
  388.                                             {{ 'sending_in_24h'|trans }}
  389.                                         {% endif %}
  390.                                     </a>
  391.                                     <meta property="position" content="{{ c }}">
  392.                                 </li>
  393.                             {% endif %}
  394.                             <li property="itemListElement" typeof="ListItem" style="margin-top:-2px;">
  395.                                 <a id="{{ category.id }}" property="item" typeof="WebPage"><span property="name">{{ category.name }}</span>
  396.                                     {% if app.request.attributes.get('av24h') %}
  397.                                         {{ 'sending_in_24h'|trans }}
  398.                                     {% endif %}
  399.                                 </a>
  400.                                 <meta property="position" content="{{ c+1 }}">
  401.                             </li>
  402.                         </ul>
  403.                     </nav>
  404.                 </div>
  405.                 <!-- END OF BREADCRUMBS -->
  406.             </div>
  407.         </div>
  408.     </section>
  409.     <!-- END OF CATEGORY NAME SECTION -->
  410.     <!-- START OF MAIN SECTION -->
  411.     {{ form_start(form, {'attr': {'method':'get', 'role':'form', 'novalidate': 'novalidate'}}) }}
  412.     <section class="section remove-padding-top">
  413.         <div class="container">
  414.             <div class="columns">
  415.                 {% include 'frontend/category/_leftSidebar.html.twig' %}
  416.                 {% set criteoIds = [] %}
  417.                 <div class="columns is-multiline is-mobile lista-produktow" v-match-heights="{ el: [ '.with-description' ] }">
  418.                     {% if products.getTotalItemCount == 0 %}
  419.                         <div style="text-align: center; width:100%; padding:40px;">
  420.                             <i class="fa fa-search-minus" style="font-size:40px; font-weight: bold; padding:20px;"></i>
  421.                             <br/>
  422.                             {{ 'no_results_category'|trans }}
  423.                         </div>
  424.                     {% else %}
  425.                         {% for productData in products %}
  426.                             {% set product = productData[0] %}
  427.                             {% set criteoIds = criteoIds|merge([product.id]) %}
  428.                             {% include 'frontend/components/smallProduct.html.twig' with {'isOneThird':1, 'product':product, 'productData':productData} %}
  429.                         {% endfor %}
  430.                     {% endif %}
  431.                 </div>
  432.             </div>
  433.                 <!-- END OF PRODUCT LIST -->
  434.         </div>
  435.         <div class="level-right">
  436.             <div class="level-item">
  437.                 {{ knp_pagination_render(products) }}
  438.             </div>
  439.         </div>
  440.     </section>
  441.     {{ form_end(form) }}
  442.     <!-- END OF MAIN SECTION -->
  443.     {% include 'frontend/category/_lastViewed.html.twig' %}
  444.     {% if category.getDescription and (app.request.query.get('page') == 1 or app.request.query.get('page') == null) %}
  445.         <div class="section">
  446.             <div class="container">
  447.                 <div id="js_cat-desc-content">
  448.                     <div id="cat-desc-excerpt" class="cat-desc-excerpt ellipsis" style="font-size: 13px;">
  449.                         {{ category.getDescription|strongReplacer|raw }}
  450.                     </div>
  451.                     <a class="dotted-link read-more" style="margin-top:10px; float:right;" data-target="js_cat-desc-content" role="button">{{ 'read_more'|trans }}...</a>
  452.                 </div>
  453.             </div>
  454.         </div>
  455.     {% endif %}
  456.     {% set criteoCount = 0 %}
  457.     {% if app.request.locale == 'pl' %}
  458.         <script type="text/javascript" src="//static.criteo.net/js/ld/ld.js" async="true"></script>
  459.         <script type="text/javascript">
  460.             window.criteo_q = window.criteo_q || [];
  461.             var deviceType = /iPad/.test(navigator.userAgent) ? "t" : /Mobile|iP(hone|od)|Android|BlackBerry|IEMobile|Silk/.test(navigator.userAgent) ? "m" : "d";
  462.             window.criteo_q.push(
  463.                 { event: "setAccount", account: 36267 },
  464.                 { event: "setSiteType", type: deviceType },
  465.                 { event: "setEmail", email: "{% if app.user.email is defined %} {{ app.user.email }} {% endif %}" },
  466.                 { event: "viewList", item:[ {% for item in criteoIds|slice(0,3) %}{% set criteoCount = criteoCount + 1 %}{% if criteoCount != 3 %} "{{ item }}", {% else %} "{{ item }}"{% endif %} {% endfor %} ]}
  467.             );
  468.         </script>
  469.     {% endif %}
  470. {% endblock %}