Spreadsheet component. Example. Google Sheets

Yes, I could probably put something together real quick.

Edit: PR is now up:

Thank you! I was able to make the recommended changes.

Currently I have the data going to particular cells in the spreadsheet. Is there a capability to populate the next row if another user works with the app? Essentially I am trying to populate the spreadsheet with different users inputs from the app.

You will need to show/explain exactly what you mean.

Most things are possible.....

The Add Row block is perfect for that, since it does not need to told by the app where to put the new row.

It just adds a new row to the bottom of the sheet.

There should be no problem with overlapping Add Row requests by different users, since I would expect Google Sheets would take care of that.

Here are my blocks and a snapshot the google spreadsheet. What I am trying to do is essentially keep the data in the first row and then from any other entry it populates the next collection of cells.


Looks like you need to work back and start again.

Create a list that contains all the items you need in a row

AppendRow that list

much more straightforward.

More examples are needed.
Why 3 contests? Why not 2 or 4?

This concept worked. Thank you!

En mi caso el problema lo reparé simplemente cambiando el texto Sheet1 por Hoja 1 ya que mi hoja de cálculo la cree en español.
image

Hi, I need help. Namely, when I add something to the sheet, the list is not constantly updated. Only after pressing update do I have the current state of the list.




I'm adding a demo video

For those who do not know your language it is hard to understand your blocks... therefore before taking a screenshot switch the language to English next time...

From your video it looks like you add an item to the spreadsheet, but in the listpicker the newly added item does not appear

The correct workflow would look like this:

  1. add an item
  2. after it has been aded successfully, read the table
  3. get the result and display the list

Taifun

I tried to do it in English

I don't know how to check "after it has been added successfully, read the table" Can you show me which blocks I should use?
Thank you.

Each method does have a corresponding event
AddRow --> FinishedAddRow
WriteCell--> FinishedWriteCell

http://ai2.appinventor.mit.edu/reference/components/storage.html#Spreadsheet

Taifun

Thank you very much :smiling_face:

1 Like

These steps do not seem to work, as i don't get the option to download a JSON file. Probably Google Developer Account's interface has changed? Please can someone help? Test?

That's correct, Google's interface has changed. Here is a newer document.

1 Like

That's a nice doc, but no author is mentioned.
It would look nice mirrored on this board.

In this guide, you will: Create a credential for Google Sheets to read and write to private spreadsheets

Appendix B: Create a Credential for Google Sheets

  1. Decide whether you even need a Google Sheets credential!
  • A credential is a long password from Google that allows your app to connect to a Google Sheets spreadsheet.
  • The password comes in the form of a small computer file, which you upload to App Inventor for use in your app.
  • Only the highlighted situation below requires making your own credential using this guide.
Situation Solution What to do
I want my app to read data from a public Google Sheets spreadsheet with only one sheet. No credential needed Create an app and leave CredentialsJson empty on the Spreadsheet component.
I want my app to read data from a public Google Sheets spreadsheet to access multiple sheets. Any credential works Use App Inventor’s credential in the Appendix folder (easiest), or create one using the process below.
I want my app to write data to a public Google Sheets spreadsheet. Any credential works Use App Inventor’s credential in the Appendix folder (easiest), or create one using the process below.
I want my app to read or write data to a private (“Restricted”) Google Sheets spreadsheet that only my classroom or I can see. Get a credential tied to your Google account Create your own credential using the process below.

Note:

  • To know whether your spreadsheet is public or private, examine the following settings in Google Sheets:

  • If you don't want to go through the credential steps, change your private spreadsheet to a public one — as long as the spreadsheet is not holding sensitive data.
  1. Look over the steps to creating a Google Sheets credential.

Here is a quick overview of the steps in this guide:

▢ Gather the username and password for your Google account. (Or create a Google account for free.)

▢ Start a Google Developer Account using your Google password (again — free)

▢ Create a Service Account as a developer

▢ Set up a coding project with Google Sheets

▢ Download a service account key and copy the service account email address

