Grav - Samouczki dotyczące wtyczek

W tym rozdziale zajmiemy się tym, jak można skonfigurować i skonfigurować wtyczkę. Ponadto zrozumiemy również strukturę wtyczki i sposób wyświetlania losowej strony. Wtyczka to oprogramowanie, które zapewnia dodatkowe funkcje, które pierwotnie nie były uzupełniane przez podstawową funkcjonalność Grav-a.

W tym artykule zamierzamy wyświetlić losową stronę za pomocą losowej wtyczki. Przed użyciem tej wtyczki zobaczymy kilka ważnych punktów losowej wtyczki.

  • Możesz użyć tej wtyczki do wyświetlenia losowej strony, używając URI jako /random.

  • Utwórz filtr, aby skorzystać z taksonomii określonej na stronach. Możesz tworzyć jakocategory : blog.

  • Możesz wyświetlić losową stronę, używając opcji filtru; informuje to Grav'a, że ​​ma używać tych samych treści, które mają być wyświetlane na losowej stronie.

Konfiguracja wtyczki

Wykonaj poniższe kroki, aby utworzyć podstawową konfigurację wtyczki przed użyciem właściwej wtyczki.

  • Utwórz folder o nazwie random pod user/plugins teczka.

  • Pod user/plugins/random folder, utwórz dwa pliki, a mianowicie -

    • random.php używany do kodu wtyczki

    • random.yaml używany do konfiguracji

Konfiguracja wtyczki

Aby użyć losowej wtyczki, musimy mieć kilka opcji konfiguracyjnych. Napiszemy następujące wiersze podrandom.yaml plik.

enabled:true
route:/random
filters:
   category:blog

Losowo tworzy zdefiniowaną trasę. Na podstawie filtrów taksonomii wybiera losowy przedmiot. Domyślna wartość filtru to'category: blog' który jest używany do losowego wyboru.

Struktura wtyczki

Poniższy kod może być użyty w strukturze wtyczki.

<?php
   namespace Grav\Plugin;
   use Grav\Common\Page\Collection;
   use Grav\Common\Plugin;
   use Grav\Common\Uri;
   use Grav\Common\Taxonomy;
   
   class RandomPlugin extends Plugin {
   }
?>

We wtyczce używamy kilku klas przy użyciu rozszerzenia useinstrukcje, dzięki czemu jest bardziej czytelny i oszczędza miejsce. Pliknamespace Grav\Pluginmusi być napisane na początku pliku PHP. Należy wpisać nazwę wtyczkititlecase i powinien zostać rozszerzony przy użyciu Plugin.

Możesz subskrybować funkcję getSubscribedEvents() do onPluginsInitializedzdarzenie; określa to, które zdarzenia subskrybuje wtyczka. W ten sposób możesz użyć wydarzenia, aby zapisać się na inne wydarzenia.

public static function getSubscribedEvents() {
   return [
      'onPluginsInitialized' => ['onPluginsInitialized', 0],
   ];
}

Użyjmy teraz onPluginInitialized wydarzenie pod RandomPlugin klasa używana do kierowania strony, która jest skonfigurowana w random.yaml plik.

Metoda onPluginInitialized() zawiera następujący kod -

public function onPluginsInitialized() {
   $uri = $this->grav['uri'];
   $route = $this->config->get('plugins.random.route');
   
   if ($route && $route == $uri->path()) {
      $this->enable([
         'onPageInitialized' => ['onPageInitialized', 0]
      ]);
   }
}

Obiekt Uri zawiera aktualne URI, informacje o trasie. Obiekt konfiguracyjny określa wartość konfiguracyjną do kierowania losowej wtyczki i zapisuje ją w obiekcie trasy.

Porównamy teraz skonfigurowaną trasę z bieżącą ścieżką URI, która informuje wtyczkę o nasłuchiwaniu pliku onPageInitialized zdarzenie.

Wyświetlanie losowej strony

Możesz wyświetlić losową stronę za pomocą kodu za pomocą następującej metody -

public function onPageInitialized() {
   $taxonomy_map = $this->grav['taxonomy'];
   $filters = (array) $this->config->get('plugins.random.filters');
   $operator = $this->config->get('plugins.random.filter_combinator', 'and');
   
   if (count($filters)) {
      $collection = new Collection();
      $collection->append($taxonomy_map->findTaxonomy($filters, $operator)->toArray());
      
      if (count($collection)) {
         unset($this->grav['page']);
         $this->grav['page'] = $collection->random()->current();
      }
   }
}

Jak pokazano w kodzie,

  • Przypisz obiekt taksonomii do zmiennej $taxonomy_map.

  • Pobierz tablicę filtrów używających skonfigurowanej taksonomii z konfiguracji wtyczki za pomocą configobiekt. Używamy przedmiotu jakocategory : blog.

  • Używamy collection aby zapisać losową stronę w $collection. Dołącz stronę, do której pasuje filtr$collection zmienna.

  • Usuń ustawienie bieżącego obiektu strony i ustaw wyświetlanie bieżącej strony jako losowej strony w kolekcji.

Na koniec zobaczymy pełny kod wtyczki, aby wyświetlić losową stronę, jak pokazano poniżej -

<?php
namespace Grav\Plugin;
use Grav\Common\Page\Collection;
use Grav\Common\Plugin;
use Grav\Common\Uri;
use Grav\Common\Taxonomy;

class RandomPlugin extends Plugin {
   public static function getSubscribedEvents() {
      return [
         'onPluginsInitialized' => ['onPluginsInitialized', 0],
      ];
   }
   public function onPluginsInitialized() {
      $uri = $this->grav['uri'];
      $route = $this->config->get('plugins.random.route');
      if ($route && $route == $uri->path()) {
         $this->enable([
            'onPageInitialized' => ['onPageInitialized', 0]
         ]);
      }
   }
   public function onPageInitialized() {
      $taxonomy_map = $this->grav['taxonomy'];
      $filters = (array) $this->config->get('plugins.random.filters');
      $operator = $this->config->get('plugins.random.filter_combinator', 'and');
      
      if (count($filters)) {
         $collection = new Collection();
         $collection->append($taxonomy_map->findTaxonomy($filters, $operator)->toArray());
         
         if (count($collection)) {
            unset($this->grav['page']);
            $this->grav['page'] = $collection->random()->current();
         }
      }
   }
}

Otwórz przeglądarkę i wpisz localhost / nazwa_folderu / random, aby zobaczyć losową stronę, jak pokazano na poniższym zrzucie ekranu -