Retrieving Data from Firebase

In this guide, we'll walk you through how to retrieve data from Firebase and incorporate it in your grid.

Note: In the next few examples, we will be using our movies data, which has the Firebase path: "https://zinggrid-examples.firebaseio.com/movies/"

Connecting to the Database

If you want to populate your grid using data stored in Firebase, then you just need to set the src attribute to the Firebase URL that includes the path to the data. You can either set the src attribute for <zing-grid> or <zg-data>, like so:

<zing-grid src="https://<databaseName>.firebaseio.com/<path>/"></zing-grid>

or

<zing-grid>
  <zg-data src="https://<databaseName>.firebaseio.com/<path>/"></zg-data>
</zing-grid>

Firebase Grid

Here is our complete grid with data retrieved from Firebase:

CRUD Grid

By default, setting the source to a Firebase URL provides us with a simple CRUD grid. You can create new rows, read from the given source, update cells or rows, and delete rows from the grid. Any changes we make will automatically be reflected in the database.

In order to update cells/rows, you need to set the editor attribute for the grid. You can create/update/delete rows through the context menu which appears after setting the context-menu attribute for the grid (see HTML and demo below). You can also do this by setting specific column types.

<zing-grid
  src="https://zinggrid-examples.firebaseio.com/movies/"
  editor context-menu infinite>
</zing-grid>
https://app.zingsoft.com/demos/embed/K81OAAXT
https://app.zingsoft.com/demos/embed/K81OAAXT
Top

Authentication

If you need to authenticate users to access your grid, you can do so in one of two ways: with queryString on <zg-param> or through the Firebase SDK adapter.

queryString Attribute

To authenticate users, you can set queryString on <zg-param> to be the auth=<ID_TOKEN> name/value pair according to Firebase specifications. Note: This assumes that you have authenticated the user and retrieved their token.

Firebase SDK Adapter

The easier way to handle authentication is to use the Firebase SDK adapter if you are using a Firestore database. This requires you to include the Firebase SDK JavaScript files (app, auth, and Firestore) and these Firebase SDK files must be included before the ZingGrid library.

Check out the example grid below which uses the Firebase SDK adapter to ensure that users can only access the grid's data if they are logged in:

https://app.zingsoft.com/demos/embed/0SK2J6EZ
https://app.zingsoft.com/demos/embed/0SK2J6EZ
Top

Using Firebase Queries

To make it easier to use Firebase queries, set the data's adapter attribute to "firebase". This will then convert all of the appropriate parameters according to what Firebase expects.

<zing-grid>
  <zg-data
    src="https://zinggrid-examples.firebaseio.com/movies/"
    adapter="firebase"></zg-data>
</zing-grid>

For example, adapter="firebase" will convert:

Sorting

If you want to enable data sorting, then set the sortBy key to the property that you want to sort on. You also use queryString, which allows you to include additional query strings in the request, such as startAt=value (where "value" refers to the values of the data that you want to start sorting at).

In the example below, we sort based on the "title" key of our data, starting at the values that begin with "D".

https://app.zingsoft.com/demos/embed/QV4FBCXK
https://app.zingsoft.com/demos/embed/QV4FBCXK

recordPath

If you have multiple top-level objects stored in your database, you can select which object you want to use to populate the grid by setting recordPath equal to the path from the JSON object to the object with the grid data. This allows you to just change recordPath to easily switch between data.

In our courses object example below (given by the path: "https://zinggrid-examples.firebaseio.com/courses/"), we have two objects. If we wanted to display the first course's array of students as a grid, we would set recordPath equal to "0.students". If we wanted to do this for the second course, we would set it to "1.students".

[
  {
    "courseId": "A21",
    "courseName": "Astronomy",
    "students": [
      {
        "grade": "A",
        "id": "241",
        "name": "Brian"
      },
      {
        "grade": "A-",
        "id": "386",
        "name": "Jenny"
      },
      ...
    ]
  },
  {
    "courseId": "M15",
    "courseName": "Greek Mythology",
    "students": [...]
  }
]
https://app.zingsoft.com/demos/embed/D64W7I1M
https://app.zingsoft.com/demos/embed/D64W7I1M

Infinite Scroll

If you want to enable infinite scroll in your grid, follow the steps below:

  1. Add height and page-size attributes to your <zing-grid> tag

    <zing-grid height="400" page-size=10>
  2. Add adapter and src attributes to <zg-data>

    <zg-data adapter="firebase" src="https://zinggrid-examples.firebaseio.com/movies">
  3. Add [name="loadByScroll"] and [value="true"] attributes to <zg-param>

    <zg-param name="loadByScroll" value="true"></zg-param>
<zing-grid height="400" page-size=10>
  <zg-data adapter="firebase" src="https://zinggrid-examples.firebaseio.com/movies">
    <zg-param name="loadByScroll" value="true"></zg-param>
  </zg-data>
</zing-grid>
https://app.zingsoft.com/demos/embed/J0L5T5YU
https://app.zingsoft.com/demos/embed/J0L5T5YU
Top

Another Version: <zg-param>

In the examples above, most of our configurations are set in the options object. Another way that you can write this is with the <zg-param> tag. <zg-param> is a child of <zg-data>, and it has two attributes: name and value. Using <zg-param> provides greater readability and allows us to focus on a more component-based approach.

For example,

<zg-data options='{"queryString": "limitToFirst=7&startAt=\"F\""}'></zg-data>

can be rewritten as:

<zg-data>
  <zg-param name="queryString" value='limitToFirst=7&startAt="F"}'></zg-param>
</zg-data>

Attributes on <zg-param> Grid

In this example, we use <zg-param> to set the adapter, sort the data, and then display the last 8 entries:

https://app.zingsoft.com/demos/embed/XTNZA1Q7
https://app.zingsoft.com/demos/embed/XTNZA1Q7
Top

[data: firebase]