▢ Upload that key to App Inventor when you need your app to connect to Google Sheets. Use the service account email address to access your private spreadsheets online.

  1. Create a Google Developer Account.
  • Do you have a standard Google account for email or Google Drive? If not, create an account at www.google.com.
  • Go to developers.google.com and sign in with your Google Account username and password.

  1. Create a “Project”
  • Google organizes your developer work into various projects you name and set up. Create a coding project with the steps below.
  • Once you have logged into your Google Developer Account in the step above, go to console.developers.google.com.
  • If this is your first time using your Google Developer Account, you will see a prompt for the Terms of Service. Check the box and continue.

  • On the developer dashboard, create a project by selecting CREATE PROJECT.

|445x313.7238346525945

Note: if you have already created projects in Google Cloud before, your screen will look like the one below.

  • Click the box shown:

  • Click on NEW PROJECT:

  • On the New Project page, give the project a name. The name does not matter. For this example, we will name it “My Applesauce App.”

|456x294.70029673590506

  • A coding project does not need to provide an organization, so leave it as No organization.

|459x295.3632569938241

  • Click CREATE.

|459x295.8958508543309

  1. Enable the Google Sheets API.
  • Click + ENABLE APIS AND SERVICES. (APIs or Application Programming Interfaces are a standard way to connect to a service over the internet. For more explanation, check out our restaurant analogy.)

|523x338.5276958601776

  • In the search bar, enter “Google Sheets API” and select the matching entry.

|573x416.50358115605724

  • Click ENABLE.

  • You should see this screen:

|444x297.17451403471637

  1. Create a service account and credential.
  • Create a service account for Google Sheets API. The service account provides a unique email address and a password (the credential) to access Google Sheets as a programmer.
  • To the right of the screen, click CREATE CREDENTIALS.

  • A guide will ask questions about what kind of project you are making. The top menu under “Which API are you using?” should say “Google Sheets API.” If not, make this selection.

  • Under the question, “What data will you be accessing?” select Application data.

  • Under the question, “Are you planning to use this API with Compute Engine, Kubernetes Engine, App Engine, or Cloud Functions?” select “No, I’m not using them.”

  • Click NEXT.

  • You should see the screen for creating a service account:

  • Fill in the name of the service account. The name does not matter. For this guide, we will name it “example-service”

  • Click CREATE AND CONTINUE

  • In the “Select a Role” dropdown menu, select “Owner” to give this service account enough permissions. (If you return to the menu later, it provides even more options under “Owner,” but you can ignore them.)

  • Press DONE. (Ignore “3 Grant Users Access to this Service”.)

  1. Download a key from your service account (and keep it safe!).
  • A key is like a password that you can use to give your app access to the Google Sheets API. You will use the key in App Inventor when making your app. (The property in App Inventor is CredentialsJSON.)
  • You may be on one of the following pages depending on your account. Click on the Credentials option to get to your list of credentials. You may see this page:

  • Or this page:

  • Once on the Credentials page, click on your Service Account:

  • Click on KEYS.

  • Click ADD KEY.

  • Under “Key type,” choose JSON. The site will download a file to your computer containing a long password. The file format is called JSON (JavaScript Object Notation).

  • Keep this JSON file safe! Move this file to an easy-to-remember place on your computer. When using the Spreadsheet component in App Inventor, you will upload this JSON file for the app to work correctly.
  1. Copy your service account email address.
  • Copy the email address associated with your service account. You will use this address when working with Google Sheets and your app.

  • Make sure to save the complete email address.
  • Paste the address somewhere on your phone or computer to find it later. (If you lose it, you can always log back into your developer console to copy it again.)
  1. Use your new credential in your app!
  • Add your new credential to the app.

    • In Designer, select a Spreadsheet component and look at the CredentialsJson property
  • Is there an existing App Inventor credential (as shown here)? You can delete the App Inventor credential or simply change the credential to your own.

  • To add your credential, click on the CredentialsJson box.

  • Here’s how it should look:

  • Add your service account email to a Google Sheets spreadsheet you want to make private (“Restricted”)

  • Click on the Share settings in Google Sheets, and set your spreadsheet to Restricted.

  • Click on the box labeled “Add people and groups”

  • Add the service account email that you created above.