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

रैंडम एक मार्ग बनाता है जिसे आप परिभाषित करते हैं। टैक्सोनॉमी फिल्टर के आधार पर, यह एक यादृच्छिक आइटम चुनता है। फ़िल्टर का डिफ़ॉल्ट मान है'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, मार्ग के बारे में जानकारी शामिल है। Config वस्तु यादृच्छिक प्लगइन मार्ग और मार्ग वस्तु में संग्रहीत के लिए विन्यास मान निर्दिष्ट करता है।

अब हम वर्तमान 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();
         }
      }
   }
}

निम्न स्क्रीनशॉट में दिखाए गए अनुसार यादृच्छिक पृष्ठ देखने के लिए अपना ब्राउज़र खोलें और लोकलहोस्ट / folder_name / यादृच्छिक टाइप करें -