publikacja: 14 grudnia 2009, 12:30; autor: Szymon Skulimowski http://wpninja.pl/tworzymy-wlasny-shortcode-wyswietlajacy-ogolna-liczbe-wpisow-i-komentarzy/

Tworzymy własny „shortcode” wyświetlający ogólną liczbę wpisów i komentarzy

Naszym zadaniem będzie wyświetlenie w dowolnym miejscu treści liczby wszystkich opublikowanych wpisów i komentarzy. W tym celu zapoznamy się nieco bliżej z jedną z ciekawszych funkcji WordPressa – znacznikami shortcode.

Narzędzie, którym się posłużymy

Słowem „shortcode” określa się specjalne znaczniki, które po umieszczeniu w treści wpisu generują odpowiednią mieszankę kodu HTML. Przykładowo:

  • [gallery]
    wyświetla galerię zdjęć, które zostały dodane do wpisu,
  • [ratings]
    wyświetla system ocen wpisu (WP-PostRatings),
  • [poll id="2"]
    wyświetla ankietę o ID = 2 (WP-Polls),
  • [youtube width="400" height="300"]eBGIQ7ZuuiU[/youtube]
    wyświetla określony film z serwisu YouTube o podanych rozmiarach (youtube with style).

Na chwilę obecną WordPress posiada tylko jeden standardowy shortcode – [gallery], reszta to już sprawka odpowiednich wtyczek. Nic nie stoi jednak na przeszkodzie aby stworzyć własny shortcode.

I wbrew pozorom nie jest to wcale trudne!

Efekt, który chcemy osiągnąć

Naszym zadaniem będzie stworzenie znacznika shortcode, który wstawiony w dowolnym miejscu treści wyświetli liczbę wszystkich opublikowanych wpisów i komentarzy.

Kawałek kodu PHP, który pobierze z bazy odpowiednie dane już mamy – wystarczy sięgnąć po artykuł Jak wyświetlić łączną ilość wpisów i komentarzy.

Aktualizacja (15.12.2009): Dzięki uprzejmości Grzegorza mamy poprawiony kod PHP.

Moglibyśmy tutaj wykorzystać jedną z wtyczek opisanych w artykule PHP we wpisach i widgetach i byłoby pozamiatane. Nam jednak zależy na trzech istotnych rzeczach:

  • zapewnienie komfortu użytkowania,
  • ograniczenie niebezpieczeństwa,
  • unikanie kopiowania kodu.

To tyle jeśli chodzi o teorię. Teraz to co tygrysy lubią najbardziej czyli praktyka!

Własny shortcode – tworzenie

Poniższy kod dodajemy do pliku functions.php:

function pokaz_statystyki ($atrybuty) {
	extract (shortcode_atts (array('typ' => ''), $atrybuty));
	if ($typ == "ilosc-wpisow") {
		$posts_stats = wp_count_posts();
		$wynik = $posts_stats->publish;
	}
	elseif ($typ == "ilosc-komentarzy") {
		$comments_stats = wp_count_comments();
		$wynik = $comments_stats->approved;
	}
	return $wynik;
}
 
add_shortcode('statystyki', 'pokaz_statystyki');

Najważniejszy zapis znajduje się w ostatnim wierszu – za jego pośrednictwem został dodany shortcode o nazwie „statystyki”. Od teraz, za każdym razem gdy w treści wpisu pojawi się [statystyki] zostanie uruchomiona funkcja „pokaz_statystyki” (wiersze 1-14).

W wierszu 2. przejmowana jest wartość atrybutu „typ”. W wierszu 3. i 7. widać, że shortcode reaguje na dwie wartości atrybutu – „ilosc-wpisów” oraz „ilosc-komentarzy”. W zależności od tego jaki typ wybierzemy zostanie pobrana odpowiednia wartość z bazy danych.

Więcej o samym tworzeniu znaczników shortcode:

Własny shortcode – korzystanie

Zgodnie z tym co stworzyliśmy powyżej możemy teraz w dowolnym miejscu w treści wpisu bądź strony zamieścić shortcode:

  • [statystyki typ="ilosc-wpisow"]
    wyświetli ilość wszystkich opublikowanych wpisów,
  • [statystyki typ="ilosc-komentarzy"]
    wyświetli ilość wszystkich zatwierdzonych komentarzy.

Koniec. Prawda, że nie było to zbyt trudne? :-)

