- [Case Studies](https://www.mergado.cz/kategorie/case-studies)
- [E‑commerce tipy](https://www.mergado.cz/kategorie/e-commerce-tipy)
- [E‑shopová řešení a platformy](https://www.mergado.cz/kategorie/e-shopova-reseni-a-platformy)
- [Mergado Pack](https://www.mergado.cz/kategorie/mergado-pack)
- [Mergado tipy](https://www.mergado.cz/kategorie/mergado-tipy)
- [Novinky v Mergadu](https://www.mergado.cz/kategorie/novinky-v-mergadu)
- [Novinky ze srovnávačů](https://www.mergado.cz/kategorie/novinky-ze-srovnavacu)
- [Pracujeme s Mergadem](https://www.mergado.cz/kategorie/pracujeme-s-mergadem)
- [Rozhovory](https://www.mergado.cz/kategorie/rozhovory)
- [Rozšíření](https://www.mergado.cz/kategorie/aplikace)
- [S Mergadem do zahraničí](https://www.mergado.cz/kategorie/s-mergadem-do-zahranici)
- [Ze života Mergada](https://www.mergado.cz/kategorie/ze-zivota-mergada)
 



 

 1. [  Úvod  ](https://www.mergado.cz/)
2. [     Blog  ](https://www.mergado.cz/blog)
3. [     Pracujeme s Mergadem  ](https://www.mergado.cz/kategorie/pracujeme-s-mergadem)
4. <a class="flex items-center gap-2 hover:underline" href="" itemid="" itemprop="item" itemscope="" itemtype="https://schema.org/Thing">    **Změny v tagu PRODUCT na Heurece** </a>
 
  

 

#  **Změny v tagu PRODUCT na Heurece** 

 

 

 [    ![](https://www.mergado.cz/sites/default/files/perm/user-avatar/jakubvsaku.jpg)   Jakub Nožička  ](https://www.mergado.cz/blog/jakub-nozicka) [Pracujeme s Mergadem](https://www.mergado.cz/kategorie/pracujeme-s-mergadem) 

26. 2. 2016

2 minuty čtení

 

 

 

 

 

  ![Změny v tagu PRODUCT na Heurece](https://www.mergado.cz/sites/default/files/field/image/heureka-spravne-nazvy-produktu.png)  

Včera se na [blogu Heureky](http://blog.heureka.cz/vyplnujte-spravne-nazvy-produktu/) objevila zajímavá informace o změnách v názvech produktů. Jak to bylo dříve a jak to bude nyní, si vysvětlíme v tomto článku.



 

 

 
                function tableOfContents() {
                  return {
                    headings_menu: [],
                    heading_active: '', // Added to track the active section
                    shouldBeSticky: false,

                    generateToC() {
                      const headings = document.querySelectorAll('.js-article-full-headings h2, .js-article-full-headings h3');
                      let headingMap = {};

                      headings.forEach((heading) => { // Use an arrow function to maintain `this` context
                        // Normalize heading text to remove diacritics, then replace non-alphanumeric characters with dashes
                        var normalizedText = heading.textContent.normalize("NFD").replace(/[\u0300-\u036f]/g, ""); // Remove diacritics
                        var id = heading.id ? heading.id : normalizedText.trim().toLowerCase()
                          .split(' ').join('-').replace(/[^a-z0-9\-]/ig, ''); // Updated regex to replace non-alphanumeric characters
                        headingMap[id] = headingMap[id] !== undefined ? ++headingMap[id] : 0;

                        // Use the updated `id` with diacritics removed for the heading id and the TOC
                        const finalId = headingMap[id] ? `${id}-${headingMap[id]}` : id;
                        this.headings_menu.push({
                          id: finalId,
                          title: heading.textContent,
                          level: heading.tagName.toLowerCase(), // Track heading level
                          active: false, // Initially set active to false
                        });
                        heading.id = finalId;
                      });
                    },

                    checkStickyNeeded() {
                      const ul = this.$el.querySelector('ul');
                      if (ul) {
                        this.shouldBeSticky = ul.scrollHeight < window.innerHeight;
                      }
                    },

                    setActiveHeading() {
                      // disabled not working with active state on click
                      // add @scroll.window="setActiveHeading()" to the parent div

                      // const headings = document.querySelectorAll('.js-article-full-headings h2');
                      // let activeHeading = '';
                      // let closestHeadingDistance = Infinity;

                      // headings.forEach((heading) => {
                      //   const rect = heading.getBoundingClientRect();
                      //   const offset = rect.top - window.innerHeight / 2; // Consider heading in the middle of the screen as active

                      //   if (offset < 0 && Math.abs(offset) < closestHeadingDistance) {
                      //     activeHeading = heading.id;
                      //     closestHeadingDistance = Math.abs(offset);
                      //   }
                      // });

                      // // Update the active state in headings_menu
                      // if (activeHeading !== this.heading_active) {
                      //   this.headings_menu = this.headings_menu.map(item => ({
                      //     ...item,
                      //     active: item.id === activeHeading,
                      //   }));
                      //   this.heading_active = activeHeading;

                      // }
                    },

                    setActiveItem(clickedId) {
                      this.headings_menu.forEach(item => {
                        item.active = (item.id === clickedId);
                      });
                      this.heading_active = clickedId; // Optionally update the heading_active property if used
                    },
                  };
                }
               1. <a :class="{ 'border-r-[3px] border-secondary': item.active, 'text-sm': item.level === 'h3' }" :href="'#' + item.id" class="inline-block text-balance hover:underline p-0.5 pr-3">  — </a>
  



 

### Jak do bylo doposud

Dlouhou dobu bylo zažitým standardem, že Heureka v XML podporovala dva typy názvů produktu. **PRODUCTNAME** znamenal (a stále znamená) **základní název** bez jakýchkoli příkras. Jedná se o **párovací element**. Jako příklad můžeme uvést fotoaparát s názem Canon *EOS 100D*. Druhý element **PRODUCT** obsahoval rozšířený název. Rozšíření mohlo být vícero typů. Bylo možné doplnit **dárek zdarma** (výsledek: *Canon EOS 100D + dárek zdarma*), **dopravu zdarma** (*Canon EOS 100D + doprava zdarma*), **libovolné příslušenství** (*Canon EOS 100D + objektiv zdarma*) nebo **všechno dohromady** (*Canon EOS 100D + dárek zdarma + doprava zdarma*).  
Toto byl dříve správný postup doporučovaný samotnou Heurekou.

### Nové elementy

Se zavedením nového elementu **&lt;GIFT&gt;**, o kterém jsme psali [v článku](https://www.mergado.cz/jak-si-nastavit-novy-tag-gift-v-exportu-pro-heureku) dříve, se informace o dárku přesunula sem. Informaci o dopravě Heureka nově vyžaduje uvádět pouze v elementu **&lt;DELIVERY&gt;**.

Doporučujeme tedy **odstranit z tagu PRODUCT veškeré benefity** a přesunout je do výše zmíněných elementů. Dnes si nám jeden klient postěžoval, že dostal od Heureky zprávu, ať z inzerce okamžitě odstraní fomulku „+ dárek zdarma“ nebo mu bude pozastavena inzerce. Taková razance v prosazování této novinky nás opravdu překvapila.

### PRODUCT vs. PRODUCTNAME

Jak tedy **správně nastavit** tyto dva elementy? PRODUCTNAME nastavte tak, aby název produktu **kopíroval název produktové karty** na Heurece, například *“Winix WAC U450*″. Rozšíření názvu (tedy element PRODUCT) je vhodné pojmout například takto: *“Čistička vzduchu Winix WAC U450”.* Benefitem takto disponovaného názvu je **vylepšení zobrazování** ve fulltextu.

### Současnost

Nová pravidla Heureky tedy kromě výše zmíněného využití další práci s PRODUCTem **značně omezují**. Dřívější pestré možnosti uvádění benefitů jsou osekány na absolutní minimum a směřovány do konkrétních elementů. Rozumíme Heurece v tom, že pro práci s uživatelskými daty je toto řešení mnohem přehlednější, nabízí se však teoretická úvaha, že by časem pro název produku mohl zůstat pouze jeden element. Nechme se překvapit.

![](/sites/default/files/users/snimek_obrazovky_porizeny_2016-02-26_152415.png)



 

- [  Elementy ](https://www.mergado.cz/tema/elementy)
- [  Heureka.cz ](https://www.mergado.cz/tema/heureka-cz)
- [  Mergado ](https://www.mergado.cz/tema/mergado)
- [  PRODUCT ](https://www.mergado.cz/tema/product)
- [  PRODUCTNAME ](https://www.mergado.cz/tema/productname)
 
 [    ![](https://www.mergado.cz/sites/default/files/perm/user-avatar/jakubvsaku.jpg)  ](https://www.mergado.cz/blog/jakub-nozicka)###  [ Jakub Nožička ](https://www.mergado.cz/blog/jakub-nozicka) 

Kuba vám odpovídal, když jste psali dotaz na Mergadovu českou podporu. Je autorem řady článků a návodů. To proto, že věděl, jaké trable jste řešili nejčastěji. Když zrovna nepracoval pro Mergado, hrál na basu s kapelou Ponk, se kterou získal hudební cenu Anděl.

 

 

 

 

 

 

 

 

 

## Mohlo by vás *zajímat*

 

 [    ![](https://www.mergado.cz/sites/default/files/perm/image/heureka_google_rec.jpg)  

### Heureka recenze do Google recenzí: nový postup krok za krokem

 

 ](https://www.mergado.cz/blog/heureka-recenze-do-google-recenzi) 

 [    ![](https://www.mergado.cz/sites/default/files/perm/image/shoptet-shopify-prevod.jpg)  

### Jak jsme s Mergadem převedli e‑shop ze Shoptetu na Shopify: kompletní migrace bez ztráty dat

 

 ](https://www.mergado.cz/blog/jak-jsme-s-mergadem-prevedli-e-shop-ze-shoptetu-na-shopify-kompletni-migrace-bez-ztraty-dat) 

 [    ![nastavení agenturních účtů](https://www.mergado.cz/sites/default/files/perm/image/new-nahladovka-na-blog-1200-x-628-px-37.png)  

### Jak nastavovat uživatelské účty agenturních pracovníků v Mergadu

 

 ](https://www.mergado.cz/blog/opravneni-uzivatelskych-uctu-pro-agentury) 

 

 

 

## Ať vám *nic neunikne*

 Přihlašte se do našeho newsletteru 

   

       

   Přihlášením souhlasíte, že vaše údaje zpracujeme v souladu s podmínkami o [ochraně osobních údajů](https://www.mergado.cz/prohlaseni-o-cookies). 

  Děkujeme, úspěšně jste se připojili k našemu seznamu odběratelů. 

 

 

 
      function ml_webform_success_5807248() {
        var r = ml_jQuery || jQuery
        r('.ml-subscribe-form-5807248 .row-success').show(), r('.ml-subscribe-form-5807248 .row-form').hide()
      }