এই নির্দেশিকাটি সাধারণ কার্ড -সম্পর্কিত ত্রুটিগুলি বর্ণনা করে যা আপনি সম্মুখীন হতে পারেন এবং কীভাবে সেগুলি ঠিক করবেন৷
চ্যাট অ্যাপের জন্য মেসেজিং এবং ইউজার ইন্টারফেস ডিজাইন ও প্রিভিউ করতে কার্ড বিল্ডার ব্যবহার করুন:
কার্ড বিল্ডার খুলুনকার্ডের ত্রুটিগুলি কীভাবে প্রদর্শিত হয়
কার্ডের ত্রুটি বিভিন্ন উপায়ে প্রকাশ পায়:
- একটি কার্ডের অংশ, যেমন একটি উইজেট বা উপাদান, অপ্রত্যাশিত উপায়ে প্রদর্শিত বা রেন্ডার হয় না।
- পুরো কার্ডটি দেখা যাচ্ছে না।
- একটি ডায়ালগ বন্ধ হয়, খোলা হয় না বা লোড হয় না।
আপনি যদি এই ধরনের আচরণের সম্মুখীন হন, তাহলে এর মানে হল আপনার অ্যাপের কার্ডে একটি ত্রুটি আছে।
রেফারেন্সের জন্য: একটি কার্যকরী, ত্রুটি-মুক্ত কার্ড বার্তা এবং ডায়ালগ
ভুল কার্ডের উদাহরণগুলি পরীক্ষা করার আগে, প্রথমে এই কার্যকরী কার্ড বার্তা এবং ডায়ালগটি বিবেচনা করুন। প্রতিটি উদাহরণের ত্রুটি এবং তার সমাধানকে বোঝাতে, এই কার্ডের JSON ত্রুটিগুলি প্রবর্তন করে সংশোধন করা হয়েছে৷
একটি ত্রুটি-মুক্ত কার্ড বার্তা
এখানে কর্মক্ষম, ত্রুটি-মুক্ত কার্ড বার্তাটি যোগাযোগের তথ্যের বিশদ বিবরণ যা একটি শিরোনাম, বিভাগ এবং উইজেট যেমন সজ্জিত পাঠ্য এবং বোতামগুলি বৈশিষ্ট্যযুক্ত:
একটি ত্রুটি-মুক্ত ডায়ালগ
এখানে একটি কার্যকরী, ত্রুটি-মুক্ত ডায়ালগ রয়েছে যা ব্যবহারকারীদের কাছ থেকে তথ্য সংগ্রহ করে একটি পরিচিতি তৈরি করে, একটি ফুটার বৈশিষ্ট্যযুক্ত, এবং পাঠ্য ইনপুট এবং সুইচ এবং বোতামগুলির মতো সম্পাদনাযোগ্য উইজেট:
ত্রুটি: একটি কার্ডের অংশ দেখা যাচ্ছে না
কখনও কখনও কার্ড রেন্ডার হয়, কিন্তু একটি কার্ডের অংশ যা আপনি দেখতে আশা করেছিলেন তা প্রদর্শিত হয় না; সম্ভাব্য কারণগুলি হল:
- একটি প্রয়োজনীয় JSON ক্ষেত্র অনুপস্থিত।
- একটি JSON ক্ষেত্র ভুল বানান বা ভুলভাবে বড় করা হয়েছে।
কারণ: একটি প্রয়োজনীয় JSON ক্ষেত্র অনুপস্থিত
এই উদাহরণের ত্রুটিতে, একটি প্রয়োজনীয় JSON ক্ষেত্র, title
, অনুপস্থিত। ফলস্বরূপ, কার্ড রেন্ডার হয়, কিন্তু কার্ডের কিছু অংশ যা প্রদর্শিত হবে বলে আশা করা হচ্ছে না। প্রয়োজনীয় ক্ষেত্রগুলি বাদ দিলে কার্ডগুলি কীভাবে রেন্ডার হয় তা অনুমান করা কঠিন হতে পারে।
এই ত্রুটি ঠিক করতে, প্রয়োজনীয় JSON ক্ষেত্র যোগ করুন; এই উদাহরণে, title
।
একটি JSON ক্ষেত্র প্রয়োজন কিনা তা জানতে, কার্ড v2 রেফারেন্স ডকুমেন্টেশন দেখুন। এই উদাহরণে, CardHeader
title
ক্ষেত্রের বিবরণ পড়ুন।
এখানে দুটি উদাহরণ আছে:
উদাহরণ 1: subtitle
নির্দিষ্ট করা কিন্তু প্রয়োজনীয় title
বাদ দিলে পুরো শিরোনামটি ফাঁকা দেখায়:
ভুল কার্ড JSON স্নিপেট দেখুন
ত্রুটি: একটি প্রয়োজনীয় ক্ষেত্র, title
, header
থেকে অনুপস্থিত।
. . . "header": { "subtitle": "Software Engineer" } . . .
সঠিক কার্ড JSON স্নিপেট দেখুন
স্থির: প্রয়োজনীয় ক্ষেত্র, title
, header
স্পেসিফিকেশনের অংশ।
. . . "header": { "title": "Sasha", "subtitle": "Software Engineer" } . . .
উদাহরণ 2: subtitle
, imageUrl
, imageType
, এবং imageAltText
উল্লেখ করা কিন্তু প্রয়োজনীয় title
বাদ দিলে ছবিটি প্রত্যাশিতভাবে রেন্ডার হয়, কিন্তু সাবটাইটেল নয়:
ভুল কার্ড JSON স্নিপেট দেখুন
ত্রুটি: একটি প্রয়োজনীয় ক্ষেত্র, title
, header
থেকে অনুপস্থিত।
. . . "header": { "subtitle": "Software Engineer", "imageUrl": "https://developers.google.com/chat/images/quickstart-app-avatar.png", "imageType": "CIRCLE", "imageAltText": "Avatar for Sasha", } . . .
সঠিক কার্ড JSON স্নিপেট দেখুন
স্থির: প্রয়োজনীয় ক্ষেত্র, title
, header
স্পেসিফিকেশনের অংশ।
. . . "header": { "title": "Sasha", "subtitle": "Software Engineer", "imageUrl": "https://developers.google.com/chat/images/quickstart-app-avatar.png", "imageType": "CIRCLE", "imageAltText": "Avatar for Sasha", } . . .
কারণ: ভুল বানান বা বড় বড় JSON
এই উদাহরণের ত্রুটিতে, কার্ড JSON-এ সমস্ত প্রয়োজনীয় ক্ষেত্র রয়েছে, কিন্তু একটি ক্ষেত্র, imageUrl
ভুলভাবে imageURL
(ক্যাপিটাল R
ক্যাপিটাল L
) হিসাবে বড় করা হয়েছে, যা একটি ত্রুটি সৃষ্টি করে: এটি যে ছবিটি নির্দেশ করে তা রেন্ডার করে না।
এই ত্রুটিটি ঠিক করতে এবং এটির মতো অন্যদের জন্য, সঠিক JSON বিন্যাস ব্যবহার করুন৷ এই ক্ষেত্রে, imageUrl
সঠিক। সন্দেহ হলে, কার্ড রেফারেন্স নথির বিরুদ্ধে কার্ড JSON চেক করুন।
ভুল কার্ড JSON স্নিপেট দেখুন
ত্রুটি: ক্ষেত্রের imageURL
ভুলভাবে বড় করা হয়েছে। এটি imageUrl
হওয়া উচিত।
. . . "header": { "title": "Sasha", "subtitle": "Software Engineer", "imageURL": "https://developers.google.com/chat/images/quickstart-app-avatar.png", "imageType": "CIRCLE", "imageAltText": "Avatar for Sasha", } . . .
সঠিক কার্ড JSON স্নিপেট দেখুন
স্থির: ক্ষেত্রের imageUrl
সঠিকভাবে বড় করা হয়েছে।
. . . "header": { "title": "Sasha", "subtitle": "Software Engineer", "imageUrl": "https://developers.google.com/chat/images/quickstart-app-avatar.png", "imageType": "CIRCLE", "imageAltText": "Avatar for Sasha", } . . .
ত্রুটি: একটি সম্পূর্ণ কার্ড দেখা যাচ্ছে না
কখনও কখনও কার্ড নিজেই প্রদর্শিত হয় না; সম্ভাব্য কারণগুলি হল:
- একটি
ButtonList
উইজেট ভুলভাবে নির্দিষ্ট করা হয়েছে। - একটি
CardFixedFooter
উইজেটে একটি ভুলভাবে নির্দিষ্ট করা বোতাম রয়েছে৷
কারণ: ভুলভাবে নির্দিষ্ট করা buttonList
বা cardFixedFooter
যদি একটি কার্ড বার্তা বা ডায়ালগে একটি ভুলভাবে নির্দিষ্ট করা ButtonList
উইজেট বা ভুলভাবে নির্দিষ্ট করা বোতাম সহ একটি CardFixedFooter
উইজেট থাকে, তবে পুরো কার্ডটি প্রদর্শিত হয় না এবং তার জায়গায় কিছুই প্রদর্শিত হয় না। ভুল স্পেসিফিকেশনের মধ্যে অনুপস্থিত ক্ষেত্র, ভুল বানান বা বড় হাতের ক্ষেত্র, অথবা অনুপস্থিত কমা, উদ্ধৃতি, বা কোঁকড়া বন্ধনীর মতো অনুপযুক্তভাবে গঠিত JSON অন্তর্ভুক্ত থাকতে পারে।
এই ত্রুটিটি ঠিক করতে, কার্ড রেফারেন্স নথির বিপরীতে কার্ড JSON চেক করুন৷ বিশেষ করে, ButtonList
উইজেট গাইডের সাথে যেকোনো ButtonList
উইজেট তুলনা করুন।
উদাহরণ: একটি ButtonList
উইজেট গাইডে , প্রথম বোতামে একটি অসম্পূর্ণ onClick
অ্যাকশন পাস করা পুরো কার্ডটিকে রেন্ডারিং থেকে বাধা দেয়।
ভুল কার্ড JSON স্নিপেট দেখুন
ত্রুটি: onClick
অবজেক্টে কোনো ক্ষেত্র নির্দিষ্ট করা নেই, তাই পুরো কার্ডটি দেখা যাচ্ছে না।
. . . { "buttonList": { "buttons": [ { "text": "Share", "onClick": { } } }, { "text": "Edit", "onClick": { "action": { "function": "goToView", "parameters": [ { "key": "viewType", "value": "EDIT", } ], } } }, ], }, } . . .
সঠিক কার্ড JSON স্নিপেট দেখুন
স্থির: onClick
অবজেক্টে এখন একটি openLink
ক্ষেত্র রয়েছে, তাই কার্ডটি প্রত্যাশিতভাবে প্রদর্শিত হবে।
. . . { "buttonList": { "buttons": [ { "text": "Share", "onClick": { "openLink": { "url": "https://example.com/share", } } }, { "text": "Edit", "onClick": { "action": { "function": "goToView", "parameters": [ { "key": "viewType", "value": "EDIT", } ], } } }, ], }, } . . .
ত্রুটি: একটি ডায়ালগ বন্ধ, স্টল, বা খোলে না৷
যদি একটি ডায়ালগ অপ্রত্যাশিতভাবে বন্ধ হয়ে যায়, লোড হতে ব্যর্থ হয় বা না খোলে, সম্ভাব্য কারণটি তার কার্ড ইন্টারফেসের সাথে একটি সমস্যা।
এই হল সবচেয়ে সাধারণ কারণ:
-
CardFixedFooter
উইজেটের কোনোprimaryButton
নেই। -
CardFixedFooter
উইজেটের একটি বোতামের কোনোonClick
অ্যাকশন নেই, অথবা এরonClick
অ্যাকশনটি ভুলভাবে নির্দিষ্ট করা হয়েছে। - একটি
TextInput
উইজেটে একটিname
ক্ষেত্র অনুপস্থিত।
কারণ: CardFixedFooter
primaryButton
নেই
একটি CardFixedFooter
উইজেটের সাথে ডায়ালগে , পাঠ্য এবং রঙ উভয় সহ একটি primaryButton
নির্দিষ্ট করা প্রয়োজন৷ primaryButton
বাদ দেওয়া বা এটিকে ভুলভাবে সেট করা সমগ্র ডায়ালগটিকে উপস্থিত হতে বাধা দেয়।
এই ত্রুটিটি ঠিক করতে, নিশ্চিত করুন যে CardFixedFooter
উইজেটে একটি সঠিকভাবে নির্দিষ্ট primaryButton
অন্তর্ভুক্ত রয়েছে।
ভুল কার্ড JSON স্নিপেট দেখুন
ত্রুটি: fixedFooter
অবজেক্টে primaryButton
ক্ষেত্র নির্দিষ্ট করা নেই, যার ফলে ডায়ালগ লোড বা খুলতে ব্যর্থ হয়।
. . . "fixedFooter": { "onClick": { . . . }, "secondaryButton": { . . . } } } . . .
সঠিক কার্ড JSON স্নিপেট দেখুন
স্থির: fixedFooter
এখন একটি primaryButton
ক্ষেত্র নির্দিষ্ট করা আছে, তাই ডায়ালগ প্রত্যাশিতভাবে কাজ করে।
. . . "fixedFooter": { "primaryButton": { "text": "Submit", "color": { "red": 0, "blue": 1, "green": 0 }, "onClick": { . . . }, "secondaryButton": { . . . } } } . . .
কারণ: FixedFooter
ভুল onClick
সেটিং
একটি CardFixedFooter
উইজেটের সাথে সংলাপে , যেকোনো বোতামে onClick
সেটিং ভুলভাবে উল্লেখ করা, বা এটি বাদ দেওয়া, ডায়ালগটি বন্ধ, লোড হতে ব্যর্থ বা না খোলার কারণ।
এই ত্রুটিটি ঠিক করতে, নিশ্চিত করুন যে প্রতিটি বোতামে একটি সঠিকভাবে নির্দিষ্ট করা onClick
সেটিংস অন্তর্ভুক্ত রয়েছে৷
ভুল কার্ড JSON স্নিপেট দেখুন
ত্রুটি: primaryButton
অবজেক্টে একটি ভুল বানানযুক্ত `প্যারামিটারস` অ্যারে সহ একটি onClick
ক্ষেত্র রয়েছে, যার ফলে ডায়ালগ লোড বা খুলতে ব্যর্থ হয়৷
. . . "fixedFooter": { "primaryButton": { "text": "Submit", "color": { "red": 0, "blue": 1, "green": 0 }, "onClick": { "action": { "function": "setLanguageType", "parrammetters": [ { "key": "languageType", "value": "C++" } ] } } }, "secondaryButton": { "text": "Cancel", "onClick": { "action": { "function": "reset" } } } } . . .
সঠিক কার্ড JSON স্নিপেট দেখুন
স্থির: primaryButton
অবজেক্টে একটি সঠিক বানান 'প্যারামিটার' অ্যারে সহ একটি onClick
ক্ষেত্র রয়েছে, তাই ডায়ালগটি প্রত্যাশা অনুযায়ী কাজ করে।
. . . "fixedFooter": { "primaryButton": { "text": "Submit", "color": { "red": 0, "blue": 1, "green": 0 }, "onClick": { "action": { "function": "setLanguageType", "parameters": [ { "key": "languageType", "value": "C++" } ] } } }, "secondaryButton": { "text": "Cancel", "onClick": { "action": { "function": "reset" } } } } . . .
কারণ: TextInput
কোন name
নেই
যদি একটি ডায়ালগে একটি TextInput
উইজেট থাকে যা name
ক্ষেত্রটি বাদ দেয়, ডায়ালগটি প্রত্যাশিতভাবে আচরণ করে না। এটি বন্ধ হতে পারে, খুলতে পারে কিন্তু লোড করতে ব্যর্থ হতে পারে বা খুলতে পারে না।
এই ত্রুটিটি ঠিক করতে, প্রতিটি TextInput
উইজেটে একটি উপযুক্ত name
ক্ষেত্র রয়েছে তা নিশ্চিত করুন। নিশ্চিত করুন যে কার্ডের প্রতিটি name
ক্ষেত্রটি অনন্য।
ভুল কার্ড JSON স্নিপেট দেখুন
ত্রুটি: textInput
অবজেক্টের name
ক্ষেত্র নির্দিষ্ট করা নেই, যার ফলে ডায়ালগ বন্ধ হয়, লোড হতে ব্যর্থ হয় বা খুলতে ব্যর্থ হয়।
. . . { "textInput": { "label": "Name", "type": "SINGLE_LINE", } } . . .
সঠিক কার্ড JSON স্নিপেট দেখুন
স্থির: textInput
এখন একটি name
ক্ষেত্র নির্দিষ্ট করা আছে, তাই ডায়ালগটি প্রত্যাশিতভাবে কাজ করে।
. . . { "textInput": { "label": "Name", "type": "SINGLE_LINE", "name": "contactName" } } . . .
একটি অ্যাসিঙ্ক্রোনাস অ্যাপ আর্কিটেকচারের সাথে ডায়ালগ খুলুন, জমা দিন বা বাতিল করুন অ্যাকশন ব্যর্থ হয়
যদি আপনার চ্যাট অ্যাপটি ত্রুটির বার্তা দেয় তাহলে Could not load dialog. Invalid response returned by bot.
ডায়ালগগুলির সাথে কাজ করার সময়, এটি হতে পারে কারণ আপনার অ্যাপ একটি অ্যাসিঙ্ক্রোনাস আর্কিটেকচার ব্যবহার করে, যেমন Cloud Pub/Sub বা Create Message API পদ্ধতি৷
একটি ডায়ালগ খোলা, জমা দেওয়া বা বাতিল করার জন্য একটি DialogEventType
সহ একটি চ্যাট অ্যাপ থেকে একটি সিঙ্ক্রোনাস প্রতিক্রিয়া প্রয়োজন৷ তদনুসারে, ডায়ালগগুলি একটি অ্যাসিঙ্ক্রোনাস আর্কিটেকচারের সাথে নির্মিত অ্যাপ দ্বারা সমর্থিত নয়৷
একটি সমাধান হিসাবে, একটি ডায়ালগের পরিবর্তে একটি কার্ড বার্তা ব্যবহার করার কথা বিবেচনা করুন৷
অন্যান্য কার্ড এবং ডায়ালগ ত্রুটি
যদি এই পৃষ্ঠায় বর্ণিত সংশোধনগুলি আপনার অ্যাপের অভিজ্ঞতার কার্ড-সম্পর্কিত ত্রুটির সমাধান না করে তবে অ্যাপের ত্রুটি লগগুলি জিজ্ঞাসা করুন ৷ লগগুলি জিজ্ঞাসা করা কার্ড JSON বা অ্যাপ কোডে ত্রুটিগুলি খুঁজে পেতে সহায়তা করতে পারে এবং লগগুলিতে বর্ণনামূলক ত্রুটির বার্তাগুলি অন্তর্ভুক্ত থাকে যা আপনাকে সেগুলি ঠিক করতে সহায়তা করে৷
সম্পর্কিত বিষয়
Google Chat অ্যাপের ত্রুটি ঠিক করতে সাহায্যের জন্য, Google Chat অ্যাপ এবং ডিবাগ চ্যাট অ্যাপের সমস্যা সমাধান এবং ঠিক করুন দেখুন।