Zachęcam do własnych eksperymentów z tą funkcjonalnością WordPressa – w razie problemów służę pomocą za pośrednictwem poniższych komentarzy.

Komentarze (11)

  1. Piotr Sajnog (14 grudnia 2009, 13:59) #:

    Dzięki za artykuł, niebawem przetestuję to rozwiązanie :)

  2. długi (14 grudnia 2009, 14:13) #:

    Fajnie :) Też sobie po testuje :) Dzięki

  3. Marcin (14 grudnia 2009, 16:38) #:

    Można taki shortcode wstawić do widgetu tekstowego?

  4. palmiak (14 grudnia 2009, 17:26) #:

    Coś się chyba we wpisie posypało. Po kodzie źródłowym się siepie z deka.

    Fajna zabawka. Trzeba promować shrttagi bo to naprawdę ułatwia robotę a sporo ludzi o nich nie wie. W końcu każdą funkcję można pod to podpiąć. Na vivee mamy pod podpięte ‚polecane stronki’ np. czyli wtyczka która pobiera dane z delicji.

  5. Paweł Rabinek (14 grudnia 2009, 20:32) #:

    Wow, nie wiedziałem, że to można tak łatwo zrobić… Dzięki za pomocny trick :)

  6. Grzesiek (15 grudnia 2009, 0:39) #:

    Hej Szymon – ciekawy wpis.

    Jedna uwaga – i jednoczesnie apel do wszystkich – unikajcie pisania bezposrednich zapytan SQL do bazy w pluginach. Rodzi to ryzyko, ze jesli w przyszlosci struktura bazy danych WP sie zmieni, wasz kod moze nie dzialac prawidlowo. Zawsze warto sprawdzic, czy informacja, ktora chcemy uzyskac nie jest czasem dostepna poprzez jakas funkcje API WordPressa. W tym konkretnym przypadku tak jest:

    1) ilosc wpisow na blogu mozna dostac w ten sposob:

    $posts_stats = wp_count_posts();
    $wynik = $posts_stats->publish; //globalna liczba opublikowanych postow na blogu

    2) ilosc komentarzy bardzo podobnie:

    $comments_stats = wp_count_comments();
    $wynik = $comments_stats->approved; //globalna liczba opublikowanych komentarzy na blogu

    Obie funkcje wp_count_posts() i wp_count_comments() zwracaja obiekty. Polecam zrobic var_dump() i sprawdzic jakie jeszcze statystyki sa dostepne.

    Pozdrawiam :)

  7. Szymon Skulimowski (15 grudnia 2009, 11:54) #:

    Grzesiek – dzięki stokrotne za słuszną uwagę i zaprezentowanie lepszego kodu – naniosłem stosowne poprawki do treści artykułu :-).

  8. Jakub Milczarek (19 grudnia 2009, 12:40) #:

    Łatwo, prosto i przyjemnie :) – na 100% wykorzystam to rozwiązanie w kilku projektach!

  9. Szymon Skulimowski (20 grudnia 2009, 22:40) #:

    Można taki shortcode wstawić do widgetu tekstowego?

    Normalnie nie można używać żadnych znaczników shortcode w widgetach.

    Żeby to zmienić wystarczy jednak dodać do pliku functions.php (plik znajduje się w katalogu aktualnie używanego szablonu graficznego – .../wp-content/themes/nazwa-szablonu/functions.php) następującą linijkę:

    add_filter('widget_text', 'do_shortcode');
  10. Krzysztof (28 grudnia 2009, 17:09) #:

    Ciekawy artykuł.
    Mam tylko jedno zastrzeżenie a mianowicie chodzi mi o małe błędy dotyczące fragmentu:

    „[...]zostanie uruchomiona funkcja „pokaz_statystyki” (wiersze 1-22).
    W wierszu 2. przejmowana jest wartość atrybutu „typ”. W wierszu 4. i 13. widać, że shortcode [...]”

    Mam na myśli to że cały kod składa się z 14 linijek a w tekście mowa jest o 22

  11. Szymon Skulimowski (28 grudnia 2009, 21:57) #:

    Poprawione – dzięki Krzysiek.

Dodaj własny komentarz

Odnośniki z innych stron (1)

Lista innych stron, które w jakiś sposób odnoszą się do opublikowanej tutaj treści:

  1. O WordPress w *.pl | WPBlogger.pl

    [...] WPNinja.pl/tworzymy-wlasny-shortcode-wyswietlajacy-ogolna-liczbe-wpisow-i-komentarzy/ [...]