लॉयल्टी टेंप्लेट

संग्रह की मदद से व्यवस्थित रहें अपनी प्राथमिकताओं के आधार पर, कॉन्टेंट को सेव करें और कैटगरी में बांटें.

लॉयल्टी पास को अपनी पसंद के मुताबिक बनाने के लिए, नीचे दिए गए टूल का इस्तेमाल करें और नीचे दिया गया कोड स्निपेट देखें.

लॉयल्टी पास, टेंप्लेट रेंडरिंग का समर्थन करता है. अगर कोई टेंप्लेट तय नहीं किया गया है, तो डिफ़ॉल्ट टेंप्लेट इस्तेमाल किया जाता है.

टेंप्लेट की परिभाषा

पास टेंप्लेट को क्लास के लेवल पर बताया जाता है. इसका इस्तेमाल, क्लास से जुड़े किसी भी ऑब्जेक्ट को दिखाने के लिए किया जाता है. टेंप्लेट से यह पता चलता है कि पास के अलग-अलग सेक्शन में कौनसे फ़ील्ड दिखाए जाने हैं.

टेंप्लेट को इन सेक्शन में बांटा गया है:

Android

टेंप्लेट की खास जानकारी

वेब

टेंप्लेट की खास जानकारी

कार्ड शीर्षक

Android

कार्ड के शीर्षक वाले एलिमेंट
  1. class.programLogo
  2. class.localizedIssuerName
    या class.issuerName
  3. class.localizedProgramName
    या class.programName
  4. class.hexBackgroundColor

वेब

कार्ड के शीर्षक वाले एलिमेंट
  1. class.programLogo
  2. class.localizedIssuerName
    या class.issuerName
  3. class.localizedProgramName
    या class.programName
  4. class.hexBackgroundColor

कार्ड के शीर्षक वाले सेक्शन में लोगो, जारी करने वाले का नाम, और प्रोग्राम का शीर्षक दिखता है. न तो फ़ील्ड में जानकारी भरने और न ही उनकी स्थिति में बदलाव किया जा सकता है.

कार्ड का टेंप्लेट

Android

टेंप्लेट की खास जानकारी

वेब

टेंप्लेट की खास जानकारी

कार्ड के टेंप्लेट वाले सेक्शन का इस्तेमाल, अतिरिक्त लाइनें दिखाने के लिए किया जाता है. इन पंक्तियों में, टेक्स्ट पर आधारित स्ट्रक्चर्ड डेटा फ़ील्ड या टेक्स्ट मॉड्यूल फ़ील्ड शामिल हो सकते हैं.

पंक्तियों की संख्या तय की जा सकती है, जो class.classTemplateInfo.cardTemplateOverride.cardRowTemplateInfos[] सूची में ऑब्जेक्ट की संख्या तय करती हैं. इस सूची में कम से कम एक एलिमेंट होना ज़रूरी है और हमने इसे ज़्यादा से ज़्यादा दो एलिमेंट के इस्तेमाल का सुझाव दिया है. हर एलिमेंट, इनमें से किसी एक तरह का होना चाहिए:

  • oneItem, जो एक आइटम स्वीकार करता है:
    • item
  • twoItems, इसमें दो आइटम स्वीकार किए जाते हैं:
    • startItem
    • endItem
  • threeItems, जिसमें तीन आइटम स्वीकार किए जाते हैं:
    • startItem
    • middleItem
    • endItem

हर आइटम को एक फ़ील्ड सिलेक्टर (.firstValue), दो फ़ील्ड सिलेक्टर (.firstValue और .secondValue) या एक तय आइटम (.predefinedItem) के तौर पर बताया जा सकता है. चुने गए फ़ील्ड की वैल्यू और उनसे जुड़े लेबल दिखते हैं. जब आप दो फ़ील्ड सिलेक्टर तय करते हैं, तो चुने गए फ़ील्ड की वैल्यू, "/" सेपरेटर के साथ दिखती है. चुने गए फ़ील्ड के लेबल के लिए भी यही लागू होता है. पहले से तय आइटम का इस्तेमाल, ज़्यादा कॉम्प्लेक्स रेंडरिंग के बारे में बताने के लिए किया जाता है.

कोड के इस नमूने में, दो पंक्तियों को तय करने के लिए कार्ड टेंप्लेट कार्ड के लाइन सेक्शन को बदलने का तरीका बताया गया है. हर लाइन में तीन ऐसे आइटम होते हैं जो हर छह कैटगरी वाले textModuleData कस्टम फ़ील्ड और उनके हेडर को लेबल के तौर पर दिखाते हैं:

