Instrukcje dotyczące pracy z platformą
hotlist.biz/admin/
Jeśli ukryjesz menu autoryzacji na stronie, to aby wejść do administratora, wystarczy wpisać ścieżkę wskazaną powyżej w pasku adresu.
Przykład linku uwierzytelniającego użytkownika
Strony
Strona - blok znajdujący się w centrum serwisu, w obszarze treści, który może zawierać dowolne dane HTML (HTML, XHTML, JAVASCRIPT, CSS lub inne).
Ładowanie zawartości strony Ajax.
Ładowanie zawartości strony Ajax.
Link z klasą «ajax_load_page» otworzy zawartość Ajax wewnątrz bloku określonego w atrybucie «data-content-block».
Ścieżka do załadowanej strony jest określona w parametrze href.
Ścieżka strony może być względna lub w pełni kwalifikowana z http.
Możesz także użyć własnych skryptów, przekazując parametr GET lub POST «p» z nazwą
(lub pełnym adresem URL) strony w «/ajax.php»
Możliwe jest również korzystanie z bezpośrednich żądań bez użycia Ajax.
Na przykład, aby załadować dane do elementu iframe. Ścieżka jest taka sama jak w przypadku korzystania z Ajax.
Skrypt ładowania danych w wyskakującym okienku:
Skrypt wyskakujący ładujący Ajax
Aktualności
Newsy - ten sam blok co strony, ale posiadają krótki opis, który jest wyświetlany w formie listy, z linkiem umożliwiającym obejrzenie pełnego tekstu newsa.
Wiadomości dotyczące ładowania treści Ajax
Wiadomości dotyczące ładowania treści Ajax.
Link z klasą «ajax_load_news» otworzy zawartość Ajax wewnątrz bloku określonego w atrybucie «data-content-block».
Ścieżka do załadowanej strony jest określona w parametrze href.
Ścieżka strony może być względna lub w pełni kwalifikowana z http.
Możesz także użyć własnych skryptów, przekazując parametr GET lub POST «news_cat_p», z pełnym adresem
artykułu, na «/ajax.php»
Możliwe jest również korzystanie z bezpośrednich żądań bez użycia Ajax.
Na przykład, aby załadować dane do elementu iframe. Ścieżka jest taka sama jak w przypadku korzystania z Ajax.
Skrypt ładowania danych w wyskakującym okienku:
Skrypt wyskakujący ładujący Ajax
Katalog artykułów
Katalog artykułów to ten sam blok co aktualności, ale istnieje możliwość podziału list artykułów na kategorie.
Oprócz wyświetlania list artykułów w kategoriach możesz także generować własne listy.
Ajax ładuje treść artykułu
Ajax ładuje treść artykułu.
Link z klasą «ajax_load_blog» otworzy zawartość Ajax wewnątrz bloku określonego w atrybucie «data-content-block».
Ścieżka do załadowanej strony jest określona w parametrze href.
Ścieżka strony może być względna lub w pełni kwalifikowana z http.
Możesz także użyć własnych skryptów, przekazując parametr GET lub POST «blog_cat_p», z pełnym adresem
artykułu, na «/ajax.php»
Możliwe jest również korzystanie z bezpośrednich żądań bez użycia Ajax.
Na przykład, aby załadować dane do elementu iframe. Ścieżka jest taka sama jak w przypadku korzystania z Ajax.
Skrypt ładowania danych w oknie popup:
Ajax ładujący wyskakujący skrypt
Przykład skryptu Ajax do ładowania własnej listy artykułów
Przykład ładowania artykułu przez Ajax w formacie JSON
Blok/Menu
Blok/Menu to blok, w którym można wstawić dowolne kody HTML. Możesz także korzystać z menu z predefiniowanymi funkcjami, takimi jak koszyk, filtr wyszukiwania, bestsellery, najnowsze artykuły i nie tylko.
Block/Menu można wykorzystać do stworzenia własnego stylu/projektu strony internetowej. Na przykład możesz utworzyć nagłówek witryny, umieścić w nim niezbędne elementy (logo, kontakty, linki nawigacyjne witryny, formularz wyszukiwania itp.) i napisać CSS dla nich style w edytorze projektu. Za pomocą bloków/menu można umieszczać skrypty, w tym w metatagach, a także włączać/wyłączać wyświetlanie tych danych na określonych stronach lub urządzeniach. W większości przypadków wystarczy skorzystać z Nagłówka/Nagłówka i Stopki/Dółu strony, a także np. lewego lub prawego Bloku/Menu, aby umieścić filtr wyszukiwania. Możesz umieścić skrypty witryny w jednym Bloku/Menu i umieścić je np. w Service tags.
Blok menu można umieścić w 7 głównych częściach serwisu:
- "Nagłówek witryny (Header)" - blok nagłówka witryny, wyświetlany nad głównym blokiem treści, wewnątrz elementu "#hotengine-header".
- "Dół serwisu (stopka)" - blok dolnej części serwisu, wyświetlany pod głównym blokiem z treścią, wewnątrz elementu "#hotengine-footer".
- "Prawo" - blok jest wyświetlany po prawej stronie obok głównego bloku z treścią i nie wykracza poza treść.
- "Lewy" - blok wyświetlany jest po lewej stronie obok głównego bloku z treścią i nie wykracza poza treść.
- «Góra» - blok jest wyświetlany u góry treści i nie wykracza poza jego obszar.
- «Dół» - blok jest wyświetlany na dole treści i nie wykracza poza jego obszar.
- "Tagi usługi przed tagiem Body (Meta nagłówka)" - blok znajduje się pod metatagami usługi i może być używany do wstawiania JavaScript, metatagów i innych danych usługi.
Wszystkie menu będą miały dodaną klasę elementu, a także unikalny ID menu_id. Podstawowe znaczniki blokowania witryn ↓
Aby utworzyć rozszerzoną wersję mobilnego menu (w stylu aplikacji), użyj «Mobile Menu Builder». Konstruktor umożliwia utworzenie wielopoziomowego menu, wyskakującego okienka «Filtr wyszukiwania», a także własnych ikon.
Sklep
Sklep może zawierać uporządkowaną listę produktów wraz z przyciskami służącymi do ich zamawiania. Sklep dostarcza dużo dodatkowych danych, podział według producentów, kategorie, typy produktów, cechy i inne właściwości.
Pamiętaj, że Twoje produkty będą dodatkowo umieszczane w naszym międzynarodowym katalogu, a kupujący będą mogli zostawić opinię na temat jakości Twojej pracy.
Listy kategorii mogą być wyświetlane na stronach lub blokach/menu. W tym celu utwórz stronę lub Blok/Menu, a w tekście umieść kod Widżet z kategoriami sklepu
Ładowanie produktu Ajax
Ładowanie produktu Ajax.
Link z klasą «ajax_load_shop» otworzy zawartość Ajax wewnątrz bloku określonego w atrybucie «data-content-block».
Ścieżka do załadowanej strony jest określona w parametrze href.
Ścieżka strony może być względna lub w pełni kwalifikowana z http.
Możesz także użyć własnych skryptów przekazując parametr GET lub POST "shop_cat_p", z pełnym adresem
produktu, pod adresem "/ajax.php"
Możliwe jest również korzystanie z bezpośrednich żądań bez użycia Ajax.
Na przykład, aby załadować dane do elementu iframe. Ścieżka jest taka sama jak w przypadku korzystania z Ajax.
Skrypty dodawania towarów do koszyka muszą być dodatkowo załadowane, jeśli korzystasz z iframe.
Skrypt ładowania danych w oknie popup:
Ajax ładujący wyskakujący skrypt
Ajax ładuje recenzje produktów
Ajax ładuje recenzje produktów.
Link z klasą «ajax_load_shop_comments» otworzy zawartość Ajax wewnątrz bloku określonego w atrybucie «data-content-block».
Ścieżka do załadowanej strony jest określona w parametrze href.
Do recenzji używane są trzy parametry:
"hotengine_shop_comments_shop_cat_page_id" - ID produktu.
"nc" - numer strony komentarza.
"snc_on_page" - liczba komentarzy na stronie (od 1 do 50).
Ścieżka strony może być względna lub w pełni kwalifikowana z http. Ścieżka musi być albo ścieżką do produktu, albo możesz od razu podać ID produktu, którego recenzje chcesz pobrać.
Możesz także użyć własnych skryptów, przekazując parametr GET lub POST «hotengine_shop_comments_shop_cat_page_id», z pełnym adresem
produktu (lub identyfikatorem produktu), w «/ajax.php». "nc" - numer strony, "snc_on_page" - liczba komentarzy na stronie. Dodatkowo możesz filtrować komentarze według oceny, przekazując zmienną „starrating_quality”, na przykład starrating_quality=5.
Możliwe jest również korzystanie z bezpośrednich żądań bez użycia Ajax.
Na przykład, aby załadować dane do elementu iframe. Ścieżka jest taka sama jak w przypadku korzystania z Ajax.
Skrypty dodawania towarów do koszyka muszą być dodatkowo załadowane, jeśli korzystasz z iframe.
Skrypt ładowania danych w oknie popup:
Ajax ładujący wyskakujący skrypt
Aby uzyskać dane w formacie JSON, wystarczy dodać zmienną GET/POST „json”.
Przykład skryptu Ajax do ładowania listy towarów + "Generator listy towarów"
Wózek ładujący Ajax
Wózek ładujący Ajax.
Link z klasą «ajax_load_cart» otworzy zawartość Ajax wewnątrz bloku określonego w atrybucie «data-content-block».
Aby załadować koszyk, przejdź na stronę «/ajax.php?cart&load_cart_ajax»
Przykład skryptu Ajax do ładowania wózka po najechaniu myszką
Ajax ładuje listę obrazów kart produktów
Lista ładowania Ajax wszystkich kategorii w formacie JSON
Ajax ładuje listę wszystkich kategorii w formacie JSON.
Aby uzyskać listę wszystkich kategorii sklepów, po prostu uruchom zapytanie pod adresem /ajax.php?json&shop_categories&start=0¶m=:productsGdzie
- &start= - ID kategorii, od której ma się rozpocząć wyświetlanie.
- ¶m= parametry jakie można uzyskać w Widżecie z kategoriami (parametr opcjonalny)
- Żądanie działa tylko na przykład z Twoją domeną http://example.com/ajax.php?json&shop_categories&start=0
Przykład wyniku: {"id":"ID kategorii","parentID":"ID kategorii nadrzędnej","child_cat":"Liczba zagnieżdżonych kategorii","child_items":"Liczba produktów w kategorii","image":"Ścieżka obrazu kategorii","title":"Nazwa kategorii"},
Ajax ładuje produkt w formacie JSON
Ajax ładuje produkt w formacie JSON.
Aby otrzymać dane karty produktu w formacie JSON, wystarczy złożyć wniosek pod wskazany adres /ajax.php?json&shop_products&id=0Podczas rozładunku towaru możesz określić opcje sortowania i filtrowania według następujących parametrów:
- id - identyfikator karty produktu (jedna lub więcej wartości oddzielonych przecinkami).
- pers_shop_cat_page_catid - identyfikator kategorii sklepu (jedna lub więcej wartości oddzielonych przecinkami)
- producer - producent (jedna lub więcej wartości oddzielonych przecinkami)
- collection - kolekcja (jedna lub więcej wartości oddzielonych przecinkami)
- sort_by - sortowanie
- order_by - sortowanie
- sort_instock_priority - priorytet sortowania
- price_from - cena od
- price_to — cena do
- stock - dostępność
Żądanie działa tylko na przykład z Twoją domeną http://example.com/ajax.php?json&shop_products&id=0
Ładowanie formularza Ajax (formularze wyskakujące)
Jak utworzyć formularz opinii?
Istnieją 3 sposoby tworzenia formularza.
- 1) Najbardziej elastycznym sposobem jest otwarcie kreatora formularzy i utworzenie formularza z wymaganymi polami. Wszystkie instrukcje są dostępne w konstruktorze formularza.
- 2)Utwórz funkcjonalną stronę (informacje zwrotne), która po otwarciu wyświetli standardowy formularz opinii.
- 3)Użyj wyskakującego formularza zwrotnego utworzonego za pomocą następującego kodu:
Code: html <a class="hotengine-dialog-email" data-site="XXXX" href="javascript://">Napisz do nas</a>
class="hotengine-dialog-email" - oznacza, że przycisk służy do wyskakującego formularza opinii, a rel="XXXX" to ID witryny.
XXXX zastąp identyfikatorem swojej witryny, który możesz znaleźć po najechaniu kursorem na przycisk PANEL ADMINISTRACYJNY.
Możesz także określić nazwę wyskakującego okienka oraz treść przycisku «Zamknij». W tym celu dodaj data-close-button="Zamknij" i data-title="Feedback" do linku z klasą e-mail.
Szerokość i wysokość okna można ustawić za pomocą data-width="600" i data-height="640".
Tekst przycisków w formularzu można ustawić za pomocą atrybutów data-send-button="Submit" i data-clear-button="Clear"
Możesz zmienić nazwy pól wejściowych za pomocą stylów CSS (tekst jest wprowadzany w formie treści, w css nie ma poklas after).
Przykład ↓
/*FORM TEXT TITTLES*/
html:lang(ru) .hotengine-form-feedback-text-title:after{ content:"Текст:"; }
html:lang(en) .hotengine-form-feedback-text-title:after{ content:"Text:"; }
html:lang(uk) .hotengine-form-feedback-text-title:after{ content:"Текст:"; }
html:lang(de) .hotengine-form-feedback-text-title:after{ content:"Text:"; }
html:lang(es) .hotengine-form-feedback-text-title:after{ content:"Texto:"; }
html:lang(fr) .hotengine-form-feedback-text-title:after{ content:"Texte:"; }
html:lang(kk) .hotengine-form-feedback-text-title:after{ content:"Мәтін:"; }
html:lang(be) .hotengine-form-feedback-text-title:after{ content:"Тэкст:"; }
html:lang(ro) .hotengine-form-feedback-text-title:after{ content:"Text:"; }
html:lang(tr) .hotengine-form-feedback-text-title:after{ content:"Metin:"; }
html:lang(it) .hotengine-form-feedback-text-title:after{ content:"Testo:"; }
html:lang(sk) .hotengine-form-feedback-text-title:after{ content:"Text:"; }
html:lang(da) .hotengine-form-feedback-text-title:after{ content:"Tekst:"; }
html:lang(pl) .hotengine-form-feedback-text-title:after{ content:"Tekst:"; }
html:lang(zh) .hotengine-form-feedback-text-title:after{ content:"文本:"; }
html:lang(hi) .hotengine-form-feedback-text-title:after{ content:"पाठ:"; }
html:lang(ar) .hotengine-form-feedback-text-title:after{ content:"النص:"; }
html:lang(pt) .hotengine-form-feedback-text-title:after{ content:"Texto:"; }
html:lang(bn) .hotengine-form-feedback-text-title:after{ content:"টেক্সট:"; }
html:lang(ru) .hotengine-form-feedback-yourname-title:after{ content:"Ваше имя:"; }
html:lang(en) .hotengine-form-feedback-yourname-title:after{ content:"Your name:"; }
html:lang(uk) .hotengine-form-feedback-yourname-title:after{ content:"Ваше ім'я:"; }
html:lang(de) .hotengine-form-feedback-yourname-title:after{ content:"Ihr name:"; }
html:lang(es) .hotengine-form-feedback-yourname-title:after{ content:"Su nombre:"; }
html:lang(fr) .hotengine-form-feedback-yourname-title:after{ content:"Votre nom:"; }
html:lang(kk) .hotengine-form-feedback-yourname-title:after{ content:"Сіздің атыңыз:"; }
html:lang(be) .hotengine-form-feedback-yourname-title:after{ content:"Ваша імя:"; }
html:lang(ro) .hotengine-form-feedback-yourname-title:after{ content:"Numele dvs.:"; }
html:lang(tr) .hotengine-form-feedback-yourname-title:after{ content:"Adınız:"; }
html:lang(it) .hotengine-form-feedback-yourname-title:after{ content:"Il tuo nome:"; }
html:lang(sk) .hotengine-form-feedback-yourname-title:after{ content:"Vaše meno:"; }
html:lang(da) .hotengine-form-feedback-yourname-title:after{ content:"Dit navn:"; }
html:lang(pl) .hotengine-form-feedback-yourname-title:after{ content:"Twoje imię:"; }
html:lang(zh) .hotengine-form-feedback-yourname-title:after{ content:"你的名称:"; }
html:lang(hi) .hotengine-form-feedback-yourname-title:after{ content:"आपका नाम:"; }
html:lang(ar) .hotengine-form-feedback-yourname-title:after{ content:"اسمك:"; }
html:lang(pt) .hotengine-form-feedback-yourname-title:after{ content:"Seu nome:"; }
html:lang(bn) .hotengine-form-feedback-yourname-title:after{ content:"আপনার নাম:"; }
html:lang(ru) .hotengine-form-feedback-yoursoname-title:after{ content:"Ваша фамилия:"; }
html:lang(en) .hotengine-form-feedback-yoursoname-title:after{ content:"Your name:"; }
html:lang(uk) .hotengine-form-feedback-yoursoname-title:after{ content:"Ваше прізвище:"; }
html:lang(de) .hotengine-form-feedback-yoursoname-title:after{ content:"Ihr name:"; }
html:lang(es) .hotengine-form-feedback-yoursoname-title:after{ content:"Su nombre:"; }
html:lang(fr) .hotengine-form-feedback-yoursoname-title:after{ content:"Votre nom:"; }
html:lang(kk) .hotengine-form-feedback-yoursoname-title:after{ content:"Сіздің аты-жөні:"; }
html:lang(be) .hotengine-form-feedback-yoursoname-title:after{ content:"Ваша прозвішча:"; }
html:lang(ro) .hotengine-form-feedback-yoursoname-title:after{ content:"Numele dumneavoastră:"; }
html:lang(tr) .hotengine-form-feedback-yoursoname-title:after{ content:"Adınız:"; }
html:lang(it) .hotengine-form-feedback-yoursoname-title:after{ content:"Il tuo nome:"; }
html:lang(sk) .hotengine-form-feedback-yoursoname-title:after{ content:"Vaše meno:"; }
html:lang(da) .hotengine-form-feedback-yoursoname-title:after{ content:"Dit navn:"; }
html:lang(pl) .hotengine-form-feedback-yoursoname-title:after{ content:"Imię i nazwisko:"; }
html:lang(zh) .hotengine-form-feedback-yoursoname-title:after{ content:"你的名称:"; }
html:lang(hi) .hotengine-form-feedback-yoursoname-title:after{ content:"आपका नाम:"; }
html:lang(ar) .hotengine-form-feedback-yoursoname-title:after{ content:"اسمك:"; }
html:lang(pt) .hotengine-form-feedback-yoursoname-title:after{ content:"O seu apelido:"; }
html:lang(bn) .hotengine-form-feedback-yoursoname-title:after{ content:"আপনার নাম:"; }html:lang(ru) .hotengine-form-feedback-yourphone-title:after{ content:"Ваш телефон:"; }
html:lang(en) .hotengine-form-feedback-yourphone-title:after{ content:"Your phone:"; }
html:lang(uk) .hotengine-form-feedback-yourphone-title:after{ content:"Ваш мобільний телефон:"; }
html:lang(de) .hotengine-form-feedback-yourphone-title:after{ content:"Ihr Telefon:"; }
html:lang(es) .hotengine-form-feedback-yourphone-title:after{ content:"Su teléfono:"; }
html:lang(fr) .hotengine-form-feedback-yourphone-title:after{ content:"Votre téléphone:"; }
html:lang(kk) .hotengine-form-feedback-yourphone-title:after{ content:"Телефон:"; }
html:lang(be) .hotengine-form-feedback-yourphone-title:after{ content:"Ваш тэлефон:"; }
html:lang(ro) .hotengine-form-feedback-yourphone-title:after{ content:"Telefonul dvs.:"; }
html:lang(tr) .hotengine-form-feedback-yourphone-title:after{ content:"Telefon:"; }
html:lang(it) .hotengine-form-feedback-yourphone-title:after{ content:"Il telefono:"; }
html:lang(sk) .hotengine-form-feedback-yourphone-title:after{ content:"Váš telefón:"; }
html:lang(da) .hotengine-form-feedback-yourphone-title:after{ content:"Din telefon:"; }
html:lang(pl) .hotengine-form-feedback-yourphone-title:after{ content:"Telefon:"; }
html:lang(zh) .hotengine-form-feedback-yourphone-title:after{ content:"你的电话:"; }
html:lang(hi) .hotengine-form-feedback-yourphone-title:after{ content:"अपने फोन:"; }
html:lang(ar) .hotengine-form-feedback-yourphone-title:after{ content:"الهاتف:"; }
html:lang(pt) .hotengine-form-feedback-yourphone-title:after{ content:"Seu telefone:"; }
html:lang(bn) .hotengine-form-feedback-yourphone-title:after{ content:"আপনার ফোন:"; }
html:lang(ru) .hotengine-form-feedback-youremail-title:after{ content:"Ваш e-mail:"; }
html:lang(en) .hotengine-form-feedback-youremail-title:after{ content:"Your e-mail:"; }
html:lang(uk) .hotengine-form-feedback-youremail-title:after{ content:"Ваш e-mail:"; }
html:lang(de) .hotengine-form-feedback-youremail-title:after{ content:"Ihre e-mail:"; }
html:lang(es) .hotengine-form-feedback-youremail-title:after{ content:"Su e-mail:"; }
html:lang(fr) .hotengine-form-feedback-youremail-title:after{ content:"Votre e-mail:"; }
html:lang(kk) .hotengine-form-feedback-youremail-title:after{ content:"Сіздің e-mail:"; }
html:lang(be) .hotengine-form-feedback-youremail-title:after{ content:"Ваш e-mail:"; }
html:lang(ro) .hotengine-form-feedback-youremail-title:after{ content:"Adresa de e-mail:"; }
html:lang(tr) .hotengine-form-feedback-youremail-title:after{ content:"E-mail:"; }
html:lang(it) .hotengine-form-feedback-youremail-title:after{ content:"Il tuo indirizzo e-mail:"; }
html:lang(sk) .hotengine-form-feedback-youremail-title:after{ content:"E-mail:"; }
html:lang(da) .hotengine-form-feedback-youremail-title:after{ content:"Din e-mail:"; }
html:lang(pl) .hotengine-form-feedback-youremail-title:after{ content:"Twój e-mail:"; }
html:lang(zh) .hotengine-form-feedback-youremail-title:after{ content:"你的电子邮件:"; }
html:lang(hi) .hotengine-form-feedback-youremail-title:after{ content:"अपने ई-मेल:"; }
html:lang(ar) .hotengine-form-feedback-youremail-title:after{ content:"البريد الإلكتروني:"; }
html:lang(pt) .hotengine-form-feedback-youremail-title:after{ content:"Seu e-mail:"; }
html:lang(bn) .hotengine-form-feedback-youremail-title:after{ content:"আপনার ই-মেইল:"; }html:lang(ru) .hotengine-form-feedback-youraddress-title:after{ content:"Ваш адрес:"; }
html:lang(en) .hotengine-form-feedback-youraddress-title:after{ content:"Your address:"; }
html:lang(uk) .hotengine-form-feedback-youraddress-title:after{ content:"Ваша адреса:"; }
html:lang(de) .hotengine-form-feedback-youraddress-title:after{ content:"Ihre Adresse:"; }
html:lang(es) .hotengine-form-feedback-youraddress-title:after{ content:"Su dirección:"; }
html:lang(fr) .hotengine-form-feedback-youraddress-title:after{ content:"Votre adresse:"; }
html:lang(kk) .hotengine-form-feedback-youraddress-title:after{ content:"Сіздің мекен-жайы:"; }
html:lang(be) .hotengine-form-feedback-youraddress-title:after{ content:"Ваш адрас:"; }
html:lang(ro) .hotengine-form-feedback-youraddress-title:after{ content:"Adresa:"; }
html:lang(tr) .hotengine-form-feedback-youraddress-title:after{ content:"Adresi:"; }
html:lang(it) .hotengine-form-feedback-youraddress-title:after{ content:"Indirizzo:"; }
html:lang(sk) .hotengine-form-feedback-youraddress-title:after{ content:"Adresa:"; }
html:lang(da) .hotengine-form-feedback-youraddress-title:after{ content:"Din adresse:"; }
html:lang(pl) .hotengine-form-feedback-youraddress-title:after{ content:"Adres:"; }
html:lang(zh) .hotengine-form-feedback-youraddress-title:after{ content:"你的地址:"; }
html:lang(hi) .hotengine-form-feedback-youraddress-title:after{ content:"आपके पते की:"; }
html:lang(ar) .hotengine-form-feedback-youraddress-title:after{ content:"العنوان الخاص بك:"; }
html:lang(pt) .hotengine-form-feedback-youraddress-title:after{ content:"O seu endereço:"; }
html:lang(bn) .hotengine-form-feedback-youraddress-title:after{ content:"আপনার ঠিকানা:"; }/*FORM TEXT TITTLES*/
Uwaga! Witryna zapewnia możliwość tworzenia własnych formularzy w trybie automatycznym, a także wykorzystania wyskakujących okienek do wysyłania niezbędnych danych od odwiedzającego. Aby to zrobić, użyj projektant form.
Ajax ładuje komentarze
Ajax загрузка комментариев.
Element z klasą „ajax_load_comments” otworzy zawartość Ajax wewnątrz bloku określonego w atrybucie „data-content-block”.
Identyfikator załadowanej strony jest określony w parametrze data-page-id. Dodatkowo możesz filtrować komentarze według oceny, przekazując zmienną „starrating_quality”, na przykład starrating_quality=5.
Do komentarzy używane są 4 parametry:
- hotengine_comments_hotengine_page_id — identyfikator strony.
- nc - numer strony komentarzy.
- snc_on_page" - liczba komentarzy na stronę (od 1 do 50).
- hotengine_comments_page_type — typ strony.
Dostępne typy stron (wymagane):
- strona - strony
- shop_category - kategorie sklepów
- shop_collection – kolekcje sklepów
- shop_producer - producenci
- blog_category - kategoria katalogu artykułów
- strona_blogu - artykuł
- news_page - aktualności
Możesz użyć własnych skryptów, przekazując parametry GET lub POST „hotengine_comments_hotengine_page_id” i „hotengine_comments_page_type” do „/ajax.php”. "nc" - numer strony, "snc_on_page" - liczba komentarzy na stronie.
Aby uzyskać dane w formacie JSON, wystarczy dodać zmienną GET/POST „json”.
Ajax загрузка отзывов к товарам
Jak korzystać z wielu lądowań?
Na platformie HotList.biz możesz skonfigurować strony Multilanding, aby w przypadku dopasowania żądania (częściowego lub pełnego) zmieniała się zawartość całych bloków na stronie (na stronach, w produktach iw menu). Zapytaniem mogą być dane zapytania wyszukiwania (ustalane automatycznie) jak również własne ustawione zmienne GET. Np. dodając tagi UTM w reklamach możesz użyć tagu "utm_term", dzięki czemu strona Multilanding będzie aktywna dla zmiennej GET "utm_term". Dane źródła skierowań są przechowywane maksymalnie przez 24 godziny. Jednocześnie dane dotyczące źródła skierowania do programu partnerskiego są przechowywane przez 120 dni.
Aby potwierdzić witrynę w centrum webmasterów (na przykład Google lub Yandex), musisz dodać tag <meta> kod.
Aby to zrobić, utwórz blok/menu, wstaw wymagany metakod i umieść go w znacznikach usług. Następnie Twoja witryna zostanie zweryfikowana.
W ten sam sposób możesz stworzyć własny nagłówek i dół strony. Do menu można wstawić prawie dowolny kod HTML.
* - nagłówek «Producent» można zastąpić słowem, którego potrzebujesz.
Zalecamy wywołanie nadrzędnej (pierwszej) rubryki «Sklep» (Store).
Przykład tworzenia kategorii sklepu:
Na początek zalecamy utworzenie kategorii głównej, w której utworzysz podkategorie.
Otwórz Edytor kategorii Sklepu w Centrum administracyjnym i kliknij «Dodaj kategorię».
Wybierz swoją witrynę i kliknij OK.
Następnie wprowadź nazwę (będzie to adres Twojej kategorii). Na przykład dla kategorii głównej utwórzmy grupę «Sklep» o nazwie «store».
Gotowe.
Podobnie możesz zarządzać kategoriami Producenci (dodatkowe kategorie).
** - Dodatkowo, jeśli chcesz otworzyć listę produktów określonej kategorii i określonego producenta, wystarczy dodać zmienną GET PRODUCER. Wystarczy podać w zmiennej ID producenta lub jego nazwę. Przykład: "/pers_shop/water/?producer=bonaqua" W tym przypadku zostanie wyświetlona lista produktów pod nagłówkiem "water", których producentem jest "bonaqua".
Wyszukiwanie odbywa się po przesłaniu formularza ze zmienną «szukaj». Typ danych do wyszukania ustalany jest za pomocą ścieżki (strony), do której przesyłany jest formularz. Aby wyszukać w "Katalogu towarów" należy dokonać wysyłki na stronie "/sklep/".
Jak dodać formularz wyszukiwania do nagłówka strony?
W Bloku/Menu znajdującym się w nagłówku strony możesz dodać następujący kod:
Code: html |
<div align="center" id="hotengine-search_form_block" itemscope itemtype="https://schema.org/WebSite"> <link itemprop="url" href="//{HOTENGINE-SC:site_url}/"/> <form id="hotengine-search-searchinput" name="hotengine-search-searchinput" method="post" action="/pl/shop/" itemprop="potentialAction" itemscope itemtype="https://schema.org/SearchAction"> <meta itemprop="target" content="//{HOTENGINE-SC:site_url}/pl/shop/?search={search}"/> <label> <input class="input" name="search" type="text" placeholder="Szukaj..." id="hotengine-smart_search_input" value="" itemprop="query-input"> </label> <label> <button type="submit" class="search-button">Odnaleźć</button> "> </label></form> </div> |
Kod natychmiast zawiera Micromarkup dla Google. W drodze do wysłania formularza (//{HOTENGINE-SC:site_url}/pl/shop/?search={search}) określony pl język, możesz go zmienić.
Przykład:
CSS blokowy, zastępując przycisk wysyłania obrazem:
Code: css |
#hotengine-search_form_block{ position: relative; width:300px; float: right; z-index:2; height: 41px; margin:33px 0px 33px 10px; } #hotengine-search_form_block input{ height: 20px; vertical-align: middle; border: 1px solid #e5e5e5; padding: 0.15em; width: 20.0em; color:#9c9b9b; height: 20px; background: #fff; padding: 0 13px; height: 41px; } #hotengine-search_form_block input[type="text"]{ text-indent:4px;height: 39px; } #hotengine-search_form_block .search-button{ background:#41474c; border-radius:0px; vertical-align:middle; display:block; position:absolute; top:0px; right:0px; border:none; color:#fff; width:41px; height:41px; text-align:center; font-size:12px; line-height:25px; cursor:pointer; overflow:hidden; } #hotengine-search_form_block .search-button:after{ content:""; width:41px; height:41px; display:block; position: absolute; right:0px; top:0px; background:none; background-color:#d6d6d6; -webkit-mask:url("") center center no-repeat; -webkit-mask-size:20px; } #hotengine-search_form_block .search-button:hover:after{ background-color:#fff; } #hotengine-search_form_block .search-button:active:after{ top:1px; } |
Wydanie wyniku wyszukiwania w formacie JSON / wskazówki wyszukiwania / rozwijana lista produktów.
Aby uzyskać dane JSON z nazwą produktu, ceną, obrazem i linkiem, możesz wykonać żądanie AJAX do pliku "/ajax.php?search_shop"
W zmiennej GET/POST "szukaj" należy podać część nazwy lub ID produktu. Żądanie można wykonać tylko w przypadku płatnego hostingu z zaparkowaną domeną. Dane mogą być wykorzystane do realizacji wydawania podpowiedzi w formularzu wyszukiwania.
Podpowiedzi możesz włączyć w "Ustawieniach", w zakładce "Szukaj" - "Włącz podpowiedzi przy wpisywaniu zapytania".
Przykład sugestii wyszukiwania ↓
Możesz włączyć tę podpowiedź podczas wyszukiwania w ustawieniach, w zakładce «Szukaj», «Ustawienia wyświetlania formularza wyszukiwania».
Utwórz «Typ produktu» – «Trampki».
"Charakterystyka" - określ kilka pól, "Wielokrotnego wyboru (pole wyboru)" z nazwami: "Kolor", "Miejsce docelowe", "Producent".
Po zapisaniu nazw pól, po prawej stronie będziesz mógł wypełnić możliwe opcje.
Twórz wartości.
Kolor: biały, czerwony, zielony.
Przeznaczenie: bieganie, koszykówka, piłka nożna.
Producent: Adidas, Asics, Nike
Teraz w karcie produktu w zakładce "Parametry, cena i odmiana" określ "Typ produktu" i podaj odpowiednie wartości.
Jeśli potrzebujesz utworzyć filtr wyszukiwania, to w sekcji «Moje bloki/menu» utwórz «Menu funkcyjne» - «Wyszukiwanie z filtrem według typów produktów».
Ten blok będzie wyświetlany wszędzie tam, gdzie włączysz wyświetlanie.
Aby wymagany typ produktu został automatycznie otwarty w określonej kategorii, w tekście «Blok funkcjonalny / menu» należy podać ID odpowiedniego typu produktu, a także dodać tekst «autopath» , aby podczas wyszukiwania odbywało się ono na tej samej stronie i nie przechodziło do ogólnego wyszukiwania witryny.
Na przykład, jeśli ID wcześniej utworzonego typu produktu wynosił 1123, tekst bloku/menu brzmiałby «1123autopath».
Teraz określ ścieżkę, gdzie ma być wyświetlany blok/menu za pomocą filtra wyszukiwania
"Wprowadź znaki, aby wyświetlić blok/menu po znalezieniu:"
/category_name/
Gdzie category_name – nazwę kategorii, ścieżkę, wzdłuż której się znajduje.
Aby ukryć filtr wyszukiwania podczas przeglądania karty produktu, w pozycji «Wprowadź znaki, po wykryciu których nie wyświetla się Blok / Menu:» wpisz
.htm
Aby ukryć pole wyszukiwania nad Typem produktu, w Edytorze wzornika w stylach CSS, dodaj «.menu_position_left .hotengine-smart_search_input_label { display: none;}»
Aby ukryć pole wyszukiwania wyboru Typu produktu, w Edytorze wzornika w stylach CSS, dodaj «.menu_position_left .shop_catalog_product_types_id_label { display: none;}»
.menu_position_left - oznacza, że ukrywamy pola w lewym bloku strony.
Aby wyświetlić liczbę produktów z podanym parametrem, można użyć parametru «count» przy tworzeniu Funkcjonalnego Bloku/Menu z filtrem wyszukiwania.
Aby ukryć nieznalezione cechy - «hideempty» (szczegóły są opisane na stronie tworzenia Funkcjonalnego Bloku/Menu).
Aby wyświetlić wybrane przez użytkownika wartości filtra wyszukiwania w górnej części strony, można użyć parametru «checkedlist». Tę funkcję można również aktywować w sekcji «Menu mobilne: Aplikacja» na karcie «Filtr wyszukiwania». Ułatwia ona użytkownikowi dostęp do wybranych wartości wyszukiwania, co jest szczególnie wygodne podczas przeglądania strony na urządzeniach mobilnych lub ekranach o niższej rozdzielczości. Funkcję wystarczy włączyć tylko raz — albo za pomocą parametru «checkedlist» w sekcji «Moje Bloki/Menu» - «Filtr wyszukiwania», albo w sekcji «Menu mobilne: Aplikacja» na karcie «Filtr wyszukiwania».
Np. po dodaniu produktu do koszyka funkcja jest wywoływana callback_hotengine_cart_plus_after, jeśli istnieje
Code: JavaScript |
if(typeof(callback_hotengine_cart_plus_after) === "function"){ callback_hotengine_cart_plus_after(); } |
Aby uruchomić własny skrypt funkcji callback_hotengine_cart_plus_after, musisz go utworzyć.
Code: JavaScript |
function callback_hotengine_cart_plus_after(){ // twój scenariusz } |
Lista niektórych dostarczonych funkcji `Callback`:
callback_hotengine_ajax_load_products_list - po załadowaniu listy produktów (uniwersalna funkcja w każdym przypadku ładowania listy produktów przez skrypt)
callback_hotengine_ajax_load_products - po załadowaniu listy produktów, po naciśnięciu przycisku "Pokaż więcej".
callback_hotengine_shop_products_list_div_button - po przewinięciu listy produktów w slajdzie
callback_hotengine_shop_page_boughtwith_loaded($id) - po załadowaniu listy, "z towarem kupują" ($id-ID załadowanych towarów)
Sklep / Opis automatyczny
callback_hotengine_shop_autodescription($type) - po wyświetleniu opisu automatycznego ($type - html,ajax)
callback_hotengine_shop_autodescription_readmore($id,$job) - po załadowaniu rozwiniętego tekstu opisu automatycznego ($job - show,hide,load)
Sklep / Koszyk
callback_hotengine_cart_plus - po wysłaniu żądania dodania towaru do koszyka
callback_hotengine_cart_addresult($result,$item_id) - po dodaniu towaru do koszyka, różne warianty wyniku ($result-wartość wyniku. Wartości: "added" - dodany, "removed" - usunięty, "instock_smaller" - pozostałość mniejsza niż dodawana, "instock_smaller_exists" - pozostałość mniejsza niż już dodana do koszyka)
callback_hotengine_cart_plus_after($items_in_cart) - po dodaniu towaru do koszyka ($items_in_cart - liczba towarów w koszyku po wykonaniu)
callback_hotengine_cart_plus_after_boughtwith($ids) - po dodaniu towaru do koszyka przesyła listę "Z towarem kupują" w zmiennej $ids
callback_hotengine_cart_plus_after_boughtwith_email($ids) - po dodaniu towaru do koszyka przesyła "Listę do wysyłki" w zmiennej $ids (E-mail do wysyłki innych towarów)
callback_hotengine_cart_count_product_num - po wyborze produktu do zmiany jego ilości w koszyku
Sklep / Wariant
callback_hotengine_shop_product_variaty_select - po wyborze wariantu
callback_hotengine_variety_change_price($price) - po wyborze wariantu i zmianie ceny ($price - nowa cena)
callback_hotengine_variety_change_sku($sku) - po wyborze wariantu i zmianie kodu towaru ($sku - nowy sku)
callback_hotengine_variety_change_skuimage($img) - po wyborze wariantu, jeśli podano nowe zdjęcie ($img - nowa ścieżka do zdjęcia)
callback_hotengine_variety_change_stock_count($stock) - po wyborze wariantu i zmianie ilości w magazynie ($stock - nowa ilość w magazynie). Ta funkcja nie jest inicjowana, jeśli nie została stworzona, ponieważ nie zawsze konieczne jest zmienianie ilości towaru w magazynie.
callback_hotengine_variety_require() - jeśli nie wybrano wariantu, przed wywołaniem okna dialogowego wiadomość
callback_hotengine_variety_require_list($href) - jeśli nie wybrano wariantu, przed wywołaniem okna dialogowego z wiadomością, przy przeglądaniu listy towarów ($href - link do przeglądania karty towaru)
Sklep / Ulubione / Porównaj
callback_hotengine_favorite_addresult($result,$count_favorite) - po dodaniu towaru do ulubionych, różne warianty wyniku ($result-wartość wyniku. Wartości: "added" - dodany, "removed" - usunięty; $count_favorite - liczba towarów w ulubionych)
callback_hotengine_compare_plus() - po dodaniu towaru do listy porównawczej
Sklep / Wyszukiwanie
callback_hotengine_shop_catalog_product_types - po wyborze typu produktu w filtrze wyszukiwania
Sklep / Stan
callback_hotengine_shop_product_stock_inform- po wywołaniu okna "Poinformuj o dostępności"
callback_hotengine_shop_product_stock_inform_send - po wysłaniu żądania "Poinformuj o dostępności"
Sklep / Dostawa
callback_hotengine_loading_delivery_type - po wyborze sposobu dostawy
callback_hotengine_loading_delivery_type_finalvalues - po wyborze sposobu dostawy wartości końcowe
Użytkownik
callback_hotengine_authorize_result($result) - funkcja po autoryzacji użytkownika ($result - rezultat wykonania: 2-błąd logowania lub hasła, 3-konto zablokowane, 4-konieczna aktywacja,5-Aktywacja powiodła się,6-Niepoprawny kod Captcha)
Sklep / Statystyki sprzedaży
callback_hotengine_statisticsell_printorder($a) - po wywołaniu okna wydruku zamówienia. $a=1 - przed wyświetleniem okna. $a=2 - po wyświetleniu okna.
Blog
callback_hotengine_blog_page_list_div_button - po przewinięciu listy artykułów w slajdzie
Dialog
callback_hotengine_dialog_email- po wywołaniu okna dla informacji zwrotnej
callback_hotengine_form_submit_result($a) - po wysłaniu formularza przez okno dialogowe. $a=0 - błąd. $a=1 - ok.
Mobilny
callback_hotengine_mobilemenu_click($a,$href) - naciśnięcie na linki w mobilnym menu. $a=0 - linki punktów i górne ikony. $a=1 - linki podkategorii. $a=2 - po wyświetleniu okna ajax z treścią.
callback_hotengine_mobilemenu_show - funkcja wyświetlania zawartości menu mobilnego (w celu stworzenia efektu wyglądu). Domyślny $("#hotengine-mobile-outer").show(0); Przykład ↓
Code: html |
var $element = $("#hotengine-mobile-outer"); |
Większość rozwiązań możesz zaimplementować za pomocą skryptów (JavaScript). Niektóre z nich są opisane na stronie instrukcji, inne na stronie ustawień. Dodatkowo na stronie można znaleźć gotowe rozwiązania Skrypty do użytku na stronach internetowych.
Dostępne formaty:
- Sitemap.xml Mapa witryny ze wszystkimi danymi
- XML Google Merchant (Rozszerzone i skrócone)
- XML Yandex Market
- CSV Price
- JSON Wszystkie dane katalogowe sklepu
- Cena za Hotline.ua + marża własna
- Cennik dla Prom.ua + marża własna
- XML dla Rozetka.ua + marża własna
Generator i lista linków dostępnych w panelu administracyjnym - «XML/CSV/XLS/JSON»
Dodatkowo przy rozładunku towaru możesz określić opcje sortowania i filtrowania według poniższych parametrów:
- sort_by - sortowanie
- order_by - sortowanie
- sort_instock_priority - priorytet sortowania
- price_from – Cena od
- price_to – cena do
- producer – producent (jedna lub więcej wartości oddzielonych przecinkami)
- stock - obecność
- collection - kolekcja (jedna lub więcej wartości oddzielonych przecinkami)
- pers_shop_cat_page_catid - ID kategorii sklepu (co najmniej jedna wartość oddzielona przecinkami)
Parametry można podać jako zmienną GET, po głównej ścieżce do pliku XML. Na przykład «ścieżka.xml?producent=1» Możesz znaleźć opcje wartości na stronie importu produktu w instrukcjach.
Aby to zrobić, określ nasze serwery NS w ustawieniach swojej domeny:
NS1.HOTLIST.BIZ
NS2.HOTLIST.BIZ
Lub adres IP 88.218.28.193 we wpisie «A» rekord.
W takim razie skontaktuj się z nami za pomocą formularza opinii . W żądaniu podaj witrynę, do której chcesz podłączyć domenę *, oraz adres tej domeny.
* - nie sprzedajemy domen, aby podłączyć swoją domenę, musisz wstępnej rejestracji/zakupu.
Domeny w strefie .RU nie są obecnie obsługiwane.
SSL
SSL oznacza Secure Socket Layer i jest standardową technologią bezpieczeństwa internetowego, która służy do zapewnienia szyfrowanego połączenia między serwerem (stroną) a przeglądarką. Certyfikat SSL pozwala nam korzystać z protokołu HTTPS (po podłączeniu certyfikatu SSL Twoja strona nie otworzy się przez HTTP, ale przez protokół HTTPS).Co to jest HTTPS?
HTTPS (Hypertext Transport Protocol Secure) – jest to protokół zapewniający bezpieczeństwo i prywatność w wymianie informacji pomiędzy serwisem a urządzeniem użytkownika. Odwiedzający serwis oczekują, że podane przez nich dane nie wpadną w ręce oszustów. Aby chronić dane, które odwiedzający zostawiają w Twojej witrynie, zacznij korzystać z protokołu HTTPS.Jak podłączyć certyfikat SSL
Możesz podłączyć nasz certyfikat SSL przy płaceniu za hosting, zaznaczając pole «SSL certyfikat».
Ponadto możesz podłączyć certyfikat SSL dla swojej domeny, kupując go od dowolnego rejestratora. Koszt podłączenia i korzystania z certyfikatu wynosi 1 USD miesięcznie (minimalny okres płatności to 12 miesięcy).
Dla sklepu internetowego wystarczy certyfikat Comodo Positive SSL.
Płatne połączenie SSL.
Możesz podłączyć usługę pocztową Google.com, Zoho.com, Yandex, Mail.ru i inne do swojej domeny.
2)Wybierz odpowiedni plan, np. 5GB - ZA DARMO, za darmo
3) Dodaj swoją domenę @twojadomena. W celu weryfikacji musisz utworzyć zawijanie CNAME lub TXT w rekordach NS domeny. Możesz przesłać dane, a my je dodamy, lub wprowadź je samodzielnie. Prześlij zarówno dane TXT, jak i CNAME.
4) Dodaj rekordy MX z nazwą @ lub pustą nazwą.
Wartości w poniższej tabeli:
Host/ Domain | Address/ Mail Server/ MX Entries/ Value | Priority |
@/ Blank/ Domain name | mx.zoho.eu. | 10 |
@/ Blank/ Domain name | mx2.zoho.eu. | 20 |
@/ Blank/ Domain name | mx3.zoho.eu. | 50 |
5) W rekordach NS domeny utwórz wpis tekstowy o wartości "v=spf1 ip4:88.218.28.193 include:zoho.eu ~all"
6) Opcjonalnie możesz dodać Podpis DKIM https://www.zoho.eu/mail/help/adminconsole/dkim-configuration.html
7) Utwórz adresy e-mail i użytkowników.
8) Określ utworzoną skrzynkę jako serwer SMTP na stronie.
SMTP server: smtp.zoho.eu
Port: 465
Security Type: SSL
Lub
SMTP server: smtp.zoho.eu
Port: 587
Security Type: TLS
https://www.zoho.eu/mail/help/zoho-smtp.html.
Instrukcja podłączenia na www.zoho.eu.
Aby połączyć się z kanałem z powiadomieniem o nowych zamówieniach, musisz wysłać hotlist_viber_key (gdzie klucz to twój klucz) na kanał https://viber.com/hotlistbiz. Możesz udostępnić ten klucz i używać go z różnych urządzeń z Viber.
Możesz zainstalować klucz w "Ustawieniach", w zakładce "Powiadomienia". Alternatywnie można użyć klucza formularza, który można określić w Edytorze formularzy.
Aby wyłączyć powiadomienia, musisz albo zmienić klucze, albo wysłać DISABLE hotlist_key (gdzie klucz to Twoja strona lub klucz formularza) do Viber.
Aby połączyć się z kanałem z powiadomieniem o nowych zamówieniach, musisz wysłać hotlist_telegram_key (gdzie klucz to twój klucz) na kanał https://t.me/ hotlistbiz_bot. Możesz udostępnić ten klucz i używać go z różnych urządzeń z Telegramem.
Klucz możesz ustawić w "Ustawieniach", w zakładce "Powiadomienia". Alternatywnie można użyć klucza formularza, który można określić w Edytorze formularzy.
Aby wyłączyć powiadomienia, musisz albo zmienić klucze, albo wysłać DISABLE hotlist_key (gdzie klucz to Twoja witryna lub klucz formularza) do Telegrama.
Ten znacznik zawiera następujące dane:
data-hotengine-marking-type= typ strony
data-hotengine-marking-timestamp= data utworzenia strony
data-hotengine-marking-view= liczba wyświetleń
Dane są wymagane, jeśli chcesz wyłączyć lub wyświetlić dodatkowe dane, na określonej stronie, przy określonym typie strony lub jeśli potrzebujesz wyświetlić liczbę wyświetleń lub datę materiału (aktualność, artykuł, produkt). Dodatkowo, sprawdzając ten element, możesz znaleźć ID wpisu (strony, artykułu lub produktu), a także inne dodatkowe dane.
Jeśli potrzebujesz więcej danych w znacznikach, daj nam znać.
Code: html |
<span class="hotengine-marking" data-hotengine-marking-type="shop_catalog_page" data-hotengine-marking-timestamp="1422368197" data-hotengine-marking-view="6" data-hotengine-marking-shop_catalog_page_id="71111" data-hotengine-marking-shop_catalog_page_price="1" data-hotengine-marking-shop_catalog_page_price_currency="USD" data-hotengine-marking-shop_catalog_page_complectation="22323" data-hotengine-marking-video="https://youtu.be/tAyVrZ1jzC4"> |
Dodatkowo przy ustalaniu indywidualnych parametrów dostawy dodawane są kolejne atrybuty:
data-hotengine-marking-delivery="xxx"
data-hotengine-marking-delivery_price="xxx"
data-hotengine-marking-delivery_note="xxx"
W obecności wymiarów i wagi towarów dodaje się następujące atrybuty: data-hotengine-marking-shop_cat_page_deliv_width="XX"
data-hotengine-marking-shop_cat_page_deliv_height="XX"
data-hotengine-marking-shop_cat_page_deliv_length="XX"
data-hotengine-marking-shop_cat_page_deliv_units="XX"
data-hotengine-marking-shop_cat_page_deliv_weight="XX"
data-hotengine-marking-shop_cat_page_deliv_weight_units="XX"
data-hotengine-marking-shop_cat_page_deliv_capacity="XX"
Przykład skryptu sprawdzającego stronę pod kątem obecności obiektu znaczników i typu strony «shop_catalog_page» (strona karty produktu).
Code: html |
var product_marking = $(".hotengine-marking[data-hotengine-marking-type='shop_catalog_page']"); if(typeof product_marking !== typeof undefined && product_marking !== false && product_marking !='undefined' && product_marking !=''){ var product_id = product_marking.attr("data-hotengine-marking-shop_catalog_page_id"); console.log("ID PRODUCT IS "+product_id); } |
Jeśli strona jest zdefiniowana jako karta produktu, to wyodrębniamy ID produktu - data-hotengine-marking-shop_catalog_page_id.
Dostępne typy stron:
Shop:
- shop_catalog_page - karta produktu
- shop_catalog_page_incategory - karta produktu na stronie z listą *
- shop_catalog_page_incategory_search - karta produktu na stronie wyników wyszukiwania
- shop_catalog_page_cart_products_list - karta produktu w koszyku
- pers_shop_catalog_category - kategoria sklepu
- shop_catalog_category - kategoria sklepu w katalogu hotlist.biz
- shop_catalog_category_collection - kategoria kolekcji, sklep
- shop_catalog_category_producer - kategoria producenta, sklep
- shop_statistic_sale - statystyki sprzedaży
- shop_catalog_page_cart_bought_with - kup z towarem (podczas przeglądania koszyka)
- blog_catalog_page - artykuł
- blog_catalog_page_incategory – lista artykułów *
- news_catalog_page - Aktualności
- news_catalog_page_incategory - lista aktualności *
- news_catalog_page_incategory_menu - Blok/Menu, generowana lista wiadomości *
* - te obiekty listy mają dodane atrybuty mikroznaczników bez użycia oddzielnego elementu oznaczania hotengine.
Przykład znaczników ↓ (Wyświetlanie daty utworzenia wpisu)
Code: html |
<!--HTML-start--> <script> //convert timestumo ti date function timeConverter(UNIX_timestamp){ var a = new Date(UNIX_timestamp * 1000); var months = ['Jan','Feb','Mar','Apr','May','Jun','Jul','Aug','Sep','Oct','Nov','Dec']; var year = a.getFullYear(); var month = months[a.getMonth()]; var date = a.getDate(); var hour = a.getHours(); var min = a.getMinutes(); var sec = a.getSeconds(); var time = date + ' ' + month + ' ' + year + ' ' + hour + ':' + min + ':' + sec; return time; } //add date to content $(function(){ $("#hotengine-content-blog .hotengine-blog-page-list-block").each(function(){ $(this).find(".contenth_i").prepend('<div class="hotengine_add_date">'+timeConverter($(this).attr("data-hotengine-marking-timestamp"))+'</div>'); }); }) </script> <!--HTML-end--> |
Ten skrypt wyszukuje element znaczników, #hotengine-content-blog .hotengine-blog-page-list-block (artykuł z listy) i wstawia datę wcześniej przekonwertowaną z TIMESTAMP przez funkcję timeConverter na początek elementu .contenth_i .
Przykład użycia znaczników dla przycisku Dashboard ↓ (Zaloguj się/Wyloguj się/Moje zamówienia)
Code: html |
<div class="auth_block"><noindex> <a class="auth_login" rel="nofollow" href="/pl/admin/">Obszar osobisty</a> <a class="auth_my_orders" rel="nofollow" href="/pl/statistic_orders.htm">Moje zamówienia</a> <a class="auth_logout" rel="nofollow" href="/?action=logout">Wyloguj</a> </noindex></div> <style> .auth_my_orders{ display:none!important; } .auth_logout{ display:none!important; } [data-hotengine-marking-userid] .auth_login {display:none!important; } [data-hotengine-marking-userid] .auth_logout{ display:inline-block!important; } [data-hotengine-marking-userid] .auth_my_orders{ display:inline-block!important; } </style> |
Ten skrypt zawiera linki. Pierwsza strona logowania (.auth_login). Drugi do strony z zamówieniami użytkowników (.auth_my_orders). Po trzecie - Wyjdź z linku (.auth_logout). Ponadto możesz utworzyć link rejestracyjny (/index.php?action=register).
Po wejściu użytkownika na stronę za pomocą stylu i atrybutu CSS [data-hotengine-marking-userid] (który pojawia się tylko wtedy, gdy użytkownik jest uwierzytelniony), ukrywanie linku .auth_login/Zostanie wyświetlone konto osobiste i link .auth_my_orders/Moje rozkazy również .auth_logout/Wyjście.
Ponadto <HTML> znaczniki są dodawane dla użytkowników data-hotengine-marking-userid, z identyfikatorem użytkownika.
Jeśli użytkownik jest dodany jako «Klient» z własnym rabatem, to dodawany jest również znacznik data-hotengine-marking-user-group-discount z wielkością jego rabatu.
Code: html |
<html lang="pl" data-hotengine-marking-userid="USERID" data-hotengine-marking-user-group-discount="-10%"> |
pl - język strony
USERID - ID użytkownika
10% - rabat dla klienta.
Jeżeli użytkownik jest dodany do Grupy Klientów, to dodatkowo wskazywany jest ID grupy, do której należy.
Code: html |
<html lang="pl" data-hotengine-marking-userid="XXXXX" data-hotengine-marking-user-group-discount="-20%" data-hotengine-marking-user-group-id="XXXXX"> |
Przykład dodatkowej marży w odmianie produktu ↓
Code: html |
<ul class="hotengine-shop-product-variety_select" size="1" data-vpid="XXXXX" > <li value="0" title="Różnorodność" >Różnorodność</li> <li value="XXXXXX" data-hotengine-variety-disable-add="1" data-hotengine-variety-pricechange="+10" data-hotengine-variety-stockcount="10" class="">Różnorodność 1</li> <li value="XXXXX" data-hotengine-variety-disable-add="0" data-hotengine-variety-pricechange="=500" data-hotengine-variety-stockcount="10" class="hotengine-shop-product-variety_hilight">Różnorodność 2</li> <li value="XXXXX" data-hotengine-variety-disable-add="0" data-hotengine-variety-pricechange="-110" data-hotengine-variety-stockcount="10" class="hotengine-shop-product-variety_hilight-selected">Różnorodność 3</li> </ul> |
data-hotengine-variety-disable-add - włączenie/wyłączenie możliwości dodania odmiany do koszyka (1-zakaz, 0-zezwalanie). Po kliknięciu na odmianę, której dodawanie jest wyłączone, nic się nie dzieje, a cena produktu i numer artykułu nie ulegają zmianie.
data-hotengine-variety-pricechange - dane o zmianach cen, możesz go użyć do wyróżnienia danych o zmianach cen (używając javascript).
data-hotengine-variety-stockcount - Ilość w magazynie
CSS klasy dla elementów:
.hotengine-shop-product-variety_hilight - wybrany obiekt (po najechaniu myszką).
.hotengine-shop-product-variety_hilight-selected - wybrany obiekt, na który kliknięto (wariant aktywny).
Dodatkowo dla wszystkich elementów potomnych bloku z wyłączoną funkcją dodawania do koszyka [data-hotengine-variety-disable-add="1"] dodano stylizację desaturacji i normalny kursor najechania.
Przykład etykiety dla zapytania w sklepie ↓
Code: html |
<span class="hotengine-marking" data-hotengine-marking-type="shop_catalog_page_incategory_search" data-hotengine-marking-search="oddzielne zapytanie wyszukiwania" data-hotengine-marking-searchparam="?&search=pełny ciąg zapytania wyszukiwania (+ sortowanie i inne dane)" data-hotengine-marking-sortparam="dodatkowe dane sortowania" data-hotengine-marking-smart_search_price_from="cena od" data-hotengine-marking-smart_search_price_to="cena do" data-hotengine-marking-smart_search="zapytanie wyszukiwania podczas korzystania z filtra wyszukiwania" data-hotengine-marking-searchresult-num="55"> |
data-hotengine-marking-searchparam - zapytanie wyszukiwania, może służyć do tworzenia linku do strony z zapytaniem.
data-hotengine-marking-searchresult-num - ilość znalezionych produktów dla wprowadzonego zapytania.
Przykład etykiety w kategoriach sklepów sklepowych ↓
Code: html |
<span class="hotengine-marking" data-hotengine-marking-type="pers_shop_catalog_category" data-hotengine-marking-view="9999" data-hotengine-marking-pers_shop_catalog_category_parent_id="222" data-hotengine-marking-pers_shop_catalog_category_child_count="2" data-hotengine-marking-pers_shop_catalog_page_count="999" data-hotengine-marking-pers_shop_catalog_page_child_count="1299" data-hotengine-marking-pers_shop_catalog_category_name="nameofcategory" data-hotengine-marking-pers_shop_catalog_category_id="8342"> |
data-hotengine-marking-pers_shop_catalog_category_parent_id - ID kategorii nadrzędnej
data-hotengine-marking-pers_shop_catalog_category_child_count - liczba podkategorii (tylko do tego rodzica)
data-hotengine-marking-pers_shop_catalog_page_count - ilość produktów w tej kategorii
data-hotengine-marking-pers_shop_catalog_page_child_count - liczba produktów w tej i podkategoriach podrzędnych
data-hotengine-marking-pers_shop_catalog_category_name - Nazwa Kategorii.
data-hotengine-marking-pers_shop_catalog_category_id - ID kategorii.
Podobne znaczniki są używane dla producentów.
Przykład wyszukiwania etykiety z zapytaniem w sklepie ↓
Code: html | ||
|
data-hotengine-marking-search - wyszukiwana fraza
Ponadto do niektórych bloków witryny dodano znaczniki "data-hotengine-..." z dodatkowymi danymi.
Na przykład "data-hotengine-product-images-count" - ilość zdjęć produktu.
W koszyku znaczniki wskazują ilość towarów, koszt całkowity oraz walutę (data-hotengine-cart-count, data-hotengine-cart-total-price, data-hotengine-cart-currency)
Dodatkowe znaczniki, «data-» zaimplementowane bezpośrednio w elementach znaczników, na przykład element class="hotengine-categories-list-block" (blok ikon kategorii) może zawierać znaczniki: data-image="1" -wskazany jest obraz kategorii, data-child-cat="7" - liczba podkategorii data-child-items="5114" - Ilość produktów we wszystkich działach wewnętrznych, a także ilość podkategorii, data-ci="44" - ID kategorii. (data-ci - kategorie sklepu, data-pci - kategorie producentów, data-cci - kategorie kolekcji, data-bci - kategorie katalogu artykułów)
W statystykach sprzedaży, przeglądając zamówienie osobno, pojawia się również mikronarzut.
Przykład sprawdzania obecności elementu znaczników ↓
Code: html |
var $catergory = $('.hotengine-marking[data-hotengine-marking-type="pers_shop_catalog_category"]'); if (typeof $catergory !== typeof undefined && $catergory !== false && $catergory !== "undefined" && $catergory.length > 0){ var $nemecat = $catergory.attr("data-hotengine-marking-pers_shop_catalog_category_name"); alert("Category name is "+$nemecat); } |
Instrukcja tworzenia Sortowania towarów w sklepie wraz z przykładem ↓
Użyj łącza, aby utworzyć automatycznie menu funkcyjne «Sortuj» lub wypełnij Blok/Menu zgodnie z instrukcją poniżej:
Utwórz «Blok/Menu», pozycja «góra».
Nazwa bloku/Menu: hotengine_sort_products
Nagłówek/menu bloku: hotengine_sort_products
Pozycja bloku/menu: Góra
Pokaż blok/menu na stronach: wszędzie
Wprowadź znaki, po wykryciu których wyświetli się blok/menu: (bez spacji)
Wprowadź znaki, które, jeśli zostaną znalezione, nie wyświetlają bloku/menu: (bez spacji)
Code: |
<form id="hotengine-sort-products-generated" name="hotengine-sort-products-generated" method="get" action=""> <span> <label> <select name="sort_by" id="sort_by" onchange="this.form.submit()"> <option value="ASC">Сортировать:</option> <option value="ASC">Rosnąco</option> <option value="DESC">Malejąco</option> </select> </label> <label> <select name="order_by" id="order_by" onchange="this.form.submit()"> <option value="5">Sortować:</option> <option value="0">Według ID produktu</option> <option value="4">Nazwa</option> <option value="1">Według daty</option> <option value="2">Według ceny</option> </select> </label> <label> <select name="NUM_ONPAGE" id="NUM_ONPAGE" onchange="this.form.submit()"> <option value="10">10</option> <option value="20">20</option> <option value="30">30</option> <option value="50">50</option> </select> </label> <input class="smart_search" name="smart_search" type="hidden" value=""> <input class="search" name="search" type="hidden" value=""> </span> </form> <script type="text/javascript" src="/templates/scripts/hotengine-script-sort-shop-products.js"></script> |
CSS styl do sortowania (dodaj w edytorze projektów do stylów css):
Code: |
.hotengine_sort_products #menu_c .headm{ display:none; } .hotengine_sort_products #menu_c { border: none; background: none; text-align: right;} .hotengine_sort_products #menu_c select { background: transparent; padding: 5px 8px 5px 5px; font-size: 12px; line-height: 1; border-radius: 2px; height: 24px; -webkit-appearance: none; overflow: hidden; background: url(/templates/styles/menu_arrow/arrow-down.svg) no-repeat 95%; background-size: 16px; } .hotengine_sort_products #menu_c select[name="NUM_ONPAGE"] { background:none;} @-moz-document url-prefix(){ .hotengine_sort_products #menu_c select { padding:0px!important; background:none!important; } .menu_position_top_000000 #menu_c span:before{ content:"Sortować:"; display:inline-block; padding: 5px; font-size: 12px; } } |
Gdzie 000000 należy zastąpić identyfikatorem utworzonego menu z kodem rozliczeniowym.
Instrukcja zmiany komunikatu o niewyselekcjonowanej odmianie ↓
Tekst błędu wyboru odmiany:
Komunikat o konieczności wyboru rodzaju produktu jest realizowany w oknie dialogowym za pomocą elementu CSS. Możesz zastąpić napisy w stylach CSS:
Code: СSS |
html:lang(ru) .hotengine-shop_cart_add_error_wrong_variety:after{ content:"Вы не выбрали разновидность товара."; } html:lang(en) .hotengine-shop_cart_add_error_wrong_variety:after{ content:"You did not select a complete set of goods."; } html:lang(uk) .hotengine-shop_cart_add_error_wrong_variety:after{ content:"Вы не обрали різновид товару."; } html:lang(pl) .hotengine-shop_cart_add_error_wrong_variety:after{ content:"Nie wybrałeś typu produktu."; } |
Ponadto, zanim wiadomość zostanie wyświetlona, dzwoni callback funkcjonować callback_hotengine_variety_require.
Podczas przeglądania listy produktów, przed wyświetleniem komunikatu, jest to tzw callback funkcjonować callback_hotengine_variety_require_list($href), mając na uwadze, że $href wysyłany jest link do karty produktu.
Przykład funkcji z oknem dialogowym, które jest domyślne i można je zmienić:
Code: JavaScript |
<script> function callback_hotengine_variety_require(){ $("body").append('<div id="hotengine-shop_cart_add_error_wrong_variety"><a class="hotengine-shop_cart_add_error_wrong_variety-btn-close" data-micromodal-close onclick=\'(function() { $("#hotengine-shop_cart_add_error_wrong_variety,#hotengine-shop_cart_add_error_wrong_variety-data").remove(); return false; })();\'></a></div>'); hotengine_micromodal({ id: "hotengine-shop-cart-add-error-wrong-variety", content: $("#hotengine-shop_cart_add_error_wrong_variety-data").html(), defaultWidth: $(window).width() > 410 ? "410px" : "90%", defaultHeight: "", minWidth: "290px", onCloseRemove: false, unsetContentHeight: true, onCloseEvent: function(){ $("#hotengine-shop-cart-add-error-wrong-variety,#hotengine-shop_cart_add_error_wrong_variety-data").remove(); } }); return false; } </script> |
W parametrach produktu możesz określić tytuł nad listą odmian. Długość nagłówka jest dodawana jako klasa CSS. Na przykład, jeśli tytuł to «Wybierz wagę», to jego długość wynosi 24 znaki. W związku z tym określona jest klasa hotengine-shop-product-variety-title_24. Możesz użyć tekstu lub długości nagłówka nad odmianą. Na przykład:
Code: JavaScript |
<script> function callback_hotengine_variety_require(){ if($(".hotengine-shop-product-variety-title_24").length > 0){ $text = "Nie wybrałeś wagi!"; } else if($(".hotengine-shop-product-variety-title_38").length > 0){ $text = "Nie wybrałeś ilości!"; } else if($(".hotengine-shop-product-variety-title_26").length > 0){ $text = "Nie wybrałeś koloru!"; } else { $text = "Nie wybrałeś odmiany!"; } $("body").append('<div id="hotengine-shop_cart_add_error_wrong_variety"><b>'+$text+'</b><a class="hotengine-shop_cart_add_error_wrong_variety-btn-close" data-micromodal-close onclick=\'(function() { $("#hotengine-shop_cart_add_error_wrong_variety,#hotengine-shop_cart_add_error_wrong_variety-data").remove(); return false; })();\'></a></div>'); hotengine_micromodal({ id: "hotengine-shop-cart-add-error-wrong-variety", content: $("#hotengine-shop_cart_add_error_wrong_variety-data").html(), defaultWidth: $(window).width() > 410 ? "410px" : "90%", defaultHeight: "", minWidth: "290px", onCloseRemove: false, unsetContentHeight: true, onCloseEvent: function(){ $("#hotengine-shop-cart-add-error-wrong-variety,#hotengine-shop_cart_add_error_wrong_variety-data").remove(); } }); return false; } </script> |
Instrukcja dodawania linku do recenzji / rating w towarach ↓
Aby utworzyć link do ikon ocen na liście produktów, musisz znaleźć wszystkie elementy listy i dodać link wokół elementów oceny.
Dodatkowo po załadowaniu listy produktów w sliderze lub skorzystaniu z przycisku "Pokaż więcej" należy ponownie dodać link (callback_hotengine_ajax_load_products i callback_hotengine_shop_products_list_div_button).
Code: JavaScript |
<script type="text/javascript"> <!-- $(function(){ $(".hotengine-shop-product-list-block .hotengine-shop-product-rating-block").each(function(){ var $urlr = $(this).parent().find(".hotengine-shop-product-read_more a").attr("href"); $(this).wrap('<a class="hotengine-shop-product-rating-block-url" href="'+$urlr+'#tabs-review"></a>'); }); }); function callback_hotengine_ajax_load_products(){ $(".hotengine-shop-products-list-content-append .hotengine-shop-product-list-block :not([.hotengine-shop-product-rating-block-url]) .hotengine-shop-product-rating-block").each(function(){ var $urlr = $(this).parent().find(".hotengine-shop-product-read_more a").attr("href"); $(this).wrap('<a class="hotengine-shop-product-rating-block-url" href="'+$urlr+'#tabs-review"></a>'); }); } function callback_hotengine_shop_products_list_div_button(){ $(".hotengine-shop-products-list-content .hotengine-shop-product-list-block .hotengine-shop-product-rating-block").each(function(){ var $urlr = $(this).parent().find(".hotengine-shop-product-read_more a").attr("href"); $(this).wrap('<a class="hotengine-shop-product-rating-block-url" href="'+$urlr+'#tabs-review"></a>'); }); } --> </script> |
Obiekt linku musi być np. umieszczony CSS:
Code: JavaScript |
.hotengine-shop-product-list-block .hotengine-shop-product-rating-block{ position:relative; display: block; bottom: 0px;} .hotengine-shop-product-list-block .hotengine-shop-product-rating-block-url{ position:relative; display: block; bottom: 1px;} |
Dodatkowe klocki w wózku: Jeśli produkt ma cenę hurtową, tworzony jest element SPAN .hotengine-shop-product-price_opt_inform_block.
Code: html |
<span class="hotengine-shop-product-price_opt_inform_block"><span class="hotengine-shop-product-price_opt_inform_block_title"></span><span class="hotengine-shop-product-price_opt_inform_original_price">100</span><span class="hotengine-shop-product-price_opt_inform_original_price_opt">100</span></span> |
.hotengine-shop-product-price_opt_inform_block_title - blok z tekstem "Cena hurtowa" (możesz zmienić za pomocą stylów CSS, treści).
.hotengine-shop-product-price_opt_inform_block - blok informacji o zniżkach
.hotengine-shop-product-price_opt_inform_original_price - cena
.hotengine-shop-product-price_opt_inform_original_price_opt - cena hurtowa
Jeśli produkt ma Promocję, tworzony jest element SPAN .hotengine-shop-product-price_sale_inform_block.
Code: html |
<span class="hotengine-shop-product-price_sale_inform_block"><span class="hotengine-shop-product-price_sale_inform_block_title"></span><span class="hotengine-shop-product-price_sale_inform_original_price">100</span><span class="hotengine-shop-product-price_sale_inform_original_price_old">120</span></span> |
.hotengine-shop-product-price_sale_inform_block_title - blok z tekstem «Cena promocyjna» (możesz zmienić za pomocą stylów CSS, treści).
.hotengine-shop-product-price_sale_inform_block - blok informacji o zniżkach
.hotengine-shop-product-price_sale_inform_original_price - cena
.hotengine-shop-product-price_sale_inform_original_price_old - stara cena produktu (wyświetlana tylko jeśli wartość jest podana i różna od zera)
Każda strona posiada unikalne dane, np. może to być ID strony (artykuł, produkt, strona).
Poniżej znajduje się lista podstawowych danych dla Autokorekty.
{HOTENGINE-SC:current_page_id} - ID bieżącej strony (artykuły, strony, produkty, aktualności)
{HOTENGINE-SC:site_url} - URL Twojej witryny (adres)
{HOTENGINE-SC:lang} - Otwórz język strony
{HOTENGINE-SC:site_tagline} - Slogan strony internetowej
{HOTENGINE-SC:contacts} - Blokuj z kontaktami
{HOTENGINE-SC:slide_menu_widget:XX} - Blokuj za pomocą widżetu Menu slajdów
{HOTENGINE-SC:slider_widget:XX} — blok z widżetem suwaka
{HOTENGINE-SC:smart_search_widget:PARAM} - Blokuj z filtrem wyszukiwania widgetów
{HOTENGINE-SC:mainmenu} - Menu główne
{HOTENGINE-SC:langmenu} - zmiana języka
{HOTENGINE-SC:user_nickname} - Nazwa użytkownika (jeśli jest autoryzowana)
{HOTENGINE-SC:user_id} - ID użytkownika (jeśli jest autoryzowany)
{HOTENGINE-SC:user_login} - Login użytkownik (jeśli ma autoryzację)
{HOTENGINE-SC:user_discount} - Niestandardowy rabat
{HOTENGINE-SC:user_cashback} - Balansować Cashback
{HOTENGINE-SC:user_group_id} - ID grupy użytkowników
{HOTENGINE-SC:shop_cart_menu} - koszyk (Koszyk z blokami/menu)
{HOTENGINE-SC:favorites} - link do wybranych produktów
{HOTENGINE-SC:shop_compare_menu} - porównanie towarów
{HOTENGINE-SC:shop_cat_page_image} - Ścieżka do obrazu produktu (jeśli strona produktu jest otwarta)
{HOTENGINE-SC:shop_cat_page_id} - ID produktu (jeśli strona produktu jest otwarta). Możesz też użyć {HOTENGINE-SC:current_page_id}
{HOTENGINE-SC:shop_cat_page_sku} - Kod produktu (jeśli strona produktu jest otwarta)
{HOTENGINE-SC:shop_cat_page_currency} - Waluta produktu (skrócona) (jeśli strona produktu jest otwarta)
{HOTENGINE-SC:shop_cat_page_currency_iso} - Waluta produktu (ISO) (jeśli strona produktu jest otwarta)
{HOTENGINE-SC:shop_cat_page_price} - Cena produktu (jeśli strona produktu jest otwarta)
{HOTENGINE-SC:shop_cat_page_title} - Nazwa produktu
{HOTENGINE-SC:shop_cat_page_video} – Video URL (link do filmu)
{HOTENGINE-SC:pers_shop_cat_val_name} - Nazwa kategorii sklepu (tylko wewnątrz kategorii i przycisku na liście podkategorii)
{HOTENGINE-SC:pers_shop_cat_val_title} - Tytuł kategorii sklepu (tylko wewnątrz kategorii i przycisku na liście podkategorii)
{HOTENGINE-SC:pers_shop_cat_val_id} - ID kategorii sklepu (tylko wewnątrz kategorii i przycisku na liście podkategorii)
{HOTENGINE-SC:shop_cat_producer_val_name} - Nazwa kategorii producenta (tylko wewnątrz kategorii i przycisku na liście podkategorii)
{HOTENGINE-SC:shop_cat_producer_val_id} - ID kategorii dostawcy (tylko wewnątrz kategorii i przycisku na liście podkategorii)
{HOTENGINE-SC:shop_cat_collection_val_name} - Nazwa kategorii kolekcji (tylko wewnątrz kategorii i przycisku na liście podkategorii)
{HOTENGINE-SC:shop_cat_collection_val_id} - ID kolekcja kategorii (tylko wewnątrz kategorii i przycisku na liście podkategorii)
{HOTENGINE-SC:blog_cat_val_name} - Nazwa kategorii katalogu artykułów (tylko wewnątrz kategorii i przycisku na liście podkategorii)
{HOTENGINE-SC:blog_cat_val_id} - ID kategorii katalogu artykułów (tylko w przycisku kategorii)
{HOTENGINE-SC:blog_cat_page_id} - ID artykułu (tylko w katalogu artykułów)
{HOTENGINE-SC:blog_cat_page_title} - Tytuł artykułu (tylko w katalogu artykułów)
{HOTENGINE-SC:blog_cat_val_id} - ID kategorii katalogu artykułów (tylko wewnątrz kategorii i przycisku na liście podkategorii)
Możesz na przykład użyć tego kodu do wyświetlenia nazwy autoryzowanego użytkownika na stronie internetowej:
Code: html |
<span class="user_login_name">Witamy {HOTENGINE-SC:user_login}</span> |
Możesz też użyć tego kodu do wygenerowania metadanych dla mediów społecznościowych (takich jak znaczniki Open Graph):
Code: html |
<meta property="og:image" content="{HOTENGINE-SC:shop_cat_page_image}"/> <meta property="og:title" content="{HOTENGINE-SC:shop_cat_page_title}> |
Przykład utworzenia linku do profilu autoryzowanego użytkownika:
Code: html |
https://hotlist.biz/{HOTENGINE-SC:lang}/users.php?p=user_profile&action=userprofile&userid={HOTENGINE-SC:user_id} |
Przykład ↓
Code: html |
<script type="text/javascript" src="/modules/jquery.cookie/jquery.cookie.min.js"></script> <script type="text/javascript"><!-- //funkcja do określania zmiennych GET z paska adresu function getParameterByName($from,$name){ var match = RegExp('[?&]' + $name + '=([^&]*)').exec($from); return match && decodeURIComponent(match[1].replace(/\+/g, ' ')); } $(function(){ //po znalezieniu sort_by zaczynamy pisać tablicę z danymi, GET zmienne sortujące witrynę var $from = window.location.href; if(getParameterByName($from,"sort_by")!=undefined){ var $hotengine_cookie_conv_to_get = [ {'sort_by': getParameterByName($from,"sort_by") }, {'order_by': getParameterByName($from,"order_by") }, {'order_by_param': getParameterByName($from,"order_by_param") }, {'shop_new_goods': getParameterByName($from,"shop_new_goods") }, {'shop_sale': getParameterByName($from,"shop_sale") }, {'shop_bestsellers': getParameterByName($from,"shop_bestsellers") }, {'shop_discount': getParameterByName($from,"shop_discount") }, {'shop_reduced_price': getParameterByName($from,"shop_reduced_price") }, {'sort_instock_priority': getParameterByName($from,"sort_instock_priority") }, {'price_from': getParameterByName($from,"price_from") }, {'price_to': getParameterByName($from,"price_to") }, {'NUM_ONPAGE': getParameterByName($from,"NUM_ONPAGE") }, {'smart_search': getParameterByName($from,"smart_search") }, {'search': getParameterByName($from,"search") }, ]; //zapisz Cookie z danymi w formacie JSON $.cookie("hotengine_cookie_conv_to_get", JSON.stringify($hotengine_cookie_conv_to_get), {expires: 365, path: "/"}); } // aby usunąć pliki cookie użyj $.cookie("hotengine_cookie_conv_to_get", null, {expires: 0, path: "/"}); }); //--> </script> |
W rezultacie, jeśli odwiedzający sortuje towary, to dane «sort_by», «order_by», «NUM_ONPAGE» i inne są pobierane z paska adresu. Dane są zapisywane do Cookie w formacie json. Następnie, podczas otwierania stron w przyszłości, witryna po wykryciu pliku cookie «hotengine_cookie_conv_to_get» konwertuje nazwy (indeksy) tablicy na zmienne GET z odpowiednimi indeksami i wartościami. W ten sposób, wybierając jednokrotne posortowanie strony, odwiedzający będzie ją widział do czasu zmiany pliku cookie.
hotengine-script-sort-shop-products.js
Jednym ze sposobów implementacji witryn wielojęzycznych jest użycie tagu z atrybutem hreflang. Przykład takiego tagu:
<link rel="alternate" hreflang="lang_code" href="url_of_page" />
Na różnych stronach serwisu (kategorie, strony, artykuły, karty produktów i inne) zaimplementowana jest funkcja wielojęzyczności. Jeśli np. posiadasz dodatkową kartę produktu w języku angielskim, białoruskim, rosyjskim i ukraińskim, to wystarczy, że we wszystkich kartach produktów w komórce «Produkt w innych językach» wpiszesz tę samą wartość, np. «1». W takim przypadku podczas otwierania strony w jednym z języków zostaną dodane tagi hreflang z linkami do stron w innych językach. Zaleca się użycie identyfikatora pierwszej karty produktu, aby uniknąć zduplikowanych wartości i kolejnych błędów. Na przykład, jeśli dodałeś produkt «Trampki» o numerze identyfikacyjnym «12345», a następnie dodałeś podobny produkt w języku angielskim, w pozycji «Produkt w innych językach» podaj «12345».
Główny wybrany język strony zostanie oznaczony dodatkowym znacznikiem hreflang="x-default".
Aby utworzyć nagłówki dla katalogu artykułów lub sklepu, zalecamy użycie prefiksu języka. Na przykład nagłówek «sukienka» można utworzyć w innych językach za pomocą przedrostka «dress_ua», «dress_de», «dress_fr»…
Możliwe jest użycie tej samej ścieżki do kategorii w innych językach, jednak podczas importu danych, np. produktu, mogą wystąpić błędy, ponieważ platforma nie będzie w stanie rozpoznać języka kategorii, do której jest dodana. Dlatego zalecamy stosowanie przedrostków w działach z nagłówkami, katalogu artykułów i sklepie internetowym. W przypadku stosowania przedrostków językowych opisanych powyżej zmienna «Kategoria w innych językach» zostanie ustawiona automatycznie.
Podczas tworzenia kart produktów «Kod produktu» musi być unikalny, dlatego w innym języku możesz użyć np. własnych końcówek «SKU/CODE_EN». W przypadku określenia «Produkt w innym języku» to przy zmianie podstawowych danych (koszt, dostępność, nowość, bestseller, dostęp) zostaną również zaktualizowane wszystkie tagi produktów wskazane jako alternatywna wersja produktu głównego.
«Filtr wyszukiwania» i «Bloki / menu» mogą być używane jednocześnie dla wszystkich języków i można osobno określić język, w którym ma być wyświetlany. Na przykład utwórz «Blocks/Menu», nagłówek witryny i umieść go na wszystkich stronach, określając język «polski (pl)». Taki blok będzie się wyświetlał wszędzie tylko wtedy, gdy otwarta będzie polska wersja serwisu. W ten sam sposób możesz utworzyć nagłówek dla innych języków. Jeśli trzeba umieścić jakiś kod, to nie trzeba tworzyć takich «Bloków / menu» dla każdego języka, można określić język «Wszystkie (wszystkie)», a blok będzie wyświetlany niezależnie od wybranego języka gość.
Prefiks języka na platformie Hotlist.biz jest wskazany na początku, na przykład, «/pl/page.htm».
Przed importem musisz zapisać plik w formacie «XLS» lub «CSV». Po zaimportowaniu sprawdź, czy język nowych kategorii jest odpowiedni. Jeśli z jakiegoś powodu określono niewłaściwy język, zmień język głównej kategorii swojego katalogu, do którego zostały dodane, w sekcji «Sklep» - «Kategorie sklepu». We wszystkich podkategoriach podrzędnych język również zostanie zastąpiony. Jeśli nie ma wielu kategorii, możesz skopiować kategorie, zastępując w nich język i nazwę, w sekcji «Sklep» - «Kategorie sklepu».
Dokonaj importu, w dziale "Sklep" - "Importuj towary". Możesz szybko uzupełnić korespondencję komórek, klikając «Pola z pliku, określ korespondencję» - «Wypełnij wybór pól korespondencji zgodnie z plikiem eksportu (pola« Wyładuj wszystko )».
Dodatkowo w celu tworzenia poprawnych znaczników dla wyszukiwarek, a także przekierowania między produktami w różnych językach, w produktach głównego języka należy eksportować i ponownie importować poprzez skopiowanie wartości komórki «ID» do pola «Produkty w inne języki». (W tym przypadku można zaimportować tylko jedną komórkę «Produkt w innych językach» i określić identyfikator lub «Kod produktu», według którego zostaną znalezione produkty do nadpisania). Zatem zarówno nowe, jak i poprzednie utworzone produkty będą miały identyczne znaczenie «Produkt w innych językach».
Kod z poniższego przykładu generuje przycisk przełączania na alternatywne języki, a jeśli dla strony/artykułu/kartki produktu zostanie podana alternatywna wersja językowa, to zostanie ona aktywowana.
1) Wklej kod CSS do Edytora projektu, w zakładce CSS.
2) Dodaj JavaScript do bloku/menu, które jest wyświetlane na wszystkich stronach.
3) Wklej kod listy rozwijanej języka do bloku/menu, w którym chcesz go umieścić, na przykład w nagłówku witryny.
4) Usuń niepotrzebne języki z bloku (class hotengine-shop-select-language-val)
Kod menu wyboru języka:
Code: html |
<span class="hotengine-shop-select-language-box"> <span class="hotengine-shop-select-language" data-lang="pl"></span> <span class="hotengine-shop-select-language-values"> <a class="hotengine-shop-select-language-val" data-lang="be"></a> <a class="hotengine-shop-select-language-val" data-lang="de"></a> <a class="hotengine-shop-select-language-val" data-lang="en"></a> <a class="hotengine-shop-select-language-val" data-lang="es"></a> <a class="hotengine-shop-select-language-val" data-lang="fr"></a> <a class="hotengine-shop-select-language-val" data-lang="kk"></a> <a class="hotengine-shop-select-language-val" data-lang="pl"></a> <a class="hotengine-shop-select-language-val" data-lang="ru"></a> <a class="hotengine-shop-select-language-val" data-lang="uk"></a> </span> </span> |
CSS style:
Code: CSS styl |
/*LANGUAGE BLOCK*/ .hotengine-shop-select-language-box { display:inline-block; width:71px; height:auto; overflow:hidden; border:1px solid transparent; line-height:30px; position:relative; z-index:1000; } .hotengine-shop-select-language { display:block; width:100%; text-align:center; cursor:pointer; } .hotengine-shop-select-language-values { display:block; width:100%; vertical-align: top; position:absolute; background:rgba(255, 255, 255, 0.80); } .hotengine-shop-select-language-box:hover{ overflow:visible;} .hotengine-shop-select-language-values:hover .hotengine-shop-select-language-val{ position:relative; } .hotengine-shop-select-language-val { width:auto; display:block; margin:0px; vertical-align:top; cursor:pointer; text-align:center; color:inherit; text-decoration:none; } .hotengine-shop-select-language-val:hover {background:inherit;color:inherit;} .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="ru"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="ru"]:after { content: "RU"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="en"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="en"]:after { content: "EN"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="uk"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="uk"]:after { content: "UA"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="de"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="de"]:after { content: "DE"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="es"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="es"]:after { content: "ES"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="fr"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="fr"]:after { content: "FR"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="kk"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="kk"]:after { content: "KK"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="be"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="be"]:after { content: "BE"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="ro"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="ro"]:after { content: "RO"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="tr"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="tr"]:after { content: "TR"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="it"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="it"]:after { content: "IT"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="sk"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="sk"]:after { content: "SK"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="da"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="da"]:after { content: "DA"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="pl"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="pl"]:after { content: "PL"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="zh"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="zh"]:after { content: "ZH"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="hi"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="hi"]:after { content: "HI"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="ar"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="ar"]:after { content: "AR"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="pt"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="pt"]:after { content: "PT"; } .hotengine-shop-select-language-box .hotengine-shop-select-language[data-lang="bn"]:after, .hotengine-shop-select-language-box .hotengine-shop-select-language-val[data-lang="bn"]:after { content: "BN"; } /*LANGUAGE BLOCK*/ |
Plik jest automatycznie pobierany na stronie, jeśli wskazane są dostępne języki:
Code: JavaScript |
<script type="text/javascript" src="/templates/scripts/hotengine-script-language.js"></script> |
Zawartość pliku
Tekst jest rozdzielany za pomocą nadrzędnego atrybutu lang elementu html.
Пример:
html:lang(ru) .hotengine-form-feedback-yourname-title:after{ content:"Ваше имя:"; }
html:lang(en) .hotengine-form-feedback-yourname-title:after{ content:"Your name:"; }
html:lang(uk) .hotengine-form-feedback-yourname-title:after{ content:"Ваше ім'я:"; }
html:lang(de) .hotengine-form-feedback-yourname-title:after{ content:"Ihr name:"; }
html:lang(es) .hotengine-form-feedback-yourname-title:after{ content:"Su nombre:"; }
html:lang(fr) .hotengine-form-feedback-yourname-title:after{ content:"Votre nom:"; }
html:lang(kk) .hotengine-form-feedback-yourname-title:after{ content:"Сіздің атыңыз:"; }
html:lang(be) .hotengine-form-feedback-yourname-title:after{ content:"Ваша імя:"; }
html:lang(ro) .hotengine-form-feedback-yourname-title:after{ content:"Numele dvs.:"; }
html:lang(tr) .hotengine-form-feedback-yourname-title:after{ content:"Adınız:"; }
html:lang(it) .hotengine-form-feedback-yourname-title:after{ content:"Il tuo nome:"; }
html:lang(sk) .hotengine-form-feedback-yourname-title:after{ content:"Vaše meno:"; }
html:lang(da) .hotengine-form-feedback-yourname-title:after{ content:"Dit navn:"; }
html:lang(pl) .hotengine-form-feedback-yourname-title:after{ content:"Twoje imię:"; }
html:lang(zh) .hotengine-form-feedback-yourname-title:after{ content:"你的名称:"; }
html:lang(hi) .hotengine-form-feedback-yourname-title:after{ content:"आपका नाम:"; }
html:lang(ar) .hotengine-form-feedback-yourname-title:after{ content:"اسمك:"; }
html:lang(pt) .hotengine-form-feedback-yourname-title:after{ content:"Seu nome:"; }
html:lang(bn) .hotengine-form-feedback-yourname-title:after{ content:"আপনার নাম:"; }
Jak przetłumaczyć całą witrynę?
Tworząc witrynę wielojęzyczną, określ język w tworzonych treściach (strona, menu, kategorie...)
I użyj ścieżek językowych na początku, /pl/ /en/ ...
Głównym językiem będzie język określony podczas rejestracji na stronie.
Podczas dodawania produktów język ustalany jest zgodnie z kategorią, w której jest dodawany.
Większość elementów na stronie możesz zastąpić stylami CSS i pseudoelementami.
Napisy o liczbie towarów
html:lang(pl).hotengine-shop-product-price_for-lang-1:after{ content:"za 1 sztukę";}
Zastąp liczbę lang-1, gdzie 1 oznacza wybraną jednostkę miary, a (pl) to język.
Lista wartości:
- 1 - 1 sztuka;
- 2 - 100 szt.;
- 3 - 1000 szt.;
- 4 - za 1 opakowanie;
- 38 - za 100 gramów;
- 5 - 1 kg;
- 6 - 1000kg ;
- 39 - 1 funt;
- 7 - 1 m2;
- 8 - za 1 metr;
- 9 - za 1 km;
- 10 - za zestaw;
- 11 - za 1 godzinę;
- 12 - w 1 dzień;
- 13 - na 1 miesiąc;
- 14 - na 1 rok;
- 15 - na sto;
- 16 - za akr;
- 17 - na hektar;
- 18 - na witrynę;
- 19 - za obiekt;
- 30 - za 1 ml;
- 31 - za 1 litr;
- 32 - za 1 km3;
- 33 - za 1 m3;
- 34 - za 1 dm33;
- 35 - za 1 cm3;
- 36 - за 1 mm3;
- 37 - за 1 hl;
Code: JavaScript |
<script> $(document).ready(function(){ $("#hotengine-shop-cart-form .hotengine-form-submit input[type='submit']").val('Wyślij zamówienie'); }); </script> |
Czytaj więcej... ↓
Tłumaczenie odbywa się za pomocą narzędzia Tłumaczenie wartości charakterystycznych.
Możesz także tłumaczyć za pomocą JavaScript. Jednak przy takim tłumaczeniu XML charakterystyka zostanie przesłana do MarketPlac w jednym języku.
Weźmy na przykład tłumaczenie z angielskiego na polski.
W takim przypadku, aby przesłać XML do MarketPlac, użyj głównego języka filtra wyszukiwania.
Показать ↓
Utwórz «Blok/Menu» i umieść go na stronach, na których włączony jest filtr wyszukiwania.
Na przykład w akapicie «Wprowadź znaki, po wykryciu których ma zostać wyświetlony Blok / Menu:» określ:
/pl/shop/
/pl/pers_shop/
Przykład tłumaczenia napisów, a także przycisk «Zastosuj»..
Code: js |
<script> $(function(){ var $dict = { 'Color': 'Kolor', 'Blue': 'Niebieski', 'Green': 'Zielony', 'Black': 'Czarny' } $.each($dict, function(txtorig, txtnew){ $("#shop_catalog_product_types_id_ajax .product_types_valuebox_checkbox span:contains('"+txtorig+"')").html(txtnew); $("#shop_catalog_product_types_id_ajax .shop_catalog_product_types_block_title:contains('"+txtorig+"')").html(txtnew); $(".shop_catalog_product_properties_block .shop_catalog_product_types_block_title:contains('"+txtorig+"')").html(txtnew); $(".shop_catalog_product_properties_block .product_types_valuebox_checkbox:contains('"+txtorig+"')").html(txtnew); }); setTimeout(() => { $(".hotengine-smart_search_submit_button").find("input").val("Apply"); $("#searchinp_smart_search .button").val("Apply"); }, 100); }); </script> |
Przykład tłumaczenia z przepisywaniem słów:
Code: js |
<script> $(function(){ var $dict = { 'Color': 'Kolor', 'Blue': 'Niebieski', 'Green': 'Zielony', 'Black': 'czarny' } $.each($dict, function(txtorig, txtnew){ $("#shop_catalog_product_types_id_ajax").html(function() { return $(this).html().replace(txtorig, txtnew); }); }); }); </script> |
Podobnie możesz dodać inne języki i nowe słowa, umieszczając kod w odpowiednich wersjach językowych serwisu.
Jak zmienić napisy w timerze?
Korzystając ze stylów CSS, możesz zastąpić słowa w liczniku czasu. Aby to zrobić np. w produkcie wstaw kod css html:
Code: css |
<style type="text/css"> <!-- /*napis pozostawiono do końca*/ html:lang(ru) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-day:after{ content:"дней"; } html:lang(ru) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-hourse:after{ content:"часов"; } html:lang(ru) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-minute:after{ content:"минут"; } html:lang(ru) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-seconds:after{ content:"секунд"; } html:lang(ru) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-left:after{ content:"осталось до конца акции!"; } html:lang(ru) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-done:after{ content:"Акция завершена!"; } html:lang(en) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-day:after{ content:"days"; } html:lang(en) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-hourse:after{ content:"hours"; } html:lang(en) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-minute:after{ content:"minute"; } html:lang(en) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-seconds:after{ content:"seconds"; } html:lang(en) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-left:after{ content:"left before the end of the campaign!"; } html:lang(en) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-done:after{ content:"Сampaign complete!"; } html:lang(pl) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-day:after{ content:"dni"; } html:lang(pl) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-hourse:after{ content:"godziny"; } html:lang(pl) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-minute:after{ content:"minuty"; } html:lang(pl) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-seconds:after{ content:"sekundy"; } html:lang(pl) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-left:after{ content:"pozostało do końca promocji!"; } html:lang(pl) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-description-akciya-countdown-l-done:after{ content:"Ackia ukończona!"; } html:lang(ru) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-akciya-countdown-numbers-days:after{ content:"дней"; } html:lang(ru) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-akciya-countdown-numbers-hours:after{ content:"часов"; } html:lang(ru) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-akciya-countdown-numbers-minutes:after{ content:"минут"; } html:lang(ru) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-akciya-countdown-numbers-seconds:after{ content:"секунд"; } html:lang(en) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-akciya-countdown-numbers-days:after{ content:"days"; } html:lang(en) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-akciya-countdown-numbers-hours:after{ content:"hours"; } html:lang(en) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-akciya-countdown-numbers-minutes:after{ content:"minute"; } html:lang(en) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-akciya-countdown-numbers-seconds:after{ content:"seconds"; } html:lang(uk) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-akciya-countdown-numbers-days:after{ content:"днів"; } html:lang(uk) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-akciya-countdown-numbers-hours:after{ content:"годин"; } html:lang(uk) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-akciya-countdown-numbers-minutes:after{ content:"хвилин"; } html:lang(uk) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-akciya-countdown-numbers-seconds:after{ content:"секунд"; } html:lang(pl) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-akciya-countdown-numbers-days:after{ content:"dni"; } html:lang(pl) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-akciya-countdown-numbers-hours:after{ content:"godziny"; } html:lang(pl) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-akciya-countdown-numbers-minutes:after{ content:"minuty"; } html:lang(pl) #hotengine-shop-product-description-akciya-countdown-block .hotengine-shop-product-akciya-countdown-numbers-seconds:after{ content:"sekundy"; } --> </style> |
lang(en) lub lang(pl) - jest to język, dla którego będzie odpowiedni napis, a następnie określa się sam blok, dla którego zostanie zmieniony napis.
Jak korzystać z Timera na innych stronach? Wklej poniższy kod, aby użyć naszego licznika odliczania:
Code: js |
<div id="hotengine-shop-product-description-akciya-countdown-block"><div id="hotengine-shop-product-description-akciya-countdown"></div><div class="hotengine-shop-product-akciya-countdown-numbers"><span class="hotengine-shop-product-akciya-countdown-numbers-days"><i></i></span><span class="hotengine-shop-product-akciya-countdown-numbers-hours"><i></i></span><span class="hotengine-shop-product-akciya-countdown-numbers-minutes"><i></i></span><span class="hotengine-shop-product-akciya-countdown-numbers-seconds"><i></i></span></div><span class="hotengine-shop-product-description-akciya-countdown-l-left"></span></div> <script type="text/javascript" src="/modules/jquery.cookie/jquery.cookie.min.js"></script> <link rel="stylesheet" type="text/css" href="/templates/javascript_timer_countdown/hotengine_timer_countdown.css" /> <script src="/templates/javascript_timer_countdown/hotengine_timer_countdown.js"></script> <script type="text/javascript"> <!-- $(function(){ var timerperiod = 5*12*60*60*1000; // okres timera, w przykładzie 5 dni 12 godzin ( 5 * 12 ...) (przykładowo tutaj data ciągle się przesuwa, czyli data bieżąca + XX dni.) // cookies ostatnia wizyta (odejmij czas ostatniej wizyty) if($.cookie("cookie_lastvisit_countdown_timer") && $.cookie("cookie_lastvisit_countdown_timer")!="null"){ var cookie_lastvisit_minus = (new Date()).getTime() - $.cookie("cookie_lastvisit_countdown_timer"); } else { var cookie_lastvisit_minus = 0; } var checkdate = timerperiod-cookie_lastvisit_minus; // aby sprawdzić datę ostatniej wizyty i zakończenie promocji if(checkdate>0){ counterdisable = false; } else { var cookie_lastvisit_minus = 0; counterdisable = true; }; var cookie_lastvisit_countdown_timerv = new Date().getTime() - cookie_lastvisit_minus; $.cookie("cookie_lastvisit_countdown_timer", cookie_lastvisit_countdown_timerv, {expires: null, path: "/"}); // cookies ostatnia wizyta (odejmij czas ostatniej wizyty) ts = (new Date()).getTime() + timerperiod - cookie_lastvisit_minus; //ustaw datę ważności hotengine_inittimer("hotengine-shop-product-description-akciya-countdown-block", new Date(ts)); }); //--> </script> |
Aby zmienić etykiety licznika, otwórz plik stylu /templates/javascript_timer_countdown/hotengine_timer_countdown.css, skopiuj jego kod i wklej go na stronie i zmień napisy.
Główne bloki witryny
ID i Class główne bloki witryny.#hotengine-wrapper
#hotengine-header
#hotengine-footer
|
* - Główny wewnętrzny blok z treścią jest realizowany za pomocą CSS Grid:
CSS Grid ↓
Code: CSS |
/*CONTENT GRID*/ #hotengine-content-container { display: grid; grid-template-areas:"container-left container-center container-right"; grid-template-columns:0% 1fr 0%; margin:0 auto; width:100%; } #hotengine-content-container[data-hasside="both"]{ grid-template-areas:"container-left container-center container-right"; grid-template-columns: auto 1fr auto; } #hotengine-content-container[data-hasside="left"]{ grid-template-areas:"container-left container-center"; grid-template-columns: auto 1fr; } #hotengine-content-container[data-hasside="right"]{ grid-template-areas:"container-center container-right"; grid-template-columns: 1fr auto; } .hotengine-wrap-container-side-center { grid-area: container-center; vertical-align:top; margin:0 auto; width:100%;} .hotengine-wrap-container-side-left { grid-area: container-left; vertical-align:top; margin:0 auto; width:auto; max-width:270px; } .hotengine-wrap-container-side-right { grid-area: container-right; vertical-align:top; margin:0 auto; width:auto; max-width:270px; } .menu_position_top { display:block; width:100%; } .menu_position_buttom { display:block; width:100%; } @media (max-width:767px){ #hotengine-content-container[data-hasside="both"]{ grid-template-areas:"container-center container-left container-right"; grid-template-columns: 1fr auto auto; } #hotengine-content-container[data-hasside="left"]{ grid-template-areas:"container-center container-left"; grid-template-columns: 1fr auto ; } #hotengine-content-container[data-hasside="right"]{ grid-template-areas:"container-center container-right"; grid-template-columns: 1fr auto ; } } /*CONTENT GRID*/ |
data-hasside - dodatkowy atrybut elementu #hotengine-content-container, który wskazuje na obecność lewego i prawego bloku.
- [data-hasside="left"] - lewy blok/menu jest obecny
- [data-hasside="right"] - obecny jest prawy blok/menu
- [data-hasside="both"] - jest lewy i prawy blok/menu
Za pomocą wskaźnika myszy możesz zmienić wysokość nagłówka strony, rozmiar logo, położenie menu głównego oraz slogan.
Jak stworzyć własny projekt nagłówka strony internetowej?
Utwórz Blok/Menu znajdujący się w Nagłówku (Nagłówku strony) i umieść w nim niezbędne elementy. Na przykład Div z numerem telefonu i Div z nazwą firmy (nie zapomnij nadać im odpowiedniej klasy lub identyfikatora, aby można było się do nich później odwołać).
Otwórz edytor projektu, ustaw położenie i właściwości projektowe tworzonych elementów w stylach CSS.
W ten sam sposób możesz stworzyć dowolne elementy graficzne na stronie i umieścić je w potrzebnych miejscach.
Wewnątrz tych bloków będzie utworzona treść lub menu.
Każdy «typ strony» wyróżnione odpowiednim blokiem, z nadaniem określonego identyfikatora.
Na przykład:
- Strony - #hotengine-content-page
- Aktualności - #hotengine-content-news
- Katalog artykułów - #hotengine-content-blog
- Katalog produktów - #hotengine-content-shop
- Katalog produktów (producenci) - #hotengine-content-shop
- Katalog produktów (kolekcje) - #hotengine-content-shop
Ten blok jest tworzony wewnątrz elementu #hotengine-content
Ponadto na stronach kategorii, na których znajduje się podrzędna lista stron, dodawana jest klasa:
- Katalog produktów — .hotengine-content-shop-category
- Katalog produktów (kolekcja) - .hotengine-content-shop-collection
- Katalog produktów (producenci) - .hotengine-content-shop-producer
- Katalog artykułów - .hotengine-content-blog-category
- Katalog wiadomości — .hotengine-content-news-category
Dodatkowo dla bloków/menu listy aktualności lub artykułów tworzony jest dodatkowy blok:
Menu ostatnich artykułów - #hotengine-content-menu-lastblogpost
Menu najnowszych wiadomości #hotengine-content-menu-lastnewspost
Jeśli używasz dołączonego szablonu, jego style mają pierwszeństwo przed niektórymi z powyższych wartości. Przed użyciem szablonu wtyczki zalecamy zresetowanie projektu do wartości domyślnej.
Css style domyślne: CSS plik Bloki strony głównej
Jeśli przesunięcia i pozycjonowania elementów nie można wykonać za pomocą CSS, możesz użyć Javascript i przesuwać obiekty po stronie.
Zmiana położenia niektórych elementów za pomocą Javascript.
Code: html |
<script type="text/javascript"> $(function(){ var newproducer = $(".hotengine-shop-product-desc-block .hotengine-shop-product-producer").html(); if(typeof newproducer !== typeof undefined && newproducer !== false && newproducer !='undefined' && newproducer !=''){ $(".hotengine-shop-product-desc-block .hotengine-shop-product-producer").hide(); $(".hotengine-shop-product-sku-box").after('<span class="hotengine-shop-product-producer">'+newproducer+'</span>'); } }); </script> |
W tym przykładzie sprawdzamy, czy producent jest określony. Jeśli producent jest określony, ukryj go i umieść za polem «Kod produktu».
«Zawijanie» elementów za pomocą Javascript.
Code: html |
<script type="text/javascript"> $(function(){ $(".element").wrap("<div class='new'></div>"); }); </script> |
W rezultacie obiekt z elementem klasy zostanie «owinięty» w element div z klasą new (<div class="new"><span class="element"></span></div>)
Katalog szablonów - https://templates.hotlist.biz/
Możesz włączyć śledzenie odwiedzających Google Analytics na stronie Ustawienia, w zakładce Statystyki/Google Analytics.
Tagi śledzenia będą wysyłać standardowe zdarzenia e-commerce dla Google Analytics 4 lub Google Tag Manager. Dodatkowo na stronie realizacji zamówienia lub przesłania formularza możesz dodatkowo ustawić własne kody konwersji.
Opisy zdarzeń:
Google Analytics 4: https://developers.google.com/gtagjs/reference/ga4-events?hl=pl
Google Tag Manager: https://developers.google.com/tag-manager/ecommerce-ga4?hl=pl
Ponadto będziesz mógł zaimplementować transfer własnych tagów za pomocą JavaScript, Shortcodes i Mikroznakowanie hotengine-markers, które umożliwiają zastępowanie danych dynamicznych.
- add_to_cart - dodanie produktu do koszyka
- add_to_wishlist - dodanie produktu do ulubionych
- begin_checkout - początek kasy
- purchase – udane zamówienie
- remove_from_cart – usunięcie towaru z koszyka
- search – Wyszukiwanie w witrynie
- select_item – wybór rodzaju produktu
- generate_lead - wyślij dane przez formularz
- sign_up - rejestracja
- view_cart - wyświetl koszyk
- view_item - wyświetl kartę przedmiotu
Dodatkowe zmienne:
- Typ strony — ecomm_pagetype
- ID produktu — ecomm_prodid
- Całkowita wartość towarów - ecomm_totalvalue
ID śledzenia Facebook Pixel można określić w ogólnych ustawieniach serwisu, w zakładce «Statystyki». Piksel będzie przesyłał dane o wizytach na stronie (PageView), zdarzeniach dodania produktu do koszyka (AddToCart), wyświetlenia produktu (ViewContent), rozpoczęcia (InitiateCheckout) i zakończenia kasy (Purchase). Koszt towarów jest tworzony w USD według kursu Twojej witryny.
Dodatkowo możesz utworzyć blok menu, aby samodzielnie wygenerować piksel z danymi produktu.
Instrukcja ↓
Uwaga! Tworząc kod piksela nie za pomocą ustawień witryny, musisz najpierw dodać główny kod piksela. Aby to zrobić, utwórz blok/menu z głównym kodem piksela i umieść go w znacznikach usług, które są wyświetlane na wszystkich stronach. W takim przypadku w ogólnych ustawieniach witryny nie trzeba określać kodu piksela. Jeśli kod piksela jest określony w ustawieniach głównych, oznacza to, że kod sprzedawcy produktów Facebooka jest już zainstalowany w witrynie.
Blok menu do generowania piksela z danymi produktu
Utwórz blok/menu z następującym kodem:
Code: |
<script> fbq('track', 'ViewContent', { content_name: '{HOTENGINE-SC:shop_cat_page_title}', content_ids: ['{HOTENGINE-SC:shop_cat_page_id}'], content_type: 'product', value: {HOTENGINE-SC:shop_cat_page_price}, currency: '{HOTENGINE-SC:shop_cat_page_currency_iso}' }); </script> |
Pokaż blok/menu na stronach: tylko na stronach sklepu
Wprowadź znaki, po wykryciu których ma zostać wyświetlony Blok/Menu: htm
Wprowadź znaki, które, jeśli zostaną znalezione, nie wyświetlają Bloku/Menu:koszyk
Jeżeli chcesz dodać zdarzenie po złożeniu wniosku przez Formularz, po tekście o pomyślnym przesłaniu danych dodaj poniższy kod:
Code: html |
<script> fbq('track', 'Purchase'); </script> |
- Witryna jest dostępna do korzystania z ogonów poleceń. Podczas zamawiania towaru lub wysyłania listu za pośrednictwem informacji zwrotnej do listu zostanie dodana informacja o źródle przejścia na Twoją stronę. Również podczas używania końcówek UTM (Łącznik URL) dane te zostaną dodane do pisma.
Oprócz standardowych danych linkera dostępny jest podział źródeł na grupy, które wykorzystywane są w statystykach sprzedaży do wyodrębnienia źródeł i wygodniejszego obliczania konwersji. Wartość grupy można ustawić za pomocą zmiennej GET «hotengine_referral_group». Jeśli nie określono żadnej wartości, a podano utm_source, zostanie ona użyta do określenia grupy hotengine_referral_group.
Dane źródła odesłania mogą być ukryte w ustawieniach przeglądarki odwiedzającego lub przy użyciu bezpiecznego protokołu strony źródłowej. Dodatkowo możesz dodatkowo grupować zamówienia za pomocą zmiennej "shop_cart_statistic_group" w linku, lub ręcznie po złożeniu zamówienia.
Możesz włączyć ogony skierowań na stronie Ustawienia, w zakładce Statystyki.
Przykład linku ze znacznikami UTM:
https://hotlist.biz/?utm_source=google&utm_medium=cpc&utm_term=slova&utm_content=soderjimoe&utm_campaign=nazvnie
Przykład linku z automatycznym znacznikiem Yandex Direct i znacznikiem UTM:
https://hotlist.biz/?utm_source=yandex_{source_type}&utm_medium=cpc&utm_term={keyword}&utm_campaign=id:{campaign_id}&utm_content=ad:{ad_id}|gbid:{gbid}|phrase:{phrase_id}|param1:{param1}|position_type:{position_type}|position:{position}|source:{source}|source_type:{source_type}|param2:{param2}
Pełne instrukcje
Przykład linku z automatycznym tagowaniem Google Adwords i znacznikami UTM:
https://hotlist.biz/?utm_source=google_adwords_{network}&utm_medium=cpc&utm_term={keyword}&utm_campaign={campaignid}&utm_content=creative:{creative}|from:{ifsearch:search}{ifcontent:content}|matchtype:{matchtype}|adgroupid:{adgroupid}|feeditemid:{feeditemid}|targetid:{targetid}|device:{device}|adposition:{adposition}|placement:{placement}|network:{network}|param1:{param1}|param2:{param2}
Pełne instrukcje
Na podany adres zostanie wysłane zapytanie POST, zawierające wszystkie dane dotyczące zamówienia, w tym dane kontaktowe klienta oraz listę towarów. Dane kontaktowe i informacje o zamówieniu zostaną przesłane w formacie JSON, żądanie POST.
Na przykład w 1s możesz zaimplementować przyjmowanie zamówień przez «HTTP usługa»->«SiteExchange» -> «POSTData»
Po złożeniu zamówienia na powyższy adres zostanie wysłane żądanie POST z następującymi danymi:
Code: JSON |
array ( 'ORDER' => array ( 'form_name' => 'NAME', 'form_soname' => 'SONAME', 'form_phone' => 'PHONENUMBER123', 'form_email' => 'email@email.com', 'add_info_addres' => 'FLAT', 'form_address' => 'ADDRESS', 'form_delivery_select' => 'Extend ADDRESS (Selected)', 'form_delivery_select_storehouse' => 'Extend PICKUP POINT (Selected)', 'form_address1' => 'Extend ADDRESS (Region)', 'form_address2' => 'Extend ADDRESS (City)', 'form_address3' => 'Extend ADDRESS (Street)', 'form_address4' => 'Extend ADDRESS (Home number)', 'form_address5' => 'Extend ADDRESS (Flat)', 'form_address6' => 'Extend ADDRESS (Branch number)', 'form_text' => 'ADD TEXT', 'post' => '1596538754', 'lang' => 'ru', 'form_delivery' => '', 'form_delivery_country_code' => '', 'order_id' => 'XXXXX', 'user_id' => XXXX, 'order_discount' => '', 'order_hash' => '55d4ed2ed42b2c116d9927c2b2ce7fef', 'time' => 1596538769, 'delivery' => '', 'delivery_id' => 0, 'abtesting' => 0, 'referral_group' => '', 'group' => '', 'referral_url' => 'https://hotlist.biz/....', 'referral_utm' => '', 'site_id' => '10954', 'site_url' => 'hotlist.biz', 'transaction_id' => 'XXXXX', 'value' => 2264, 'currency' => 'USD', 'shipping' => '0', 'items' => array ( 0 => array ( 'id' => '284430', 'name' => 'Trampki Adidas Originals Streetball FX9701 (42)', 'sku' => '200976_42', 'sku_parent' => '200976', 'variant' => '42 ', 'category' => 'sport_shoes', 'quantity' => '1', 'price' => '686', 'currency' => 'USD', 'complectation_id' => '409151', ), 1 => array ( 'id' => '284436', 'name' => 'Torba na buty z kieszenią Kite Education College', 'sku' => '200982', 'sku_parent' => '200982', 'variant' => '', 'category' => 'bags_for_shoes', 'quantity' => '1', 'price' => '736', 'currency' => 'USD', 'complectation_id' => 0, ), 2 => array ( 'id' => '284438', 'name' => 'Trampki ASICS Gel-Venture 8 Gs (43)', 'sku' => '200984_43', 'sku_parent' => '200984', 'variant' => '43 ', 'category' => 'sport_shoes', 'quantity' => '1', 'price' => '842', 'currency' => 'USD', 'complectation_id' => '409154', ), ), ), ) |
Jeśli po wysłaniu żądania Twój serwis zwróci dane JSON zawierające "Number" lub "crm_order_id", to do zamówienia zostanie dodany zewnętrzny numer zamówienia.
Na podany adres zostanie wysłane żądanie POST ze wszystkimi danymi zamówienia, które uległy zmianie w Statystyce sprzedaży. Informacje zostaną przesłane żądaniem POST w formacie JSON.
Na przykład w 1s możesz zaimplementować przyjmowanie zamówień przez «HTTP usługa»->«SiteExchange» -> «POSTData»
Ponadto możesz włączyć zewnętrzny dostęp do swoich statystyk, określając «Klucz dostępu do statystyk sprzedaży».
Po zmianie statusu zamówienia na powyższy adres zostanie wysłane zapytanie POST w formacie JSON z następującymi danymi:
Code: JSON |
array ( 'ORDER' = array ( 'shop_cart_statistic_crm_order_id' = '123', 'shop_cart_statistic_product_price' = '2264', 'shop_cart_statistic_product_currency' = '5', 'shop_cart_statistic_discount' = '', 'shop_cart_statistic_discount_before' = '', 'shop_cart_statistic_product_price_before' = '2264', 'shop_cart_statistic_product_currency_before' = '5', 'shop_cart_statistic_selldone_datestump_unsted' = '0', 'shop_cart_statistic_selldone' = '0', 'shop_cart_statistic_status_pay' = '0', 'shop_cart_statistic_allow_online_pay' = '0', 'shop_cart_statistic_selldone_from_seller' = '0', 'shop_cart_statistic_delivery_status' = '0', 'shop_cart_statistic_products_preview' = '', 'shop_cart_statistic_admin_note' = '', 'shop_cart_statistic_delivery_selected_id_before' = '3482', 'shop_cart_statistic_delivery_selected_id' = '3482', 'shop_cart_statistic_delivery_track_id' = '', 'shop_cart_statistic_delivery_track_id_link' = '', 'shop_cart_statistic_byer_name' = 'NAME SONAME', 'shop_cart_statistic_byer_phone' = 'PHONENUMBER123', 'shop_cart_statistic_byer_address' = 'ADDRESS', 'shop_cart_statistic_byer_address_eform0' => 'Extend ADDRESS (Selected)', 'shop_cart_statistic_byer_address_eform1' => 'Extend ADDRESS (Region)', 'shop_cart_statistic_byer_address_eform2' => 'Extend ADDRESS (City)', 'shop_cart_statistic_byer_address_eform3' => 'Extend ADDRESS (Street)', 'shop_cart_statistic_byer_address_eform4' => 'Extend ADDRESS (Home number)', 'shop_cart_statistic_byer_address_eform5' => 'Extend ADDRESS (Flat)', 'shop_cart_statistic_byer_address_eform6' => 'Extend ADDRESS (Branch number)', 'shop_cart_statistic_byer_email' = 'email@email.com', 'shop_cart_statistic_byer_paymentmethod_selected' => 'PaymentMethod (Selected)', 'shop_cart_statistic_group' = '', 'shop_cart_statistic_referral_group' = '', 'shop_cart_statistic_referral_url' = 'http://hotlist.biz', 'shop_cart_statistic_referral_utm' = '', 'shop_cart_statistic_site_manager_id_operator_current' = '1', 'cat_page_extend_1c_exportsalestat' = 'http://hotlist.biz/', 'buyer_id' = '1', 'manager_id_operator' = '0', 'order_products' = '284430,284436,284438', 'order_products_article' = '200976_42|200982|200984_43', 'order_products_num' = '1,1,1', 'order_products_complectationid' = '409151,407678,409154', 'order_products_prices' = '686,736,842', 'order_products_currency' = 'USD,USD,USD', 'order_products_titles' = 'Trampki Adidas Originals Streetball FX9701|Torba na buty z kieszenią Kite Education College|Trampki ASICS Gel-Venture 8 Gs', 'order_products_complectation_titles' = '42||43', 'order_products_prices_without_discount' = ',,', 'post' = '1596578917', 'shop_cart_statistic_product_sendto_userid' = '1', 'Zapisać' = 'Zapisać', 'order_id' = 63738, 'order_discount' = '', 'time' = 1596578927, 'delivery' = NULL, 'delivery_id' = '3482', 'referral_group' = '', 'group' = '', 'referral_url' = 'http://hotlist.biz/pl/pers_shop/sport_shoes/284438.htm', 'referral_utm' = '', 'site_url' = 'hotlist.biz', 'transaction_id' = 63738, 'crm_oder_id' = '123', 'value' = '2264', 'currency' = 'USD', 'items' = array ( 0 = array ( 'id' = '284430', 'name' = 'Trampki Adidas Originals Streetball FX9701', 'sku' = '200976_42', 'variant' = '42', 'quantity' = '1', 'price' = '686', 'currency' = 'USD', 'complectation_id' = '409151', 'price_without_discount' = '', ), 1 = array ( 'id' = '284436', 'name' = 'Torba na buty z kieszenią Kite Education College', 'sku' = '200982', 'variant' = '', 'quantity' = '1', 'price' = '736', 'currency' = 'USD', 'complectation_id' = '407678', 'price_without_discount' = '', ), 2 = array ( 'id' = '284438', 'name' = 'Trampki ASICS Gel-Venture 8 Gs', 'sku' = '200984_43', 'variant' = '43', 'quantity' = '1', 'price' = '842', 'currency' = 'USD', 'complectation_id' = '409154', 'price_without_discount' = '', ), ), ), ) |
'shop_cart_statistic_selldone' - '3', status transakcji //0 - Niezrealizowane, 1 - Zamówienie w trakcie realizacji, 3 - Zrealizowane, 2 - Anulowane, 5 - Anulowane (brak w magazynie), 6 - Anulowane (Anulowane), usuń - Usuń zamówienie
'shop_cart_statistic_status_pay' - '0', Status zamówienia //0-Nie określono, 1 - Zapłacono online, niezweryfikowano, 4 - Zapłacono online i zweryfikowano, 2 - Zapłacono, 3 - Przedpłacono, 5 - Oczekuje na płatność
'shop_cart_statistic_selldone_from_seller' - '1', Status dla kupującego //0 - Nie przetworzone, 1 - Przetwarzane, 3 - Wysłane / Przetworzone, 2 - Anulowane
'shop_cart_statistic_admin_note' - 'Uwaga dla administratora',
'shop_cart_statistic_delivery_status' - '0', '0 - Nie określono, 1 - Dostarczono, 2 - Nie dostarczono, 3 - Oczekuje na przesyłkę, 4 - Przekazano kurierowi, 5 - W drodze, 6 - Wysłano na pocztę, 7 - Wysłano na adres odbiorcy, 8 - Dostarczono pocztą Office, 9 - Dostarczone na adres odbiorcy'
'shop_cart_statistic_crm_order_id' - 'XXX', 'Zewnętrzny kod zamówienia (do użytku w zewnętrznych systemach CRM)'
Więcej o polach w statystykach sprzedaży możesz dowiedzieć się podczas edycji zamówienia.
Podczas zmiany produktów w zamówieniu wysyłane jest żądanie JSON z listą item, a także numer zamówienia:
Code: JSON |
array ( 'ORDER' = array ( 'order_id' = 63738, 'time' = 1596589307, 'transaction_id' = 63738, 'crm_oder_id' = '123', 'value' = 2264, 'currency' = 'USD', 'items' = array ( 0 = array ( 'id' = '284430', 'name' = 'Trampki Adidas Originals Streetball FX9701', 'sku' = '200976_42', 'variant' = '42', 'quantity' = '1', 'price' = '686', 'currency' = 'USD', 'complectation_id' = '409151', ), 1 = array ( 'id' = '284436', 'name' = 'Torba na buty z kieszenią Kite Education College', 'sku' = '200982', 'variant' = 'XX', 'quantity' = '1', 'price' = '736', 'currency' = 'USD', 'complectation_id' = '407678', ), 2 = array ( 'id' = '284438', 'name' = 'Trampki ASICS Gel-Venture 8 Gs', 'sku' = '200984_43', 'variant' = '43', 'quantity' = '1', 'price' = '842', 'currency' = 'USD', 'complectation_id' = '409154', ), ), ), ) |
Określ klucz dostępu do statystyk sprzedaży w ustawieniach, w zakładce «Sklep»;. Jeśli potrzebujesz uzyskać dostęp do statystyk sprzedaży przez zewnętrzną aplikację, możesz wykonać żądanie (POST/GET lub AJAX) do «/ajax.php?statistic_sell»
W takim przypadku musisz podać klucz w żądaniu z szyfrowaniem MD5. Na przykład, jeśli masz klucz «123», wtedy w zapytaniu będzie «202cb962ac59075b964b07152d234b70».
W takim przypadku prośba będzie wyglądać następująco: «/ajax.php?statistic_sell&key=202cb962ac59075b964b07152d234b70»
W żądaniu możesz określić dane do sortowania lub wyszukiwania (parametry GET / POST), które możesz pobrać ze swojej strony statystyk sprzedaży w centrum administracyjnym (/page.php?p=statistic_sell&mystat). Sortowanie i selekcja parametrów odbywa się za pomocą żądania GET/POST, na przykład, «&sort_dateperiod=1week» oznacza, że będą wyświetlane tygodniowe statystyki sprzedaży.
Dane są wyświetlane w formacie JSON.
Pamiętaj, że jeśli korzystasz z żądań stron otwartych dla odwiedzających, będą oni mogli uzyskać dostęp do Twoich statystyk sprzedaży za pomocą Twojego klucza .
Określ klucz dostępu do cennika sklepu w ustawieniach, w zakładce «Sklep». Pełna wersja cennika do pobrania znajduje się pod adresem «/csv_export_products.csv»
W takim przypadku musisz podać klucz w żądaniu z szyfrowaniem MD5. Na przykład, jeśli masz klucz «123», wtedy w zapytaniu będzie «202cb962ac59075b964b07152d234b70».
В таком случае запрос будет выглядеть так: «/csv_export_products.csv?key=202cb962ac59075b964b07152d234b70»
W żądaniu możesz określić dane do sortowania i wybierania pól, które możesz pobrać na swojej stronie eksportu w centrum administracyjnym (/page.php?p=submit_catalog_page&subpage&export_from_shop). Sortowanie i selekcja parametrów odbywa się za pomocą żądania GET/POST, na przykład, «&export_product_access=export_product_access» oznacza, że wyładuje pole z danymi o dostępie do produktu.
Dane są wyświetlane w formacie CSV.
Przesyłany plik jest zapisywany w pamięci podręcznej w celu zmniejszenia obciążenia i jest aktualizowany raz dziennie. Możesz usunąć pamięć podręczną za pomocą przycisku «Wyczyść pamięć podręczną przesyłania plików XML/CSV».
Przykład: https://blog.hotlist.biz/csv_export_products.csv?key=202cb962ac59075b964b07152d234b70
Więcej informacji o sposobach reklamy i promocji znajduje się na tej stronie. https://hotlist.biz/pl/user_guide_seo.html
Zalecamy włączenie «przekierowania z powiązaniem języka». Ta funkcja pomaga uniknąć duplikatów strony początkowej (duplikaty są szkodliwe dla SEO). Ze względu na fakt, że strona startowa domain.com i strona domena.com/pl/ w określonym języku to ta sama strona, zalecamy włączenie przekierowań 301 na stronę w określonym języku. Można to zrobić w Centrum administracyjnym, Ustawienia, Strona początkowa.
Jeśli planujesz używać własnej domeny, zalecamy tymczasowe ograniczenie dostępu do witryny i otwarcie jej po zakupie domeny.
Jeśli chcesz usunąć informacje o witrynie / firmie, otwórz stronę do zmiany informacji o witrynie / firmie i zaznacz pole «Usuń witrynę i wszystkie dane» u dołu. Po pewnym czasie informacje o firmie / stronie znikną z emisji wyszukiwarek.
Buforowanie plików multimedialnych
W oparciu o zalecenia wyszukiwarek i dla wygody odwiedzających włączyliśmy w Twojej witrynie «Kompresję danych» oraz Buforowanie plików graficznych i skryptów JavaScript. Czas pamięci podręcznej dla tych plików – jeden tydzień.Jeśli prześlesz nowy obraz na stary, zobaczysz stary obraz, dopóki pamięć podręczna przeglądarki nie zostanie wyczyszczona. Każda przeglądarka ma swój własny sposób czyszczenia pamięci podręcznej. Na przykład w Chrome, aby wymusić wyczyszczenie, musisz nacisnąć «CTRL + F5» w oknie przeglądarki, w Twojej witrynie.
Buforowanie serwera
Dodatkowo, aby przyspieszyć pracę serwisów, wdrożyliśmy również buforowanie niektórych danych tekstowych, które jest czyszczone automatycznie w przypadku ich zmiany. Jeśli jednak zmieniłeś zawartość strony/produktu/artykułu/menu, ale zmiany nie zostały wyświetlone na stronie, to musisz wymusić wyczyszczenie pamięci podręcznej za pomocą linku w panelu administracyjnym «Wyczyść pamięć podręczną» na stronie, na której zmiany nie były wyświetlane.Utrzymanie witryny i czyszczenie Buforowanie
Witryna przechowuje w pamięci podręcznej takie dane, jak «Typ produktu», «Promocje» (w tym licznik czasu), przesłane pliki «RSS/XML/CSV» oraz liczba produktów w kategorii. Aby wyczyścić pamięć podręczną RSS/XML/CSV, wybierz «XML/CSV/XLS/JSON» - «Wyczyść pamięć podręczną przesłanych plików XML/CSV» w panelu administratora.Aby przeliczyć odmiany, liczbę produktów w kategoriach i wyczyścić pamięć podręczną Promocji, przejdź do «Ustawień», «Sklepu» i na dole listy w pozycji «Przeliczanie produktów i kategorii» wybierz parametry niezbędne do ponownego obliczenia i konserwacji.
Ta procedura jest zalecana po większej aktualizacji danych w sklepie, zmianie kategorii, dodaniu i zmianie lub usunięciu dużej liczby odmian, dodaniu i zmianie kategorii, przeniesieniu tagów produktów do innych kategorii lub gdy timer wygasa w promocjach .
Administracja serwisu nie prowadzi działalności handlowej i nie ponosi odpowiedzialności za jakość usług/towarów sprzedawanych w ramach Hotlist.biz. Odpowiedzialność za wszystkie opublikowane towary i usługi ponoszą użytkownicy, którzy je dodali.
Łączność: https://hotlist.biz/pl/feedback.html