openmct/platform/entanglement
Andrew Henry cbcfd44016 Elements pool and drag drop (#2196)
* Implemented drag-and-drop composition

* Added composition policy for tables

* Reimplemented elements pool in Vue

* No need to resolve all objects on the navigated path

* Only show elements pool in edit mode

* Remove old elements pool

* Updated legacy code to use composition policy API

* Keep object in sync when mutated
2018-10-23 10:52:37 -07:00
..
src Elements pool and drag drop (#2196) 2018-10-23 10:52:37 -07:00
test Build refactor to webpack (#2139) 2018-08-07 14:47:50 -07:00
bundle.js Elements pool and drag drop (#2196) 2018-10-23 10:52:37 -07:00
README.md Typo corrections, I avoided making changes to words that have regional spelling differences. 2016-09-03 09:16:54 -04:00

Entanglement

Entanglement is the process of moving, copying, and linking domain objects in such a way that their relationships are impossible to discern.

This bundle provides move, copy, and link functionality. Achieving a state of entanglement is left up to the end user.

Services implement logic

Each method (move, copy, link) is implemented as a service, and each service provides two functions: validate and perform.

validate(object, parentCandidate) returns true if the object can be move/copy/linked into the parentCandidate's composition.

perform(object, parentObject) move/copy/links the object into the parentObject's composition.

Actions implement user interactions

Actions are used to expose move/copy/link to the user. They prompt for input where necessary, and complete the actions.