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
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 ?
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
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:
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
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:
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:
Now that we have the label, let’s construct the filter to search for all matching presentations:
As you can see, the query (line 9) filters for three different criteria:
The next step is to use the search query to list all matching presentations:
We use the Drive.Files.list method of the advanced Drive service and submit a set of arguments (see optionalArgs in line 5):
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:
Recommended by LinkedIn
Here’s how the code looks like:
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.
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.
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.
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.
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.
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:
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