Grav - रूप

आप का उपयोग करके एक प्रपत्र बना सकते हैं 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 विषय की फ़ाइल।

निम्न स्क्रीन एक सरल रूप दिखाती है -