openmct/platform
Andrew Henry 92737b43af
[API] Changes to mutation API (#3483)
Changes how object mutation works behind the scenes in order to keep objects in sync automatically when their model changes.

* The way that objects are mutated and observed has not changed, openmct.objects.mutate and openmct.objects.observe should still be used in the same way that they were before.

* Behind the scenes, domain objects that are mutable are wrapped in a new MutableDomainObject that exposes mutator and observer functions that allow objects to be mutated in such a way that all instances can be kept in sync.

* It is now possible to retrieve MutableDomainObjects from the API, instead of regular domain objects. These are automatically updated when mutation occurs on any instance of the object, replacing the need for "*" listeners. Note that the view API now provides objects in this form by default. Therefore, you do not need to do anything differently in views, the domain objects will just magically keep themselves up to date.

* If for some reason you need to retrieve an object manually via openmct.objects.get (you should ask why you need to do this) and you want it to magically keep itself in sync, there is a new API function named openmct.objects.getMutable(identifier). Note that if you do this you will be responsible for the object's lifecycle. It relies on listeners which must be destroyed when the object is no longer needed, otherwise memory leaks will occur. You can destroy a MutableDomainObject and its (internal) listeners by calling openmct.objects.destroyMutable(mutableDomainObject). Any listeners created by calls to openmct.objects.observe need to be cleaned up separately.

* If the composition of a MutableDomainObject is retrieved using the Composition API, all children will be returned as MutableDomainObjects automatically. Their lifecycle will be managed automatically, and is tied to the lifecycle of the parent.
Any MutableDomainObject provided by the Open MCT framework itself (eg. provided to view providers by the View API, or from the composition API) will have its lifecycle managed by Open MCT, you don't need to worry destroying it.
2021-01-17 14:15:09 -08:00
..
commonUI [API] Changes to mutation API (#3483) 2021-01-17 14:15:09 -08:00
containment [API] Changes to mutation API (#3483) 2021-01-17 14:15:09 -08:00
core Legacy and new object providers work together (#3461) 2020-10-19 10:17:18 -07:00
data [Documentation] Updated copyright statement. Fixes #1081 2016-07-12 16:55:57 -07:00
entanglement Move action (#3356) 2020-11-24 14:37:28 -08:00
execution Bump copyright year to 2020 (#3169) 2020-09-14 11:17:31 -07:00
exporters Bump copyright year to 2020 (#3169) 2020-09-14 11:17:31 -07:00
features [Inspector] Allow styles (including font and font size) to be saved and reused (#3432) 2020-11-02 12:35:43 -08:00
forms Plan view to display activities (#3413) 2020-10-02 11:13:04 -07:00
framework Bump copyright year to 2020 (#3169) 2020-09-14 11:17:31 -07:00
identity Bump copyright year to 2020 (#3169) 2020-09-14 11:17:31 -07:00
import-export Three Dot Menu Prototype (#3325) 2020-11-19 09:53:06 -08:00
persistence Bump copyright year to 2020 (#3169) 2020-09-14 11:17:31 -07:00
policy Bump copyright year to 2020 (#3169) 2020-09-14 11:17:31 -07:00
representation Bump copyright year to 2020 (#3169) 2020-09-14 11:17:31 -07:00
search [Search] Index domain object type and provide query lite (index only) option (#3416) 2021-01-08 14:16:01 -08:00
status Bump copyright year to 2020 (#3169) 2020-09-14 11:17:31 -07:00
telemetry Bump copyright year to 2020 (#3169) 2020-09-14 11:17:31 -07:00
README.md [Documentation] Updated copyright statement. Fixes #1081 2016-07-12 16:55:57 -07:00

This directory contains all bundles for the Open MCT platform, as well as the framework which runs them.