Python

 {
   ... //Rest of class
   "textModulesData": [
        {
            "header": "Label 1",
            "body": "Some info 1",
            "id": "myfield1"
        },
        {
            "header": "Label 2",
            "body": "Some info 2",
            "id": "myfield2"
        },
        {
            "header": "Label 3",
            "body": "Some info 3",
            "id": "myfield3"
        },
        {
            "header": "Label 4",
            "body": "Some info 4",
            "id": "myfield4"
        },
        {
            "header": "Label 5",
            "body": "Some info 5",
            "id": "myfield5"
        },
        {
            "header": "Label 6",
            "body": "Some info 6",
            "id": "myfield6"
        }
    ],
   "classTemplateInfo": {
        "cardTemplateOverride": {
            "cardRowTemplateInfos": [{
                "threeItems": {
                    "startItem": {
                        "firstValue": {
                            "fields": [{
                                "fieldPath": "class.textModulesData['myfield1']"
                            }]
                        }
                    },
                    "middleItem": {
                        "firstValue": {
                            "fields": [{
                                "fieldPath": "class.textModulesData['myfield2']"
                            }]
                        }
                    },
                    "endItem": {
                        "firstValue": {
                            "fields": [{
                                "fieldPath": "class.textModulesData['myfield3']"
                            }]
                        }
                    },
                }
            },{
                "threeItems": {
                    "startItem": {
                        "firstValue": {
                            "fields": [{
                                "fieldPath": "class.textModulesData['myfield4']"
                            }]
                        }
                    },
                    "middleItem": {
                        "firstValue": {
                            "fields": [{
                                "fieldPath": "class.textModulesData['myfield5']"
                            }]
                        }
                    },
                    "endItem": {
                        "firstValue": {
                            "fields": [{
                                "fieldPath": "class.textModulesData['myfield6']"
                            }]
                        }
                    },
                }
            }]
        }
    }
}
    

Java

// Rest of class
  .setTextModulesData((new ArrayList<TextModuleData>() {
    {
      add((new TextModuleData()).setHeader("Label 1")
        .setBody("Some info 1")
        .setId("myfield1"));
      add((new TextModuleData()).setHeader("Label 2")
        .setBody("Some info 1")
        .setId("myfield2"));
      add((new TextModuleData()).setHeader("Label 3")
        .setBody("Some info 3")
        .setId("myfield3"));
      add((new TextModuleData()).setHeader("Label 4")
        .setBody("Some info 4")
        .setId("myfield4"));
      add((new TextModuleData()).setHeader("Label 5")
        .setBody("Some info 5")
        .setId("myfield5"));
      add((new TextModuleData()).setHeader("Label 6")
        .setBody("Some info 5")
        .setId("myfield6"));
    }
  }))
  .setClassTemplateInfo((new ClassTemplateInfo())
    .setCardTemplateOverride((new CardTemplateOverride())
      .setCardRowTemplateInfos(new ArrayList<CardRowTemplateInfo>() {
        {
          add((new CardRowTemplateInfo()).setThreeItems((new CardRowThreeItems())
            .setStartItem((new TemplateItem()).setFirstValue((new FieldSelector()).setFields(new ArrayList<FieldReference>(){
              {
                add((new FieldReference()).setFieldPath("class.textModulesData['myfield1']"));
              }
            })))
            .setMiddleItem((new TemplateItem()).setFirstValue((new FieldSelector()).setFields(new ArrayList<FieldReference>(){
              {
                add((new FieldReference()).setFieldPath("class.textModulesData['myfield2']"));
              }
            })))
            .setEndItem((new TemplateItem()).setFirstValue((new FieldSelector()).setFields(new ArrayList<FieldReference>(){
              {
                add((new FieldReference()).setFieldPath("class.textModulesData['myfield3']"));
              }
            })))
          ));
          add((new CardRowTemplateInfo()).setThreeItems((new CardRowThreeItems())
            .setStartItem((new TemplateItem()).setFirstValue((new FieldSelector()).setFields(new ArrayList<FieldReference>(){
              {
                add((new FieldReference()).setFieldPath("class.textModulesData['myfield4']"));
              }
            })))
            .setMiddleItem((new TemplateItem()).setFirstValue((new FieldSelector()).setFields(new ArrayList<FieldReference>(){
              {
                add((new FieldReference()).setFieldPath("class.textModulesData['myfield5']"));
              }
            })))
            .setEndItem((new TemplateItem()).setFirstValue((new FieldSelector()).setFields(new ArrayList<FieldReference>(){
              {
                add((new FieldReference()).setFieldPath("class.textModulesData['myfield6']"));
              }
            })))
          ));
          }
  })))
    

PHP

