How to Write an Add-on for Google Docs

You have seen examples of some really useful add-ons for Google Docs but wouldn’t it be great if you could write your own add-on, one that adds new features to your Google Docs, one that makes you a rock star among the millions of Google Docs users.

Create a Google Add-on for Docs & Sheets

This step-by-step tutorial (download) will walk you through the process of creating your own add-on for Google Docs. The add-on used in the demo lets you insert a image of any address on Google Maps inside a Google Document without requiring any screen capture software.
Ok, lets’s get going.
Step 1. Open a new document inside Google Drive and choose Tools -> Script Editor. This is the Apps Script IDE where we’ll write the code for the add-on.
Step 2. Choose File -> New HTML to create a new HTML file inside the Script Editor and name your file as googlemaps.html (or anything you like).
Step 3. Copy-paste the following code in the HTML file and save your changes. This is the code that will be used to render the sidebar in your Google Documents.
  1. <!-- Use this CSS stylesheet to ensure that add-ons styling
  2. matches the default Google Docs styles -->
  3. <link href="https://ssl.gstatic.com/docs/script/css/add-ons.css"
  4. rel="stylesheet">
  5.  
  6. <!-- The sidebar will have a input box and the search button -->
  7. <div class="sidebar">
  8. <!-- The search box for Google Maps -->
  9. <div class="block form-group">
  10. <input type="text" id="search" placeholder="Enter address.. " />
  11. <button class="blue" id="load_maps">Search Google Maps</button>
  12. </div>
  13. <!-- The container for the Google Maps static image -->
  14. <div id='maps'></div>
  15.  
  16. </div>
  17.  
  18. <!-- Load the jQuery library from the Google CDN -->
  19. <script src="//ajax.googleapis.com/ajax/libs/jquery/1.10.1/jquery.min.js">
  20. </script>
  21.  
  22. <script>
  23. // Attach click handlers after the Sidebar has loaded in Google Docs
  24. $(function() {
  25.  
  26. // Use Static Maps to generate an image of the address entered by the user
  27. $('#load_maps').click(function() {
  28. var mapURL = 'https://maps.googleapis.com/maps/api/staticmap?center='
  29. + encodeURIComponent($('#search').val())
  30. + '&zoom=14&size=200x400&sensor=false';
  31. $('#maps').html('<img src=" ' + mapURL + ' "/>');
  32. });
  33. // If the user presses the Enter key in the search box, perform a search
  34. $('#search').keyup(function(e) {
  35. if (e.keyCode === 13) {
  36. $('#load_maps').click();
  37. }
  38. });
  39.  
  40. // When a user clicks the thumbnail image in the sidebar, call
  41. // insertGoogleMap to insert the maps image in the current document
  42. $('#maps').click(function() {
  43. google.script.run.insertGoogleMap($('#search').val());
  44. });
  45. });
  46. </script>
Step 4. Next we will write the server side JavaScript (Google Script) that will actually render the sidebar and insert Google Maps images in the document.
  1. /* What should the add-on do after it is installed */
  2. function onInstall() {
  3. onOpen();
  4. }
  5.  
  6. /* What should the add-on do when a document is opened */
  7. function onOpen() {
  8. DocumentApp.getUi()
  9. .createAddonMenu() // Add a new option in the Google Docs Add-ons Menu
  10. .addItem("Google Maps", "showSidebar")
  11. .addToUi(); // Run the showSidebar function when someone clicks the menu
  12. }
  13.  
  14. /* Show a 300px sidebar with the HTML from googlemaps.html */
  15. function showSidebar() {
  16. var html = HtmlService.createTemplateFromFile("googlemaps")
  17. .evaluate()
  18. .setTitle("Google Maps - Search"); // The title shows in the sidebar
  19. DocumentApp.getUi().showSidebar(html);
  20. }
  21.  
  22. /* This Google Script function does all the magic. */
  23. function insertGoogleMap(e) {
  24. var map = Maps.newStaticMap()
  25. .setSize(800, 600) // Insert a Google Map 800x600 px
  26. .setZoom(15)
  27. .setCenter(e); // e contains the address entered by the user
  28. DocumentApp.getActiveDocument()
  29. .getCursor() // Find the location of the cursor in the document
  30. .insertInlineImage(map.getBlob()); // insert the image at the cursor
  31. }
Save your changes and then choose onOpen from the Run menu inside the Script editor. Authorize the script and switch to your Google Document.
You’ll see a new Google Maps option under the Add-ons menu. Select the menu item and you’ll be able to insert maps images inside your Google Documents without using any screen capture software.

Share your Google Add-ons with other Google Docs users

Now that your first Google add-on is ready, you may want to distribute it to other users of Google Docs. The easiest option would be that you share your document with public and set the permission as Anyone can view. Now anyone can create a copy of your document in their own Google Drive and use your add-on.
SHARE

Unknown

  • Image
  • Image
  • Image
  • Image
  • Image
    Blogger Comment
    Facebook Comment

0 comments:

Post a Comment