Układanie Fundamentów Tematu
Dwa pierwsze rozdziały tego przewodnika były teoretyczne; ten będzie praktyczny.
Zamierzamy stworzyć fundamenty plików i folderów dla twojego tematu, są dwie drogi żeby to osiągnąc:
Zduplikowac domyślny motyw i dostosuj pliki..
Tworzenie każdego pliku od podstaw.
Nie trzeba dodawać, że radzimy wybrać pierwszą opcje:Minimalny PrestaShop wymaga wielu plików i lini kodu, o niektórych z nich możesz zapomnieć kiedy startujesz od zera.
Budowanie PrestaShop jest skomplikowanym przedsięwzięciem. Na przykład w porównaniu z motywem WordPress, który może pracować z pojedynczym plikiem index.php
, minimalny PrestaShop wymaga wiele więcej stron: Stronę domową, stronę produktu, strony konta użytkownika, stronę koszyka, strony procesu zamówienia, itd. Budowanie motywu strony e-commerce oznacza o wiele bardziej skomplikowane zestawienie ze sobą stron i szablonów.
To dlatego radzimy, aby rozpocząć swój własny motyw za pomocą fundamentów położonych przez domyślny motyw. Kompletny i sprawdzony, domyślny motyw PrestaShop zapewnia, że wszystkie niezbędne strony są już na miejscu, pozostawiając swobodę przerobienia wyświetlanej strony, korzystając z własnych obrazów, w celu zwiększenia jej własnych skryptów.
Odkrywanie prawdy, opierając się na wcześniejszych odkryciach: Kopiowanie domyślnego motywu
Duplikowanie plików z domyślnego motywu jest łatwe, a nawet jest to możliwe za pomocą dwóch różnych sposobów.
Z Panelu administracyjnego
Panel administracyjny PrestaShop może pomóc stworzyć nowy katalog tematyczny na podstawie jakiegokolwiek innego zainstalowanego motywu, a to wszystko w kilka kliknięć:
Przejdź do "Szablony" strona preferencji.
Kliknij przycisk "Dodaj nowy szablon" w prawym górnym rogu ekranu.
W oknie "Importuj szablon" które zostanie otwarte, przejdź do sekcji "Utwórz nowy szablon" i kliknij przycisk "Tworzenie nowego szablonu".
W utworzonym formularzu wypełnij różne pola:
Nazwa szablonu.Daj mu swoją unikalną nazwę - można na przykład poprzedzić ją nazwą swojej firmy lub inicjałami. Upewnij się na stronie Addonsów, że żaden inny szablon nie używa tej nazwy, tym bardziej jeśli zamierzasz sprzedać ten szablon w internecie.
Podgląd obrazu w szablonie. Ponieważ nie masz jeszcze ostatecznego projektu do szablonu, można to zrobić póżniej
Domyślna lewa kolunma/Domyślna prawa kolumna. Czy planujesz mieć na swoim szablonie boczny pasek tresći? Jeśli tak to po której stronie? Sprawdź odpowiednie opcje.
Ilość produktów na stronie. Kolejne pole informacyjne które możesz edytować później.
Nazwa katolgu szablonu. Powinieneś użyć tej samej nazwy co nazwa szablonu, małymi literami spacje zastąpić myślnikami. Na przykład,"Mój Testowy Szablon" będzie się nazywał "mój testowy-szablon" jako nazwa folderu.
Kopiowanie brakujących plików z istniejącego tematu. W tym miejscu należy wskazać temat, aby skopiować pliki. To jest bardzo ważne! Możesz wybrać domyśny temat, albo wszystkie inne dostepne z których chcesz zbudować swój temat.
Responsywność. Czy planujesz, aby twój projekt szablonu dostosowywał się do każdego rozmiaru ekranu? Jeśli tak to włącz tą opcje na "Tak".
Kliknij przycisk "Zapisz".
PrestaShop utworzy folder szablonu i skopiuje wszystkie potrzebne pliki ze szablonu źródłowego, dzięki czemu można swobodnie eksperymentować z tymi plikami.
Z poziomu systemu operacyjnego/ serwera FTP
Oczywiście, że można tworzyć kopie samemu:
Przejdź do folderu
/themes
w instalacji PrestaShop (online lub na pulpicie)Stwórz nowy folder dla swojego szablonu. Powinna to być ostateczna nazwa twojego szablonu, w jednym słowie małymi literami. Upewnij się czy na stronie Addons żaden inny szablon nie używa już tej nazwy, tym bardziej jeśli masz plan ewentualnej sprzedaży szablonu przez internet.
Skopiuj treści folderu tematycznego (dla 1.6 motywu domyślnego,
/default-bootstrap
) i wklej go w nowo utworzonym folderze.
To wszystko!
Czyszczenie
Zarówno domyślny motyw i twoja instalacja PrestaShop zawierają ładunek treści i stylów, które niekoniecznie są przydatne do twojego szablonu. Na przykład wiele, modułów jest zainstalowanych i aktywowanych domyślnie przez instalatora PrestaShop. Chociaż niektóre z nich są niezbędne do prawidłowego funkcjonowania kompletnego sklepu, inne mogą być po prostu odłożone na bok podczas budowania szablonu. To jest twój obowiązek jako twórcy motywu zbudować szablony i style przynajmniej dla wszystkich modułów domyslnego PrestaShop (albo dostosować te domyślne) wraz z tymi dodatkowymi modułami które mają wspierać twój szablon.
Chodzi o to, że motyw musi pochodzić z niestandardowych szablonów i plików CSS dla domyślnych modułów PrestaShop. Te pliki szablonów przechowywane są w podfolderze /modules
w folderze tematycznym subfolder, natomiast style są w podfolderze /css/modules
.
Na przykład, w domyśłnym motywie, pliki do modułu Layered Navigation mozna znaleźć w następujących ścieżkach:
Plik szablonu:
/themes/default-bootstrap/modules/blocklayered/blocklayered.tpl
.Plik CSS:
/themes/default-bootstrap/css/modules/blocklayered/blocklayered.css
.
Jak widać, jeśli chcemy zmienić moduły występujące na stronie głównej, przy jednoczesnym zachowaniu jego układu, trzeba tylko zmienić swój plik CSS i zostawić sam plik szablonu. Na przykłąd aby zmienić stylistykę modułu Layered Navigation, należy umieścić swoją dostosowaną wersję w tym folderze: /themes/YOUR_THEME/css/modules/blocklayered/blocklayered.css
. Wystarczy upewnić się że korzysta się z tej samej ścieżki dostepu do orginalnych plików modułu.
Niezbędne moduły
Niezbędne moduły szablonów to:
Nazwa modułu | Dlaczego jest niezbędny |
blok koszyka | Wyświetla cały proces zamówienia i płatności. |
blok moje konto | Wyświetla proces tworzenia użytkownika |
Po prostu nie można sprzedać produktu, jeśli ywój szablon nie obsługuje tych modułów.
Konieczne moduły
Są również moduły, które nie są konieczne do funkcjonawania sklepu, ale powinny być uwględnione przy projektowaniu motywu. Należy starać się budować jak najlepiej swój szablon mając te moduły w pamięci.
Konieczne moduły szablonu to:
Nazwa modułu | Dlaczego jest niezbędny |
blok kategorii | Wyświetla kategorie produktów |
blok cms | Listy i wyświetlenia stron CMS (tj. Zasady i warunki, nota prawna itp.) |
blok kontakt | Wyświetla informacje o Obsłudze Klienta |
blok informacji kontaktowych | Wyświetla informacje o kontakcie do sklepu. |
blok kontaktu w stopce | Wyświetla w stopce linki do stron konta użytkownika |
blok wyszukiwania | Wyświetla wyszukiwarkę i jej wyniki |
blok tagów | Wyśwuetla tagi produktów |
produkty wyróżnione | Wyświetla produkty wyróżnione |
Moduły które dobrze mieć
W końcu moduły które nie są tak ważne jak reszta z nich , ale moga przynieść dużo korzyści dla sklepu i pomoc klientom dowiedzieć się więcej o produktach i sklepie. Powinno się zaprojektować sklep z tymi aktywnymi modułami.
Moduły szablonu które dobrze mieć to:
Nazwa modułu | Dlaczego jest niezbędny |
blok najlepiej sprzedające | Wyświetla produkty które się najlepiej sprzedają |
blok warstwowy | Wyświetla warstwowe filtry nawigacji |
blok linków | Wyświetla dodatkowe linki niestandardowe |
blok producentów | Lista i wyświetlenia producentów/marki z produktów sklepu |
blok nowych produktów | Wyświetla najnowsze produkty |
blok newslettera | Wyświetla formularz, w którym klienci mogą się zapisać do newslettera Twojego sklepu |
blok kanałów rss | Wyświetla zawartość kanału RSS z innej strony |
blok społecznościowy | Wyświetla informacje o stronach społecznościowych w twoim sklepie |
blok specjalny | Wyświetla bieżące rabaty |
blok sklepu | Wyświetla link do znajdowanego sklepu |
blok dostawcy | Listy i wyświetlenia dostawców sklepu |
blok ostatnio przeglądane | Wymienia produkty, które klient ostatnio oglądał |
blok listy życzeń | Wyświetla liste życzeń klienta |
komentarz produktów | Wyświetla sekcje komentarza na każdej stronie produktu |
Wszytkie te szablony modułu są włączane domyślnie w domyślnym folderze tematu /modules
, ponieważ są one funkcją strony czołowej są one potrzebne do tego szablonu Można bezpiecznie włączyć/odinstlować dowolny inny moduł na stronie panelu admistracyjnego "Moduły". Dzięki temu można rozpocząc z czystym kontem.
W pełni czysty stan byłby wtedy kiedy wszystkie moduły zostałyby wyłączone i ponownie zainstalowane jeden po drugim, co pozwala na włączenie ich do swojego projektu podczas tworzenia szablonu. Jest to dobry sposób pracy, który pomaga ustalić jaka treść zepsuła układ strony, ale osiągniecie celu trwa dłużej. Przechowując znany zestaw podstawowych modułów pomaga to zbudować swój szablon szybciej, jednocześnie ma się pewność że będzie to działać w większości konfiguracji
Tworzenie treści
Twój temat będzie wyświetlał treść wzięte z bazy PrestaShop. Niezależnie czy planujecie zatrzymać szablon dla siebie albo podzielić się /sprzedać go aby inni mogli z niego skorzystać, nie można po prostu rozpocząć projektowania bez zawartości, wraz z aktywacją niektórych kluczowych cech, które w każdym sklepie można używać ze sobą.
Dane demo instalowane z PrestaShop wystarczą do pomocy, ponieważ obejmują produkty, kategorie, sklepy itd. Począwszy od świeżej instalacji PrestaShop daje Tobie przewagę z zawartością demo, pusty sklep będzie wymagał aby rozpocząć dodawanie zawartości (albo fałszywe lub prawdziwe) do sklepu, aby zobaczyć jak twój szablon na to reaguje.
Projekt !
Teraz gdy domyślny motyw został przekształcony we własnym folderze, to jest czas aby zbadać jego pliki: Szablony Smarty, zasady CSS, kody JavaScript, połozenie zaczepów i bloków treści... Wszytko można zmienić, a do Ciebie należy decyzja jak chcesz to przerobić!
Pliki CSS
Możesz edytować styl tematu poprzez edycje plików CSS.
Plik global.css
zawiera globalną strukturę i najważniejszą część projektowania szablonu
Zazwyczaj jest jeden arkusz stylów na kontroler. Na przykład strona produktu ma plik product.css
.
Jeśli używasz Sass/Compass, musisz najpierw edytować pliki SCSS, następnie zregenrować pliki CSS. Gdy arkusz stylów jest generowany z pliku SCSS, linia i plik SCSS są wymienione w pliku.Sample code from product.css
Obrazy
Obrazy które są używane przez szablon (nie przez produkty) są przechowywane w folderze szablonu/img
, natomiast obrazy które mają być użyte przez sklep są przechowywane w folderze głównym /img
instalacji PrestaShop.
Ikony są szczególnym przypadkiem: PrestaShop 1.6 używa FontAwesome jako zestaw ikon: http://fontawesome.io/. Jest to trzcionka wykonana z ikon, co daje wektorowe skalowanie ikon, które można błyskawicznie dostosować.
Używanie FontAwesome pozwala na:
użycie pojedynczego pliku do wyświetlania różnych ikon.
cieszyć się elastycznością: Rozmiaru, koloru, cieni, i wszystkim tym co można zrobić z mocą CSS.
doskonałe renderowanie na wszystkich rozmiarach ekranów: PC, TV, Retina, itd.)
Pliki Szablonu
Pliki szablonu Smarty (.tpl
) jest sposobem na odzielenie treści od sposobu w jaki treść jest prezentowana.
Szablon ma tylko kilka dynamicznych elementów (gdzie idzie zawartość). Ułatwia to projektowanie i aktualizacje Twoich obydwu stron, za równo w odniesieniu do treści jak i jej prezentacji.Template file for the HTTP 404 Error page
Silnik szablonu używa {...} do obsługi instrukcji. Pozostała część dokumentu jest wysyłana do przeglądarki
Możliwe jest użycie szablonu do generowania plików HTML, a także plikó XML, plików tekstowych etc.
Pliki PDF
Pliki PDF są także generowane z szablonów Smarty (.tpl
pliki). Główna różnica między tym jak pliki szablonów używają do generowania HTML, jest taka że szablony PDF nie pozwalają na zasoby zewnętrzne takie jak CSS. Dlatego należy użyć wewnętrznej stylizacji albo inline, aby zmienić styl twojej faktury, opóźnienia zamówienia, opóźnienia zwrotu, etc. Domyśłna isnatalcja PrestaShop pochodzi z dwóch stylów szablonów: delivery-slip.style-tab.tpl
i invoice.style-tab.tpl
. Możesz je w znaleźć folderze/pdf/
. Poniższa tabela pokazuje jak zakładki stylu są powiązane:
Szablon PDF | Zakładka stylu |
Opóźnienia dostawy |
|
Kolejność dostawy |
|
Zwroty zamówienia |
|
Faktura |
|
Opóźnienia zamówień |
|
Zauważ, że jeśli chcesz zastosować inny szablon stylu, trzeba będzie zastąpić odpowiedni PDF Class w katalogu /classes/pdf/
.
Wewnętrzna zakładka w katalogach stylu może być stosowana tylko do głównych plików szablonów PDF, takich jak invoice.tpl
, delivery-slip.tpl
, etc. W celu ponownego użycia zmiennych w szablonach które są włączone w szablonach, można przypisać zmienne Smarty lub zastosować stylizacje inline odzielnie w każdym z tych plików.
Rozdrapywać daną rzecz: Tworzenie wszystkich plików od zera
Oh naprawdę? Chcesz zrobić to ręcznie? To odważne, ale postaramy się pomóc
Po pierwsze, jets lista niezbędnych plików szablonów (First, here is the list of necessary template files (spoiler alert: istnieje z ich 60, Tak wszystkie są konieczne do różnych funkcji PrestaShop):
Nazwa pliku | Dlaczego jest niezbędny | Inne pliki szablonów używane przez ten szablon w domyślnym temacie |
404.tpl | Wyświetla się kiedy plik nie może być znaleziony | |
address.tpl | Umożliwia kientowi stworzyć nowy adres. |
|
addresses.tpl | Umożliwia klientowi oglądanie aktualnych adresów | |
authentication.tpl | Umożliwia klientowi zalogować się do jego konta. |
|
best-sales.tpl | Wyświetla najlepiej sprzedające się produkty. |
|
breadcrumb.tpl | Wyświetla ścieżkę kategorii, do obecnego produktu/kategorii |
|
category-cms-tree-branch.tpl | Biegnie przez kategorie CMS w celu ich wyświetlania. |
|
category-count.tpl | Wyświetla liczbę produktów w kategorii | |
category-tree-branch.tpl | Biegnie przez kategorie produktów w celu ich wyświetlenia. |
|
category.tpl | Wyświetla zawartość kategorii: widoku, obrazu, tekstu, porównywarki produktów itd. |
|
cms.tpl | Wyświetla zawartość strony CMS. | |
contact-form.tpl | Wyświetla formularz kontaktowy klienta. |
|
discount.tpl | Wyświetla listę kuponów klienta | |
errors.tpl | Wyświetla aktualny błąd/błędy | |
footer.tpl | Wyświetla stopkę |
|
global.tpl | Definiuje kilka zmiennych Smarty, i najbardziej znaczące z nich JavaScript | |
guest-tracking.tpl | Wyświetla stronę śledzenia dla klientów gości (interesantów bez konta) |
|
header.tpl | Wyświetla nagłówek: HTML doctype, linki do plikó CSS, itd. |
|
history.tpl | Wyświetla wszystkie swoje poprzednie zamówienia dla klienta |
|
identity.tpl | Wyświetla i aktualizuje dane osobowe klienta |
|
layout.tpl | Uruchamia główne paczki tematu: Nagłówek, stopkę, kolumny, aktualny szablon i edycje na żywo. |
|
maintenance.tpl | Wyświetla specjalną stronę gdy sklep jest w konserwacji | |
manufacturer-list.tpl | Wyświetla listę wszystkich producentów |
|
manufacturer.tpl | Wyświetla produkty od tego samego producenta. |
|
my-account.tpl | Wyświetla stronę konta klienta | |
nbr-product-page.tpl | Wyświetla liczbę produktów na bierzącej stronę | |
new-products.tpl | Displays a block with the new products. |
|
order-address-multishipping-products.tpl | Wyswietla adresy dostarczenia produktów w sytuacji multishippingu |
|
order-address-multishipping.tpl |
| |
order-address-product-line.tpl | ||
order-address.tpl |
| |
order-carrier.tpl |
| |
order-confirmation.tpl |
| |
order-detail.tpl | ||
order-follow.tpl | ||
order-opc-new-account.tpl | ||
order-opc.tpl |
| |
order-payment.tpl |
| |
order-return.tpl |
| |
order-slip.tpl | ||
order-steps.tpl | ||
pagination.tpl | ||
password.tpl |
| |
prices-drop.tpl |
| |
product-compare.tpl | ||
product-list-colors.tpl | ||
product-list.tpl | ||
product-sort.tpl | ||
product.tpl |
| |
products-comparison.tpl | ||
restricted-country.tpl | ||
scenes.tpl | ||
search.tpl |
| |
shopping-cart-product-line.tpl | ||
shopping-cart.tpl |
| |
sitemap.tpl |
| |
stores.tpl | ||
store_infos.tpl | ||
supplier-list.tpl | ||
supplier.tpl | Umożliwia wyświetlanie produktów za dostawcę |
|
Last updated