Google Apps Script memungkinkan Anda membuat dan mengubah Google Dokumen secara terprogram, serta menyesuaikan antarmuka pengguna dengan menu, kotak dialog, dan sidebar baru.
Dasar-dasar
Apps Script dapat berinteraksi dengan Google Dokumen dengan dua cara umum: skrip apa pun dapat membuat atau mengubah dokumen jika pengguna skrip memiliki izin yang sesuai untuk dokumen, dan skrip juga dapat diikat ke dokumen, yang memberi skrip kemampuan khusus untuk mengubah antarmuka pengguna atau merespons saat dokumen dibuka. Untuk membuat skrip yang terikat penampung dari dalam Google Dokumen, klik Ekstensi > Apps Script.
Dalam kedua kasus tersebut, Anda dapat berinteraksi dengan dokumen Google Dokumen dengan mudah melalui Layanan Dokumen Apps Script, seperti yang ditunjukkan pada contoh berikut.
function createDoc() { var doc = DocumentApp.create('Sample Document'); var documentTab = doc.getTab('t.0').asDocumentTab(); var body = documentTab.getBody(); var rowsData = [['Plants', 'Animals'], ['Ficus', 'Goat'], ['Basil', 'Cat'], ['Moss', 'Frog']]; body.insertParagraph(0, doc.getName()) .setHeading(DocumentApp.ParagraphHeading.HEADING1); table = body.appendTable(rowsData); table.getRow(0).editAsText().setBold(true); }
Skrip di atas membuat dokumen baru di Google Drive pengguna, lalu mengambil tab dengan ID t.0
(tab pertama default), menyisipkan paragraf yang berisi teks yang sama dengan nama dokumen, menata gaya paragraf tersebut sebagai judul, dan menambahkan tabel berdasarkan nilai dalam array dua dimensi. Skrip ini juga dapat dengan mudah membuat perubahan ini pada dokumen yang ada dengan mengganti panggilan ke DocumentApp.create()
dengan DocumentApp.openById()
atau openByUrl()
.
Untuk skrip yang dibuat di dalam dokumen (terikat penampung), gunakan
DocumentApp.getActiveDocument()
dan Document.getActiveTab()
.
Struktur dokumen
Dari perspektif Apps Script, dokumen Google Dokumen disusun
seperti dokumen HTML—yaitu, dokumen terdiri dari satu atau beberapa
objek Tab
, yang masing-masing berisi
elemen (seperti Paragraph
atau
Table
) yang sering kali berisi elemen
lain. Sebagian besar skrip yang mengubah dokumen Google Dokumen dimulai dengan panggilan ke
getTab()
dan
asDocumentTab()
,
diikuti dengan getBody()
,
karena Body
adalah elemen inti
yang berisi semua elemen lain dalam tab, kecuali untuk
HeaderSection
,
FooterSection
, dan
Footnotes
.
Namun, ada aturan tentang jenis elemen yang dapat berisi jenis elemen lainnya. Selain itu, Layanan Dokumen di Apps Script hanya dapat menyisipkan jenis elemen tertentu ke dalam elemen lain. Hierarki di bawah menunjukkan elemen yang dapat dimuat oleh jenis elemen tertentu.
Elemen yang ditampilkan dalam cetak tebal dapat disisipkan; elemen yang tidak cetak tebal hanya dapat dimanipulasi di tempat.
- Dokumen
- Tab
- DocumentTab
- Body
- HeaderSection
- ListItem
- HorizontalRule
- InlineDrawing
- InlineImage
- Teks
- UnsupportedElement (nomor halaman, dll.)
- Paragraf
- HorizontalRule
- InlineDrawing
- InlineImage
- Teks
- UnsupportedElement (nomor halaman, dll.)
- Tabel
- ListItem
- FooterSection
- ListItem
- HorizontalRule
- InlineDrawing
- InlineImage
- Teks
- UnsupportedElement (nomor halaman, dll.)
- Paragraf
- HorizontalRule
- InlineDrawing
- InlineImage
- Teks
- UnsupportedElement (nomor halaman, dll.)
- Tabel
- ListItem
- FootnoteSection
- DocumentTab
- Tab
Mengganti teks
Apps Script sering digunakan untuk mengganti teks di Google Dokumen. Misalnya, Anda memiliki spreadsheet yang berisi informasi klien dan ingin membuat Google Dokumen yang dipersonalisasi untuk setiap klien. (Jenis operasi ini sering disebut penggabungan email.)
Ada banyak cara untuk mengganti teks, tetapi cara yang paling mudah adalah
metode replaceText()
yang ditunjukkan dalam contoh di bawah. replaceText
mendukung sebagian besar
fitur ekspresi reguler JavaScript. Fungsi pertama di bawah ini
menambahkan beberapa baris teks placeholder ke Google Dokumen; di dunia nyata, Anda
akan lebih cenderung mengetik placeholder ke dalam dokumen sendiri. Fungsi
kedua mengganti placeholder dengan properti yang ditentukan dalam
objek client
.
Perhatikan bahwa kedua fungsi ini menggunakan metode
getActiveDocument()
dan
getActiveTab()
,
yang hanya berlaku untuk skrip yang dibuat di dalam dokumen Google Dokumen;
dalam skrip mandiri, gunakan
DocumentApp.create()
,
openById()
,
atau openByUrl()
,
yang digabungkan dengan Document.getTab()
.
function createPlaceholders() { var body = DocumentApp.getActiveDocument().getActiveTab().asDocumentTab().getBody(); body.appendParagraph('{name}'); body.appendParagraph('{address}'); body.appendParagraph('{city} {state} {zip}'); }
function searchAndReplace() { var body = DocumentApp.getActiveDocument().getActiveTab().asDocumentTab().getBody(); var client = { name: 'Joe Script-Guru', address: '100 Script Rd', city: 'Scriptville', state: 'GA', zip: 94043 }; body.replaceText('{name}', client.name); body.replaceText('{address}', client.address); body.replaceText('{city}', client.city); body.replaceText('{state}', client.state); body.replaceText('{zip}', client.zip); }
Menu dan antarmuka pengguna kustom
Anda dapat menyesuaikan Google Dokumen dengan menambahkan menu, kotak dialog, dan sidebar. Namun, perlu diingat bahwa skrip hanya dapat berinteraksi dengan UI untuk instance dokumen terbuka saat ini, dan hanya jika skrip tersebut terikat dengan dokumen.
Lihat cara menambahkan menu kustom dan dialog ke Google Dokumen. Untuk mempelajari lebih lanjut cara membuat antarmuka kustom untuk dialog atau sidebar, lihat panduan Layanan HTML. Jika Anda berencana memublikasikan antarmuka kustom sebagai bagian dari add-on, ikuti panduan gaya untuk konsistensi dengan gaya dan tata letak editor Google Dokumen.
Add-on untuk Google Dokumen
Add-on berjalan di dalam Google Dokumen dan dapat diinstal dari add-on store Google Dokumen. Jika Anda telah mengembangkan skrip untuk Google Dokumen dan ingin membagikannya kepada semua orang, Apps Script memungkinkan Anda memublikasikan skrip sebagai add-on sehingga pengguna lain dapat menginstalnya dari add-on store.
Untuk melihat cara membuat add-on untuk Google Dokumen, lihat panduan memulai untuk mem-build add-on Dokumen.
Pemicu
Skrip yang terikat ke Google Dokumen dapat menggunakan pemicu sederhana untuk merespons peristiwa onOpen
dokumen, yang terjadi setiap kali pengguna yang memiliki akses edit ke dokumen membukanya di Google Dokumen.
Untuk menyiapkan pemicu, cukup tulis fungsi yang disebut onOpen()
. Untuk contoh
pemicu ini, lihat Menu kustom di Google Workspace.
Meskipun pemicu sederhana berguna untuk menambahkan menu, pemicu ini tidak dapat menggunakan layanan Apps Script yang memerlukan otorisasi.