// Rest of class
    $textModulesData1 = new Google_Service_Walletobjects_TextModuleData();
    $textModulesData1->setBody("Some info 1");
    $textModulesData1->setHeader("Label 1");
    $textModulesData1->setId("myfield1");

    $textModulesData2 = new Google_Service_Walletobjects_TextModuleData();
    $textModulesData2->setBody("Some info 2");
    $textModulesData2->setHeader("Label 2");
    $textModulesData2->setId("myfield2");

    $textModulesData3 = new Google_Service_Walletobjects_TextModuleData();
    $textModulesData3->setBody("Some info 3");
    $textModulesData3->setHeader("Label 3");
    $textModulesData3->setId("myfield3");

    $textModulesData4 = new Google_Service_Walletobjects_TextModuleData();
    $textModulesData4->setBody("Some info 4");
    $textModulesData4->setHeader("Label 4");
    $textModulesData4->setId("myfield4");

    $textModulesData5 = new Google_Service_Walletobjects_TextModuleData();
    $textModulesData5->setBody("Some info 5");
    $textModulesData5->setHeader("Label 5");
    $textModulesData5->setId("myfield5");

    $textModulesData6 = new Google_Service_Walletobjects_TextModuleData();
    $textModulesData6->setBody("Some info 6");
    $textModulesData6->setHeader("Label 6");
    $textModulesData6->setId("myfield6");

    $textModulesDatas = array($textModulesData1, $textModulesData2, $textModulesData3,
                  $textModulesData4, $textModulesData5, $textModulesData6);

    $startItemField = new Google_Service_Walletobjects_FieldReference();
    $startItemField->setFieldPath("class.textModulesData['myfield1']");

    $startItemFirstValue = new Google_Service_Walletobjects_FieldSelector();
    $startItemFirstValue->setFields(array($startItemField));

    $startItem = new Google_Service_Walletobjects_TemplateItem();
    $startItem->setFirstValue($startItemFirstValue);

    $middleItemField = new Google_Service_Walletobjects_FieldReference();
    $middleItemField->setFieldPath("class.textModulesData['myfield2']");

    $middleItemFirstValue = new Google_Service_Walletobjects_FieldSelector();
    $middleItemFirstValue->setFields(array($middleItemField));

    $middleItem = new Google_Service_Walletobjects_TemplateItem();
    $middleItem->setFirstValue($middleItemFirstValue);

    $endItemField = new Google_Service_Walletobjects_FieldReference();
    $endItemField->setFieldPath("class.textModulesData['myfield3']");

    $endItemFirstValue = new Google_Service_Walletobjects_FieldSelector();
    $endItemFirstValue->setFields(array($endItemField));

    $endItem = new Google_Service_Walletobjects_TemplateItem();
    $endItem->setFirstValue($endItemFirstValue);

    $cardRowTemplate = new Google_Service_Walletobjects_CardRowThreeItems();
    $cardRowTemplate->setStartItem($startItem);
    $cardRowTemplate->setMiddleItem($middleItem);
    $cardRowTemplate->setEndItem($endItem);

    $cardRowTemplateInfo1 = new Google_Service_Walletobjects_CardRowTemplateInfo();
    $cardRowTemplateInfo1->setThreeItems($cardRowTemplate);

    $startItemField2 = new Google_Service_Walletobjects_FieldReference();
    $startItemField2->setFieldPath("class.textModulesData['myfield4']");

    $startItemFirstValue2 = new Google_Service_Walletobjects_FieldSelector();
    $startItemFirstValue2->setFields(array($startItemField2));

    $startItem2 = new Google_Service_Walletobjects_TemplateItem();
    $startItem2->setFirstValue($startItemFirstValue2);

    $middleItemField2 = new Google_Service_Walletobjects_FieldReference();
    $middleItemField2->setFieldPath("class.textModulesData['myfield5']");

    $middleItemFirstValue2 = new Google_Service_Walletobjects_FieldSelector();
    $middleItemFirstValue2->setFields(array($middleItemField2));

    $middleItem2 = new Google_Service_Walletobjects_TemplateItem();
    $middleItem2->setFirstValue($middleItemFirstValue2);

    $endItemField2 = new Google_Service_Walletobjects_FieldReference();
    $endItemField2->setFieldPath("class.textModulesData['myfield6']");

    $endItemFirstValue2 = new Google_Service_Walletobjects_FieldSelector();
    $endItemFirstValue2->setFields(array($endItemField2));

    $endItem2 = new Google_Service_Walletobjects_TemplateItem();
    $endItem2->setFirstValue($endItemFirstValue2);

    $cardRowTemplate2 = new Google_Service_Walletobjects_CardRowThreeItems();
    $cardRowTemplate2->setStartItem($startItem2);
    $cardRowTemplate2->setMiddleItem($middleItem2);
    $cardRowTemplate2->setEndItem($endItem2);

    $cardRowTemplateInfo2 = new Google_Service_Walletobjects_CardRowTemplateInfo();
    $cardRowTemplateInfo2->setThreeItems($cardRowTemplate2);

    $cardTemplateOverride = new Google_Service_Walletobjects_CardTemplateOverride();
    $cardTemplateOverride->setCardRowTemplateInfos(array($cardRowTemplateInfo1,
                  $cardRowTemplateInfo2));

    $classTemplateInfo = new Google_Service_Walletobjects_ClassTemplateInfo();
    $classTemplateInfo->setCardTemplateOverride($cardTemplateOverride);

    $payload->setTextModulesData($textModulesDatas);
    $payload->setClassTemplateInfo($classTemplateInfo);
    

इस कोड से, कोड टेंप्लेट के इस सेक्शन का फ़ॉर्मैट बनाया जाता है:

लेबल के बदलाव का उदाहरण.

अगर कोई आइटम खाली है, तो वह नहीं दिखता है. ज़्यादा जानकारी के लिए, फ़ील्ड रेफ़रंस देखें. अगर किसी पंक्ति के सभी आइटम खाली हैं, तो पंक्ति नहीं दिखाई जाती है. अगर किसी पंक्ति में मौजूद सभी आइटम खाली हैं, लेकिन सभी आइटम खाली नहीं हैं, तो जो आइटम खाली नहीं हैं उन्हें फिर से व्यवस्थित किया गया है. साथ ही, उन्हें कम आइटम वाली पंक्ति के तौर पर दिखाया जाता है.

अगर आप कार्ड टेंप्लेट नहीं बदलते, तो पंक्तियों की डिफ़ॉल्ट संख्या, आइटम की डिफ़ॉल्ट संख्या, और डिफ़ॉल्ट फ़ील्ड रेफ़रंस का इस्तेमाल किया जाता है. ज़्यादा जानकारी के लिए, डिफ़ॉल्ट टेंप्लेट देखें.

हीरो इमेज बनाने के बाद, यह पहली लाइन के बाद दिख सकता है. इसके अलावा, यह तब हो सकता है, जब cardRowTemplateInfos सूची में कई लाइनें हों या लाइन के ऊपर सिर्फ़ एक लाइन हो.

कार्ड बारकोड

Android

