Empower your Google Workspace documents with Apps Script
Level-up your Google Workspace experience

Empower your Google Workspace documents with Apps Script

Automatically update design and content of your presentations and spreadsheets

At shiftavenue, we usually aim to improve the lives of others. We have published articles and posts describing the problems our customers have faced and the solutions we implemented together with them. 

This article however covers an internal topic that came up in the last weeks and will explain how we implemented a quality of life improvement for ourselves to get rid of manual, easy-to-forget tasks and how to ultimately save precious time.

The Scenario

We use the Google Workspace suite for our daily work to create and manage our documents. Storage and management are done with Google Drive, Google Slides is used for working with presentations, Google Sheets for spreadsheets and so on and so forth. We use the services to create internal and customer-facing documents (you might have seen some of our slide decks when we posted on LinkedIn about the workshops and solutions that we can provide, the presentations have been created using Google Slides).

To have a uniform appearance for all of our documents, we create and rely on template designs and layouts that are reused for all managed documents. Furthermore, we want to reuse common content across documents, e.g. company data or personal information. Also, in case charts are used in a Google Slides presentation or a Google Sheets spreadsheet, we want to have the charts up-to-date in case the data changes (you can e.g. create charts in Google Spreadsheets based on data stored in Google BigQuery).

Now in case of changes, one could go through all of his documents and do all of this manually: updating the template design for slide decks or text documents and updating charts and data displayed in spreadsheets. But who actually wants to do this manually each and every time ? Isn’t there a way to automate such things ?

Our consultants at work

We looked for a solution to implement automation scripts doing exactly these tasks. Now, all Google Workspace services provide REST APIs and client libraries to interact with these APIs in your favorite programming language. Unfortunately, for the things mentioned they do not offer this kind of functionality.

However, there’s a second option available called Google Apps Script. This service offers way more functionality than the APIs and can be used to automate design and content updates for (a subset) of Google Workspace documents. As there were no other options available, we decided to go ahead with Apps Script.

But even Apps Script has its limitations. At the time this article was written, not all document types could be automated. In fact it’s limited to Google Slides and Google Spreadsheets. We automated as much as possible, so our scripts which we will show you here automate the following:

  • automatically update the design and theme of Google Slides presentations based on a central master theme slide deck
  • automatically update content of linked slides (we will cover later what a “linked slide” actually is) in all Google Slides presentations
  • automatically updating charts from Google Sheets documents embedded in slides for all Google Slides presentations
  • automatically refreshing all data sources in Google Sheets documents, resulting in automatic updates of charts/graphs using the data sources

Apps Script - what’s that ?

Apps Script is a completely free and fully managed platform by Google aiming to create applications and automate tasks that integrate with Google Workspace services. It provides its own code/script editor that you can access when navigating to the Apps Script portal. Scripts are separated into “projects”. When creating a project, you will be able to develop the script in the mentioned editor.

Scripts are written in vanilla JavaScript by default, however it’s possible to use TypeScript (which of course requires a little more effort to set up). Scripts can be deployed as web applications, executable APIs, as a reusable library or as a so-called “Add-On”. Execution is triggered by either calling the deployed web app or API or by including the library or Add-On into a separate application/script.

We decided to develop our scripts in plain JavaScript and to deploy them as executable APIs. This opens up the possibility to manage the code as well as the deployment and execution of the scripts outside of Apps Script and can be integrated well with standard source control systems like GitHub or Gitlab. However, describing our deployment and execution setup would blow up this article, hence we will focus on the functionality of the scripts themselves (stay tuned for a follow-up article about how we deploy and execute the scripts).

Automatically update the design of presentations

So let’s start with automatically updating themes for your Google Slides presentations. Our script is basically separated into three important steps:

  • grab all Google Slides presentations in the entire shiftavenue Google Drive environment that have a specific label set (more on that later)
  • grab our master slide deck presentation
  • iterate through all found documents and update the theme by applying the latest state of our central master slide deck

Before we jump into it, one side note: we will be making use of advanced services in Apps Script for some parts of our functionality. Check out this documentation on how to enable advanced services for your scripts.

As mentioned, we only update the presentations that have a specific label set (read more about labels here). This is done to reduce the amount of documents to be updated and to be able to control which documents will be updated in general. Our label is called Auto Design Update and it can either be set to True or False. It is important to mention that labels can only be created by Google Workspace Admins, so make sure to assign yourself the correct rights or to find an administrator. We decided to apply this label on all new presentations and set it to True by default as we want to enable this feature automatically for all new slide decks.

Here’s how it looks like when checking the labels of a document:

Shown in Google Drive when checking document labels

Now that we have the label, let’s construct the filter to search for all matching presentations:

Drive search query and its parameters

As you can see, the query (line 9) filters for three different criteria:

  • the mimeType, otherwise the search would return all document types
  • trashed=false makes sure that documents located in trash bins will be omitted
  • and finally checking for the Auto Design Update label: unfortunately the label names and string representations of the values (like True or False) can not be used here, instead it is required to input the label ID, the ID of the text field in which you can find the value (again, either True or False) and finally the ID of the value itself (yes, you can not set True here, you need to the find the ID representation of this string value). Getting the IDs requires some effort, but you can use the advanced Drive Labels service available in Apps Script for getting the relevant values (with the advanced service, you can search for labels based on their name)

The next step is to use the search query to list all matching presentations:

Function for executing search and returning documents

