@itwin/core-frontend 4.4.0-dev.8 → 4.5.0-dev.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (204) hide show
  1. package/CHANGELOG.md +8 -1
  2. package/lib/cjs/DisplayStyleState.d.ts +3 -0
  3. package/lib/cjs/DisplayStyleState.d.ts.map +1 -1
  4. package/lib/cjs/DisplayStyleState.js +10 -0
  5. package/lib/cjs/DisplayStyleState.js.map +1 -1
  6. package/lib/cjs/Viewport.d.ts +5 -0
  7. package/lib/cjs/Viewport.d.ts.map +1 -1
  8. package/lib/cjs/Viewport.js +6 -0
  9. package/lib/cjs/Viewport.js.map +1 -1
  10. package/lib/cjs/common/gltf/GltfSchema.d.ts +20 -3
  11. package/lib/cjs/common/gltf/GltfSchema.d.ts.map +1 -1
  12. package/lib/cjs/common/gltf/GltfSchema.js.map +1 -1
  13. package/lib/cjs/common/imdl/ImdlModel.d.ts +15 -1
  14. package/lib/cjs/common/imdl/ImdlModel.d.ts.map +1 -1
  15. package/lib/cjs/common/imdl/ImdlModel.js +11 -3
  16. package/lib/cjs/common/imdl/ImdlModel.js.map +1 -1
  17. package/lib/cjs/common/imdl/ParseImdlDocument.d.ts +3 -1
  18. package/lib/cjs/common/imdl/ParseImdlDocument.d.ts.map +1 -1
  19. package/lib/cjs/common/imdl/ParseImdlDocument.js +66 -11
  20. package/lib/cjs/common/imdl/ParseImdlDocument.js.map +1 -1
  21. package/lib/cjs/render/GraphicBranch.d.ts +10 -0
  22. package/lib/cjs/render/GraphicBranch.d.ts.map +1 -1
  23. package/lib/cjs/render/GraphicBranch.js.map +1 -1
  24. package/lib/cjs/render/webgl/BranchState.d.ts +2 -0
  25. package/lib/cjs/render/webgl/BranchState.d.ts.map +1 -1
  26. package/lib/cjs/render/webgl/BranchState.js +2 -0
  27. package/lib/cjs/render/webgl/BranchState.js.map +1 -1
  28. package/lib/cjs/render/webgl/Graphic.d.ts.map +1 -1
  29. package/lib/cjs/render/webgl/Graphic.js +3 -0
  30. package/lib/cjs/render/webgl/Graphic.js.map +1 -1
  31. package/lib/cjs/render/webgl/InstancedGeometry.d.ts +1 -0
  32. package/lib/cjs/render/webgl/InstancedGeometry.d.ts.map +1 -1
  33. package/lib/cjs/render/webgl/InstancedGeometry.js +1 -0
  34. package/lib/cjs/render/webgl/InstancedGeometry.js.map +1 -1
  35. package/lib/cjs/request/utils.d.ts +18 -0
  36. package/lib/cjs/request/utils.d.ts.map +1 -0
  37. package/lib/cjs/request/utils.js +45 -0
  38. package/lib/cjs/request/utils.js.map +1 -0
  39. package/lib/cjs/tile/BatchedTileIdMap.d.ts +1 -2
  40. package/lib/cjs/tile/BatchedTileIdMap.d.ts.map +1 -1
  41. package/lib/cjs/tile/BatchedTileIdMap.js +3 -3
  42. package/lib/cjs/tile/BatchedTileIdMap.js.map +1 -1
  43. package/lib/cjs/tile/GltfReader.d.ts +4 -1
  44. package/lib/cjs/tile/GltfReader.d.ts.map +1 -1
  45. package/lib/cjs/tile/GltfReader.js +125 -26
  46. package/lib/cjs/tile/GltfReader.js.map +1 -1
  47. package/lib/cjs/tile/ImdlDecoder.d.ts +7 -1
  48. package/lib/cjs/tile/ImdlDecoder.d.ts.map +1 -1
  49. package/lib/cjs/tile/ImdlDecoder.js.map +1 -1
  50. package/lib/cjs/tile/ImdlGraphicsCreator.d.ts.map +1 -1
  51. package/lib/cjs/tile/ImdlGraphicsCreator.js +28 -17
  52. package/lib/cjs/tile/ImdlGraphicsCreator.js.map +1 -1
  53. package/lib/cjs/tile/ImdlReader.d.ts +2 -1
  54. package/lib/cjs/tile/ImdlReader.d.ts.map +1 -1
  55. package/lib/cjs/tile/ImdlReader.js +1 -0
  56. package/lib/cjs/tile/ImdlReader.js.map +1 -1
  57. package/lib/cjs/tile/RealityModelTileTree.d.ts.map +1 -1
  58. package/lib/cjs/tile/RealityModelTileTree.js +2 -3
  59. package/lib/cjs/tile/RealityModelTileTree.js.map +1 -1
  60. package/lib/cjs/tile/RealityTileTree.d.ts +31 -0
  61. package/lib/cjs/tile/RealityTileTree.d.ts.map +1 -1
  62. package/lib/cjs/tile/RealityTileTree.js +6 -0
  63. package/lib/cjs/tile/RealityTileTree.js.map +1 -1
  64. package/lib/cjs/tile/TileDrawArgs.d.ts +6 -0
  65. package/lib/cjs/tile/TileDrawArgs.d.ts.map +1 -1
  66. package/lib/cjs/tile/TileDrawArgs.js +7 -0
  67. package/lib/cjs/tile/TileDrawArgs.js.map +1 -1
  68. package/lib/cjs/tile/TileTreeReference.d.ts +2 -0
  69. package/lib/cjs/tile/TileTreeReference.d.ts.map +1 -1
  70. package/lib/cjs/tile/TileTreeReference.js +5 -0
  71. package/lib/cjs/tile/TileTreeReference.js.map +1 -1
  72. package/lib/cjs/tile/map/ArcGISTileMap.d.ts +6 -2
  73. package/lib/cjs/tile/map/ArcGISTileMap.d.ts.map +1 -1
  74. package/lib/cjs/tile/map/ArcGISTileMap.js +127 -69
  75. package/lib/cjs/tile/map/ArcGISTileMap.js.map +1 -1
  76. package/lib/cjs/tile/map/ArcGisUtilities.d.ts.map +1 -1
  77. package/lib/cjs/tile/map/ArcGisUtilities.js +5 -0
  78. package/lib/cjs/tile/map/ArcGisUtilities.js.map +1 -1
  79. package/lib/cjs/tile/map/ImageryProviders/ArcGISImageryProvider.d.ts.map +1 -1
  80. package/lib/cjs/tile/map/ImageryProviders/ArcGISImageryProvider.js +61 -39
  81. package/lib/cjs/tile/map/ImageryProviders/ArcGISImageryProvider.js.map +1 -1
  82. package/lib/cjs/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.js +1 -1
  83. package/lib/cjs/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.js.map +1 -1
  84. package/lib/cjs/tile/map/MapLayerImageryProvider.d.ts +6 -0
  85. package/lib/cjs/tile/map/MapLayerImageryProvider.d.ts.map +1 -1
  86. package/lib/cjs/tile/map/MapLayerImageryProvider.js +47 -7
  87. package/lib/cjs/tile/map/MapLayerImageryProvider.js.map +1 -1
  88. package/lib/cjs/tile/map/WmsCapabilities.d.ts.map +1 -1
  89. package/lib/cjs/tile/map/WmsCapabilities.js +1 -15
  90. package/lib/cjs/tile/map/WmsCapabilities.js.map +1 -1
  91. package/lib/cjs/tile/map/WmsUtilities.d.ts +7 -0
  92. package/lib/cjs/tile/map/WmsUtilities.d.ts.map +1 -1
  93. package/lib/cjs/tile/map/WmsUtilities.js +22 -0
  94. package/lib/cjs/tile/map/WmsUtilities.js.map +1 -1
  95. package/lib/cjs/tile/map/WmtsCapabilities.d.ts.map +1 -1
  96. package/lib/cjs/tile/map/WmtsCapabilities.js +2 -16
  97. package/lib/cjs/tile/map/WmtsCapabilities.js.map +1 -1
  98. package/lib/cjs/tools/SelectTool.d.ts +1 -0
  99. package/lib/cjs/tools/SelectTool.d.ts.map +1 -1
  100. package/lib/cjs/tools/SelectTool.js +19 -13
  101. package/lib/cjs/tools/SelectTool.js.map +1 -1
  102. package/lib/esm/DisplayStyleState.d.ts +3 -0
  103. package/lib/esm/DisplayStyleState.d.ts.map +1 -1
  104. package/lib/esm/DisplayStyleState.js +10 -0
  105. package/lib/esm/DisplayStyleState.js.map +1 -1
  106. package/lib/esm/Viewport.d.ts +5 -0
  107. package/lib/esm/Viewport.d.ts.map +1 -1
  108. package/lib/esm/Viewport.js +6 -0
  109. package/lib/esm/Viewport.js.map +1 -1
  110. package/lib/esm/common/gltf/GltfSchema.d.ts +20 -3
  111. package/lib/esm/common/gltf/GltfSchema.d.ts.map +1 -1
  112. package/lib/esm/common/gltf/GltfSchema.js.map +1 -1
  113. package/lib/esm/common/imdl/ImdlModel.d.ts +15 -1
  114. package/lib/esm/common/imdl/ImdlModel.d.ts.map +1 -1
  115. package/lib/esm/common/imdl/ImdlModel.js +11 -3
  116. package/lib/esm/common/imdl/ImdlModel.js.map +1 -1
  117. package/lib/esm/common/imdl/ParseImdlDocument.d.ts +3 -1
  118. package/lib/esm/common/imdl/ParseImdlDocument.d.ts.map +1 -1
  119. package/lib/esm/common/imdl/ParseImdlDocument.js +67 -12
  120. package/lib/esm/common/imdl/ParseImdlDocument.js.map +1 -1
  121. package/lib/esm/render/GraphicBranch.d.ts +10 -0
  122. package/lib/esm/render/GraphicBranch.d.ts.map +1 -1
  123. package/lib/esm/render/GraphicBranch.js.map +1 -1
  124. package/lib/esm/render/webgl/BranchState.d.ts +2 -0
  125. package/lib/esm/render/webgl/BranchState.d.ts.map +1 -1
  126. package/lib/esm/render/webgl/BranchState.js +2 -0
  127. package/lib/esm/render/webgl/BranchState.js.map +1 -1
  128. package/lib/esm/render/webgl/Graphic.d.ts.map +1 -1
  129. package/lib/esm/render/webgl/Graphic.js +3 -0
  130. package/lib/esm/render/webgl/Graphic.js.map +1 -1
  131. package/lib/esm/render/webgl/InstancedGeometry.d.ts +1 -0
  132. package/lib/esm/render/webgl/InstancedGeometry.d.ts.map +1 -1
  133. package/lib/esm/render/webgl/InstancedGeometry.js +1 -0
  134. package/lib/esm/render/webgl/InstancedGeometry.js.map +1 -1
  135. package/lib/esm/request/utils.d.ts +18 -0
  136. package/lib/esm/request/utils.d.ts.map +1 -0
  137. package/lib/esm/request/utils.js +40 -0
  138. package/lib/esm/request/utils.js.map +1 -0
  139. package/lib/esm/tile/BatchedTileIdMap.d.ts +1 -2
  140. package/lib/esm/tile/BatchedTileIdMap.d.ts.map +1 -1
  141. package/lib/esm/tile/BatchedTileIdMap.js +3 -3
  142. package/lib/esm/tile/BatchedTileIdMap.js.map +1 -1
  143. package/lib/esm/tile/GltfReader.d.ts +4 -1
  144. package/lib/esm/tile/GltfReader.d.ts.map +1 -1
  145. package/lib/esm/tile/GltfReader.js +126 -27
  146. package/lib/esm/tile/GltfReader.js.map +1 -1
  147. package/lib/esm/tile/ImdlDecoder.d.ts +7 -1
  148. package/lib/esm/tile/ImdlDecoder.d.ts.map +1 -1
  149. package/lib/esm/tile/ImdlDecoder.js.map +1 -1
  150. package/lib/esm/tile/ImdlGraphicsCreator.d.ts.map +1 -1
  151. package/lib/esm/tile/ImdlGraphicsCreator.js +28 -17
  152. package/lib/esm/tile/ImdlGraphicsCreator.js.map +1 -1
  153. package/lib/esm/tile/ImdlReader.d.ts +2 -1
  154. package/lib/esm/tile/ImdlReader.d.ts.map +1 -1
  155. package/lib/esm/tile/ImdlReader.js +1 -0
  156. package/lib/esm/tile/ImdlReader.js.map +1 -1
  157. package/lib/esm/tile/RealityModelTileTree.d.ts.map +1 -1
  158. package/lib/esm/tile/RealityModelTileTree.js +2 -3
  159. package/lib/esm/tile/RealityModelTileTree.js.map +1 -1
  160. package/lib/esm/tile/RealityTileTree.d.ts +31 -0
  161. package/lib/esm/tile/RealityTileTree.d.ts.map +1 -1
  162. package/lib/esm/tile/RealityTileTree.js +6 -0
  163. package/lib/esm/tile/RealityTileTree.js.map +1 -1
  164. package/lib/esm/tile/TileDrawArgs.d.ts +6 -0
  165. package/lib/esm/tile/TileDrawArgs.d.ts.map +1 -1
  166. package/lib/esm/tile/TileDrawArgs.js +8 -1
  167. package/lib/esm/tile/TileDrawArgs.js.map +1 -1
  168. package/lib/esm/tile/TileTreeReference.d.ts +2 -0
  169. package/lib/esm/tile/TileTreeReference.d.ts.map +1 -1
  170. package/lib/esm/tile/TileTreeReference.js +5 -0
  171. package/lib/esm/tile/TileTreeReference.js.map +1 -1
  172. package/lib/esm/tile/map/ArcGISTileMap.d.ts +6 -2
  173. package/lib/esm/tile/map/ArcGISTileMap.d.ts.map +1 -1
  174. package/lib/esm/tile/map/ArcGISTileMap.js +130 -71
  175. package/lib/esm/tile/map/ArcGISTileMap.js.map +1 -1
  176. package/lib/esm/tile/map/ArcGisUtilities.d.ts.map +1 -1
  177. package/lib/esm/tile/map/ArcGisUtilities.js +5 -0
  178. package/lib/esm/tile/map/ArcGisUtilities.js.map +1 -1
  179. package/lib/esm/tile/map/ImageryProviders/ArcGISImageryProvider.d.ts.map +1 -1
  180. package/lib/esm/tile/map/ImageryProviders/ArcGISImageryProvider.js +61 -39
  181. package/lib/esm/tile/map/ImageryProviders/ArcGISImageryProvider.js.map +1 -1
  182. package/lib/esm/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.js +1 -1
  183. package/lib/esm/tile/map/ImageryProviders/ArcGISMapLayerImageryProvider.js.map +1 -1
  184. package/lib/esm/tile/map/MapLayerImageryProvider.d.ts +6 -0
  185. package/lib/esm/tile/map/MapLayerImageryProvider.d.ts.map +1 -1
  186. package/lib/esm/tile/map/MapLayerImageryProvider.js +48 -8
  187. package/lib/esm/tile/map/MapLayerImageryProvider.js.map +1 -1
  188. package/lib/esm/tile/map/WmsCapabilities.d.ts.map +1 -1
  189. package/lib/esm/tile/map/WmsCapabilities.js +1 -15
  190. package/lib/esm/tile/map/WmsCapabilities.js.map +1 -1
  191. package/lib/esm/tile/map/WmsUtilities.d.ts +7 -0
  192. package/lib/esm/tile/map/WmsUtilities.d.ts.map +1 -1
  193. package/lib/esm/tile/map/WmsUtilities.js +22 -0
  194. package/lib/esm/tile/map/WmsUtilities.js.map +1 -1
  195. package/lib/esm/tile/map/WmtsCapabilities.d.ts.map +1 -1
  196. package/lib/esm/tile/map/WmtsCapabilities.js +2 -16
  197. package/lib/esm/tile/map/WmtsCapabilities.js.map +1 -1
  198. package/lib/esm/tools/SelectTool.d.ts +1 -0
  199. package/lib/esm/tools/SelectTool.d.ts.map +1 -1
  200. package/lib/esm/tools/SelectTool.js +19 -13
  201. package/lib/esm/tools/SelectTool.js.map +1 -1
  202. package/lib/public/scripts/parse-imdl-worker.js +1 -1
  203. package/lib/workers/webpack/parse-imdl-worker.js +1 -1
  204. package/package.json +20 -19
