Grav - त्वरित गाइड

Gravएक फ्लैट-फाइल आधारित सामग्री प्रबंधन प्रणाली है। यह सिस्टम सामग्री को संग्रहीत करने के लिए डेटाबेस का उपयोग नहीं करता है, इसके बजाय यह सामग्री को संग्रहीत करने के लिए एक पाठ (.txt) फ़ाइल या एक मार्कडाउन (.md) फ़ाइल का उपयोग करता है। फ्लैट-फ़ाइल भाग पठनीय पाठ को संदर्भित करता है और यह एक आसान तरीके से सामग्री को संभालता है जो एक डेवलपर के लिए सरल हो सकता है।

ग्रेव द्वारा विकसित किया गया था Rocket Themeटीम। यह PHP पर चलता है और Joomla, Wordpress या Drupal की तरह एक ओपन-सोर्स CMS है।

क्यों ग्रेव?

Grav अब सबसे तेज फ्लैट-फाइल कंटेंट मैनेजमेंट सिस्टम है। ग्रव के साथ सामग्री प्रकाशित और प्रबंधित करना अधिक आसान है। यह एक डेवलपर को डेटाबेस के बजाय फ़ाइलों (जैसे पाठ या मार्कडाउन फ़ाइलों) में सामग्री संग्रहीत करके बहुत आसानी से सामग्री को संभालने की अनुमति देता है।

Grav आपको एक सरल, प्रबंधनीय और एक त्वरित साइट बनाने में मदद करता है। यह डेटाबेस संचालित सीएमएस की तुलना में कम है और फ़ाइल हैंडलिंग के लिए I / O के साथ उपयोगी है, जब आपके पास पर्याप्त संसाधन नहीं हैं।

Grav की सुविधाएँ

  • यह एक तेज, आसान और शक्तिशाली फ्लैट-फाइल वेब प्लेटफॉर्म है।

  • इसका उपयोग बिना किसी अतिरिक्त टूल या HTML ज्ञान के वेबसाइट बनाने के लिए किया जाता है।

  • यह सामग्री को संग्रहीत करने के लिए पाठ फ़ाइल या मार्कडाउन फ़ाइल का उपयोग करता है।

  • यह डेटाबेस का उपयोग नहीं करता है, इसलिए यह अड़चन के उदाहरणों को कम करता है।

  • यह Twig द्वारा प्रदान किए गए PHP आधारित टेम्पलेट का उपयोग करता है जिसे सीधे PHP में पार्स किया जाता है जो इसे तेज बनाता है।

लाभ

  • यह डेटाबेस सीएमएस पर आधारित नहीं है, इसलिए इसे स्थापित करना बहुत आसान है और जब आप सर्वर पर फाइल अपलोड करते हैं तो इसका उपयोग करने के लिए तैयार होंगे।

  • यह चीजों को आसान बनाने के लिए मार्कडाउन टेक्स्ट फाइलों का उपयोग करता है। इसका उपयोग करते हुए, सामग्री को गतिशील रूप से HTML में परिवर्तित किया जाता है और ब्राउज़र में प्रदर्शित किया जाता है।

  • सुरक्षा के मामले में, Grav में व्यवस्थापक क्षेत्र और डेटाबेस नहीं है। इसलिए महत्वपूर्ण डेटा तक पहुंचने के लिए खाते में या डेटाबेस में हैकिंग का कोई मौका नहीं है।

  • आप आसानी से अपनी वेबसाइट की बैकअप कॉपी रखने के लिए सभी फाइलों का बैकअप ले सकते हैं, क्योंकि बैकअप के लिए कोई डेटाबेस नहीं है।

  • यह सॉफ्टवेयर का एक टुकड़ा है जिसे सीखने के लिए अधिक समय की आवश्यकता नहीं होती है।

नुकसान

  • आपके पास ऐसे उदाहरण हो सकते हैं जहां अनधिकृत उपयोगकर्ता फ़ाइलों से आपकी सामग्री तक सीधे पहुंच सकते हैं क्योंकि फ़ाइलों के लिए कोई डेटाबेस नहीं है।

  • Grav CMS का उपयोग करके जटिल वेबसाइट बनाना मुश्किल है।

इस अध्याय में, हम Grav की स्थापना को समझेंगे। हम Grav के लिए सॉफ्टवेयर आवश्यकताओं पर चर्चा करेंगे और इसे डाउनलोड करने का तरीका भी बताएंगे।

Grav के लिए सॉफ्टवेयर आवश्यकताएँ

आइए अब Grav के लिए सॉफ्टवेयर आवश्यकताओं को समझते हैं।

Web Server

  • WAMP (विंडोज)
  • LAMP (लिनक्स)
  • XAMP (बहु-मंच)
  • MAMP (Macintosh)
  • Nginx
  • Microsoft IIS

Operating System - क्रॉस-प्लेटफॉर्म

Browser Support - IE (इंटरनेट एक्सप्लोरर 8+), फ़ायरफ़ॉक्स, गूगल क्रोम, सफारी, ओपेरा

PHP Compatibility - PHP 5.4 या उच्चतर

Text Editors

  • उदात्त पाठ (मैक / विंडोज / लिनक्स)
  • एटम (मैक / विंडोज)
  • नोटपैड ++ (विंडोज)
  • ब्लूफ़िश (मैक / विंडोज / लिनक्स)

Grav डाउनलोड करें

इस लिंक पर क्लिक करें https://getgrav.org/downloads और Grav डाउनलोड करने के लिए नीचे दिए गए स्क्रीनशॉट में दिखाए गए चरणों का पालन करें।

डाउनलोड किए गए Grav फ़ाइल को अपने वेब सर्वर में अनज़िप करें।

सेटअप विज़ार्ड

ग्रेव की स्थापना एक बहुत ही सरल प्रक्रिया है। Grav सेटअप के लिए नीचे दिए गए चरणों का पालन करें।

  • ज़िप फ़ाइल डाउनलोड करें और इसे अपने वेब सर्वर या स्थानीय होस्ट में निकालें। अपने वर्तमान नाम से उस फ़ोल्डर का नाम बदलें जिसे आप अपनी साइट पर संदर्भित करने के लिए उपयोग करना चाहते हैं।

  • अपना ब्राउज़र खोलें और नेविगेट करें localhost/<your_folder_name>, आपको एक स्क्रीन पर रीडायरेक्ट किया जाएगा जो दिखाता है you have installed Grav successfully निम्नलिखित स्क्रीनशॉट में के रूप में।

  • Grav एक नमूना पृष्ठ के साथ आता है जो आपको आरंभ करने में मदद करता है। उपरोक्त स्क्रीनशॉट में, आप होम लिंक देख सकते हैं जिसने एक नमूना पृष्ठ प्रदर्शित किया है।

इस अध्याय में, हम इस बारे में अध्ययन करते हैं Grav Pages। पेज को साइट के बिल्डिंग ब्लॉक्स के रूप में परिभाषित किया जा सकता है। पेज कंटेंट और नेवीगेशन को जोड़ते हैं; यह अनुभवहीन उपयोगकर्ताओं के लिए भी आसान काम करता है।

शुरुआत करने के लिए, आइए जानते हैं कि एक साधारण पेज कैसे बनाया जाए। सभी उपयोगकर्ता सामग्री के तहत संग्रहीत किया जाएगाuser/pages/फ़ोल्डर। केवल एक फोल्डर कहा जाएगा01.home। फ़ोल्डर का संख्यात्मक भाग वैकल्पिक है; यह आपके पृष्ठों के क्रम को व्यक्त करता है (उदाहरण के लिए, 01 02 से पहले आएगा) और स्पष्ट रूप से ग्रेव को सूचित करता है कि यह पृष्ठ मेनू में दिखाई देना चाहिए।

अब देखते हैं कि नया पेज कैसे बनाया जाता है।

Step 1 - के तहत एक फ़ोल्डर बनाएँ /user/pages/; उदाहरण के लिए, 02.about जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

Step 2 - नामक एक फ़ाइल बनाएँ default.md नव निर्मित के अंदर 02.about निम्नलिखित सामग्री के साथ फ़ोल्डर।

---
title: About Us
---

# About Us Page!

This is the body of **about us page**.

उपरोक्त कोड कुछ का उपयोग करता है Markdownवाक्यविन्यास संक्षेप में नीचे समझाया गया है। आप विस्तार से अध्ययन कर सकते हैंMarkdownमें Markdown अध्याय।

  • के बीच सामग्री --- संकेतक हैं Page Headers

  • # या hashes में वाक्य रचना Markdown एक शीर्षक इंगित करता है जिसे परिवर्तित किया जाएगा <h1> HTML में हैडर।

  • ** मार्कर बोल्ड टेक्स्ट या इंगित करते हैं <b> HTML में।

Step 3 - अपने ब्राउज़र को पुनः लोड करें और आप निम्न स्क्रीनशॉट में दिखाए अनुसार मेनू में नया पृष्ठ देख सकते हैं।

पेज के प्रकार

Grav Pages 3 प्रकार के पृष्ठों का समर्थन करता है -

  • मानक पृष्ठ।
  • लिस्टिंग पृष्ठ।
  • मॉड्यूलर पेज।

मानक पृष्ठ

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

लिस्टिंग पृष्ठ

लिस्टिंग पेज एक मानक पृष्ठ का विस्तार है जिसमें पृष्ठों के संग्रह का संदर्भ है। लिस्टिंग पेज सेट करने का सबसे आसान तरीका है कि लिस्टिंग पेज के नीचे बाल पेज बनाए जाएँ। एक ब्लॉग सूची पृष्ठ इसके लिए एक अच्छा उदाहरण है।

लिस्टिंग पेज के साथ एक नमूना ब्लॉग कंकाल Grav डाउनलोड में पाया जा सकता है । एक नमूना निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

मॉड्यूलर पेज

मॉड्यूलर पेज लिस्टिंग पेज का एक रूप है जो अपने चाइल्ड पेज से सिंगल पेज बनाता है। यह हमें छोटे मॉड्यूलर सामग्री पृष्ठों से बहुत जटिल एक-पेज लेआउट बनाने की अनुमति देता है। यह पृष्ठ के प्राथमिक फ़ोल्डर में पाए गए कई मॉड्यूलर फ़ोल्डरों से मॉड्यूलर पेज का निर्माण करके प्राप्त किया जा सकता है।

एक मॉड्यूलर पृष्ठ का उपयोग करके एक-पेज का कंकाल ग्रैव डाउनलोड में पाया जा सकता है । एक नमूना निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

फ़ोल्डर

/user/pagesफ़ोल्डर में उनके संबंधित पृष्ठों की सामग्री होगी। अंदर फ़ोल्डर्स/user/pagesफ़ोल्डर स्वचालित रूप से Grav द्वारा मेनू के रूप में व्यवहार किया जाता है और ऑर्डर करने के उद्देश्य से उपयोग किया जाता है। उदाहरण के लिए,01.homeफ़ोल्डर को घर के रूप में माना जाएगा। आदेश भी बनाए रखा जाना है, यानी 01.home 02.about से पहले आ जाएगा।

आपको एक प्रविष्टि-बिंदु प्रदान करना चाहिए ताकि यह उस ब्राउज़र को निर्दिष्ट करे जहां आप अपनी साइट के रूट पर ब्राउज़र को इंगित करते हैं। उदाहरण के लिए, यदि आप अपने ब्राउज़र में http://mysite.com दर्ज करते हैं, तो Grav एक अन्य की अपेक्षा करता हैhome/ डिफ़ॉल्ट रूप से, लेकिन आप बदलकर घर के स्थान को ओवरराइड कर सकते हैं home.alias Grav विन्यास फाइल में विकल्प।

फ़ोल्डर नाम के रूप में पहचाने जाने से पहले अंडरस्कोर (_) Modular folders, जो एक विशेष फ़ोल्डर प्रकार है जिसे केवल मॉड्यूलर सामग्री के साथ उपयोग करने का इरादा है। उदाहरण के लिए, जैसे फ़ोल्डर के लिएpages/02.about, स्लग डिफ़ॉल्ट होगा about, और URL http://mysite.com/about होगा।

यदि फ़ोल्डर नाम संख्याओं के साथ उपसर्ग नहीं है, तो उस पृष्ठ को अदृश्य माना जाता है और उसे नेविगेशन में प्रदर्शित नहीं किया जाएगा। उदाहरण के लिए, यदिuser/pages/ है /contactफ़ोल्डर, नेविगेशन में प्रदर्शित नहीं किया जाएगा। इसे हेडर सेक्शन के अंदर पेज में ही दिखाया जा सकता है।

---
title: contact
visible: true
---

डिफ़ॉल्ट रूप से एक पृष्ठ नेविगेशन में दिखाई देता है यदि आसपास के फ़ोल्डर में संख्यात्मक उपसर्ग हैं। दृश्यता सेट करने के लिए वैध मान हैं true या false

आदेश

फ़ोल्डर के आदेश को नियंत्रित करने के कई तरीके हैं, जिनमें से एक महत्वपूर्ण तरीका सेट करना है content.order.byपृष्ठ कॉन्फ़िगरेशन सेटिंग्स का। विकल्प नीचे सूचीबद्ध हैं।

  • default - फाइल सिस्टम का उपयोग ऑर्डर करने के लिए किया जा सकता है, अर्थात, 02.about से पहले 01.home।

  • title - शीर्षक का उपयोग आदेश देने के लिए किया जा सकता है जो प्रत्येक पृष्ठ में परिभाषित किया गया है।

  • date - आदेश तारीख पर आधारित हो सकता है जो प्रत्येक पृष्ठ में परिभाषित किया गया है।

  • folder - किसी भी संख्यात्मक उपसर्ग से मिलकर फ़ोल्डर का नाम, जैसे 01., हटा दिया जाएगा।

  • basename - ऑर्डर न्यूमेरिक ऑर्डर के बिना अल्फाबेटिक फोल्डर पर आधारित है।

  • modified - पेज के संशोधित टाइमस्टैम्प का भी उपयोग किया जा सकता है।

  • header.x - पेज हेडर फील्ड के किसी भी ऑर्डर के लिए इस्तेमाल किया जा सकता है।

  • manual - order_manual वैरिएबल ऑर्डर का उपयोग करके बनाया जा सकता है।

  • random - अपने ऑर्डर को रैंडमाइज भी किया जा सकता है।

मैनुअल ऑर्डर को विशेष रूप से विकल्पों की एक सूची प्रदान करके परिभाषित किया गया है content.order.customकॉन्फ़िगरेशन सेटिंग। आप सेट कर सकते हैंpages.order.dir और यह pages.order.by Grav सिस्टम कॉन्फ़िगरेशन फ़ाइल में डिफ़ॉल्ट व्यवहार को ओवरराइड करने के विकल्प।

पृष्ठ की फाइल

पृष्ठ फ़ोल्डर के अंदर का पृष्ठ इस प्रकार बनाया जाना चाहिए .mdफ़ाइल, यानी, मार्कडाउन स्वरूपित फ़ाइल; यह YAML के सामने के मामले के साथ चिह्नित है। defaultमुख्य टेम्पलेट के लिए मानक नाम होगा और आप इसे कोई भी नाम दे सकते हैं। एक साधारण पृष्ठ के लिए एक उदाहरण नीचे दिखाया गया है -

---
title: Title of the page
taxonomy:
   category: blog page
---
# Title of the page

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Pellentesque porttitor eu
felis sed ornare. Sed a mauris venenatis, pulvinar velit vel, dictum enim. Phasellus
ac rutrum velit. **Nunc lorem** purus, hendrerit sit amet augue aliquet, iaculis
ultricies nisl. Suspendisse tincidunt euismod risus. Nunc a accumsan purus.

--- मार्करों के बीच की सामग्री को YAML के सामने के मामले के रूप में जाना जाता है और इस YAML के सामने के मामले में बुनियादी YAML सेटिंग्स होती हैं। उपरोक्त उदाहरण में, हम ब्लॉग पृष्ठ पर शीर्षक और वर्गीकरण स्थापित कर रहे हैं। --- मार्करों की जोड़ी के बाद का खंड वास्तविक सामग्री है जो हम अपनी साइट पर देखते हैं।

सारांश आकार और विभाजक

सारांश का डिफ़ॉल्ट आकार सेट किया जा सकता है site.yaml के माध्यम से इस्तेमाल किया page.summary()। यह उन ब्लॉगों के लिए उपयोगी है जहाँ केवल सारांश जानकारी की आवश्यकता होती है न कि पूर्ण पृष्ठ की सामग्री की। आप उपयोग कर सकते हैंmanual summary separator के रूप में भी जाना जाता है summary delimiter: === और सुनिश्चित करें कि आपने इसे अपनी सामग्री में ऊपर और नीचे की खाली लाइनों के साथ रखा है, जैसा कि नीचे दिखाया गया है।

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor
incididunt ut labore et dolore magna aliqua.

===

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt
ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation
ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in
reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur
sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id
est laborum."

संदर्भित होने पर विभाजक के ऊपर के पाठ का उपयोग किया जाएगा page.summary() और जब संदर्भित द्वारा पूर्ण सामग्री page.content()

अन्य पृष्ठ ढूँढना

ग्रव को फीचर कहा जाता है find() किसी अन्य पृष्ठ को खोजने और उस पृष्ठ पर कार्य करने की विधि।

उदाहरण के लिए, यदि आप किसी विशेष पृष्ठ पर कंपनी के सभी स्थान सूचीबद्ध करना चाहते हैं, तो निम्नलिखित मार्कडाउन नियम का उपयोग करें -

# Locations 
<ul>
   {% for loc in page.find('/locations').children if loc != page %}
      <li><a href="{{loc.url}}">{{ loc.title }}</a></li>
   {% endfor %}
</ul>

मार्कडाउन सिंटैक्स को पढ़ने में आसान और लिखने में आसान प्रारूप में सादे पाठ लिखने के रूप में परिभाषित किया गया है, जिसे बाद में HTML कोड में बदल दिया गया है। मार्कडाउन सिंटैक्स में प्रतीकों (जैसे) (*) या (`) का उपयोग किया जाता है। इन प्रतीकों का उपयोग बोल्ड करने, हेडर बनाने और अपनी सामग्री को व्यवस्थित करने के लिए किया जाता है।

Markdown सिंटैक्स का उपयोग करने के लिए, आपको अपने .md फ़ाइल को बनाना होगा user/pages/02.mypageफ़ोल्डर। अपने में Markdown सिंटैक्स को सक्षम करें\user\config\system.yaml विन्यास फाइल।

मार्कडाउन सिंटैक्स का उपयोग करने के कई लाभ हैं, उनमें से कुछ इस प्रकार हैं।

  • यह सीखना आसान है और इसमें न्यूनतम चरित्र हैं।

  • जब आप मार्कडाउन का उपयोग करते हैं तो त्रुटियां होने की बहुत कम संभावना होती है।

  • वैध XHTML आउटपुट।

  • आपकी सामग्री और दृश्य प्रदर्शन को अलग रखा गया है ताकि यह आपकी वेबसाइट के रूप को प्रभावित न करे।

  • आप किसी भी टेक्स्ट एडिटर या मार्कडाउन एप्लिकेशन का उपयोग कर सकते हैं।

निम्नलिखित अनुभागों में, हम एचटीएमएल के मुख्य तत्वों की चर्चा करेंगे जिनका उपयोग मार्कडाउन में किया जाता है।

शीर्षकों

प्रत्येक शीर्षलेख टैग प्रत्येक शीर्ष के लिए # के साथ बनाया गया है, अर्थात, h1 से h6 तक # दिखाए गए अनुसार # संख्या बढ़ जाती है।

#my new Heading
	##my new Heading
	###my new Heading
	####my new Heading
	#####my new Heading
	######my new Heading

के रूप में एक ब्राउज़र में .md फ़ाइल खोलेंlocalhost/Grav/mypage; आपको निम्नलिखित परिणाम प्राप्त होंगे -

टिप्पणियाँ

आप निम्न प्रारूप में टिप्पणी लिख सकते हैं।

<!—
   This is my new comment
-->

के रूप में एक ब्राउज़र में .md फ़ाइल खोलेंlocalhost/Grav/mypage; आपको निम्नलिखित परिणाम प्राप्त होंगे -

क्षैतिज नियम

पैराग्राफ के बीच एक विषयगत विराम बनाने के लिए क्षैतिज नियमों का उपयोग किया जाता है। आप निम्न विधियों में से किसी का उपयोग करके पैराग्राफ के बीच विराम पैदा कर सकते हैं।

  • ___ - तीन अंडरस्कोर

  • --- - तीन डैश

  • *** - तीन तारांकन

के रूप में एक ब्राउज़र में एमडी फाइल खोलेंlocalhost/Grav/mypage; आपको निम्नलिखित परिणाम प्राप्त होंगे -

शरीर की नकल

Body copy मार्कडाउन सिंटैक्स में सामान्य प्रारूप में टेक्स्ट लिखने के रूप में परिभाषित किया जा सकता है, नहीं (p) टैग का उपयोग किया जाता है

उदाहरण

It is a way of writing your plain text in an easy to read and write format, 
which later gets converted into HTML code.

के रूप में एक ब्राउज़र में .md फ़ाइल खोलेंlocalhost/Grav/mypage; आपको निम्नलिखित परिणाम प्राप्त होंगे -

ज़ोर

जोर मार्काट सिंटैक्स में लेखन प्रारूप हैं जो टेक्स्ट के एक हिस्से को बोल्ड, इटैलिकाइज़ या स्ट्राइकथ्रू करने के लिए उपयोग किया जाता है। आइए हम उनकी चर्चा नीचे करते हैं -

साहसिक

पाठ के एक हिस्से को दो का उपयोग करके बोल्ड बनाया जा सकता है (**) दोनों ओर संकेत।

Example

The newest articles from **Advance Online Publication (AOP)** and the current issue.

इस उदाहरण में, हमें दिखाना होगा ‘Advance Online Publication (AOP)’ शब्द बोल्ड के रूप में।

के रूप में एक ब्राउज़र में .md फ़ाइल खोलेंlocalhost/Grav/mypage, आप निम्नलिखित परिणाम प्राप्त करेंगे -

तिर्छा

उपयोग “_” (अंडरस्कोर) टेक्स्ट को इटैलिक करने के लिए शब्द के दोनों ओर साइन करें।

Example

The newest articles from _Advance Online Publication_ (AOP) and the current issues.

इस उदाहरण में, हमें इटैलिकाइज करना है “Advance Online Publication” (AOP) शब्द।

के रूप में एक ब्राउज़र में .md फ़ाइल खोलेंlocalhost/Grav/mypage। यह आपको निम्नलिखित परिणाम देगा -

स्ट्राइकथ्रू

दो का उपयोग करें "~~" (tildes) शब्द के दोनों ओर शब्द को स्ट्राइकथ्रू करने के लिए।

Example

The newest articles from ~~Advance Online Publication~~ (AOP) and the current issues.

इस उदाहरण में, हमें "अग्रिम ऑनलाइन प्रकाशन" (AOP) शब्द पर प्रहार करना होगा।

के रूप में एक ब्राउज़र में .md फ़ाइल खोलेंlocalhost/Grav/mypage। यह आपको निम्नलिखित परिणाम देगा -

ब्लॉककोट

एक ब्लॉक उद्धरण बनाने के लिए, आपको एक जोड़ना होगा > वाक्य या शब्द से पहले हस्ताक्षर करें।

Example

>The newest articles from Advance Online Publication (AOP) and the current issues.

इस उदाहरण में हमने वाक्य से पहले एक> चिन्ह का उपयोग किया है।

के रूप में एक ब्राउज़र में .md फ़ाइल खोलेंlocalhost/Grav/mypage; आपको निम्नलिखित परिणाम प्राप्त होंगे -

ब्लॉकचोट का उपयोग निम्नलिखित तरीके से भी किया जा सकता है -

>The newest articles from Advance Online Publication (AOP) and the current issues.
>>> The newest articles from Advance Online Publication (AOP) and the current issues.

के रूप में एक ब्राउज़र में .md फ़ाइल खोलेंlocalhost/Grav/mypage; आपको निम्नलिखित परिणाम प्राप्त होंगे -

नोटिस

कुछ महत्वपूर्ण बातों की जानकारी देने या सूचित करने के लिए नोटिस का उपयोग किया जा सकता है।

चार प्रकार के नोटिस हैं - पीला, लाल, नीला और हरा।

पीला

आप का उपयोग करना चाहिए >>> वर्णन करने वाले पीले नोटिस प्रकार से पहले साइन इन करें !Info या जानकारी।

Example

>>>Neurotransmitter-gated ion channels of the Cys-loop receptor family are essential
mediators of fast neurotransmission throughout the nervous system and are implicated
in many neurological disorders.

लाल

चार का प्रयोग करें >>>> चेतावनी के लिए लाल नोटिस से पहले संकेत।

Example

>>>>Neurotransmitter-gated ion channels of the Cys-loop receptor family are essential
mediators of fast neurotransmission throughout the nervous system and are implicated
in many neurological disorders.

नीला

पांच का उपयोग करें >>>>> ब्लू नोटिस प्रकार के लिए संकेत, यह एक नोट का वर्णन करता है।

Example

>>>>>Neurotransmitter-gated ion channels of the Cys-loop receptor family are essential
mediators of fast neurotransmission throughout the nervous system and are implicated
in many neurological disorders.

हरा

छह का उपयोग करें >>>>>> ग्रीन नोटिस प्रकार से पहले संकेत, यह एक टिप का वर्णन करता है।

Example

>>>>>>Neurotransmitter-gated ion channels of the Cys-loop receptor family are essential
mediators of fast neurotransmission throughout the nervous system and are implicated
in many neurological disorders.

के रूप में एक ब्राउज़र में एमडी फाइल खोलें localhost/Grav/mypage; आपको निम्नलिखित परिणाम प्राप्त होंगे -

सूचियों

इस खंड में, हम समझेंगे कि कैसे Grav में अनियंत्रित और आदेशित सूचियाँ काम करती हैं।

अक्रमित

एक अनियंत्रित सूची में, गोलियों का उपयोग किया जाता है। उपयोग*, - , +। गोलियों के लिए प्रतीक। किसी भी पाठ से पहले प्रतीक के साथ अंतरिक्ष का उपयोग करें और गोली प्रदर्शित की जाएगी।

Example

+ Bullet
+ Bullet
+ Bullet
   -Bullet
   -Bullet
   -Bullet
   *Bullet

के रूप में एक ब्राउज़र में .md फ़ाइल खोलेंlocalhost/Grav/mypage; आपको निम्नलिखित परिणाम प्राप्त होंगे -

आदेश दिया

कुछ सूचीबद्ध करने से पहले संख्याओं को जोड़ें।

Example

1. Coffee
2. Tea
3. Green Tea

के रूप में एक ब्राउज़र में .md फ़ाइल खोलेंlocalhost/Grav/mypage। यह आपको निम्नलिखित परिणाम देगा -

कोड

इस खंड में, हम समझेंगे कि इनलाइन और ब्लॉक कोड "फैंस" ग्राव में कैसे काम करते हैं।

इनलाइन कोड

उपयोग करके इनलाइन कोड बनाएं (`) मार्कडाउन में कोड का उपयोग करने के लिए।

Example

In the given example, '<section></section>' must be converted into code.

के रूप में एक ब्राउज़र में .md फ़ाइल खोलेंlocalhost/Grav/mypage आपको निम्नलिखित परिणाम प्राप्त होंगे -

ब्लॉक कोड "बाड़"

