Configure a Space
Configure a place for collecting data by creating a Space.
The DevXP engineering team hosts office hours every Thursday at 11 a.m. Pacific Time where we answer your questions live and help you get up and running with Flatfile. Join us!
Flatfile Spaces are micro-applications, each having their own database, filestore, and auth. A Space is comprised of Workbooks, Files and Users. It can also include Documents, Themes and Metadata.
In this example, we’ll create a simple Space with a Workbook and a Document. We’ll also theme the Space to be red.
Dynamically build your Space
When the “Create New Space” button is clicked from within your App in the dashboard, it triggers a job event
within the space domain
that initiates a configure operation
.
This operation is analogous to performing a POST request to the endpoint /api/v1/spaces with the parameter autoconfigure
set to true.
Usage
In the following code, we will:
- Filter on the
red
namespace. (Or replace this with your namespace.) - Filter for a job by the
domain
(space) and theoperation
(configure) it was created. - Listen for a
job:ready
event. - Acknowledge the Job and mark the progress.
- Add the contents of the Space, including one Workbook and a simple Document.
- Update the space theme to be the color
red
. - Complete (or fail) the job.
Run your listener locally and create a new Space
To allow this listener to run, you’ll want to run it locally using the same “develop” command you used when initially setting up the listener.
As a reminder, that command is:
Once this is running, click the “Create New Space” button in your dashboard.
Meet your Space
So what did that just do?
In your Flatfile account you should now be able to see your Space.
As you can see, this Space has a Workbook with a sheet and fields. A is like a template, its definition includes a profile of the data it expects to hold. We call that profile a Blueprint.
Blueprint is Flatfile’s robust data definition language (DDL) that emphasizes validation and data preparation. Flatfile APIs leverage Blueprint for their create, update, and read operations.
Watch your Events
Because your listener was running, it logged your activity as the Space was being built. You should see several events that took place.
Now, to watch your listener receive another event, make a few changes in the Workbook. For example, try typing text into a cell.
Typing in a cell (editing a Record) triggers an Event!
▶ commit:created 10:13:05.159 AM us_evt_1234
↳ on(**, {})
↳ on(commit:created, {"sheetSlug":"contacts"})
---
## Next steps
Now that you have a Workbook in a Space, which acts both as a schema and destination for your data, you're ready to [Add data transformations](../custom/add-data-transformation.mdx).