कार्ड के बारकोड वाले एलिमेंट
  1. class.classTemplateInfo
      .cardBarcodeSectionDetails
      .firstTopDetail
  2. class.classTemplateInfo
      .cardBarcodeSectionDetails
      .secondTopDetail
  3. object.barcode.type और object.barcode.value
    या object.accountId
  4. object.barcode.alternateText
    या object.accountId
    या object.barcode.value
  5. class.classTemplateInfo
      .cardBarcodeSectionDetails
      .firstBottomDetail
  6. object.heroImage
    या class.heroImage

वेब

कार्ड के बारकोड वाले एलिमेंट
  1. class.classTemplateInfo
      .cardBarcodeSectionDetails
      .firstTopDetail
  2. class.classTemplateInfo
      .cardBarcodeSectionDetails
      .secondTopDetail
  3. object.barcode.type और object.barcode.value
    या object.accountId
  4. object.barcode.alternateText
    या object.accountId
    या object.barcode.value
  5. class.classTemplateInfo
      .cardBarcodeSectionDetails
      .firstBottomDetail

कार्ड बारकोड सेक्शन का इस्तेमाल, बारकोड के ऊपर और नीचे अतिरिक्त टेक्स्ट या इमेज दिखाने के लिए किया जाता है. इस सेक्शन में मौजूद किसी भी फ़ील्ड की ज़रूरत नहीं है.

फ़ील्ड चुनने के लिए तीन फ़ील्ड सिलेक्टर इस्तेमाल किए जा सकते हैं. इनका इस्तेमाल दो फ़ील्ड के साथ-साथ, दो फ़ील्ड को बारकोड के नीचे परिभाषित करने के लिए किया जा सकता है. इन्हें बिना किसी लेबल के दिखाया जाता है. या तो ये टेक्स्ट-आधारित स्ट्रक्चर्ड डेटा फ़ील्ड, टेक्स्ट मॉड्यूल फ़ील्ड या इमेज मॉड्यूल फ़ील्ड हो सकते हैं. इमेज का इस्तेमाल करने पर, ब्रैंड के दिशा-निर्देशों का पालन किया जाना चाहिए.

बारकोड को टाइप और वैल्यू के हिसाब से तय किया जाता है. इस्तेमाल किए जा सकने वाले बारकोड के टाइप की लिस्ट देखने के लिए, पहचान फ़ाइल देखें. इसके अलावा, टेक्स्ट को बारकोड के ठीक नीचे दिखाया जा सकता है. इस टेक्स्ट की मदद से, बारकोड को स्कैन करना आसान हो जाता है. ऐसा, किसी दूसरे इस्तेमाल के लिए भी किया जा सकता है.

कोड का यह सैंपल दिखाता है कि बारकोड के ऊपर इमेज दिखाने के लिए, पास के बारकोड सेक्शन को कैसे बदला जा सकता है:

Python

#... rest of class
    "imageModulesData": [
        {
            "mainImage": {
                "sourceUri": {
                    "uri":  "http://farm4.staticflickr.com/3738/12440799783_3dc3c20606_b.jpg",
                    "description": "Coffee"
                }
            },
            "Id": "myimage"
        }
    ],
    "classTemplateInfo": {
        "cardBarcodeSectionDetails": {
            "firstTopDetail": {
                "fieldSelector": {
                    "fields": [
                        {
                        "fieldPath": "class.imageModulesData['myimage'].mainImage"
                        }
                    ]
                }
            }
        }
    }
}
    

Java

//... rest of class
  .setImageModulesData((new ArrayList<ImageModuleData>() {
    {
      add((new ImageModuleData())
        .setId("myimage")
        .setMainImage((new Image()).setSourceUri((new ImageUri()).setDescription("Coffee beans")
          .setUri("http://farm4.staticflickr.com/3738/12440799783_3dc3c20606_b.jpg"))));
        }
      }))
      .setClassTemplateInfo((new ClassTemplateInfo())
        .setCardBarcodeSectionDetails((new CardBarcodeSectionDetails())
          .setFirstTopDetail((new BarcodeSectionDetail())
            .setFieldSelector((new FieldSelector())
              .setFields((new ArrayList<FieldReference>(){
                {
                  add((new FieldReference()).setFieldPath("class.imageModulesData['myimage'].mainImage"));
                }
            })))))
      }
    

PHP

//... rest of class
    $imageUri = new Google_Service_Walletobjects_ImageUri();
    $imageUri->setUri("https://farm8.staticflickr.com/7340/11177041185_a61a7f2139_o.jpg");
    $imageUri->setDescription("Baconrista flights image");
    $image = new Google_Service_Walletobjects_Image();
    $image->setSourceUri($imageUri);
    $imageModulesData = new Google_Service_Walletobjects_ImageModuleData();
    $imageModulesData->setMainImage($image);
            $imageModulesData->setId("myimage");

    $cardBarcodeFieldReference = new Google_Service_Walletobjects_FieldReference();
    $cardBarcodeFieldReference->setFieldPath("class.imageModulesData['myimage'].mainImage");

    $cardBarcodeFieldSelector = new Google_Service_Walletobjects_FieldSelector();
    $cardBarcodeFieldSelector->setFields(array($cardBarcodeFieldReference));

    $cardBarcodeDetail = new Google_Service_Walletobjects_BarcodeSectionDetail();
    $cardBarcodeDetail->setFieldSelector($cardBarcodeFieldSelector);

    $cardBarcodeSectionDetails = new Google_Service_Walletobjects_CardBarcodeSectionDetails();
    $cardBarcodeSectionDetails->setFirstTopDetail($cardBarcodeDetail);

    $classTemplateInfo = new Google_Service_Walletobjects_ClassTemplateInfo();
    $classTemplateInfo->setCardBarcodeSectionDetails($cardBarcodeSectionDetails);

    $payload->setClassTemplateInfo($classTemplateInfo);
            $payload->setImageModuleData($imageModulesData);
    

