Skip to content

Commit bb1c305

Browse files
authored
Entities section descriptions (#1829)
1 parent ab07302 commit bb1c305

File tree

1 file changed

+36
-16
lines changed

1 file changed

+36
-16
lines changed

docs/entities-intro.rst

+36-16
Original file line numberDiff line numberDiff line change
@@ -4,14 +4,23 @@
44
Introduction to Entities
55
**************************
66

7-
If you've heard something about ODK Entities and want to better understand whether they're useful for your longitudinal data collection, you're in the right place! We've organized this page as a series of questions that are independent from each other so you can pick and choose the sections that interest you.
7+
If you've heard something about ODK Entities and want to better understand whether they're useful for your longitudinal data collection, you're in the right place! We've organized this page as a series of questions that are independent from each other so you can focus on the topics that interest you.
88

99
If you're someone who learns best by doing, you may prefer to jump straight into the tutorial on :doc:`building a community reporting tool with Entities <tutorial-community-reporting>` and to come back here if you have any questions. If you have a question that we haven't answered, you can `post on the forum <https://forum.getodk.org/c/support/6>`_.
1010

11+
**Topics**
12+
13+
* :ref:`Overview <entities-intro-concepts>`: how Entities fit with ODK concepts like Forms and longitudinal data collection
14+
* :ref:`What's coming <entities-intro-limitations>`: current limitations and plans for the future
15+
* :ref:`Alternatives <entities-intro-alternatives>`: other concepts in ODK you can use and other software to consider
16+
* :ref:`Get started <entities-intro-get-started>`: how to use Entities in your workflow
17+
1118
.. note::
1219

1320
This document assumes you are using `ODK Cloud <https://getodk.org/#pricing>`_ or an up-to-date :doc:`ODK Central <central-intro>` server. Entities are not yet available in other ODK-compatible systems.
1421

22+
.. _entities-intro-concepts:
23+
1524
Concepts
1625
========
1726

@@ -82,12 +91,14 @@ Why can't I just flow data from one form to another form?
8291

8392
We have added the Entity concept instead of letting data flow directly between forms because it adds more flexibility. In particular, it's common to have a workflow centered around a thing with a status that determines what needs to be done with that thing. Having an Entity representation with one or more properties that represent its status means it's significantly easier to have multiple forms that can update that status and to show a list of Entities with the latest status information.
8493

85-
In many contexts, the information that needs to be shared between forms is minimal and sometimes as little as an ID and label are enough. Sometimes the subjects of a workflow are known ahead of time, either from a prior ODK form or some other system. Entities makes both of these cases straightforward to represent.
94+
In many contexts, the information that needs to be shared between forms is minimal and sometimes as little as an ID and label are enough. Sometimes the subjects of a workflow are known ahead of time, either from a prior ODK form or some other system. Entities make both of these scenarios straightforward to represent.
8695

8796
If your workflow requires accessing all captured data about an Entity, directly flowing data between forms would likely have worked well. You can achieve something similar with Entities by creating an Entity List that represents encounters with the Entity.
8897

8998
For example, let's say that you have trees that you want to evaluate over time. You could have a ``trees`` Entity List that includes fixed properties of the trees: their location, their species, etc. Then you could have a second Entity List called ``tree_measurements`` that includes a property that represents a link back to a ``tree`` Entity as well as any measurements made during a new encounter.
9099

100+
.. _entities-intro-limitations:
101+
91102
Limitations
92103
===========
93104

@@ -129,6 +140,13 @@ If there is a parent-child relationship between the different Entities, you can
129140

130141
Similarly, if you'd like to establish relationships between multiple Entities of different types, you can have a registration form for each type and include a field to represent a link to another Entity.
131142

143+
My Entities have associated media, can I attach files to them?
144+
---------------------------------------------------------------
145+
146+
Not yet, but this is something we will eventually support. If you are interested in possible temporary workarounds, see `this forum thread <https://forum.getodk.org/t/retrieving-dynamic-media-from-entity/47820>`_
147+
148+
.. _entities-intro-alternatives:
149+
132150
Alternatives
133151
============
134152

@@ -160,7 +178,7 @@ ODK is a flexible data collection platform. Its strength is that it lets you qui
160178

161179
The domain that you work in likely has systems for managing workflows similar to the ones you need to support. This could be a system designed to support a community health worker program, to monitor tree health over time, to track samples in a lab, etc. Those systems typically have some built-in concepts around the data that needs to be collected, the people that might be involved, the status changes that a workflow subject can go through, and so on.
162180

163-
If you have specialized software that supports your domain's workflows, we recommend giving that software a try. If instead you prefer the flexibility to define your forms and Entity Lists to exactly match your workflow needs, ODK will be better a fit.
181+
If you have specialized software that supports your domain's workflows, we recommend giving that software a try. If you find that you need the flexibility to define your forms and Entity Lists to exactly match your workflow needs, ODK may be a better fit.
164182

165183
Here are some questions to consider when deciding between using ODK and specialized software:
166184

@@ -172,8 +190,21 @@ In general, workflows that are focused or short-lived can very easily be represe
172190

173191
That said, in many contexts, workflow needs are so specific that a flexible platform like ODK offers great benefits. Once you have defined your workflow in ODK, the forms you have built can become the standard, specialized way to support others in your domain.
174192

175-
Mechanics
176-
=========
193+
.. _entities-intro-get-started:
194+
195+
Get started
196+
============
197+
198+
How do I use forms to create or update Entities?
199+
------------------------------------------------
200+
201+
Add an ``entities`` sheet to your form. This sheet is used to define how data from this form's submissions should be applied to Entity Lists. Currently, a single submission can only affect a single Entity in a fixed Entity List. To specify which list to create or update an Entity in, use the ``list_name`` column. If you're creating Entities, you'll also need to specify an expression to label each Entity in the ``label`` column (it's optional if you're doing an update). This is very similar to :ref:`the instance_name column <instance-name>` for naming filled forms.
202+
203+
Next, specify which form fields should be saved to Entity properties. This is done on the ``survey`` sheet by putting the desired property name in the ``save_to`` column for each form field that you want to save.
204+
205+
.. seealso::
206+
* :doc:`Community reporting tutorial <tutorial-community-reporting>`
207+
* :ref:`Central Entities documentation <central-entities-follow-up-forms>`
177208

178209
How do I access Entities from my forms?
179210
---------------------------------------
@@ -193,17 +224,6 @@ You can access a specific Entity's properties using a :ref:`lookup expression <r
193224
* :doc:`Community reporting tutorial <tutorial-community-reporting>`
194225
* :ref:`Central Entities documentation <central-entities-follow-up-forms>`
195226

196-
How do I use forms to create or update Entities?
197-
------------------------------------------------
198-
199-
Add an ``entities`` sheet to your form and use it to define the Entity List that the form's submission will populate and an expression for each Entity's label.
200-
201-
Next, specify which form fields should be saved to Entity properties. This is done on the ``survey`` sheet by putting the desired property name in the ``save_to`` column for each form field that you want to save.
202-
203-
.. seealso::
204-
* :doc:`Community reporting tutorial <tutorial-community-reporting>`
205-
* :ref:`Central Entities documentation <central-entities-follow-up-forms>`
206-
207227
What form fields should I save to my Entities as properties?
208228
------------------------------------------------------------
209229

0 commit comments

Comments
 (0)