Grav-플러그인 튜토리얼

이 장에서는 플러그인을 설정하고 구성하는 방법에 대해 알아 봅니다. 또한 플러그인의 구조와 임의 페이지를 표시하는 방법도 이해합니다. 플러그인은 원래 Grav의 핵심 기능으로 완료되지 않은 추가 기능을 제공하는 소프트웨어입니다.

이 글에서는 랜덤 플러그인을 사용하여 랜덤 페이지를 보여줄 것입니다. 이 플러그인을 사용하기 전에 무작위 플러그인의 몇 가지 중요한 사항을 살펴 보겠습니다.

  • 이 플러그인을 사용하여 URI를 다음과 같이 사용하여 임의 페이지를 표시 할 수 있습니다. /random.

  • 페이지에 지정된 분류를 사용하려면 필터를 만듭니다. 다음과 같이 만들 수 있습니다.category : blog.

  • 필터 옵션을 사용하여 임의의 페이지를 표시 할 수 있습니다. 이것은 Grav에게 무작위 페이지에 표시 될 동일한 콘텐츠를 사용하도록 알려줍니다.

플러그인 설정

실제 플러그인을 사용하기 전에 다음 단계에 따라 플러그인에 대한 기본 설정을 만듭니다.

  • 라는 폴더 만들기 random 아래의 user/plugins 폴더.

  • 아래의 user/plugins/random 폴더, 즉 두 개의 파일을 만듭니다-

    • random.php 플러그인 코드에 사용

    • random.yaml 구성에 사용

플러그인 구성

무작위 플러그인을 사용하려면 몇 가지 구성 옵션이 필요합니다. 아래에 다음 줄을 작성합니다.random.yaml 파일.

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

Random은 사용자가 정의한 경로를 만듭니다. 분류 필터를 기반으로 무작위 항목을 선택합니다. 필터의 기본값은 다음과 같습니다.'category: blog' 무작위 선택에 사용됩니다.

플러그인 구조

플러그인 구조에서 다음 코드를 사용할 수 있습니다.

<?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 {
   }
?>

플러그인에서 여러 클래스를 사용하고 있습니다. use더 읽기 쉽게 만들고 공간도 절약합니다. 그만큼namespace Grav\PluginPHP 파일 상단에 작성해야합니다. 플러그인 이름을 작성해야합니다.titlecase 다음을 사용하여 확장해야합니다. Plugin.

당신은 기능을 구독 할 수 있습니다 getSubscribedEvents() ~로 onPluginsInitialized행사; 이것은 플러그인이 구독하는 이벤트를 결정합니다. 이와 같이 이벤트를 사용하여 다른 이벤트를 구독 할 수 있습니다.

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

이제 onPluginInitialized 아래의 이벤트 RandomPlugin 에 구성된 페이지 라우팅에 사용되는 클래스 random.yaml 파일.

방법 onPluginInitialized() 다음 코드를 포함합니다-

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

열린 우리당의 객체 경로에 대한 현재의 URI 정보를 포함하고 있습니다. 구성 객체는 임의의 플러그인을 라우팅하고 경로 객체에 저장에 대한 구성 값을 지정합니다.

이제 구성된 경로를 플러그인이 수신하도록 알리는 현재 URI 경로와 비교합니다. onPageInitialized 행사.

임의 페이지 표시

다음 방법으로 코드를 사용하여 임의의 페이지를 표시 할 수 있습니다.

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();
      }
   }
}

코드에서 볼 수 있듯이

  • 분류 개체를 변수에 할당 $taxonomy_map.

  • 다음을 사용하여 플러그인 구성에서 구성된 분류를 사용하는 필터 배열을 가져옵니다. config목적. 우리는 항목을 다음과 같이 사용하고 있습니다.category : blog.

  • 우리는 사용하고 있습니다 collection 임의의 페이지를 $collection. 필터와 일치하는 페이지를 다음에 추가하십시오.$collection 변하기 쉬운.

  • 현재 페이지 개체를 설정 해제하고 컬렉션에서 임의의 페이지로 표시되도록 현재 페이지를 설정합니다.

마지막으로, 아래와 같이 임의의 페이지를 표시하는 플러그인의 전체 코드를 볼 수 있습니다.

<?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();
         }
      }
   }
}

브라우저를 열고 localhost / folder_name / random 을 입력 하면 다음 스크린 샷과 같이 임의의 페이지가 표시됩니다.