วิดเจ็ต

วิดเจ็ตคือองค์ประกอบ UI ที่มีฟังก์ชันต่อไปนี้อย่างน้อย 1 อย่าง

  • โครงสร้างสำหรับวิดเจ็ตอื่นๆ เช่น การ์ดและส่วนต่างๆ
  • ข้อมูลแก่ผู้ใช้ เช่น ข้อความและรูปภาพ หรือ
  • ความสามารถในการดำเนินการ เช่น ปุ่ม ช่องป้อนข้อความ หรือช่องทำเครื่องหมาย

ชุดวิดเจ็ตที่เพิ่มลงในส่วนการ์ดจะกำหนด UI โดยรวมของ ส่วนเสริม วิดเจ็ตมีลักษณะและฟังก์ชันเหมือนกันทั้งบนเว็บและอุปกรณ์เคลื่อนที่ เอกสารอ้างอิง อธิบายวิธีการสร้างชุดวิดเจ็ตหลายวิธี

ประเภทวิดเจ็ต

โดยทั่วไปแล้ว วิดเจ็ตส่วนเสริมจะแบ่งออกเป็น 3 กลุ่ม ได้แก่ วิดเจ็ตโครงสร้าง วิดเจ็ตข้อมูล และวิดเจ็ตการโต้ตอบของผู้ใช้

วิดเจ็ตโครงสร้าง

วิดเจ็ตโครงสร้างมีคอนเทนเนอร์และการจัดระเบียบสำหรับวิดเจ็ตอื่นๆ ที่ใช้ใน UI

  • ชุดปุ่ม: กลุ่มปุ่มข้อความหรือปุ่มรูปภาพตั้งแต่ 1 ปุ่มขึ้นไปที่จัดกลุ่มไว้ด้วยกันในแถวแนวนอน
  • การ์ด: การ์ดบริบทเดียวที่มีส่วนการ์ดอย่างน้อย 1 ส่วน กำหนดวิธีที่ผู้ใช้ย้าย ระหว่างการ์ดโดยการกำหนดค่า การนำทางการ์ด
  • ส่วนหัวของการ์ด: ส่วนหัวของการ์ดที่ระบุ ส่วนหัวของการ์ดมีชื่อ คำบรรยาย และรูปภาพได้ การดำเนินการในการ์ดและ การดำเนินการสากลจะปรากฏใน ส่วนหัวของการ์ดหากมีการใช้
  • ส่วนการ์ด: กลุ่มวิดเจ็ตที่รวบรวมไว้ โดยแบ่งออกจากส่วนการ์ดอื่นๆ ด้วย เส้นแนวนอน และอาจมีส่วนหัวของส่วนก็ได้ การ์ดแต่ละใบต้องมีส่วนการ์ดอย่างน้อย 1 ส่วน คุณเพิ่มการ์ดหรือส่วนหัวของการ์ดลงในส่วนการ์ดไม่ได้

ตัวอย่างการ์ดที่แสดงวิดเจ็ตโครงสร้าง

เมื่อเพิ่มวิดเจ็ตลงในคอนเทนเนอร์ใดคอนเทนเนอร์หนึ่ง คุณจะสร้างและเพิ่มสำเนาของ วิดเจ็ตนั้น หากคุณเปลี่ยนวิดเจ็ตหลังจากเพิ่มแล้ว การเปลี่ยนแปลงจะไม่ แสดงในอินเทอร์เฟซ ตรวจสอบว่าวิดเจ็ตเสร็จสมบูรณ์แล้วก่อนเพิ่ม หากต้องการเปลี่ยนวิดเจ็ตหลังจากเพิ่มแล้ว ให้สร้างส่วนการ์ดหรือการ์ดทั้งหมดใหม่ ดูรายละเอียดเพิ่มเติมได้ที่สร้างการ์ด

นอกจากวิดเจ็ตโครงสร้างพื้นฐานเหล่านี้แล้ว คุณยังใช้บริการการ์ดในส่วนเสริมของ Google Workspace เพื่อสร้างโครงสร้างที่ซ้อนทับกับการ์ดปัจจุบันได้ด้วย ดังนี้ ส่วนท้ายแบบคงที่และการ์ดแสดงตัวอย่าง

คุณเพิ่มแถวปุ่มแบบคงที่ที่ด้านล่างของการ์ดได้ แถวนี้ จะไม่เลื่อนหรือเลื่อนตามเนื้อหาที่เหลือของการ์ด