कोड, नीचे दिए गए बारकोड सेक्शन फ़ॉर्मैट के साथ एक पास बनाता है:

कार्ड बारकोड ओवरराइड का उदाहरण.

अगर आप बारकोड सेक्शन को नहीं बदलते हैं, तो डिफ़ॉल्ट बारकोड फ़ील्ड का इस्तेमाल किया जाता है. ज़्यादा जानकारी के लिए, डिफ़ॉल्ट टेंप्लेट देखें.

ब्यौरे वाला टेंप्लेट

Android

ब्यौरे वाले टेंप्लेट के सेक्शन
  • class.classTemplateInfo.detailsTemplateOverride
      .detailsItemInfos[0].item
  • class.classTemplateInfo.detailsTemplateOverride
      .detailsItemInfos[1].item
  • class.classTemplateInfo.detailsTemplateOverride
      .detailsItemInfos[2].item
  • class.classTemplateInfo.detailsTemplateOverride
      .detailsItemInfos[3].item
  • ...

वेब

ब्यौरे वाले टेंप्लेट के सेक्शन
  • class.classTemplateInfo.detailsTemplateOverride
      .detailsItemInfos[0].item
  • class.classTemplateInfo.detailsTemplateOverride
      .detailsItemInfos[1].item
  • class.classTemplateInfo.detailsTemplateOverride
      .detailsItemInfos[2].item
  • class.classTemplateInfo.detailsTemplateOverride
      .detailsItemInfos[3].item
  • ...

जानकारी वाले सेक्शन में, आइटम की सूची शामिल है class.classTemplateInfo.detailsTemplateOverride.detailsItemInfos[]. आइटम में किसी भी तरह का स्ट्रक्चर्ड डेटा फ़ील्ड, टेक्स्ट मॉड्यूल फ़ील्ड, लिंक मॉड्यूल फ़ील्ड, इमेज मॉड्यूल या मैसेज शामिल हो सकते हैं.

हर आइटम को एक फ़ील्ड सिलेक्टर (.firstValue), दो फ़ील्ड सिलेक्टर (.firstValue और .secondValue) या एक पहले से तय आइटम (.predefinedItem) के तौर पर बताया जा सकता है. चुने गए फ़ील्ड की वैल्यू और उनसे जुड़े लेबल दिखाए जाते हैं. जब आप दो फ़ील्ड सिलेक्टर तय करते हैं, तो चुने गए फ़ील्ड की वैल्यू, "/" सेपरेटर के साथ दिखती हैं. यही बात चुने गए फ़ील्ड के लेबल पर भी लागू होती है. पहले से तय आइटम का इस्तेमाल, ज़्यादा कॉम्प्लेक्स रेंडरिंग को तय करने के लिए किया जाता है. इमेज मॉड्यूल फ़ील्ड, लेबल के बिना पूरी चौड़ाई में रेंडर किए जाते हैं.

कोड के इस नमूने में पास के ब्यौरे वाले सेक्शन को बदलने का तरीका बताया गया है. इसमें, लेबल वाले एक linksModuleData फ़ील्ड को दिखाने का तरीका बताया गया है:

Python

//... rest of class
   "linksModuleData": {
        "uris": [
            {
                "uri": "http://maps.google.com/",
                "description": "Nearby Locations",
                "id":"mylink"
            }
        ]
    },
   "classTemplateInfo": {
        "detailsTemplateOverride": {
            "detailsItemInfos": [
                {
                    "item":{
                        "firstValue": {
                            "fields": [{
                                "fieldPath": "class.linksModuleData.uris['mylink']"
                            }]
                        }
                    }
                }
            ]
        }
     }
//... rest of class
    

