Content instances of specific classes specification
TypeScript type: ContentInstancesOfSpecificClassesSpecification.
This specification creates content for all instances of specific ECClasses.
Attributes
Attribute: classes
Defines a set of multi schema classes that specify which ECClasses need to be selected to form the result.
// The specification returns content of all `bis.PhysicalModel` classes.
const ruleset: Ruleset = {
id: "example",
rules: [
{
ruleType: "Content",
specifications: [
{
specType: "ContentInstancesOfSpecificClasses",
classes: { schemaName: "BisCore", classNames: ["PhysicalModel"], arePolymorphic: false },
},
],
},
],
};
data:image/s3,"s3://crabby-images/6dce2/6dce233b63d158e378436193f9fc8ccbb3d3654c" alt="Example of using "classes" attribute"
Attribute: excludedClasses
Defines a set of multi schema classes that prevents specified ECClasses and subclasses from being selected by classes
attribute.
// The specification returns content of all classes derived from `bis.Model` except for excluded `bis.PhysicalModel` class.
const ruleset: Ruleset = {
id: "example",
rules: [
{
ruleType: "Content",
specifications: [
{
specType: "ContentInstancesOfSpecificClasses",
classes: { schemaName: "BisCore", classNames: ["Model"], arePolymorphic: true },
excludedClasses: { schemaName: "BisCore", classNames: ["PhysicalModel"] },
},
],
},
],
};
|
Result |
excludedClasses: [] |
data:image/s3,"s3://crabby-images/68fec/68fec5c0b61cd054082ab8bf0f295b48f4e145a3" alt="Example when doing normal class based instance select" |
excludedClasses as defined in the above ruleset |
data:image/s3,"s3://crabby-images/9d26e/9d26e81fe8329747744ebf1426eccbd2134375b3" alt="Example when selecting instances with some classes excluded" |
Attribute: handlePropertiesPolymorphically
Specifies whether properties of derived classes should be included in the content.
|
|
Type |
boolean |
Is Required |
No |
Default Value |
false |
// This ruleset returns content of all `bis.ViewDefinition` instances, including all properties from derived classes.
const ruleset: Ruleset = {
id: "example",
rules: [
{
ruleType: "Content",
specifications: [
{
specType: "ContentInstancesOfSpecificClasses",
classes: { schemaName: "BisCore", classNames: ["ViewDefinition"], arePolymorphic: true },
handlePropertiesPolymorphically: true,
},
],
},
],
};
|
Result |
handlePropertiesPolymorphically: false |
data:image/s3,"s3://crabby-images/724a1/724a1a1f9064b2509c143fdf07d6987c46d9546e" alt="Example when only selecting class specified properties" |
handlePropertiesPolymorphically: true |
data:image/s3,"s3://crabby-images/dfabc/dfabc979cb20c011ea6aa340a877fb9186c574b8" alt="Example when selecting parent and child class properties" |
Attribute: instanceFilter
Specifies an ECExpression for filtering instances of ECClasses specified through the classes
attribute.
// This ruleset returns content of all `bis.SpatialViewDefinition` instances whose `Pitch` property is greater or equal to 0.
const ruleset: Ruleset = {
id: "example",
rules: [
{
ruleType: "Content",
specifications: [
{
specType: "ContentInstancesOfSpecificClasses",
classes: { schemaName: "BisCore", classNames: ["SpatialViewDefinition"] },
instanceFilter: "this.Pitch >= 0",
},
],
},
],
};
|
Result |
instanceFilter: "" |
data:image/s3,"s3://crabby-images/a3c6a/a3c6aa1029c4d20a5f4b70e5e3a402db74a5eacf" alt="Example when selecting all instances" |
instanceFilter as defined in the above ruleset |
data:image/s3,"s3://crabby-images/e5a8a/e5a8aafba440c5be85208103f85c04f73c9a9efd" alt="Example when filtering instances" |
Attribute: onlyIfNotHandled
When true
, the specification takes effect only when all other specifications with higher priority are ruled out. This attribute is most useful for defining fallback specifications.
|
|
Type |
boolean |
Is Required |
No |
Default Value |
false |
// This ruleset defines two specifications that return content for `bis.ViewDefinition` and `bis.PhysicalModel`
// instances respectively.
const ruleset: Ruleset = {
id: "example",
rules: [
{
ruleType: "Content",
specifications: [
{
specType: "ContentInstancesOfSpecificClasses",
classes: { schemaName: "BisCore", classNames: ["ViewDefinition"], arePolymorphic: true },
},
// The following specification is defined second so it's lower in priority. Because it has `onlyIfNotHandled` attribute,
// it's overriden by the specification above.
{
specType: "ContentInstancesOfSpecificClasses",
classes: { schemaName: "BisCore", classNames: ["PhysicalModel"], arePolymorphic: true },
onlyIfNotHandled: true,
},
],
},
],
};
|
Result |
onlyIfNotHandled: true |
data:image/s3,"s3://crabby-images/b4256/b4256c27aa678e0273d30cdfd44ab3c9d9051826" alt="Example using both specifications" |
onlyIfNotHandled: false |
data:image/s3,"s3://crabby-images/0a490/0a49063710af57dd338487b8501b825330859a3e" alt="Example with "only if not handled" specifications" |
Attribute: priority
Controls the order in which specifications are handled — specification with higher priority value is handled first. If priorities are equal, the specifications are handled in the order they appear in the ruleset.
|
|
Type |
number |
Is Required |
No |
Default Value |
1000 |
// Specifications to return content for `bis.PhysicalModel` and `bis.DictionaryModel` respectively.
// The `bis.PhysicalModel` specification has lower priority so it's displayed after the
// higher priority specification.
const ruleset: Ruleset = {
id: "example",
rules: [
{
ruleType: "Content",
specifications: [
{
specType: "ContentInstancesOfSpecificClasses",
classes: { schemaName: "BisCore", classNames: ["PhysicalModel"] },
priority: 0,
},
{
specType: "ContentInstancesOfSpecificClasses",
classes: { schemaName: "BisCore", classNames: ["DictionaryModel"] },
priority: 1,
},
],
},
],
};
data:image/s3,"s3://crabby-images/323e6/323e6093b56d0078093747bc824f1fa95babef7b" alt="Example of using "priority" attribute"
Attribute: relatedProperties
Specifications of related properties which are included in the generated content.
// This ruleset returns content for `bis.SpatialViewDefinition`, which includes all properties from related `bis.DisplayStyle` instances.
const ruleset: Ruleset = {
id: "example",
rules: [
{
ruleType: "Content",
specifications: [
{
specType: "ContentInstancesOfSpecificClasses",
classes: { schemaName: "BisCore", classNames: ["SpatialViewDefinition"] },
relatedProperties: [
{
propertiesSource: {
relationship: { schemaName: "BisCore", className: "ViewDefinitionUsesDisplayStyle" },
direction: "Forward",
},
},
],
},
],
},
],
};
relatedProperties: [] |
relatedProperties as defined in the above ruleset |
data:image/s3,"s3://crabby-images/87740/8774040c19b9ed7c4286631e002d7189f4e172e9" alt="Example when doing normal property select" |
data:image/s3,"s3://crabby-images/907fd/907fd1ece1979dfec42611fb54a6936f5af390a1" alt="Example when selecting with "related properties"" |
Attribute: calculatedProperties
Specifications of calculated properties whose values are generated using provided ECExpressions.
// In addition to returning content for all `bis.SpatialViewDefinition` instances, this ruleset also adds a
// custom `Camera view direction` property to each instance.
const ruleset: Ruleset = {
id: "example",
rules: [
{
ruleType: "Content",
specifications: [
{
specType: "ContentInstancesOfSpecificClasses",
classes: { schemaName: "BisCore", classNames: ["SpatialViewDefinition"] },
calculatedProperties: [
{
label: "Camera view direction",
value: 'IIf (this.pitch >= 10, "Vertical upwards", IIf (this.pitch <= -10, "Vertical downwards", "Horizontal"))',
},
],
},
],
},
],
};
data:image/s3,"s3://crabby-images/13e9d/13e9d9b653c9f971b5985d71773b2ac2b0588eb1" alt="Example of using "calculated properties" attribute"
Attribute: propertyCategories
Defines a list of custom categories.
Custom categories are not present in the result unless they contain at least one property. To assign a property to the category, reference its id
in PropertySpecification.categoryId
when defining propertyOverrides
.
// This ruleset places camera-related `bis.SpatialViewDefinition` properties inside a custom category.
const ruleset: Ruleset = {
id: "example",
rules: [
{
ruleType: "Content",
specifications: [
{
specType: "ContentInstancesOfSpecificClasses",
classes: { schemaName: "BisCore", classNames: ["SpatialViewDefinition"] },
propertyCategories: [
{
id: "camera_category",
label: "Camera settings",
autoExpand: true,
},
],
propertyOverrides: [
{ name: "EyePoint", categoryId: "camera_category" },
{ name: "FocusDistance", categoryId: "camera_category" },
{ name: "IsCameraOn", categoryId: "camera_category" },
],
},
],
},
],
};
data:image/s3,"s3://crabby-images/6ae35/6ae357ad0c5e53a38a36433e6f1056100f2f8931" alt="Example of using "property categories" attribute"
Attribute: propertyOverrides
Specifications of various property overrides that allow customizing individual properties display.
// The specification returns content for `bis.ViewDefinition` with one
// overriden property label.
const ruleset: Ruleset = {
id: "example",
rules: [
{
ruleType: "Content",
specifications: [
{
specType: "ContentInstancesOfSpecificClasses",
classes: { schemaName: "BisCore", classNames: ["ViewDefinition"], arePolymorphic: true },
propertyOverrides: [{ name: "Model", labelOverride: "Container Model" }],
},
],
},
],
};
|
Result |
propertyOverrides: [] |
data:image/s3,"s3://crabby-images/32b21/32b213071f42c46149aec6e5b847f78fd9af2a8b" alt="Example when doing normal property select" |
propertyOverrides as defined in the above ruleset |
data:image/s3,"s3://crabby-images/10743/10743abab6509a07e775fc99f7e4bf3a7a39c306" alt="Example when selecting with "property overrides"" |
Attribute: relatedInstances
Specifications of related instances that can be used when creating the content. There are several use cases when this is useful:
When there's a need to only load instances that have a related instance. Providing a related instance
specification with isRequired set to true
filters-out the instances that don't have the related instance.
When there's a need to filter instances by a related instance value. The alias attribute may then be used
in the instanceFilter
attribute to reference related instance property values.
When there's a need to customize content based on related instance property values. Related instance classes are included when looking for customization rules,
which allows referencing related instances and their properties in customization rule ECExpressions by their
alias.
// The specification returns content for `bis.ModelSelector` filtered by related
// `bis.SpatialViewDefinition` instance `Yaw` property value.
const ruleset: Ruleset = {
id: "example",
rules: [
{
ruleType: "Content",
specifications: [
{
specType: "ContentInstancesOfSpecificClasses",
classes: { schemaName: "BisCore", classNames: ["ModelSelector"], arePolymorphic: true },
relatedInstances: [
{
relationshipPath: { relationship: { schemaName: "BisCore", className: "SpatialViewDefinitionUsesModelSelector" }, direction: "Backward" },
alias: "relatedInstance",
},
],
instanceFilter: "relatedInstance.Yaw > 0",
},
],
},
],
};
|
Result |
SpatialViewDefinition instances |
data:image/s3,"s3://crabby-images/fe57a/fe57a11006f3e9b768fd8c773df2978facf1cbc6" alt="A list of spatial view definitions" |
ModelSelector instances |
data:image/s3,"s3://crabby-images/2f745/2f7457d26f7c8a9d06dd0314a8bc173c6eaf8f69" alt="A list of model selectors" |
ModelSelector instances filtered by SpatialViewDefinition.Yaw |
data:image/s3,"s3://crabby-images/4c888/4c88878aa43b544d40a869dfb54fe7860fa52d82" alt="A list of model selectors filtered by yaw of related spatial view definition" |