Grav - थीम्स मूल बातें

थीम आपके Grav साइट के लुक को नियंत्रित करती है। Grav में थीम्स शक्तिशाली ट्विग टेंपलेटिंग इंजन के साथ बनाए गए हैं ।

सामग्री पृष्ठ और टहनी टेम्पलेट

आपके द्वारा बनाए गए पृष्ठ, किसी विशिष्ट टेम्पलेट फ़ाइल को नाम से या पृष्ठ के लिए टेम्पलेट हेडर चर को सेट करके संदर्भित करते हैं। पृष्ठ नाम का उपयोग सरल रखरखाव के लिए सलाह दी जाती है।

Grav Base पैकेज स्थापित करने के बाद, आप पाएंगे defauld.mdउपयोगकर्ता / पृष्ठों / 01.home फ़ोल्डर में फ़ाइल। फ़ाइल का नाम,default Grav को बताता है कि इस पृष्ठ को ट्वीग टेम्पलेट के साथ प्रस्तुत किया जाना चाहिए default.html.twig अंदर रखा गया themes/<mytheme>/templates फ़ोल्डर।

उदाहरण के लिए, यदि आपके पास एक फाइल है जिसे कहा जाता है contact.md, यह के रूप में टहनी टेम्पलेट के साथ प्रदान किया जाएगा themes/<mytheme>/templates/contact.html.twig

थीम संगठन

निम्नलिखित अनुभागों में, हम विषय संगठन, यानी इसकी परिभाषा, विन्यास और बहुत कुछ के बारे में चर्चा करेंगे।

परिभाषा और विन्यास

विषय के बारे में जानकारी में परिभाषित किया जाएगा user/themes/antimatter/blueprints.yamlफ़ाइल और प्रपत्र परिभाषाएँ व्यवस्थापन पैनल में उपयोग की जा सकती हैं। आप निम्नलिखित सामग्री देखेंगेuser/themes/antimatter/blueprints.yaml के लिए दर्ज Antimatter theme

name: Antimatter
version: 1.6.0
description: "Antimatter is the default theme included with **Grav**"
icon: empire
author:
   name: Team Grav
   email: [email protected]
   url: http://getgrav.org
homepage: https://github.com/getgrav/grav-theme-antimatter
demo: http://demo.getgrav.org/blog-skeleton
keywords: antimatter, theme, core, modern, fast, responsive, html5, css3
bugs: https://github.com/getgrav/grav-theme-antimatter/issues
license: MIT

form:
   validation: loose
   fields:
      dropdown.enabled:
         type: toggle
         label: Dropdown in navbar
         highlight: 1
         default: 1
         options:
            1: Enabled
            0: Disabled
         validate:
            type: bool

थीम कॉन्फ़िगरेशन विकल्पों का उपयोग करने के लिए, आपको नामक फ़ाइल में डिफ़ॉल्ट सेटिंग्स प्रदान करने की आवश्यकता है user/themes/<mytheme>/<mytheme>.yaml

Example

enable: true

थीम और प्लगइन्स इवेंट

प्लग इन आर्किटेक्चर के माध्यम से ग्रेव के साथ बातचीत करने की थीम की क्षमता ग्रेव की एक और शक्तिशाली विशेषता है। इसे प्राप्त करने के लिए, बस बनाएँuser/themes/<mytheme>/<mytheme>.php (उदाहरण के लिए, antimatter.php डिफ़ॉल्ट एंटीमैटर थीम) फ़ाइल के लिए और निम्न प्रारूप का उपयोग करें।

<?php
namespace Grav\Theme;

use Grav\Common\Theme;

class MyTheme extends Theme {
   public static function getSubscribedEvents() {
      return [
         'onThemeInitialized' => ['onThemeInitialized', 0]
      ];
   }
   public function onThemeInitialized() {
      if ($this->isAdmin()) {
         $this->active = false;
         return;
      }
      
      $this->enable([
         'onTwigSiteVariables' => ['onTwigSiteVariables', 0]
      ]);
   }
   public function onTwigSiteVariables() {
      $this->grav['assets']
         ->addCss('plugin://css/mytheme-core.css')
         ->addCss('plugin://css/mytheme-custom.css');

      $this->grav['assets']
         ->add('jquery', 101)
         ->addJs('theme://js/jquery.myscript.min.js');
   }
}

टेम्पलेट्स

Grav विषय की संरचना में कोई नियम निर्धारित नहीं है सिवाय इसके कि प्रत्येक पृष्ठ प्रकार की सामग्री के लिए टेम्पलेट / फ़ोल्डर में संबंधित टहनी टेम्पलेट होना चाहिए।

पृष्ठ सामग्री और टहनी टेम्पलेट के बीच इस तंग युग्मन के कारण, डाउनलोड पृष्ठ में उपलब्ध कंकाल पैकेजों के आधार पर सामान्य थीम बनाना अच्छा है ।

मान लीजिए आप अपने विषय में मॉड्यूलर टेम्पलेट का समर्थन करना चाहते हैं, तो आपको बनाना होगा modular/फोल्डर और स्टोर ट्वीग टेम्प्लेट फाइल इसके अंदर। यदि आप प्रपत्रों का समर्थन करना चाहते हैं, तो आपको बनाना चाहिएform/ इसमें फोल्डर और स्टोर फॉर्म टेम्प्लेट।

ब्लूप्रिंट

हर एक टेम्पलेट फ़ाइलों के लिए विकल्पों और कॉन्फ़िगरेशन के लिए रूपों को परिभाषित करना blueprints/फ़ोल्डर का उपयोग किया जाता है। इन के माध्यम से संपादन योग्य नहीं होगाAdministrator Panelऔर यह वैकल्पिक रूप से उपयोग किया जाता है। विषय के बिना पूरी तरह कार्यात्मक हैblueprints फ़ोल्डर।

एससीएसएस / कम / सीएसएस

यदि आप SASS या LESS के साथ साइट विकसित करना चाहते हैं, तो आपको उप-फ़ोल्डर बनाना होगा user/themes/<mytheme>/scss/, या less/ यदि आप एक सीएसएस / फ़ोल्डर के साथ कम चाहते हैं।

स्वचालित रूप से उत्पन्न फ़ाइलों के लिए जो SASS या LESS से संकलित हैं, css-compiled/फ़ोल्डर का उपयोग किया जाता है। एंटीमैटर थीम में,scss SASS के वेरिएंट का उपयोग किया जाता है।

अपनी मशीन में SASS को स्थापित करने के लिए इन चरणों का पालन करें।

  • थीम के मूल में, scss shell स्क्रिप्ट निष्पादित करने के लिए नीचे दी गई कमांड टाइप करें।

$ ./scss.sh
  • इसे सीधे चलाने के लिए निम्न कमांड टाइप करें।
$ scss --sourcemap --watch scss:css-compiled

css-compiled/ सभी संकलित scss फ़ाइलें सम्‍मिलित होंगी और css फ़ाइल आपके थीम के अंदर जेनरेट की जाएगी।

अन्य फ़ोल्डर

इसे अलग से बनाने की सिफारिश की गई है images/, fonts/ तथा js/ आपके फ़ोल्डर में user/themes/<mytheme>/ किसी भी चित्र, फोंट और जावास्क्रिप्ट फ़ाइलों के लिए फ़ोल्डर आपके विषय में उपयोग किया जाता है।

थीम उदाहरण

की समग्र फ़ोल्डर संरचना Antimatter अब तक हमने जिस विषय पर चर्चा की, वह नीचे दिखाया गया है।