enuchi / React-Google-Apps-Script

This is your boilerplate project for developing React apps inside Google Sheets, Docs, Forms and Slides projects. It's perfect for personal projects and for publishing complex add-ons in the Google Workspace Marketplace.
MIT License
1.32k stars 171 forks source link

React & Google Apps Script logos

Built with React v18 and Vite for best-in-class frontend development.

[![Status](https://img.shields.io/badge/status-active-success.svg?color=46963a&style=flat-square)]() [![GitHub Issues](https://img.shields.io/github/issues/enuchi/React-Google-Apps-Script.svg?color=lightblue&style=flat-square)](https://github.com/enuchi/React-Google-Apps-Script/issues) [![GitHub Pull Requests](https://img.shields.io/github/issues-pr/enuchi/React-Google-Apps-Script.svg?color=blue&style=flat-square)](https://github.com/enuchi/React-Google-Apps-Script/pulls) [![License](https://img.shields.io/github/license/enuchi/React-Google-Apps-Script?color=pink&style=flat-square)](/LICENSE)

πŸš€ This is your boilerplate project for developing React apps inside Google Sheets, Docs, Forms and Slides projects. It's perfect for personal projects and for publishing complex add-ons in the Google Workspace Marketplace.


πŸ“ Table of Contents


πŸ”Ž About

Google Apps Script is Google's Javascript-based development platform for building applications and add-ons for Google Sheets, Docs, Forms and other Google Apps.

Google Apps Scripts lets you add custom user interfaces inside dialog windows. Using this template, it's easy to run React apps inside these dialogs, and build everything from small projects to advanced add-ons that can be published in the Google Workspace Marketplace.

React & Google Apps Script

This repo is a boilerplate project for developing React apps with Google Apps Script projects. You can use this starter template to build your own React apps and deploy them inside Google Sheets, Docs, Forms and Slides for use in dialogs and sidebars. Sample code is provided showing how your React app can interact with the underlying Google Apps Script server-side code.

Read on to get started with your own project!

🚜 Install

These instructions will get you set up with a copy of the React project code on your local machine. It will also get you logged in to clasp, which lets you manage script projects from the command line.

See deploy for notes on how to deploy the project and see it live in a Google Spreadsheet.

Prerequisites

🏁 Getting started

Full steps to getting your local environment set up, deploying your app, and also running your app locally for local development are shown in the video below:

https://github.com/enuchi/React-Google-Apps-Script/assets/31550519/83622b83-0d0e-43de-a589-36f96d51c9c4

1. First, let's clone the repo and install the dependencies. This project is published as a public template, so you can also fork the repo or select "Use this template" in GitHub.

git clone https://github.com/enuchi/React-Google-Apps-Script.git
cd React-Google-Apps-Script
yarn install

2. Next, we'll need to log in to clasp, which lets us manage our Google Apps Script projects locally.

yarn run login

3. Now let's run the setup script to create a New spreadsheet and script project from the command line.

yarn run setup

Alternatively, you can use an existing Google Spreadsheet and Script file instead of creating a new one.

See instructions here for using an existing project. You will need to update the `.clasp.json` file in the root of this project with the following three key/value pairs (see .clasp.json.SAMPLE for reference): ```json { "scriptId": "1PY037hPcy................................................", "parentId": ["1Df30......................................."], "rootDir": "./dist" } ``` - `scriptId`: Your existing script project's `scriptId`. You can find it by opening your spreadsheet, selecting **Tools > Script Editor** from the menubar, then **File > Project properties**, and it will be listed as "Script ID". - `parentId`: An array with a single string, the ID of the parent file (spreadsheet, doc, etc.) that the script project is bound to. You can get this ID from the url, where the format is usually `https://docs.google.com/spreadsheets/d/{id}/edit`. This allows you to run `npm run open` and open your file directly from the command line. - `rootDir`: This should always be `"./dist"`, i.e. the local build folder that is used to store project files.

Next, let's deploy the app so we can see it live in Google Spreadsheets.

https://github.com/enuchi/React-Google-Apps-Script/assets/31550519/0c67c4b8-e3f5-4345-8460-470e9211aeb9


πŸš€ Deploy

Run the deploy command. You may be prompted to update your manifest file. Type 'yes'.

yarn run deploy

The deploy command will build all necessary files using production settings, including all server code (Google Apps Script code), client code (React bundle), and config files. All bundled files will be outputted to the dist/ folder, then pushed to the Google Apps Script project.

Now open Google Sheets and navigate to your new spreadsheet (e.g. the file "My React Project"). You can also run yarn run open. Make sure to refresh the page if you already had it open. You will now see a new menu item appear containing your app!


🎈 Local Development

We can develop our client-side React apps locally, and see our changes directly inside our Google Spreadsheet dialog window.

There are two steps to getting started: installing a certificate (first time only), and running the start command.

  1. Generating a certificate for local development

    Install the mkcert package:

    # mac:
    brew install mkcert
    
    # windows:
    choco install mkcert

    More install options here.

    Then run the mkcert install script:

    mkcert -install

    Create the certs in your repo:

    yarn run setup:https
  2. Now you're ready to start:

    yarn run start

The start command will create and deploy a development build, and serve your local files.

After running the start command, navigate to your spreadsheet and open one of the menu items. It should now be serving your local files. When you make and save changes to your React app, your app will reload instantly within the Google Spreadsheet, and have access to any server-side functions!

https://github.com/enuchi/React-Google-Apps-Script/assets/31550519/981604ac-bdea-489d-97fa-72e6d24ba6dd


πŸ” Using React DevTools

React DevTools is a tool that lets you inspect the React component hierarchies during development.

Instructions for installing React DevTools
You will need to use the "standalone" version of React DevTools since our React App is running in an iframe ([more details here](https://github.com/facebook/react/tree/master/packages/react-devtools#usage-with-react-dom)). 1. In your repo install the React DevTools package as a dev dependency: ```bash yarn add -D react-devtools ``` 2. In a new terminal window run `npx react-devtools` to launch the DevTools standalone app. 3. Add `` to the top of your `` in your React app, e.g. in the [index.html](https://github.com/enuchi/React-Google-Apps-Script/blob/e73e51e56e99903885ef8dd5525986f99038d8bf/src/client/dialog-demo-bootstrap/index.html) file in the sample Bootstrap app. 4. Deploy your app (`yarn run deploy:dev`) and you should see DevTools tool running and displaying your app hierarchy. 5. Don't forget to remove the ` Githubissues.
  • Githubissues is a development platform for aggregating issues.