در افزونه Google Workspace میتوانید ویجتهایی ایجاد کنید که کنشهای مرتبط دارند. میتوانید از یک اقدام برای نوشتن پیشنویسهای ایمیل جدید استفاده کنید، و بهصورت اختیاری آنها را با استفاده از اطلاعات وارد شده در رابط کاربری افزونه یا اطلاعات یک پیام باز پر کنید. به عنوان مثال، میتوانید دکمهای در رابط کاربری پیام افزونه خود داشته باشید که پاسخی به پیامی که در حال حاضر باز شده است را ایجاد میکند که از قبل با اطلاعات افزونه پر شده است.
هنگامی که اقدامی که پیامها را ایجاد میکند فعال میشود، Gmail یک تابع پاسخ به تماس را برای ایجاد و برگرداندن پیشنویس اجرا میکند. سپس Gmail آن پیشنویس را در UI خود در یک پنجره استاندارد نوشتن ایمیل نمایش میدهد که کاربر میتواند آن را ویرایش و در صورت نیاز ارسال کند.
پیکربندی یک اقدام برای ایجاد یک پیام پیش نویس
برای پیکربندی یک ویجت برای شروع یک اقدام پیش نویس در هنگام انتخاب، باید موارد زیر را انجام دهید:
مطمئن شوید که مانیفست شما شامل محدوده
action.compose
باشد:https://www.googleapis.com/auth/gmail.addons.current.action.compose
به جای آن میتوانید از یک محدوده مجاز بیشتر استفاده کنید، اما فقط در صورتی باید این کار را انجام دهید که این محدوده کاملاً ضروری باشد.
یک شی
Action
ایجاد کنید و آن را با تابع callback که تعریف کرده اید مرتبط کنید.تابع کنترل ویجت
setComposeAction()
ویجت را فراخوانی کنید و شیAction
را در اختیار آن قرار دهید وComposeEmailType
را مشخص کنید.تابع callback را که عمل ایجاد پیش نویس را اجرا می کند، پیاده سازی کنید. به این تابع یک شی رویداد به عنوان آرگومان داده می شود. تابع callback باید موارد زیر را انجام دهد:
- یک شی
GmailDraft
ایجاد کنید. - یک شی
ComposeActionResponse
با استفاده از کلاسComposeActionResponseBuilder
و شیGmailDraft
بسازید. -
ComposeActionResponse
ساخته شده را برگردانید.
- یک شی
میتوانید GmailDraft
را که در عملکرد پاسخ به تماس ایجاد میکنید با گیرندگان، موضوع، متن پیام و پیوستها از قبل پر کنید. برای پر کردن پیشنویس، دادهها میتوانند از هر منبعی باشند، اما معمولاً از اطلاعات ارائهشده به خود افزونه، اطلاعات موجود در پیام باز یا اطلاعات جمعآوریشده از یک سرویس شخص ثالث به دست میآیند. شی رویداد ارسال شده به تابع پاسخ به تماس حاوی شناسه پیام باز و سایر اطلاعات افزودنی است که می توانید برای تکمیل پیش نویس استفاده کنید.
می توانید پیش نویس را به عنوان یک پیام مستقل جدید یا پاسخی به یک پیام موجود ایجاد کنید. این توسط فهرست ComposeEmailType
که به setComposeAction()
داده شده کنترل می شود. میتوانید پیشنویسهای پاسخ را بهعنوان پاسخهای تکی یا پیامهای «پاسخ به همه» ایجاد کنید.
پیش نویس های مستقل
یک پیش نویس مستقل یک رشته جدید را شروع می کند و پاسخی به هیچ پیام موجود نیست. میتوانید یک پیشنویس مستقل با یکی از عملکردهای سرویس Gmail زیر ایجاد کنید:
-
GmailApp.createDraft(recipient, subject, body)
-
GmailApp.createDraft(recipient, subject, body, options)
به پیش نویس ها پاسخ دهید
پیش نویس پاسخ بخشی از یک رشته پیام موجود است. پیشنویسهای پاسخ یا پاسخهای تکی هستند که فقط برای فرستنده پیام ارسال میشوند یا پیشنویسهای «پاسخ به همه» هستند که برای همه کسانی که آن پیام را دریافت کردهاند ارسال میشوند. می توانید با یکی از این توابع سرویس Gmail یک پیش نویس پاسخ ایجاد کنید:
-
GmailMessage.createDraftReply(body)
-
GmailMessage.createDraftReply(body, options)
-
GmailMessage.createDraftReplyAll(body)
-
GmailMessage.createDraftReplyAll(body, options)
-
GmailThread.createDraftReply(body)
-
GmailThread.createDraftReply(body, options)
-
GmailThread.createDraftReplyAll(body)
-
GmailThread.createDraftReplyAll(body, options)
مثال
قطعه کد زیر نشان می دهد که چگونه می توان اقدامی را که پیش نویس پاسخ را به یک دکمه می سازد اختصاص داد.
var composeAction = CardService.newAction()
.setFunctionName('createReplyDraft');
var composeButton = CardService.newTextButton()
.setText('Compose Reply')
.setComposeAction(
composeAction,
CardService.ComposedEmailType.REPLY_AS_DRAFT);
// ...
/**
* Creates a draft email (with an attachment and inline image)
* as a reply to an existing message.
* @param {Object} e An event object passed by the action.
* @return {ComposeActionResponse}
*/
function createReplyDraft(e) {
// Activate temporary Gmail scopes, in this case to allow
// a reply to be drafted.
var accessToken = e.gmail.accessToken;
GmailApp.setCurrentMessageAccessToken(accessToken);
// Creates a draft reply.
var messageId = e.gmail.messageId;
var message = GmailApp.getMessageById(messageId);
var draft = message.createDraftReply('',
{
htmlBody: "Kitten! <img src='cid:kitten'/>",
attachments: [
UrlFetchApp.fetch('https://example.com/images/myDog.jpg')
.getBlob()
],
inlineImages: {
"kitten": UrlFetchApp.fetch('https://example.com/images/myKitten.jpg')
.getBlob()
}
}
);
// Return a built draft response. This causes Gmail to present a
// compose window to the user, pre-filled with the content specified
// above.
return CardService.newComposeActionResponseBuilder()
.setGmailDraft(draft).build();
}