Logo

dev-resources.site

for different kinds of informations.

Building a CRUD app with Google Sheets

Published at
12/7/2023
Categories
crud
appsmith
Author
joseph_appsmith
Categories
2 categories in total
crud
open
appsmith
open
Author
15 person written this
joseph_appsmith
open
Building a CRUD app with Google Sheets

Goal

This tutorial covers the basics for creating a CRUD (Create, Read, Update, Delete) app using Google Sheets as the datasource. 

Prerequisites

  • An Appsmith account

  • A Google account

Overview

Google Sheets is actually our most used datasource in Appsmith! It's great for quickly prototyping an app, or building a PoC (proof of concept) or MVP (minimum viable product). 

For this tutorial, we'll be using a mock dataset for an events app at a software company. Start out by copying the sample sheet to your Google account, and give it a unique name so it's easy to find from Appsmith.

Sample Events sheet <= Make a copy

Next, we'll create a Google Sheets datasource in Appsmith, and then add APIs and a table widget to display and edit the sheet data. 

  1. Create a Google Sheets Datasource

    Start out by creating a new app, and then add a Google Sheets datasource. 

    gsheets datasource

    1. In the Appsmith editor, click the Datasources [+] button and choose Google Sheets
    2. Name the datasource 
    3. Set the Permissions to: Read / Write / Delete | Selected google sheets
    4. Click Save and authorize, then choose your Google account and authorize Appsmith to connect
    5. In the next screen, find and select your new copy of the Events sheet

    Note: Best practice is to create a new datasource for each sheet, instead of using the Read / Write / Delete | ALL google sheets option. 

    Keep in mind, if you choose ALL Google Sheets, and you share the workspace with someone else as a developer or admin, they will be able to access all of your Google Sheets!

  2. Get data from Google Sheets

    Next, we'll add an API to get data from the sheet. Make sure to create the new API under the Google Sheets datasource you just created. You can use the [+] New query button on the Google Sheets datasource, or the [+] Query/JS button, then select the Google Sheets datasource. 

    Pro Tip: You can also use the keyboard shortcut cmd-shift-+ to add a new API. More keyboard shortcuts here

    1. Add a new Google Sheets API and name it getRows
    2. Configure as follows:\ Operation: Fetch Many\ Entity: Sheet Row(s)\ Spreadsheet: The Events sheet you just copied\ Sheet: events
    3. Click RUN

    gsheets getrows

    You should get back a response with data from the spreadsheet. Now, on the right panel under Add new widget, click the Table binding shortcut. This will add a table widget to the canvas and automatically connect it to the getRows API. Alternatively, you can drag in a table widget, then set the Table Data property to {{getRows.data}}.

    Notice the toast message about the getRows API running on page load now? Appsmith automatically sets a query to run on page load if it's connected to a widget. This way the widget will have data to display when the app first opens. You can also set a query to run on page load in the Settings tab for that query. 

  3. Add a row to Google Sheets

    The table widget has an awesome new feature for adding a row directly from the table, instead of using a form widget. First, we'll enable adding a row, then we'll create the new API, and lastly, we'll connect the new API to the table widget. 

    To get started, select the table widget and find the Adding a row section at the bottom of the property pane:

    1. Table Widget > Adding a row > 
      1. Allow adding a row => ON

    Then go up to the column settings for the table widget:

    1. Table Widget > Data > Columns >
      1. Click the checkbox to mark all columns as editable
    2. On the top of the table widget, click the + Add new row button
      1. Enter some dummy data in the new row, but don't click Save row yet!\ This will give us a draft row object to use in the addRow API. 

    edit table

    Next, create a new API under the Google Sheets datasource. 

    1. Add new API: Insert One > Sheet row
    2. Name the API addRow 
    3. Set the Row object to: {{Table1.newRow}}

    save row api

    You should see the data you entered for the new row in the evaluated value pane. Now, head back to the table widget properties to connect the API to the SAVE button. Once the addRow API runs, you'll want to run the getRows API again to update the data in the table widget. This can easily be done using the callback option in the action selector. 

    addrow

    1. Table Widget > Adding a row > 
      1. On Save => addRow API
        1. Callbacks: On Success => getRows

    Now, head back to the new row you started to add on the table widget and click Save row. You should see the new row added to the sheet, and the table widget updated with the new data. 

  4. Updating a row in Google Sheets

    Next, we'll add a new API for updating a row and use the table widget's row editing feature. This will be similar to the addRow API, but now we must also specify the rowIndex of the row to update. Start out by creating the new API. 

    1. Add new API: Update One > Sheet Row
    2. Name the API updateRow
    3. Set body to {{Table1.updatedRow}}

    Notice how there's a new SAVE/DISCARD column in the table widget now? That gets added when you enable row editing, but you have to configure which action to run when the user clicks save. 

    1. Table Widget > Columns > Save/Discard (click the gear icon)
    2. Set the On Save to updateRow
      1. Callback: On Success => getRows

    updating a row

    Now you should be able to edit a row, then click SAVE to update the sheet and refresh the table widget. 

  5. Deleting a row in Google Sheets

    Lastly, we'll add an API for deleting a row, then connect it to a new button in the table widget. Start out by adding a new button column to the table widget, then create an API and link it to the new button. 

    1. Table Widget > Columns > [+] Add new column
    2. Set the column name to Delete
    3. Click the gear icon to open the column settings
    4. Set Column type to Icon Button, and select the trash icon

    Now, add the deleteRow API. 

    1. Add new API: Delete One > Sheet Row
    2. Name the API deleteRow
    3. Set the rowIndex to {{Table1.triggeredRow.rowIndex}}

    Lastly, connect the API to the new delete button. 

    1. Table Widget > Columns > Delete (click the gear icon)
    2. OnClick => deleteRow
      1. Callback: On Success => getRows

    delete row

    And that's it! You now have APIs for Creating, Reading, Updating, and Deleting data in Google Sheets; a complete CRUD app without writing a single line of code. 