ตัวอย่างวิดเจ็ตส่วนท้ายแบบคงที่

ข้อมูลโค้ดต่อไปนี้แสดงวิธีกำหนดส่วนท้ายแบบคงที่ตัวอย่างและเพิ่มลงในการ์ด

var fixedFooter = CardService.newFixedFooter()
    .setPrimaryButton(
        CardService.newTextButton()
            .setText("Primary")
            .setOpenLink(CardService.newOpenLink()
                .setUrl("https://www.google.com")))
    .setSecondaryButton(
        CardService.newTextButton()
            .setText("Secondary")
            .setOnClickAction(
                CardService.newAction()
                    .setFunctionName(
                        "secondaryCallback")));

var card = CardService.newCardBuilder()
    // (...)
    .setFixedFooter(fixedFooter)
    .build();

การ์ดแสดงตัวอย่าง

ตัวอย่างการแจ้งเตือนการ์ดแอบดู

เมื่อการกระทำของผู้ใช้ทริกเกอร์เนื้อหาตามบริบทใหม่ เช่น การเปิดข้อความ Gmail คุณจะแสดงเนื้อหาตามบริบทใหม่ทันที (ลักษณะการทำงานเริ่มต้น) หรือแสดงการแจ้งเตือนการ์ดแสดงตัวอย่างที่ด้านล่างของ แถบด้านข้างก็ได้ หากผู้ใช้คลิก "กลับ" เพื่อกลับไปที่หน้าแรกขณะที่ทริกเกอร์ตามบริบททํางานอยู่ การ์ดแสดงตัวอย่างจะปรากฏขึ้นเพื่อช่วยให้ผู้ใช้ค้นหาเนื้อหาตามบริบทอีกครั้ง

หากต้องการแสดงการ์ดแสดงตัวอย่างเมื่อมีเนื้อหาตามบริบทใหม่ ให้เพิ่ม .setDisplayStyle(CardService.DisplayStyle.PEEK) ลงในคลาส CardBuilder การ์ดแสดงตัวอย่างจะปรากฏก็ต่อเมื่อมีการส่งคืนออบเจ็กต์การ์ดรายการเดียวพร้อมทริกเกอร์ตามบริบทเท่านั้น ไม่เช่นนั้น การ์ดที่ส่งคืนจะแทนที่การ์ดปัจจุบัน

หากต้องการปรับแต่งส่วนหัวของการ์ดแสดงตัวอย่าง ให้เพิ่ม.setPeekCardHeaderเมธอดที่มี ออบเจ็กต์ CardHeader มาตรฐานเมื่อสร้างการ์ดตามบริบท โดยค่าเริ่มต้น ส่วนหัวของการ์ด Peek จะมีเฉพาะชื่อของส่วนเสริม ตัวอย่างการ์ดแสดงตัวอย่างที่ปรับแต่ง

จากคู่มือเริ่มใช้งานฉบับย่อของส่วนเสริม Cats สำหรับ Google Workspace โค้ดต่อไปนี้จะแจ้งให้ผู้ใช้ทราบเกี่ยวกับเนื้อหาตามบริบทใหม่ด้วยการ์ด Peek และปรับแต่งส่วนหัวของการ์ด Peek เพื่อแสดงหัวข้อของชุดข้อความ Gmail ที่เลือก

