UNPKG

@itwin/presentation-common

Version:

Common pieces for iModel.js presentation packages

57 lines 2.82 kB
/** @packageDocumentation * @module PresentationRules */ import { SingleSchemaClassSpecification } from "./ClassSpecifications.js"; import { RelationshipDirection } from "./RelationshipDirection.js"; /** * Specification of a single step in [[RelationshipPathSpecification]]. * * @see [Relationship path specification reference documentation page]($docs/presentation/RelationshipPathSpecification.md) * @public */ export interface RelationshipStepSpecification { /** This attribute specifies the ECRelationship that should be used to traverse to target class. */ relationship: SingleSchemaClassSpecification; /** * This attribute specifies the direction in which the [[relationship]] should be followed. * @see RelationshipDirection */ direction: `${RelationshipDirection}`; /** * This attribute may be used to specialize the target of the relationship. */ targetClass?: SingleSchemaClassSpecification; } /** * Specification of a single step in [[RepeatableRelationshipPathSpecification]]. * * @see [Repeatable relationship path specification reference documentation page]($docs/presentation/RepeatableRelationshipPathSpecification.md) * @public */ export interface RepeatableRelationshipStepSpecification extends RelationshipStepSpecification { /** * When a number is specified, the relationship is traversed recursively the specified number of times. * * When it is set to a special value `"*"`, the same relationship is traversed recursively unbounded number * of times, starting from zero (the relationship is not followed). On each traversal iteration, Presentation * rules engine accumulates all indirectly related ECInstances as defined by the remaining relationship path. */ count?: number | "*"; } /** * Relationship path specification is used to define a relationship path to an ECClass. * * @see [Relationship path specification reference documentation page]($docs/presentation/RelationshipPathSpecification.md) * @public */ export type RelationshipPathSpecification = RelationshipStepSpecification | RelationshipStepSpecification[]; /** * This specification declares a step in a relationship path between a source and target ECInstances. A step * can optionally be repeated a number of times to traverse the same relationship recursively. Multiple * specifications of this type can be chained together to express complex indirect relationships. * * @see [Repeatable relationship path specification reference documentation page]($docs/presentation/RepeatableRelationshipPathSpecification.md) * @public */ export type RepeatableRelationshipPathSpecification = RepeatableRelationshipStepSpecification | RepeatableRelationshipStepSpecification[]; //# sourceMappingURL=RelationshipPathSpecification.d.ts.map