उपयोग (```) यदि आप कोड की कई पंक्तियों को अवरुद्ध करना चाहते हैं तो बाड़ें।

Example

```
You’re Text Here

```

के रूप में एक ब्राउज़र में .md फ़ाइल खोलेंlocalhost/Grav/mypage; आपको निम्नलिखित परिणाम प्राप्त होंगे -

टेबल

Grav में, हेडर सेक्शन के तहत पाइप और डैश का उपयोग करके टेबल बनाए जाते हैं। पाइपों को लंबवत संरेखित नहीं किया जाना चाहिए।

उदाहरण

| Number  |    Points       |
| ------  | -----------     |
|   1     | Eve Jackson 94  |
|   2     | John Doe 80     |
|   3     | Adam Johnson 67 |

के रूप में एक ब्राउज़र में .md फ़ाइल खोलेंlocalhost/Grav/mypage; आपको निम्नलिखित परिणाम प्राप्त होंगे -

सही लिखा हुआ पाठ

तालिका सामग्री को दाईं ओर प्राप्त करने के लिए, आपको शीर्षकों के नीचे डैश के दाईं ओर एक बृहदान्त्र जोड़ना होगा।

| Number |     Points      |
| ------:| -----------:    |
|   1    | Eve Jackson 94  |
|   2    | John Doe 80     |
|   3    | Adam Johnson 67 |

के रूप में एक ब्राउज़र में .md फ़ाइल खोलेंlocalhost/Grav/mypage; आपको निम्नलिखित परिणाम प्राप्त होंगे -

लिंक

इस खंड में, हम समझेंगे कि Grav में लिंक कैसे काम करते हैं।

मूल लिंक

([]) वर्ग कोष्ठक और (()) कोष्ठक की सहायता से लिंक बनाए जाते हैं। में[] कोष्ठक, आपको सामग्री और में लिखना होगा () डोमेन नाम लिखें।

Example

[Follow the Given link](http://www.google.com)

के रूप में एक ब्राउज़र में .md फ़ाइल खोलेंlocalhost/Grav/mypage; आपको निम्नलिखित परिणाम प्राप्त होंगे -

एक शीर्षक जोड़ें

इस अनुभाग में, हम समझेंगे कि कैसे .md फ़ाइल में एक शीर्षक जोड़ना है।

Example

[Google](https://www.gogle.com/google/ "Visit Google!")

के रूप में एक ब्राउज़र में .md फ़ाइल खोलेंlocalhost/Grav/mypage; आपको निम्नलिखित परिणाम प्राप्त होंगे -

इमेजिस

छवियाँ एक लिंक के समान हैं, लेकिन सिंटैक्स की शुरुआत में एक विस्मयादिबोधक बिंदु है।

Example

![Nature] (/Grav/images/Grav-images.jpg)

के रूप में एक ब्राउज़र में .md फ़ाइल खोलेंlocalhost/Grav/mypage आपको निम्नलिखित परिणाम प्राप्त होंगे -

इस अध्याय में, हम समझेंगे कि Grav में पृष्ठों को कैसे जोड़ा जाए। आप एक पेज को दूसरे तरीके से सरल तरीके से लिंक कर सकते हैं और यहां तक ​​कि रिमोट पेज को पेज लिंकिंग के साथ जोड़ा जा सकता है। Grav में कई उत्तरदायी लिंकिंग विकल्प हैं। अगर आपने इस्तेमाल किया हैHTML पहले फ़ाइलों को लिंक करने के लिए, फिर Grav में पेज लिंकिंग को समझना बहुत आसान है।

नीचे दिए गए Grav साइट के पेज डायरेक्टरी का एक मूल उदाहरण है। हम निम्न निर्देशिका का उपयोग एक उदाहरण के रूप में करेंगे जैसा कि छवि में दिखाया गया है।

नीचे दिए गए Grav लिंक के कुछ सामान्य घटक हैं।

[Linked Content](../path/slug/page)
  • []- पाठ या वैकल्पिक सामग्री को जोड़ने के लिए निर्दिष्ट करता है जो जुड़ा हुआ है। HTML में, हम सामग्री को रखने के लिए <a href=""> और </a> का उपयोग करते हैं।

  • () - URL को इस ब्रैकेट में रखा गया है, जिसे सीधे वर्ग ब्रैकेट के बाद रखा गया है।

  • ../ - एक निर्देशिका द्वारा एक कदम को इंगित करता है।

सामग्री में 4 प्रकार के लिंक दिए गए हैं जो नीचे सूचीबद्ध हैं -

  • Slug Relative

  • Directory Relative

  • Absolute

  • Remote

स्लग रिलेटिव

आंतरिक लिंक आपकी फ़ाइल / निर्देशिका संरचना में कुछ नामों तक सीमित नहीं हैं। स्लग को हेडर और फॉलबैक निर्देशिका नाम दोनों से खींचा जा सकता है, जो बाद में आपको आसानी से लिंक बनाने में मदद करता है क्योंकि किसी विशिष्ट फ़ाइल नाम को याद रखने की कोई आवश्यकता नहीं है लेकिन एक प्रासंगिक स्लग को याद कर सकते हैं। Grav का टेम्पलेटिंग इंजन फाइल का नाम जानने के लिए उपयोग करता है कि कौन सा टेम्पलेट लागू करना है।

[link](../dog)

उपरोक्त कोड आपको निम्न परिणाम देता है -

उपरोक्त उदाहरण में, आपको एक निर्देशिका को स्थानांतरित करना होगा और उस डिफ़ॉल्ट पृष्ठ को लोड करना होगा जो अंदर स्थित है pages/01.home/02.nature/item.md से निर्देशिका pages/01.home/02.dog/item.md। फ़ाइल, item.md में स्लग नहीं दिया गया है, इसलिए Grav निर्देशिका नाम का उपयोग करता है।

अगला, आपको एक समान उदाहरण मिलता है, जिससे लिंक करना pages/01.home/01.dog/item.md सेवा pages/02.black/01.fish/item.md, लेकिन जब यह item.md फ़ाइल को लोड करता है, तो फ़ाइल के लिए एक स्लग सौंपा जाएगा 01.fish

[link](../../black/fish)

उपरोक्त कोड आपको निम्नलिखित परिणाम देता है -

अब आप देखेंगे कि डिफ़ॉल्ट स्लग फ़ोल्डर नाम के साथ बदल दिया जाएगा black आइटम के हेडर में स्लग।

निर्देशिका संबंधी

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

आप अपनी फ़ाइल के लिंक को सीधे उसकी निर्देशिका या स्लग के बजाय नाम से इंगित करेंगे। आप इससे लिंक बना सकते हैंpages/01.home/01.dog/item.md to pages/02.black/01.fish/item.md नीचे दिखाए अनुसार कमांड का उपयोग करें।

[link](../../02.black/01.fish/item.md)

उपरोक्त कोड आपको निम्नलिखित परिणाम देता है -

जैसा कि दिखाया गया है, दोनों फ़ोल्डर ऊपर ले जाए गए हैं ../../, और फिर नीचे दो फ़ोल्डरों पर, सीधे इंगित करता है item.md फ़ाइल।

पूर्ण लिंक

यह रिश्तेदार लिंक के समान है, आपके आधार पर /user/pages/Grav में निर्देशिका। इसके अलावा, यह दो तरीकों से किया जा सकता है।

  • Slug Relative style

  • Directory Relative style

स्लग रिलेटिव स्टाइल

आप इसे स्लग रिलेटिव टाइप के रूप में कर सकते हैं। यह पथ में निर्देशिका नाम का उपयोग करता है। यह आदेश की त्रुटियों को समाप्त करता है और लिंक को तोड़कर बाद में बदलता है। यह प्रारंभ में फ़ोल्डर नाम की संख्या को बदलता है जो लिंक को तोड़ने की ओर जाता है।

नीचे दिए गए निरपेक्ष लिंक का एक उदाहरण है, लिंक / के साथ खुलता है। यह निर्दिष्ट करता है कि पूर्ण लिंक में बनाया गया हैpages/01.home/01.dog/item.md स्लग शैली में।

[link](/home/nature)

उपरोक्त कोड आपको निम्नलिखित परिणाम देता है -

Directory relative styleGitHub जैसी सेवाओं के साथ उपयोग किए जाने पर यह अधिक सुसंगत है। वे Grav के लचीलेपन का लाभ नहीं है। नीचे आप एक पूर्ण लिंक का उदाहरण देख सकते हैंpages/01.home/01.dog/item.md निर्देशिका सापेक्ष शैली का उपयोग करना।

[link](/01.home/01.dog)

दूरस्थ

दूरस्थ लिंक आपको इसके URL के माध्यम से किसी भी फ़ाइल या दस्तावेज़ से सीधे लिंक करने की अनुमति देते हैं। अपनी खुद की साइट की सामग्री को शामिल करने की कोई आवश्यकता नहीं है।

निम्नलिखित उदाहरण आपको दिखाता है कि कैसे लिंक करना है TutorialsPoint पृष्ठ।

[link](http://www.tutorialspoint.com)

उपरोक्त कोड आपको निम्नलिखित परिणाम देता है -

आप सुरक्षित HTTPS लिंक सहित किसी भी URL से सीधे लिंक कर सकते हैं।

इस अध्याय में, हम Grav में इमेज लिंकिंग को समझेंगे। Grav आपको छवियों को एक पृष्ठ से दूसरे और यहां तक ​​कि दूरस्थ पृष्ठों से लिंक करने की अनुमति देता है। यदि आपने HTML का उपयोग करके फ़ाइलों को लिंक किया है, तो Grav में इमेज लिंकिंग को समझना बहुत आसान होगा।

इस संरचना का उपयोग करते हुए, हम देखेंगे कि विभिन्न प्रकार के लिंक का उपयोग करके पृष्ठ में मीडिया फ़ाइलों को कैसे प्रदर्शित किया जाए। इस संरचना के अंतर्गत प्रत्येक फ़ोल्डर में चित्र हैं और इसके अंतर्गत एक विशेष निर्देशिका है/02.green/img01 जो पेज के रूप में कार्य करता है, लेकिन इसमें केवल मीडिया फ़ाइलें होती हैं।

आइए Grav markdown- आधारित छवि टैग के कुछ सामान्य तत्वों पर ध्यान दें।

![Alt Text](../path/image.ext)
  • ! - यह एक छवि टैग को इंगित करता है जब आप इसे मार्कडाउन लिंक टैग की शुरुआत में रखते हैं।

  • [] - यह छवि के लिए वैकल्पिक ऑल-टेक्स्ट निर्दिष्ट करता है।

  • () - इसे सीधे वर्ग कोष्ठक के बाद रखा जाता है जिसमें फ़ाइल पथ होता है।

  • ../ - यह एक निर्देशिका को ऊपर ले जाने का संकेत देता है।

Grav पांच प्रकार की छवि लिंक का उपयोग करता है जैसा कि नीचे सूचीबद्ध है -

  • Slug Relative

  • Directory Relative

  • Absolute

  • Remote

  • Media Actions on Images

स्लग रिलेटिव

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

उदाहरण

![link](../water/img01/img.jpg)

यहाँ ../ इंगित करता है कि आपका लिंक एक फ़ोल्डर ऊपर ले जाता है और फिर नीचे एक फ़ोल्डर और img.jpg गंतव्य है।

जब आप उपरोक्त पथ का उपयोग करते हैं, तो आपको निम्न आउटपुट प्राप्त होंगे -

Grav पृष्ठ की प्राथमिक मार्कडाउन फ़ाइल के हेडर में स्लग का समर्थन करता है और यह स्लग दिए गए पेज के लिए फ़ोल्डर नाम की जगह लेता है।

अगर 01.sky फ़ोल्डर में इसके माध्यम से एक स्लग सेट है .md फ़ाइल, अर्थात, /pages/01.blue/01.sky/text.md, तो फ़ाइल का हेडर इस प्रकार होगा -

---
title: Sky
slug: test-slug
taxonomy:
   category: blog
---

उपरोक्त कोड में, हमने स्लग सेट किया है test-slugजो एक वैकल्पिक है। एक बार जब आप स्लग सेट कर लेते हैं, तो आप मीडिया फाइल से लिंक कर सकते हैंSlug Relative या Absolute लिंक के लिए URL सेट।

निर्देशिका संबंधी

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

उदाहरण

![My image](../../blue/img01/img.jpg)

जब आप उपरोक्त पथ का उपयोग करते हैं, तो यह नीचे दिखाए अनुसार आउटपुट प्रदर्शित करेगा -

पूर्ण

निरपेक्ष लिंक रिश्तेदार लिंक के समान हैं लेकिन अंतर केवल इतना है कि वे साइट की जड़ के सापेक्ष हैं और वर्तमान में हैं /user/pages/ निर्देशिका।

आप दो अलग-अलग तरीकों से पूर्ण लिंक का उपयोग कर सकते हैं -

  • आप उपयोग कर सकते हैं Slug Relative शैली जिसमें पथ में स्लग या निर्देशिका नाम शामिल हैं और आमतौर पर पूर्ण लिंकिंग में उपयोग किया जाता है।

  • आप उपयोग कर सकते हैं Absolute Link जिसके साथ लिंक खुलता है a/

![My image](/blue/img01/img.jpg)

जब आप उपरोक्त पथ का उपयोग करते हैं, तो आपको निम्न आउटपुट प्राप्त होंगे -

दूरस्थ

दूरस्थ छवि लिंक किसी भी मीडिया फ़ाइल को सीधे उसके URL के माध्यम से प्रदर्शित करने की अनुमति देते हैं। इन लिंक में आपकी अपनी साइट की सामग्री शामिल नहीं है। निम्न उदाहरण दिखाता है कि दूरस्थ URL का उपयोग करके छवि कैसे प्रदर्शित करें -

![Remote Image 1](http://www.freedomwallpaper.com/nature-wallpaper/spring_nature-wide.jpg)

जब आप नीचे दी गई छवि में दिखाए गए लिंक पर क्लिक करते हैं, तो यह दिए गए URL से छवि प्रदर्शित करेगा।

छवियों पर मीडिया क्रियाएँ

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

उदाहरण

आप नीचे दिए गए प्रारूप का उपयोग करके एक छवि लोड कर सकते हैं -

![Styling Example](../img01/img.jpg?cropResize = 400, 200)

जब आप उपरोक्त पथ का उपयोग करते हैं, तो आपको नीचे दिखाए अनुसार एक आउटपुट प्राप्त होगा -

मीडिया फ़ाइलों में विभिन्न प्रकार की प्रदर्शन सामग्री होती है जैसे कि चित्र, वीडियो और कई अन्य फाइलें। Grav इन फ़ाइलों को किसी भी पेज द्वारा उपयोग किए जाने के लिए स्वचालित रूप से ढूँढता है और संसाधित करता है। पृष्ठ की कार्यक्षमता में अंतर्निहित का उपयोग करके, आप मेटाडेटा तक पहुँच सकते हैं और गतिशील रूप से मीडिया को संशोधित कर सकते हैं।

Smart-cachingGrav द्वारा उपयोग किया जाता है जो आवश्यक होने पर इन-कैश जनरेट मीडिया बनाता है। इस तरह से सभी बार-बार मीडिया बनाने के बजाय कैश्ड संस्करण का उपयोग कर सकते हैं।

समर्थित मीडिया फ़ाइलें

निम्नलिखित मीडिया फ़ाइल प्रकार हैं जो Grav द्वारा समर्थित हैं -

  • Image - जेपीजी, जेपीईजी, पीएनजी

  • Animated Image - जिफ

  • vectorized Image - svg

  • Video - mp4, mov, m4v, swf

  • Data/information - txt, doc, pdf, html, zip, gz

मोड प्रदर्शित करें

Grav में कुछ प्रकार के डिस्प्ले मोड निम्नलिखित हैं -

  • Source - यह इमेज, वीडियो या फाइल का विजुअल डिस्प्ले है।

  • text - मीडिया फ़ाइलों की शाब्दिक प्रस्तुति।

  • thumbnail - मीडिया फ़ाइल के लिए थंबनेल छवि।

थम्बनेल का पता लगाना

आप तीन स्थानों का उपयोग करके थंबनेल का पता लगा सकते हैं -

  • In the same folder where your media files exists- [मीडिया-नाम] [मीडिया-विस्तार]। यहाँ, मीडिया-नाम और मीडिया-विस्तार वास्तविक मीडिया फ़ाइल का नाम और विस्तार है और थंब-एक्सटेंशन वह विस्तार है जो छवि मीडिया प्रकार द्वारा समर्थित है।

  • User Folder − उपयोगकर्ता / images / मीडिया / thumb- [मीडिया एक्सटेंशन] .png; यहाँ, मीडिया-विस्तार वास्तविक मीडिया फ़ाइल का विस्तार है।

  • System folder- प्रणाली / चित्र / मीडिया / अंगूठा- [मीडिया-विस्तार] .Png; यहाँ, मीडिया-विस्तार वास्तविक मीडिया फ़ाइल का विस्तार है।

लाइटबॉक्स और लिंक

Grav एक एंकर टैग का आउटपुट देता है जिसमें लाइटबॉक्स प्लगइन के कुछ तत्व पढ़ने के लिए होते हैं। यदि आप एक लाइटबॉक्स लाइब्रेरी का उपयोग करना चाहते हैं जो आपके प्लगइन्स में शामिल नहीं है, तो आप अपने स्वयं के प्लगइन बनाने के लिए निम्नलिखित विशेषताओं का उपयोग कर सकते हैं।

  • rel- लाइटबॉक्स लिंक का संकेत देता है। मान lightbox है।

  • href - यह मीडिया ऑब्जेक्ट के लिए एक URL है।

  • data-width - उपयोगकर्ता द्वारा चुने गए लाइटबॉक्स की चौड़ाई निर्धारित करें।

  • data-height - उपयोगकर्ता द्वारा चुने गए लाइटबॉक्स की ऊंचाई निर्धारित करें।

  • data-srcset - छवि मीडिया के मामले में srcset स्ट्रिंग का उपयोग किया जाता है।

कार्रवाई

Grav में बिल्डर पैटर्न का उपयोग मीडिया को संभालने, कई क्रियाओं को करने के लिए किया जाता है। कुछ प्रकार के कार्य हैं जो सभी माध्यमों के लिए समर्थित हैं जबकि कुछ ऐसे हैं जो केवल विशिष्ट माध्यम के लिए उपलब्ध हैं।

आम

6 प्रकार की सामान्य क्रियाएं हैं जो मीडिया प्रकारों के लिए उपलब्ध हैं। प्रत्येक क्रिया को नीचे समझाया गया है।

अनु क्रमांक। कार्रवाई और विवरण
1 यूआरएल ()

url () वापस देता है raw url path मीडिया को।

2 html ([शीर्षक] [, alt] [, कक्षाएं]

आउटपुट में मीडिया के लिए एक वैध html टैग होगा।

3

display(mode)

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

4 संपर्क()

लिंक से पहले लागू किए गए लिंक लिंक के लक्ष्य पर लागू होंगे।

5 लाइटबॉक्स ([चौड़ाई, ऊंचाई])

लाइटबॉक्स लिंक एक्शन के समान है लेकिन इसमें थोड़ा अंतर है कि यह कुछ अतिरिक्त विशेषताओं के साथ लिंक बनाता है।

6 थंबनेल

किसी भी प्रकार की मीडिया फ़ाइल के लिए पृष्ठ और डिफ़ॉल्ट के बीच चयन करें और इसे मैन्युअल रूप से किया जा सकता है।

छवियों पर कार्रवाई

निम्न तालिका उन कुछ कार्यों को सूचीबद्ध करती है जो छवियों पर लागू होते हैं।

अनु क्रमांक। कार्रवाई और विवरण
1 आकार (चौड़ाई, ऊंचाई, [पृष्ठभूमि])

आकार और छवि की चौड़ाई और आकार बदलकर।

2 जबरदस्ती (चौड़ाई, ऊंचाई)

मूल अनुपात की आवश्यकता के अनुसार छवि को स्ट्रेच करता है।

3 फसल (आकार, चौड़ाई)

छवि को उसकी चौड़ाई और ऊंचाई के अनुसार छोटे या बड़े आकार का आकार देता है।

4 फसल (x, y, चौड़ाई, ऊंचाई)

X और y स्थान से चौड़ाई और ऊंचाई द्वारा वर्णित छवि को काटता है।

5 क्रॉपज़ूम (चौड़ाई, ऊँचाई)

अनुरोध के अनुसार चित्रों को ज़ूम और क्रॉप करने में मदद करता है।

6 गुणवत्ता (मान)

0 और 100 के बीच की छवि गुणवत्ता के लिए मान सेट करता है।

7 निगेट ()

रंग नकारात्मकता में उलटे हो जाते हैं।

8 चमक (मान)

के साथ value का -255 सेवा +255, चमक फिल्टर छवि में जोड़ा जाता है।

9 इसके विपरीत (मान)

छवि के विपरीत फ़िल्टर को लागू करने के लिए -100 से +100 तक के मूल्य का उपयोग किया जाता है।

10 ग्रेस्केल ()

वह ग्रेस्केल फिल्टर का उपयोग छवि को संसाधित करने के लिए किया जाता है।

1 1 नक्काशी ()

छवि को संसाधित करने के लिए एम्बॉसिंग फ़िल्टर का भी उपयोग किया जाता है।

12 चिकनी (मान)

-10 से +10 तक मान सेट करके छवियों को स्मूथिंग फ़िल्टर लागू किया जाता है।

13 तेज ()

छवि पर पैनापन फ़िल्टर जोड़ा जाता है।

14 धार ()

छवि पर बढ़त खोजने वाला फ़िल्टर जोड़ा जाता है।

15 colorize (लाल, हरा, नीला)

लाल, हरे और नीले रंगों को समायोजित करके छवि को रंग देता है।

16 सेपिया ()

विंटेज लुक देने के लिए सीपिया फिल्टर मिलाया जाता है।

एनीमेशन और चित्र और वीडियो को सदिश करना

छवियाँ और वीडियो पर एनिमेटेड और वेक्टर किए गए कार्य किए जाते हैं। निम्नलिखित वह क्रिया है जो छवियों और वीडियो पर होती है।

अनु क्रमांक। कार्रवाई और विवरण
1 आकार (चौड़ाई, ऊँचाई)

आकार परिवर्तन कार्रवाई सेट हो जाएगी width, height, data-width तथा data-height जिम्मेदार बताते हैं।

युग्म

Grav में छवि हेरफेर कार्यक्षमता है जो छवियों के साथ काम करना आसान बनाता है।

![My New Image](/images/maxresdefault.jpg?negate&cropZoom = 500, 500&lightbox & cropZoom = 600,
200&contrast = -100&sharp&sepia)

उपरोक्त कोड एक आउटपुट उत्पन्न करेगा जैसा कि नीचे दिखाया गया है -

उत्तरदायी चित्र

निम्न तालिका कुछ प्रकार की उत्तरदायी छवियों को सूचीबद्ध करती है।

अनु क्रमांक। कार्रवाई और विवरण
1 उच्च घनत्व प्रदर्शित करता है

फ़ाइल नाम के लिए एक प्रत्यय जोड़ें और यू पेज में उच्च घनत्व छवि जोड़ सकते हैं।

2 मीडिया के प्रश्नों के साथ आकार

फ़ाइल नाम के लिए एक प्रत्यय जोड़ें और यू पेज में उच्च घनत्व छवि जोड़ सकते हैं।

जिन मेटाफ़ाइल्स

image1.jpg, archive.zipया किसी अन्य संदर्भ में चर सेट करने की क्षमता है या मेटाफ़ाइल द्वारा ओवरराइड किया जा सकता है। ये फाइलें तब का प्रारूप लेती हैं<filename>.meta.yaml। उदाहरण के लिए, यदि आपके पास एक छवि हैimage2.jpg, तब आपका मेटाफ़िल बनाया जा सकता है image2.jpg.meta.yaml। सामग्री yaml सिंटैक्स में होनी चाहिए। आप इस पद्धति का उपयोग करके अपनी पसंद की कोई भी फ़ाइल या मेटाडेटा जोड़ सकते हैं।

मॉड्यूलर पृष्ठों को पहली बार में समझना मुश्किल है लेकिन एक बार जब आपको इसके बारे में पता चल जाता है, तो इसके साथ काम करना बहुत आसान होगा। यह अपने चाइल्ड पेज से सिंगल पेज बनाने में सक्षम बनाता है। इसमें मॉड्यूलर सामग्री पृष्ठों से जटिल एक पृष्ठ लेआउट बनाने की क्षमता है।

मॉड्यूलर पृष्ठों को गैर-रूटेबल के रूप में सेट किया जाता है क्योंकि वे सीधे URL के माध्यम से नहीं पहुँच सकते हैं। वे फ़ोल्डर नाम से पहले _ (अंडरस्कोर) द्वारा पहचाने जाते हैं। यह उन पृष्ठों का एक संग्रह है जो एक पृष्ठ प्राप्त करने के लिए प्रत्येक के ऊपर एक प्रदर्शित होते हैं। उदाहरण के लिए, उपयोगकर्ता / पृष्ठ / होम / _हल्डर।

फ़ोल्डर संरचना

एक पृष्ठ के कंकाल के मामले में, आप इस पृष्ठ को 01.home फ़ोल्डर में पा सकते हैं । इसमें आपको सिंगल मोड्यूलर मिलता है.mdफ़ाइल जो बताती है कि कौन से पृष्ठ शामिल होने चाहिए और प्रदर्शित करने के लिए पृष्ठों का क्रम। modular.html.twig आपके वर्तमान थीम फ़ोल्डर में पाया जा सकता है।

नीचे दी गई छवि में, आप एक फ़ोल्डर संरचना देख सकते हैं जो मॉड्यूलर पृष्ठों के लिए बनाई गई है।

प्रत्येक उप-फ़ोल्डर में एक .md फ़ाइल होनी चाहिए जो एक मार्कडाउन फ़ाइल का वर्णन करती है।

सबसे पहले, आपको उप फ़ोल्डर बनाना होगा /users/pages/01.homeफ़ोल्डर। इसके बाद, प्रत्येक फ़ोल्डर में एक .md फ़ाइल और एक मॉड्यूलरDd फ़ाइल होनी चाहिए ।

जब आप उप फ़ोल्डर बनाते हैं, तो छवि और फ़ाइल दोनों एक ही फ़ोल्डर में होनी चाहिए।

मॉड्यूलर पेज कैसे बनाये

मॉड्यूलर पेज बनाने के लिए, आपको दिए गए चरणों का पालन करना चाहिए।

Step 1 - में कुछ पेज बनाएँ /user/pages/01.home/। फ़ोल्डर। नीचे दी गई छवि में, आप देख सकते हैं कि हमने modular.md फ़ाइल के साथ दो फ़ोल्डर बनाए हैं।

Step 2 - एक मॉड्यूलर पेज बनाने के लिए, आपको प्रत्येक फ़ोल्डर में एक फ़ाइल बनानी चाहिए और इसे नाम देना चाहिए text.md

Step 3- इसके बाद, text.md फ़ाइल में अपना कोड जोड़ें , इसे सहेजें और समान चलाएं।

Example

सभी चार पृष्ठों को .md फ़ाइल के रूप में सहेजें । यहां हमने 4 पेज बनाए हैं और text.md, text1.md, text2.md और text3.md नाम दिए हैं।

---
title: Bio-diversity
---

## Bio-diversity

Biodiversity refers to the variety of life. It is seen in the number of species in an 
[ecosystem](https://simple.wikipedia.org/wiki/Ecosystem) or on the entire [Earth]
(https://simple.wikipedia.org/wiki/Earth). Biodiversity gets used as a measure of the
health of biological systems, and to see if there is a danger that too many species
become[extinct](https://simple.wikipedia.org/wiki/Extinct).

अब, 4 पृष्ठ बनाएं, उन्हें जोड़ें \templates\modular फ़ोल्डर नीचे दिखाया गया है।

अगला, होम पेज पर जाएं और रिफ्रेश करें, आप बदलाव देख सकते हैं।

नए नेविगेशन बार में, आप चार फ़ाइल लिंक देख सकते हैं।

मल्टी-भाषा को आपकी वेबसाइट में विभिन्न भाषाओं के उपयोग के रूप में परिभाषित किया गया है। हम विभिन्न प्रक्रियाओं को सीखेंगे जो आपकी Grav साइट में बहु-भाषाओं का उपयोग करने में आपकी सहायता करेंगी।

बहु - भाषा मूल बातें

मूल रूप से Grav को किसी भी पृष्ठ के प्रतिनिधित्व के लिए एक .md फ़ाइल की आवश्यकता होती है । जब आप बहु-भाषा समर्थन सक्षम करते हैं, तो यह एक फ़ाइल की तरह दिखेगाdefault.en.md या default.fr.md.

भाषा विन्यास

आपको पहले अपने में कुछ बुनियादी भाषा विन्यास स्थापित करना होगा user/config/system.yamlफ़ाइल। फ़ाइल।

Language:
   Supported:
      - en
      - Fr

ऐसा करने से, आपने Grav में बहु-भाषा समर्थन सक्षम किया है। उपरोक्त कोड में,en अंग्रेजी भाषा का अर्थ है और frफ्रेंच का मतलब है। इसका मतलब है कि आपकी साइट इन दो भाषाओं का समर्थन करेगी। यहां डिफ़ॉल्ट भाषा एन (अंग्रेजी) है । यदि आप पहले Fr (फ्रेंच) लिखते हैं , तो वह आपकी डिफ़ॉल्ट भाषा बन जाती है।

एकाधिक भाषा पृष्ठ

यदि आपकी डिफ़ॉल्ट भाषा के रूप में सेट है English, फिर ग्रेव की तलाश करेंगे default.en.mdफ़ाइल। यदि वह फ़ाइल नहीं मिली है, तो Grav आपके द्वारा सेट की गई अन्य भाषा के लिए दिखता है। यदि दोनों भाषाओं को नहीं मिला है, तो यह इसके लिए दिखता हैdefault.md फ़ाइल।

Example

default.en.md फ़ाइल

---
title: Home
---

# Grav is Running!
## You have installed **Grav** successfully

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

फ्रेंच के लिए डिफ़ॉल्ट भाषा के रूप में, default.fr.md फ़ाइल होगी -

---
titre: Accueil
---

# Grav est en marche!
## Vous avez installé ** ** Grav succès

उपरोक्त कोड निम्नलिखित आउटपुट उत्पन्न करेगा -

URL के माध्यम से सक्रिय भाषा

अगर आप भाषा कोड के साथ अपनी वेबसाइट पर एक URL अपडेट करना चाहते हैं, तो इन चरणों का पालन करें -

Example

यदि आप चाहते हैं कि आपकी साइट अंग्रेजी में हो, तो नीचे की पंक्ति अपने ब्राउज़र में टाइप करें -

http://www.mysite.com/en

यदि आप चाहते हैं कि आपकी साइट फ़्रेंच में हो, तो अपने ब्राउज़र में निम्न पंक्ति टाइप करें -

http://www.mysite.com/fr

ब्राउज़र के माध्यम से सक्रिय भाषा

Grav में पाने की क्षमता है http_accept_languageमूल्य और समर्थित भाषा प्रस्तुत करने के लिए उनकी तुलना करें। यदि आप यह कार्य करना चाहते हैं, तो अपने को सक्षम करेंuser/system.yaml भाषा अनुभाग में फ़ाइल के रूप में -

language :
   http_accept_language : true

भाषा-आधारित मुखपृष्ठ

भाषा आधारित मुख पृष्ठ रखने के लिए, आपको अपने कोड में निम्नलिखित को सक्षम करना होगा site.yaml फ़ाइल -

home:
   aliases:
      en: /homepage
      fr: /page-d-accueil

इस तरह, ग्रेव को पता चलेगा कि सक्रिय भाषाओं में से किस भाषा का उपयोग करना है।

निम्न कोड Grav को आपके डिफ़ॉल्ट भाषा मार्ग पर पुनर्निर्देशित करने के लिए मजबूर करेगा। और शामिल_ विकल्प विकल्प आपके url की तरह भाषा कोड जोड़ने के लिए बाध्य करता हैhttp://www.mysite.com/en/home

languages:
   home_redirect:
      include_lang: true
      include_route: false

भाषा-आधारित टहनी टेम्पलेट

यदि आपकी फ़ाइल default.en.md है , तो Grav एक मूलभूत फ़ाइल के लिए default.html.twig के रूप में दिखेगी । जब आपको एक भाषा-विशिष्ट टहनी फ़ाइल की आवश्यकता होती है, तो आपको इसे भाषा फ़ोल्डर के मूल स्तर पर अपलोड करना होगा। यदि आपका वर्तमान विषय हैtemplates/default.html.twig आप अवश्य बनाएं templates/en/ फ़ोल्डर और इसमें अपना अंग्रेज़ी-विशिष्ट फ़ोल्डर रखें: templates/en/default.html.twig

भाषा स्विचर

भाषा स्विचर प्लगइन Grav पैकेज मैनेजर (GPM) पर उपलब्ध है ।

ट्विग के माध्यम से अनुवाद

टहनी फिल्टर और टी () फ़ंक्शन का उपयोग करें । दोनों समान रूप से कार्य करते हैं। यदि आपके पास एक और टहनी फ़ाइल है, तो यह आपको एक सरणी से अनुवाद करने की अनुमति देता है।

प्लगइन और थीम भाषा अनुवाद

एक बनाने के द्वारा प्लगइन्स और विषयों में अपने अनुवाद प्रदान करें languages.yaml अपने विषय या प्लगइन (/user/plugins/error/languages.yaml) की जड़ में फ़ाइल और सभी समर्थित भाषाओं में होना चाहिए।

अनुवाद ओवरराइड्स

यदि आप अनुवाद को ओवरराइड करना चाहते हैं, तो आपको अपने उपयोगकर्ता / भाषाओं / फ़ोल्डर में भाषा फ़ाइल में मूल्य युग्म रखना होगा ।

उन्नत

Environment – Based Language Handling

URL के अनुसार उपयोगकर्ताओं को आपकी साइट के सही संस्करण में रूट करना संभव है। यदि आपकी साइट url हैhttp://english.yoursite.com, अपने मानक के लिए एक उपनाम http://www.yoursite.com, तो आप के रूप में एक विन्यास बना सकते हैं /user/english.yoursite.com/config/system.yaml.

languages:
   supported:
      - fr
      - en

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

भाषा उपनाम रूट

एक ही पृष्ठ के विभिन्न भाषा संस्करणों के बीच स्विच करना बहुत मुश्किल है, आप इसका उपयोग कर सकते हैं Page.rawRoute()आपके पेज ऑब्जेक्ट पर विधि। यह एक ही पृष्ठ के विभिन्न भाषा अनुवादों के लिए एक ही कच्चा मार्ग प्राप्त करता है। उचित मार्ग प्राप्त करने के लिए भाषा कोड को सामने रखें।

यदि आप फ्रेंच में कस्टम मार्ग के साथ पृष्ठ पर हैं -

/ma-page-francaise-personnalisee

अंग्रेजी पृष्ठ का कस्टम मार्ग है -

/my-custom-french-page

आपको फ्रांसीसी पृष्ठ का कच्चा पृष्ठ मिलता है और वह हो सकता है -

/blog/custom/my-page

इसके बाद सिर्फ अपनी इच्छित भाषा जोड़ें, जो आपका नया URL होगा।

/en/blog/custom/my-page

अनुवाद का समर्थन

Grav थीम और प्लगइन्स में उपयोग किए जाने वाले PHP के माध्यम से Twig में अनुवाद प्रदान करने के लिए सरल तंत्र प्रदान करता है। यह डिफ़ॉल्ट रूप से सक्षम है और उपयोग करता हैenभाषा यदि कोई विशिष्ट भाषा परिभाषित नहीं है। सक्षम या अक्षम करने के लिए, system.yaml फ़ाइल पर जाएं और परिवर्तन करें।

languages:
   translations: true

आप कई तरीकों और विभिन्न स्थानों पर अनुवाद प्रदान कर सकते हैं। पहला स्थान सिस्टम / भाषा फ़ोल्डर है। में फ़ाइलें बनाई जानी चाहिएen.yaml, fr.yaml, आदि प्रारूप। प्रत्येक याम्ल फ़ाइल में मुख्य जोड़े की एक सरणी या नेस्टेड सरणियाँ होनी चाहिए।

SITE_NAME: My Blog Site
HEADER:
   MAIN_TEXT: Welcome to my new blog site
   SUB_TEXT: Check back daily for the latest news

Session Based Active Language

आप सक्रिय भाषा के सत्र-आधारित भंडारण को सक्रिय कर सकते हैं। सक्षम करने के लिए आपके पास होना चाहिएsession : enables : true in system.yaml और भाषा सेटिंग सक्षम करें।

languages:
   session_store_active: true

Language Switcher

GPM से भाषा स्विचिंग प्लगइन स्थापित करें।

Setup with language specific domains

डिफ़ॉल्ट भाषा असाइन करने के लिए पर्यावरण आधारित भाषा हैंडलिंग कॉन्फ़िगरेशन है। इस विकल्प को अपने system.yaml में जोड़ें; इसे सच करना होगा।

pages.redirect_default_route: true

निम्नलिखित को अपने में जोड़ें .htaccess अपनी आवश्यकताओं के अनुसार भाषा स्लग और डोमेन नाम को फाइल करें और चुनें।

# http://www.cheat-sheets.org/saved-copy/mod_rewrite_cheat_sheet.pdf
# http://www.workingwith.me.uk/articles/scripting/mod_rewrite

# handle top level e.g. http://Grav-site.com/de
RewriteRule ^en/?$ "http://Grav-site.com" [R = 301, L] RewriteRule ^de/?$ "http://Grav-site.de" [R = 301, L]

# handle sub pages, exclude admin path
RewriteCond %{REQUEST_URI} !(admin) [NC]
RewriteRule ^en/(.*)$ "http://Grav-site.com/$1" [R = 301, L]
RewriteCond %{REQUEST_URI} !(admin) [NC]
RewriteRule ^de/(.*)$ "http://Grav-site.de/$1" [R = 301, L]

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

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

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

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 अब तक हमने जिस विषय पर चर्चा की, वह नीचे दिखाया गया है।

इस अध्याय में, हम अवधारणा को समझने के लिए Grav विषय बनाते हैं।

antimatter

जब आप Grav बेस पैकेज स्थापित करते हैं, तो डिफ़ॉल्ट Antimatter विषय स्थापित है, जो उपयोग करता है Nucleus(सीएसएस स्टाइल का एक सरल आधार सेट)। न्यूक्लियस एक हल्का सीएसएस फ्रेमवर्क है जिसमें आवश्यक सीएसएस स्टाइलिंग और एचटीएमएल मार्कअप होता है जो एक अनूठा लुक और फील देता है।

बूटस्ट्रैप

आइए हम एक थीम बनाएं जो लोकप्रिय बूटस्ट्रैप फ्रेमवर्क का उपयोग करे । बूटस्ट्रैप एक ओपन-सोर्स और सबसे लोकप्रिय HTML, CSS और JS फ्रेमवर्क है जो फ्रंट-एंड वेब डेवलपमेंट को तेज और आसान बनाता है।

निम्नलिखित कदम विषय के निर्माण का वर्णन करते हैं -

चरण 1: बेस थीम सेटअप

ग्रेव थीम के कुछ प्रमुख तत्व हैं, जैसा कि हमने थीम बेसिक्स अध्याय में अध्ययन किया है, जिसे नए विषय बनाने के लिए पालन किया जाना है।

  • Grav बेस पैकेज इंस्टॉल करने के बाद, बूटस्ट्रैप नामक एक फोल्डर बनाएं user/themes फ़ोल्डर नीचे दिखाया गया है।

  • के अंदर user/themes/bootstrap फ़ोल्डर, बनाएँ css/, fonts/, images/, js/ तथा templates/ जैसा की नीचे दिखाया गया।

  • नामक एक थीम फ़ाइल बनाएँ bootstrap.php अपने में user/themes/bootstrap फ़ोल्डर और उसमें निम्न सामग्री चिपकाएँ।

<?php
namespace Grav\Theme;
use Grav\Common\Theme;
class Bootstrap extends Theme {}
  • अब, एक थीम कॉन्फ़िगरेशन फ़ाइल बनाएं bootstrap.yaml में themes/bootstrap फ़ोल्डर और उसमें निम्न सामग्री लिखें।

enable: true
  • हम छोड़ देंगे blueprints फ़ोल्डर जैसा कि हमारे पास कोई कॉन्फ़िगरेशन विकल्प नहीं है और इस अध्याय के लिए नियमित सीएसएस का उपयोग करेगा।

चरण 2: बूटस्ट्रैप जोड़ें

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

पैकेज को अनज़िप करें और आपको तीन फ़ोल्डर दिखाई देंगे जैसे कि सीएसएस, फोंट और जेएस। अब इन 3 फ़ोल्डरों की सामग्री को समान रूप से नामित फ़ोल्डरों में कॉपी करेंuser/themes/bootstrap जो पहले बनाए गए थे।

चरण 3: बेस टेम्प्लेट

जैसा कि हमने पिछले अध्याय में अध्ययन किया है, सामग्री इसमें संग्रहीत है default.md फ़ाइल जो Grav को निर्देश देती है कि रेंडरिंग टेम्प्लेट को देखना है default.html.twig। इस फ़ाइल में वह सब कुछ शामिल है जो आपको एक पृष्ठ प्रदर्शित करने की आवश्यकता है।

एक बेहतर समाधान है जो ट्विग एक्सटेंड्स टैग का उपयोग करता है जो आपको ब्लॉक लेआउट को ब्लॉक के साथ परिभाषित करने की अनुमति देता है । यह टहनी टेम्पलेट को आधार टेम्पलेट को विस्तारित करने और आधार में परिभाषित ब्लॉकों के लिए परिभाषा प्रदान करने की अनुमति देगा।

एक सरल बूटस्ट्रैप बेस टेम्पलेट बनाने के लिए इन चरणों का पालन करें -

  • नामक एक फ़ोल्डर बनाएँ partials में user/themes/bootstrap/templatesफ़ोल्डर। इसका उपयोग हमारे आधार टेम्पलेट को संग्रहीत करने के लिए किया जाता है।

  • में partials फ़ोल्डर, एक बनाएँ base.html.twig निम्नलिखित सामग्री के साथ फ़ाइल।

<!DOCTYPE html>
<html lang = "en">
   <head>
      {% block head %}
      <meta charset = "utf-8">
      <meta http-equiv = "X-UA-Compatible" content = "IE = edge">
      <meta name = "viewport" content = "width = device-width, initial-scale = 1">
      {% if header.description %}
      <meta name = "description" content = "{{ header.description }}">
      {% else %}
      <meta name = "description" content = "{{ site.description }}">
      {% endif %}
      {% if header.robots %}
      <meta name = "robots" content = "{{ header.robots }}">
      {% endif %}
      <link rel = "icon" type = "image/png" href="{{ theme_url }}/images/favicon.png">

      <title>{% if header.title %}{{ header.title }} | {% endif %}{{ site.title }}</title>

      {% block stylesheets %}
         {# Bootstrap core CSS #}
         {% do assets.add('theme://css/bootstrap.min.css',101) %}

      {# Custom styles for this theme #}
         {% do assets.add('theme://css/bootstrap-custom.css',100) %}

         {{ assets.css() }}
      {% endblock %}

      {% block javascripts %}
         {% do assets.add('https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js', 101) %}
         {% do assets.add('theme://js/bootstrap.min.js') %}

         {% if browser.getBrowser == 'msie' and browser.getVersion >= 8 and browser.getVersion <= 9 %}
            {% do assets.add('https://oss.maxcdn.com/html5shiv/3.7.2/html5shiv.min.js') %}
            {% do assets.add('https://oss.maxcdn.com/respond/1.4.2/respond.min.js') %}
         {% endif %}

         {{ assets.js() }}
      {% endblock %}

      {% endblock head %}
   </head>
      <body>
         {# include the header + navigation #}
         {% include 'partials/header.html.twig' %}

         <div class = "container">
            {% block content %}{% endblock %}
         </div>

         <div class = "footer">
            <div class = "container">
               <p class = "text-muted">Bootstrap Theme for <a href = "http://getgrav.org">Grav</a></p>
            </div>
         </div>
      </body>
   {% block bottom %}{% endblock %}
</html>

चरण 4: इसे तोड़कर

आइए देखें कि कोड कैसे काम करता है base.html.twig फ़ाइल के रूप में नीचे दिखाया गया है।

  • {% block head %}{% endblock head %}सिंटैक्स का उपयोग आधार टहनी टेम्पलेट में एक क्षेत्र को परिभाषित करने के लिए किया जाता है। के अंदर का सिर{% endblock head %} वैकल्पिक है।

  • अगर स्टेटमेंट टेस्ट करता है कि क्या ए meta descriptionपृष्ठ शीर्षकों में सेट किया गया है या नहीं। यदि सेट नहीं है, तो टेम्पलेट का उपयोग करके प्रस्तुत करना चाहिएsite.description के रूप में परिभाषित किया गया है user/config/site.yaml फ़ाइल।

  • वर्तमान विषय का मार्ग इसके द्वारा दिया गया है theme_url परिवर्तनशील।

  • वाक्य रचना {% do assets.add('theme://css/bootstrap.min.css',101) %} का उपयोग करने के लिए किया जाता है Asset Managertheme://वर्तमान थीम पथ का प्रतिनिधित्व करता है और 101 उस क्रम का प्रतिनिधित्व करता है जहां उच्च मूल्य पहले निम्न मान से आता है। हम सीडीएन लिंक भी स्पष्ट रूप से प्रदान कर सकते हैं -

{% do assets.addCss('http://fonts.googleapis.com/css?family = Open + Sans') %}

or,

{% do assets.addJs(' https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js') %}
  • कॉल करने पर सभी जावास्क्रिप्ट टैग और सीएसएस लिंक टैग टेम्पलेट द्वारा प्रदान किए जाते हैं {{ assets.css() }} या {{ assets.js() }} क्रमशः बनाया जाता है।

  • वाक्य रचना {# ... #} का उपयोग ट्विग में टिप्पणी लिखने के लिए किया जाता है।

  • एक और टहनी टेम्पलेट को शामिल करने के लिए {% include 'partials/header.html.twig' %} टैग का उपयोग किया जाता है।

  • एक टेम्पलेट से सामग्री द्वारा प्रदान की जाती है {% block content %}{% endblock %} टैग।

  • कस्टम जावास्क्रिप्ट आरंभीकरण या विश्लेषणात्मक कोड जोड़ने के लिए, {% block bottom %}{% endblock %} टेम्प्लेट के लिए प्लेसहोल्डर के रूप में टैग का उपयोग किया जाता है।

चरण 5: हैडर टेम्पलेट

कब {% include 'partials/header.html.twig' %}निष्पादित किया जाता है, ट्विग प्रतिपादन इंजन टिग टेम्पलेट के लिए खोज करता है। तो बनाएँheader.html.twig टेम्पलेट फ़ाइल के अंदर user/themes/bootstrap/templates/partials निम्नलिखित सामग्री के साथ फ़ोल्डर।

<nav class = "navbar navbar-default navbar-inverse navbar-static-top" role = "navigation">
   <div class = "container">
      <div class = "navbar-header">
         <button type = "button" class = "navbar-toggle"
            data-toggle = "collapse" data-target = ".navbar-collapse">
               <span class = "sr-only">Toggle navigation</span>
               <span class = "icon-bar"></span>
               <span class = "icon-bar"></span>
               <span class = "icon-bar"></span>
         </button>
         <a class = "navbar-brand" href = "#">Grav</a>
      </div>
      
      <div class = "navbar-collapse collapse">
         <ul class = "nav navbar-nav navbar-right">
            {% for page in pages.children %}
            {% if page.visible %}
            {% set current_page = (page.active or page.activeChild) ? 'active' : '' %}
            <li class = "{{ current_page }}"><a href = "{{ page.url }}">{{ page.menu }}</a></li>
            {% endif %}
            {% endfor %}
         </ul>
      </div>
      
   </div>
</nav>

जब भी कोई नया पेज बनाया जाता है तो उपरोक्त कोड एक नावबार बनाता है और सभी मेनू आइटम को स्वचालित रूप से प्रदर्शित करता है user/pages फ़ोल्डर।

Step 6 − Default Template

सामग्री के प्रत्येक आइटम में एक विशेष फ़ाइल नाम होता है जैसे कि default.md जो ग्रेव को एक टेम्प्लेट फ़ाइल के लिए खोज करने का निर्देश देता है default.html.twig। अब हम बनाते हैंdefault.html.twig अपने में फाइल करें user/themes/bootstrap/templates/ निम्नलिखित सामग्री के साथ फ़ोल्डर।

{% extends 'partials/base.html.twig' %}
{% block content %}
   {{ page.content }}
{% endblock %}

उपरोक्त default.html.twig फ़ाइल फैली हुई है partials/base.html.twig और आधार टेम्पलेट का उपयोग करने के लिए कहता है {{ page.content }} के लिए content खंड मैथा।

चरण 7: थीम सीएसएस

में partials/base.html.twig एक कस्टम थीम सीएसएस का उपयोग करते हुए फ़ाइल assets.add('theme://css/bootstrap-custom.css',100), जो आपकी साइट में उपयोग किए गए किसी भी कस्टम सीएसएस को संग्रहीत करता है।

अब हम निम्नलिखित सामग्री के साथ उपयोगकर्ता / थीम / बूटस्ट्रैप / सीएसएस फ़ोल्डर में एक बूटस्ट्रैप-custom.css फ़ाइल बनाते हैं -

/* Restrict the width */
.container {
   width: auto;
   max-width: 960px;
   padding: 0 12px;
}

/* Place footer text center */
.container .text-muted {
   margin: 18px 0;
   text-align: center;
}

/* Sticky footer styles
-------------------------------------------------- */
html {
   position: relative;
   min-height: 80%;
}

body {
   /* Margin bottom by footer height */
   margin-bottom: 60px;
}

.footer {
   position: absolute;
   bottom: 0;
   width: 100%;
   /* Set the fixed height of the footer here */
   height: 50px;
   background-color: #dcdcdc;
}

/* Typography */
/* Tables */
table {
   width: 100%;
   border: 1px solid #f0f0f0;
   margin: 30px 0;
}

th {
   font-weight: bold;
   background: #f9f9f9;
   padding: 5px;
}

td {
   padding: 5px;
   border: 1px solid #f0f0f0;
}

/* Notice Styles */
blockquote {
   padding: 0 0 0 20px !important;
   font-size: 16px;
   color: #666;
}

blockquote > blockquote > blockquote {
   margin: 0;
}

blockquote > blockquote > blockquote p {
   padding: 15px;
   display: block;
   margin-top: 0rem;
   margin-bottom: 0rem;
   border: 1px solid #f0f0f0;
}

blockquote > blockquote > blockquote > p {
   /* Yellow */
   margin-left: -75px;
   color: #8a6d3b;
   background-color: #fcf8e3;
   border-color: #faebcc;
}

blockquote > blockquote > blockquote > blockquote > p {
   /* Red */
   margin-left: -100px;
   color: #a94442;
   background-color: #f2dede;
   border-color: #ebccd1;
}

blockquote > blockquote > blockquote > blockquote > blockquote > p {
   /* Blue */
   margin-left: -125px;
   color: #31708f;
   background-color: #d9edf7;
   border-color: #bce8f1;
}

blockquote > blockquote > blockquote > blockquote > blockquote > blockquote > p {
   /* Green */
   margin-left: -150px;
   color: #3c763d;
   background-color: #dff0d8;
   border-color: #d6e9c6;
}

चरण 8: परीक्षण

अपनी डिफ़ॉल्ट थीम को नए के साथ बदलें bootstrapविषय। को खोलोuser/config/system.yaml फ़ाइल और उस पंक्ति को संपादित करें जिसमें शामिल हैं -

pages:
   themes: antimatter

और उपरोक्त कोड को इसमें बदलें -

pages:
   theme: bootstrap

अब अपनी Grav साइट को पुनः लोड करें और आप नीचे दिखाए गए अनुसार नई स्थापित थीम देखेंगे।

इस अध्याय में, आइए अध्ययन करते हैं Twig Filters and Functions। फिल्टर का उपयोग डेटा को उस तरह से स्वरूपित करने के लिए किया जाता है जैसा आप आवश्यक आउटपुट के साथ चाहते हैं। सामग्री उत्पन्न करने के लिए फ़ंक्शंस का उपयोग किया जाता है।

Twig टेम्प्लेट पाठ फाइलें हैं जिनमें भाव और चर को मान द्वारा प्रतिस्थापित किया जाता है। टहनी तीन प्रकार के टैग का उपयोग करता है।

  • Output tags - मूल्यांकन किए गए भाव परिणाम को प्रदर्शित करने के लिए निम्न सिंटैक्स का उपयोग किया जाता है।

{{  Place Your Output Here  }}
  • Action Tags - निम्नलिखित कथनों का उपयोग यहाँ कथनों को निष्पादित करने के लिए किया जाता है।

{%  executable statements are placed here  %}
  • Comment tags - निम्नलिखित सिंटैक्स का उपयोग ट्विग टेम्प्लेट फ़ाइल में टिप्पणी लिखने के लिए किया जाता है।

{#  write your comment here  #}

टहनी फ़िल्टर

टहनी फ़िल्टर का उपयोग करता है |फिल्टर नाम के बाद ट्विन चर के लिए फिल्टर लागू करने के लिए चरित्र। तर्क जुड़वा कार्यों की तरह ही कोष्ठक में पारित किया जा सकता है।

निम्न तालिका Grav में प्रयुक्त Twig फिल्टर दिखाती है -

अनु क्रमांक। फ़िल्टर और विवरण उदाहरण
1

Absolute URL

यह सापेक्ष पथ लेता है और इसे एक पूर्ण URL में परिवर्तित करता है।

'<img src="/some/path/img.jpg"/>' |absolute_url

में कनवर्ट करता है -

<img src="http://learn.getGrav.org/some/path/img.jpg" />
2

Camelize

यह एक स्ट्रिंग को CamelCase प्रारूप में परिवर्तित करता है।

'contact_us'| camelize

में कनवर्ट करता है -

ContactUs
3

Contains

अगर यह स्ट्रिंग पाता है।

'This is some string' | contains('some')

आउटपुट है -

1
4

Defined

आप जाँच सकते हैं कि कुछ चर परिभाषित किया गया है या नहीं। यदि चर परिभाषित नहीं है, तो आप एक डिफ़ॉल्ट मान प्रदान कर सकते हैं।

set header_image_width = 
page.header.header_image_width|defined(900)

यह सेट करता है header_image_width यदि यह परिभाषित नहीं है तो मान 900 के साथ।

5

Ends-With

आप यह निर्धारित कर सकते हैं कि एंड्स-विथ फ़िल्टर का उपयोग करके किसी स्ट्रिंग को दिए गए स्ट्रिंग के साथ समाप्त होता है या नहीं।

'this is an example for ends-with filter' | ends_with('filter')

इसे इस प्रकार प्रदर्शित किया जाता है -

True
6

FieldName

यह फ़ील्ड नाम को डॉट नोटेशन में बदलकर फ़िल्टर करता है।

'field.name'|fieldName

इसे इस प्रकार प्रदर्शित किया जाता है -

field[name]
7

Humanize

इसका उपयोग स्ट्रिंग को मानव पठनीय प्रारूप में बदलने के लिए किया जाता है।

'some_text_to_read'|humanize

इसे इस प्रकार प्रदर्शित किया जाता है -

Some text to read
8

Ksort

यह कुंजी का उपयोग करके एक सरणी मानचित्र को सॉर्ट करता है।

{% set ritems = {'orange':1, 'apple':2, 'peach':3}|ksort %}
{% for key, value in ritems %}{{ key }}:{{ value }}, {% endfor %}

इसे इस प्रकार प्रदर्शित किया जाता है -

apple:2, orange:1, peach:3,
9

Left Trim

यह एक स्ट्रिंग की शुरुआत में सफेद रिक्त स्थान को निकालने के लिए उपयोग किया जाता है और स्ट्रिंग के बाईं ओर से दिए गए मिलान चरित्र को निकालता है।

'/strip/leading/slash/'|ltrim('/')

इसे इस प्रकार प्रदर्शित किया जाता है -

strip/leading/slash/
10

Markdown

इसका उपयोग Grav के मार्कडाउन पार्सर का उपयोग करके स्ट्रिंग युक्त मार्कडाउन को HTML में बदलने के लिए किया जाता है।

'## some text with markdown'|markdown

इसे इस प्रकार प्रदर्शित किया जाता है -

some text with markdown

1 1

MD5

स्ट्रिंग के लिए md5 हैश इस फ़िल्टर का उपयोग करके बनाया जा सकता है।

'something'|md5

इसे इस प्रकार प्रदर्शित किया जाता है -

437b930db84b8079c2dd804a71936b5f
12

Monthize

Monthize फ़िल्टर का उपयोग करके, हम एक पूर्णांक संख्या को दिनों की संख्या में बदल सकते हैं।

'61'|monthize

इसे इस प्रकार प्रदर्शित किया जाता है -

2
13

Nice Time

नाइस टाइम फिल्टर का उपयोग करके, हम आउटपुट के रूप में अच्छे मानव पठनीय समय प्रारूप में एक तारीख प्राप्त कर सकते हैं।

page.date|nicetime(false)

इसे इस प्रकार प्रदर्शित किया जाता है -

3 hrs ago
14

Ordinalize

ऑर्डिनल (जैसे 1 सेंट , 2 एन डी , 3 आरडी ) को पूर्णांक के लिए ऑर्डिनलाइज फिल्टर का उपयोग करके दिया जा सकता है।

'78'| ordinalize

इसे इस प्रकार प्रदर्शित किया जाता है -

78th
15

Pluralize

एक स्ट्रिंग को बहुवचन फिल्टर का उपयोग करके अपने बहुवचन अंग्रेजी रूप में परिवर्तित किया जा सकता है।

'child'|pluralize

इसे इस प्रकार प्रदर्शित किया जाता है -

children
16

Randomize

यह फ़िल्टर प्रदान की गई सूची को यादृच्छिक बनाने में मदद करता है। यदि पैरामीटर में कोई मान हैं, तो उन मानों को यादृच्छिक करने से छोड़ दिया जाता है।

{% set ritems = ['one', 'two', 'three', 'four', 'five', 'six', 'seven', 'eight', 'nine', 'ten']|randomize(3) %}
{% for ritem in ritems %}{{ ritem }}, {% endfor %}

इसे इस प्रकार प्रदर्शित किया जाता है -

one, two, three, eight, six, five, nine, seven, ten, four,
17

Right Trim

यह बाएं ट्रिम के समान है सिवाय इसके कि यह व्हाट्सएप और मिलान वाले चरित्र को स्ट्रिंग के दाईं ओर से हटाता है।

'/strip/leading/slash/'|rtrim('/')

इसे इस प्रकार प्रदर्शित किया जाता है -

/strip/leading/slash
18

Singularize

एक स्ट्रिंग को एकवचन फिल्टर का उपयोग करके अंग्रेजी एकवचन संस्करण में परिवर्तित किया जा सकता है।

'vehicles'|singularize

इसे इस प्रकार प्रदर्शित किया जाता है -

vehicle
19

Safe Email

सुरक्षित ईमेल फ़िल्टर का उपयोग ASCII वर्णों में एक ईमेल पते को परिवर्तित करने के लिए किया जाता है ताकि यह ईमेल को स्पैम करने के लिए कठिन बना दे।

"[email protected]"|safe_email

आउटपुट है -

[email protected]
20

SortByKey

यह कुंजियों का उपयोग करके सरणी मानचित्र को सॉर्ट करने के लिए उपयोग किया जाता है।

{% set people = [{'email':'[email protected]', 'id':3}, {'email':'[email protected]', 'id':1}, {'email':'[email protected]', 'id':7}]|sort_by_key('id') %}
{% for person in people %}{{ person.email }}:{{ person.id }}, {% endfor %}

यह प्रदर्शित करता है -

[email protected]:1, [email protected]:3, [email protected]:7,
21

Starts-With

आप निर्धारित कर सकते हैं कि स्टार्ट-विथ फ़िल्टर का उपयोग करके किसी स्ट्रिंग को किसी स्ट्रिंग से शुरू किया जाता है या नहीं।

'this is an example for starts-with filter' |starts_with('this')

आउटपुट है -

true
22

Translate

अधिक विस्तृत जानकारी के लिए।

MY_LANGUAGE_KEY_STRING

यह प्रदर्शित करता है -

'Some text in English'
23

Translate Admin

यह वर्तमान भाषा में एक स्ट्रिंग का अनुवाद करता है जिसे इसमें सेट किया गया है user.yaml फ़ाइल।

24

Titleize

शीर्षक का उपयोग करके एक स्ट्रिंग को शीर्षक केस प्रारूप में परिवर्तित किया जाता है।

'welcome page'|titleize

इसे इस प्रकार प्रदर्शित किया जाता है -

Welcome Page
25

UnderScoreize

अंडरस्कोराइज़ फिल्टर का उपयोग करके प्रारूप।

'ContactUs'|underscorize

यह करने के लिए परिवर्तित है -

contact_us
26

Truncate a string

आप किसी स्ट्रिंग को छोटा करने या स्ट्रिंग को छोटा करने के लिए Truncate का उपयोग कर सकते हैं, आपको वर्णों की संख्या निर्दिष्ट करनी होगी।

'one sentence. two sentences'|truncate(5)

यह करने के लिए छोटा है -

one s...

आप उपयोग कर सकते हैं true पैरामीटर के रूप में यदि आप वर्णों की दी गई संख्या के बाद स्ट्रिंग को निकटतम वाक्य-अंत तक नहीं करना चाहते हैं।

'one sentence. two sentences'|truncate(5, true)

यह करने के लिए छोटा है -

one sentence
आप HTML पाठ को भी हटा सकते हैं, लेकिन आपको इसका उपयोग करना चाहिए striptags पहले फ़िल्टर करें truncate फिल्टर।
'<p>one <strong>sentence<strong>. two sentences</p>'|striptags|truncate(5)

इसे इस प्रकार प्रदर्शित किया जाता है -

one s

टहनी के कार्य

पैरामीटर को पास करके ट्विग फ़ंक्शंस को सीधे बुलाया जाता है। निम्नलिखित तालिका के कार्यों को सूचीबद्ध करता है -

अनु क्रमांक। समारोह विवरण उदाहरण
1

Array

इस फ़ंक्शन ने सरणी के लिए एक मान डाला।

array(value)
2

Authorize

यह फ़ंक्शन एक प्रमाणित उपयोगकर्ता बनाता है जो एक संसाधन को देखने के लिए अधिकृत है और अनुमति स्ट्रिंग या अनुमति स्ट्रिंग की सरणी को स्वीकार करता है।

authorize(['admin.statistics', 'admin.super'])
3

Dump

यह एक मान्य टहनी चर को स्वीकार करता है और इसे ग्रेव डिबगर पैनल में डाल देता है। हालाँकि, डिबगर को संदेश टैब मान देखने में सक्षम होना चाहिए।

dump(page.header)
4

Debug

यह डंप () फ़ंक्शन के समान काम करता है।

5

Gist

यह फ़ंक्शन Gistub Gist ID के आधार पर Gist एम्बेड कोड बनाता है।

6

Random String Generation

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

generate_random_string(10)
7

Repeat

यह फ़ंक्शन दिए गए समय के लिए स्ट्रिंग को दोहराएगा।

repeat('Grav ', 10) will repeat Grav 10 times.
8

String

निर्दिष्ट वर्ण लंबाई की एक यादृच्छिक स्ट्रिंग उत्पन्न करता है।

ta (23)
9

Translate Array

यह एक फंक्शन है जिसके साथ जुड़ा हुआ है |ta फिल्टर।

10

Url

यह फ़िल्टर एक URL बनाएगा और यह PHP URL स्ट्रीम को मान्य HTML संसाधनों में भी परिवर्तित करेगा। यदि URL को हल नहीं किया जा सकता है तो एक डिफ़ॉल्ट मान पारित किया जा सकता है।

url('theme://images/logo.png') | default('http://www.placehold.it/150x100/f4f4f4')
1 1

Translate

अनुवाद फ़िल्टर का उपयोग करते हुए, एक स्ट्रिंग का अनुवाद किया जाता है |t फिल्टर।

t('SITE_NAME')

इसका अनुवाद है -

Site Name

इस अध्याय में, हम समझते हैं Theme VariablesGrav में। ऑब्जेक्ट और वेरिएबल्स को आपके थीम को डिज़ाइन करते समय टहनी टेम्प्लेट से एक्सेस किया जाता है और इन ऑब्जेक्ट्स और वेरिएबल्स को Twig Templating Framework द्वारा पढ़ा और हेरफेर किया जाता है।

कोर ऑब्जेक्ट्स

टहनी टेम्पलेट कई हैं core objects; प्रत्येक वस्तु का एक सेट है variables तथा functions

निम्न तालिका संक्षिप्त विवरण के साथ चर दिखाती है।

अनु क्रमांक। चर और विवरण
1

{{ base_dir }}

हम इस वैरिएबल का उपयोग करके Grav इंस्टॉल बेस फाइल डायरेक्टरी प्राप्त कर सकते हैं।

2

{{ base_url }}

इस चर का उपयोग करके Grav साइट के बेस url तक पहुँचा जा सकता है।

3

{{ base_url_relative }}

यह बेस यूआरएल के सापेक्ष पथ को ग्रेव साइट पर लौटाता है।

4

{{ base_url_absolute }}

यह बेस यूआरएल के निरपेक्ष पथ को Grav साइट पर लौटाता है।

5

{{ theme_dir }}

इसका उपयोग वर्तमान थीम की फ़ाइल निर्देशिका फ़ोल्डर को वापस करने के लिए किया जाता है।

6

{{ theme_url }}

इसका उपयोग वर्तमान विषय के सापेक्ष URL को वापस करने के लिए किया जाता है।

config ऑब्जेक्ट

में configuration.yaml फ़ाइल, किसी भी Grav विन्यास सेटिंग तक पहुँचने के लिए विन्यास वस्तु सेट है।

{{ config.pages.theme }}

यह वर्तमान में कॉन्फ़िगर की गई थीम को लौटा देगा।

साइट वस्तु

के लिए एक उपनाम प्रदान करता है config.site ऑब्जेक्ट, कॉन्फ़िगरेशन सेट में प्रतिनिधित्व करता है site.yaml फ़ाइल।

स्टाइलशीट ऑब्जेक्ट

ये ऑब्जेक्ट सीएसएस स्टाइलशीट परिसंपत्तियों को संग्रहीत करने के लिए एक सरणी प्रदान करते हैं, जिसे सीएसएस को टेम्पलेट्स में जोड़ने के लिए लूप किया जा सकता है।

स्क्रिप्ट वस्तु

ये ऑब्जेक्ट एक ऐसी सरणी प्रदान करते हैं, जिसमें जावास्क्रिप्ट संपत्ति होती है, जिसे लूप किया जाता है और जावा स्क्रिप्ट को टेम्प्लेट में जोड़ा जाता है।

पृष्ठ वस्तु

चूंकि Grav की संरचना में परिभाषित किया गया है pages/ फ़ोल्डर, page objectप्रत्येक पृष्ठ का प्रतिनिधित्व करने के लिए जिम्मेदार है। page object उस पृष्ठ के बारे में सभी जानकारी शामिल है जिस पर आप वर्तमान में काम कर रहे हैं।

निम्नलिखित तालिका पृष्ठ वस्तु के तरीकों को दिखाती है।

अनु क्रमांक। विधि और विवरण उदाहरण
1

summary([size])

यह पैरामीटर के रूप में प्रदान किए गए निर्दिष्ट आकार के साथ पृष्ठ सामग्री का एक सार देता है।

यदि आकार निर्दिष्ट नहीं है, तो मान से प्राप्त किया जाता है summary.size चर में system/config/site.yaml फ़ाइल।

आप सीमांकित भी कर सकते हैं ===आपकी सामग्री में। सीमांकक से पहले की सामग्री का उपयोग सारांश के लिए किया जाएगा।

{{ page.summary }}

या

{{ page.summary(80) }}
2

content()

इसका उपयोग पृष्ठ की संपूर्ण HTML सामग्री प्राप्त करने के लिए किया जाता है।

{{ page.content }}
3

headers()

यह पृष्ठ के YAML सामने-मामले में परिभाषित पृष्ठ शीर्षकों को लौटाता है।

title: About Us
author: Johnson
उपरोक्त हेडर को इस प्रकार एक्सेस किया जा सकता है:
The author of this page is:  {{ page.header.author }}
4

media()

इसका उपयोग सभी मीडिया फ़ाइलों जैसे छवियों, वीडियो और अन्य फ़ाइलों तक पहुंचने के लिए किया जाता है। यह एक सरणी लौटाएगा जिसमें एक पृष्ठ से जुड़े सभी मीडिया होंगे।

{% set first_image = page.media|first %}
{% set my_pdf = page.media['myfile.pdf'] %}
{% for image in page.media.images  %}
   {{ image.html }}
{% endfor %}
5

title()

यह पृष्ठ के शीर्षक को लौटाने के लिए सेट है जो पृष्ठ के लिए YAML हेडर में परिभाषित किया गया है।

title: My Page
6

menu()

का मूल्य menuवैरिएबल लौटाया जाता है जो पेज के YAML हेडर में निर्दिष्ट होता है। अगर दtitle चर सेट नहीं किया गया है, तो यह डिफ़ॉल्ट रूप से होगा title

title: My Blog
menu: my blog page
7

visible()

इसका उपयोग पृष्ठ की दृश्यता निर्धारित करने के लिए किया जाता है। आमतौर पर अवधि (यानी, 01.foldername) के बाद संख्यात्मक मान वाले पृष्ठ मेनू में प्रदर्शित किए जाते हैं और फ़ोल्डर नाम जिसमें संख्यात्मक मान नहीं होते हैं (यानी, फ़ोल्डरनाम) दिखाई नहीं देते हैं। हम इसे पेज हेडर में ओवरराइड कर सकते हैं।

title: About Us
visible: true
8

routable()

इसका उपयोग करके हम यह निर्धारित कर सकते हैं कि कोई पृष्ठ है या नहीं routable या not routableइसका अर्थ है कि क्या आप पृष्ठ पर अपने ब्राउज़र को इंगित करते हुए सामग्री वापस प्राप्त कर सकते हैं। जो पेज रूटेबल नहीं हैं, उनका उपयोग प्लगइन्स, टेम्प्लेट आदि में किया जा सकता है और इन पेजों को सीधे एक्सेस नहीं किया जा सकता है। यह पेज हेडर में सेट किया गया है।

title: My Page
routable: true
9

slug()

इस चर का उपयोग करके, हम पृष्ठ के URL में प्रदर्शित प्रत्यक्ष नाम प्राप्त कर सकते हैं।

my-page
10

url([include_host = false])

इसका उपयोग पृष्ठ का URL वापस करने के लिए किया जाता है

{{ page.url }}  { # could return /myfolder/mypage #}

या

{{ page.url(true) }}  {# could return http: //mysite.com/ myfolder/mypage #}
1 1

route()

इसका उपयोग पृष्ठ की आंतरिक रूटिंग को वापस करने के लिए किया जाता है।

12

home()

इस चर का उपयोग करके आप यह निर्धारित कर सकते हैं कि पृष्ठ किस रूप में कॉन्फ़िगर किया गया है homeपृष्ठ या नहीं। यह तब सही होता है जब किसी पृष्ठ को होम पेज के रूप में कॉन्फ़िगर किया गया हो और कॉन्फ़िगर न किए जाने पर गलत हो। आप इस सेटिंग को पा सकते हैंsystem.yaml फ़ाइल।

13

root()

यह निर्धारित करता है कि वर्तमान पृष्ठ पदानुक्रम का मूल पृष्ठ है या नहीं। यह लौट आता हैtrue यदि यह एक मूल पृष्ठ है या false अगर यह रूट पेज नहीं है।

14

active()

आप यह निर्धारित कर सकते हैं कि क्या ब्राउज़र इस चर का उपयोग करके वर्तमान पृष्ठ तक पहुंच रहा है। यह लौट आता हैtrue यदि ब्राउज़र इस पृष्ठ तक पहुँच रहा है या false अगर यह नहीं है।

15

modular()

इस चर का उपयोग करके, हम यह निर्धारित कर सकते हैं कि यह पृष्ठ मॉड्यूलर है या नहीं। यदि यह एक मॉड्यूलर पेज है तो यह वापस आ जाता हैtrue तथा false अगर यह नहीं है।

16

activeChild()

यह चर निर्धारित कर सकता है कि इस URI के URL में सक्रिय पृष्ठ का URL है या नहीं; या, सरल शब्दों में इस पृष्ठ का URL वर्तमान URL में है। यह तब बहुत उपयोगी होता है जब आप नेवीगेशन पर काम कर रहे होते हैं और आप यह जानना चाहते हैं कि क्या पेज एक ही पैरेंट पेज पर चल रहे हैं।

17

find(url)

मार्ग URL द्वारा निर्दिष्ट के रूप में, पृष्ठ ऑब्जेक्ट इस चर द्वारा लौटाया जाता है।

{% include 'modular/author-detail.html.twig' with {'page': page.find('/authors/ john-bloggs')} %}
18

collection()

इस चर का उपयोग संग्रह के पृष्ठ शीर्षलेखों द्वारा निर्धारित संदर्भ के लिए पृष्ठों के समूह को वापस करने के लिए किया जाता है।

{% for child in page.collection %}
   {% include 'partials /blog_item.html.twig' with {'page':child, 'truncate':true} %}
{% endfor %}
19

isFirst()

यदि वर्तमान पृष्ठ इसके पहले पृष्ठ का भाई है, तो यह वापस आ जाता है true और लौटता है false

20

isLast()

यदि वर्तमान पृष्ठ इसके भाई-बहन के पृष्ठ से अंतिम है, तो यह वापस आ जाता है true और लौटता है false

21

nextSibling()

वर्तमान स्थिति के संदर्भ में, यह सरणी से अगला सिबलिंग पृष्ठ लौटाता है।

22

prevSibling()

वर्तमान स्थिति के संदर्भ में, यह सरणी से पिछला सिबलिंग पृष्ठ लौटाता है।

23

children()

जैसा कि पृष्ठ सामग्री संरचना में परिभाषित किया गया है, इस चर के द्वारा बाल पृष्ठों की सरणी को लौटाया जाता है।

24

orderBy()

क्रमबद्ध बच्चों के क्रम प्रकार को इस विधि द्वारा लौटाया जाता है। शामिल किए जाने वाले मान हैंdefault, title, date तथा folder और ये मान पृष्ठ शीर्ष लेख में कॉन्फ़िगर किए गए हैं।

25

orderDir()

क्रमबद्ध बाल पृष्ठों का क्रम निर्देश इस विधि द्वारा वापस किया जाता है। और मूल्य या तो हो सकते हैंasc(आरोही) या desc(descending)। आमतौर पर ये मान पेज हेडर में कॉन्फ़िगर किए जाते हैं।

26

orderManual()

यह विधि एक सरणी देता है जिसमें मैनुअल पेज ऑर्डर करने की सुविधा होती है और यह ऑर्डर पेज के किसी भी बच्चे के लिए होगा। यह मान आमतौर पर पेज हेडर में सेट किया जाएगा।

27

maxCount()

यह चर बताता है कि कितने बच्चों के पृष्ठों को वापस करने की अनुमति है। आमतौर पर पृष्ठ हेडर्स में मान निर्दिष्ट किया जाता है।

28

children.count()

यह चर एक पृष्ठ के लिए कितने बाल पृष्ठ देता है।

29

children.current()

यह चर वर्तमान बाल आइटम लौटाएगा।

30

children.next()

यह बाल पृष्ठों की एक सरणी से अगले बाल आइटम को वापस कर देगा।

31

children.prev()

यह चाइल्ड पेजों की एक सरणी से पिछले चाइल्ड आइटम को लौटाएगा।

32

children.nth(position)

इससे बच्चों की सरणी में बच्चे की स्थिति वापस आ जाएगी।

33

parent()

एक नेस्टेड ट्री संरचना में जब आप मूल पृष्ठ पर वापस नेविगेट करना चाहते हैं, तब आप इस चर का उपयोग कर सकते हैं। यह वर्तमान पृष्ठ के लिए मूल पृष्ठ ऑब्जेक्ट लौटाएगा।

34

isPage()

इस चर का उपयोग करके, आप यह निर्धारित कर सकते हैं कि क्या इस पृष्ठ में एक वास्तविक है .md फ़ाइल या यह रूट करने के लिए सिर्फ एक फ़ोल्डर है।

35

isDir()

इस चर का उपयोग करके आप यह निर्धारित कर सकते हैं कि क्या वर्तमान पृष्ठ केवल राउटिंग के लिए एक फ़ोल्डर है। यह लौट आता हैtrue या false इसके आधार पर।

36

id()

यह पृष्ठ के लिए अद्वितीय आईडी लौटाएगा।

37

modified()

जब पृष्ठ अंतिम बार संशोधित किया गया था, तो यह टाइमस्टैम्प लौटाता है।

38

date()

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

39

filePath()

इसके इस्तेमाल से आप पेज का पूरा फाइल पा सकते हैं।

/Users/yourname/sites/ Grav/user/pages/ 01.home/default.md
40

filePathClean()

यह सापेक्ष पथ लौटा देगा।

user/pages/ 01.home/default.md
41

path()

यह उस निर्देशिका का पूर्ण पथ लौटाएगा जिसमें वर्तमान पृष्ठ मौजूद है।

/Users/yourname /sites/ Grav/user/pages /01.home
42

folder()

यह पृष्ठ के लिए फ़ोल्डर का नाम वापस कर देगा।

43

taxonomy()

यह टैक्सोनॉमी की एक सरणी लौटाएगा जो पेज के साथ जुड़ा हुआ है।

पेज ऑब्जेक्ट

पेज ऑब्जेक्ट को ऑब्जेक्ट्स के नेस्टेड ट्री के रूप में दर्शाया जाता है। यह नस्टेड ट्री बनाते समय बहुत उपयोगी हैnavigations, sitemap या finding a particular page

बच्चों की विधि

यह पृष्ठ ऑब्जेक्ट की एक सरणी देता है जिसमें चाइल्ड पेज होते हैं। किसी ट्री जैसे संरचना वाले पृष्ठ ऑब्जेक्ट को फ़ोल्डर में प्रत्येक पृष्ठ पर पुनरावृत्त किया जा सकता है।

मेनू के लिए शीर्ष स्तर के पृष्ठ प्राप्त करने के लिए, निम्न कोड का उपयोग करें।

<ul class = "navigation">
   {% for page in pages.children %}
      {% if page.visible %}
         <li><a href = "{{ page.url }}">{{ page.menu }}</a></li>
      {% endif %}
   {% endfor %}
</ul>

उड़ी वस्तु

वर्तमान यूआरआई का हिस्सा उड़ी वस्तु के कई तरीकों का उपयोग करके पहुँचा जा सकता है।

http://mysite.com/Grav/section/category/page.json/param1:foo/param2:bar/?query1 = baz&query2 = qux:

निम्न तालिका उड़ी वस्तु के तरीकों को दिखाती है।

अनु क्रमांक। विधि और विवरण उदाहरण
1

path()

इस विधि का उपयोग करके वर्तमान url के भाग तक पहुँचा जा सकता है।

uri.path = /section/category/page
2

paths()

इस पद्धति का उपयोग करके पथ तत्वों की सरणी को लौटाया जाता है।

uri.paths = [section, category, page])
3

route([absolute = false][, domain = false])

यह विधि निरपेक्ष या सापेक्ष URL के साथ मार्ग देती है।

uri.route(true) = http://mysite.com/Grav/ section/category/page

या,

uri.route() = /section/category/page)
4

params()

यह URL में पैरामीटर भाग लौटाएगा।

uri.params = /param1:foo/param2:bar
5

param(id)

यह परम का मूल्य लौटाएगा।

uri.param('param1') = foo
6

query()

इस पद्धति का उपयोग करके URL के क्वेरी भाग को एक्सेस किया जा सकता है।

uri.query = query1=bar&query2=qux
7

query(id)

इसका उपयोग करके आप विशिष्ट क्वेरी आइटम तक पहुँच सकते हैं।

uri.query('query1') = bar
8

url([include_host = true])

यह पूरा URL लौटाता है जिसमें होस्ट हो या न हो।

uri.url(false) = Grav/section/ category/page/param:foo?query = bar
9

extension()

यह एक्सटेंशन वापस कर देगा या यदि प्रदान नहीं किया जाता है, तो यह html वापस कर देगा।

uri.extension = json)
10

host()

यह URL का होस्ट लौटाता है।

uri.host = mysite.com
1 1

base()

इससे URL का आधार भाग वापस आ जाएगा।

uri.base = http://mysite.com
12

rootUrl([include_host = true])

यह Grav इंस्टेंस का रूट URL लौटाएगा।

uri.rootUrl() = http://mysite.com/Grav
13

referrer()

पृष्ठ की संदर्भ जानकारी इस विधि द्वारा वापस आ जाती है।

हेडर ऑब्जेक्ट

यह इसके लिए एक वैकल्पिक है page.header()मूल पृष्ठ का। जब आप बाल पृष्ठों के माध्यम से लूपिंग कर रहे हों, तो मूल पृष्ठ शीर्षलेख का उपयोग करना अधिक उपयुक्त होता है।

सामग्री वस्तु

यह इसके लिए एक वैकल्पिक है page.content() मूल पृष्ठ का।

करयुक्त वस्तु

साइट की सभी वर्गीकरण जानकारी वैश्विक करोनॉमी ऑब्जेक्ट में निहित हैं।

ब्राउज़र वस्तु

Grav प्रोग्रामेटिकली यूजर के प्लेटफॉर्म, ब्राउजर और वर्जन को बिल्ट-इन सपोर्ट के जरिए निर्धारित करता है।

{{ browser.platform}}   # windows
{{ browser.browser}}    # chrome
{{ browser.version}}    # 24

कस्टम चर जोड़ना

कस्टम चर को कई तरीकों से जोड़ा जाता है। यदि आप साइट-वाइड चर का उपयोग कर रहे हैं, तो इसे अंदर डालेंuser/config/site.yaml फ़ाइल और आप इसे नीचे दिखाए अनुसार एक्सेस कर सकते हैं।

{{ site.my_variable }}

यदि चर केवल एक विशेष पृष्ठ के लिए है, तो आप इसे YAML फ्रंट-मैटर में जोड़ सकते हैं और इसका उपयोग करके एक्सेस कर सकते हैं page.header वस्तु।

For example -

title: My Page
author: John

लेखक का नाम इस रूप में देखा जा सकता है -

The author of this page is: {{ page.header.author }}

कस्टम ऑब्जेक्ट्स जोड़ना

प्लगइन्स का उपयोग करके, आप कस्टम ऑब्जेक्ट्स को ट्विग ऑब्जेक्ट में जोड़ सकते हैं। यह एक उन्नत विषय है और हम प्लगइन्स अध्याय में अधिक जानकारी देखेंगे ।

इस अध्याय में आइए अध्ययन करते हैं Asset Manager। संपत्ति जोड़ने और प्रबंधित करने के लिए इंटरफ़ेस को एकीकृत करने के लिए एसेट मैनेजर को ग्रैव 0.9.0 में पेश किया गया थाJavaScript तथा CSS। थीम और प्लगइन्स से इन परिसंपत्तियों को जोड़ने से उन्नत क्षमताएं मिलेंगी जैसे किordering तथा Asset PipelineAsset Pipeline का उपयोग संपत्तियों को कम करने और संपीड़ित करने के लिए किया जाता है ताकि यह ब्राउज़र की आवश्यकताओं को कम कर दे और परिसंपत्तियों के आकार को भी कम कर दे।

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

विन्यास

एसेट मैनेजर में कॉन्फ़िगरेशन विकल्पों का एक सेट होता है। system.yamlफ़ाइल में डिफ़ॉल्ट मान शामिल हैं; आप इन मूल्यों को अपने में ओवरराइड कर सकते हैंuser/config/system.yaml फ़ाइल।

assets:                     # Configuration for Assets Manager (JS, CSS)
   css_pipeline: false      # The CSS pipeline is the unification of multiple CSS resources into one file
   css_minify: true         # Minify the CSS during pipelining
   css_rewrite: true        # Rewrite any CSS relative URLs during pipelining
   js_pipeline: false       # The JS pipeline is the unification of multiple JS resources into one file
   js_minify: true          # Minify the JS during pipelining

थीम्स में संपत्ति

एंटीवाटर थीम डिफ़ॉल्ट थीम के रूप में आती है जब आप Grav स्थापित करते हैं। यह एक उदाहरण दिखाता है कि आपके सीएसएस फाइलों को कैसे जोड़ा जाएbase.html.twig फ़ाइल जो इस विषय में रहती है।

{% block stylesheets %}
   {% do assets.addCss('theme://css/pure-0.5.0/grids-min.css', 103) %}
   {% do assets.addCss('theme://css-compiled/nucleus.css',102) %}
   {% do assets.addCss('theme://css-compiled/template.css',101) %}
   {% do assets.addCss('theme://css/custom.css',100) %}
   {% do assets.addCss('theme://css/font-awesome.min.css',100) %}
   {% do assets.addCss('theme://css/slidebars.min.css') %}

   {% if browser.getBrowser == 'msie' and browser.getVersion == 10 %}
      {% do assets.addCss('theme://css/nucleus-ie10.css') %}
   {% endif %}
   {% if browser.getBrowser == 'msie' and browser.getVersion >= 8 and browser.getVersion <= 9 %}
      {% do assets.addCss('theme://css/nucleus-ie9.css') %}
      {% do assets.addJs('theme://js/html5shiv-printshiv.min.js') %}
   {% endif %}
{% endblock %}
{{ assets.css() }}

उपरोक्त कोड को नीचे संक्षेप में समझाया गया है।

  • में परिभाषित क्षेत्र block टहनी टैग को टेम्प्लेट में बदला या जोड़ा जा सकता है जो एक का विस्तार करता है और आप की संख्या देख सकते हैं do assets.addCss() इस ब्लॉक के अंदर कॉल करता है।

  • {% do %} टैग आपको किसी भी आउटपुट के बिना चर को संभालने की अनुमति देता है जिसे ट्विग में ही बनाया गया है।

  • सीएसएस परिसंपत्तियों का उपयोग करके एसेट मैनेजर में जोड़ा जा सकता है addCss()तरीका। आप दूसरे पैरामीटर के रूप में एक संख्यात्मक मान पारित करके स्टाइलशीट की प्राथमिकता निर्धारित कर सकते हैं। के लिए कॉलaddCss() विधि CSS संपत्तियों से HTML टैग्स को प्रस्तुत करता है।

जावास्क्रिप्ट संपत्ति का उपयोग उसी तरह से किया जाता है जैसे सीएसएस संपत्ति। जावास्क्रिप्ट संपत्ति के भीतरblock नीचे दिखाए गए अनुसार टैग्स।

{% block javascripts %}
   {% do assets.addJs('jquery',101) %}
   {% do assets.addJs('theme://js/modernizr.custom.71422.js',100) %}
   {% do assets.addJs('theme://js/antimatter.js') %}
   {% do assets.addJs('theme://js/slidebars.min.js') %}
   {% do assets.addInineJs('alert(\'This is inline!\')') %}
{% endblock %}
{{ assets.js() }}

एसेट्स जोड़ना

निम्नलिखित तालिका विभिन्न प्रकार के ऐड मेथड्स को सूचीबद्ध करती है -

अनु क्रमांक। विधि और विवरण
1

add(asset, [options])

फ़ाइल एक्सटेंशन के आधार पर, addविधि संपत्ति से मेल खाती है। यह सीएसएस या जेएस के लिए सीधे तरीकों में से एक को कॉल करने के लिए एक उचित विधि है। आप का उपयोग कर सकते हैंoptionsप्राथमिकता तय करना। क्या किसी परिसंपत्ति को संयोजन / पाइपलाइन में शामिल किया जाना चाहिए या पाइपलाइन विशेषता द्वारा नियंत्रित नहीं किया जाना चाहिए।

2

addCss(asset, [options])

इस पद्धति का उपयोग करके, आप CSS संपत्तियों में संपत्ति जोड़ सकते हैं। दूसरे पैरामीटर में प्राथमिकता के आधार पर, सूची में परिसंपत्ति का आदेश दिया जाता है। यदि कोई प्राथमिकता निर्धारित नहीं है, तो डिफ़ॉल्ट रूप से 10 सेट है। क्या किसी परिसंपत्ति को संयोजन / पाइपलाइन में शामिल किया जाना चाहिए या पाइपलाइन विशेषता द्वारा नियंत्रित नहीं किया जाना चाहिए।

3

addDirCss(directory)

इस पद्धति का उपयोग करके, आप सीएसएस परिसंपत्तियों से मिलकर एक इकाई निर्देशिका जोड़ सकते हैं जिसे वर्णानुक्रम में व्यवस्थित किया जाएगा।

4

addInlineCss(css, [options])

आप इस पद्धति का उपयोग करके इनलाइन स्टाइल टैग के अंदर CSS की एक स्ट्रिंग प्रदान कर सकते हैं।

5

addJs(asset, [options])

इस पद्धति का उपयोग करके, आप JS संपत्तियों में संपत्ति जोड़ सकते हैं। यदि प्राथमिकता सेट नहीं है, तो यह डिफ़ॉल्ट प्राथमिकता को 10 पर सेट करता है। पाइपलाइन विशेषता यह निर्धारित करती है कि किसी परिसंपत्ति को संयोजन में शामिल किया जाना चाहिए / पाइपलाइन को छोटा करना या नहीं।

6

addInlineJs(javascript, [options])

यह विधि आपको इनलाइन स्क्रिप्ट टैग के अंदर JS की एक स्ट्रिंग जोड़ने की अनुमति देती है।

7

addDirJs(directory)

इस पद्धति का उपयोग करके, आप जेएस परिसंपत्तियों से मिलकर एक इकाई निर्देशिका जोड़ सकते हैं, जिसे वर्णानुक्रम में व्यवस्थित किया जाएगा।

8

registerCollection(name, array)

यह विधि आपको एक नाम के साथ सीएसएस या जेएस संपत्ति से मिलकर एक सरणी को पंजीकृत करने की अनुमति देती है ताकि इसे बाद में उपयोग करके उपयोग किया जा सके add()तरीका। यदि आप कई थीम या प्लगइन्स का उपयोग कर रहे हैं, तो यह विधि बहुत उपयोगी है।

विकल्प

नीचे दिखाए गए अनुसार संपत्ति की सरणी को पास करने के लिए कई विकल्प हैं -

सीएसएस के लिए

  • priority - यह पूर्णांक मान लेता है और डिफ़ॉल्ट मान 100 होगा।

  • pipeline - जब किसी परिसंपत्ति को पाइपलाइन में शामिल नहीं किया जाता है, तो यह सेट हो जाता है falseमूल्य। और डिफ़ॉल्ट मान सेट किया गया हैtrue

जेएस के लिए

  • priority - पूर्णांक मान लेता है और डिफ़ॉल्ट मान 100 होगा।

  • pipeline - जब एक परिसंपत्ति पाइपलाइन में शामिल नहीं है, falseसेट है। और डिफ़ॉल्ट मान सेट किया गया हैtrue

  • loading - यह विकल्प 3 मानों का समर्थन करता है जैसे empty, async तथा defer

  • group- इसमें एक स्ट्रिंग होती है जो एक समूह के लिए विशिष्ट नाम निर्दिष्ट करती है। और डिफ़ॉल्ट मान सेट किया गया हैtrue

Example

{% do assets.addJs('theme://js/example.js', 
{'priority':101, 'pipeline':true, 'loading':'async', 'group':'top'}) %}

रेंडरिंग एसेट्स

CSS और JS संपत्तियों की वर्तमान स्थिति निम्न का उपयोग करके प्रदान की जा सकती है -

सीएसएस ()

सभी सीएसएस परिसंपत्तियों के आधार पर, जिन्हें एसेट मैनेजर में जोड़ा गया है, css()विधि HTML सीएसएस लिंक टैग से मिलकर एक सूची प्रदान करती है। पाइपलाइन विशेषता के आधार पर, सूची में मिनी फ़ाइल और व्यक्तिगत / संयुक्त संपत्ति हो सकती है।

js ()

जेएस की सभी संपत्तियों के आधार पर, जो कि एसेट मैनेजर के रूप में है js()विधि HTML जेएस लिंक टैग से मिलकर एक सूची प्रदान करती है। पाइपलाइन विशेषता के आधार पर, सूची में मिनी फ़ाइल और व्यक्तिगत / संयुक्त संपत्ति हो सकती है।

जिसका नाम एसेट्स रखा गया है

Grav आपको एक नाम के साथ CSS और JS संपत्तियों के संग्रह को पंजीकृत करने की अनुमति देता है, ताकि आप इसका उपयोग कर सकें addपंजीकृत नाम का उपयोग करके एसेट मैनेजर को संपत्ति। यह Grav में एक विशेषता का उपयोग करके पूरा किया जा सकता हैnamed assets। ये कस्टम संग्रह में परिभाषित किए गए हैंsystem.yaml; संग्रह किसी भी विषय या प्लगइन द्वारा इस्तेमाल किया जा सकता है।

assets:
   collections:
      jquery: system://assets/jquery/jquery-2.1.3.min.js
      bootstrap:
         - https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css
         - https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap-theme.min.css
         - https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/js/bootstrap.min.js

registerCollection() विधि को निम्नलिखित कोड के साथ प्रोग्रामेटिक रूप से उपयोग किया जा सकता है -

$assets = $this->Grav['assets']; $bootstrapper_bits = [https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css,
      https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap-theme.min.css,
      https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/js/bootstrap.min.js];
   $assets->registerCollection('bootstrap', $bootstrap_bits);
$assets->add('bootstrap', 100);

समूहीकृत संपत्ति

Grav 0.9.43 नामक एक नई सुविधा के साथ पेश किया गया था Grouped Assets, जो आपको वैकल्पिक से मिलकर विकल्प सरणी पास करने की अनुमति देता है groupसंपत्ति जोड़ते समय। जब आप पृष्ठ के विशिष्ट भाग में कुछ JS फाइल या इनलाइन JS की आवश्यकता हो तो यह सुविधा बहुत उपयोगी है।

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

{% do assets.addJs('theme://js/example.js', {'priority':102, 'group':'bottom'}) %}

यदि कोई समूह किसी परिसंपत्ति के लिए निर्धारित नहीं है, तो headडिफ़ॉल्ट समूह के रूप में सेट किया गया है। यदि आप चाहते हैं कि ये संपत्ति नीचे समूह में प्रस्तुत करें, तो आपको अपने विषय में निम्नलिखित जोड़ना होगा।

{{ assets.js('bottom') }}

स्थैतिक संपत्ति

जब भी आप एसेट मैनेजर के उपयोग के बिना संपत्ति का संदर्भ लेना चाहते हैं, तब आप इसका उपयोग कर सकते हैं url()सहायक विधि। उदाहरण के लिए, जब आप किसी छवि को विषय से संदर्भित करना चाहते हैं, तो आप निम्न सिंटैक्स का उपयोग कर सकते हैं।

<img src = "{{ url("theme://" ~ widget.image) }}" alt = "{{ widget.text|e }}" />

url() सहायक विधि वैकल्पिक रूप से URL को डोमेन और स्कीमा का उपयोग करके शामिल करने के लिए दूसरा पैरामीटर लेता है true या falseमान। डिफ़ॉल्ट रूप से, मान सेट हैfalse जो केवल सापेक्ष URL प्रदर्शित करता है।

Example

url("theme://somepath/mycss.css", true)

इस अध्याय में, हम इस बारे में अध्ययन करते हैं 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 इसका सटीक संदर्भ देता है।

इस अध्याय में, हम समझेंगे कि Grav में एक अतिरिक्त कार्यक्षमता के रूप में एक प्लगइन कैसे काम करता है। प्लगइन सॉफ्टवेयर का एक टुकड़ा है जो अतिरिक्त कार्यक्षमता प्रदान करता है जो मूल रूप से Grav की मुख्य कार्यक्षमता से पूरा नहीं हुआ था।

साइट की कार्यक्षमता का विस्तार करने के लिए Grav Plugin अपलोड किया जा सकता है। प्लगइन्स का उपयोग आपके काम को आसान बनाने के लिए किया जाता है। Dependency Injection ContainerGrav में प्रमुख वस्तुओं तक पहुँचने में मदद करता है। की मदद से पूरे जीवन चक्र मेंGrav's event hooks, हम अपनी आवश्यकता के अनुसार Grav में हेरफेर कर सकते हैं और Grav को जो भी जानते हैं, उसे एक्सेस भी कर सकते हैं। हम अध्याय Grav - घटना हुक में Grav घटना हुक के बारे में विस्तार से अध्ययन करेंगे ।

Dependency Injection एक सॉफ्टवेयर डिजाइन पैटर्न है जिसमें घटकों को घटक के भीतर हार्ड कोडिंग के बजाय उनकी निर्भरता दी जाती है।

Grav के लिए कई मुफ्त प्लगइन्स उपलब्ध हैं जिनका उपयोग ब्लॉग आर्काइव, साइटमैप, सर्च इंजन, फॉर्म, लाइट स्लाइडर और कई अन्य चीजों को प्रदर्शित करने के लिए किया जाता है। आप यहां से प्लगइन्स डाउनलोड कर सकते हैं । प्लगइन फ़ोल्डर में, आप एक अद्वितीय नाम के साथ प्लगइन्स को स्टोर कर सकते हैं; नाम प्लगइन के कार्य से संबंधित होना चाहिए और इसमें कोई कैपिटल लेटर, अंडरस्कोर या स्पेस नहीं होना चाहिए। हम अध्याय Grav - प्लगइन ट्यूटोरियल में प्लगइन का उपयोग करने के तरीके के बारे में अध्ययन करेंगे ।

शक्तिशाली

प्लगइन्स लिखना आसान, लचीला और शक्तिशाली है। 46 प्लगइन्स हैं, और इसमें शामिल विशेषताएं हैंdisplaying a sitemap, provides breadcrumbs, display blog archives आदि।

अनिवार्य

जब Grav आपके सिस्टम पर इंस्टॉल होता है, तो आप देख सकते हैं कि अंदर दो प्लगइन्स हैं <your_folder_name>/user/plugins फ़ोल्डर।

  • त्रुटि प्लगइन

  • समस्या प्लगइन

Error Plugin - इसका उपयोग प्रदर्शित करने के लिए किया जाता है HTTP त्रुटियाँ 404 Page Not Found जब दिए गए URI के लिए कोई अनुरोध पृष्ठ उपलब्ध नहीं है।

Problem Plugin- इसका उपयोग अनुमतियों, होस्टिंग सेटअप और लापता फ़ोल्डरों के मुद्दों का पता लगाने के लिए किया जाता है। जब आप ऐसे मुद्दों की पहचान करने के लिए नए 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 / यादृच्छिक टाइप करें -

इस अध्याय में, हम इस बारे में अध्ययन करेंगे Event HooksGrav में। में प्लगइन्स अध्याय आप देखेंगे, प्लगइन का तर्क दो तरीकों में शामिल किया गया था। तरीके हैंonPluginsInitialized तथा onPageInitialized; ये विधियां ईवेंट हुक के समान हैं। Grav plugins की शक्ति को अधिक जानने और नियंत्रित करने के लिए, आपको ईवेंट हुक की उपलब्धता की जांच करने की आवश्यकता है। इवेंट हुक का शुरू से अंत तक ग्राव के साथ सीधा संबंध है। आपको उस आदेश के बारे में पता होना चाहिए जिसमें हुक कहा जाता है और इन कॉल के समय क्या उपयोग करने योग्य है।

निम्न तालिका कोर ग्रेव को सूचीबद्ध करती है event hooks जो एक पृष्ठ के प्रसंस्करण के दौरान सक्रिय होते हैं।

अनु क्रमांक। घटना विवरण
1

onFatalException

आप किसी भी क्षण इस घटना को आग लगा सकते हैं, यदि PHPएक घातक अपवाद देता है। Problem प्लगइन इसका उपयोग पूर्ण विवरण की एक सूची प्रदर्शित करने के प्रबंधन के लिए करता है, जिसके लिए ग्रेव घातक त्रुटि को बचाता है।

2

onPluginsInitialized

यह Grav में प्रयोग करने योग्य पहला प्लगइन ईवेंट है। निम्नलिखित वस्तुओं को नीचे वर्णित के रूप में पेश किया गया है -

  • Uri
  • Config
  • Debugger
  • Cache
  • Plugins
3

onAssetsInitialized

यह निर्दिष्ट करता है कि ए assets प्रबंधक लोड और उपयोग और प्रबंधन के लिए तैयार है।

4

onPageNotFound

यदि आपको कोई अप्रत्याशित पृष्ठ मिला है, तो आप इस घटना को खारिज कर सकते हैं। वर्तमान में, त्रुटि प्लगइन का उपयोग एक निर्दिष्ट करने के लिए किया जाता है404 error पृष्ठ।

5

onPageInitialized

यह अनुरोधित पृष्ठ को a द्वारा निर्दिष्ट करता है URL जिसे पेज ऑब्जेक्ट में लोड किया गया है।

6

onOutputGenerated

यह द्वारा आउटपुट प्रक्रिया को निर्दिष्ट करता है Twig templatingयन्त्र। वर्तमान में, यह सिर्फ एक स्ट्रिंग हैHTML

7

onOutputRendered

यह एक आउटपुट प्रक्रिया है, जिसे डिस्प्ले में भेजा जाता है।

8

onShutdown

यह एक नई और बहुत शक्तिशाली घटना है जो आपको क्रिया करने की अनुमति देती है। यह Grav के बाद किया जाता हैcompleted processingऔर क्लाइंट का कनेक्शन बंद है। इस व्यक्तिगत कार्रवाई को उपयोगकर्ता के साथ किसी भी तरह की बातचीत की आवश्यकता नहीं होती है, जिसके परिणामस्वरूप यह प्रदर्शन को प्रभावित कर सकता है। इसमें यूजर ट्रैकिंग और जॉब प्रोसेसिंग शामिल है।

9

onBeforeDownload

यह एक नई घटना है passesकिसी फ़ाइल में ईवेंट ऑब्जेक्ट में। यह उपयोगकर्ताओं को लॉगिंग, अनुदान प्रदर्शन करने और उल्लिखित फ़ाइल को डाउनलोड करने की अनुमति को अनदेखा करने की अनुमति देता है।

टहनी घटना हुक

नीचे बताए अनुसार उपयोग करने के लिए ट्विग के पास इवेंट हुक का अपना संग्रह है।

अनु क्रमांक। घटना विवरण
1

onTwigTemplatePaths

टेंपलेट पाथ का बेस लोकेशन पर सेट है Twig object। इस घटना का उपयोग अन्य स्थानों को जोड़ने के लिए किया जाता है जहां ट्वीग टेम्पलेट पथों की खोज करेगा।

2

onTwiglnitialized

यह initialize टहनी टेम्प्लेटिंग इंजन।

3

onTwigExtensions

यह निर्दिष्ट करता है कि कोर टहनी एक्सटेंशन उपयोग के लिए तैयार है। यह ईवेंट हुक आपको अपना स्वयं का ट्विग एक्सटेंशन जोड़ने की अनुमति देता है।

4

onTwigPageVariables

यह टहनी प्रक्रिया आपको सीधे एक पृष्ठ की अनुमति देती है, अर्थात आप इसका पता लगा सकते हैं process:twig:truYAML हेडर के एक पृष्ठ में। यहां आप Twig में किसी भी चर को जोड़ सकते हैं और इस प्रक्रिया के दौरान टहनी के लिए सुलभ होना चाहिए।

5

onTwigSiteVariables

इस प्रक्रिया में, आपको पूर्ण साइट टेम्पलेट दिखाई देगा order wiseटहनी विधियों द्वारा। इसके अलावा, आप इस प्रक्रिया के दौरान Twig में किसी भी चर को जोड़ सकते हैं।

संग्रह कार्यक्रम हुक

निम्न तालिका एक संग्रह ईवेंट हुक को सूचीबद्ध करती है।

अनु क्रमांक। घटना विवरण
1

onCollectionProcessed

इस सेक्शन में एक बार प्रक्रिया पूरी होने के बाद आप कर सकते हैं control संग्रह।

पृष्ठ ईवेंट हुक

निम्न तालिका पृष्ठ ईवेंट हुक के संग्रह को सूचीबद्ध करती है।

अनु क्रमांक। घटना विवरण
1

onBuildPagesInitialized

यह घटना सामग्री को नियंत्रित करने और परिणामों को कैश करने के लिए प्लगइन्स के लिए उपयोगी है। इस घटना के सक्रिय होने के बाद पृष्ठों को पुनर्नवीनीकरण किया जाएगा। यह तब होता है, जब कैश होता हैexpired या जरूरत है refreshing

2

onBlueprintCreated

यह घटना प्रसंस्करण और प्रबंधन रूपों में मदद करती है।

3

onPageContentRaw

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

4

onPageProcessed

एक बार एक पेज testedऔर निश्चित किया गया है, हर पृष्ठ Grav प्रणाली में खारिज कर दिया गया है। इस मामले में प्रदर्शन कोई मायने नहीं रखता, क्योंकि यह कैश्ड पेज पर नहीं चलेगा।

5

onPageContentProcessed

आप देख सकते हैं कि इस घटना को खारिज कर दिया गया है, एक बार पृष्ठ की सामग्री () तकनीक ने पृष्ठ की सामग्री तय कर दी है। यह घटना उस स्थिति में उपयोगी है, जब आप पोस्ट-निर्धारित सामग्री पर कार्रवाई करना चाहते हैं, लेकिन सुनिश्चित करें कि परिणाम हैंcached

6

onFolderProcessed

एक बार folderपरीक्षण किया जाता है और ठीक किया जाता है, हर फ़ोल्डर को Grav सिस्टम में खारिज कर दिया जाता है। इस मामले में प्रदर्शन कोई मायने नहीं रखता, क्योंकि यह कैश्ड पेज पर नहीं चलेगा।

Grav Administration PanelGrav के लिए प्लगइन एक वेब ग्राफिकल यूजर इंटरफेस (GUI) है। यह पृष्ठों को आसानी से बना और संशोधित कर सकता है। यह एक वैकल्पिक प्लगइन है और प्रभावी ढंग से काम करने के लिए ग्रेव इस पर पूरी तरह से निर्भर नहीं है। Grav के आसान उपयोग के लिए व्यवस्थापक सीमित विचार प्रदान करता है।

विशेषताएं

प्रशासन पैनल की विशेषताएं निम्नलिखित हैं -

  • प्लगइन प्रबंधक सूची में मौजूद प्लगइन्स को सक्षम या अक्षम करें।

  • आप पृष्ठों को आसानी से बना, संपादित, कॉपी और हटा सकते हैं।

  • डैशबोर्ड पर नवीनतम पृष्ठ अपडेट की सूची प्रदर्शित होती है।

  • नवीनतम उपलब्ध अपडेट को केवल एक क्लिक द्वारा आसानी से देखा जा सकता है।

  • खोज बॉक्स का उपयोग करके सूची से विशेष पृष्ठ खोजें।

  • इसमें पासवर्ड भूलने की कार्यक्षमता शामिल है।

  • मीडिया फ़ाइलों को ड्रैग-एन-ड्रॉप विधि द्वारा अपलोड किया जा सकता है।

  • सामान्य और विशेषज्ञ मोड में याम्ल या फ़ॉर्म के माध्यम से संपादन की अनुमति देता है।

  • डैशबोर्ड में साइट गतिविधि, नवीनतम पेज अपडेट और रखरखाव की स्थिति शामिल है।

  • इसमें अजाक्स संचालित बैकअप और स्पष्ट-कैश क्षमताएं हैं।

  • इसमें साइट और सिस्टम कॉन्फ़िगरेशन प्रबंधन शामिल हैं।

  • GPM द्वारा संचालित नए प्लगइन्स और थीम इंस्टॉलेशन।

  • उपयोगकर्ता लॉगिन के दौरान स्वचालित पासवर्ड एन्क्रिप्शन सुविधा प्रदान की जाती है।

  • यह कोड संपादक प्रदान करता है जो तत्काल Grav- संचालित पूर्वावलोकन के साथ शक्तिशाली सिंटैक्स को उजागर करता है।

  • थीम प्रबंधक का उपयोग करके स्थापित थीम लिस्टिंग और कॉन्फ़िगरेशन किया जा सकता है।

  • यह लॉग-इन उपयोगकर्ताओं को भी प्रबंधित करता है।

इंस्टालेशन

व्यवस्थापक प्लगइन का उपयोग करने के लिए, हमें चलाने की आवश्यकता है latest Grav। आप CLI (कमांड लाइन इंटरफ़ेस) में निम्न कमांड चला सकते हैं।

$ bin/gpm selfupgrade -f

selfupgrade Grav को नवीनतम संस्करण में अद्यतन करने के लिए उपयोग किया जाता है। -f GPM (Grav Package Manager) इंडेक्स को रीफ्रेश करने के लिए उपयोग किया जाता है।

हमें स्थापित करने की आवश्यकता है admin, form, email तथा loginप्लगइन्स अपने व्यवस्थापक प्लगइन ठीक से चलाने के लिए। जैसा कि सभी प्लगइन्स पर निर्भरता है, आपको सहमत होने की आवश्यकता है जब यह आपको व्यवस्थापक प्लगइन स्थापित करते समय अन्य प्लगइन्स को स्थापित करने का संकेत देता है; ये प्लगइन्स GPM (Grav Package Manager) के माध्यम से उपलब्ध हैं। हम अध्याय Grav - GPM में GPM के बारे में अधिक अध्ययन करेंगे ।

कमांड प्रॉम्प्ट का उपयोग करके व्यवस्थापक प्लगइन को स्थापित करने के लिए निम्न कमांड का उपयोग किया जाता है।

$ bin/gpm install admin

मैनुअल स्थापना

हम निम्नलिखित प्लगइन्स को व्यक्तिगत रूप से डाउनलोड करके प्रशासन पैनल को मैन्युअल रूप से स्थापित कर सकते हैं -

  • admin
  • form
  • login
  • email

सभी प्लगइन्स डाउनलोड करने के बाद, सभी जिप फाइल को निकालें और स्टोर करें <your_folder_name>/user/pluginsफ़ोल्डर। प्लगइन फ़ोल्डर में, आप एक अद्वितीय नाम के साथ प्लगइन्स को स्टोर कर सकते हैं; नाम प्लगइन के कार्य से संबंधित होना चाहिए। फ़ोल्डर का नाम बदला जा सकता हैadmin/, email/, form/ तथा login/। प्लगिन फ़ोल्डर में सभी चार प्लगइन्स को एक साथ संग्रहीत करना आवश्यक है; अन्यथा व्यवस्थापक पैनल ठीक से काम नहीं करेगा।

उपयोगकर्ता बनाना

हम कमांड लाइन इंटरफेस का उपयोग करके उपयोगकर्ता खाता बना सकते हैं। उपयोगकर्ता खाता बनाने के लिए निम्नलिखित कमांड का उपयोग करें।

$bin/grav newuser

अन्यथा, आप कोड की निम्नलिखित पंक्तियों को लिखकर स्वयं उपयोगकर्ता खाता भी बना सकते हैं -

email: [email protected]
access:
   admin:
      login: true
      super: true
   site:
      login: true
fullname: 'Tutorials Point'
title: tp
password: 'Password'

उपरोक्त पंक्तियाँ सहेजें <your_folder_name>/user/account/admin.yamlफ़ाइल। आपके उपरोक्त कोड को सहेजने के लिए आपने जो नाम उपयोग किया है वह होगाusernameआपके लॉगिन के लिए, अर्थात्, व्यवस्थापक। आप संपादित कर सकते हैंemail, fullname, title और यह password अपनी आवश्यकताओं के अनुसार।

प्रयोग

आप अपने ब्राउज़र को इंगित करके प्रशासन पैनल तक पहुँच सकते हैं localhost/<your_folder_name>/adminऔर आपको नीचे दिखाए गए अनुसार एक स्क्रीन मिलेगी। आप सेट कर सकते हैंusername तथा password में यमल फ़ाइल में निर्दिष्ट है creating user अनुभाग।

इस अध्याय में, हम इसके बारे में अध्ययन करेंगे Administrative Panel DashboardGrav में। डैशबोर्ड Grav प्रशासन पैनल प्लगइन के लिए सूचना के एक तंत्रिका केंद्र के रूप में कार्य करता है। आप निरीक्षण कर सकते हैंtraffic statistics, create new backups, Grav updates, maintenance information, नवीनतम पृष्ठ अपडेट देखें और आप इस एकल पृष्ठ की मदद से Grav का कैश साफ़ कर सकते हैं।

Step 1 - आप उपयोगकर्ता को अनुमतियाँ निर्दिष्ट कर सकते हैं और सामग्री को बदल सकते हैं Dashboardमांग के अनुसार। डैशबोर्ड की स्क्रीन कुछ हद तक निम्न स्क्रीनशॉट की तरह होगी।

Step 2 - अब आप की विशेषताएं देखेंगे Cache and Updates Checking डैशबोर्ड में।

आपको डैशबोर्ड मेनू के शीर्ष पर दो टैब दिखाई देंगे।

  • कैश को साफ़ करें
  • अद्यतन के लिए जाँच

कैश को साफ़ करें

यह सभी कैश सामग्री को हटाने के लिए निर्दिष्ट करता है, जिसमें छवियों का कैश, और संपत्ति भी शामिल है।

आप नीचे बताए गए अनुसार लटकती मेनू में और अधिक सुविधाएँ देख सकते हैं।

  • All cache - यह सभी कैश को हटाने के लिए निर्दिष्ट करता है

  • Assets only - यह केवल परिसंपत्तियों के कैश को हटाने के लिए निर्दिष्ट करता है।

  • Images only - यह केवल छवियों के कैश को हटाने के लिए निर्दिष्ट करता है।

  • Cache only - यह केवल कैश को हटाने के लिए परिभाषित करता है।

अद्यतन के लिए जाँच

यह टैब आपकी साइट के अपडेट की जांच करने के लिए निर्दिष्ट करता है। यदि नए अपडेट उपलब्ध हैं, तो आपको डैशबोर्ड पर एक सूचना मिलेगी। आपको समर्थित प्लगइन्स, थीम और यहां तक ​​कि Grav के लिए अपडेट प्राप्त होंगे।

रखरखाव और सांख्यिकी

यह भाग आपको आपकी साइट के बारे में महत्वपूर्ण जानकारी जानने की अनुमति देता है।

रखरखाव

यह खंड आपको Grav सुविधाओं के लिए एक प्रतिशत ग्राफ प्रदान करता है जो पूरी तरह से अद्यतित हैं। आप रखरखाव और सांख्यिकी अनुभाग के ऊपर, एक आवश्यक अद्यतन की सूचना देखेंगे।

  • Update- जैसे ही कोई नया अपडेट उपलब्ध होगा, अपडेट बटन दिखाई देगा। अगला, आप इसे क्लिक कर सकते हैं और अपने प्लगइन्स और थीम को अपडेट कर सकते हैं। आप देखेंगेUpdate Grav Now नोटिफिकेशन बार में बटन, जो आपके Grav के कोर सेक्शन को अपडेट करता है।

  • Backup- इस भाग में, आप वह ग्राफ देख सकते हैं जो आपको दिखाता है कि आपने कितने समय तक अपनी साइट का बैकअप नहीं लिया है। इसे ज़िप फ़ाइल को जनरेट और डाउनलोड करके निष्पादित किया जा सकता है, इसे अपनी साइट के डेटा के लिए बैकअप के रूप में सहेजें।

आंकड़े

यह आपकी साइट पर आगंतुकों के आवागमन का एक सरल और त्वरित लुक ग्राफ प्रदर्शित करता है, जो पिछले दिन, सप्ताह और महीने में प्राप्त हुआ था। यह सप्ताह के दिनों में अलग किए गए बार ग्राफ को दिखाता है।

Step 3 - इसके बाद, आप नीचे दिखाए गए अनुसार नवीनतम पृष्ठ अपडेट की विस्तार से जानकारी देखेंगे।

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

पर क्लिक कर सकते हैं titleसूची से एक पृष्ठ की; जो आपको व्यवस्थापक अनुभाग में पृष्ठ संपादक पर पुनर्निर्देशित करेगा।

Manage Pages बटन आपको प्रशासनिक पैनल के पृष्ठों पर पुनर्निर्देशित करता है।

इस अध्याय में, हम इसके बारे में अध्ययन करेंगे Configuration SystemGrav के प्रशासन पैनल में। आप सीधे कॉन्फ़िगरेशन पृष्ठ की सहायता से अपनी साइट की प्रणाली की सेटिंग्स को कॉन्फ़िगर कर सकते हैं। इसके अलावा, आप अपने सर्वर के गुणों का संक्षिप्त विवरण देखेंगे जिनमें PHP, सर्वर वातावरण, और अन्य कई घटक शामिल हैं जो आपकी साइट को कैसे नियंत्रित करते हैं।

सिस्टम टैब आपको सेटिंग्स को संशोधित करने की अनुमति देता है /user/config/system.yamlफ़ाइल। यह ग्रेव के संचालन से संबंधित कई प्राथमिक प्रणालियों को प्रभावित करता है। सेटिंग्स को विभिन्न वर्गों में विभाजित किया जा सकता है जो आपको Grav के प्रदर्शन की विभिन्न विशेषताएं दिखाते हैं।

नीचे एक विस्तृत सूची दी गई है configuration sections जो सिस्टम टैब में प्रदर्शित होते हैं -

सामग्री

इस अनुभाग में, आप के मूल गुणों को ठीक कर सकते हैं Content अपनी साइट के लिए हैंडलिंग जैसा कि नीचे दिखाया गया है।

  • Home Page - वह होम पेज निर्दिष्ट करता है जिसे आप अपनी साइट के लिए प्रदर्शित करना चाहते हैं।

  • Default Theme - आपकी साइट के लिए प्राथमिक डिफ़ॉल्ट विषय प्रदर्शित करता है।

  • Process- यह नियंत्रित करता है कि पृष्ठों को कैसे संसाधित किया जाता है। विश्व स्तर पर प्रति पृष्ठ के बजाय सेट किया जा सकता है।

  • TimeZone - सर्वर में डिफ़ॉल्ट टाइमज़ोन सेट करता है।

  • Short Date Format - लघु तिथि प्रारूप प्रदर्शित करता है।

  • Long Date Format - लंबी तिथि प्रारूप प्रदर्शित करता है।

  • Default Ordering - इस आदेश का उपयोग करके सूची में पृष्ठ प्रदर्शित किए जाते हैं।

  • Default Order Direction - एक सूची में पृष्ठों की दिशा निर्दिष्ट करता है।

  • Default Page Count - एक सूची में अधिकतम डिफ़ॉल्ट पृष्ठ गणना को परिभाषित करता है।

  • Date Based Publishing - यह स्वचालित रूप से तिथि के अनुसार पदों को प्रकाशित करता है।

  • Events- यह घटनाओं को सक्षम या अक्षम करने के लिए निर्दिष्ट करता है। अक्षम करने से प्लगइन को नुकसान होगा।

  • Redirect Default Route - यह एक डिफ़ॉल्ट मार्ग को परिभाषित करता है और स्वचालित रूप से एक पृष्ठ पर पुनर्निर्देशित करता है।

बोली

आप सेट कर सकते हैं Multi language features इस क्षेत्र में नीचे दिखाया गया है।

  • Supported - यह दो अक्षर भाषा कोड की सूची को अल्पविराम से अलग करता है, यानी, en, fr, de।

  • Translations Enabled - Grav, प्लगइन्स और एक्सटेंशन में अनुवाद सक्षम करता है।

  • Translations Fallback - यह विकल्प समर्थित अनुवाद को निर्दिष्ट करता है, अगर सक्रिय भाषा मौजूद नहीं है।

  • Active Language in Section - आप क्षेत्र में सक्रिय भाषा को संग्रहीत कर सकते हैं।

  • Home Redirect Include Language - इसमें डिमांड के अनुसार होम इनडायरेक्ट (/ en) भाषा शामिल है।

  • Home redirect Include Route - यह व्यवस्थापक होम रूट को पुनर्निर्देशित करता है।

  • Set language from browser - यह ब्राउज़र से भाषा को निर्दिष्ट करता है।

  • Override locale - यह लोकेल को ओवरराइड करने के लिए निर्दिष्ट करता है।

HTTP हेडर

इस अनुभाग का उपयोग सेट करने के लिए किया जाता है HTTP Headersविकल्प। यह सेटिंग ब्राउज़र आधारित कैशिंग और अनुकूलन में मदद करती है।

  • Expires - समाप्ति समय को परिभाषित करता है और सेकंड में मान सेट करता है।

  • Last Modified - अंतिम संशोधित हेडर सेट किया गया है जो प्रॉक्सी और ब्राउज़र कैशिंग को अनुकूलित करने में मदद करता है।

  • ETag - परिभाषित करता है e tag header एक संशोधित पृष्ठ की पहचान करने के लिए।

  • Vary Accept Encoding- आपको स्वीकार करने के लिए वैरी: एचटीटीपी हेडर की व्यवस्था करनी चाहिए। इससे प्रॉक्सी पर कैश का फायदा होगा।

markdown

इस खंड में, हम इस बारे में अध्ययन करेंगे कि Grav कैसे प्रबंधित करता है Markdownऔर मार्कडाउन एक्स्ट्रा को सक्षम करने के लिए इसकी विशेषताएं। यह उपयोगकर्ता की मदद करता है और Grav की पृष्ठ सामग्री को बड़ा करता है।

  • Markdown Extra - यह मार्कडाउन अतिरिक्त के लिए एक डिफ़ॉल्ट समर्थन निर्दिष्ट करता है।

  • Auto Line Breaks - यह मार्कडाउन में लाइन ब्रेक को निर्दिष्ट करता है।

  • Auto URL Links - यह HTML हाइपरलिंक में URL के रूपांतरण को निर्दिष्ट करता है।

  • Escape Markup - यह HTML ऑब्जेक्ट्स में मार्कअप टैब निर्दिष्ट करता है।

कैशिंग

इस अनुभाग में, आप अपनी साइट के प्राथमिक को कॉन्फ़िगर कर सकते हैं Cachingकार्य करता है। ग्राव ने कैशिंग सुविधा को जोड़ा है जो उपयोगकर्ताओं के लिए सबसे तेज फ्लैट-फाइल सीएमएस विकल्प बनाने में मदद करता है।

  • Caching - यह स्विच करने के लिए निर्दिष्ट करता है ON/OFF विश्व स्तर पर enable/disable Grav कैशिंग।

  • Cache Check Method - यह फ़ाइल, फ़ोल्डर और कोई नहीं के लिए कैश चेक विधियों को परिभाषित करता है।

  • Cache Driver- यह उपयोगकर्ताओं को कैश ड्राइवर चुनने के लिए निर्दिष्ट करता है। ऑटो डिटेक्ट कैश ड्राइवर को सबसे अच्छा लगता है।

  • Cache Prefix- यह Grav कुंजी के भाग के लिए एक पहचानकर्ता को निर्दिष्ट करता है। इसे तभी बदलें जब जरूरत हो या फिर इसे न बदलें।

  • Lifetime - यह सेकंड में कैश जीवनकाल को परिभाषित करता है, 0=infinite

  • Gzip Compression - प्रदर्शन को बढ़ाने के लिए, Grav पेज के Gzip कम्प्रेशन को सक्षम करें।

टहनी लगाना

इस खंड में, ग्रेव ने इस पर प्रकाश डाला Twig templatingविशेषताएं। आप यहां ट्विग कैशिंग, डिबग को कॉन्फ़िगर कर सकते हैं और ट्रैकिंग सेटिंग को संशोधित कर सकते हैं।

  • Twig Caching- यह Twig कैशिंग सिस्टम को नियंत्रित करने के लिए निर्दिष्ट करता है। यह सक्षम होने पर सर्वश्रेष्ठ प्रदर्शन देता है।

  • Twig Debug - यह Twig डीबगर एक्सटेंशन को लोड न करने के विकल्प को परिभाषित करता है।

  • Detect Changes - ट्विग टेम्प्लेट्स में किए गए कोई भी बदलाव, यह अपने आप ट्विग कैश को फिर से जोड़ देगा।

  • Autoescape Variables - सभी चर हैं autoescapes; इससे आपकी साइट को नुकसान हो सकता है।

संपत्ति

इस अनुभाग का उपयोग सीएसएस और जावास्क्रिप्ट संपत्ति सहित परिसंपत्तियों को संभालने के लिए किया जाता है, जैसा कि नीचे दिखाया गया है।

  • CSS Pipeline - एक फ़ाइल में कई सीएसएस संसाधनों का एकीकरण।

  • CSS Minify - पाइपलाइन के दौरान सीएसएस को छोटा किया जाता है।

  • CSS Minify Windows Override - यह डिफ़ॉल्ट रूप से गलत सेट किया गया है और यह विंडोज प्लेटफॉर्म के लिए मिनिफाई ओवरराइड को परिभाषित करता है।

  • CSS Rewrite - सीएसएस सापेक्ष URL पाइपलाइनिंग के दौरान फिर से लिखे गए हैं।

  • JavaScript Pipeline - एकल फ़ाइल में कई जावास्क्रिप्ट संसाधनों का एकीकरण।

  • JavaScript Minify - पाइपलाइनिंग के दौरान JS को छोटा किया जाता है।

  • Enable Timestamps on Assets - संपत्ति पर टाइमस्टैम्प सक्षम हैं।

  • Collections - एसेट्स संग्रह को व्यक्तिगत रूप से जोड़ा जाता है।

त्रुटि हैंडलर

साइट विकास के समय के दौरान, यह खंड ग्रेव त्रुटि रिपोर्टिंग का प्रबंधन करने के लिए बहुत उपयोगी है।

  • Display Error - फुल बैकट्रेस-स्टाइल एरर पेज प्रदर्शित होता है।

  • Log Errors - लॉग त्रुटियों को प्रदर्शित किया जाता है /logs फ़ोल्डर।

डीबगर

यह त्रुटि से निपटने के समान है, डिबगिंग टूल Grav में एकीकृत हैं ताकि त्रुटियों का पता लगाया जा सके और उनका निवारण किया जा सके।

  • Debugger - डीबगर और इसकी सेटिंग्स सक्षम हैं।

  • Debug Twig - टहनी टेम्पलेट्स डिबगर सक्षम है।

  • Shutdown Close Connection - कॉल करने से पहले onShutdown(), आपको कनेक्शन बंद करने की आवश्यकता है।

मीडिया

इस अनुभाग का उपयोग प्रबंधन करने के लिए किया जाता है mediaGrav की सामग्री। आप छवि गुणवत्ता, फ़ाइल अपलोड आकार और कई मीडिया हैंडलिंग विकल्प यहां कॉन्फ़िगर कर सकते हैं।

  • Default Image Quality - छवियों को कैशिंग या पुनः साझा करते समय डिफ़ॉल्ट छवि गुणवत्ता का उपयोग करें।

  • Cache all Images - सभी छवियां ग्रेव के कैश सिस्टम के माध्यम से चलाई जाती हैं, भले ही इसमें मीडिया जोड़तोड़ न हो।

  • Image Debug Watermark - आप रेटिना के साथ काम करते हुए, छवियों पर एक ओवरले दिखाते हुए, आप छवि की पिक्सेल गहराई का संकेत कर सकते हैं।

  • File Upload Limit - यह बाइट्स में अधिकतम अपलोड आकार को परिभाषित करता है (0 अनंत है)।

  • Enable Timestamps on Media - अंतिम संशोधित तिथि के अनुसार प्रत्येक मीडिया आइटम में टाइमस्टैम्प जोड़ें।

अधिवेशन

नीचे बताई गई विशेषताएँ आपको सक्षम करने में मदद करती हैं session सहयोग।

  • Enable - यह Grav के भीतर सत्र समर्थन को निर्दिष्ट करता है।

  • Timeout - यह सेकंड में सत्र का समय निर्दिष्ट करता है।

  • Name - यह सत्र कुकी का नाम निर्दिष्ट करता है, जिसे एक पहचानकर्ता द्वारा विकसित और लागू किया जाता है।

उन्नत

इस अनुभाग में, आप देखेंगे advanced सिस्टम विकल्प।

  • Absolute URLs - यह निरपेक्ष या सापेक्ष URL निर्दिष्ट करता है base_url

  • Parameter Separate - आप पैरामीटर विभाजक की सहायता से विंडोज पर अपाचे को बदल सकते हैं।

इस अध्याय में, हम अध्ययन करेंगे कि कैसे करना है Configure SiteGrav के प्रशासन पैनल में। आप सीधे कॉन्फ़िगरेशन पृष्ठ की सहायता से अपनी साइट के सिस्टम की सेटिंग्स को कॉन्फ़िगर कर सकते हैं। साइट टैब आप में सेटिंग्स को संशोधित करने की अनुमति देता है/user/config/system.yamlफ़ाइल। यह टैब आपको उन विकल्पों और फ़ील्ड को संशोधित करने की अनुमति देता है जो साइट से संबंधित सुविधाओं जैसे कि नाम, डिफ़ॉल्ट लेखक आदि को आपकी साइट में उपयोग करते हैं।

निम्नलिखित विभिन्न कॉन्फ़िगरेशन सेटिंग्स हैं जो आप साइट टैब में देख सकते हैं ।

चूक

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

  • Site Title - यह आपकी साइट के लिए शीर्षक निर्दिष्ट करता है।

  • Default Author - यह एक डिफ़ॉल्ट लेखक नाम निर्दिष्ट करता है जो थीम या पृष्ठ सामग्री में उपयोग किया जाता है।

  • Default Email - यह थीम या पृष्ठों में एक डिफ़ॉल्ट ईमेल निर्दिष्ट करता है।

  • Taxonomy Types - यह उन वर्गीकरण प्रकारों को निर्दिष्ट करता है जो आप पृष्ठों में उपयोग करते हैं।

पेज सारांश

पृष्ठ सारांश में आपको पृष्ठ की सामग्री का एक छोटा पूर्वावलोकन प्रस्तुत करने की क्षमता होती है। आप सारांश सामग्री की सहायता से सारांश पृष्ठ के बीच पृष्ठ में "कट ऑफ" बिंदु को परिभाषित कर सकते हैं।

  • Enabled - यह निर्दिष्ट करता है कि पेज सारांश सक्षम है या नहीं।

  • Summary Size - यह पृष्ठ में सामग्री सारांश के रूप में उपयोग किए जाने वाले वर्णों की संख्या को परिभाषित करता है।

  • Format- लघु सीमांकक की पहली घटना का उपयोग करता है, लंबे समय तक सारांश की उपेक्षा करता है।

  • Delimiter- यह सारांश सीमांकक निर्दिष्ट करता है। डिफ़ॉल्ट मान डिफ़ॉल्ट '===' है। आप पृष्ठ सारांश में इसका उपयोग कर सकते हैं और पैराग्राफ खोलने के बाद इसे पोस्ट कर सकते हैं।

मेटाडाटा

मेटाडेटा पृष्ठों में एक महत्वपूर्ण भूमिका निभाता है और आपके एसईओ में सुधार करता है। आप यहां कई मेटाडेटा गुण सेट कर सकते हैं, ताकि आपके लिंक मांग के अनुसार कई खोज इंजन और सामाजिक फ़ीड में दिखाई दे सकें।

यह डिफ़ॉल्ट मेटाडेटा मान निर्दिष्ट करता है, बाद में आप संशोधन कर सकते हैं।

रीडायरेक्ट और रूट

इससे आप अपनी साइट के अन्य पृष्ठों पर रीडायरेक्ट और रूट सेट कर सकते हैं।

  • Custom Redirects- यह अन्य पृष्ठों पर जाने के लिए मार्गों को परिभाषित करता है। मानक रेगेक्स का प्रतिस्थापन मान्य है।

  • Custom Routes- अन्य पृष्ठों के लिए उपनाम। मानक रेगेक्स का प्रतिस्थापन मान्य है।

इस अध्याय में, हम समझेंगे कि कैसे Grav में प्रशासन पैनल पृष्ठ काम करते हैं। पृष्ठ आपकी साइट की सामग्री को बनाने, संपादित करने या हटाने के लिए एक आसान पहुँच प्रदान करते हैं। प्रशासनिक पैनल के पृष्ठों में, आप अपनी साइट के लिए बनाए गए पृष्ठों की सूची देख सकते हैं और अपनी साइट के लिए नए मॉड्यूलर या गैर-मॉड्यूलर पृष्ठ भी बना सकते हैं।

नए पृष्ठ जोड़ना

आप देख सकते हैं कि सबसे ऊपर तीन बटन मौजूद हैं pages निम्न स्क्रीनशॉट में दिखाए गए अनुसार प्रशासनिक पैनल।

  • Back - यह प्रशासनिक पृष्ठ के डैशबोर्ड पर वापस ले जाता है।

  • Add Page - यह एक नया गैर-मॉड्यूलर सामग्री बनाता है।

  • Add Modular - यह नया मॉड्यूलर कंटेंट तैयार करता है।

पृष्ठ जोड़ें

यह आपकी साइट के लिए गैर मॉड्यूलर पेज बनाता है जिसमें आपकी साइट पर पेज जोड़ते समय विभिन्न फ़ील्ड शामिल होते हैं जैसे Title, Folder Name, Parent root आदि।

जब आप पर क्लिक करेंगे Add Page बटन, एक पॉपअप विंडो नीचे दिखाई गई है -

इसमें निम्नलिखित क्षेत्र शामिल हैं -

  • Page Title - यहां आप पेज का शीर्षक दर्ज करें।

  • Folder Name - यह पेज के लिए फ़ोल्डर का नाम दर्ज करना है या शीर्षक दर्ज करते ही नाम अपने आप उत्पन्न हो जाएगा।

  • Parent Page - यह आपके नए बनाए गए पृष्ठ के लिए मूल पृष्ठ सेट करता है।

  • Page File - यह पेज के लिए चयनित थीम टेम्पलेट प्रदर्शित करता है।

  • Visible- यह पृष्ठ को नेविगेशन बार में ऑटो, हां या नहीं पर सेट करके दिखाई देता है ।

खेतों में सभी जानकारी भरने के बाद, पर क्लिक करें Continueबटन। यह आपको पेज एडिटर पर रीडायरेक्ट करेगा।

मॉड्यूलर पेज जोड़ें

मॉड्यूलर पेज अपने चाइल्ड पेज से सिंगल पेज बनाने में सक्षम बनाता है। इसमें मॉड्यूलर सामग्री पृष्ठों से जटिल एक पृष्ठ लेआउट बनाने की क्षमता है।

जब आप पर क्लिक करेंगे Add Modular बटन, एक पॉपअप विंडो नीचे दिखाई गई है -

विंडो में निम्नलिखित फ़ील्ड शामिल हैं -

  • Page Title - यहां हम मॉड्यूलर पेज का शीर्षक दर्ज करते हैं।

  • Folder Name - यह पेज के लिए फ़ोल्डर का नाम दर्ज करना है या शीर्षक दर्ज करते ही नाम अपने आप उत्पन्न हो जाता है।

  • Page - यह आपके नए बनाए गए मॉड्यूलर सबपेज के लिए पेरेंट पेज सेट करता है।

  • Modular Template - यह आपके मॉड्यूलर पृष्ठों के लिए प्रदर्शित किए जाने वाले विशेष टेम्पलेट का चयन करता है।

खेतों में सभी जानकारी भरने के बाद, पर क्लिक करें Continueबटन। यह आपको पेज एडिटर पर रीडायरेक्ट करेगा।

पृष्ठों की सूची

यह उन पृष्ठों की सूची प्रदर्शित करता है जो साइट के लिए बनाए गए हैं।

यहां आप अपने बनाए गए पृष्ठों तक आसानी से पहुंच सकते हैं और इसे संपादित कर सकते हैं।

  • पृष्ठ के किसी भी शीर्षक पर क्लिक करने पर, यह आपको संपादन के उद्देश्य से पृष्ठ संपादक में पुनर्निर्देशित कर देगा।

  • पृष्ठ को दाईं ओर स्थित X आइकन का उपयोग पृष्ठ को हटाने के लिए किया जाता है।

  • फ़िल्टर बॉक्स का उपयोग उस पृष्ठ को खोजने के लिए किया जाता है जिसे आप खोज रहे हैं। यह पृष्ठों को प्रकारों के अनुसार फ़िल्टर करता है ताकि केवल पृष्ठ पसंद होंmodular, visible और / या routable सूची में प्रदर्शित हैं।

  • खोज बॉक्स का उपयोग उस पृष्ठ को खोजने के लिए किया जाता है जब आप उस पृष्ठ का सही नाम जानते हैं।

  • जब आप सीधे पृष्ठ के बाईं ओर के आइकनों पर होवर करते हैं, तो यह आपको वर्तमान स्थिति दिखाएगा, अर्थात, Page . Routable . Visible . Published, इसका मतलब है कि पृष्ठ URL के माध्यम से दिखाई दे रहा है और नेविगेशन मेनू में प्रदर्शित किया जाएगा।

जब आप सूची में प्रदर्शित पृष्ठ पर क्लिक करते हैं, तो आपको निम्न स्क्रीन दिखाई देगी।

उपरोक्त स्क्रीन में, आपके पास पृष्ठ को संपादित करने, सामग्री जोड़ने या अपने पृष्ठ पर छवियां जोड़ने के विकल्प हैं। Optionsटैब में प्रकाशन, टैक्सोनॉमी और साइट मैप विकल्प होते हैं, जिनका हम पेज एडिटर विकल्प अध्याय में अध्ययन करते हैं । Advancedटैब में पृष्ठ के उन्नत विकल्प होते हैं जैसे सेटिंग, ऑर्डर करना और ओवरराइड करना जो पेज एडिटर एडवांस्ड चैप्टर में कवर किया जाएगा ।

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

Options टैब में दो खंड हैं -

  • Publishing
  • Taxonomies

प्रकाशित करना

पृष्ठ को प्रकाशित और प्रकाशित करने के लिए दिनांक और समय सेट करने के लिए इस अनुभाग का उपयोग किया जाता है। प्रकाशित या अप्रकाशित करने की सामग्री पर आपका पूर्ण नियंत्रण होगा और आप विशेष पृष्ठ के लिए मेटाडेटा मान बना सकते हैं।

निम्नलिखित क्षेत्र प्रकाशन अनुभाग में मौजूद हैं -

  • Published - डिफ़ॉल्ट रूप से, पृष्ठ पर सेट किया गया है Yes, अर्थात, प्रकाशित। चयन करकेNo आप पृष्ठ को अप्रकाशित कर सकते हैं।

  • Date - पेज के लिए तारीख और समय निर्धारित करें।

  • Published Date - पेज को स्वचालित रूप से प्रकाशित करने के लिए तारीख और समय निर्धारित करें।

  • Unpublished Date - पेज को स्वचालित रूप से अप्रकाशित करने के लिए तारीख और समय निर्धारित करें।

  • Metadata - मेटाडेटा मान सेट करें जो सभी पृष्ठों पर प्रदर्शित होगा।

taxonomies

इस अनुभाग में, आप पृष्ठ पर श्रेणियां प्रदर्शित कर सकते हैं और अपने पृष्ठ और इसके संरचनात्मक गुणों को कॉन्फ़िगर कर सकते हैं।

निम्नलिखित क्षेत्र टैक्सोनोमी अनुभाग में मौजूद हैं।

  • Category- यह पेज के लिए श्रेणियां सेट करता है। यह सामग्री को छाँटने और छानने में मदद करता है।

  • Tag- यह आपके पेज के बारे में जानकारी प्रदान करता है। यह संगठन और सामग्री को फ़िल्टर करने में मदद करता है।

पृष्ठ संपादक एक पाठ संपादक है और पृष्ठों को भी प्रबंधित करता है; यह आपको मीडिया फ़ाइलों, प्रकाशन और वर्गीकरण विकल्पों, सेटिंग्स और थीम विशिष्ट विकल्पों सहित सामग्री बनाने की अनुमति देता है। निम्न स्क्रीनशॉट संपादक पृष्ठ के उन्नत टैब को दिखाता है।

उन्नत टैब में तीन खंड होते हैं -

  • Settings

  • Ordering

  • Overrides

समायोजन

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

निम्नलिखित क्षेत्र सेटिंग्स अनुभाग में मौजूद हैं -

  • Folder Numeric Prefix - मैनुअल ऑर्डर देने के लिए नंबर निर्धारित किया गया है।

  • Folder Name - जहाँ आपके पृष्ठ स्थित हैं, फ़ोल्डर नाम दर्ज करें।

  • Parent - अपने पृष्ठों के लिए रूट सेट करें या कुछ पृष्ठ उपपृष्ठ के रूप में दिखाई देते हैं।

  • Page File - प्रदर्शित करने के लिए पृष्ठ पर विषय टेम्पलेट सेट करें।

  • Body Classes - पेज के मुख्य भाग पर लागू किया गया वर्ग नाम दर्ज करें।

आदेश

यह खंड एक विशेष क्रम में गैर-संख्या वाले फ़ोल्डरों को सेट करना है।

चार-पंक्तियों वाले तीर पर दबाएँ और दबाए रखें और किसी विशेष क्रम में अपने पृष्ठों को पुनर्व्यवस्थित करने की स्थिति में ले जाएँ।

ओवरराइड

Overrides विकल्प पृष्ठ को अतिरिक्त कार्यक्षमता देते हैं जैसे कैशिंग, नेवीगेशन दृश्यता, डिफ़ॉल्ट नाम के अलावा किसी अन्य चीज़ के लिए स्लग को सेट करना जो फ़ोल्डर नाम पर आधारित है।

निम्नलिखित फ़ील्ड ओवरराइड्स अनुभाग में मौजूद हैं।

  • Menu- मेनू के रूप में उपयोग किए जाने वाले नाम को सेट करता है। अगर कुछ भी सेट नहीं हैTitle इस्तेमाल किया जाएगा।

  • Slug - URL का पेज का हिस्सा इस स्लग वेरिएबल द्वारा सेट किया जा सकता है।

  • Page redirect - किसी भिन्न URL पर पुनर्निर्देशित करने के लिए एक पृष्ठ URL सेट करता है।

  • Process - वह प्रक्रिया जो आप पृष्ठ सामग्री में उपलब्ध कराना चाहते हैं।

  • Default Child Type - बाल पृष्ठों के लिए, पृष्ठ प्रकार डिफ़ॉल्ट के रूप में सेट किया गया है।

  • Routable - यह जांचने के लिए पृष्ठ सेट करता है कि यह URL द्वारा उपलब्ध है या नहीं।

  • Caching - पेज के लिए कैशिंग सेट करता है।

  • Visible - निर्दिष्ट करता है कि पेज नेविगेशन में दिखाई दे रहा है या नहीं।

  • Display Template - प्रदर्शित करने के लिए पृष्ठ पर टेम्पलेट सेट करता है।

Blueprintsसंसाधन (सूचना का स्रोत) के बारे में मेटाडेटा जानकारी है। इसके दो उद्देश्य हैं -

  • पहले संसाधन की पहचान है।
  • दूसरा रूपों के बारे में है।

यह पूरी जानकारी प्रत्येक प्लगिन या थीम में मौजूद ब्लूप्रिंट्स.माइल फाइल में सेव है ।

संसाधन पहचान

में blueprints.yaml फ़ाइल पहचान प्रत्येक विषयों और plugins के लिए परिभाषित किया गया है। जब तक ब्लूप्रिंट्स को प्रारूपित और पूरी तरह से संकलित नहीं किया जाता है, तब तक Grav रिपॉजिटरी में संसाधन नहीं जोड़े जाएंगे।

ब्लूप्रिंट उदाहरण

name: plugin name
version: 0.6.0
description: Adds an advanced plugin to manage your site
icon: empire
author:
   name: Team Grav
   email: [email protected]
   url: http://getGrav.org
homepage: https://github.com/getGrav/Grav-plugin-assets
keywords: assets, plugin, manager, panel
bugs: https://github.com/getGrav/Grav-plugin-assets/issues
readme: https://github.com/getGrav/Grav-plugin-assets/blob/develop/README.md
license: MIT

dependencies:
   - form
   - email
   - login

form:
   validation: loose
   fields:
      Basics:
         type: section
         title: Basics
         underline: false
      enabled:
         type: hidden
         label: Plugin status
         highlight: 1
         default: 0
         options:
            1: Enabled
            0: Disabled
         validate:
            type: bool

निम्नलिखित कुछ गुण वैकल्पिक हैं और कुछ का उपयोग आपकी पहचान और संसाधन देने के लिए किया जाता है।

अनु क्रमांक। गुण और विवरण
1

name*

संसाधन का नाम उल्लेख करें।

2

version*

संसाधन के संस्करण को निर्दिष्ट करता है।

3

description*

संसाधन के बारे में संक्षिप्त विवरण देता है। यह 200 से अधिक वर्णों से अधिक नहीं होना चाहिए।

4

icon*

एक नया विषय या प्लगइन विकसित करने के लिए एक आइकन पुस्तकालय निर्दिष्ट करता है।

5

author.name*

डेवलपर का नाम निर्दिष्ट करता है।

6

author.email (optional)

डेवलपर का ईमेल पता निर्दिष्ट करता है।

7

author.url (optional)

डेवलपर का URL होमपेज निर्दिष्ट करता है।

8

homepage (optional)

आपके संसाधन के लिए मुखपृष्ठ के लिए आवंटित यूआरएल निर्दिष्ट करता है।

9

docs (optional)

दस्तावेज़ीकरण लिंक निर्दिष्ट करता है जो आपने अपने संसाधन के लिए लिखा है।

10

demo (optional)

डेमो संसाधन के लिंक को निर्दिष्ट करता है।

1 1

guide (optional)

आपके संसाधन के लिए गाइड या ट्यूटोरियल कैसे करें, इसका लिंक निर्दिष्ट करता है।

12

keywords (optional)

उन कीवर्ड की सूची निर्दिष्ट करता है जो आपके संसाधन से संबंधित हैं।

13

bugs (optional)

Url को निर्दिष्ट करता है जहां मुद्दों या बगों की सूचना दी जा सकती है।

14

license (optional)

आपके संसाधन लाइसेंस यानी MIT, GPL आदि को निर्दिष्ट करता है।

15

dependencies (optional)

प्लगइन्स या थीम के लिए आवश्यक निर्भरता का नाम निर्दिष्ट करता है।

निम्नलिखित लॉगिन प्लगइन खाका का एक उदाहरण है -

name: Login
version: 0.3.3
description: Enables user authentication and login screen.
icon: sign-in
author:
   name: Team Grav
   email: [email protected]
   url: http://getGrav.org
keywords: admin, plugin, login
homepage: https://github.com/getGrav/Grav-plugin-login
keywords: login, authentication, admin, security
bugs: https://github.com/Getgrav/Grav-plugin-login/issues
license: MIT

फार्म

यदि आप थीम इंटरफ़ेस या प्लगइन्स चाहते हैं तो ब्लूप्रिंट्स . yaml फ़ाइल को फॉर्म से भर सकते हैं । इस संसाधन का हिस्सा के माध्यम से विन्यस्त किया जा सकता हैAdmin Plugin, जो द्वारा परिभाषित किया गया है Forms मेटाडाटा।

निम्नलिखित अभिलेखागार प्लगइन अभिलेखागार का एक उदाहरण है ।yaml फ़ाइल।

enabled: true
built_in_css: true
date_display_format: 'F Y'
show_count: true
limit: 12
order:
   by: date
   dir: desc
filter_combinator: and
filters:
   category: blog

ये प्लगइन की डिफ़ॉल्ट सेटिंग्स हैं। व्यवस्थापक प्लगइन के उपयोग के बिना उन्हें कॉन्फ़िगर करने के लिए उपयोगकर्ता को इस फ़ाइल को कॉपी करना होगा/user/config/plugins/archives.yamlफ़ोल्डर और परिवर्तन करें। आप सही तरीके से अभिलेखागार प्रदान कर सकते हैं । आप उपयोगकर्ताओं से व्यवस्थापक इंटरफ़ेस में सेटिंग्स बदलने का विकल्प चुन सकते हैं।

परिवर्तनों को सहेजने के बाद, यह स्वचालित रूप से लिखा जाएगा <your_folder_name>/user/config/plugins/archives.yaml

अभिलेखागार प्लगइन की खाका फ़ाइल में नीचे दी गई संरचना है -

name: Archives
version: 1.3.0
description: The **Archives** plugin creates links for pages grouped by month/year
icon: university
author:
   name: Team Grav
   email: [email protected]
   url: http://getGrav.org
homepage: https://github.com/getGrav/Grav-plugin-archives
demo: http://demo.getGrav.org/blog-skeleton
keywords: archives, plugin, blog, month, year, date, navigation, history
bugs: https://github.com/getGrav/Grav-plugin-archives/issues
license: MIT

form:
   validation: strict
   fields:
      enabled:
         type: toggle
         label: Plugin status
         highlight: 1
         default: 1
         options:
            1: Enabled
            0: Disabled
         validate:
            type: bool

      date_display_format:
         type: select
         size: medium
         classes: fancy
         label: Date Format
         default: 'jS M Y'
         options:
            'F jS Y': "January 1st 2014"
            'l jS of F': "Monday 1st of January"
            'D, m M Y': "Mon, 01 Jan 2014"
            'd-m-y': "01-01-14"
            'jS M Y': "10th Feb 2014"

      limit:
         type: text
         size: x-small
         label: Count Limit
         validate:
            type: number
            min: 1

      order.dir:
         type: toggle
         label: Order Direction
         highlight: asc
         default: desc
         options:
            asc: Ascending
            desc: Descending

पुरालेख में मौजूद तत्व तत्व निम्नलिखित हैं ।

Toggle

enabled:
   type: toggle
   label: Plugin status
   highlight: 1
   default: 1
   options:
      1: Enabled
      0: Disabled
   validate:
      type: bool

Select

date_display_format:
   type: select
   size: medium
   classes: fancy
   label: Date Format
   default: 'jS M Y'
   options:
      'F jS Y': "January 1st 2014"
      'l jS of F': "Monday 1st of January"
      'D, m M Y': "Mon, 01 Jan 2014"
      'd-m-y': "01-01-14"
      'jS M Y': "10th Feb 2014"

Text

limit:
   type: text
   size: x-small
   label: Count Limit
   validate:
      type: number
      min: 1

मूल तत्व सक्षम, date_display_format और सीमा विकल्प हैं। इस मूल तत्व में मौजूद फ़ील्ड प्रकार, आकार, लेबल, डिफ़ॉल्ट और विकल्प निर्धारित करता है। फ़ील्ड प्रकार के आधार पर, अन्य फ़ील्ड बदल सकते हैं; उदाहरण के लिए, चयन फ़ील्ड को विकल्प सूची की आवश्यकता होती है।

Order direction

order.dir:
   type: toggle
   label: Order Direction
   highlight: asc
   default: desc
   options:
      asc: Ascending
      desc: Descending

इस क्षेत्र में नेस्टेड विकल्प होते हैं। कई फ़ील्ड प्रकार हैं जिनका उपयोग प्लगइन्स / व्यवस्थापक / थीम / Grav / टेम्पलेट्स / फ़ॉर्म / फ़ील्ड में किया जा सकता है । जैसा कि हम आर्काइव.माइल फाइल में देख सकते हैं , फॉर्म वेरिफिकेशन सख्त है। जब सत्यापन को सख्त के रूप में सेट किया जाता है, तो सभी विकल्पों के लिए आपको ब्लूप्रिंट फॉर्म को जोड़ना होगा, अन्यथा यह बचत करते समय एक त्रुटि उत्पन्न करेगा। Form.validation जब आप व्यवस्थापक इंटरफ़ेस के लिए केवल दो क्षेत्रों को अनुकूलित कर ढीला के रूप में स्थापित किया जा सकता है।

निम्न तालिका उपरोक्त फार्म तत्वों से संबंधित क्षेत्रों का एक संक्षिप्त विवरण देती है।

अनु क्रमांक। फ़ील्ड और विवरण
1

Type

फ़ील्ड प्रकार इंगित करता है।

2

Size

क्षेत्र का आकार निर्दिष्ट करता है।

3

Label

फ़ील्ड पर लेबल निर्दिष्ट करता है।

4

Validate

यह क्षेत्र के प्रकार और क्षेत्र में दर्ज न्यूनतम लंबाई को मान्य करता है।

5

Default

डिफ़ॉल्ट फ़ील्ड सेट करता है।

6

Options

विकल्पों की सूची निर्दिष्ट करता है।

7

Classes

क्षेत्र के लिए वर्ग निर्दिष्ट करता है।

प्रपत्र फ़ील्ड व्यवस्थापक में उपलब्ध है

कई बिल्ट-इन-फॉर्म फ़ील्ड उपलब्ध हैं जो प्लगइन्स और थीम द्वारा उपयोग किए जाते हैं या अपने स्वयं के फॉर्म फ़ील्ड बना सकते हैं। निम्न तालिका उपलब्ध प्रपत्र फ़ील्ड की सूची देती है -

सामान्य रूप क्षेत्र

अनु क्रमांक। फ़ील्ड और विवरण
1

Checkbox

एकल चेकबॉक्स प्रदर्शित करता है।

2

Checkboxes

चेकबॉक्स की सूची प्रदर्शित करता है।

3

Date

दिनांक फ़ील्ड शामिल है।

4

Datetime

इसमें दिनांक और समय फ़ील्ड शामिल हैं।

5

Email

सत्यापन के साथ एक ईमेल पता फ़ील्ड शामिल है।

6

Password

एक पासवर्ड फ़ील्ड शामिल है जो डॉट प्रारूप में प्रदर्शित होता है।

7

Hidden

छिपा इनपुट क्षेत्र शामिल हैं।

8

Radio

सूची से केवल एक विकल्प चुनने की अनुमति देता है।

9

Select

इस फ़ील्ड में कुछ विकल्प हैं।

10

Spacer

शीर्षक, पाठ या क्षैतिज रेखा को प्रपत्र में जोड़ता है।

1 1

Text

सामान्य पाठ फ़ील्ड शामिल है।

12

Textarea

इसमें मल्टीलाइन टेक्स्ट इनपुट शामिल हैं।

विशेष फार्म क्षेत्र

अनु क्रमांक। फ़ील्ड और विवरण
1

Array

कई मुख्य मूल्य पंक्तियों को जोड़ता है।

2

Ignore

अप्रयुक्त खेतों को हटा दिया जाता है।

3

Columns

प्रपत्र को कई स्तंभों में विभाजित करता है।

4

Column

एकल कॉलम प्रदर्शित करता है।

5

Dateformat

दिनांक और समय प्रारूप सेट करता है।

6

Display

बिना किसी इनपुट मूल्य के पाठ मूल्य प्रदर्शित करता है।

7

Frontmatter

पृष्ठ कच्चे प्रारूप में प्रदर्शित होता है।

8

List

एक कुंजी के बिना वस्तुओं की एक सूची प्रदर्शित करता है।

9

Markdown

मार्कडाउन संपादक प्रदर्शित करता है।

10

Pages

पृष्ठों की सूची प्रदर्शित करता है।

1 1

Section

सेटिंग पृष्ठ को अनुभागों में विभाजित किया गया है और प्रत्येक अनुभाग का शीर्षक है।

12

Selectize

इसका उपयोग बक्से का चयन करने के लिए किया जाता है।

13

Tabs

सेटिंग्स को टैब की सूची में विभाजित किया गया है।

14

Tab

टैब फ़ील्ड टैब प्रदान करने के लिए उपयोग करता है।

15

Taxonomy

यह टैक्सोनॉमी का चयन करने के लिए एक पूर्व-चयनित है।

16

Toggle

यह टॉगल प्रभाव का प्रतिनिधित्व करता है जो इनपुट के चालू या बंद प्रकार को निर्दिष्ट करता है।

इस अध्याय में, हम Grav में प्रदर्शन और कैशिंग की अवधारणाओं को समझेंगे।

प्रदर्शन

शब्द प्रदर्शन सिस्टम प्रदर्शन को इस तरह से संदर्भित करता है कि क्या यह सिस्टम पर उच्च भार को संभाल सकता है और उच्च भार को संभालने के लिए सिस्टम को संशोधित कर सकता है।

गौरव के प्रदर्शन से संबंधित निम्नलिखित बातों पर विचार करें -

  • Grav के बेहतर प्रदर्शन के लिए, आप PHP का उपयोग कर सकते हैं opcache तथा usercache। Opcache PHP 5.4 के साथ अच्छी तरह से काम करता है और usercache PHP 5.5, PHP 5.6 और Zend opcache के साथ तेजी से काम करता है।

  • SSD(सॉलिड स्टेट ड्राइव) जिसमें फ्लैश मेमोरी का उपयोग किया गया है और जिसमें कोई चलते हुए हिस्से नहीं हैं। कभी-कभी कैश को उपयोगकर्ता कैश में संग्रहीत किया जाएगा या फ़ाइलों के रूप में संग्रहीत किया जाएगा। तो SSD ड्राइव बेहतर प्रदर्शन दे सकते हैं।

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

  • Grav है faster memoryजिसमें इसका कैश भारी मेमोरी का उपयोग करता है जो आपके सर्वर पर बेहतर प्रदर्शन प्रदान करता है। अन्य प्लेटफार्मों की तुलना में, यह मेमोरी की कम मात्रा का उपयोग करता है।

  • Grav का उपयोग करता है shared hostingसाझा सर्वर पर चीजों को साझा करने के लिए। होस्टिंग साझा करना कम लागत में उपलब्ध है और कभी-कभी यह सर्वर पर चीजों को धीमा कर सकता है।

  • मल्टी कोर प्रोसेसर का उपयोग कई कार्यों को तेजी से संभालने के लिए किया जाता है। उन्नत प्रोसेसर इन प्रोसेसर से बेहतर हैं जो उपयोगकर्ता को कार्य पूरा करने में मदद करता है।

कैशिंग

सामान्य तौर पर, कैश कैश मेमोरी में संग्रहीत डेटा होता है। कैश मैकेनिज्म Grav को तेज बनाता है जिसमें ब्राउज़र को मूल सर्वर के बजाय कैश से फाइलें मिल सकती हैं, जिससे समय और अतिरिक्त नेटवर्क ट्रैफिक की बचत होती है।

ग्रेव डॉक्ट्रिन कैश लाइब्रेरी का उपयोग करता है जो निम्नलिखित का समर्थन करता है -

  • ऑटो (डिफ़ॉल्ट) - यह स्वचालित रूप से डिफ़ॉल्ट विकल्प का उपयोग करता है।

  • फ़ाइल - इसमें मौजूद कैश फ़ाइलों को निर्दिष्ट करता है cache/ फ़ोल्डर।

  • APC

  • XCache

  • Memcache

  • Redis

  • WinCache

डिफ़ॉल्ट रूप से, Grav ऑटो सेटिंग का उपयोग करता है। यह APC के लिए, फिर WinCache, XCache के लिए प्रयास करेगा और अंतिम रूप से यह फाइल का उपयोग करता है।

कैशिंग प्रकार

कैशिंग के 5 प्रकार हैं -

  • PHP में YAML कॉन्फ़िगरेशन कैशिंग।

  • पृष्ठ वस्तुओं के लिए कोर ग्राव कैशिंग।

  • PHP क्लासेस के रूप में टेम्प्लेट फाइलों की ट्विग कैशिंग।

  • मीडिया संसाधनों के लिए छवि कैशिंग।

  • पाइपलाइन के साथ CSS और jQuery के एसेट कैशिंग।

YAML विन्यास के कैशिंग में संग्रहीत /cacheफ़ोल्डर। छवि कैशिंग में अपनी छवियों को संग्रहीत करता है/imagesफ़ोल्डर। कोर Grav कैशिंग के लिए कॉन्फ़िगरेशन विकल्प में संग्रहीत हैuser/config/system.yml नीचे दिखाए अनुसार -

cache:
   enabled: true
   check:
      method: file
   driver: auto
   prefix: 'g'
  • enabled विकल्प कैशिंग को सही पर सेट करके सक्षम करता है।

  • method फ़ाइलों या फ़ोल्डर जैसे पृष्ठों में अपडेट के लिए विकल्प जाँच।

  • driver विकल्प विभिन्न प्रकार के कैशिंग विकल्प निर्दिष्ट करता है जैसे कि ऑटो, फ़ाइल, एपीसी, एक्सचे, मेमचे, रेडिस या विनकाच।

  • prefix विकल्प कैश उपसर्ग स्ट्रिंग को परिभाषित करता है।

Memcache विकल्प

यदि आप उपयोग कर रहे हैं memcached server, तो आप का उपयोग करके कुछ अतिरिक्त विन्यास विकल्प जोड़ने की जरूरत है memcache में ड्राइवर user/config/system.yml file। इन विकल्पों को इसके तहत परिभाषित किया जा सकता हैcache: समूह।

cache:
...
...
   memcache:
      server:localhost
      port: 8080

रेडिस विकल्प

यदि आप उपयोग कर रहे हैं redis, तो आपको उपयोग करके कुछ अतिरिक्त कॉन्फ़िगरेशन विकल्प जोड़ने की आवश्यकता है redis में ड्राइवर user/config/system.yml file। इन विकल्पों को इसके तहत परिभाषित किया जा सकता हैcache: समूह।

cache:
...
...
   redis:
   	server:localhost
      port: 8080

टहनी टेम्प्लेट अपने स्वयं के कैशिंग तंत्र का उपयोग करता है ताकि टिव्ग ड्राइवर का उपयोग किया जा सके user/config/system.yml फ़ाइल।

twig:
   cache: true
   debug: true
   auto_reload: true
   autoescape: false

इसके कुछ विकल्प हैं जैसे -

  • cache विकल्प यह सच करने के लिए सेट करके टहनी कैशिंग को सक्षम करता है।

  • debug विकल्प टहनी डिबग को सक्षम करता है।

  • auto_reload विकल्प का उपयोग सही पर सेट करके परिवर्तनों को पुनः लोड करने के लिए किया जाता है।

  • autoescape विकल्प का उपयोग टहनी चर से बचने के लिए किया जाता है।

कैशिंग और ईवेंट

कैशिंग सक्षम होने पर ईवेंट का उपयोग किया जा सकता है। इसे छोड़कर सभी घटनाओं के लिए सक्षम किया जा सकता हैOnPageContentRaw, OnPageProcessed, OnPageContentProcessed, OnTwigPageVariables तथा OnFolderProcessedआयोजन। इन घटनाओं का उपयोग सभी पृष्ठों और फ़ोल्डरों पर किया जा सकता है और केवल तभी चल सकता है जब इवेंट प्रोसेसिंग कर रहे हों। पृष्ठ के कैश होने के बाद ये ईवेंट नहीं चलाए जा सकते।

थीम और प्लगइन्स को विकसित करते समय डिबगिंग और लॉगिंग जानकारी बहुत आवश्यक है। Grav डीबगिंग जानकारी का उपयोग नीचे बताई गई कुछ विशेषताओं का उपयोग करके करता है।

PHP डीबग बार

Grav नामक टूल आता है Debug Barडिबगिंग जानकारी प्रदर्शित करने के लिए। डिफ़ॉल्ट रूप से, यह सुविधा अक्षम है। आप इसे विश्व स्तर पर चालू कर सकते हैं या अपने विकास के वातावरण के लिए system.yaml का उपयोग कर सकते हैं ।

debugger:
   enabled: true
   twig: true
   shutdown:
      close_connection: true

डिबगर को सक्षम करने के बाद true, आप निम्न डिबग बार देख सकते हैं जैसा कि नीचे दिखाया गया है। जी सिंबल पर क्लिक करें जो कोने के बाईं ओर मौजूद है।

में debugबार, आप समग्र मेमोरी उपयोग और दाईं ओर कोने में प्रसंस्करण के लिए उपयोग किए गए समय को देख सकते हैं। इसमें कई टैब भी शामिल हैं जो विस्तार से जानकारी प्रदान करते हैं।

संदेश टैब में, आप उन संदेशों को देख सकते हैं जो आपको अपनी Grav विकास प्रक्रिया को डीबग करने में मदद करेंगे और जानकारी कोड के माध्यम से इस टैब पर पोस्ट हो जाएगी $Grav['debugger']→addMessage($my_var)

टाइमलाइन टैब में, आप Grav टाइमिंग के टूटने को देख सकते हैं।

त्रुटि प्रदर्शन

यह एक रनटाइम पर ब्लॉक या पेज के बारे में त्रुटि संदेश प्रदर्शित करता है। Grav में, आप आसानी से त्रुटि की पहचान कर सकते हैं और त्रुटियों को बहुत जल्दी हल कर सकते हैं। निम्नलिखित त्रुटि संदेश हैं जो आपकी स्क्रीन पर प्रदर्शित होंगे जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

में उपयोगकर्ता / config / system.yaml फ़ाइल, तो आप गलत पर निर्धारित कर उस त्रुटि पृष्ठ निष्क्रिय कर सकते हैं।

errors:
   display: false
   log: true

लॉगिंग

लॉगिंग का उपयोग पुस्तकालयों और एप्लिकेशन से त्रुटियों और स्थिति की जानकारी के लिए किया जाता है। Grav में, नीचे दिए गए अनुसार कुछ महत्वपूर्ण लॉगिंग विशेषताएं हैं।

$Grav['log']->info('My informational message'); $Grav['log']->notice('My notice message');
$Grav['log']->debug('My debug message'); $Grav['log']->warning('My warning message');
$Grav['log']->error('My error message'); $Grav['log']->critical('My critical message');
$Grav['log']->alert('My alert message'); $Grav['log']->emergency('Emergency, emergency, there is an emergency here!');

सभी लॉगिंग संदेश Grav.log फ़ाइल में प्रदर्शित होंगे जो फ़ोल्डर के अंतर्गत मौजूद है <your_folder_name> /logs/Grav.log

इस अध्याय में, हम समझेंगे कि Grav में CLI कैसे काम करता है। CLI में संग्रहीत कमांड लाइन इंटरफ़ेस के लिए खड़ा है bin/Grav। यह कुछ कार्य करता है जैसे किclearing cache, बनाना backup प्रतिलिपि, आदि

विभिन्न प्लेटफार्मों पर सीएलआई एक्सेस करना अलग है। विंडोज पर, आप के माध्यम से पहुँच सकते हैंcmdमैक पर आप के माध्यम से उपयोग कर सकते हैं Terminalऔर लिनक्स पर आप शेल का उपयोग कर सकते हैं। विंडोज़ में, आप UNIX शैली कमांड का उपयोग नहीं कर सकते। इनका उपयोग करने के लिए बस msysgit पैकेज स्थापित करें जो GIT और GIT BASH प्रदान करता है और Windows पर UNIX शैली कमांड प्रदान करता है।

आप नीचे दिए गए आदेश का उपयोग करके Grav में उपलब्ध कमांड को सूचीबद्ध कर सकते हैं -

$ bin/Grav list

आप निम्न स्क्रीनशॉट में दिखाए अनुसार उपलब्ध कमांड देख सकते हैं -

नई परियोजना निर्माण

ग्रेव के साथ नया प्रोजेक्ट बनाना बहुत सरल है। आप Grav उदाहरण के साथ एक नया प्रोजेक्ट बना सकते हैं।

  • अपनी खोलो terminal या console और अपने Grav फ़ोल्डर में नेविगेट करें।

$ cd ../ProjectFolder/grav
  • आपका Grav आपके वेब सर्वर के रूट में इंस्टॉल हो जाएगा। यदि आप अपने Grav के रूट फोल्डर के अंदर संपर्क नामक फोल्डर बनाना चाहते हैं, तो कमांड का उपयोग करें -

$ bin/Grav  project-name  ../webroot/ contact

यह सभी आवश्यक निर्भरताओं को डाउनलोड करेगा और एक नया Grav उदाहरण बनाएगा।

Grav निर्भरता स्थापित करना

निर्भरता स्थापित करते समय, Grav स्वतः ही प्लगइन्स स्थापित करता है error लगाना, problems प्लगइन और antimatterविषय। आप अपने टर्मिनल या कंसोल में निम्न कमांड का उपयोग करके इन्हें स्थापित कर सकते हैं -

$ cd ../webroot/myproject
$ bin/Grav install

अब आप उनके संबंधित फ़ोल्डरों में डाउनलोड किए गए प्लगइन्स देखेंगे -

  • ../webroot/ myproject / उपयोगकर्ता / प्लगइन्स / त्रुटि

  • ../webroot/ myproject / user / plugins / problems

  • ../webroot/ myproject / उपयोगकर्ता / थीम / एंटीमैटर

क्लियरिंग ग्रेव कैश

आप उन फ़ाइलों और फ़ोल्डरों को हटा सकते हैं जो कैश को संग्रहीत करने के लिए साफ़ करते हैं cache/फ़ोल्डर। कैश साफ़ करने के लिए, आप नीचे दिए गए कमांड का उपयोग कर सकते हैं -

$ cd ../webroot/myproject
$ bin/Grav clear-cache

बैकअप बनाना

Grav में, आप अपने प्रोजेक्ट को रूट फ़ोल्डर में संग्रहीत कर सकते हैं। चूंकि यह डेटाबेस का उपयोग नहीं करेगा इसलिए बैकअप लेने में कोई कठिनाई नहीं है। यदि आप myproject नामक अपनी परियोजना का बैकअप बनाना चाहते हैं (../webroot/myproject), तो निम्न कमांड का उपयोग करें -

$ cd ../webroot/myproject
$ bin/Grav backup

आप के तहत बनाई गई बैकअप की एक ज़िप फ़ाइल देखेंगे backup/ फ़ोल्डर।

अद्यतन करने वाला संगीतकार

आप Grav कंपोज़र को अपडेट कर सकते हैं जो Github के माध्यम से इंस्टॉल किया गया था और कंपोज़र आधारित विक्रेता पैकेज का उपयोग करके मैन्युअल रूप से इंस्टॉल किया गया था। कमांड है -

$ bin/Grav composer

GPM, Grav Package Manager के लिए है जिसका उपयोग Grav रिपॉजिटरी में उपलब्ध प्लगइन्स को स्थापित, अपडेट, अनइंस्टॉल और लिस्ट करने के लिए किया जाता है। GPM कमांड लाइन इंटरफेस जैसे कि टर्मिनल या cmd का उपयोग करके कमांड निष्पादित करता है।

आप बहुत आसानी से सीएलआई तक पहुंच सकते हैं। विंडोज पर, आप के माध्यम से पहुँच सकते हैंcmdमैक पर आप के माध्यम से उपयोग कर सकते हैं Terminal और लिनक्स पर आप उपयोग कर सकते हैं shell। विंडोज़ में, आप UNIX शैली कमांड का उपयोग नहीं कर सकते। इनका उपयोग करने के लिए बस msysgit पैकेज स्थापित करें जो GIT और GIT BASH प्रदान करता है और Windows पर UNIX शैली कमांड प्रदान करता है।

Grav रिपॉजिटरी पर उपलब्ध कमांड को सूचीबद्ध करने के लिए कमांड को निम्न प्रकार से लिखें -

$ bin/gpm list

आप निम्नलिखित प्राप्त करेंगे -

आप नीचे दिखाए अनुसार लाइन में मदद जोड़कर कमांड्स की मदद कर सकते हैं -

$ bin/gpm help install

आप कमांड लाइन इंटरफेस पर PHP के संस्करण को निम्न कमांड का उपयोग करके पा सकते हैं -

$ php -v

यह कैसे काम करता है?

जब आप कमांड लाइन इंटरफ़ेस पर कमांड चलाते हैं, GPM स्वचालित रूप से आवश्यक डेटा डाउनलोड करता है GetGrav.orgसाइट। इसमें उपलब्ध पैकेजों के सभी विवरण शामिल हैं और उन पैकेजों को भी निर्धारित करता है जिन्हें स्थापित करने की आवश्यकता होती है और किन पैकेजों को अद्यतन करने की आवश्यकता होती है।

जब आप रिपॉजिटरी से पैकेज डाउनलोड कर रहे होते हैं, तो ग्रॉव रिपॉजिटरी स्थानीय रूप से कैश हो जाती है और कोई अनुरोध संपर्क करने में सक्षम नहीं होगा GetGrav.org कैश उत्पन्न होने के बाद सर्वर।

कुछ कमांड के साथ आते हैं --force (-f)विकल्प, जो रिपॉजिटरी को फिर से लाने के लिए मजबूर करता है। इस विकल्प का उपयोग करके, कैश साफ़ होने से पहले 24 घंटे के चक्र की प्रतीक्षा करने की आवश्यकता नहीं है।

आदेश

आप कुछ आदेशों का उपयोग करके Grav रिपॉजिटरी से उपलब्ध पैकेज डाउनलोड कर सकते हैं। कमांड का उपयोग करने के लिए, अपना टर्मिनल खोलें और Grav फ़ोल्डर की अपनी रूट पर नेविगेट करें और टाइप करेंbin/gpm <command>

सूची

सूचकांक कमांड का उपयोग Grav रिपॉजिटरी में उपलब्ध प्लगइन्स, थीम को सूचीबद्ध करने के लिए किया जाता है। उपलब्ध संसाधनों को सूचीबद्ध करने के लिए अपने टर्मिनल में नीचे दिए गए कमांड का उपयोग करें।

$ bin/gpm index

प्रत्येक पंक्ति प्लगइन या थीम, स्लग, प्लगइन या थीम के संस्करण को परिभाषित करती है और यह भी प्रदर्शित करती है कि यह स्थापित है या नहीं।

जानकारी

जानकारी कमांड का उपयोग पैकेज के बारे में जानकारी प्रदर्शित करने के लिए किया जाता है जैसे कि लेखक, संस्करण, अंतिम अपडेट का दिनांक और समय, पैकेज का भंडार, पैकेज का डाउनलोड लिंक, लाइसेंस जानकारी आदि।

इंस्टॉल

जैसा कि नाम से पता चलता है कि इंस्टॉलेशन कमांड Grav रिपॉजिटरी से पैकेज के लिए आवश्यक संसाधन स्थापित करता है।

आप आवश्यक पैकेज को स्थापित करने के लिए निम्न कमांड का उपयोग कर सकते हैं।

$ bin/gpm install package_name

यदि आप पहले से स्थापित पैकेज को स्थापित करने का प्रयास करते हैं, तो यह सूचित करता है कि आगे क्या करना है।

यदि आप टाइप करते हैं Y, यह पहले से ही स्थापित पैकेज पर ओवरराइट करेगा और यदि आप टाइप करते हैं N, यह स्थापना प्रक्रिया को समाप्त कर देगा।

अपडेट करें

अद्यतन आदेश अद्यतन किए जाने वाले पैकेज के बारे में सूचित करता है। मान लीजिए अगर सभी पैकेज अद्यतित हैं, तो यह अद्यतन करने के लिए कुछ भी नहीं कहेगा।

$ bin/gpm update

आत्म उन्नयन

ग्रेव को नवीनतम संस्करण में अपग्रेड करने के लिए सेल्फ अपग्रेड कमांड का उपयोग किया जाता है। ग्रेव को अपग्रेड करने के लिए निम्न कमांड का उपयोग करें।

$ bin/gpm self-upgrade

यदि आप Grav के नवीनतम संस्करण का उपयोग कर रहे हैं, तो यह एक संदेश प्रदर्शित करेगा जिसमें कहा गया है कि "आप पहले से ही Grav का नवीनतम संस्करण चला रहे हैं" रिलीज़ होने की तारीख और स्क्रीन में दिखाए गए समय के साथ।

आप विभिन्न प्रकार के साथ Grav का निर्माण कर सकते हैं Development जैसे कि Grav Core, Grav Plugins, Grav Skeleton तथा Grav Themes

Grav कोर

Grav एक आधुनिक CMS है जिसमें लेखन सामग्री सरल है और पृष्ठों का निर्माण अधिक अनुकूल और सहज है। Grav coreसिस्टम फ़ोल्डर के बारे में विशेष रूप से बात करता है जो ग्रेव के बारे में सब कुछ नियंत्रित करता है और ग्रेव वर्कफ़्लो और जीवन चक्र के गुणों का प्रतिनिधित्व करता है। यह मुख्य रूप से उन पृष्ठों पर केंद्रित है जिन्हें अच्छे तरीके से लिखा जा सकता है। यह आपकी सामग्री पर ध्यान केंद्रित करता है और आपकी सामग्री को नेविगेट करने योग्य साइट में बदल देता है।

Grav प्लगइन्स

Pluginसॉफ्टवेयर का एक टुकड़ा है जो उन्नत कार्यक्षमता प्रदान करता है जो मूल रूप से Grav की मुख्य कार्यक्षमता द्वारा पूरा नहीं किया गया था। Grav रिपॉजिटरी पर कई प्लगइन्स उपलब्ध हैं जो साइट पर कार्यक्षमता दिखाते हैं।

Grav plugins से संबंधित निम्नलिखित बिंदुओं पर विचार करें -

  • Grav ही है super-lean जो आपकी साइट के लिए केवल आवश्यक प्लगइन्स जोड़ता है।

  • अतिरिक्त कार्यक्षमता जोड़ने के लिए प्रतीक्षा करने की आवश्यकता नहीं है जो आप चाहते हैं। इसे प्राप्त करने के लिए, Grav का विस्तार करने के लिए बस एक प्लगइन बनाएं।

  • प्लगइन्स इतने लचीले और शक्तिशाली हैं जो साइट मैप, ब्लॉग आर्काइव्स, सर्च इंजन, ब्रेडक्रंब आदि प्रदान करते हैं।

ग्रेव कंकाल

Grav skeletonएक नमूना साइट का वर्णन करता है जिसमें Grav Core, प्लगइन्स, पृष्ठ, विषय सभी एक साथ हैं। ग्रेव के पीछे प्रारंभिक विचार बहुत आसानी से साइट का निर्माण करना था। एक साइट को विकसित करने के लिए आवश्यक सभी को एक में रखा गया हैuserफ़ोल्डर। Grav का कंकाल विभिन्न निर्भरताओं जैसे प्लगइन्स, थीम आदि के साथ आता है और एक पैकेज में संग्रहीत होता है जिसे अनज़िप किया जा सकता है।

Grav थीम्स

Grav विभिन्न प्रकार का समर्थन करता है themesehich एक Grav साइट का एक अभिन्न हिस्सा है। जब आप अपने सिस्टम पर Grav स्थापित करते हैं, तो यह आता हैAntimatterविषय। अधिकांश थीम कंकाल पैकेज या नमूना पृष्ठों के साथ आते हैं। आप के तहत नमूना पृष्ठों को देख सकते हैंuser/pages फ़ोल्डर जो कंकाल पैकेज के समान अनुभव प्रदान करता है।

The installed theme requires appropriate twig templates for your pages. A theme is combination of theme and content which is equal to the entire site design. You can create your own twig templating engine according to your design.

Theme/Plugin Release Process

You can notice some of the points for your created theme or plugin which is added in the Grav repository.

  • It is an open source which is licensed by MIT.

  • It has the README.md file which specifies installation process and configuration of the project.

  • It contains blueprints.yaml file which includes information about resource and can be found at the root of each plugin and theme.

  • Contains CHANGELOG.md file which includes version of the theme or plugin and displays the information whenever changes made to the file.

  • Creating releases are better ways to place your completed theme or plugin on the GitHub. If there is no release, then you won't find your plugin or theme.

  • Add the details about your plugin or theme and do a test to ensure its working functionality.

ChangeLog Format

The changelog format is written in the Markdown syntax which keeps the content and visual display separate. It uses simple CSS which is displayed in the following format.

# vX.Y.Z
## 01/01/2015
1. [](#new)
   * New features added
   * Another new feature
2. [](#improved)
   * Improvement made
   * Another improvement
3. [](#bugfix)
   * Bugfix implemented
   * Another bugfix
...repeat...

GitHub Setup

GitHub is a largest open community which shares your projects with the users, get feedback and contribute to the repositories hosted on GitHub.

Clone the URL of external repository into single project folder on your local system. You can clone the external Git repository to new repository as shown in the steps below.

Open the command line and create folder called "my_project".

$ mkdir my_project
$ cd my_project $ mkdir Grav
$ cd Grav $ git clone https://github.com/getGrav/Grav.git
$ git clone https://github.com/Grav_project/Grav-plugin-error.git $ git clone https://github.com/ Grav_project /Grav-plugin-problems.git
$ git clone https://github.com/ Grav_project /Grav-theme-antimatter.git

Here Grav_project is a repository where you will get all the files and folders related to this repository will be saved in the /my_project/Grav folder. Grav includes dependencies such as error plugin, problems plugin and Antimatter theme.

You can setup the test site for Grav by using the bin/Grav new-project command. We need to develop the cloned code from the web root. So we have to symbolically link the related parts using -s flag to the bin/Grav new-project command.

Create one configuration file in a new folder called .Grav/ to find the repository by using the command and you need to create this under the root directory.

$ cd
$ mkdir .Grav $ vi .Grav/config

Navigate to your Grav folder and setup the symbolically linked site using -s flag.

$ cd ~/Projects/Grav/Grav $ bin/Grav my-project -s ~/www/Grav

Here, www is a root folder and Grav is the location where you're going to create the test site.

In this chapter, we will understand the lifecycle of Grav. Grav Lifecycle determines how Grav processes in order to extend the Grav via Plugins. The following diagram shows the flow of Grav lifecycle process.

The following four steps from the Grav lifecycle −

  • PHP Version

  • Loader class is initialized

  • Obtain Grav Instance

  • Call Grav Process

PHP Version

It checks the version of PHP to make sure that we are running the PHP version above 5.4.0.

Loader class is initialized

In the second step, the class loader gets initialized.

Obtain Grav Instance

  • If no instance exists, then it calls the load() method and adds Grav.

  • It initializes the debugger value and adds to the debugger.

  • It registers the log and the error handler.

  • It adds the uri, task, events, cache, session, plugins, themes, twig, taxonomy, language, pages, assets and base url.

  • It registers the stream and the config handler.

Call Grav Process

  • It initializes the configuration, Uri object, error handler, debugger and session.

  • After initializing, it starts buffering the output.

  • It initializes the timezone and the plugins and fires the onPluginsInitialized event.

  • Next it initializes the theme and fires the onThemeInitialized and onTask[TASK] events.

  • It initializes the assets and fires the onAssetsInitialized event.

  • It initializes the twig with the following actions −

    • Based on the configuration, it sets the twig template paths.

    • Handles the available language templates.

    • Next it fires the onTwigTemplatePaths event.

    • Loader chain and twig configuration is loaded.

    • Fires onTwigInitialized event.

    • It loads the twig extensions and fires onTwigExtensions event.

    • It sets the standard twig variables.

  • Next it initializes the pages.

    • It calls the buildPages() method.

    • If cache is good, then it loads pages from cache. If cache is not good then the recurse() method is called.

    • onBuildPagesInitialized event is fired in the recurse() method.

    • If a file is found as .md, the following actions are performed −

      • To load the file details, the init() method is called.

      • It sets the filePath, modified and id.

      • The header() method is called to initialize header variables.

      • The slug() method is called to set the URL slug.

      • The visible() method is called to set the visible state.

      • Based on the folder that starts with _(underscore), modularTwig() is set.

    • It later fires the onPageProcessed event.

    • recurse() the children if a folder is found.

    • It fires the onFolderProcessed event.

    • calls the buildRoutes() method.

    • For all pages the taxonomy is initialized

    • The route table is built for fast lookup.

  • The events onPagesInitialized and onPageInitialized gets fired.

  • Debugger CSS/JS is added to the assets.

  • Using Twig's processSite() method, we get the output.

    • The event onTwigSiteVariables is fired.

    • Gets the output of the page.

    • When page is not found or not routable then the event onPageNotFound is fired.

    • All Twig variables are set on twig object.

    • Template name is set depending upon the file/header/extension information.

    • render() method is called.

    • Returns the file format in HTML

  • It fires the onOutputGenerated event.

  • Set the HTTP headers.

  • Displays the output

  • The output buffer is flushed to the page.

  • The event onOutputRendered will get fire.

  • Closes the connection to client.

  • Lastly, it fires the onShutDown event.

When the content() method is called on page, then the following lifecycle occurs.

  • The event onPageContentRaw will get fire.

  • According to the Markdown and Twig settings, it processes the page.

  • It fires the onPageContentProcessed event.

YAML stands for YAML Ain't Markup Language which includes human readable content and often used in configuration files, blueprints (metadata information about resource) and page settings.

Features

Following are the features of YAML −

  • Compared to XML or JSON, YAML is less complex and provides same features.

  • It provides configuration settings without the need to learn complex code types such as CSS, JavaScript or PHP.

  • YAML describes data and content of the YAML file which can be easily translated to multiple language types.

Basic Rules of YAML

There are some basic rules of YAML which are used to reduce the ambiguity in multiple languages and editable programs.

  • You must end the YAML files with .yaml extension.

  • YAML must be case-sensitive.

  • YAML doesn't support the use of tabs. Instead of tabs, it uses spaces which are not supported universally.

Basic Data Types of YAML

YAML supports some basic data types which can be used with programming languages such as −

  • Scalars − strings or numbers.

  • Sequences − arrays or lists.

  • Mappings − hashes or dictionaries.

Scalars

Scalars are the basic data types that use strings or numbers on the pages to work with the data. It may be a boolean property (either yes or no), integer value such as 2 or string of text such as word or sentence or title of the website.

For instance −

string: "Grav"
integer: 10
float: 10.5
boolean: true

Sometimes scalars come with unquoted values like integer, float or Boolean. The string value uses punctuation which comes with single or double quotation marks which uses escaping to specify ASCII and Unicode characters.

Sequences

YAML represent sequences in the form of arrays or lists. It defines each item with opening dash (-) placed in the list as shown below.

For instance −

- Apple
- Orange
- Grapes

Suppose if you want to define nested sequence with the sub items, and then place a single space before each dash in the sub items.

For instance −

-
   - Apple
   - Orange
   - Grapes

If you want nested sequence within the nested list, then add some levels as shown below −

For instance −

-
   -
      - Apple
      - Orange
      - Grapes

Mappings

It is a way of defining keys along with the values.

For example, you can assign some value to a specific element as −

Sports: cricket

Here the value is "cricket" that maps with the key called "Sports". You can use this mapping with the sequence to specify the list of items for cricket; for example, we will define some player names for the value "cricket" making names as child and Sports: cricket as parent.

Sports: cricket
- Sachin Tendulkar
- Rahul Dravid
- M S Dhoni

आप का उपयोग करके एक प्रपत्र बना सकते हैं formइस लिंक में उपलब्ध प्लगइन । फॉर्म प्लगइन खोजें और इसे अपने Grav फ़ोल्डर में स्थापित करें।

आप कमांड का उपयोग करके भी इस प्लगइन को स्थापित कर सकते हैं $ bin/gpm install Form। Grav के अपने रूट फ़ोल्डर में नेविगेट करें और यह कमांड टाइप करें। यह स्वचालित रूप से फॉर्म प्लगइन डाउनलोड करेगा और आवश्यक निर्भरताएं स्थापित करेगा।

एक सरल रूप बनाना

आप एक साधारण फॉर्म बना सकते हैं जिसे पेज YAML फ्रंटमैटर में परिभाषित किया जा सकता है। निम्नलिखित एक फार्म का एक उदाहरण है -

---
title: Contact Form

form:
   name: contact

   fields:
      - name: name
         label: Name
         placeholder: Enter your name
         autofocus: on
         autocomplete: on
         type: text
         validate:
            required: true

      - name: email
         label: Email
         placeholder: Enter your email address
         type: email
         validate:
            required: true

      - name: message
         label: Message
         placeholder: Enter your message
         type: textarea
         validate:
            required: true

      - name: g-recaptcha-response
         label: Captcha
         type: captcha
         recatpcha_site_key: 6LelOg4TAAAAALAt1CjjjVMxFLKY8rrnednYVbr8
         recaptcha_not_validated: 'Captcha not valid!'
         validate:
            required: true

   buttons:
      - type: submit
         value: Submit
      - type: reset
         value: Reset

   process:
      - email:
         subject: "[Site Contact Form] {{ form.value.name|e }}"
         body: "{% include 'forms/data.html.twig' %}"
      - save:
         fileprefix: contact-
         dateformat: Ymd-His-u
         extension: txt
         body: "{% include 'forms/data.txt.twig' %}"
      - message: Thank you for getting in touch!
      - display: thankyou
---

उपरोक्त कोड नाम, ईमेल, संदेश और कैप्चा फ़ील्ड के साथ सरल फ़ॉर्म पेज दिखाता है। जब आप फॉर्म भरने के बाद जानकारी सबमिट करते हैं, तो फॉर्म को जोड़कर प्रक्रिया होगीprocess कोड में दिखाए गए अनुसार YAML फ्रंटमैटर के लिए फ़ील्ड।

process फ़ील्ड निम्नलिखित जानकारी का उपयोग करती है -

  • email विकल्प जैसे दो क्षेत्रों का उपयोग करता है from फ़ील्ड ईमेल का प्रेषक निर्दिष्ट करें और to फ़ील्ड मेल का रिसीवर निर्दिष्ट करें।

  • subject उपयोग [feedback][entered mail] वह विकल्प जिसमें ईमेल दर्ज किए गए ईमेल पर भेजा जाता है।

  • ईमेल का मुख्य भाग इसमें निर्दिष्ट किया गया है forms/data.html.twig फ़ाइल जो विषय फ़ोल्डर में मौजूद है।

  • प्रपत्र इनपुट डेटा के अंतर्गत संग्रहीत किया जाता है user/dataफ़ोल्डर। टेम्पलेट में परिभाषित किया गया हैforms/data.txt.twig फ़ाइल जो विषय फ़ोल्डर में मौजूद है।

  • के तहत एक उपपृष्ठ बनाएँ thankyou/ उप फ़ोल्डर जो उस पृष्ठ पर पुनर्निर्देशित किया जाएगा जब कोई उपयोगकर्ता प्रपत्र सबमिट करता है।

आप निम्न तालिका में दिखाए गए प्रपत्र फ़ील्ड के साथ कुछ फ़ील्ड का उपयोग कर सकते हैं -

अनु क्रमांक। फ़ील्ड और विवरण
1

Captcha

यह एक एंटीस्पैम क्षेत्र है जिसका उपयोग कंप्यूटिंग में यह निर्धारित करने के लिए किया जाता है कि उपयोगकर्ता मानव है या नहीं।

2

Checkbox

यह एक साधारण चेकबॉक्स प्रदर्शित करता है।

3

Checkboxes

यह कई चेकबॉक्स प्रदर्शित करता है।

4

Date and Datetime

दोनों क्षेत्रों को क्रमशः समय के साथ दिनांक और दिनांक प्रदर्शित करने के लिए उपयोग किया जाता है।

5

Email

यह सत्यापन के साथ एक ईमेल क्षेत्र है।

6

Hidden

यह छिपे हुए क्षेत्र को निर्दिष्ट करता है।

7

Password

यह पासवर्ड फ़ील्ड निर्दिष्ट करता है।

8

Radio

यह सरल रेडियो बटन प्रदर्शित करता है।

9

Select

यह चुनिंदा क्षेत्र प्रदान करता है।

10

Spacer

यह शीर्षक, पाठ या क्षैतिज रेखा को फ़ॉर्म में जोड़ने की अनुमति देता है।

1 1

Text

यह सरल पाठ फ़ील्ड प्रदर्शित करता है।

12

Textarea

यह सरल पाठ क्षेत्र फ़ील्ड प्रदर्शित करता है।

13

Display

यह पाठ या निर्देश क्षेत्र प्रदर्शित करता है, इनपुट क्षेत्र नहीं।

फ़ील्ड्स पैरामीटर

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

अनु क्रमांक। पैरामीटर और विवरण
1

label

यह लेबल फ़ील्ड को परिभाषित करता है।

2

validate.required

यह आवश्यक तत्व बनाता है।

3

validate.pattern

यह सत्यापन पैटर्न निर्दिष्ट करता है।

4

validate.message

सत्यापन विफल होने पर यह संदेश प्रदर्शित करता है।

5

type

यह फ़ील्ड प्रकार को परिभाषित करता है।

6

default

यह डिफ़ॉल्ट फ़ील्ड प्रकार को परिभाषित करता है।

7

size

यह बड़े, एक्स-छोटे, मध्यम, लंबे, छोटे जैसे क्षेत्र के आकार को प्रदर्शित करता है।

8

name

यह फ़ील्ड नाम को परिभाषित करता है।

9

classes

यह सीएसएस कक्षाओं के साथ स्ट्रिंग का उपयोग करता है।

10

id

यह फ़ील्ड आईडी को परिभाषित करता है।

1 1

style

यह क्षेत्र की शैली को निर्दिष्ट करता है।

12

title

यह क्षेत्र के शीर्षक को परिभाषित करता है।

13

disabled

यह निर्धारित करता है कि फ़ील्ड अक्षम अवस्था में है या नहीं।

14

placeholder

यह एक छोटा संकेत है जो उपयोगकर्ता द्वारा किसी मूल्य में प्रवेश करने से पहले इनपुट क्षेत्र में प्रदर्शित किया जाता है।

15

autofocus

यह निर्दिष्ट करता है कि पृष्ठ लोड होने पर इनपुट तत्व को स्वचालित रूप से फ़ोकस प्राप्त करना चाहिए।

16

novalidate

यह निर्दिष्ट करता है कि फॉर्म डेटा सबमिट किए जाने पर मान्य नहीं होना चाहिए।

17

readonly

यह फ़ील्ड को केवल पढ़ने के लिए निर्धारित करता है।

18

autocomplete

यह क्षेत्र में विकल्प प्रदर्शित करता है जब उपयोगकर्ता क्षेत्र में टाइप करना शुरू करता है और पहले से टाइप किए गए मूल्यों के आधार पर मूल्यों को प्रदर्शित करता है।

कुछ क्षेत्रों में विशिष्ट पैरामीटर शामिल हैं जैसे -

अनु क्रमांक। पैरामीटर और विवरण
1

date and datetime

ये खेत उपयोग करते हैं validate.min तथा validate.max न्यूनतम और अधिकतम मान सेट करने के लिए।

2

spacer

यह उपयोगकर्ता है underline जोड़ने के लिए <hr> टैग, का उपयोग करके पाठ मान जोड़ता है text और उपयोग करता है title <h3> टैग के रूप में।

3

select

यह उपयोगकर्ता है multiple कई मान जोड़ने के लिए पैरामीटर।

4

select and checkboxes

यह उपयोगकर्ता है options उपलब्ध विकल्पों को सेट करने के लिए फ़ील्ड।

5

display

यह उपयोगकर्ता है contentसामग्री प्रदर्शित करने के लिए पैरामीटर। यह सेट करता हैmarkdown सामग्री दिखाने के लिए सही है।

6

captcha

यह उपयोगकर्ता है recatpcha_site_key तथा recaptcha_not_validated मापदंडों।

कैप्चा पर ध्यान दें

हमारे पास फ़ील्ड के अंतर्गत कैप्चा जानकारी पर कोड है g-recaptcha-response जैसा कि नीचे दिखाया गया है -

- name: g-recaptcha-response
   label: Captcha
   type: captcha
   recatpcha_site_key: 6LelOg4TAAAAALAt1CjjjVMxFLKY8rrnednYVbr8
   recaptcha_not_validated: 'Captcha not valid!'
   validate:
		required: true

आपकी वेबसाइट को स्पैम और दुरुपयोग से बचाने के लिए reCaptcha का उपयोग किया जाता है। इसका उपयोग करता हैrecatpcha_site_keyविकल्प और अपनी साइट पर विजेट प्रदर्शित करता है। ReCaptcha का उपयोग करने के लिए, बस reCaptcha डॉक्स देखें । यदि reCaptcha गलत है, तो यह संदेश का उपयोग करके प्रदर्शित करेगाrecaptcha_not_validated विकल्प।

रूप क्रिया

ईमेल

आप के तहत विशिष्ट विकल्पों के साथ एक ईमेल भेज सकते हैं process नीचे दिखाए अनुसार फ़ील्ड -

- email:
	from: "{{ config.plugins.email.from }}"
	to: "{{ config.plugins.email.to }}"
	subject: "Contact by {{ form.value.name|e }}"
	body: "{% include 'forms/data.html.twig' %}"

यह ईमेल विकल्प का उपयोग करता है जिसमें दो फ़ील्ड शामिल हैं; from फ़ील्ड ईमेल पते और भेजने वाले को निर्दिष्ट करता है toफ़ील्ड ईमेल प्लगइन कॉन्फ़िगरेशन का उपयोग करके ईमेल पते की प्राप्ति को निर्दिष्ट करता है। ईमेल फ़ील्ड भी उपयोग करता हैsubject वह विकल्प जिसमें एक ईमेल उस विषय के साथ दर्ज ईमेल पर भेजा जाता है [संपर्क द्वारा] [नाम दर्ज किया गया] और ईमेल का मुख्य भाग परिभाषित किया गया है forms/data.html.twig विषय की फ़ाइल।

अन्य पृष्ठ पर पुनर्निर्देशित करना

आप उपयोग करके किसी अन्य पृष्ठ पर पुनर्निर्देशित कर सकते हैं message तथा display के तहत परिभाषित विकल्प process मैदान।

process:
   - message: Thank you for getting in touch!
   - display: thankyou

messageविकल्प एक संदेश सेट करता है जिसे उपयोगकर्ता को सबमिट बटन पर क्लिक करने पर प्रदर्शित किया जाना चाहिए। जब कोई उपयोगकर्ता प्रपत्र सबमिट करता है, तो उसे दूसरे पृष्ठ पर पुनः निर्देशित किया जाना चाहिए। के तहत एक उपपृष्ठ बनाएंthankyou सबफ़ोल्डर जहाँ आपका form.mdफ़ाइल संग्रहीत है। फॉर्म जमा करने के बाद, यह पृष्ठ पर पुनर्निर्देशित किया जाएगा और उपरोक्त संदेश प्रदर्शित करेगा।

उपपृष्ठ बुलाया thankyou/formdata.md निम्नलिखित सामग्री होगी।

---
title: Email sent
cache_enable: false
process:
   twig: true
---

## Your email has been sent!

जब आप फ़ॉर्म जमा करते हैं, तो प्लगइन उपयोगकर्ता को एक ईमेल भेजेगा और डेटा को इसके अंतर्गत सहेजा जाएगा data/folder

सहेजें

इसका उपयोग डेटा को किसी फ़ाइल में सहेजने के लिए किया जाता है, जो इसके अंतर्गत सहेजी जाती है user/data फ़ोल्डर।

उदाहरण के लिए -

process:
   - save:
      fileprefix: contact-
      dateformat: Ymd-His-u
      extension: txt
      body: "{% include 'forms/data.txt.twig' %}"

एक्सटेंशन टेक्स्ट के साथ डेटा को टेक्स्ट फॉर्मेट में स्टोर किया जाएगा। शरीर से लिया जाता हैtemplates/forms/data.html.twig विषय की फ़ाइल।

निम्न स्क्रीन एक सरल रूप दिखाती है -

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

Grav विभिन्न प्रकार की होस्टिंग सेवाओं का समर्थन करता है -

  • Rochen Web Hosting

  • WireNine

  • Crucial Web Hosting

  • Arvixe

  • SiteGround

  • Dreamhost

रोचेन वेब होस्टिंग

इसका उपयोग दोनों के लिए किया जा सकता है GetGrav.org तथा RocketTheme.comलंबे समय तक होस्टिंग प्रदाता के रूप में। यह Grav प्रदर्शन को बढ़ाने के लिए Intel XEON प्रोसेसर के साथ SSD ड्राइव, Litespeed वेब सर्वर का उपयोग करता है। यह दो प्रकार के विकल्प प्रदान करता है; एक हैShared होस्टिंग और दूसरा है Burst मेजबानी।

रोचेन वेब होस्टिंग की अधिक जानकारी के लिए, इस लिंक पर क्लिक करें ।

WireNine

वायरलाइन 665 से अधिक देशों में ग्राहकों के लिए विश्वसनीय वेब होस्टिंग सेवाएं प्रदान करता है। यह सर्वर की कार्यक्षमता बढ़ाने के लिए Intel Xeon E5 v3 CPUs, DDR4 ECC ram और निरर्थक RAID SSD स्टोरेज का उपयोग करता है। यह 100% अपटाइम सुनिश्चित करने के लिए अधिकतम विश्वसनीयता और स्थिरता प्रदान करता है। इसमें अनुकूलित सॉफ्टवेयर शामिल हैं जैसे कि CloudLinux, Litespeed, MariaDB, PHP, Ruby, Python, Perg आदि।

वायरनीन होस्टिंग की जानकारी के लिए इस लिंक पर जाएँ।

महत्वपूर्ण वेब होस्टिंग

यह एक और वेब होस्टिंग प्रकार है जो गति और समर्थन पर अधिक ध्यान केंद्रित करता है। यह Grav प्रदर्शन को बढ़ाने के लिए Intel XEON प्रोसेसर के साथ SSD ड्राइव, Litespeed वेब सर्वर का उपयोग करता है।

आप इस लिंक में Crucial Web Hosting पर अधिक जानकारी प्राप्त कर सकते हैं ।

Arvixe

अरविक्स एक वेब होस्टिंग प्रकार है, जो बेजोड़ विश्वसनीयता, गुणवत्ता और सामर्थ्य के संयोजन के साथ वेब होस्टिंग प्रदान करता है। इसने वेब होस्टिंग क्षेत्र में अच्छी कार्यक्षमता प्रदान करने के लिए कई वेब होस्टिंग पुरस्कार जीते हैं।

अरविक्स वेब होस्टिंग की अधिक जानकारी के लिए, इस लिंक पर क्लिक करें ।

SiteGround

यह जूमला, वर्डप्रेस, मैगनेटो और अन्य वेब अनुप्रयोगों के लिए होस्टिंग समाधान प्रदान करता है। इसकी टैगलाइन हैWeb Hosting Crafted With Care जो वेब होस्टिंग योजनाओं को सावधानी से संभालता है और नई तकनीक प्रदान करता है जो आपकी वेबसाइट को तेजी से चलाते हैं।

SiteGround होस्टिंग की जानकारी के लिए बस इस लिंक पर जाएँ।

Dreamhost

यह आपकी व्यक्तिगत या व्यवसाय संबंधी वेब होस्टिंग आवश्यकताओं के लिए अधिक कार्यक्षमता प्रदान करके सुविधाओं की सूची प्रदान करता है। इसमें अल्ट्रा-फास्ट SSDs और 64GB रैम के साथ नए समर्पित सर्वर हैं।

ड्रीमहोस्ट वेब होस्टिंग के बारे में अधिक जानकारी के लिए, इस लिंक पर क्लिक करें ।

सर्वर की त्रुटि Grav की ग़लतफ़हमी के कारण होती है। जब सर्वर को आंतरिक त्रुटि का सामना करना पड़ा या अप्रत्याशित रूप से कुछ हुआ, तो ग्रेव पेज की सेवा और पुनर्प्राप्त करने में असमर्थ है।

यदि सर्वर उत्पादन मोड में चल रहा है, तो उपयोगकर्ता से जानकारी छिपाने के लिए, सर्वर त्रुटि संदेश उत्पन्न होता है। सभी त्रुटि संदेश Grav.log फ़ाइल में फ़ोल्डर <your_folder_name> /logs/Grav.log के अंतर्गत मौजूद हैं ।

निम्नलिखित कुछ कारण हैं जो सर्वर त्रुटि का कारण बन सकते हैं -

  • आउट-ऑफ-डेट कॉन्फ़िगरेशन
  • गलत फ़ाइल अनुमति
  • अमान्य स्वरूपित कॉन्फ़िगरेशन फ़ाइलें
  • फ़ाइल सिस्टम में परिवर्तन Grav के लिए ज्ञात नहीं है

आउट-ऑफ-डेट कॉन्फ़िगरेशन

आप यह जांचने के लिए कैश फ्लश कर सकते हैं कि कॉन्फ़िगरेशन अप-टू-डेट है या नहीं। कैश फ्लश करने के लिए निम्न कमांड का उपयोग करें।

bin/Grav clear-cache

स्थापना और कॉन्फ़िगरेशन समस्याएँ

स्थापना और विन्यास के मुद्दे हैं -

  • कॉन्फ़िगरेशन समस्याएँ
  • स्थापना समस्याएँ
  • व्यवस्था की आवश्यकता
  • फ़ाइल अनुमतियाँ

सामान्य रूप में, permissionअपने होस्टिंग वातावरण पर कुछ करने की अनुमति देने की एक प्रक्रिया है। अनुमति में सर्वर पर फ़ाइलों को पढ़ने या लिखने या फ़ाइल सिस्टम पर फ़ाइलों को संपादित करना शामिल है। Grav एक फ्लैट फ़ाइल आधारित CMS है जिसे कैश और लॉग फाइल बनाने के लिए फाइल सिस्टम में लिखना पड़ता है।

Grav तीन मुख्य परिदृश्यों के अंतर्गत आता है -

PHP / Webserver उसी उपयोगकर्ता के साथ चलता है जो फ़ाइलों को संपादित करता है

यह परिदृश्य सबसे साझा होस्टिंग सेटअप और स्थानीय विकास के लिए भी बढ़िया काम करता है। समर्पित वेब होस्ट पर, हम इस दृष्टिकोण को पर्याप्त सुरक्षित नहीं मान सकते।

PHP / वेबसर्वर विभिन्न खातों के साथ चलता है लेकिन समान समूह

उपयोगकर्ता और PHP / वेबसर्वर खाते के बीच साझा समूह का उपयोग कर 775 और 664 अनुमतियों के साथ , आप सुनिश्चित कर सकते हैं कि दो अलग-अलग खातों में होगाRead/Writeफ़ाइलों तक पहुँच। हम उचित अनुमतियों के साथ रूट पर umask 0002 सेट करके नई फाइलें बना सकते हैं ।

विभिन्न खाते, अनुमतियाँ मैन्युअल रूप से ठीक करें

इस दृष्टिकोण में अलग-अलग खाते होंगे और फाइलों के स्वामित्व और अनुमति को अपडेट करेंगे जो यह सुनिश्चित करते हैं कि PHP / Webserver उपयोगकर्ता के पास होगा Read/Write फाइलों पर पहुंच।

निम्नलिखित का सरल कोड है permissions-fixingशेल स्क्रिप्ट। आप इस फ़ाइल को उस समूह के अनुसार संपादित कर सकते हैं जो सेटअप के लिए काम करता है।

#!/bin/sh
chown joeblow:staff .
chown -R joeblow:staff *
find . -type f ! -path "./bin/" | xargs chmod 664
find . -type f -path "./bin/" | xargs chmod 775
find . -type d | xargs chmod 775
find . -type d | xargs chmod +s
umask 0002
  • chown joeblow: स्टाफ का उपयोग डायरेक्टरी के समूह और उपयोगकर्ता को joeblow और स्टाफ में बदलने के लिए किया जाता है।

  • chown -R joeblow: कर्मचारी * लाइन फ़ाइलों और सबफ़ोल्डर के स्वामित्व को joeblow और कर्मचारियों में परिवर्तित करता है।

  • लाइन ढूंढते हैं। -टाइप च! -पथ "./bin/" | xargs chmod 664 निर्देशिका से सभी फ़ाइलों के लिए 664 अनुमतियाँ सेट करता है दूसरों के लिए पढ़ें और समूह और उपयोगकर्ता के लिए पढ़ें / लिखें

  • लाइन ढूंढते हैं। -प्रत्यय f -path "./bin/" | xargs chmod 775 समूह और उपयोगकर्ता के लिए दूसरों और RWX के लिए निर्देशिका से RX के लिए सभी फ़ाइलों के लिए 775 अनुमतियाँ सेट करता है ।

  • umask 0002 का उपयोग 664 और 775 अनुमतियों के साथ नई फाइलें बनाने के लिए किया जाता है।