Contact collection demonstrates how a data object can be treated as a collection of multiple smaller objects.
The collection pattern demonstrated here might be a fit for your scenario if:
- Your data can be described as a homogenous collection of separately usable pieces.
- The consumers of your data (e.g. views or other data objects) might prefer to operate on a single piece, rather than the full collection.
Whereas a non-collection approach might have a collection data object holding handles to many other completely distinct data objects, the collection approach uses a single data object to organize all the data in one place. It then provides interfaces to access individual members as standalone objects. In this example, the ContactCollection
data object stores contact data with one contact per key in its root, to be accessed through a Contact
class which is not a data object. In comparison, the non-collection approach would have stored handles to separate Contact
(full-fledged) data objects. @fluid-example/todo
is a good example of the non-collection approach, storing TodoItem
data objects as handles in the Todo
data object.
The key feature of the collection pattern is that it facilitates individual retrieval of a piece for use in consumers that don't wish to operate on (or shouldn't have access to) the full collection. This enables you to retain the granular access that individual data objects provide without the overhead of data object creation and async access of handles.
The specific access mechanisms can vary -- in this example, ContactCollection
has getContacts()
and getContact()
methods which return Contact
objects. getContacts()
is used in the renderContactCollection()
view, and getContact()
is used by the app to retrieve a singular Contact
for use with the renderContact()
view.
For another example of this pattern, consider the SharedDirectory
DDS. The getWorkingDirectory()
method allows granular access to an IDirectory
that can be used separately from the remainder of the SharedDirectory
, despite the data being stored in the same data store. Although the details differ since it is a DDS rather than a data object, the principle is the same.
You can run this example using the following steps:
- Enable corepack by running
corepack enable
. - Run
pnpm install
andpnpm run build:fast --nolint
from theFluidFramework
root directory.- For an even faster build, you can add the package name to the build command, like this:
pnpm run build:fast --nolint @fluid-example/contact-collection
- For an even faster build, you can add the package name to the build command, like this:
- In a separate terminal, start a Tinylicious server by following the instructions in Tinylicious.
- Run
pnpm start
from this directory and open http://localhost:8080 in a web browser to see the app running.
npm run test:jest
For in browser testing update ./jest-puppeteer.config.js
to:
launch: {
dumpio: true, // output browser console to cmd line
slowMo: 500,
headless: false,
},
Contact collection uses the following distributed data structures:
- SharedDirectory -- root