ส่วนเสริมของเอดิเตอร์ที่เผยแพร่แล้ว
จะสร้างรายการในเมนูที่กำหนดเองได้ในเมนูส่วนขยายของเอดิเตอร์ แทรก
เมนูส่วนเสริมโดยใช้ Ui.createAddonMenu และเพิ่มรายการลงใน
เมนูด้วย Menu.addItem โดยปกติแล้วเมนูจะสร้างขึ้นในonOpenเมธอดของส่วนเสริม
สร้างเมนูแบบไดนามิกที่จะเปลี่ยนไปตามการโต้ตอบของผู้ใช้หรือสถานะของส่วนเสริม อย่างไรก็ตาม ส่วนเสริมต้อง
สร้างเมนูเริ่มต้นก่อนที่ผู้ใช้จะให้สิทธิ์
ส่วนเสริม ด้วยเหตุนี้ โปรดตรวจสอบโหมดการให้สิทธิ์ของส่วนเสริม
ก่อนสร้างเมนูใน onOpen อย่าดำเนินการใดๆ ที่ต้องมีการให้สิทธิ์ (เช่น การตรวจสอบสคริปต์ Properties) ขณะที่ส่วนเสริมอยู่ในสถานะScriptApp.AuthMode.NONE ดูรายละเอียดเพิ่มเติมเกี่ยวกับโหมดการให้สิทธิ์และวงจรการใช้งานได้ที่
วงจรการใช้งานการให้สิทธิ์
การพยายามดำเนินการที่ต้องมีการให้สิทธิ์เมื่อโหมดการให้สิทธิ์เป็น ScriptApp.AuthMode.NONE จะทำให้เกิดข้อผิดพลาด การดำเนินการนี้อาจทำให้เมนูส่วนเสริมไม่แสดง
ตัวอย่างต่อไปนี้แสดงวิธีสร้างเมนูส่วนเสริมแบบไดนามิก สำหรับโหมดการให้สิทธิ์ต่างๆ
function onOpen(e) {
// Or DocumentApp, SlidesApp, or FormApp.
var menu = SpreadsheetApp.getUi().createAddonMenu();
if (e && e.authMode == ScriptApp.AuthMode.NONE) {
// Add a normal menu item (works in all authorization modes).
menu.addItem('Start workflow', 'startWorkflow');
} else {
// Add a menu item based on properties (doesn't work in AuthMode.NONE).
var properties = PropertiesService.getDocumentProperties();
var workflowStarted = properties.getProperty('workflowStarted');
if (workflowStarted) {
menu.addItem('Check workflow status', 'checkWorkflow');
} else {
menu.addItem('Start workflow', 'startWorkflow');
}
// Record analytics.
UrlFetchApp.fetch('http://www.example.com/analytics?event=open');
}
menu.addToUi();
}