@@ -1 +1 @@
1
- {"version":3,"file":"WmtsCapabilities.js","sourceRoot":"","sources":["../../../../src/tile/map/WmtsCapabilities.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module Views\n */\n\nimport { Point2d, Range2d } from \"@itwin/core-geometry\";\nimport { request, RequestBasicCredentials, RequestOptions } from \"../../request/Request\";\nimport { MapCartoRectangle, WmsUtilities } from \"../internal\"; // WmsUtilities needed for getBaseUrl\n\nenum OwsConstants {\n ABSTRACT_XMLTAG = \"ows:Abstract\",\n ACCESSCONSTRAINTS_XMLTAG = \"ows:AccessConstraints\",\n ALLOWEDVALUES_XMLTAG = \"ows:AllowedValues\",\n BOUNDINGBOX_XMLTAG = \"ows:BoundingBox\",\n CONSTRAINT_XMLTAG = \"ows:Constraint\",\n DCP_XMLTAG = \"ows:DCP\",\n FEES_XMLTAG = \"ows:Fees\",\n GET_XMLTAG = \"ows:Get\",\n HTTP_XMLTAG = \"ows:HTTP\",\n IDENTIFIER_XMLTAG = \"ows:Identifier\",\n KEYWORDS_XMLTAG = \"ows:Keywords\",\n KEYWORD_XMLTAG = \"ows:Keyword\",\n LOWERCORNER_XMLTAG = \"ows:LowerCorner\",\n OPERATION_XMLTAG = \"ows:Operation\",\n OPERATIONSMETADATA_XMLTAG = \"ows:OperationsMetadata\",\n POST_XMLTAG = \"ows:Post\",\n SERVICEIDENTIFICATION_XMLTAG = \"ows:ServiceIdentification\",\n SERVICETYPE_XMLTAG = \"ows:ServiceType\",\n SERVICETYPEVERSION_XMLTAG = \"ows:ServiceTypeVersion\",\n SUPPORTEDCRS_XMLTAG = \"ows:SupportedCRS\",\n TITLE_XMLTAG = \"ows:Title\",\n UPPERCORNER_XMLTAG = \"ows:UpperCorner\",\n VALUE_XMLTAG = \"ows:Value\",\n WGS84BOUNDINGBOX_XMLTAG = \"ows:WGS84BoundingBox\"\n\n}\n\nenum XmlConstants {\n // Operations names\n GETCAPABILITIES = \"GetCapabilities\",\n GETTILE = \"GetTile\",\n GETFEATUREINFO = \"GetFeatureInfo\",\n\n MATRIXWIDTH_XMLTAG = \"MatrixWidth\",\n MATRIXHEIGHT_XMLTAG = \"MatrixHeight\",\n SCALEDENOMINATOR_XMLTAG = \"ScaleDenominator\",\n\n TILEHEIGHT_XMLTAG = \"TileHeight\",\n TILEMATRIX_XMLTAG = \"TileMatrix\",\n TILEMATRIXSETLINK_XMLTAG = \"TileMatrixSetLink\",\n TILEWIDTH_XMLTAG = \"TileWidth\",\n TOPLEFTCORNER_XMLTAG = \"TopLeftCorner\",\n WELLKNOWNSCALESET_XMLTAG = \"WellKnownScaleSet\",\n\n CONSTRAINT_NAME_FILTER = \"Encoding\",\n STYLE_ISDEFAULT = \"IsDefault\",\n XLINK_HREF = \"xlink:href\",\n}\n\n/** @internal\n*/\nexport enum WmtsConstants {\n GOOGLEMAPS_LEVEL0_SCALE_DENOM = 559082264.0287178,\n GOOGLEMAPS_COMPATIBLE_WELLKNOWNNAME = \"googlemapscompatible\",\n}\n\n/**\n * fetch XML from HTTP request\n * @param url server URL to address the request\n * @internal\n */\nasync function getXml(url: string, credentials?: RequestBasicCredentials): Promise<string> {\n const options: RequestOptions = {\n timeout: 20000,\n retryCount: 2,\n auth: credentials,\n };\n return request(url, \"text\", options);\n}\n\n/**\n * Utility function to extract an element' text content\n * @return An element's text content, default to provided defaultTest value if no text is available.\n * @param url server URL to address the request\n * @internal\n */\nconst getElementTextContent = (elem: Element, qualifiedName: string, defaultText?: string) => {\n\n const tmpElem = elem.getElementsByTagName(qualifiedName);\n if (tmpElem.length > 0) {\n return tmpElem[0].textContent ?? defaultText;\n } else\n return defaultText;\n\n};\n\n/** Encapsulation of the capabilities for an WMTS server\n * @internal\n */\nexport namespace WmtsCapability {\n export class ServiceIdentification {\n public readonly abstract?: string;\n public readonly accessConstraints?: string;\n public readonly fees?: string;\n public readonly serviceType?: string;\n public readonly serviceTypeVersion?: string;\n public readonly title?: string;\n public readonly keywords?: string[];\n\n constructor(elem: Element) {\n this.abstract = getElementTextContent(elem, OwsConstants.ABSTRACT_XMLTAG);\n this.serviceType = getElementTextContent(elem, OwsConstants.SERVICETYPE_XMLTAG);\n this.serviceTypeVersion = getElementTextContent(elem, OwsConstants.SERVICETYPEVERSION_XMLTAG);\n this.title = getElementTextContent(elem, OwsConstants.TITLE_XMLTAG);\n\n const keywords = elem.getElementsByTagName(OwsConstants.KEYWORDS_XMLTAG);\n if (keywords.length > 0) {\n const keyword = keywords[0].getElementsByTagName(OwsConstants.KEYWORD_XMLTAG);\n this.keywords = [];\n for (const keyworkElem of keyword) {\n const keyWordText = keyworkElem.textContent;\n if (keyWordText)\n this.keywords.push(keyWordText);\n }\n }\n\n this.accessConstraints = getElementTextContent(elem, OwsConstants.ACCESSCONSTRAINTS_XMLTAG);\n\n this.fees = getElementTextContent(elem, OwsConstants.FEES_XMLTAG);\n }\n }\n\n export class OperationMetadata {\n private _getCapabilities?: Operation;\n public get getCapabilities(): Operation | undefined { return this._getCapabilities; }\n\n private _getFeatureInfo?: Operation;\n public get getFeatureInfo(): Operation | undefined { return this._getFeatureInfo; }\n\n private _getTile?: Operation;\n public get getTile(): Operation | undefined { return this._getTile; }\n\n private readOperation(op: Element) {\n const nameAttr = op.attributes.getNamedItem(\"name\");\n if (!nameAttr)\n return;\n\n if (nameAttr.textContent === XmlConstants.GETCAPABILITIES) {\n this._getCapabilities = new Operation(op);\n } else if (nameAttr.textContent === XmlConstants.GETTILE) {\n this._getTile = new Operation(op);\n } else if (nameAttr.textContent === XmlConstants.GETFEATUREINFO) {\n this._getFeatureInfo = new Operation(op);\n }\n }\n\n constructor(elem: Element) {\n const operation = elem.getElementsByTagName(OwsConstants.OPERATION_XMLTAG);\n if (operation.length > 0) {\n for (const op of operation) {\n this.readOperation(op);\n }\n }\n }\n }\n\n export class HttpDcp {\n public readonly url?: string;\n public readonly constraintName?: string;\n\n // For simplicity of use we create a 'static' encoding property instead of having\n // a generic constraint data model.\n // We make sure the constraint name is 'encoding' related.\n public readonly encoding?: string;\n\n constructor(elem: Element) {\n const url = elem.getAttribute(XmlConstants.XLINK_HREF);\n if (url)\n this.url = url ?? \"\";\n\n const constraint = elem.getElementsByTagName(OwsConstants.CONSTRAINT_XMLTAG);\n if (constraint.length > 0) {\n this.constraintName = constraint[0].getAttribute(\"name\") ?? \"\";\n if (this.constraintName?.endsWith(XmlConstants.CONSTRAINT_NAME_FILTER)) {\n const allowedValues = constraint[0].getElementsByTagName(OwsConstants.ALLOWEDVALUES_XMLTAG);\n if (allowedValues.length > 0) {\n this.encoding = getElementTextContent(allowedValues[0], OwsConstants.VALUE_XMLTAG);\n }\n }\n }\n }\n }\n\n export class Operation {\n public readonly name?: string;\n private _getDcpHttp?: HttpDcp[];\n public get getDcpHttp(): HttpDcp[] | undefined { return this._getDcpHttp; }\n private _postDcpHttp?: HttpDcp[];\n public get postDcpHttp(): HttpDcp[] | undefined { return this._postDcpHttp; }\n\n constructor(elem: Element) {\n const name = elem.getAttribute(\"name\");\n if (name)\n this.name = name;\n\n const dcp = elem.getElementsByTagName(OwsConstants.DCP_XMLTAG);\n if (!dcp || dcp.length === 0)\n return;\n\n const dcpHttp = dcp[0].getElementsByTagName(OwsConstants.HTTP_XMLTAG);\n if (!dcpHttp || dcpHttp.length === 0)\n return;\n\n const get = dcpHttp[0].getElementsByTagName(OwsConstants.GET_XMLTAG);\n if (get.length > 0) {\n this._getDcpHttp = [];\n\n for (const getItem of get) {\n this._getDcpHttp?.push(new HttpDcp(getItem));\n }\n }\n\n const post = dcpHttp[0].getElementsByTagName(OwsConstants.POST_XMLTAG);\n if (post.length > 0) {\n this._postDcpHttp = [];\n\n for (const postItem of post) {\n this._postDcpHttp?.push(new HttpDcp(postItem));\n }\n }\n }\n }\n\n export class Contents {\n public readonly layers: Layer[] = [];\n public readonly tileMatrixSets: TileMatrixSet[] = [];\n\n constructor(elem: Element) {\n // Layers\n const layer = elem.getElementsByTagName(\"Layer\");\n if (layer) {\n for (const layerElem of layer)\n this.layers.push(new Layer(layerElem));\n }\n\n // TileMatrixSet\n const tms = elem.querySelectorAll(\"Contents > TileMatrixSet\");\n if (tms) {\n for (const tmsElem of tms)\n this.tileMatrixSets.push(new TileMatrixSet(tmsElem));\n }\n\n }\n\n public getGoogleMapsCompatibleTileMatrixSet(): TileMatrixSet[] {\n const googleMapsTms: TileMatrixSet[] = [];\n this.tileMatrixSets.forEach((tms) => {\n if (tms.wellKnownScaleSet?.toLowerCase().includes(WmtsConstants.GOOGLEMAPS_COMPATIBLE_WELLKNOWNNAME))\n googleMapsTms.push(tms);\n\n // In case wellKnownScaleSet was not been set properly, infer from scaleDenominator\n // Note: some servers are quite inaccurate in their scale values, hence I used a delta value of 1.\n else if (tms.tileMatrix.length > 0\n && Math.abs(tms.tileMatrix[0].scaleDenominator - WmtsConstants.GOOGLEMAPS_LEVEL0_SCALE_DENOM) < 1\n && (tms.supportedCrs.includes(\"3857\") || tms.supportedCrs.includes(\"900913\"))\n )\n googleMapsTms.push(tms);\n });\n return googleMapsTms;\n }\n\n public getEpsg4326CompatibleTileMatrixSet(): TileMatrixSet[] {\n return this.tileMatrixSets.filter((tms) => tms.supportedCrs.includes(\"4326\"));\n }\n }\n\n export class Style {\n public readonly isDefault: boolean = false;\n public readonly title?: string;\n public readonly identifier?: string;\n // TODO: LegendURL\n\n constructor(elem: Element) {\n if (!elem)\n return;\n\n const isDefault = elem.getAttribute(\"isDefault\");\n if (isDefault)\n this.isDefault = isDefault.toLowerCase() === \"true\";\n\n this.title = getElementTextContent(elem, OwsConstants.TITLE_XMLTAG);\n this.identifier = getElementTextContent(elem, OwsConstants.IDENTIFIER_XMLTAG);\n }\n }\n\n export class BoundingBox {\n public readonly crs?: string;\n public readonly range?: Range2d;\n\n constructor(elem: Element) {\n this.crs = elem.getAttribute(\"crs\") ?? undefined;\n\n const lowerCorner = getElementTextContent(elem, OwsConstants.LOWERCORNER_XMLTAG);\n const upperCorner = getElementTextContent(elem, OwsConstants.UPPERCORNER_XMLTAG);\n if (lowerCorner && upperCorner) {\n const lowerCornerArray = lowerCorner?.split(\" \").map((x: string) => +x);\n const upperCornerArray = upperCorner?.split(\" \").map((x: string) => +x);\n if (lowerCornerArray && lowerCornerArray.length === 2 && upperCornerArray && upperCornerArray.length === 2)\n this.range = Range2d.createXYXY(lowerCornerArray[0], lowerCornerArray[1], upperCornerArray[0], upperCornerArray[1]);\n }\n }\n }\n\n export class TileMatrixSetLimits {\n public limits?: Range2d;\n public tileMatrix?: string;\n\n constructor(elem: Element) {\n\n this.tileMatrix = getElementTextContent(elem, \"TileMatrix\");\n\n const minTileRow = getElementTextContent(elem, \"MinTileRow\");\n const maxTileRow = getElementTextContent(elem, \"MaxTileRow\");\n const minTileCol = getElementTextContent(elem, \"MinTileCol\");\n const maxTileCol = getElementTextContent(elem, \"MaxTileCol\");\n\n if (minTileRow !== undefined && maxTileRow !== undefined && minTileCol !== undefined && maxTileCol)\n this.limits = Range2d.createXYXY(Number(minTileCol), Number(minTileRow), Number(maxTileCol), Number(maxTileRow));\n }\n }\n\n export class TileMatrixSetLink {\n public readonly tileMatrixSet: string;\n public readonly tileMatrixSetLimits = new Array<TileMatrixSetLimits>();\n\n constructor(elem: Element) {\n\n this.tileMatrixSet = getElementTextContent(elem, \"TileMatrixSet\", \"\")!;\n\n const tileMatrixLimitsRoot = elem.getElementsByTagName(\"TileMatrixSetLimits\");\n if (tileMatrixLimitsRoot.length > 0) {\n const tileMatrixLimits = tileMatrixLimitsRoot[0].getElementsByTagName(\"TileMatrixSetLimits\");\n for (const tmsl of tileMatrixLimits) {\n this.tileMatrixSetLimits.push(new TileMatrixSetLimits(tmsl));\n }\n }\n }\n }\n\n export class TileMatrixSet {\n public readonly identifier: string;\n public readonly title?: string;\n public readonly abstract?: string;\n public readonly supportedCrs: string;\n public readonly wellKnownScaleSet: string;\n public readonly tileMatrix: TileMatrix[] = [];\n\n constructor(elem: Element) {\n const identifier = getElementTextContent(elem, OwsConstants.IDENTIFIER_XMLTAG);\n if (identifier)\n this.identifier = identifier;\n else\n throw new Error(\"No Identifier found.\");\n\n this.title = getElementTextContent(elem, OwsConstants.TITLE_XMLTAG);\n this.abstract = getElementTextContent(elem, OwsConstants.ABSTRACT_XMLTAG);\n\n const supportedCrs = getElementTextContent(elem, OwsConstants.SUPPORTEDCRS_XMLTAG);\n if (supportedCrs)\n this.supportedCrs = supportedCrs;\n else\n throw new Error(\"No supported CRS found.\");\n\n this.wellKnownScaleSet = getElementTextContent(elem, XmlConstants.WELLKNOWNSCALESET_XMLTAG, \"\")!;\n\n // TileMatrix:\n // TileMatrix is mandatory on TileMatrixSet, if it doesn't exists, something is OFF with the capability.\n const tileMatrix = elem.getElementsByTagName(XmlConstants.TILEMATRIX_XMLTAG);\n if (tileMatrix.length === 0)\n throw new Error(\"No matrix set link found for WMTS layer\");\n\n for (const tm of tileMatrix) {\n this.tileMatrix.push(new TileMatrix(tm));\n }\n }\n }\n\n export class TileMatrix {\n public readonly identifier: string;\n public readonly title?: string;\n public readonly abstract?: string;\n public readonly scaleDenominator: number;\n public readonly topLeftCorner: Point2d;\n public readonly tileWidth: number;\n public readonly tileHeight: number;\n public readonly matrixWidth: number;\n public readonly matrixHeight: number;\n\n constructor(elem: Element) {\n const identifier = getElementTextContent(elem, OwsConstants.IDENTIFIER_XMLTAG, \"\");\n if (identifier)\n this.identifier = identifier;\n else\n throw new Error(\"No Identifier found.\");\n\n this.title = getElementTextContent(elem, OwsConstants.TITLE_XMLTAG);\n this.abstract = getElementTextContent(elem, OwsConstants.ABSTRACT_XMLTAG);\n\n // Scale denominator\n const scaleDenom = getElementTextContent(elem, XmlConstants.SCALEDENOMINATOR_XMLTAG, \"\");\n if (!scaleDenom)\n throw new Error(\"No scale denominator found on TileMatrix.\");\n this.scaleDenominator = +scaleDenom;\n\n // Top left corner\n const topLeftCorner = getElementTextContent(elem, XmlConstants.TOPLEFTCORNER_XMLTAG, \"\")?.split(\" \").map((x: string) => +x);\n if (topLeftCorner?.length !== 2)\n throw new Error(\"No TopLeftCorner found on TileMatrix.\");\n this.topLeftCorner = Point2d.create(topLeftCorner[0], topLeftCorner[1]);\n\n // Tile Width\n const tileWidth = getElementTextContent(elem, XmlConstants.TILEWIDTH_XMLTAG);\n if (!tileWidth)\n throw new Error(\"No tile width found on TileMatrix.\");\n this.tileWidth = +tileWidth;\n\n // Tile Height\n const tileHeight = getElementTextContent(elem, XmlConstants.TILEHEIGHT_XMLTAG);\n if (!tileHeight)\n throw new Error(\"No tile height found on TileMatrix.\");\n this.tileHeight = +tileHeight;\n\n // Matrix Width\n const matrixWidth = getElementTextContent(elem, XmlConstants.MATRIXWIDTH_XMLTAG);\n if (!matrixWidth)\n throw new Error(\"No tile width found on TileMatrix.\");\n this.matrixWidth = +matrixWidth;\n\n // Matrix Height\n const matrixHeight = getElementTextContent(elem, XmlConstants.MATRIXHEIGHT_XMLTAG);\n if (!matrixHeight)\n throw new Error(\"No tile height found on TileMatrix.\");\n this.matrixHeight = +matrixHeight;\n }\n }\n\n export class Layer {\n public readonly identifier: string;\n public readonly title?: string;\n public readonly abstract?: string;\n public readonly format?: string;\n public readonly wsg84BoundingBox?: MapCartoRectangle;\n public readonly boundingBox?: BoundingBox;\n public readonly styles: Style[] = [];\n public readonly tileMatrixSetLinks: TileMatrixSetLink[] = [];\n\n constructor(elem: Element) {\n\n const identifier = getElementTextContent(elem, OwsConstants.IDENTIFIER_XMLTAG, \"\");\n if (identifier)\n this.identifier = identifier;\n else\n throw new Error(\"No Identifier found.\");\n\n this.title = getElementTextContent(elem, OwsConstants.TITLE_XMLTAG);\n this.format = getElementTextContent(elem, \"Format\");\n\n // BoundingBox\n const boundingBox = elem.getElementsByTagName(OwsConstants.BOUNDINGBOX_XMLTAG);\n if (boundingBox.length > 0)\n this.boundingBox = new BoundingBox(boundingBox[0]);\n\n let lowerCornerArray: number[] | undefined, upperCornerArray: number[] | undefined;\n const bbox = elem.getElementsByTagName(OwsConstants.WGS84BOUNDINGBOX_XMLTAG);\n if (bbox.length > 0) {\n lowerCornerArray = getElementTextContent(bbox[0], OwsConstants.LOWERCORNER_XMLTAG)?.split(\" \").map((x: string) => +x);\n upperCornerArray = getElementTextContent(bbox[0], OwsConstants.UPPERCORNER_XMLTAG)?.split(\" \").map((x: string) => +x);\n }\n\n if (lowerCornerArray?.length === 2 && upperCornerArray?.length === 2)\n this.wsg84BoundingBox = MapCartoRectangle.fromDegrees(lowerCornerArray[0], lowerCornerArray[1], upperCornerArray[0], upperCornerArray[1]);\n\n // If we could not initialized WSG84 bounding box, attempt to initialized it from Bounding Box\n if (!this.wsg84BoundingBox && (this.boundingBox?.crs?.includes(\"EPSG:4326\") || this.boundingBox?.crs?.includes(\"CRS:84\"))) {\n const range = this.boundingBox.range;\n if (range)\n this.wsg84BoundingBox = MapCartoRectangle.fromDegrees(range.low.x, range.low.y, range.high.x, range.high.y);\n else\n this.wsg84BoundingBox = MapCartoRectangle.createMaximum();\n }\n\n // Style\n const style = elem.getElementsByTagName(\"Style\");\n if (style.length > 0) {\n for (const styleElem of style)\n this.styles.push(new Style(styleElem));\n }\n\n // TileMatrixSetLink\n // TileMatrixSetLink is mandatory on Layer, if it doesn't exists, something is OFF with the capability.\n const tileMatrixSetLink = elem.getElementsByTagName(XmlConstants.TILEMATRIXSETLINK_XMLTAG);\n\n if (tileMatrixSetLink.length === 0)\n throw new Error(\"No matrix set link found for WMTS layer\");\n\n for (const tmsl of tileMatrixSetLink)\n this.tileMatrixSetLinks.push(new TileMatrixSetLink(tmsl));\n }\n }\n}\n/** @internal */\nexport class WmtsCapabilities {\n private static _capabilitiesCache = new Map<string, WmtsCapabilities | undefined>();\n\n public readonly version?: string;\n public readonly serviceIdentification?: WmtsCapability.ServiceIdentification;\n public readonly contents?: WmtsCapability.Contents;\n\n public readonly operationsMetadata?: WmtsCapability.OperationMetadata;\n\n constructor(xmlDoc: Document) {\n\n const capabilities = xmlDoc.getElementsByTagName(\"Capabilities\");\n if (capabilities.length !== 0) {\n const capability = capabilities[0];\n this.version = capability.getAttribute(\"version\") ?? undefined;\n\n // Service Identification\n const serviceIdentification = capability.getElementsByTagName(OwsConstants.SERVICEIDENTIFICATION_XMLTAG);\n if (serviceIdentification.length > 0)\n this.serviceIdentification = new WmtsCapability.ServiceIdentification(serviceIdentification[0]);\n\n // Operations metadata\n const operationsMetadata = capability.getElementsByTagName(OwsConstants.OPERATIONSMETADATA_XMLTAG);\n if (operationsMetadata.length > 0)\n this.operationsMetadata = new WmtsCapability.OperationMetadata(operationsMetadata[0]);\n\n // Contents\n const content = capability.getElementsByTagName(\"Contents\");\n if (content.length > 0)\n this.contents = new WmtsCapability.Contents(content[0]);\n }\n }\n\n public static createFromXml(xmlCapabilities: string): WmtsCapabilities | undefined {\n const parser = new DOMParser();\n const xmlDoc = parser.parseFromString(xmlCapabilities, \"text/xml\");\n return new WmtsCapabilities(xmlDoc);\n }\n\n public static async create(url: string, credentials?: RequestBasicCredentials, ignoreCache?: boolean, queryParams?: {[key: string]: string}): Promise<WmtsCapabilities | undefined> {\n if (!ignoreCache) {\n const cached = WmtsCapabilities._capabilitiesCache.get(url);\n if (cached !== undefined)\n return cached;\n }\n\n const tmpUrl = new URL(WmsUtilities.getBaseUrl(url));\n tmpUrl.searchParams.append(\"request\", \"GetCapabilities\");\n tmpUrl.searchParams.append(\"service\", \"WMTS\");\n if (queryParams) {\n Object.keys(queryParams).forEach((paramKey) => {\n if (!tmpUrl.searchParams.has(paramKey))\n tmpUrl.searchParams.append(paramKey, queryParams[paramKey]);\n });\n }\n\n const xmlCapabilities = await getXml(tmpUrl.toString(), credentials);\n if (!xmlCapabilities)\n return undefined;\n\n const capabilities = WmtsCapabilities.createFromXml(xmlCapabilities);\n if (capabilities)\n WmtsCapabilities._capabilitiesCache.set(url, capabilities);\n\n return capabilities;\n }\n}\n"]}
1
+ {"version":3,"file":"WmtsCapabilities.js","sourceRoot":"","sources":["../../../../src/tile/map/WmtsCapabilities.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module Views\n */\n\nimport { Point2d, Range2d } from \"@itwin/core-geometry\";\nimport { RequestBasicCredentials } from \"../../request/Request\";\nimport { MapCartoRectangle, WmsUtilities } from \"../internal\";\n\nenum OwsConstants {\n ABSTRACT_XMLTAG = \"ows:Abstract\",\n ACCESSCONSTRAINTS_XMLTAG = \"ows:AccessConstraints\",\n ALLOWEDVALUES_XMLTAG = \"ows:AllowedValues\",\n BOUNDINGBOX_XMLTAG = \"ows:BoundingBox\",\n CONSTRAINT_XMLTAG = \"ows:Constraint\",\n DCP_XMLTAG = \"ows:DCP\",\n FEES_XMLTAG = \"ows:Fees\",\n GET_XMLTAG = \"ows:Get\",\n HTTP_XMLTAG = \"ows:HTTP\",\n IDENTIFIER_XMLTAG = \"ows:Identifier\",\n KEYWORDS_XMLTAG = \"ows:Keywords\",\n KEYWORD_XMLTAG = \"ows:Keyword\",\n LOWERCORNER_XMLTAG = \"ows:LowerCorner\",\n OPERATION_XMLTAG = \"ows:Operation\",\n OPERATIONSMETADATA_XMLTAG = \"ows:OperationsMetadata\",\n POST_XMLTAG = \"ows:Post\",\n SERVICEIDENTIFICATION_XMLTAG = \"ows:ServiceIdentification\",\n SERVICETYPE_XMLTAG = \"ows:ServiceType\",\n SERVICETYPEVERSION_XMLTAG = \"ows:ServiceTypeVersion\",\n SUPPORTEDCRS_XMLTAG = \"ows:SupportedCRS\",\n TITLE_XMLTAG = \"ows:Title\",\n UPPERCORNER_XMLTAG = \"ows:UpperCorner\",\n VALUE_XMLTAG = \"ows:Value\",\n WGS84BOUNDINGBOX_XMLTAG = \"ows:WGS84BoundingBox\"\n\n}\n\nenum XmlConstants {\n // Operations names\n GETCAPABILITIES = \"GetCapabilities\",\n GETTILE = \"GetTile\",\n GETFEATUREINFO = \"GetFeatureInfo\",\n\n MATRIXWIDTH_XMLTAG = \"MatrixWidth\",\n MATRIXHEIGHT_XMLTAG = \"MatrixHeight\",\n SCALEDENOMINATOR_XMLTAG = \"ScaleDenominator\",\n\n TILEHEIGHT_XMLTAG = \"TileHeight\",\n TILEMATRIX_XMLTAG = \"TileMatrix\",\n TILEMATRIXSETLINK_XMLTAG = \"TileMatrixSetLink\",\n TILEWIDTH_XMLTAG = \"TileWidth\",\n TOPLEFTCORNER_XMLTAG = \"TopLeftCorner\",\n WELLKNOWNSCALESET_XMLTAG = \"WellKnownScaleSet\",\n\n CONSTRAINT_NAME_FILTER = \"Encoding\",\n STYLE_ISDEFAULT = \"IsDefault\",\n XLINK_HREF = \"xlink:href\",\n}\n\n/** @internal\n*/\nexport enum WmtsConstants {\n GOOGLEMAPS_LEVEL0_SCALE_DENOM = 559082264.0287178,\n GOOGLEMAPS_COMPATIBLE_WELLKNOWNNAME = \"googlemapscompatible\",\n}\n\n/**\n * Utility function to extract an element' text content\n * @return An element's text content, default to provided defaultTest value if no text is available.\n * @param url server URL to address the request\n * @internal\n */\nconst getElementTextContent = (elem: Element, qualifiedName: string, defaultText?: string) => {\n\n const tmpElem = elem.getElementsByTagName(qualifiedName);\n if (tmpElem.length > 0) {\n return tmpElem[0].textContent ?? defaultText;\n } else\n return defaultText;\n\n};\n\n/** Encapsulation of the capabilities for an WMTS server\n * @internal\n */\nexport namespace WmtsCapability {\n export class ServiceIdentification {\n public readonly abstract?: string;\n public readonly accessConstraints?: string;\n public readonly fees?: string;\n public readonly serviceType?: string;\n public readonly serviceTypeVersion?: string;\n public readonly title?: string;\n public readonly keywords?: string[];\n\n constructor(elem: Element) {\n this.abstract = getElementTextContent(elem, OwsConstants.ABSTRACT_XMLTAG);\n this.serviceType = getElementTextContent(elem, OwsConstants.SERVICETYPE_XMLTAG);\n this.serviceTypeVersion = getElementTextContent(elem, OwsConstants.SERVICETYPEVERSION_XMLTAG);\n this.title = getElementTextContent(elem, OwsConstants.TITLE_XMLTAG);\n\n const keywords = elem.getElementsByTagName(OwsConstants.KEYWORDS_XMLTAG);\n if (keywords.length > 0) {\n const keyword = keywords[0].getElementsByTagName(OwsConstants.KEYWORD_XMLTAG);\n this.keywords = [];\n for (const keyworkElem of keyword) {\n const keyWordText = keyworkElem.textContent;\n if (keyWordText)\n this.keywords.push(keyWordText);\n }\n }\n\n this.accessConstraints = getElementTextContent(elem, OwsConstants.ACCESSCONSTRAINTS_XMLTAG);\n\n this.fees = getElementTextContent(elem, OwsConstants.FEES_XMLTAG);\n }\n }\n\n export class OperationMetadata {\n private _getCapabilities?: Operation;\n public get getCapabilities(): Operation | undefined { return this._getCapabilities; }\n\n private _getFeatureInfo?: Operation;\n public get getFeatureInfo(): Operation | undefined { return this._getFeatureInfo; }\n\n private _getTile?: Operation;\n public get getTile(): Operation | undefined { return this._getTile; }\n\n private readOperation(op: Element) {\n const nameAttr = op.attributes.getNamedItem(\"name\");\n if (!nameAttr)\n return;\n\n if (nameAttr.textContent === XmlConstants.GETCAPABILITIES) {\n this._getCapabilities = new Operation(op);\n } else if (nameAttr.textContent === XmlConstants.GETTILE) {\n this._getTile = new Operation(op);\n } else if (nameAttr.textContent === XmlConstants.GETFEATUREINFO) {\n this._getFeatureInfo = new Operation(op);\n }\n }\n\n constructor(elem: Element) {\n const operation = elem.getElementsByTagName(OwsConstants.OPERATION_XMLTAG);\n if (operation.length > 0) {\n for (const op of operation) {\n this.readOperation(op);\n }\n }\n }\n }\n\n export class HttpDcp {\n public readonly url?: string;\n public readonly constraintName?: string;\n\n // For simplicity of use we create a 'static' encoding property instead of having\n // a generic constraint data model.\n // We make sure the constraint name is 'encoding' related.\n public readonly encoding?: string;\n\n constructor(elem: Element) {\n const url = elem.getAttribute(XmlConstants.XLINK_HREF);\n if (url)\n this.url = url ?? \"\";\n\n const constraint = elem.getElementsByTagName(OwsConstants.CONSTRAINT_XMLTAG);\n if (constraint.length > 0) {\n this.constraintName = constraint[0].getAttribute(\"name\") ?? \"\";\n if (this.constraintName?.endsWith(XmlConstants.CONSTRAINT_NAME_FILTER)) {\n const allowedValues = constraint[0].getElementsByTagName(OwsConstants.ALLOWEDVALUES_XMLTAG);\n if (allowedValues.length > 0) {\n this.encoding = getElementTextContent(allowedValues[0], OwsConstants.VALUE_XMLTAG);\n }\n }\n }\n }\n }\n\n export class Operation {\n public readonly name?: string;\n private _getDcpHttp?: HttpDcp[];\n public get getDcpHttp(): HttpDcp[] | undefined { return this._getDcpHttp; }\n private _postDcpHttp?: HttpDcp[];\n public get postDcpHttp(): HttpDcp[] | undefined { return this._postDcpHttp; }\n\n constructor(elem: Element) {\n const name = elem.getAttribute(\"name\");\n if (name)\n this.name = name;\n\n const dcp = elem.getElementsByTagName(OwsConstants.DCP_XMLTAG);\n if (!dcp || dcp.length === 0)\n return;\n\n const dcpHttp = dcp[0].getElementsByTagName(OwsConstants.HTTP_XMLTAG);\n if (!dcpHttp || dcpHttp.length === 0)\n return;\n\n const get = dcpHttp[0].getElementsByTagName(OwsConstants.GET_XMLTAG);\n if (get.length > 0) {\n this._getDcpHttp = [];\n\n for (const getItem of get) {\n this._getDcpHttp?.push(new HttpDcp(getItem));\n }\n }\n\n const post = dcpHttp[0].getElementsByTagName(OwsConstants.POST_XMLTAG);\n if (post.length > 0) {\n this._postDcpHttp = [];\n\n for (const postItem of post) {\n this._postDcpHttp?.push(new HttpDcp(postItem));\n }\n }\n }\n }\n\n export class Contents {\n public readonly layers: Layer[] = [];\n public readonly tileMatrixSets: TileMatrixSet[] = [];\n\n constructor(elem: Element) {\n // Layers\n const layer = elem.getElementsByTagName(\"Layer\");\n if (layer) {\n for (const layerElem of layer)\n this.layers.push(new Layer(layerElem));\n }\n\n // TileMatrixSet\n const tms = elem.querySelectorAll(\"Contents > TileMatrixSet\");\n if (tms) {\n for (const tmsElem of tms)\n this.tileMatrixSets.push(new TileMatrixSet(tmsElem));\n }\n\n }\n\n public getGoogleMapsCompatibleTileMatrixSet(): TileMatrixSet[] {\n const googleMapsTms: TileMatrixSet[] = [];\n this.tileMatrixSets.forEach((tms) => {\n if (tms.wellKnownScaleSet?.toLowerCase().includes(WmtsConstants.GOOGLEMAPS_COMPATIBLE_WELLKNOWNNAME))\n googleMapsTms.push(tms);\n\n // In case wellKnownScaleSet was not been set properly, infer from scaleDenominator\n // Note: some servers are quite inaccurate in their scale values, hence I used a delta value of 1.\n else if (tms.tileMatrix.length > 0\n && Math.abs(tms.tileMatrix[0].scaleDenominator - WmtsConstants.GOOGLEMAPS_LEVEL0_SCALE_DENOM) < 1\n && (tms.supportedCrs.includes(\"3857\") || tms.supportedCrs.includes(\"900913\"))\n )\n googleMapsTms.push(tms);\n });\n return googleMapsTms;\n }\n\n public getEpsg4326CompatibleTileMatrixSet(): TileMatrixSet[] {\n return this.tileMatrixSets.filter((tms) => tms.supportedCrs.includes(\"4326\"));\n }\n }\n\n export class Style {\n public readonly isDefault: boolean = false;\n public readonly title?: string;\n public readonly identifier?: string;\n // TODO: LegendURL\n\n constructor(elem: Element) {\n if (!elem)\n return;\n\n const isDefault = elem.getAttribute(\"isDefault\");\n if (isDefault)\n this.isDefault = isDefault.toLowerCase() === \"true\";\n\n this.title = getElementTextContent(elem, OwsConstants.TITLE_XMLTAG);\n this.identifier = getElementTextContent(elem, OwsConstants.IDENTIFIER_XMLTAG);\n }\n }\n\n export class BoundingBox {\n public readonly crs?: string;\n public readonly range?: Range2d;\n\n constructor(elem: Element) {\n this.crs = elem.getAttribute(\"crs\") ?? undefined;\n\n const lowerCorner = getElementTextContent(elem, OwsConstants.LOWERCORNER_XMLTAG);\n const upperCorner = getElementTextContent(elem, OwsConstants.UPPERCORNER_XMLTAG);\n if (lowerCorner && upperCorner) {\n const lowerCornerArray = lowerCorner?.split(\" \").map((x: string) => +x);\n const upperCornerArray = upperCorner?.split(\" \").map((x: string) => +x);\n if (lowerCornerArray && lowerCornerArray.length === 2 && upperCornerArray && upperCornerArray.length === 2)\n this.range = Range2d.createXYXY(lowerCornerArray[0], lowerCornerArray[1], upperCornerArray[0], upperCornerArray[1]);\n }\n }\n }\n\n export class TileMatrixSetLimits {\n public limits?: Range2d;\n public tileMatrix?: string;\n\n constructor(elem: Element) {\n\n this.tileMatrix = getElementTextContent(elem, \"TileMatrix\");\n\n const minTileRow = getElementTextContent(elem, \"MinTileRow\");\n const maxTileRow = getElementTextContent(elem, \"MaxTileRow\");\n const minTileCol = getElementTextContent(elem, \"MinTileCol\");\n const maxTileCol = getElementTextContent(elem, \"MaxTileCol\");\n\n if (minTileRow !== undefined && maxTileRow !== undefined && minTileCol !== undefined && maxTileCol)\n this.limits = Range2d.createXYXY(Number(minTileCol), Number(minTileRow), Number(maxTileCol), Number(maxTileRow));\n }\n }\n\n export class TileMatrixSetLink {\n public readonly tileMatrixSet: string;\n public readonly tileMatrixSetLimits = new Array<TileMatrixSetLimits>();\n\n constructor(elem: Element) {\n\n this.tileMatrixSet = getElementTextContent(elem, \"TileMatrixSet\", \"\")!;\n\n const tileMatrixLimitsRoot = elem.getElementsByTagName(\"TileMatrixSetLimits\");\n if (tileMatrixLimitsRoot.length > 0) {\n const tileMatrixLimits = tileMatrixLimitsRoot[0].getElementsByTagName(\"TileMatrixSetLimits\");\n for (const tmsl of tileMatrixLimits) {\n this.tileMatrixSetLimits.push(new TileMatrixSetLimits(tmsl));\n }\n }\n }\n }\n\n export class TileMatrixSet {\n public readonly identifier: string;\n public readonly title?: string;\n public readonly abstract?: string;\n public readonly supportedCrs: string;\n public readonly wellKnownScaleSet: string;\n public readonly tileMatrix: TileMatrix[] = [];\n\n constructor(elem: Element) {\n const identifier = getElementTextContent(elem, OwsConstants.IDENTIFIER_XMLTAG);\n if (identifier)\n this.identifier = identifier;\n else\n throw new Error(\"No Identifier found.\");\n\n this.title = getElementTextContent(elem, OwsConstants.TITLE_XMLTAG);\n this.abstract = getElementTextContent(elem, OwsConstants.ABSTRACT_XMLTAG);\n\n const supportedCrs = getElementTextContent(elem, OwsConstants.SUPPORTEDCRS_XMLTAG);\n if (supportedCrs)\n this.supportedCrs = supportedCrs;\n else\n throw new Error(\"No supported CRS found.\");\n\n this.wellKnownScaleSet = getElementTextContent(elem, XmlConstants.WELLKNOWNSCALESET_XMLTAG, \"\")!;\n\n // TileMatrix:\n // TileMatrix is mandatory on TileMatrixSet, if it doesn't exists, something is OFF with the capability.\n const tileMatrix = elem.getElementsByTagName(XmlConstants.TILEMATRIX_XMLTAG);\n if (tileMatrix.length === 0)\n throw new Error(\"No matrix set link found for WMTS layer\");\n\n for (const tm of tileMatrix) {\n this.tileMatrix.push(new TileMatrix(tm));\n }\n }\n }\n\n export class TileMatrix {\n public readonly identifier: string;\n public readonly title?: string;\n public readonly abstract?: string;\n public readonly scaleDenominator: number;\n public readonly topLeftCorner: Point2d;\n public readonly tileWidth: number;\n public readonly tileHeight: number;\n public readonly matrixWidth: number;\n public readonly matrixHeight: number;\n\n constructor(elem: Element) {\n const identifier = getElementTextContent(elem, OwsConstants.IDENTIFIER_XMLTAG, \"\");\n if (identifier)\n this.identifier = identifier;\n else\n throw new Error(\"No Identifier found.\");\n\n this.title = getElementTextContent(elem, OwsConstants.TITLE_XMLTAG);\n this.abstract = getElementTextContent(elem, OwsConstants.ABSTRACT_XMLTAG);\n\n // Scale denominator\n const scaleDenom = getElementTextContent(elem, XmlConstants.SCALEDENOMINATOR_XMLTAG, \"\");\n if (!scaleDenom)\n throw new Error(\"No scale denominator found on TileMatrix.\");\n this.scaleDenominator = +scaleDenom;\n\n // Top left corner\n const topLeftCorner = getElementTextContent(elem, XmlConstants.TOPLEFTCORNER_XMLTAG, \"\")?.split(\" \").map((x: string) => +x);\n if (topLeftCorner?.length !== 2)\n throw new Error(\"No TopLeftCorner found on TileMatrix.\");\n this.topLeftCorner = Point2d.create(topLeftCorner[0], topLeftCorner[1]);\n\n // Tile Width\n const tileWidth = getElementTextContent(elem, XmlConstants.TILEWIDTH_XMLTAG);\n if (!tileWidth)\n throw new Error(\"No tile width found on TileMatrix.\");\n this.tileWidth = +tileWidth;\n\n // Tile Height\n const tileHeight = getElementTextContent(elem, XmlConstants.TILEHEIGHT_XMLTAG);\n if (!tileHeight)\n throw new Error(\"No tile height found on TileMatrix.\");\n this.tileHeight = +tileHeight;\n\n // Matrix Width\n const matrixWidth = getElementTextContent(elem, XmlConstants.MATRIXWIDTH_XMLTAG);\n if (!matrixWidth)\n throw new Error(\"No tile width found on TileMatrix.\");\n this.matrixWidth = +matrixWidth;\n\n // Matrix Height\n const matrixHeight = getElementTextContent(elem, XmlConstants.MATRIXHEIGHT_XMLTAG);\n if (!matrixHeight)\n throw new Error(\"No tile height found on TileMatrix.\");\n this.matrixHeight = +matrixHeight;\n }\n }\n\n export class Layer {\n public readonly identifier: string;\n public readonly title?: string;\n public readonly abstract?: string;\n public readonly format?: string;\n public readonly wsg84BoundingBox?: MapCartoRectangle;\n public readonly boundingBox?: BoundingBox;\n public readonly styles: Style[] = [];\n public readonly tileMatrixSetLinks: TileMatrixSetLink[] = [];\n\n constructor(elem: Element) {\n\n const identifier = getElementTextContent(elem, OwsConstants.IDENTIFIER_XMLTAG, \"\");\n if (identifier)\n this.identifier = identifier;\n else\n throw new Error(\"No Identifier found.\");\n\n this.title = getElementTextContent(elem, OwsConstants.TITLE_XMLTAG);\n this.format = getElementTextContent(elem, \"Format\");\n\n // BoundingBox\n const boundingBox = elem.getElementsByTagName(OwsConstants.BOUNDINGBOX_XMLTAG);\n if (boundingBox.length > 0)\n this.boundingBox = new BoundingBox(boundingBox[0]);\n\n let lowerCornerArray: number[] | undefined, upperCornerArray: number[] | undefined;\n const bbox = elem.getElementsByTagName(OwsConstants.WGS84BOUNDINGBOX_XMLTAG);\n if (bbox.length > 0) {\n lowerCornerArray = getElementTextContent(bbox[0], OwsConstants.LOWERCORNER_XMLTAG)?.split(\" \").map((x: string) => +x);\n upperCornerArray = getElementTextContent(bbox[0], OwsConstants.UPPERCORNER_XMLTAG)?.split(\" \").map((x: string) => +x);\n }\n\n if (lowerCornerArray?.length === 2 && upperCornerArray?.length === 2)\n this.wsg84BoundingBox = MapCartoRectangle.fromDegrees(lowerCornerArray[0], lowerCornerArray[1], upperCornerArray[0], upperCornerArray[1]);\n\n // If we could not initialized WSG84 bounding box, attempt to initialized it from Bounding Box\n if (!this.wsg84BoundingBox && (this.boundingBox?.crs?.includes(\"EPSG:4326\") || this.boundingBox?.crs?.includes(\"CRS:84\"))) {\n const range = this.boundingBox.range;\n if (range)\n this.wsg84BoundingBox = MapCartoRectangle.fromDegrees(range.low.x, range.low.y, range.high.x, range.high.y);\n else\n this.wsg84BoundingBox = MapCartoRectangle.createMaximum();\n }\n\n // Style\n const style = elem.getElementsByTagName(\"Style\");\n if (style.length > 0) {\n for (const styleElem of style)\n this.styles.push(new Style(styleElem));\n }\n\n // TileMatrixSetLink\n // TileMatrixSetLink is mandatory on Layer, if it doesn't exists, something is OFF with the capability.\n const tileMatrixSetLink = elem.getElementsByTagName(XmlConstants.TILEMATRIXSETLINK_XMLTAG);\n\n if (tileMatrixSetLink.length === 0)\n throw new Error(\"No matrix set link found for WMTS layer\");\n\n for (const tmsl of tileMatrixSetLink)\n this.tileMatrixSetLinks.push(new TileMatrixSetLink(tmsl));\n }\n }\n}\n/** @internal */\nexport class WmtsCapabilities {\n private static _capabilitiesCache = new Map<string, WmtsCapabilities | undefined>();\n\n public readonly version?: string;\n public readonly serviceIdentification?: WmtsCapability.ServiceIdentification;\n public readonly contents?: WmtsCapability.Contents;\n\n public readonly operationsMetadata?: WmtsCapability.OperationMetadata;\n\n constructor(xmlDoc: Document) {\n\n const capabilities = xmlDoc.getElementsByTagName(\"Capabilities\");\n if (capabilities.length !== 0) {\n const capability = capabilities[0];\n this.version = capability.getAttribute(\"version\") ?? undefined;\n\n // Service Identification\n const serviceIdentification = capability.getElementsByTagName(OwsConstants.SERVICEIDENTIFICATION_XMLTAG);\n if (serviceIdentification.length > 0)\n this.serviceIdentification = new WmtsCapability.ServiceIdentification(serviceIdentification[0]);\n\n // Operations metadata\n const operationsMetadata = capability.getElementsByTagName(OwsConstants.OPERATIONSMETADATA_XMLTAG);\n if (operationsMetadata.length > 0)\n this.operationsMetadata = new WmtsCapability.OperationMetadata(operationsMetadata[0]);\n\n // Contents\n const content = capability.getElementsByTagName(\"Contents\");\n if (content.length > 0)\n this.contents = new WmtsCapability.Contents(content[0]);\n }\n }\n\n public static createFromXml(xmlCapabilities: string): WmtsCapabilities | undefined {\n const parser = new DOMParser();\n const xmlDoc = parser.parseFromString(xmlCapabilities, \"text/xml\");\n return new WmtsCapabilities(xmlDoc);\n }\n\n public static async create(url: string, credentials?: RequestBasicCredentials, ignoreCache?: boolean, queryParams?: {[key: string]: string}): Promise<WmtsCapabilities | undefined> {\n if (!ignoreCache) {\n const cached = WmtsCapabilities._capabilitiesCache.get(url);\n if (cached !== undefined)\n return cached;\n }\n\n const tmpUrl = new URL(WmsUtilities.getBaseUrl(url));\n tmpUrl.searchParams.append(\"request\", \"GetCapabilities\");\n tmpUrl.searchParams.append(\"service\", \"WMTS\");\n if (queryParams) {\n Object.keys(queryParams).forEach((paramKey) => {\n if (!tmpUrl.searchParams.has(paramKey))\n tmpUrl.searchParams.append(paramKey, queryParams[paramKey]);\n });\n }\n\n const xmlCapabilities = await WmsUtilities.fetchXml(tmpUrl.toString(), credentials);\n if (!xmlCapabilities)\n return undefined;\n\n const capabilities = WmtsCapabilities.createFromXml(xmlCapabilities);\n if (capabilities)\n WmtsCapabilities._capabilitiesCache.set(url, capabilities);\n\n return capabilities;\n }\n}\n"]}
@@ -87,6 +87,7 @@ export declare class SelectionTool extends PrimitiveTool {
87
87
  protected selectByPointsEnd(ev: BeButtonEvent): boolean;
88
88
  onMouseMotion(ev: BeButtonEvent): Promise<void>;
89
89
  selectDecoration(ev: BeButtonEvent, currHit?: HitDetail): Promise<EventHandled>;
90
+ processHit(ev: BeButtonEvent, hit: HitDetail): Promise<EventHandled>;
90
91
  onMouseStartDrag(ev: BeButtonEvent): Promise<EventHandled>;
91
92
  onMouseEndDrag(ev: BeButtonEvent): Promise<EventHandled>;
92
93
  onDataButtonUp(ev: BeButtonEvent): Promise<EventHandled>;
@@ -1 +1 @@
1
- {"version":3,"file":"SelectTool.d.ts","sourceRoot":"","sources":["../../../src/tools/SelectTool.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"SelectTool.d.ts","sourceRoot":"","sources":["../../../src/tools/SelectTool.ts"],"names":[],"mappings":"AAIA;;GAEG;AAEH,OAAO,EAAQ,OAAO,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAW,OAAO,EAAW,MAAM,sBAAsB,CAAC;AAEjE,OAAO,EACoB,UAAU,EAAmB,sBAAsB,EAE7E,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAE,kBAAkB,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAC7E,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAGzC,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAEjD,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAY,aAAa,EAAE,cAAc,EAAE,YAAY,EAAsC,YAAY,EAAe,MAAM,QAAQ,CAAC;AAM9I;;;GAGG;AACH,oBAAY,eAAe;IACzB,4IAA4I;IAC5I,IAAI,IAAA;IACJ,sDAAsD;IACtD,IAAI,IAAA;IACJ,wHAAwH;IACxH,GAAG,IAAA;CACJ;AAED;;;GAGG;AACH,oBAAY,aAAa;IACvB,+FAA+F;IAC/F,OAAO,IAAA;IACP,iEAAiE;IACjE,GAAG,IAAA;IACH,qEAAqE;IACrE,MAAM,IAAA;CACP;AAED;;;GAGG;AACH,oBAAY,mBAAmB;IAC7B,gCAAgC;IAChC,qBAAqB,IAAA;IACrB,qCAAqC;IACrC,0BAA0B,IAAA;IAC1B,yDAAyD;IACzD,wBAAwB,IAAA;IACxB,8CAA8C;IAC9C,2BAA2B,IAAA;CAC5B;AAED;;GAEG;AACH,qBAAa,aAAc,SAAQ,aAAa;IAC9C,OAAuB,MAAM,UAAS;IACtC,OAAuB,MAAM,SAAY;IACzC,OAAuB,QAAQ,SAAiB;IAChD,SAAS,CAAC,iBAAiB,UAAS;IACpC,SAAS,CAAC,YAAY,UAAS;IAC/B,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,OAAO,EAAE,CAAM;IAC3C,OAAO,CAAC,qBAAqB,CAAoD;IACjF,OAAO,CAAC,mBAAmB,CAAqD;IAEhE,sBAAsB,IAAI,OAAO;IACjC,cAAc,IAAI,IAAI;IAEtC,SAAS,CAAC,wBAAwB,CAAC,GAAG,EAAE,aAAa,GAAG,OAAO;IAC/D,SAAS,CAAC,oBAAoB,IAAI,OAAO;IACzC,SAAS,CAAC,uBAAuB,IAAI,OAAO;IAC5C,SAAS,CAAC,gBAAgB,IAAI,OAAO;IAErC,IAAW,eAAe,IAAI,eAAe,CAAgE;IAC7G,IAAW,eAAe,CAAC,MAAM,EAAE,eAAe,EAAgD;IAClG,IAAW,aAAa,IAAI,aAAa,CAA4D;IACrG,IAAW,aAAa,CAAC,IAAI,EAAE,aAAa,EAA4C;IAExF,OAAO,CAAC,MAAM,CAAC,cAAc;IAC7B,OAAO,CAAC,MAAM,CAAC,YAAY,CAAsB;IAEjD,OAAO,CAAC,MAAM,CAAC,sBAAsB;IA8BrC,OAAO,CAAC,MAAM,CAAC,YAAY;IAC3B,OAAO,CAAC,MAAM,CAAC,UAAU,CAAoB;IAE7C,OAAO,CAAC,MAAM,CAAC,oBAAoB;IAoCnC,SAAS,CAAC,UAAU,CAAC,IAAI,EAAE,aAAa,EAAE,MAAM,EAAE,eAAe,GAAG,IAAI;IAgExE,SAAS,CAAC,cAAc,IAAI,IAAI;IAahC,SAAS,CAAC,WAAW,CAAC,GAAG,EAAE,aAAa,GAAG,OAAO;IAO3C,eAAe,CAAC,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,mBAAmB,GAAG,OAAO;IAyBpE,gBAAgB,CAAC,SAAS,EAAE,OAAO,EAAE,OAAO,EAAE,mBAAmB,GAAG,OAAO,CAAC,OAAO,CAAC;IAEjG,SAAS,CAAC,mBAAmB,CAAC,EAAE,EAAE,aAAa,GAAG,OAAO;IASzD,OAAO,CAAC,sBAAsB;IA0C9B,SAAS,CAAC,qBAAqB,CAAC,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE,aAAa,EAAE,MAAM,EAAE,eAAe,EAAE,OAAO,EAAE,OAAO;IA8G9H,SAAS,CAAC,mBAAmB,CAAC,EAAE,EAAE,aAAa,GAAG,OAAO;IAYzD,SAAS,CAAC,iBAAiB,CAAC,EAAE,EAAE,aAAa,GAAG,OAAO;IAsBjC,aAAa,CAAC,EAAE,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC;IAKxD,gBAAgB,CAAC,EAAE,EAAE,aAAa,EAAE,OAAO,CAAC,EAAE,SAAS,GAAG,OAAO,CAAC,YAAY,CAAC;IAU/E,UAAU,CAAC,EAAE,EAAE,aAAa,EAAE,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,YAAY,CAAC;IAoB3D,gBAAgB,CAAC,EAAE,EAAE,aAAa,GAAG,OAAO,CAAC,YAAY,CAAC;IAS1D,cAAc,CAAC,EAAE,EAAE,aAAa,GAAG,OAAO,CAAC,YAAY,CAAC;IAIxD,cAAc,CAAC,EAAE,EAAE,aAAa,GAAG,OAAO,CAAC,YAAY,CAAC;IA8BxD,eAAe,CAAC,EAAE,EAAE,aAAa,GAAG,OAAO,CAAC,YAAY,CAAC;IAwCzD,SAAS;IAMT,WAAW;IAQX,gBAAgB,CAAC,EAAE,EAAE,YAAY,EAAE,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,YAAY,CAAC;IAMhF,WAAW,CAAC,EAAE,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC;IAK5C,eAAe,CAAC,EAAE,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC;IAKhD,aAAa,CAAC,EAAE,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC;IAKpD,QAAQ,CAAC,OAAO,EAAE,eAAe,GAAG,IAAI;IAElC,uBAAuB,CAAC,SAAS,EAAE,OAAO,EAAE,QAAQ,EAAE,cAAc,EAAE,MAAM,EAAE,aAAa,GAAG,OAAO,CAAC,YAAY,CAAC;IAInH,SAAS,CAAC,GAAG,EAAE,SAAS,EAAE,GAAG,CAAC,EAAE,cAAc,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAerF,aAAa,IAAI,OAAO,CAAC,IAAI,CAAC;IAErB,SAAS;IAKT,aAAa;WASf,SAAS,IAAI,OAAO,CAAC,OAAO,CAAC;IAEjD,OAAO,CAAC,iBAAiB;IAazB;;OAEG;IACa,4BAA4B,IAAI,UAAU,EAAE,GAAG,SAAS;IAuBxE;;OAEG;IACmB,8BAA8B,CAAC,YAAY,EAAE,sBAAsB,GAAG,OAAO,CAAC,OAAO,CAAC;CAwB7G"}
@@ -428,6 +428,22 @@ class SelectionTool extends PrimitiveTool_1.PrimitiveTool {
428
428
  return (currHit.isElementHit ? IModelApp_1.IModelApp.viewManager.overrideElementButtonEvent(currHit, ev) : IModelApp_1.IModelApp.viewManager.onDecorationButtonEvent(currHit, ev));
429
429
  return Tool_1.EventHandled.No;
430
430
  }
431
+ async processHit(ev, hit) {
432
+ if (hit.isModelHit || hit.isMapHit)
433
+ return Tool_1.EventHandled.No; // model hit = terrain, reality models, background maps, etc - not selectable
434
+ switch (this.selectionMode) {
435
+ case SelectionMode.Replace:
436
+ await this.processSelection(hit.sourceId, ev.isControlKey ? SelectionProcessing.InvertElementInSelection : SelectionProcessing.ReplaceSelectionWithElement);
437
+ break;
438
+ case SelectionMode.Add:
439
+ await this.processSelection(hit.sourceId, SelectionProcessing.AddElementToSelection);
440
+ break;
441
+ case SelectionMode.Remove:
442
+ await this.processSelection(hit.sourceId, SelectionProcessing.RemoveElementFromSelection);
443
+ break;
444
+ }
445
+ return Tool_1.EventHandled.Yes;
446
+ }
431
447
  async onMouseStartDrag(ev) {
432
448
  IModelApp_1.IModelApp.accuSnap.clear(); // Need to test hit at start drag location, not current AccuSnap...
433
449
  if (Tool_1.EventHandled.Yes === await this.selectDecoration(ev))
@@ -452,21 +468,11 @@ class SelectionTool extends PrimitiveTool_1.PrimitiveTool {
452
468
  return Tool_1.EventHandled.Yes;
453
469
  }
454
470
  const hit = await IModelApp_1.IModelApp.locateManager.doLocate(new ElementLocateManager_1.LocateResponse(), true, ev.point, ev.viewport, ev.inputSource);
455
- if (hit !== undefined && !hit.isModelHit && !hit.isMapHit) { // model hit = terrain, reality models, background maps, etc - not selectable
471
+ if (hit !== undefined) {
456
472
  if (Tool_1.EventHandled.Yes === await this.selectDecoration(ev, hit))
457
473
  return Tool_1.EventHandled.Yes;
458
- switch (this.selectionMode) {
459
- case SelectionMode.Replace:
460
- await this.processSelection(hit.sourceId, ev.isControlKey ? SelectionProcessing.InvertElementInSelection : SelectionProcessing.ReplaceSelectionWithElement);
461
- break;
462
- case SelectionMode.Add:
463
- await this.processSelection(hit.sourceId, SelectionProcessing.AddElementToSelection);
464
- break;
465
- case SelectionMode.Remove:
466
- await this.processSelection(hit.sourceId, SelectionProcessing.RemoveElementFromSelection);
467
- break;
468
- }
469
- return Tool_1.EventHandled.Yes;
474
+ if (Tool_1.EventHandled.Yes === await this.processHit(ev, hit))
475
+ return Tool_1.EventHandled.Yes;
470
476
  }
471
477
  if (!ev.isControlKey && this.wantSelectionClearOnMiss(ev) && this.processMiss(ev))
472
478
  this.syncSelectionMode();
@@ -1 +1 @@
1
- {"version":3,"file":"SelectTool.js","sourceRoot":"","sources":["../../../src/tools/SelectTool.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module SelectionSet\n */\n\nimport { Id64, Id64Arg } from \"@itwin/core-bentley\";\nimport { Point2d, Point3d, Range2d } from \"@itwin/core-geometry\";\nimport { ColorDef } from \"@itwin/core-common\";\nimport {\n ButtonGroupEditorParams, DialogItem, DialogItemValue, DialogPropertySyncItem, PropertyDescription, PropertyEditorParamTypes,\n SuppressLabelEditorParams,\n} from \"@itwin/appui-abstract\";\nimport { LocateFilterStatus, LocateResponse } from \"../ElementLocateManager\";\nimport { HitDetail } from \"../HitDetail\";\nimport { IModelApp } from \"../IModelApp\";\nimport { Pixel } from \"../render/Pixel\";\nimport { DecorateContext } from \"../ViewContext\";\nimport { ViewRect } from \"../common/ViewRect\";\nimport { PrimitiveTool } from \"./PrimitiveTool\";\nimport { BeButton, BeButtonEvent, BeModifierKeys, BeTouchEvent, CoordinateLockOverrides, CoreTools, EventHandled, InputSource } from \"./Tool\";\nimport { ManipulatorToolEvent } from \"./ToolAdmin\";\nimport { ToolAssistance, ToolAssistanceImage, ToolAssistanceInputMethod, ToolAssistanceInstruction, ToolAssistanceSection } from \"./ToolAssistance\";\n\n// cSpell:ignore buttongroup\n\n/** The method for choosing elements with the [[SelectionTool]]\n * @public\n * @extensions\n */\nexport enum SelectionMethod {\n /** Identify element(s) by picking for drag selection (inside/overlap for drag box selection determined by point direction and shift key) */\n Pick,\n /** Identify elements by overlap with crossing line */\n Line,\n /** Identify elements by box selection (inside/overlap for box selection determined by point direction and shift key) */\n Box,\n}\n\n/** The mode for choosing elements with the [[SelectionTool]]\n * @public\n * @extensions\n */\nexport enum SelectionMode {\n /** Identified elements replace the current selection set (use control key to add or remove) */\n Replace,\n /** Identified elements are added to the current selection set */\n Add,\n /** Identified elements are removed from the current selection set */\n Remove,\n}\n\n/** The processing method to use to update the current selection.\n * @public\n * @extensions\n */\nexport enum SelectionProcessing {\n /** Add element to selection. */\n AddElementToSelection,\n /** Remove element from selection. */\n RemoveElementFromSelection,\n /** If element is in selection remove it, else add it. */\n InvertElementInSelection,\n /** Replace current selection with element. */\n ReplaceSelectionWithElement,\n}\n\n/** Tool for picking a set of elements of interest, selected by the user.\n * @public\n */\nexport class SelectionTool extends PrimitiveTool {\n public static override hidden = false;\n public static override toolId = \"Select\";\n public static override iconSpec = \"icon-cursor\";\n protected _isSelectByPoints = false;\n protected _isSuspended = false;\n protected readonly _points: Point3d[] = [];\n private _selectionMethodValue: DialogItemValue = { value: SelectionMethod.Pick };\n private _selectionModeValue: DialogItemValue = { value: SelectionMode.Replace };\n\n public override requireWriteableTarget(): boolean { return false; }\n public override autoLockTarget(): void { } // NOTE: For selecting elements we only care about iModel, so don't lock target model automatically.\n\n protected wantSelectionClearOnMiss(_ev: BeButtonEvent): boolean { return SelectionMode.Replace === this.selectionMode; }\n protected wantEditManipulators(): boolean { return SelectionMethod.Pick === this.selectionMethod; }\n protected wantPickableDecorations(): boolean { return this.wantEditManipulators(); } // Allow pickable decorations selection to be independent of manipulators...\n protected wantToolSettings(): boolean { return true; }\n\n public get selectionMethod(): SelectionMethod { return this._selectionMethodValue.value as SelectionMethod; }\n public set selectionMethod(method: SelectionMethod) { this._selectionMethodValue.value = method; }\n public get selectionMode(): SelectionMode { return this._selectionModeValue.value as SelectionMode; }\n public set selectionMode(mode: SelectionMode) { this._selectionModeValue.value = mode; }\n\n private static methodsMessage(str: string) { return CoreTools.translate(`ElementSet.SelectionMethods.${str}`); }\n private static _methodsName = \"selectionMethods\";\n /* The property descriptions used to generate ToolSettings UI. */\n private static _getMethodsDescription(): PropertyDescription {\n return {\n name: SelectionTool._methodsName,\n displayLabel: \"\",\n typename: \"enum\",\n editor: {\n name: \"enum-buttongroup\",\n params: [{\n type: PropertyEditorParamTypes.ButtonGroupData,\n buttons: [\n { iconSpec: \"icon-select-single\" },\n { iconSpec: \"icon-select-line\" },\n { iconSpec: \"icon-select-box\" },\n ],\n } as ButtonGroupEditorParams, {\n type: PropertyEditorParamTypes.SuppressEditorLabel,\n suppressLabelPlaceholder: true,\n } as SuppressLabelEditorParams,\n ],\n },\n enum: {\n choices: [\n { label: SelectionTool.methodsMessage(\"Pick\"), value: SelectionMethod.Pick },\n { label: SelectionTool.methodsMessage(\"Line\"), value: SelectionMethod.Line },\n { label: SelectionTool.methodsMessage(\"Box\"), value: SelectionMethod.Box },\n ],\n },\n };\n }\n\n private static modesMessage(str: string) { return CoreTools.translate(`ElementSet.SelectionModes.${str}`); }\n private static _modesName = \"selectionModes\";\n /* The property descriptions used to generate ToolSettings UI. */\n private static _getModesDescription(): PropertyDescription {\n return {\n name: SelectionTool._modesName,\n displayLabel: \"\",\n typename: \"enum\",\n editor: {\n name: \"enum-buttongroup\",\n params: [{\n type: PropertyEditorParamTypes.ButtonGroupData,\n buttons: [\n { iconSpec: \"icon-replace\" },\n { iconSpec: \"icon-select-plus\" },\n {\n iconSpec: \"icon-select-minus\",\n isEnabledFunction: () => {\n const tool = IModelApp.toolAdmin.activeTool;\n return tool instanceof PrimitiveTool ? tool.iModel.selectionSet.isActive : false;\n },\n },\n ],\n } as ButtonGroupEditorParams, {\n type: PropertyEditorParamTypes.SuppressEditorLabel,\n suppressLabelPlaceholder: true,\n } as SuppressLabelEditorParams,\n ],\n },\n enum: {\n choices: [\n { label: SelectionTool.modesMessage(\"Replace\"), value: SelectionMode.Replace },\n { label: SelectionTool.modesMessage(\"Add\"), value: SelectionMode.Add },\n { label: SelectionTool.modesMessage(\"Remove\"), value: SelectionMode.Remove },\n ],\n },\n };\n }\n\n protected showPrompt(mode: SelectionMode, method: SelectionMethod): void {\n let mainMsg = \"ElementSet.Prompts.\";\n switch (method) {\n case SelectionMethod.Pick:\n mainMsg += \"IdentifyElement\";\n break;\n case SelectionMethod.Line:\n mainMsg += (0 === this._points.length ? \"StartPoint\" : \"EndPoint\");\n break;\n case SelectionMethod.Box:\n mainMsg += (0 === this._points.length ? \"StartCorner\" : \"OppositeCorner\");\n break;\n }\n\n const mainInstruction = ToolAssistance.createInstruction(this.iconSpec, CoreTools.translate(mainMsg));\n const sections: ToolAssistanceSection[] = [];\n\n switch (method) {\n case SelectionMethod.Pick:\n const mousePickInstructions: ToolAssistanceInstruction[] = [];\n mousePickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.AcceptElement\"), false, ToolAssistanceInputMethod.Mouse));\n mousePickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClickDrag, CoreTools.translate(\"ElementSet.Inputs.BoxCorners\"), false, ToolAssistanceInputMethod.Mouse));\n mousePickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.RightClickDrag, CoreTools.translate(\"ElementSet.Inputs.CrossingLine\"), false, ToolAssistanceInputMethod.Mouse));\n mousePickInstructions.push(ToolAssistance.createModifierKeyInstruction(ToolAssistance.shiftKey, ToolAssistanceImage.LeftClickDrag, CoreTools.translate(\"ElementSet.Inputs.OverlapSelection\"), false, ToolAssistanceInputMethod.Mouse));\n if (SelectionMode.Replace === mode) {\n mousePickInstructions.push(ToolAssistance.createKeyboardInstruction(ToolAssistance.ctrlKeyboardInfo, CoreTools.translate(\"ElementSet.Inputs.InvertSelection\"), false, ToolAssistanceInputMethod.Mouse));\n mousePickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.CursorClick, CoreTools.translate(\"ElementSet.Inputs.ClearSelection\"), false, ToolAssistanceInputMethod.Mouse));\n }\n sections.push(ToolAssistance.createSection(mousePickInstructions, ToolAssistance.inputsLabel));\n\n const touchPickInstructions: ToolAssistanceInstruction[] = [];\n if (!ToolAssistance.createTouchCursorInstructions(touchPickInstructions))\n touchPickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.OneTouchTap, CoreTools.translate(\"ElementSet.Inputs.AcceptElement\"), false, ToolAssistanceInputMethod.Touch));\n sections.push(ToolAssistance.createSection(touchPickInstructions, ToolAssistance.inputsLabel));\n break;\n case SelectionMethod.Line:\n const mouseLineInstructions: ToolAssistanceInstruction[] = [];\n mouseLineInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.AcceptPoint\"), false, ToolAssistanceInputMethod.Mouse));\n if (SelectionMode.Replace === mode)\n mouseLineInstructions.push(ToolAssistance.createModifierKeyInstruction(ToolAssistance.ctrlKey, ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.InvertSelection\"), false, ToolAssistanceInputMethod.Mouse));\n sections.push(ToolAssistance.createSection(mouseLineInstructions, ToolAssistance.inputsLabel));\n\n const touchLineInstructions: ToolAssistanceInstruction[] = [];\n touchLineInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.OneTouchDrag, CoreTools.translate(\"ElementSet.Inputs.AcceptPoint\"), false, ToolAssistanceInputMethod.Touch));\n sections.push(ToolAssistance.createSection(touchLineInstructions, ToolAssistance.inputsLabel));\n break;\n case SelectionMethod.Box:\n const mouseBoxInstructions: ToolAssistanceInstruction[] = [];\n mouseBoxInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.AcceptPoint\"), false, ToolAssistanceInputMethod.Mouse));\n mouseBoxInstructions.push(ToolAssistance.createModifierKeyInstruction(ToolAssistance.shiftKey, ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.OverlapSelection\"), false, ToolAssistanceInputMethod.Mouse));\n if (SelectionMode.Replace === mode)\n mouseBoxInstructions.push(ToolAssistance.createModifierKeyInstruction(ToolAssistance.ctrlKey, ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.InvertSelection\"), false, ToolAssistanceInputMethod.Mouse));\n sections.push(ToolAssistance.createSection(mouseBoxInstructions, ToolAssistance.inputsLabel));\n\n const touchBoxInstructions: ToolAssistanceInstruction[] = [];\n touchBoxInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.OneTouchDrag, CoreTools.translate(\"ElementSet.Inputs.AcceptPoint\"), false, ToolAssistanceInputMethod.Touch));\n sections.push(ToolAssistance.createSection(touchBoxInstructions, ToolAssistance.inputsLabel));\n break;\n }\n\n const instructions = ToolAssistance.createInstructions(mainInstruction, sections);\n IModelApp.notifications.setToolAssistance(instructions);\n }\n\n protected initSelectTool(): void {\n const method = this.selectionMethod;\n const mode = this.selectionMode;\n const enableLocate = SelectionMethod.Pick === method;\n\n this._isSelectByPoints = false;\n this._points.length = 0;\n\n this.initLocateElements(enableLocate, false, enableLocate ? \"default\" : IModelApp.viewManager.crossHairCursor, CoordinateLockOverrides.All);\n IModelApp.locateManager.options.allowDecorations = true; // Always locate to display tool tip even if we reject for adding to selection set...\n this.showPrompt(mode, method);\n }\n\n protected processMiss(_ev: BeButtonEvent): boolean {\n if (!this.iModel.selectionSet.isActive)\n return false;\n this.iModel.selectionSet.emptyAll();\n return true;\n }\n\n public updateSelection(elementId: Id64Arg, process: SelectionProcessing): boolean {\n let returnValue = false;\n switch (process) {\n case SelectionProcessing.AddElementToSelection:\n returnValue = this.iModel.selectionSet.add(elementId);\n break;\n case SelectionProcessing.RemoveElementFromSelection:\n returnValue = this.iModel.selectionSet.remove(elementId);\n break;\n case SelectionProcessing.InvertElementInSelection: // (if element is in selection remove it else add it.)\n returnValue = this.iModel.selectionSet.invert(elementId);\n break;\n case SelectionProcessing.ReplaceSelectionWithElement:\n this.iModel.selectionSet.replace(elementId);\n returnValue = true;\n break;\n default:\n return false;\n }\n // always force UI to sync display of options since the select option of Remove should only be enabled if the selection set has elements.\n if (returnValue)\n this.syncSelectionMode();\n return returnValue;\n }\n\n public async processSelection(elementId: Id64Arg, process: SelectionProcessing): Promise<boolean> { return this.updateSelection(elementId, process); }\n\n protected useOverlapSelection(ev: BeButtonEvent): boolean {\n if (undefined === ev.viewport)\n return false;\n const pt1 = ev.viewport.worldToView(this._points[0]);\n const pt2 = ev.viewport.worldToView(ev.point);\n const overlapMode = (pt1.x > pt2.x);\n return (ev.isShiftKey ? !overlapMode : overlapMode); // Shift inverts inside/overlap selection...\n }\n\n private selectByPointsDecorate(context: DecorateContext): void {\n if (!this._isSelectByPoints)\n return;\n\n const ev = new BeButtonEvent();\n IModelApp.toolAdmin.fillEventFromCursorLocation(ev);\n if (undefined === ev.viewport)\n return;\n\n const vp = context.viewport;\n const bestContrastIsBlack = (ColorDef.black === vp.getContrastToBackgroundColor());\n const crossingLine = (SelectionMethod.Line === this.selectionMethod || (SelectionMethod.Pick === this.selectionMethod && BeButton.Reset === ev.button));\n const overlapSelection = (crossingLine || this.useOverlapSelection(ev));\n\n const position = vp.worldToView(this._points[0]);\n position.x = Math.floor(position.x) + 0.5;\n position.y = Math.floor(position.y) + 0.5;\n const position2 = vp.worldToView(ev.point);\n position2.x = Math.floor(position2.x) + 0.5;\n position2.y = Math.floor(position2.y) + 0.5;\n const offset = position2.minus(position);\n\n const drawDecoration = (ctx: CanvasRenderingContext2D) => {\n ctx.strokeStyle = bestContrastIsBlack ? \"black\" : \"white\";\n ctx.lineWidth = 1;\n if (overlapSelection)\n ctx.setLineDash([5, 5]);\n\n if (crossingLine) {\n ctx.beginPath();\n ctx.moveTo(0, 0);\n ctx.lineTo(offset.x, offset.y);\n ctx.stroke();\n } else {\n ctx.strokeRect(0, 0, offset.x, offset.y);\n ctx.fillStyle = bestContrastIsBlack ? \"rgba(0,0,0,.06)\" : \"rgba(255,255,255,.06)\";\n ctx.fillRect(0, 0, offset.x, offset.y);\n }\n };\n context.addCanvasDecoration({ position, drawDecoration });\n }\n\n protected selectByPointsProcess(origin: Point3d, corner: Point3d, ev: BeButtonEvent, method: SelectionMethod, overlap: boolean) {\n const vp = ev.viewport;\n if (!vp)\n return;\n\n const pts: Point2d[] = [];\n pts[0] = new Point2d(Math.floor(origin.x + 0.5), Math.floor(origin.y + 0.5));\n pts[1] = new Point2d(Math.floor(corner.x + 0.5), Math.floor(corner.y + 0.5));\n const range = Range2d.createArray(pts);\n\n const rect = new ViewRect();\n rect.initFromRange(range);\n const allowTransients = this.wantPickableDecorations();\n\n vp.readPixels(rect, Pixel.Selector.Feature, (pixels) => {\n if (undefined === pixels)\n return;\n\n const sRange = Range2d.createNull();\n sRange.extendPoint(Point2d.create(vp.cssPixelsToDevicePixels(range.low.x), vp.cssPixelsToDevicePixels(range.low.y)));\n sRange.extendPoint(Point2d.create(vp.cssPixelsToDevicePixels(range.high.x), vp.cssPixelsToDevicePixels(range.high.y)));\n\n pts[0].x = vp.cssPixelsToDevicePixels(pts[0].x);\n pts[0].y = vp.cssPixelsToDevicePixels(pts[0].y);\n\n pts[1].x = vp.cssPixelsToDevicePixels(pts[1].x);\n pts[1].y = vp.cssPixelsToDevicePixels(pts[1].y);\n\n let contents = new Set<string>();\n const testPoint = Point2d.createZero();\n\n const getPixelElementId = (pixel: Pixel.Data) => {\n if (undefined === pixel.elementId || Id64.isInvalid(pixel.elementId))\n return undefined; // no geometry at this location...\n\n if (!allowTransients && Id64.isTransient(pixel.elementId))\n return undefined; // tool didn't request pickable decorations...\n\n if (!vp.isPixelSelectable(pixel))\n return undefined; // reality model, terrain, etc - not selectable\n\n return pixel.elementId;\n };\n\n if (SelectionMethod.Box === method) {\n const outline = overlap ? undefined : new Set<string>();\n const offset = sRange.clone();\n offset.expandInPlace(-2);\n for (testPoint.x = sRange.low.x; testPoint.x <= sRange.high.x; ++testPoint.x) {\n for (testPoint.y = sRange.low.y; testPoint.y <= sRange.high.y; ++testPoint.y) {\n const pixel = pixels.getPixel(testPoint.x, testPoint.y);\n const elementId = getPixelElementId(pixel);\n if (undefined === elementId)\n continue;\n\n if (undefined !== outline && !offset.containsPoint(testPoint))\n outline.add(elementId.toString());\n else\n contents.add(elementId.toString());\n }\n }\n if (undefined !== outline && 0 !== outline.size) {\n const inside = new Set<string>();\n contents.forEach((id) => {\n if (!outline.has(id))\n inside.add(id);\n });\n\n contents = inside;\n }\n } else {\n const closePoint = Point2d.createZero();\n for (testPoint.x = sRange.low.x; testPoint.x <= sRange.high.x; ++testPoint.x) {\n for (testPoint.y = sRange.low.y; testPoint.y <= sRange.high.y; ++testPoint.y) {\n const pixel = pixels.getPixel(testPoint.x, testPoint.y);\n const elementId = getPixelElementId(pixel);\n if (undefined === elementId)\n continue;\n\n const fraction = testPoint.fractionOfProjectionToLine(pts[0], pts[1], 0.0);\n pts[0].interpolate(fraction, pts[1], closePoint);\n if (closePoint.distance(testPoint) < 1.5)\n contents.add(elementId.toString());\n }\n }\n }\n\n if (0 === contents.size) {\n if (!ev.isControlKey && this.wantSelectionClearOnMiss(ev) && this.processMiss(ev))\n this.syncSelectionMode();\n return;\n }\n\n switch (this.selectionMode) {\n case SelectionMode.Replace:\n if (!ev.isControlKey)\n this.processSelection(contents, SelectionProcessing.ReplaceSelectionWithElement); // eslint-disable-line @typescript-eslint/no-floating-promises\n else\n this.processSelection(contents, SelectionProcessing.InvertElementInSelection); // eslint-disable-line @typescript-eslint/no-floating-promises\n break;\n case SelectionMode.Add:\n this.processSelection(contents, SelectionProcessing.AddElementToSelection); // eslint-disable-line @typescript-eslint/no-floating-promises\n break;\n case SelectionMode.Remove:\n this.processSelection(contents, SelectionProcessing.RemoveElementFromSelection); // eslint-disable-line @typescript-eslint/no-floating-promises\n break;\n }\n }, true);\n }\n\n protected selectByPointsStart(ev: BeButtonEvent): boolean {\n if (BeButton.Data !== ev.button && BeButton.Reset !== ev.button)\n return false;\n this._points.length = 0;\n this._points.push(ev.point.clone());\n this._isSelectByPoints = true;\n IModelApp.accuSnap.enableLocate(false);\n IModelApp.toolAdmin.setLocateCircleOn(false);\n this.showPrompt(this.selectionMode, this.selectionMethod);\n return true;\n }\n\n protected selectByPointsEnd(ev: BeButtonEvent): boolean {\n if (!this._isSelectByPoints)\n return false;\n\n const vp = ev.viewport;\n if (vp === undefined) {\n this.initSelectTool();\n return false;\n }\n\n const origin = vp.worldToView(this._points[0]);\n const corner = vp.worldToView(ev.point);\n if (SelectionMethod.Line === this.selectionMethod || (SelectionMethod.Pick === this.selectionMethod && BeButton.Reset === ev.button))\n this.selectByPointsProcess(origin, corner, ev, SelectionMethod.Line, true);\n else\n this.selectByPointsProcess(origin, corner, ev, SelectionMethod.Box, this.useOverlapSelection(ev));\n\n this.initSelectTool();\n vp.invalidateDecorations();\n return true;\n }\n\n public override async onMouseMotion(ev: BeButtonEvent): Promise<void> {\n if (undefined !== ev.viewport && this._isSelectByPoints)\n ev.viewport.invalidateDecorations();\n }\n\n public async selectDecoration(ev: BeButtonEvent, currHit?: HitDetail): Promise<EventHandled> {\n if (undefined === currHit)\n currHit = await IModelApp.locateManager.doLocate(new LocateResponse(), true, ev.point, ev.viewport, ev.inputSource);\n\n if (undefined !== currHit)\n return (currHit.isElementHit ? IModelApp.viewManager.overrideElementButtonEvent(currHit, ev) : IModelApp.viewManager.onDecorationButtonEvent(currHit, ev));\n\n return EventHandled.No;\n }\n\n public override async onMouseStartDrag(ev: BeButtonEvent): Promise<EventHandled> {\n IModelApp.accuSnap.clear(); // Need to test hit at start drag location, not current AccuSnap...\n if (EventHandled.Yes === await this.selectDecoration(ev))\n return EventHandled.Yes;\n if (InputSource.Touch === ev.inputSource && SelectionMethod.Pick === this.selectionMethod)\n return EventHandled.No; // Require method change for line/box selection...allow IdleTool to handle touch move...\n return this.selectByPointsStart(ev) ? EventHandled.Yes : EventHandled.No;\n }\n\n public override async onMouseEndDrag(ev: BeButtonEvent): Promise<EventHandled> {\n return this.selectByPointsEnd(ev) ? EventHandled.Yes : EventHandled.No;\n }\n\n public override async onDataButtonUp(ev: BeButtonEvent): Promise<EventHandled> {\n if (undefined === ev.viewport)\n return EventHandled.No;\n\n if (this.selectByPointsEnd(ev))\n return EventHandled.Yes;\n\n if (SelectionMethod.Pick !== this.selectionMethod) {\n if (!ev.isControlKey && this.wantSelectionClearOnMiss(ev) && this.processMiss(ev))\n this.syncSelectionMode();\n if (InputSource.Touch !== ev.inputSource)\n this.selectByPointsStart(ev); // Require touch move and not tap to start crossing line/box selection...\n return EventHandled.Yes;\n }\n\n const hit = await IModelApp.locateManager.doLocate(new LocateResponse(), true, ev.point, ev.viewport, ev.inputSource);\n if (hit !== undefined && !hit.isModelHit && !hit.isMapHit) { // model hit = terrain, reality models, background maps, etc - not selectable\n if (EventHandled.Yes === await this.selectDecoration(ev, hit))\n return EventHandled.Yes;\n\n switch (this.selectionMode) {\n case SelectionMode.Replace:\n await this.processSelection(hit.sourceId, ev.isControlKey ? SelectionProcessing.InvertElementInSelection : SelectionProcessing.ReplaceSelectionWithElement);\n break;\n\n case SelectionMode.Add:\n await this.processSelection(hit.sourceId, SelectionProcessing.AddElementToSelection);\n break;\n\n case SelectionMode.Remove:\n await this.processSelection(hit.sourceId, SelectionProcessing.RemoveElementFromSelection);\n break;\n }\n return EventHandled.Yes;\n }\n\n if (!ev.isControlKey && this.wantSelectionClearOnMiss(ev) && this.processMiss(ev))\n this.syncSelectionMode();\n\n return EventHandled.Yes;\n }\n\n public override async onResetButtonUp(ev: BeButtonEvent): Promise<EventHandled> {\n if (this._isSelectByPoints) {\n if (undefined !== ev.viewport)\n ev.viewport.invalidateDecorations();\n this.initSelectTool();\n return EventHandled.Yes;\n }\n\n // Check for overlapping hits...\n const lastHit = SelectionMode.Remove === this.selectionMode ? undefined : IModelApp.locateManager.currHit;\n if (lastHit && this.iModel.selectionSet.has(lastHit.sourceId)) {\n const autoHit = IModelApp.accuSnap.currHit;\n\n // Play nice w/auto-locate, only remove previous hit if not currently auto-locating or over previous hit\n if (undefined === autoHit || autoHit.isSameHit(lastHit)) {\n const response = new LocateResponse();\n let nextHit;\n do {\n nextHit = await IModelApp.locateManager.doLocate(response, false, ev.point, ev.viewport, ev.inputSource);\n } while (undefined !== nextHit && (nextHit.isModelHit || nextHit.isMapHit)); // Ignore reality models, terrain, maps, etc.\n\n // remove element(s) previously selected if in replace mode, or if we have a next element in add mode\n if (SelectionMode.Replace === this.selectionMode || undefined !== nextHit)\n await this.processSelection(lastHit.sourceId, SelectionProcessing.RemoveElementFromSelection);\n\n // add element(s) located via reset button\n if (undefined !== nextHit)\n await this.processSelection(nextHit.sourceId, SelectionProcessing.AddElementToSelection);\n\n return EventHandled.Yes;\n }\n }\n\n if (EventHandled.Yes === await this.selectDecoration(ev, IModelApp.accuSnap.currHit))\n return EventHandled.Yes;\n\n await IModelApp.accuSnap.resetButton();\n return EventHandled.Yes;\n }\n\n public override async onSuspend() {\n this._isSuspended = true;\n if (this.wantEditManipulators())\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, ManipulatorToolEvent.Suspend);\n }\n\n public override async onUnsuspend() {\n this._isSuspended = false;\n if (this.wantEditManipulators())\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, ManipulatorToolEvent.Unsuspend);\n\n this.showPrompt(this.selectionMode, this.selectionMethod);\n }\n\n public override async onTouchMoveStart(ev: BeTouchEvent, startEv: BeTouchEvent): Promise<EventHandled> {\n if (startEv.isSingleTouch && !this._isSelectByPoints)\n await IModelApp.toolAdmin.convertTouchMoveStartToButtonDownAndMotion(startEv, ev);\n return (this._isSuspended || this._isSelectByPoints) ? EventHandled.Yes : EventHandled.No;\n }\n\n public override async onTouchMove(ev: BeTouchEvent): Promise<void> {\n if (this._isSelectByPoints)\n return IModelApp.toolAdmin.convertTouchMoveToMotion(ev);\n }\n\n public override async onTouchComplete(ev: BeTouchEvent): Promise<void> {\n if (this._isSelectByPoints)\n return IModelApp.toolAdmin.convertTouchEndToButtonUp(ev);\n }\n\n public override async onTouchCancel(ev: BeTouchEvent): Promise<void> {\n if (this._isSelectByPoints)\n return IModelApp.toolAdmin.convertTouchEndToButtonUp(ev, BeButton.Reset);\n }\n\n public override decorate(context: DecorateContext): void { this.selectByPointsDecorate(context); }\n\n public override async onModifierKeyTransition(_wentDown: boolean, modifier: BeModifierKeys, _event: KeyboardEvent): Promise<EventHandled> {\n return (modifier === BeModifierKeys.Shift && this._isSelectByPoints) ? EventHandled.Yes : EventHandled.No;\n }\n\n public override async filterHit(hit: HitDetail, out?: LocateResponse): Promise<LocateFilterStatus> {\n if (!this.wantPickableDecorations() && !hit.isElementHit)\n return LocateFilterStatus.Reject;\n\n const mode = this.selectionMode;\n if (SelectionMode.Replace === mode)\n return LocateFilterStatus.Accept;\n\n const isSelected = this.iModel.selectionSet.has(hit.sourceId);\n const status = ((SelectionMode.Add === mode ? !isSelected : isSelected) ? LocateFilterStatus.Accept : LocateFilterStatus.Reject);\n if (out && LocateFilterStatus.Reject === status)\n out.explanation = CoreTools.translate(`ElementSet.Error.${isSelected ? \"AlreadySelected\" : \"NotSelected\"}`);\n return status;\n }\n\n public async onRestartTool(): Promise<void> { return this.exitTool(); }\n\n public override async onCleanup() {\n if (this.wantEditManipulators())\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, ManipulatorToolEvent.Stop);\n }\n\n public override async onPostInstall() {\n await super.onPostInstall();\n if (!this.targetView)\n return;\n if (this.wantEditManipulators())\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, ManipulatorToolEvent.Start);\n this.initSelectTool();\n }\n\n public static async startTool(): Promise<boolean> { return new SelectionTool().run(); }\n\n private syncSelectionMode(): void {\n if (SelectionMode.Remove === this.selectionMode && !this.iModel.selectionSet.isActive) {\n // No selection active resetting selection mode since there is nothing to Remove\n this.selectionMode = SelectionMode.Replace;\n this.initSelectTool();\n }\n if (this.wantToolSettings()) {\n const syncMode: DialogPropertySyncItem = { value: this._selectionModeValue, propertyName: SelectionTool._modesName };\n IModelApp.toolAdmin.toolSettingsState.saveToolSettingProperty(this.toolId, syncMode);\n this.syncToolSettingsProperties([syncMode]);\n }\n }\n\n /** Used to supply DefaultToolSettingProvider with a list of properties to use to generate ToolSettings. If undefined then no ToolSettings will be displayed\n * @beta\n */\n public override supplyToolSettingsProperties(): DialogItem[] | undefined {\n if (!this.wantToolSettings())\n return undefined;\n\n // load latest values from session\n IModelApp.toolAdmin.toolSettingsState.getInitialToolSettingValues(this.toolId, [SelectionTool._modesName])?.forEach((value) => {\n if (value.propertyName === SelectionTool._modesName)\n this._selectionModeValue = value.value;\n });\n\n // Make sure a mode of SelectionMode.Remove is valid\n if (SelectionMode.Remove === this.selectionMode && !this.iModel.selectionSet.isActive) {\n this.selectionMode = SelectionMode.Replace;\n IModelApp.toolAdmin.toolSettingsState.saveToolSettingProperty(this.toolId, { propertyName: SelectionTool._modesName, value: this._selectionModeValue });\n }\n\n const toolSettings = new Array<DialogItem>();\n // generate 3 columns - label will be placed in column 0 and button group editors in columns 1 and 2.\n toolSettings.push({ value: this._selectionMethodValue, property: SelectionTool._getMethodsDescription(), editorPosition: { rowPriority: 0, columnIndex: 1 } });\n toolSettings.push({ value: this._selectionModeValue, property: SelectionTool._getModesDescription(), editorPosition: { rowPriority: 0, columnIndex: 2 } });\n return toolSettings;\n }\n\n /** Used to send changes from UI back to Tool\n * @beta\n */\n public override async applyToolSettingPropertyChange(updatedValue: DialogPropertySyncItem): Promise<boolean> {\n let changed = false;\n if (updatedValue.propertyName === SelectionTool._methodsName) {\n const saveWantManipulators = this.wantEditManipulators();\n this._selectionMethodValue = updatedValue.value;\n if (this._selectionMethodValue) {\n const currWantManipulators = this.wantEditManipulators();\n if (saveWantManipulators !== currWantManipulators)\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, currWantManipulators ? ManipulatorToolEvent.Start : ManipulatorToolEvent.Stop);\n changed = true;\n }\n }\n if (updatedValue.propertyName === SelectionTool._modesName) {\n this._selectionModeValue = updatedValue.value;\n if (this._selectionModeValue) {\n if (this.wantToolSettings())\n IModelApp.toolAdmin.toolSettingsState.saveToolSettingProperty(this.toolId, { propertyName: SelectionTool._modesName, value: this._selectionModeValue });\n changed = true;\n }\n }\n if (changed)\n this.initSelectTool();\n return true; // return true if change is valid\n }\n}\n"]}
1
+ {"version":3,"file":"SelectTool.js","sourceRoot":"","sources":["../../../src/tools/SelectTool.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module SelectionSet\n */\n\nimport { Id64, Id64Arg } from \"@itwin/core-bentley\";\nimport { Point2d, Point3d, Range2d } from \"@itwin/core-geometry\";\nimport { ColorDef } from \"@itwin/core-common\";\nimport {\n ButtonGroupEditorParams, DialogItem, DialogItemValue, DialogPropertySyncItem, PropertyDescription, PropertyEditorParamTypes,\n SuppressLabelEditorParams,\n} from \"@itwin/appui-abstract\";\nimport { LocateFilterStatus, LocateResponse } from \"../ElementLocateManager\";\nimport { HitDetail } from \"../HitDetail\";\nimport { IModelApp } from \"../IModelApp\";\nimport { Pixel } from \"../render/Pixel\";\nimport { DecorateContext } from \"../ViewContext\";\nimport { ViewRect } from \"../common/ViewRect\";\nimport { PrimitiveTool } from \"./PrimitiveTool\";\nimport { BeButton, BeButtonEvent, BeModifierKeys, BeTouchEvent, CoordinateLockOverrides, CoreTools, EventHandled, InputSource } from \"./Tool\";\nimport { ManipulatorToolEvent } from \"./ToolAdmin\";\nimport { ToolAssistance, ToolAssistanceImage, ToolAssistanceInputMethod, ToolAssistanceInstruction, ToolAssistanceSection } from \"./ToolAssistance\";\n\n// cSpell:ignore buttongroup\n\n/** The method for choosing elements with the [[SelectionTool]]\n * @public\n * @extensions\n */\nexport enum SelectionMethod {\n /** Identify element(s) by picking for drag selection (inside/overlap for drag box selection determined by point direction and shift key) */\n Pick,\n /** Identify elements by overlap with crossing line */\n Line,\n /** Identify elements by box selection (inside/overlap for box selection determined by point direction and shift key) */\n Box,\n}\n\n/** The mode for choosing elements with the [[SelectionTool]]\n * @public\n * @extensions\n */\nexport enum SelectionMode {\n /** Identified elements replace the current selection set (use control key to add or remove) */\n Replace,\n /** Identified elements are added to the current selection set */\n Add,\n /** Identified elements are removed from the current selection set */\n Remove,\n}\n\n/** The processing method to use to update the current selection.\n * @public\n * @extensions\n */\nexport enum SelectionProcessing {\n /** Add element to selection. */\n AddElementToSelection,\n /** Remove element from selection. */\n RemoveElementFromSelection,\n /** If element is in selection remove it, else add it. */\n InvertElementInSelection,\n /** Replace current selection with element. */\n ReplaceSelectionWithElement,\n}\n\n/** Tool for picking a set of elements of interest, selected by the user.\n * @public\n */\nexport class SelectionTool extends PrimitiveTool {\n public static override hidden = false;\n public static override toolId = \"Select\";\n public static override iconSpec = \"icon-cursor\";\n protected _isSelectByPoints = false;\n protected _isSuspended = false;\n protected readonly _points: Point3d[] = [];\n private _selectionMethodValue: DialogItemValue = { value: SelectionMethod.Pick };\n private _selectionModeValue: DialogItemValue = { value: SelectionMode.Replace };\n\n public override requireWriteableTarget(): boolean { return false; }\n public override autoLockTarget(): void { } // NOTE: For selecting elements we only care about iModel, so don't lock target model automatically.\n\n protected wantSelectionClearOnMiss(_ev: BeButtonEvent): boolean { return SelectionMode.Replace === this.selectionMode; }\n protected wantEditManipulators(): boolean { return SelectionMethod.Pick === this.selectionMethod; }\n protected wantPickableDecorations(): boolean { return this.wantEditManipulators(); } // Allow pickable decorations selection to be independent of manipulators...\n protected wantToolSettings(): boolean { return true; }\n\n public get selectionMethod(): SelectionMethod { return this._selectionMethodValue.value as SelectionMethod; }\n public set selectionMethod(method: SelectionMethod) { this._selectionMethodValue.value = method; }\n public get selectionMode(): SelectionMode { return this._selectionModeValue.value as SelectionMode; }\n public set selectionMode(mode: SelectionMode) { this._selectionModeValue.value = mode; }\n\n private static methodsMessage(str: string) { return CoreTools.translate(`ElementSet.SelectionMethods.${str}`); }\n private static _methodsName = \"selectionMethods\";\n /* The property descriptions used to generate ToolSettings UI. */\n private static _getMethodsDescription(): PropertyDescription {\n return {\n name: SelectionTool._methodsName,\n displayLabel: \"\",\n typename: \"enum\",\n editor: {\n name: \"enum-buttongroup\",\n params: [{\n type: PropertyEditorParamTypes.ButtonGroupData,\n buttons: [\n { iconSpec: \"icon-select-single\" },\n { iconSpec: \"icon-select-line\" },\n { iconSpec: \"icon-select-box\" },\n ],\n } as ButtonGroupEditorParams, {\n type: PropertyEditorParamTypes.SuppressEditorLabel,\n suppressLabelPlaceholder: true,\n } as SuppressLabelEditorParams,\n ],\n },\n enum: {\n choices: [\n { label: SelectionTool.methodsMessage(\"Pick\"), value: SelectionMethod.Pick },\n { label: SelectionTool.methodsMessage(\"Line\"), value: SelectionMethod.Line },\n { label: SelectionTool.methodsMessage(\"Box\"), value: SelectionMethod.Box },\n ],\n },\n };\n }\n\n private static modesMessage(str: string) { return CoreTools.translate(`ElementSet.SelectionModes.${str}`); }\n private static _modesName = \"selectionModes\";\n /* The property descriptions used to generate ToolSettings UI. */\n private static _getModesDescription(): PropertyDescription {\n return {\n name: SelectionTool._modesName,\n displayLabel: \"\",\n typename: \"enum\",\n editor: {\n name: \"enum-buttongroup\",\n params: [{\n type: PropertyEditorParamTypes.ButtonGroupData,\n buttons: [\n { iconSpec: \"icon-replace\" },\n { iconSpec: \"icon-select-plus\" },\n {\n iconSpec: \"icon-select-minus\",\n isEnabledFunction: () => {\n const tool = IModelApp.toolAdmin.activeTool;\n return tool instanceof PrimitiveTool ? tool.iModel.selectionSet.isActive : false;\n },\n },\n ],\n } as ButtonGroupEditorParams, {\n type: PropertyEditorParamTypes.SuppressEditorLabel,\n suppressLabelPlaceholder: true,\n } as SuppressLabelEditorParams,\n ],\n },\n enum: {\n choices: [\n { label: SelectionTool.modesMessage(\"Replace\"), value: SelectionMode.Replace },\n { label: SelectionTool.modesMessage(\"Add\"), value: SelectionMode.Add },\n { label: SelectionTool.modesMessage(\"Remove\"), value: SelectionMode.Remove },\n ],\n },\n };\n }\n\n protected showPrompt(mode: SelectionMode, method: SelectionMethod): void {\n let mainMsg = \"ElementSet.Prompts.\";\n switch (method) {\n case SelectionMethod.Pick:\n mainMsg += \"IdentifyElement\";\n break;\n case SelectionMethod.Line:\n mainMsg += (0 === this._points.length ? \"StartPoint\" : \"EndPoint\");\n break;\n case SelectionMethod.Box:\n mainMsg += (0 === this._points.length ? \"StartCorner\" : \"OppositeCorner\");\n break;\n }\n\n const mainInstruction = ToolAssistance.createInstruction(this.iconSpec, CoreTools.translate(mainMsg));\n const sections: ToolAssistanceSection[] = [];\n\n switch (method) {\n case SelectionMethod.Pick:\n const mousePickInstructions: ToolAssistanceInstruction[] = [];\n mousePickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.AcceptElement\"), false, ToolAssistanceInputMethod.Mouse));\n mousePickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClickDrag, CoreTools.translate(\"ElementSet.Inputs.BoxCorners\"), false, ToolAssistanceInputMethod.Mouse));\n mousePickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.RightClickDrag, CoreTools.translate(\"ElementSet.Inputs.CrossingLine\"), false, ToolAssistanceInputMethod.Mouse));\n mousePickInstructions.push(ToolAssistance.createModifierKeyInstruction(ToolAssistance.shiftKey, ToolAssistanceImage.LeftClickDrag, CoreTools.translate(\"ElementSet.Inputs.OverlapSelection\"), false, ToolAssistanceInputMethod.Mouse));\n if (SelectionMode.Replace === mode) {\n mousePickInstructions.push(ToolAssistance.createKeyboardInstruction(ToolAssistance.ctrlKeyboardInfo, CoreTools.translate(\"ElementSet.Inputs.InvertSelection\"), false, ToolAssistanceInputMethod.Mouse));\n mousePickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.CursorClick, CoreTools.translate(\"ElementSet.Inputs.ClearSelection\"), false, ToolAssistanceInputMethod.Mouse));\n }\n sections.push(ToolAssistance.createSection(mousePickInstructions, ToolAssistance.inputsLabel));\n\n const touchPickInstructions: ToolAssistanceInstruction[] = [];\n if (!ToolAssistance.createTouchCursorInstructions(touchPickInstructions))\n touchPickInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.OneTouchTap, CoreTools.translate(\"ElementSet.Inputs.AcceptElement\"), false, ToolAssistanceInputMethod.Touch));\n sections.push(ToolAssistance.createSection(touchPickInstructions, ToolAssistance.inputsLabel));\n break;\n case SelectionMethod.Line:\n const mouseLineInstructions: ToolAssistanceInstruction[] = [];\n mouseLineInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.AcceptPoint\"), false, ToolAssistanceInputMethod.Mouse));\n if (SelectionMode.Replace === mode)\n mouseLineInstructions.push(ToolAssistance.createModifierKeyInstruction(ToolAssistance.ctrlKey, ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.InvertSelection\"), false, ToolAssistanceInputMethod.Mouse));\n sections.push(ToolAssistance.createSection(mouseLineInstructions, ToolAssistance.inputsLabel));\n\n const touchLineInstructions: ToolAssistanceInstruction[] = [];\n touchLineInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.OneTouchDrag, CoreTools.translate(\"ElementSet.Inputs.AcceptPoint\"), false, ToolAssistanceInputMethod.Touch));\n sections.push(ToolAssistance.createSection(touchLineInstructions, ToolAssistance.inputsLabel));\n break;\n case SelectionMethod.Box:\n const mouseBoxInstructions: ToolAssistanceInstruction[] = [];\n mouseBoxInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.AcceptPoint\"), false, ToolAssistanceInputMethod.Mouse));\n mouseBoxInstructions.push(ToolAssistance.createModifierKeyInstruction(ToolAssistance.shiftKey, ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.OverlapSelection\"), false, ToolAssistanceInputMethod.Mouse));\n if (SelectionMode.Replace === mode)\n mouseBoxInstructions.push(ToolAssistance.createModifierKeyInstruction(ToolAssistance.ctrlKey, ToolAssistanceImage.LeftClick, CoreTools.translate(\"ElementSet.Inputs.InvertSelection\"), false, ToolAssistanceInputMethod.Mouse));\n sections.push(ToolAssistance.createSection(mouseBoxInstructions, ToolAssistance.inputsLabel));\n\n const touchBoxInstructions: ToolAssistanceInstruction[] = [];\n touchBoxInstructions.push(ToolAssistance.createInstruction(ToolAssistanceImage.OneTouchDrag, CoreTools.translate(\"ElementSet.Inputs.AcceptPoint\"), false, ToolAssistanceInputMethod.Touch));\n sections.push(ToolAssistance.createSection(touchBoxInstructions, ToolAssistance.inputsLabel));\n break;\n }\n\n const instructions = ToolAssistance.createInstructions(mainInstruction, sections);\n IModelApp.notifications.setToolAssistance(instructions);\n }\n\n protected initSelectTool(): void {\n const method = this.selectionMethod;\n const mode = this.selectionMode;\n const enableLocate = SelectionMethod.Pick === method;\n\n this._isSelectByPoints = false;\n this._points.length = 0;\n\n this.initLocateElements(enableLocate, false, enableLocate ? \"default\" : IModelApp.viewManager.crossHairCursor, CoordinateLockOverrides.All);\n IModelApp.locateManager.options.allowDecorations = true; // Always locate to display tool tip even if we reject for adding to selection set...\n this.showPrompt(mode, method);\n }\n\n protected processMiss(_ev: BeButtonEvent): boolean {\n if (!this.iModel.selectionSet.isActive)\n return false;\n this.iModel.selectionSet.emptyAll();\n return true;\n }\n\n public updateSelection(elementId: Id64Arg, process: SelectionProcessing): boolean {\n let returnValue = false;\n switch (process) {\n case SelectionProcessing.AddElementToSelection:\n returnValue = this.iModel.selectionSet.add(elementId);\n break;\n case SelectionProcessing.RemoveElementFromSelection:\n returnValue = this.iModel.selectionSet.remove(elementId);\n break;\n case SelectionProcessing.InvertElementInSelection: // (if element is in selection remove it else add it.)\n returnValue = this.iModel.selectionSet.invert(elementId);\n break;\n case SelectionProcessing.ReplaceSelectionWithElement:\n this.iModel.selectionSet.replace(elementId);\n returnValue = true;\n break;\n default:\n return false;\n }\n // always force UI to sync display of options since the select option of Remove should only be enabled if the selection set has elements.\n if (returnValue)\n this.syncSelectionMode();\n return returnValue;\n }\n\n public async processSelection(elementId: Id64Arg, process: SelectionProcessing): Promise<boolean> { return this.updateSelection(elementId, process); }\n\n protected useOverlapSelection(ev: BeButtonEvent): boolean {\n if (undefined === ev.viewport)\n return false;\n const pt1 = ev.viewport.worldToView(this._points[0]);\n const pt2 = ev.viewport.worldToView(ev.point);\n const overlapMode = (pt1.x > pt2.x);\n return (ev.isShiftKey ? !overlapMode : overlapMode); // Shift inverts inside/overlap selection...\n }\n\n private selectByPointsDecorate(context: DecorateContext): void {\n if (!this._isSelectByPoints)\n return;\n\n const ev = new BeButtonEvent();\n IModelApp.toolAdmin.fillEventFromCursorLocation(ev);\n if (undefined === ev.viewport)\n return;\n\n const vp = context.viewport;\n const bestContrastIsBlack = (ColorDef.black === vp.getContrastToBackgroundColor());\n const crossingLine = (SelectionMethod.Line === this.selectionMethod || (SelectionMethod.Pick === this.selectionMethod && BeButton.Reset === ev.button));\n const overlapSelection = (crossingLine || this.useOverlapSelection(ev));\n\n const position = vp.worldToView(this._points[0]);\n position.x = Math.floor(position.x) + 0.5;\n position.y = Math.floor(position.y) + 0.5;\n const position2 = vp.worldToView(ev.point);\n position2.x = Math.floor(position2.x) + 0.5;\n position2.y = Math.floor(position2.y) + 0.5;\n const offset = position2.minus(position);\n\n const drawDecoration = (ctx: CanvasRenderingContext2D) => {\n ctx.strokeStyle = bestContrastIsBlack ? \"black\" : \"white\";\n ctx.lineWidth = 1;\n if (overlapSelection)\n ctx.setLineDash([5, 5]);\n\n if (crossingLine) {\n ctx.beginPath();\n ctx.moveTo(0, 0);\n ctx.lineTo(offset.x, offset.y);\n ctx.stroke();\n } else {\n ctx.strokeRect(0, 0, offset.x, offset.y);\n ctx.fillStyle = bestContrastIsBlack ? \"rgba(0,0,0,.06)\" : \"rgba(255,255,255,.06)\";\n ctx.fillRect(0, 0, offset.x, offset.y);\n }\n };\n context.addCanvasDecoration({ position, drawDecoration });\n }\n\n protected selectByPointsProcess(origin: Point3d, corner: Point3d, ev: BeButtonEvent, method: SelectionMethod, overlap: boolean) {\n const vp = ev.viewport;\n if (!vp)\n return;\n\n const pts: Point2d[] = [];\n pts[0] = new Point2d(Math.floor(origin.x + 0.5), Math.floor(origin.y + 0.5));\n pts[1] = new Point2d(Math.floor(corner.x + 0.5), Math.floor(corner.y + 0.5));\n const range = Range2d.createArray(pts);\n\n const rect = new ViewRect();\n rect.initFromRange(range);\n const allowTransients = this.wantPickableDecorations();\n\n vp.readPixels(rect, Pixel.Selector.Feature, (pixels) => {\n if (undefined === pixels)\n return;\n\n const sRange = Range2d.createNull();\n sRange.extendPoint(Point2d.create(vp.cssPixelsToDevicePixels(range.low.x), vp.cssPixelsToDevicePixels(range.low.y)));\n sRange.extendPoint(Point2d.create(vp.cssPixelsToDevicePixels(range.high.x), vp.cssPixelsToDevicePixels(range.high.y)));\n\n pts[0].x = vp.cssPixelsToDevicePixels(pts[0].x);\n pts[0].y = vp.cssPixelsToDevicePixels(pts[0].y);\n\n pts[1].x = vp.cssPixelsToDevicePixels(pts[1].x);\n pts[1].y = vp.cssPixelsToDevicePixels(pts[1].y);\n\n let contents = new Set<string>();\n const testPoint = Point2d.createZero();\n\n const getPixelElementId = (pixel: Pixel.Data) => {\n if (undefined === pixel.elementId || Id64.isInvalid(pixel.elementId))\n return undefined; // no geometry at this location...\n\n if (!allowTransients && Id64.isTransient(pixel.elementId))\n return undefined; // tool didn't request pickable decorations...\n\n if (!vp.isPixelSelectable(pixel))\n return undefined; // reality model, terrain, etc - not selectable\n\n return pixel.elementId;\n };\n\n if (SelectionMethod.Box === method) {\n const outline = overlap ? undefined : new Set<string>();\n const offset = sRange.clone();\n offset.expandInPlace(-2);\n for (testPoint.x = sRange.low.x; testPoint.x <= sRange.high.x; ++testPoint.x) {\n for (testPoint.y = sRange.low.y; testPoint.y <= sRange.high.y; ++testPoint.y) {\n const pixel = pixels.getPixel(testPoint.x, testPoint.y);\n const elementId = getPixelElementId(pixel);\n if (undefined === elementId)\n continue;\n\n if (undefined !== outline && !offset.containsPoint(testPoint))\n outline.add(elementId.toString());\n else\n contents.add(elementId.toString());\n }\n }\n if (undefined !== outline && 0 !== outline.size) {\n const inside = new Set<string>();\n contents.forEach((id) => {\n if (!outline.has(id))\n inside.add(id);\n });\n\n contents = inside;\n }\n } else {\n const closePoint = Point2d.createZero();\n for (testPoint.x = sRange.low.x; testPoint.x <= sRange.high.x; ++testPoint.x) {\n for (testPoint.y = sRange.low.y; testPoint.y <= sRange.high.y; ++testPoint.y) {\n const pixel = pixels.getPixel(testPoint.x, testPoint.y);\n const elementId = getPixelElementId(pixel);\n if (undefined === elementId)\n continue;\n\n const fraction = testPoint.fractionOfProjectionToLine(pts[0], pts[1], 0.0);\n pts[0].interpolate(fraction, pts[1], closePoint);\n if (closePoint.distance(testPoint) < 1.5)\n contents.add(elementId.toString());\n }\n }\n }\n\n if (0 === contents.size) {\n if (!ev.isControlKey && this.wantSelectionClearOnMiss(ev) && this.processMiss(ev))\n this.syncSelectionMode();\n return;\n }\n\n switch (this.selectionMode) {\n case SelectionMode.Replace:\n if (!ev.isControlKey)\n this.processSelection(contents, SelectionProcessing.ReplaceSelectionWithElement); // eslint-disable-line @typescript-eslint/no-floating-promises\n else\n this.processSelection(contents, SelectionProcessing.InvertElementInSelection); // eslint-disable-line @typescript-eslint/no-floating-promises\n break;\n case SelectionMode.Add:\n this.processSelection(contents, SelectionProcessing.AddElementToSelection); // eslint-disable-line @typescript-eslint/no-floating-promises\n break;\n case SelectionMode.Remove:\n this.processSelection(contents, SelectionProcessing.RemoveElementFromSelection); // eslint-disable-line @typescript-eslint/no-floating-promises\n break;\n }\n }, true);\n }\n\n protected selectByPointsStart(ev: BeButtonEvent): boolean {\n if (BeButton.Data !== ev.button && BeButton.Reset !== ev.button)\n return false;\n this._points.length = 0;\n this._points.push(ev.point.clone());\n this._isSelectByPoints = true;\n IModelApp.accuSnap.enableLocate(false);\n IModelApp.toolAdmin.setLocateCircleOn(false);\n this.showPrompt(this.selectionMode, this.selectionMethod);\n return true;\n }\n\n protected selectByPointsEnd(ev: BeButtonEvent): boolean {\n if (!this._isSelectByPoints)\n return false;\n\n const vp = ev.viewport;\n if (vp === undefined) {\n this.initSelectTool();\n return false;\n }\n\n const origin = vp.worldToView(this._points[0]);\n const corner = vp.worldToView(ev.point);\n if (SelectionMethod.Line === this.selectionMethod || (SelectionMethod.Pick === this.selectionMethod && BeButton.Reset === ev.button))\n this.selectByPointsProcess(origin, corner, ev, SelectionMethod.Line, true);\n else\n this.selectByPointsProcess(origin, corner, ev, SelectionMethod.Box, this.useOverlapSelection(ev));\n\n this.initSelectTool();\n vp.invalidateDecorations();\n return true;\n }\n\n public override async onMouseMotion(ev: BeButtonEvent): Promise<void> {\n if (undefined !== ev.viewport && this._isSelectByPoints)\n ev.viewport.invalidateDecorations();\n }\n\n public async selectDecoration(ev: BeButtonEvent, currHit?: HitDetail): Promise<EventHandled> {\n if (undefined === currHit)\n currHit = await IModelApp.locateManager.doLocate(new LocateResponse(), true, ev.point, ev.viewport, ev.inputSource);\n\n if (undefined !== currHit)\n return (currHit.isElementHit ? IModelApp.viewManager.overrideElementButtonEvent(currHit, ev) : IModelApp.viewManager.onDecorationButtonEvent(currHit, ev));\n\n return EventHandled.No;\n }\n\n public async processHit(ev: BeButtonEvent, hit: HitDetail): Promise<EventHandled> {\n if (hit.isModelHit || hit.isMapHit)\n return EventHandled.No; // model hit = terrain, reality models, background maps, etc - not selectable\n\n switch (this.selectionMode) {\n case SelectionMode.Replace:\n await this.processSelection(hit.sourceId, ev.isControlKey ? SelectionProcessing.InvertElementInSelection : SelectionProcessing.ReplaceSelectionWithElement);\n break;\n\n case SelectionMode.Add:\n await this.processSelection(hit.sourceId, SelectionProcessing.AddElementToSelection);\n break;\n\n case SelectionMode.Remove:\n await this.processSelection(hit.sourceId, SelectionProcessing.RemoveElementFromSelection);\n break;\n }\n return EventHandled.Yes;\n }\n\n public override async onMouseStartDrag(ev: BeButtonEvent): Promise<EventHandled> {\n IModelApp.accuSnap.clear(); // Need to test hit at start drag location, not current AccuSnap...\n if (EventHandled.Yes === await this.selectDecoration(ev))\n return EventHandled.Yes;\n if (InputSource.Touch === ev.inputSource && SelectionMethod.Pick === this.selectionMethod)\n return EventHandled.No; // Require method change for line/box selection...allow IdleTool to handle touch move...\n return this.selectByPointsStart(ev) ? EventHandled.Yes : EventHandled.No;\n }\n\n public override async onMouseEndDrag(ev: BeButtonEvent): Promise<EventHandled> {\n return this.selectByPointsEnd(ev) ? EventHandled.Yes : EventHandled.No;\n }\n\n public override async onDataButtonUp(ev: BeButtonEvent): Promise<EventHandled> {\n if (undefined === ev.viewport)\n return EventHandled.No;\n\n if (this.selectByPointsEnd(ev))\n return EventHandled.Yes;\n\n if (SelectionMethod.Pick !== this.selectionMethod) {\n if (!ev.isControlKey && this.wantSelectionClearOnMiss(ev) && this.processMiss(ev))\n this.syncSelectionMode();\n if (InputSource.Touch !== ev.inputSource)\n this.selectByPointsStart(ev); // Require touch move and not tap to start crossing line/box selection...\n return EventHandled.Yes;\n }\n\n const hit = await IModelApp.locateManager.doLocate(new LocateResponse(), true, ev.point, ev.viewport, ev.inputSource);\n if (hit !== undefined) {\n if (EventHandled.Yes === await this.selectDecoration(ev, hit))\n return EventHandled.Yes;\n\n if (EventHandled.Yes === await this.processHit(ev, hit))\n return EventHandled.Yes;\n }\n\n if (!ev.isControlKey && this.wantSelectionClearOnMiss(ev) && this.processMiss(ev))\n this.syncSelectionMode();\n\n return EventHandled.Yes;\n }\n\n public override async onResetButtonUp(ev: BeButtonEvent): Promise<EventHandled> {\n if (this._isSelectByPoints) {\n if (undefined !== ev.viewport)\n ev.viewport.invalidateDecorations();\n this.initSelectTool();\n return EventHandled.Yes;\n }\n\n // Check for overlapping hits...\n const lastHit = SelectionMode.Remove === this.selectionMode ? undefined : IModelApp.locateManager.currHit;\n if (lastHit && this.iModel.selectionSet.has(lastHit.sourceId)) {\n const autoHit = IModelApp.accuSnap.currHit;\n\n // Play nice w/auto-locate, only remove previous hit if not currently auto-locating or over previous hit\n if (undefined === autoHit || autoHit.isSameHit(lastHit)) {\n const response = new LocateResponse();\n let nextHit;\n do {\n nextHit = await IModelApp.locateManager.doLocate(response, false, ev.point, ev.viewport, ev.inputSource);\n } while (undefined !== nextHit && (nextHit.isModelHit || nextHit.isMapHit)); // Ignore reality models, terrain, maps, etc.\n\n // remove element(s) previously selected if in replace mode, or if we have a next element in add mode\n if (SelectionMode.Replace === this.selectionMode || undefined !== nextHit)\n await this.processSelection(lastHit.sourceId, SelectionProcessing.RemoveElementFromSelection);\n\n // add element(s) located via reset button\n if (undefined !== nextHit)\n await this.processSelection(nextHit.sourceId, SelectionProcessing.AddElementToSelection);\n\n return EventHandled.Yes;\n }\n }\n\n if (EventHandled.Yes === await this.selectDecoration(ev, IModelApp.accuSnap.currHit))\n return EventHandled.Yes;\n\n await IModelApp.accuSnap.resetButton();\n return EventHandled.Yes;\n }\n\n public override async onSuspend() {\n this._isSuspended = true;\n if (this.wantEditManipulators())\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, ManipulatorToolEvent.Suspend);\n }\n\n public override async onUnsuspend() {\n this._isSuspended = false;\n if (this.wantEditManipulators())\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, ManipulatorToolEvent.Unsuspend);\n\n this.showPrompt(this.selectionMode, this.selectionMethod);\n }\n\n public override async onTouchMoveStart(ev: BeTouchEvent, startEv: BeTouchEvent): Promise<EventHandled> {\n if (startEv.isSingleTouch && !this._isSelectByPoints)\n await IModelApp.toolAdmin.convertTouchMoveStartToButtonDownAndMotion(startEv, ev);\n return (this._isSuspended || this._isSelectByPoints) ? EventHandled.Yes : EventHandled.No;\n }\n\n public override async onTouchMove(ev: BeTouchEvent): Promise<void> {\n if (this._isSelectByPoints)\n return IModelApp.toolAdmin.convertTouchMoveToMotion(ev);\n }\n\n public override async onTouchComplete(ev: BeTouchEvent): Promise<void> {\n if (this._isSelectByPoints)\n return IModelApp.toolAdmin.convertTouchEndToButtonUp(ev);\n }\n\n public override async onTouchCancel(ev: BeTouchEvent): Promise<void> {\n if (this._isSelectByPoints)\n return IModelApp.toolAdmin.convertTouchEndToButtonUp(ev, BeButton.Reset);\n }\n\n public override decorate(context: DecorateContext): void { this.selectByPointsDecorate(context); }\n\n public override async onModifierKeyTransition(_wentDown: boolean, modifier: BeModifierKeys, _event: KeyboardEvent): Promise<EventHandled> {\n return (modifier === BeModifierKeys.Shift && this._isSelectByPoints) ? EventHandled.Yes : EventHandled.No;\n }\n\n public override async filterHit(hit: HitDetail, out?: LocateResponse): Promise<LocateFilterStatus> {\n if (!this.wantPickableDecorations() && !hit.isElementHit)\n return LocateFilterStatus.Reject;\n\n const mode = this.selectionMode;\n if (SelectionMode.Replace === mode)\n return LocateFilterStatus.Accept;\n\n const isSelected = this.iModel.selectionSet.has(hit.sourceId);\n const status = ((SelectionMode.Add === mode ? !isSelected : isSelected) ? LocateFilterStatus.Accept : LocateFilterStatus.Reject);\n if (out && LocateFilterStatus.Reject === status)\n out.explanation = CoreTools.translate(`ElementSet.Error.${isSelected ? \"AlreadySelected\" : \"NotSelected\"}`);\n return status;\n }\n\n public async onRestartTool(): Promise<void> { return this.exitTool(); }\n\n public override async onCleanup() {\n if (this.wantEditManipulators())\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, ManipulatorToolEvent.Stop);\n }\n\n public override async onPostInstall() {\n await super.onPostInstall();\n if (!this.targetView)\n return;\n if (this.wantEditManipulators())\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, ManipulatorToolEvent.Start);\n this.initSelectTool();\n }\n\n public static async startTool(): Promise<boolean> { return new SelectionTool().run(); }\n\n private syncSelectionMode(): void {\n if (SelectionMode.Remove === this.selectionMode && !this.iModel.selectionSet.isActive) {\n // No selection active resetting selection mode since there is nothing to Remove\n this.selectionMode = SelectionMode.Replace;\n this.initSelectTool();\n }\n if (this.wantToolSettings()) {\n const syncMode: DialogPropertySyncItem = { value: this._selectionModeValue, propertyName: SelectionTool._modesName };\n IModelApp.toolAdmin.toolSettingsState.saveToolSettingProperty(this.toolId, syncMode);\n this.syncToolSettingsProperties([syncMode]);\n }\n }\n\n /** Used to supply DefaultToolSettingProvider with a list of properties to use to generate ToolSettings. If undefined then no ToolSettings will be displayed\n * @beta\n */\n public override supplyToolSettingsProperties(): DialogItem[] | undefined {\n if (!this.wantToolSettings())\n return undefined;\n\n // load latest values from session\n IModelApp.toolAdmin.toolSettingsState.getInitialToolSettingValues(this.toolId, [SelectionTool._modesName])?.forEach((value) => {\n if (value.propertyName === SelectionTool._modesName)\n this._selectionModeValue = value.value;\n });\n\n // Make sure a mode of SelectionMode.Remove is valid\n if (SelectionMode.Remove === this.selectionMode && !this.iModel.selectionSet.isActive) {\n this.selectionMode = SelectionMode.Replace;\n IModelApp.toolAdmin.toolSettingsState.saveToolSettingProperty(this.toolId, { propertyName: SelectionTool._modesName, value: this._selectionModeValue });\n }\n\n const toolSettings = new Array<DialogItem>();\n // generate 3 columns - label will be placed in column 0 and button group editors in columns 1 and 2.\n toolSettings.push({ value: this._selectionMethodValue, property: SelectionTool._getMethodsDescription(), editorPosition: { rowPriority: 0, columnIndex: 1 } });\n toolSettings.push({ value: this._selectionModeValue, property: SelectionTool._getModesDescription(), editorPosition: { rowPriority: 0, columnIndex: 2 } });\n return toolSettings;\n }\n\n /** Used to send changes from UI back to Tool\n * @beta\n */\n public override async applyToolSettingPropertyChange(updatedValue: DialogPropertySyncItem): Promise<boolean> {\n let changed = false;\n if (updatedValue.propertyName === SelectionTool._methodsName) {\n const saveWantManipulators = this.wantEditManipulators();\n this._selectionMethodValue = updatedValue.value;\n if (this._selectionMethodValue) {\n const currWantManipulators = this.wantEditManipulators();\n if (saveWantManipulators !== currWantManipulators)\n IModelApp.toolAdmin.manipulatorToolEvent.raiseEvent(this, currWantManipulators ? ManipulatorToolEvent.Start : ManipulatorToolEvent.Stop);\n changed = true;\n }\n }\n if (updatedValue.propertyName === SelectionTool._modesName) {\n this._selectionModeValue = updatedValue.value;\n if (this._selectionModeValue) {\n if (this.wantToolSettings())\n IModelApp.toolAdmin.toolSettingsState.saveToolSettingProperty(this.toolId, { propertyName: SelectionTool._modesName, value: this._selectionModeValue });\n changed = true;\n }\n }\n if (changed)\n this.initSelectTool();\n return true; // return true if change is valid\n }\n}\n"]}
@@ -100,6 +100,9 @@ export declare abstract class DisplayStyleState extends ElementState implements
100
100
  * @see [DisplayStyleSettings.contextRealityModels]($common).
101
101
  */
102
102
  forEachRealityModel(func: (model: ContextRealityModelState) => void): void;
103
+ private getRealityModels;
104
+ /** Iterate over the reality models attached to this display style. */
105
+ get realityModels(): Iterable<ContextRealityModelState>;
103
106
  /** @internal */
104
107
  forEachRealityTileTreeRef(func: (ref: TileTreeReference) => void): void;
105
108
  /** @internal */