Java

 //... rest of class
  .setLinksModuleData((new ArrayList<LinksModuleData>() {
    {
      add((new LinksModuleData()).setDescription("Nearby Locations")
        .setUri("http://maps.google.com/")
        .setId("mylink"));
      }))
      .setClassTemplateInfo((new ClassTemplateInfo())
        .setDetailsTemplateOverride((new DetailsTemplateOverride())
          .setDetailsItemInfos(new ArrayList<DetailsItemInfo>(){
            {
              add((new DetailsItemInfo())
                .setItem((new TemplateItem()).setFirstValue((new FieldSelector()).setFields(new ArrayList<FieldReference>(){
                  {
                    add((new FieldReference()).setFieldPath("class.linksModuleData.uris['mylink']"));
                  }
                }))));
              }
            }))
//... rest of class
    

PHP



    //... rest of class building
    $locationUri = new Google_Service_Walletobjects_Uri();
    $locationUri->setUri("http://maps.google.com/");
    $locationUri->setDescription("Nearby Locations");
    $locationUri->setId("mylink");

    $linksModuleData = new Google_Service_Walletobjects_LinksModuleData();
    $linksModuleData->setUris(array($locationUri));

    $detailItemFieldReference = new Google_Service_Walletobjects_FieldReference();
    $detailItemFieldReference->setFieldPath("class.linksModuleData.uris['mylink']");
    $detailItemFieldSelector = new Google_Service_Walletobjects_FieldSelector();
    $detailItemFieldSelector->setFields(array($detailItemFieldReference));

    $detailItem = new Google_Service_Walletobjects_TemplateItem();
    $detailItem->setFirstValue($detailItemFieldSelector);

    $detailsItemInfo = new Google_Service_Walletobjects_DetailsItemInfo();
    $detailsItemInfo->setItem($detailItem);

    $cardDetailsTemplateOverride = new Google_Service_Walletobjects_DetailsTemplateOverride();
    $cardDetailsTemplateOverride->setDetailsItemInfos(array($detailsItemInfo));

    $classTemplateInfo = new Google_Service_Walletobjects_ClassTemplateInfo();
    $classTemplateInfo->setDetailsTemplateOverride($cardDetailsTemplateOverride);

    $payload->setClassTemplateInfo($classTemplateInfo);
    $payload->setLinksModuleData($linksModuleData);
    //... rest of class
    

कोड, नीचे दिए गए सेक्शन सेक्शन के फ़ॉर्मैट के साथ पास बनाता है:

जानकारी में बदलाव करने का उदाहरण.

अगर कोई आइटम खाली है, तो वह नहीं दिखता है. ज़्यादा जानकारी के लिए, फ़ील्ड रेफ़रंस देखें.

अगर आप ज़्यादा जानकारी वाले टेंप्लेट को नहीं बदलते, तो डिफ़ॉल्ट क्रम में, संदर्भ फ़ील्ड की डिफ़ॉल्ट सूची दिखती है. ज़्यादा जानकारी के लिए, डिफ़ॉल्ट टेंप्लेट देखें.

सूची टेम्प्लेट

टेंप्लेट एलिमेंट की सूची बनाएं
  1. class.classTemplateInfo.listTemplateOverride
      .firstRowOption.fieldOption.fields[]
  2. class.classTemplateInfo.listTemplateOverride
      .secondRowOption.fields[]
  3. class.programLogo
  4. class.hexBackgroundColor

सूची टेंप्लेट सेक्शन का इस्तेमाल, यह चुनने के लिए किया जाता है कि Google Wallet ऐप्लिकेशन के "पास" व्यू में कौनसा फ़ील्ड दिखाना है. सूची में पास, लोगो, बैकग्राउंड का रंग, और तीन लाइनों के साथ दिखता है.

कोड के इस नमूने में, पास की सूची के टेंप्लेट को बदलने का तरीका बताया गया है. इससे, सूची के टेंप्लेट की पहली पंक्ति में, एक पास की समयसीमा खत्म होने की तारीख वाला फ़ील्ड दिखता है:

Python


#... rest of class definition
   "classTemplateInfo": {
        "listTemplateOverride":{
            "firstRowOption": {
                "fieldOption":{
                    "fields": [{
                        "fieldPath": "object.validTimeInterval.end"
                    }]
                }
            }
        }
   }
}
    

Java

//... rest of class
  .setClassTemplateInfo((new ClassTemplateInfo())
    .setListTemplateOverride((new ListTemplateOverride())
      .setFirstRowOption((new FirstRowOption())
        .setFieldOption((new FieldSelector()).setFields(new ArrayList<FieldReference>(){
          {
            add((new FieldReference()).setFieldPath("object.validTimeInterval.end"));
          }
        }))))
//... rest of class
    

PHP

    //... rest of class
    $fieldReference = new Google_Service_Walletobjects_FieldReference();
    $fieldReference->setFieldPath("object.validTimeInterval.end");

    $fieldOption = new Google_Service_Walletobjects_FieldSelector();
    $fieldOption->setFields(array($fieldReference));

    $firstRowOption = new Google_Service_Walletobjects_FirstRowOption();
    $firstRowOption->setFieldOption($fieldOption);

    $listTemplateOverride = new Google_Service_Walletobjects_ListTemplateOverride();
    $listTemplateOverride->setFirstRowOption($firstRowOption);

    $classTemplateInfo = new Google_Service_Walletobjects_ClassTemplateInfo();
    $classTemplateInfo->setListTemplateOverride($listTemplateOverride);

    $payload->setClassTemplateInfo($classTemplateInfo);
    //... rest of class
    

कोड पास इस टेंप्लेट टेंप्लेट को दिखाने के लिए एक पास बनाता है:

ओवरराइड की गई सूची
                                                                           का उदाहरण.

तीन पंक्तियों को एक फ़ील्ड सिलेक्टर के साथ तय किया जा सकता है. फ़ील्ड, बिना लेबल के दिखाए जाते हैं.

लेबल

स्ट्रक्चर्ड डेटा के सभी फ़ील्ड में, Google से मिला लेबल होता है. इन लेबल में से हर भाषा में अनुवाद उपलब्ध कराने की ज़िम्मेदारी Google की है.

आप class.custom<name_of_the_field>Label फ़ील्ड में से किसी एक का इस्तेमाल करके, इनमें से कुछ लेबल को पसंद के मुताबिक बना सकते हैं. किसी लेबल को पसंद के मुताबिक बनाने पर, उस खास लेबल के लिए सभी भाषाओं में अनुवाद उपलब्ध कराने की ज़िम्मेदारी आपकी होती है. आपको उन भाषाओं में अनुवाद करने की सुविधा मिलती है.

फ़ील्ड रेफ़रंस

फ़ील्ड रेफ़रंस का इस्तेमाल, class.classTemplateInfo.*.fields[] फ़ॉर्म के साथ टेंप्लेट के अलग-अलग हिस्सों में किया जाता है. फ़ील्ड रेफ़रंस में स्ट्रक्चर्ड डेटा फ़ील्ड, टेक्स्ट मॉड्यूल फ़ील्ड, लिंक मॉड्यूल फ़ील्ड, इमेज मॉड्यूल फ़ील्ड या मैसेज के पाथ की सूची होती है.

हर फ़ील्ड रेफ़रंस में, सभी तरह के पाथ की अनुमति नहीं होती. उदाहरण के लिए, कुछ फ़ील्ड रेफ़रंस सिर्फ़ टेक्स्ट पर आधारित स्ट्रक्चर्ड डेटा फ़ील्ड या टेक्स्ट मॉड्यूल फ़ील्ड के पाथ की अनुमति देते हैं. टेक्स्ट पर आधारित स्ट्रक्चर्ड फ़ील्ड टाइप के स्ट्रक्चर्ड डेटा फ़ील्ड होते हैं. जैसे, स्ट्रिंग, स्थानीय जगह के अनुसार स्ट्रिंग, तारीख या पैसा.

इस सूची का इस्तेमाल फ़ॉलबैक लॉजिक को लागू करने के लिए किया जा सकता है. इसका मतलब है कि अगर सूची का पहला पाथ किसी खाली फ़ील्ड पर ले जाता है, तो अगले पाथ का आकलन किया जाता है. फ़ॉलबैक लॉजिक, मुख्य तौर पर टेक्स्ट वाले स्ट्रक्चर्ड डेटा फ़ील्ड या टेक्स्ट मॉड्यूल फ़ील्ड पर टारगेट किया जाता है. एक ही सूची में अलग-अलग तरह के फ़ील्ड शामिल न करें. फ़ॉलबैक लॉजिक का इस्तेमाल सावधानी से करें. साथ ही, ऐसा सिर्फ़ कुछ खास मामलों में करें, जब आप उन फ़ील्ड का एक जैसा पैटर्न रखें जो कुछ ऑब्जेक्ट में मौजूद हैं, लेकिन दूसरे ऑब्जेक्ट में नहीं. ज़्यादातर मामलों में, इस्तेमाल के अलग-अलग उदाहरणों के लिए अलग-अलग क्लास बनाना आसान होता है.

अगर किसी फ़ील्ड की रेफ़रंस सूची में मौजूद सभी पाथ, खाली फ़ील्ड में बदल जाते हैं, तो फ़ील्ड रेफ़रंस का इस्तेमाल करने वाला आइटम नहीं दिखता है. अगर आप चाहते हैं कि फ़ील्ड रेफ़रंस का इस्तेमाल करने वाला आइटम हमेशा मौजूद हो, तो पक्का करें कि कम से कम एक पाथ खाली न हो. हमारा सुझाव है कि आप खाली वैल्यू दिखाने के लिए, फ़ील्ड को किसी खास वर्ण, जैसे कि '-' पर सेट करें. भले ही, कुछ फ़ील्ड, स्ट्रिंग में सिर्फ़ स्पेस की अनुमति देते हों.

सूची में शामिल किसी फ़ील्ड को रेफ़र करने के लिए, आप सूची में फ़ील्ड के इंडेक्स का इस्तेमाल कर सकते हैं. ज़्यादातर मामलों में, आप रेफ़रंस आईडी का इस्तेमाल कर सकते हैं. सूची में मौजूद ऐसे आइटम के बारे में .id के बारे में बताया जा सकता है जिनका आईडी बताया जा सकता है. हमारा सुझाव है कि आप सूची में मौजूद फ़ील्ड के इंडेक्स पर रेफ़रंस आईडी का इस्तेमाल करें.

यहां उदाहरण के तौर पर, सूची में शामिल फ़ील्ड का रेफ़रंस देने का तरीका बताया गया है.

  • object.imageModulesData[0].id = my-first-id
  • object.imageModulesData[1].id = my-second-id
  • class.detailsTemplateOverride.detailsItemInfos[0].item.firstValue.fields[0].fieldPath = object.imageModulesData[‘my-second-id’]
  • class.detailsTemplateOverride.detailsItemInfos[1].item.firstValue.fields[0].fieldPath = object.imageModulesData[0]

ऐसे में, पास के ब्यौरे वाले सेक्शन में पहला आइटम, ऑब्जेक्ट में बताई गई दूसरी इमेज होगा. पास के ब्यौरे वाले सेक्शन में दूसरा आइटम, ऑब्जेक्ट में बताया गया पहला इमेज है.

डिफ़ॉल्ट टेंप्लेट

Android

डिफ़ॉल्ट टेंप्लेट एलिमेंट
  1. class.programLogo
  2. class.localizedIssuerName
    या class.issuerName
  3. class.localizedProgramName
    या class.programName
  4. पॉइंट
    या object.loyaltyPoints.localizedLabel
    या object.loyaltyPoints.label
  5. object.loyaltyPoints.balance
  6. इनाम
    या object.secondaryLoyaltyPoints.localizedLabel
    या object.secondaryLoyaltyPoints.label
  7. object.secondaryLoyaltyPoints.balance
  8. object.barcode.type और object.barcode.value
    या object.accountId
  9. object.barcode.alternateText
    या object.accountId
    या object.barcode.value
  10. object.heroImage
    या class.heroImage
  11. class.hexBackgroundColor
  12. सदस्य का नाम
    या class.localizedAccountNameLabel
    या class.accountNameLabel
  13. object.accountName
  14. सदस्य आईडी
    या class.localizedAccountIdLabel
    या class.accountIdLabel
  15. object.accountId
  16. टियर
    या class.localizedRewardsTierLabel
    या class.rewardsTierLabel
  17. class.localizedRewardsTier
    या class.rewardsTier
  18. दूसरे इनाम का टियर
    या class.localizedSecondaryRewardsTierLabel
    या class.secondaryRewardsTierLabel
  19. class.localizedSecondaryRewardsTier
    या class.secondaryRewardsTier
  20. class.imageModulesData[0].mainImage
  21. object.imageModulesData[0].mainImage
  22. class.messages[].header
  23. class.messages[].body
  24. object.messages[].header
  25. object.messages[].body
  26. class.textModulesData[0..9].header
  27. class.textModulesData[0..9].body
  28. object.textModulesData[0..9].header
  29. object.textModulesData[0..9].body
  30. class.linksModuleData.uris[].description
  31. object.linksModuleData.uris[].description
  32. class.homepageUri

वेब

डिफ़ॉल्ट टेंप्लेट एलिमेंट
  1. class.programLogo
  2. class.localizedIssuerName
    या class.issuerName
  3. class.localizedProgramName
    या class.programName
  4. पॉइंट
    या object.loyaltyPoints.localizedLabel
    या object.loyaltyPoints.label
  5. object.loyaltyPoints.balance
  6. इनाम
    या object.secondaryLoyaltyPoints.localizedLabel
    या object.secondaryLoyaltyPoints.label
  7. object.secondaryLoyaltyPoints.balance
  8. object.barcode.type और object.barcode.value
    या object.accountId
  9. object.barcode.alternateText
    या object.accountId
    या object.barcode.value
  10. object.heroImage
    या class.heroImage
  11. class.hexBackgroundColor
  12. सदस्य का नाम
    या class.localizedAccountNameLabel
    या class.accountNameLabel
  13. object.accountName
  14. सदस्य आईडी
    या class.localizedAccountIdLabel
    या class.accountIdLabel
  15. object.accountId
  16. टियर
    या class.localizedRewardsTierLabel
    या class.rewardsTierLabel
  17. class.localizedRewardsTier
    या class.rewardsTier
  18. दूसरे इनाम का टियर
    या class.localizedSecondaryRewardsTierLabel
    या class.secondaryRewardsTierLabel
  19. class.localizedSecondaryRewardsTier
    या class.secondaryRewardsTier
  20. class.imageModulesData[0].mainImage
  21. object.imageModulesData[0].mainImage
  22. class.messages[].header
  23. class.messages[].body
  24. object.messages[].header
  25. object.messages[].body
  26. class.textModulesData[0..9].header
  27. class.textModulesData[0..9].body
  28. object.textModulesData[0..9].header
  29. object.textModulesData[0..9].body
  30. class.linksModuleData.uris[].description
  31. object.linksModuleData.uris[].description
  32. class.homepageUri

इमेज मॉड्यूल फ़ील्ड के लिए, हम क्लास से एक और सिर्फ़ एक इमेज मॉड्यूल फ़ील्ड दिखाते हैं. साथ ही, ऑब्जेक्ट से सिर्फ़ एक इमेज मॉड्यूल फ़ील्ड दिखाते हैं. अगर आपको किसी भी लेवल पर इमेज मॉड्यूल के एक से ज़्यादा फ़ील्ड की ज़रूरत है, तो डिफ़ॉल्ट टेंप्लेट को बदलें.

टेक्स्ट मॉड्यूल फ़ील्ड के लिए, हम क्लास से ज़्यादा से ज़्यादा 10 टेक्स्ट मॉड्यूल फ़ील्ड और ऑब्जेक्ट से 10 टेक्स्ट मॉड्यूल फ़ील्ड दिखाते हैं. फ़ील्ड उसी क्रम में दिखाए जाते हैं जिस क्रम में वे श्रेणी में तय किए जाते हैं. अगर आपको किसी भी लेवल पर 10 से ज़्यादा टेक्स्ट मॉड्यूल फ़ील्ड की ज़रूरत है, तो डिफ़ॉल्ट टेंप्लेट बदलें.

मैसेज के लिए, हम क्लास से ज़्यादा से ज़्यादा 10 मैसेज और ऑब्जेक्ट से 10 मैसेज दिखाते हैं. हम मैसेज के क्रम की गारंटी नहीं देते हैं. अगर आपको किसी भी लेवल पर 10 से ज़्यादा मैसेज की ज़रूरत हो या किसी ऑर्डर के लिए गारंटी दी गई हो, तो डिफ़ॉल्ट टेंप्लेट को बदलें.

लिंक मॉड्यूल फ़ील्ड के लिए, आप ज़्यादा यूआरआई की संख्या तय नहीं कर सकते. हर लेवल (क्लास या ऑब्जेक्ट) के लिए, यूआरआई को इस क्रम में बांटा जाता है:

  1. मैप निर्देशांक
  2. टेलीफ़ोन नंबर
  3. ईमेल पते
  4. वेब पेज

हर ग्रुप के लिए, यूआरआई उसी क्रम में दिखाए जाते हैं जिस क्रम में वे अरे में बताए जाते हैं. अगर आपको किसी दूसरे ऑर्डर की ज़रूरत है, तो डिफ़ॉल्ट टेंप्लेट को बदलें.

सूची के डिफ़ॉल्ट टेंप्लेट के एलिमेंट
  1. class.localizedIssuerName
    या class.issuerName
  2. class.localizedProgramName
    या class.programName
  3. class.programLogo
  4. class.hexBackgroundColor