DisplayedTrailsProperty¶
Overview¶
A Property that will contain a list of Trails where the root of the trail is a root Node of a Display, and the leaf node is the provided Node.
// REVIEW: This is a very complicated component and deserves a bit more doc. Some ideas about what to explain: // REVIEW: 1. That this is synchronously updated and doesn't listen to instances. // REVIEW: 2. // REVIEW: 2. // REVIEW: 2.
// REVIEW: can you describe this a bit more. Do you mean any Node in a trail? What about if the provided Node is disposed? NOTE: If a Node is disposed, it will be removed from the trails.
@author Jonathan Olson <jonathan.olson@colorado.edu>
Class DisplayedTrailsProperty¶
Constructor¶
new DisplayedTrailsProperty( node : Node, providedOptions? : DisplayedTrailsPropertyOptions )¶
Instance Methods¶
dispose()¶
REVIEW: I always forget why you don't need to also clear your reference to the provided Node. Do you? REVIEW: Also maybe assert here that your provided node is in this listened to Node set?
Instance Properties¶
node : Node¶
(readonly)
REVIEW: How about a rename like "targetNode", no strong preference if you don't want to.
listenedNodeSet : Set<Node>¶
(readonly)
REVIEW: Please add doc why we only need to listen to a Node once, even if it is in multiple trails?
Type DisplayedTrailsPropertyOptions¶
- display?: DisplayPredicate
If provided, we will only report trails that are rooted for the specific Display provided. - followPDOMOrder?: boolean
If true, we will additionally follow the pdomParent if it is available (if our child node is specified in a pdomOrder of another node, we will follow that order). This essentially tracks the following:
REVIEW: I'd actually add [a-z]?Pdom[A-Z] to phet/bad-sim-text if you're alright with that. Close to https://github.com/phetsims/chipper/blob/f56c273970f22f857bc8f5bd0148f256534a702f/eslint/rules/bad-sim-text.js#L35-L36
REVIEW: Aren't these boolean values opposite? followPDOMOrder:true should respect pdomOrder. Also, it isn't clear from the doc how you ask for "all trails, visual or PDOM". Is that part of the featureset? I believe that likely we would always force visible as a base feature, and only add on visibility, but this should be explained. As easy as the doc update above I just did: "we will additionally follow the pdomParent" - followPDOMOrder: true = visual trails (just children) - followPDOMOrder: false = pdom trails (respecting pdomOrder) - requireVisible?: boolean
If true, we will only report trails where every node is visible: true. - requirePDOMVisible?: boolean
If true, we will only report trails where every node is pdomVisible: true. - requireEnabled?: boolean
If true, we will only report trails where every node is enabled: true. - requireInputEnabled?: boolean
If true, we will only report trails where every node is inputEnabled: true.
Source Code¶
See the source for DisplayedTrailsProperty.ts in the scenery repository.