var peekHeader = CardService.newCardHeader()
    .setTitle('Contextual Cat')
    .setImageUrl('https://www.gstatic.com/images/
        icons/material/system/1x/pets_black_48dp.png')
    .setSubtitle(text);

. . .

var card = CardService.newCardBuilder()
    .setDisplayStyle(CardService.DisplayStyle.PEEK)
    .setPeekCardHeader(peekHeader);

วิดเจ็ตข้อมูล

วิดเจ็ตข้อมูลจะแสดงข้อมูลต่อผู้ใช้

  • รูปภาพ: รูปภาพที่ระบุโดย URL ที่โฮสต์และเข้าถึงได้แบบสาธารณะ
  • DecoratedText: สตริงเนื้อหาข้อความที่คุณจับคู่กับองค์ประกอบอื่นๆ ได้ เช่น ป้ายกำกับด้านบนและด้านล่าง รวมถึงรูปภาพหรือไอคอน วิดเจ็ต DecoratedText ยังมีวิดเจ็ต Button หรือ Switch ได้ด้วย สวิตช์ที่เพิ่ม สามารถเป็นสวิตช์เปิด/ปิดหรือช่องทำเครื่องหมาย ข้อความเนื้อหา สามารถใช้การจัดรูปแบบ HTML ได้ แต่ป้ายกำกับด้านบนและด้านล่าง ต้องใช้ข้อความธรรมดา
  • ย่อหน้าข้อความ: ย่อหน้าข้อความซึ่งอาจมีองค์ประกอบที่จัดรูปแบบ HTML

ตัวอย่างวิดเจ็ตข้อมูลในการ์ด

วิดเจ็ตการโต้ตอบของผู้ใช้

วิดเจ็ตการโต้ตอบของผู้ใช้ช่วยให้ส่วนเสริมตอบสนอง ต่อการดำเนินการของผู้ใช้ได้ กำหนดค่าวิดเจ็ตเหล่านี้ด้วยการตอบกลับการดำเนินการเพื่อแสดง การ์ดต่างๆ เปิด URL แสดงการแจ้งเตือน เขียนอีเมลฉบับร่าง หรือเรียกใช้ ฟังก์ชัน Apps Script อื่นๆ ดูรายละเอียดได้ที่คำแนะนำการสร้างการ์ดแบบอินเทอร์แอกทีฟ

  • การดำเนินการกับการ์ด: รายการเมนู ที่อยู่ในเมนูแถบส่วนหัวของส่วนเสริม เมนูแถบส่วนหัวยังอาจมีรายการที่กำหนดเป็นการดำเนินการสากล ซึ่งจะปรากฏในการ์ดทุกใบ ที่ส่วนเสริมกำหนด
  • เครื่องมือเลือกวันที่และเวลา: วิดเจ็ตช่วยให้ผู้ใช้ เลือกวันที่ เวลา หรือทั้งวันที่และเวลาได้ ดูข้อมูลเพิ่มเติมได้ที่เครื่องมือเลือกวันที่และเวลา
  • ปุ่มรูปภาพ: ปุ่มที่ใช้รูปภาพแทนข้อความ ใช้ไอคอนที่กำหนดไว้ล่วงหน้าอย่างใดอย่างหนึ่ง หรือรูปภาพที่โฮสต์แบบสาธารณะ
  • อินพุตการเลือก: ช่องป้อนข้อมูลที่แสดงตัวเลือกต่างๆ วิดเจ็ตอินพุตการเลือก แสดงเป็นช่องทำเครื่องหมาย ปุ่มตัวเลือก หรือกล่องการเลือกแบบเลื่อนลง
  • สวิตช์: วิดเจ็ตสลับที่ใช้กับวิดเจ็ต DecoratedText โดยค่าเริ่มต้น รายการเหล่านี้จะแสดงเป็นสวิตช์เปิด/ปิด แต่คุณสามารถแสดงเป็น ช่องทําเครื่องหมายได้
  • ปุ่มข้อความ: ปุ่ม ที่มีป้ายกำกับข้อความ ระบุสีพื้นหลังสำหรับปุ่มข้อความ (ค่าเริ่มต้นคือโปร่งใส) นอกจากนี้ คุณยังปิดใช้ปุ่มได้ตามต้องการ
  • การป้อนข้อความ: ช่องป้อนข้อความ วิดเจ็ตมีข้อความชื่อ ข้อความคำแนะนำ และข้อความหลายบรรทัดได้ วิดเจ็ตสามารถทริกเกอร์การดำเนินการเมื่อค่าข้อความเปลี่ยนแปลง
  • ตารางกริด: เลย์เอาต์แบบหลายคอลัมน์ แสดงสินค้าด้วยรูปภาพ ชื่อ คำบรรยาย และตัวเลือกการปรับแต่ง เช่น สไตล์เส้นขอบและการครอบตัด
ตัวอย่างเมนูที่แสดงการดำเนินการกับการ์ด ตัวอย่างวิดเจ็ตการโต้ตอบของผู้ใช้ในการ์ด

DecoratedText ช่องทำเครื่องหมาย

คุณกำหนดวิดเจ็ต DecoratedText ที่มีช่องทำเครื่องหมายแนบอยู่แทนปุ่มหรือสวิตช์เปิด/ปิดแบบไบนารีได้ เช่นเดียวกับสวิตช์เปิด/ปิด ค่าของช่องทําเครื่องหมายจะรวมอยู่ใน ออบเจ็กต์เหตุการณ์การกระทํา ที่ส่งไปยัง Action ที่แนบมา กับ DecoratedText นี้ โดยเมธอด setOnClickAction

ตัวอย่างวิดเจ็ตช่องทำเครื่องหมายข้อความที่ตกแต่งแล้ว

ข้อมูลโค้ดต่อไปนี้แสดงวิธีกำหนดวิดเจ็ตช่องทำเครื่องหมาย DecoratedText เพื่อเพิ่มลงในการ์ด

var decoratedText = CardService.newDecoratedText()
    // (...)
    .setSwitch(CardService.newSwitch()
        .setFieldName('form_input_switch_key')
        .setValue('switch_is_on')
        .setControlType(
            CardService.SwitchControlType.CHECK_BOX));

เครื่องมือเลือกวันที่และเวลา

กำหนดวิดเจ็ตที่อนุญาตให้ผู้ใช้เลือกเวลา วันที่ หรือทั้ง 2 อย่าง ใช้ setOnChangeAction เพื่อกำหนดฟังก์ชันตัวแฮนเดิลวิดเจ็ตให้เรียกใช้เมื่อ ค่าของเครื่องมือเลือกมีการเปลี่ยนแปลง

ตัวอย่างการ์ดแสดงตัวอย่างที่ปรับแต่ง

ข้อมูลโค้ดต่อไปนี้แสดงวิธีกำหนดเครื่องมือเลือกวันที่เท่านั้น เครื่องมือเลือกเวลาเท่านั้น และเครื่องมือเลือกวันที่และเวลาเพื่อเพิ่มลงในการ์ด

var dateOnlyPicker = CardService.newDatePicker()
    .setTitle("Enter a date")
    .setFieldName("date_field")
    // Set default value as May 24 2019. Either a
    // number or string is acceptable.
    .setValueInMsSinceEpoch(1558668600000)
    .setOnChangeAction(CardService.newAction()
        .setFunctionName("handleDateChange"));

var timeOnlyPicker = CardService.newTimePicker()
    .setTitle("Enter a time")
    .setFieldName("time_field")
    // Set default value as 23:30.
    .setHours(23)
    .setMinutes(30)
    .setOnChangeAction(CardService.newAction()
        .setFunctionName("handleTimeChange"));

var dateTimePicker = CardService.newDateTimePicker()
    .setTitle("Enter a date and time")
    .setFieldName("date_time_field")
    // Set default value as May 24 2019 03:30 AM UTC.
    // Either a number or string is acceptable.
    .setValueInMsSinceEpoch(1558668600000)
    // EDT time is 4 hours behind UTC.
    .setTimeZoneOffsetInMins(-4 * 60)
    .setOnChangeAction(CardService.newAction()
        .setFunctionName("handleDateTimeChange"));

ต่อไปนี้เป็นตัวอย่างฟังก์ชันตัวแฮนเดิลวิดเจ็ตเครื่องมือเลือกวันที่และเวลา ตัวแฮนเดิลนี้จะจัดรูปแบบและบันทึกสตริงที่แสดงวันที่และเวลาที่ผู้ใช้เลือกในวิดเจ็ตเครื่องมือเลือกวันที่และเวลาที่มีรหัส myDateTimePickerWidgetID:

function handleDateTimeChange(event) {
  var dateTimeInput =
    event.commonEventObject.formInputs["myDateTimePickerWidgetID"];
  var msSinceEpoch = dateTimeInput.msSinceEpoch;
  var hasDate = dateTimeInput.hasDate;
  var hasTime = dateTimeInput.hadTime;

  // The following requires you to configure the add-on to read user locale
  // and timezone.
  // See:
  // https://developers.google.com/workspace/add-ons/how-tos/access-user-locale
  var userTimezoneId = event.userTimezone.id;

  // Format and log the date-time selected using the user's timezone.
  var formattedDateTime;
  if (hasDate && hasTime) {
    formattedDateTime = Utilities.formatDate(
      new Date(msSinceEpoch), userTimezoneId, "yyy/MM/dd hh:mm:ss");
  } else if (hasDate) {
    formattedDateTime = Utilities.formatDate(
      new Date(msSinceEpoch), userTimezoneId, "yyy/MM/dd")
      + ", Time unspecified";
  } else if (hasTime) {
    formattedDateTime = "Date unspecified, "
      + Utilities.formatDate(
          new Date(msSinceEpoch), userTimezoneId, "hh:mm a");
  }

  if (formattedDateTime) {
    console.log(formattedDateTime);
  }
}

 

ตารางต่อไปนี้แสดงตัวอย่าง UI การเลือกตัวเลือกในเดสก์ท็อปและ อุปกรณ์เคลื่อนที่ เมื่อเลือกแล้ว เครื่องมือเลือกวันที่จะเปิด UI ปฏิทินแบบรายเดือน เพื่อให้ผู้ใช้เลือกวันที่ใหม่ได้

เมื่อผู้ใช้เลือกเครื่องมือเลือกเวลาในอุปกรณ์เดสก์ท็อป เมนูแบบเลื่อนลงจะเปิดขึ้นพร้อมรายการเวลาที่คั่นด้วยช่วงเวลา 30 นาที ผู้ใช้ยัง พิมพ์เวลาที่ต้องการได้ด้วย ในอุปกรณ์เคลื่อนที่ การเลือกเครื่องมือเลือกเวลาจะเปิดเครื่องมือเลือกเวลา "นาฬิกา" ในตัวของอุปกรณ์เคลื่อนที่

เดสก์ท็อป มือถือ
ตัวอย่างการเลือกเครื่องมือเลือกวันที่ ตัวอย่างการเลือกเครื่องมือเลือกวันที่บนอุปกรณ์เคลื่อนที่
ตัวอย่างการเลือกเครื่องมือเลือกเวลา ตัวอย่างการเลือกเครื่องมือเลือกเวลาบนอุปกรณ์เคลื่อนที่

GRid

แสดงรายการในเลย์เอาต์หลายคอลัมน์ด้วยวิดเจ็ตตารางกริด แต่ละรายการสามารถ แสดงรูปภาพ ชื่อ และคำบรรยายแทนเสียงได้ ใช้ตัวเลือกการกำหนดค่าเพิ่มเติมเพื่อ ตั้งค่าตำแหน่งของข้อความที่สัมพันธ์กับรูปภาพในรายการตารางกริด

กําหนดค่ารายการตารางกริดด้วยตัวระบุที่ส่งคืนเป็นพารามิเตอร์ไปยัง การกระทําที่กําหนดในตารางกริด

ตัวอย่างวิดเจ็ตตารางกริดที่แสดงข้อมูลติดต่อ

var gridItem = CardService.newGridItem()
  .setIdentifier("item_001")
  .setTitle("Lucian R.")
  .setSubtitle("Chief Information Officer")
  .setImage(imageComponent);

var cropStyle = CardService.newImageCropStyle()
  .setImageCropType(CardService.ImageCropType.RECTANGLE_4_3);

var imageComponent = CardService.newImageComponent()
  .setImageUrl("https://developers.google.com/workspace/
      images/cymbal/people/person1.jpeg")
  .setCropStyle(cropStyle)

var grid = CardService.newGrid()
  .setTitle("Recently viewed")
  .addItem(gridItem)
  .setNumColumns(2)
  .setOnClickAction(CardService.newAction()
    .setFunctionName("handleGridItemClick"));

การจัดรูปแบบข้อความ

วิดเจ็ตแบบข้อความบางรายการรองรับการจัดรูปแบบ HTML ของข้อความพื้นฐาน เมื่อตั้งค่า เนื้อหาข้อความของวิดเจ็ตเหล่านี้ ให้ใส่แท็ก HTML ที่เกี่ยวข้อง

แท็กที่รองรับและวัตถุประสงค์ของแท็กแสดงอยู่ในตารางต่อไปนี้

รูปแบบ ตัวอย่าง ผลลัพธ์ที่แสดง
ตัวหนา "This is <b>bold</b>." ข้อความนี้คือตัวหนา
ตัวเอียง "This is <i>italics</i>." นี่คือตัวเอียง
ขีดเส้นใต้ "This is <u>underline</u>." นี่คือขีดเส้นใต้
ขีดทับ "This is <s>strikethrough</s>." นี่คือขีดทับ
สีแบบอักษร "This is <font color=\"#FF0000\">red font</font>." นี่คือแบบอักษรสีแดง
ไฮเปอร์ลิงก์ "This is a <a href=\"https://www.google.com\">hyperlink</a>." นี่คือไฮเปอร์ลิงก์
เวลา "This is a time format: <time>2023-02-16 15:00</time>." รูปแบบเวลาคือ
บรรทัดใหม่ "This is the first line. <br> This is a new line." นี่คือบรรทัดแรก
นี่คือบรรทัดใหม่