توضّح هذه الصفحة كيفية إعداد الأوامر والردّ عليها بصفتك مطوّر تطبيق Google Chat.
تساعد الأوامر المستخدمين في اكتشاف الميزات الرئيسية لتطبيق Chat واستخدامها. ويمكن لتطبيقات Chat فقط الاطّلاع على محتوى الأمر. على سبيل المثال، إذا أرسل مستخدم رسالة تتضمّن أمرًا يبدأ بشرطة مائلة، لن تظهر الرسالة إلا للمستخدم وتطبيق Chat.
لتحديد ما إذا كان عليك إنشاء أوامر وفهم كيفية تصميم تفاعلات المستخدم، يُرجى الاطّلاع على تحديد جميع رحلات المستخدم.
أنواع أوامر تطبيق Chat
يمكنك إنشاء أوامر تطبيق Chat كأوامر تبدأ بشرطة مائلة أو أوامر سريعة أو إجراءات للرسائل. لاستخدام كل نوع من الأوامر، يمكن للمستخدمين إجراء ما يلي:-
الأوامر التي تبدأ بشرطة مائلة: يمكن للمستخدمين اختيار أمر يبدأ بشرطة مائلة من القائمة أو كتابة شرطة مائلة (
/) ثم نص محدّد مسبقًا، مثل/about. تتطلّب تطبيقات Chat عادةً نص وسيطة للأمر الذي يبدأ بشرطة مائلة.يمكنك إنشاء أمر يبدأ بشرطة مائلة إذا كان تطبيق Chat يتطلّب إدخالات إضافية من المستخدم. على سبيل المثال، يمكنك إنشاء أمر يبدأ بشرطة مائلة باسم
/searchيتم تشغيله بعد أن يُدخِل المستخدم عبارة للبحث عنها، مثل/search receipts. -
الأوامر السريعة: يستخدم المستخدمون الأوامر من خلال فتح القائمة من قسم الردّ على رسالة في Chat. لاستخدام أمر، ينقرون على إضافة
ويختارون أمرًا من القائمة.
يمكنك إنشاء أمر سريع إذا كان تطبيق Chat يمكنه الردّ على المستخدم على الفور، بدون انتظار إدخالات إضافية. على سبيل المثال، يمكنك إنشاء أمر سريع باسم صورة عشوائية يردّ على الفور بصورة.
-
إجراءات الرسائل: ( إصدار المعاينة للمطوّرين) يستخدم المستخدمون إجراءات الرسائل من خلال تمرير مؤشر الماوس فوق رسالة والنقر على قائمة النقاط الثلاث. لاستخدام أمر، يفتحون قائمة النقاط الثلاث ويختارون أمرًا من القائمة.
يمكنك إنشاء إجراء للرسالة إذا كان تطبيق Chat يمكنه تنفيذ إجراءات استنادًا إلى سياق الرسالة.
توضّح الصور التالية كيفية عثور المستخدمين على قائمة الأوامر التي تبدأ بشرطة مائلة والأوامر السريعة وإجراءات الرسائل:
المتطلبات الأساسية
HTTP
إضافة Google Workspace توسّع نطاق Google Chat. لإنشاء إضافة، يُرجى إكمال دليل البدء السريع لـ HTTP.
برمجة التطبيقات
إضافة Google Workspace توسّع نطاق Google Chat. لإنشاء إضافة، يُرجى إكمال دليل البدء السريع لـ "برمجة التطبيقات".
إعداد الأمر
يوضّح هذا القسم كيفية إكمال الخطوات التالية لإعداد أمر:
- إنشاء اسم ووصف للأمر
- ضبط الأمر في Google Cloud Console
تسمية الأمر ووصفه
اسم الأمر هو ما يكتبه المستخدمون أو يختارونه لاستدعاء تطبيق Chat. ويظهر أيضًا وصف قصير أسفل الاسم لتشجيع المستخدمين على معرفة كيفية استخدام الأمر:
عند اختيار اسم ووصف لأمرك، يُرجى مراعاة الاقتراحات التالية:
لتسمية أمر:
- استخدِم كلمات أو عبارات قصيرة وواضحة ومحدّدة للإجراء لجعل الأوامر واضحة للمستخدم. على سبيل المثال، بدلاً من الاسم
Create a reminder، استخدِمRemind me. - ننصحك باستخدام اسم فريد أو شائع لأمرك. إذا كان أمرك يصف تفاعلاً أو ميزة نموذجية، يمكنك استخدام اسم شائع يعرفه المستخدمون ويتوقعونه، مثل
SettingsأوFeedback. بخلاف ذلك، حاوِل استخدام أسماء أوامر فريدة، لأنّه إذا كان اسم أمرك هو نفسه في تطبيقات Chat الأخرى، على المستخدم فلترة الأوامر المشابهة للعثور على أمرك واستخدامه.
لوصف أمر:
- اجعل الوصف قصيرًا وواضحًا ليعرف المستخدمون ما يمكن توقّعه عند استخدام الأمر.
- أخبِر المستخدمين إذا كانت هناك أي متطلبات تنسيق للأمر. على سبيل المثال، إذا أنشأت أمرًا يبدأ بشرطة مائلة ويتطلّب نص وسيطة، اضبط الوصف على شيء مثل
Remind me to do [something] at [time]. - أخبِر المستخدمين إذا كان تطبيق Chat يردّ على الجميع في المساحة أو
بشكل خاص على المستخدم الذي يستدعي الأمر. على سبيل المثال، بالنسبة إلى الأمر السريع
About، يمكنك وصفه على أنّهLearn about this app (Only visible to you).
ضبط الأمر في Google Cloud Console
لإنشاء أمر يبدأ بشرطة مائلة أو أمر سريع أو إجراء للرسالة، عليك تحديد معلومات عن الأمر أو الإجراء في إعدادات تطبيق Chat لواجهة Google Chat API.
لضبط أمر في Google Chat API، يُرجى إكمال الخطوات التالية:
في Google Cloud Console، انقر على "القائمة" > واجهات برمجة التطبيقات والخدمات > واجهات برمجة التطبيقات والخدمات المفعَّلة > Google Chat API
انقر على الإعداد.
ضمن إعدادات الاتصال، انتقِل إلى المشغّلات وحدِّد تفاصيل نقطة النهاية. عليك استخدام هذا المشغّل في القسم التالي للردّ على الأمر.
- عنوان URL لنقطة نهاية HTTP: يمكنك تحديد عنوان URL واحد لنقطة نهاية HTTP الشائعة هنا. بدلاً من ذلك، لاستخدام نقاط نهاية HTTP مختلفة لمشغّلات مختلفة، حدِّد نقطة النهاية مباشرةً في حقل أمر التطبيق.
- برمجة التطبيقات: أدخِل رقم تعريف عملية نشر "برمجة التطبيقات". سيتم استدعاء الدالة
onAppCommandتلقائيًا. لاستخدام دالة مختلفة في "برمجة التطبيقات"، حدِّد اسم الدالة المخصّصة في حقل أمر التطبيق.
ضمن الأوامر ، انقر على إضافة أمر.
أدخِل المعلومات التالية عن الأمر:
- رقم تعريف الأمر: رقم من 1 إلى 1000 يستخدمه تطبيق Chat للتعرّف على الأمر وعرض ردّ.
- الوصف: النص الذي يوضّح كيفية استخدام الأمر وتنسيقه. يمكن أن يصل عدد أحرف الوصف إلى 50 حرفًا.
- نوع الأمر: اختَر أمرًا سريعًا أو أمرًا يبدأ بشرطة مائلة أو إجراء للرسالة.
- حدِّد اسمًا للأمر:
- اسم الأمر السريع: الاسم المعروض الذي يختاره المستخدمون من القائمة لاستدعاء الأمر. يمكن أن يصل عدد أحرفه إلى 50 حرفًا ويتضمّن أحرفًا خاصة. على سبيل المثال،
Remind me. - اسم الأمر الذي يبدأ بشرطة مائلة: النص الذي يكتبه المستخدمون لاستدعاء الأمر في رسالة. يجب أن يبدأ بشرطة مائلة وأن يحتوي على نص فقط، ويمكن أن يصل عدد أحرفه إلى 50 حرفًا. على سبيل المثال،
/remindMe. - اسم إجراء الرسالة:
(إصدار المعاينة للمطوّرين)
الاسم المعروض الذي يختاره المستخدمون من
القائمة لاستدعاء إجراء الرسالة. يمكن أن يصل عدد أحرفه إلى 50 حرفًا ويتضمّن أحرفًا خاصة. على سبيل المثال،
Remind me.
- اسم الأمر السريع: الاسم المعروض الذي يختاره المستخدمون من القائمة لاستدعاء الأمر. يمكن أن يصل عدد أحرفه إلى 50 حرفًا ويتضمّن أحرفًا خاصة. على سبيل المثال،
اختياري: رسالة إشعار التحميل: ( إصدار المعاينة للمطوّرين) هي رسالة إشعار مؤقتة يتم عرضها للمستخدم أثناء تنفيذ إجراء الرسالة. لا تتوفّر هذه الرسالة إلا لإجراءات الرسائل التي لا تفتح مربعات حوار.
اختياري: إذا كنت تريد أن يردّ تطبيق Chat على الأمر باستخدام مربع حوار، ضَع علامة في مربّع الاختيار فتح مربع حوار.
انقر على حفظ.
تم الآن ضبط الأمر لتطبيق Chat.
الردّ على أمر
عندما يستخدم المستخدمون أمرًا، يتلقّى تطبيق Chat
عنصر حدث.
يحتوي حمولة الحدث على عنصر
appCommandPayload
يتضمّن تفاصيل عن الأمر الذي تم استدعاؤه (بما في ذلك رقم تعريف الأمر
ونوعه)، ما يتيح لك عرض ردّ مناسب.
يتم إرسال عنصر الحدث إلى نقطة نهاية HTTP أو دالة "برمجة التطبيقات"
التي حدّدتها عند ضبط مشغّل أمر التطبيق
الحدث.
/help لتوضيح كيفية الحصول على الدعم.يعرض الرمز البرمجي التالي مثالاً على تطبيق Chat يردّ على الأمر الذي يبدأ بشرطة مائلة /about باستخدام رسالة نصية. للردّ على الأوامر التي تبدأ بشرطة مائلة، يعالج تطبيق Chat عناصر الأحداث من مشغّل أمر التطبيق. عندما تحتوي حمولة عنصر الحدث على رقم تعريف أمر يبدأ بشرطة مائلة، يعرض تطبيق Chat الإجراء DataActions
مع عنصر createMessageAction:
Node.js
Python
جافا
برمجة التطبيقات
الردّ على إجراء رسالة
يعرض الرمز البرمجي التالي مثالاً على تطبيق Chat يردّ على إجراء الرسالة ذكِّرني باستخدام رسالة نصية. للردّ على إجراءات الرسائل، يعالج تطبيق Chat عناصر الأحداث من مشغّل أمر التطبيق. عندما تحتوي حمولة عنصر الحدث على
رقم تعريف أمر إجراء الرسالة، يعرض تطبيق Chat الإجراء
DataActions مع عنصر createMessageAction
object:
Node.js
/**
* Responds to an APP_COMMAND interaction event from Google Chat.
*
* @param {Object} event The interaction event from Google Chat.
* @param {Object} res The HTTP response object.
* @return {Object} The JSON response message with a confirmation.
*/
function onAppCommand(event, res) {
// Collect the command ID and type from the event metadata.
const {appCommandId, appCommandType} =
event.chat.appCommandPayload.appCommandMetadata;
if (appCommandType === 'MESSAGE_ACTION' &&
appCommandId === REMIND_ME_COMMAND_ID) {
// Message actions can access the context of the message they were
// invoked on, such as the text or sender of that message.
const messageText = event.chat.appCommandPayload.message.text;
// Return a response that includes details from the original message.
return res.json({
"hostAppDataAction": {
"chatDataAction": {
"createMessageAction": {
"message": {
"text": `Setting a reminder for message: "${messageText}"`
}
}
}
}
});
}
}
Python
def on_app_command(event):
"""Responds to an APP_COMMAND interaction event from Google Chat.
Args:
event (dict): The interaction event from Google Chat.
Returns:
dict: The JSON response message with a confirmation.
"""
# Collect the command ID and type from the event metadata.
payload = event.get('chat', {}).get('appCommandPayload', {})
metadata = payload.get('appCommandMetadata', {})
if metadata.get('appCommandType') == 'MESSAGE_ACTION' and \
metadata.get('appCommandId') == REMIND_ME_COMMAND_ID:
# Message actions can access the context of the message they were
# invoked on, such as the text or sender of that message.
message_text = payload.get('message', {}).get('text')
# Return a response that includes details from the original message.
return {
"hostAppDataAction": {
"chatDataAction": {
"createMessageAction": {
"message": {
"text": f'Setting a reminder for message: "{message_text}"'
}
}
}
}
}
جافا
/**
* Responds to an APP_COMMAND interaction event from Google Chat.
*
* @param event The interaction event from Google Chat.
* @param response The HTTP response object.
*/
void onAppCommand(JsonObject event, HttpResponse response) throws Exception {
// Collect the command ID and type from the event metadata.
JsonObject payload = event.getAsJsonObject("chat").getAsJsonObject("appCommandPayload");
JsonObject metadata = payload.getAsJsonObject("appCommandMetadata");
String appCommandType = metadata.get("appCommandType").getAsString();
if (appCommandType.equals("MESSAGE_ACTION")) {
int commandId = metadata.get("appCommandId").getAsInt();
if (commandId == REMIND_ME_COMMAND_ID) {
// Message actions can access the context of the message they were
// invoked on, such as the text or sender of that message.
String messageText = payload.getAsJsonObject("message").get("text").getAsString();
// Return a response that includes details from the original message.
JsonObject responseMessage = new JsonObject();
responseMessage.addProperty("text", "Setting a reminder for message: " + messageText);
JsonObject createMessageAction = new JsonObject();
createMessageAction.add("message", responseMessage);
JsonObject chatDataAction = new JsonObject();
chatDataAction.add("createMessageAction", createMessageAction);
JsonObject hostAppDataAction = new JsonObject();
hostAppDataAction.add("chatDataAction", chatDataAction);
JsonObject finalResponse = new JsonObject();
finalResponse.add("hostAppDataAction", hostAppDataAction);
response.getWriter().write(finalResponse.toString());
}
}
}
برمجة التطبيقات
/**
* Responds to an APP_COMMAND interaction event in Google Chat.
*
* @param {Object} event The interaction event from Google Chat.
* @return {Object} The JSON response message with a confirmation.
*/
function onAppCommand(event) {
// Collect the command ID and type from the event metadata.
const {appCommandId, appCommandType} =
event.chat.appCommandPayload.appCommandMetadata;
if (appCommandType === 'MESSAGE_ACTION' &&
appCommandId === REMIND_ME_COMMAND_ID) {
// Message actions can access the context of the message they were
// invoked on, such as the text or sender of that message.
const messageText = event.chat.appCommandPayload.message.text;
// Return a response that includes details from the original message.
return CardService.newChatResponseBuilder()
.setText("Setting a reminder for message: " + messageText)
.build();
}
}
لاستخدام عينة التعليمات البرمجية هذه، استبدِل REMIND_ME_COMMAND_ID برقم تعريف الأمر الذي حدّدته عند ضبط الأمر في Chat API.
اختبار الأمر
لاختبار الأمر والرمز البرمجي، يُرجى الاطّلاع على اختبار الميزات التفاعلية لتطبيقات Google Chat.
للتعرّف على كيفية اختبار الأمر واستخدامه في واجهة مستخدم Chat، يُرجى الاطّلاع على مقالة استخدام التطبيقات في Google Chat في مستندات مركز مساعدة Google Chat.
مواضيع ذات صلة
- عرض نماذج تطبيقات Chat التي تستخدم الأوامر
- إرسال رسالة
- فتح مربعات حوار تفاعلية