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 इसका सटीक संदर्भ देता है।