We use the Drive.Files.list method of the advanced Drive service and submit a set of arguments (see optionalArgs in line 5):

  • the search query mentioned above as parameter q
  • to configure the search to look through the entire shiftavenue Google Drive environment, corpora has to be set to allDrives and includeItemsFromAllDrives as well as supportsAllDrives have to be set to true

The remaining setup is necessary as results are returned in multiple pages, each page having up to 500 documents. In the end, we get all elements of every page and return all found presentations as an array (result).

Now that we grabbed all presentations, let’s update the design for all of them! For this, we will make use of Google Slides magic:

  • grab a slide (doesn’t matter which one) from the central master slide deck and copy & paste it to the presentation to be updated
  • the presentation now has two designs applied at the same time: the one that’s currently used and the one that’s derived from the appended master presentation slide
  • finally, you remove the currently applied design so only the new one remains. This will automatically apply the only remaining design on all other slides. Hocus Pocus! You now have the latest master design applied to your presentation!

Here’s how the code looks like:

Google slides magic codified

Working with Google Slides is as easy as using the SlidesApp class. No additional authentication configuration is required, as it automatically uses the account of the user executing the script.

And that’s all there is to say about updating designs with Apps Script! Of course, this procedure has to be repeated for all presentations returned by the Drive.Files.list snippet mentioned above. If you want to have a look at the entire script and all the shown snippets connected together, we have published it on GitHub. Check it out here.

Automatically update linked content

So, now you know how we update our slide designs to match what our marketing department creates and publishes. But what about linked or embedded content? Think of the following scenario:

You are in a boardroom meeting, ready to present this quarter’s great financial results. As you come up to the slide in question, you realize: It contains last quarter’s abysmal numbers. Oh, the embarrassment! Had you linked the slide and updated it instead, everything would have been fine.

You should listen to Drake, and I'm not talking about his music

We are doing exactly this at shiftavenue. Our slides are reused internally, as it would not make sense for everyone to create the same slides over and over again. We do however want our content to be up-to-date as much as possible.

Having gone down the rabbit hole of Google Workspace APIs, we found that we could update linked Slides and linked Sheets in Slides, as well as data sources in Sheets. Perfect!

We decided as a company that we wanted to update all content, but we recommend you start out with a label as well, especially if you have a large amount of files to go through. While the content update works well, it is a time-consuming process. But more on that in a later installment of this article series.

The code to accomplish this feat looks very similar to our design updater: A query, a function to retrieve all files, and a function to update all linked content. We’ll spare you the function code to go through Google Drive again - if you’re that interested, you can find it in our repository as well.

Drive search query

Notice that the query this time takes all Sheets and Slides, as our goal is to update every supported content type. And of course, updating content in the recycle bin is not really necessary, so we still filter those files out.

The function to update linked content is deceptively simple. We iterate over each file that was found, compare the MIME type, and call the respective interface.

Refresh the content of each and every slide

With slides we have two content types to update, linked slides as well as linked charts. Unfortunately, Google does not provide a simple interface to update all linked content programmatically, so that we have to iterate through all slides and update any linked content we can find.

Refresh data sources of spreadsheet

Sheets are slightly simpler, as the only content we can refresh are data sources. To be able to refresh all possible data sources, BigQuery execution can be enabled as well.

Don't forget data backed by BigQuery

Once again, you can find the entire code here. Be warned though: While updating all content to be up-to-date may seem like a great idea, it comes with a tradeoff. The execution time of the code is rather high, so as long as there are no bulk operations available for Google Workspace endpoints, you will have to find a way to cope with that.

Configuring access to documents

An important side note is making sure to set the correct access level for the user executing the scripts. As both of them fetch and update documents in our entire shiftavenue Google Drive environment, the script needs to be executed by a user that has read and write access to all presentations and spreadsheets in our environment (write access is needed as we are adding and removing objects).

We decided to create a service user for this and to grant the account access to all team drives, folders and documents where necessary. Access to personal drives is not granted by default and would need to be configured by our colleagues explicitly. This way, you can control which files the account has access to in general and you can e.g. exclude confidential files if desired.

Conclusion

With our scripts, we can enjoy automatic design and content updates for our slide decks and spreadsheets. The scripts have now been running for a few weeks and have been doing their job very well.

Now, as much as we have praised Apps Script, there are also a lot of things that - at least in our personal opinion - severely downgrade the developer experience. In general, we would actually make the statement that the service is not aimed at the “standard” software engineer/developer at all. While the main selling point is the easy and fast development of scripts (which is true once you get a hang of all Apps Script concepts), there are a few restrictive aspects:

  • being limited to use JavaScript
  • developing in a separate code editor; no integration with standard source control systems by default; no pull request-based review of script changes
  • as everything-as-code lovers, creating projects as well as deploying scripts and configuring execution triggers all being manual tasks simply is pain

As mentioned before in this article, there’s the possibility to actually integrate this with standard developer workflows to some extent, but this requires a not to be ignored amount of additional effort (again, this is a topic for a separate article, so stay tuned).

Nevertheless, it is important to state that the integration with the different Google Workspace services is done very well and you can implement a lot of fun and useful automation scripts with it. All in all, we are happy with our solution and will continue to use it in the future and maybe even extend it.

We hope that this article was helpful and you could learn something new. Please let us know any feedback or questions you might have!

To view or add a comment, sign in

More articles by shiftavenue

Insights from the community

Others also viewed

Explore topics