Grav - थीम अनुकूलन

इस अध्याय में, हम इस बारे में अध्ययन करते हैं Theme Customization। अपनी थीम को कस्टमाइज़ करने के कई तरीके हैं। Grav आपके विषय को आसानी से कस्टमाइज़ करने के लिए कई सुविधाएँ और कुछ कार्यक्षमता प्रदान करता है।

कस्टम सीएसएस

आप अपना खुद का प्रदान कर सकते हैं custom.cssअपने विषय को अनुकूलित करने के लिए फ़ाइल। एंटीमैटर थीम संदर्भित करता हैcss/custom.css के उपयोग के माध्यम से फ़ाइल Asset Manager। यदि CSS फ़ाइल का कोई संदर्भ नहीं मिलता है, तोAsset ManagerHTML में संदर्भ नहीं जोड़ा जाएगा। Antimatter में CSS फ़ाइल बनानाcss/फ़ोल्डर डिफ़ॉल्ट CSS को ओवरराइड करेगा। उदाहरण के लिए -

custom.css

body a {
   color: #FFFF00;
}

डिफ़ॉल्ट लिंक रंग को ओवरराइड किया गया है और पीले रंग में सेट किया गया है।

कस्टम SCSS / LESS

कस्टम सीएसएस फ़ाइल प्रदान करने का एक और तरीका है custom.scssफ़ाइल। एससीएसएस (वाक्य रचना बहुत बढ़िया स्टाइल शीट) एक सीएसएस पूर्वप्रक्रमक जो आप ऑपरेटरों, चर, नेस्टेड संरचनाओं, आयात, partials के उपयोग के माध्यम कुशलता सीएसएस का निर्माण और मिश्रण-इन करने की अनुमति देता है। एंटीमैटर SCSS का उपयोग करके लिखा गया है।

SCSS का उपयोग करने के लिए, आपको SCSS कंपाइलर की आवश्यकता है। आप किसी भी प्लेटफ़ॉर्म पर SCSS कंपाइलर को स्थापित करने के लिए कमांड-लाइन टूल्स और GUI एप्लिकेशन का उपयोग कर सकते हैं। एंटीमैटर का उपयोग करता हैscss/ फ़ोल्डर अपने सभी जगह के लिए .scssफ़ाइलें। संकलित फ़ाइलों में संग्रहीत हैंcss-compiled/ फ़ोल्डर।

SCSS फ़ाइलों को किसी भी अद्यतन के लिए देखा जाना चाहिए जो निम्नलिखित कमांड का उपयोग करके किया जा सकता है -

scss --watch scss:css-compiled

उपरोक्त कमांड SCSS कंपाइलर को स्कैस नामक डायरेक्टरी देखने के लिए कहता है और जब भी css-compiled फ़ोल्डर को अद्यतन किया जाता है SCSS संकलक को संकलित करना चाहिए।

आप अपने कस्टम SCSS कोड को रख सकते हैं scss/template/_custom.scssफ़ाइल। इस फ़ाइल में अपना कोड रखने के कई फायदे हैं।

  • SCSS फ़ाइलों और अन्य CSS फ़ाइलों के किसी भी अद्यतन को संकलित किया जाता है css-compiled/template.css फ़ाइल

  • आप अपने विषय में उपयोग किए जाने वाले किसी भी SCSS का उपयोग कर सकते हैं और इसके लिए सभी चर और मिश्रण-इन्स का उपयोग कर सकते हैं।

  • आसान विकास के लिए, आपको मानक एससीएसएस की सभी सुविधाओं और कार्यात्मकताओं तक पहुंच प्रदान की जाती है।

का एक उदाहरण _custom.scss फ़ाइल नीचे दिखाई गई है -

body {
   a {
      color: darken($core-accent, 20%);
   }
}

जब आप अपनी थीम अपग्रेड करते हैं, तो सभी कस्टम सीएसएस ओवरराइड हो जाएंगे। किसी विषय को अनुकूलित करने के लिए इस तरह से चुनने का यह मुख्य दोष है। यह विषय विरासत का उपयोग करके हल किया जा सकता है।

थीम वंशानुक्रम

Theme Inheritanceएक विषय को संशोधित या अनुकूलित करने का सबसे अच्छा तरीका है और कुछ सेटअप के साथ पूरा किया जा सकता है। मूल विचार यह है कि एक थीम को आधार-विषय के रूप में परिभाषित किया जाता है जिसे आप विरासत में प्राप्त कर रहे हैं, और केवल कुछ बिट्स को संशोधित किया जा सकता है और बाकी चीजों को आधार थीम द्वारा नियंत्रित किया जाता है। थीम इनहेरिटेंस का उपयोग करने का लाभ यह है कि जब भी बेस थीम को अपडेट किया जाता है, तो अनुकूलित विरासत में मिली थीम सीधे प्रभावित नहीं होगी। इसे पूरा करने के लिए, आपको इन चरणों का पालन करने की आवश्यकता है।

  • अपनी नई थीम को स्टोर करने के लिए, नया फ़ोल्डर बनाएं mytheme/ के भीतर /user/themes/ फ़ोल्डर।

  • आगे आपको एक नई थीम YAML फाइल बनाने की आवश्यकता है जिसे कहा जाता है mytheme.yaml नव निर्मित के तहत /user/themes/mytheme/ निम्नलिखित सामग्री के साथ फ़ोल्डर।

streams:
   schemes:
      theme:
         type: ReadOnlyStream
         prefixes:
            '':
               - user/themes/mytheme
               - user/themes/antimatter
  • नामक एक YAML फ़ाइल बनाएँ blueprints.yaml के नीचे /user/themes/mytheme/ निम्नलिखित सामग्री के साथ फ़ोल्डर।

name: MyTheme
version: 1.0.0
description: "Extending Antimatter"
icon: crosshairs
author:
   name: Team Grav
   email: [email protected]
   url: http://getgrav.org

अब हम समझेंगे कि किसी विषय को कैसे परिभाषित किया जाए blueprints.yamlइसमें मूल तत्व होते हैं। आपके प्रपत्र फ़ंक्शंस को नियंत्रित करने के लिए फ़ॉर्म परिभाषा के लिए अधिक विवरण प्रदान किए जा सकते हैं। blueprints.yaml इस पर अधिक जानकारी के लिए फ़ाइल की जांच की जा सकती है।

  • अपने में user/config/system.yaml फाइल एडिट pages: theme: नीचे दिए गए अनुसार अपने डिफ़ॉल्ट विषय को नए विषय में बदलने का विकल्प।

pages:
   theme: mytheme

अब नई थीम बनाई गई है और इस नए के लिए एंटीमैटर बेस थीम होगी mythemeविषय। यदि आप विशिष्ट SCSS को संशोधित करना चाहते हैं, तो हमें SCSS संकलक को कॉन्फ़िगर करने की आवश्यकता है ताकि यह आपका दिखता होmytheme पहला और दूसरा एंटीमैटर थीम।

यह निम्नलिखित सेटिंग्स का उपयोग करता है -

  • सबसे पहले कॉपी करें template.scss फ़ाइल जो में रखी गई है antimatter/scss/ फ़ोल्डर और इसे पेस्ट करें mytheme/scss/फ़ोल्डर। इस फ़ाइल में सभी शामिल होंगे@import जैसे विभिन्न फ़ाइलों के लिए कॉल template/_custom.scss और उप फाइलें।

  • load-path इशारा करना antimatter/scss/फ़ोल्डर जिसमें बड़ी संख्या में SCSS फाइलें होती हैं। SCSS संकलक को चलाने के लिए, आपको प्रदान करने की आवश्यकता हैload-path to it as shown below.

scss --load-path ../antimatter/scss --watch scss:css-compiled
  • अब, नामक एक फाइल बनाएं _custom.scss के अंतर्गत mytheme/scss/template/। इस फ़ाइल में आपके सभी संशोधन होंगे।

जब कस्टम SCSS फ़ाइल बदली जाती है, तो स्वचालित रूप से सभी SCSS फाइलें फिर से संकलित की जाएंगी template.css के तहत स्थित है mytheme/css-compiled/ फ़ोल्डर और फिर Grav इसका सटीक संदर्भ देता है।