Conclusion

Google Sheets is a great choice for a backend when you need to quickly throw together an app, build a PoC or test out an idea. And Appsmith's native Google Sheets connector makes it easy to quickly build a full CRUD app on top of your sheets data. 

Additional Resources

appsmith Article's
27 articles in total
Favicon
OpenAI Assistants with Structured Outputs
Favicon
Appsmith: Free Open-source Low-Code App Builder
Favicon
Automating Customer Feedback Analysis with Appsmith, Fathom, Slack, and AI
Favicon
Streamline Procurement Approvals with Low-Code Workflow Automation
Favicon
The Only Appsmith Alternative You Need to Know
Favicon
FileMaker API Connector: A Free and Open-Source Starter Solution for Integrating FileMaker with Any API Or Database
Favicon
Explorando o AppSmith com uma REST API
Favicon
Tutorial: Utilizando ferramentas Low Code em Equipe Distribuída
Favicon
Building a CRUD app with Google Sheets
Favicon
15+ Best Customer Service Software Platforms for 2024 and How to Integrate Them
Favicon
The Future of Intent-Driven Design
Favicon
Appsmith vs Retool: Everything You Need To Know
Favicon
Appsmith Innovate Announcements: 1-Click Upgrade, Community Portal, and Templates
Favicon
Are You Still Building Internal Tools From Scratch in 2023?
Favicon
Fostering a Product-First Mindset 🚀
Favicon
How We Fixed Performance With JS Object Variable Mutation
Favicon
Make a Admin Panel in Appsmith
Favicon
Building a contact application with Django and Appsmith
Favicon
Build a Video Approval Tool on Appsmith with Airtable and Notion
Favicon
Build an Equipment Checkout App for the Admin Team at Your Company
Favicon
Appwrite & Appsmith: The perfect open-source duo for your business apps
Favicon
Building a Real-Time Bitcoin Price Tracker in Appsmith
Favicon
How to Deploy Appsmith on private instance using Docker
Favicon
How to Deploy Appsmith on DigitalOcean
Favicon
Build a Cryptocurrency Price Tracker - Appsmith
Favicon
How to work with GraphQL on Appsmith
Favicon
How to Build an Issue Tracker with Appsmith

Featured ones: