เมนูที่กำหนดเองสำหรับส่วนเสริมเครื่องมือแก้ไข

ส่วนเสริมของเอดิเตอร์ที่เผยแพร่แล้ว จะสร้างรายการในเมนูที่กำหนดเองได้ในเมนูส่วนขยายของเอดิเตอร์ แทรก เมนูส่วนเสริมโดยใช้ 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();
}