@itwin/ecschema-metadata 5.1.0-dev.9 → 5.2.0-dev.2

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 (210) hide show
  1. package/CHANGELOG.md +74 -1
  2. package/lib/cjs/Context.d.ts +1 -1
  3. package/lib/cjs/Context.js +1 -1
  4. package/lib/cjs/Context.js.map +1 -1
  5. package/lib/cjs/Deserialization/Helper.d.ts +30 -11
  6. package/lib/cjs/Deserialization/Helper.d.ts.map +1 -1
  7. package/lib/cjs/Deserialization/Helper.js +124 -96
  8. package/lib/cjs/Deserialization/Helper.js.map +1 -1
  9. package/lib/cjs/Deserialization/SchemaGraphUtil.d.ts +12 -3
  10. package/lib/cjs/Deserialization/SchemaGraphUtil.d.ts.map +1 -1
  11. package/lib/cjs/Deserialization/SchemaGraphUtil.js +36 -23
  12. package/lib/cjs/Deserialization/SchemaGraphUtil.js.map +1 -1
  13. package/lib/cjs/Deserialization/XmlParser.d.ts.map +1 -1
  14. package/lib/cjs/Deserialization/XmlParser.js +14 -5
  15. package/lib/cjs/Deserialization/XmlParser.js.map +1 -1
  16. package/lib/cjs/Deserialization/XmlSerializationUtils.js +1 -1
  17. package/lib/cjs/Deserialization/XmlSerializationUtils.js.map +1 -1
  18. package/lib/cjs/ECName.js +1 -1
  19. package/lib/cjs/ECName.js.map +1 -1
  20. package/lib/cjs/ECObjects.d.ts +1 -1
  21. package/lib/cjs/ECObjects.js +2 -2
  22. package/lib/cjs/ECObjects.js.map +1 -1
  23. package/lib/cjs/IncrementalLoading/ClassParsers.d.ts +60 -0
  24. package/lib/cjs/IncrementalLoading/ClassParsers.d.ts.map +1 -0
  25. package/lib/cjs/IncrementalLoading/ClassParsers.js +111 -0
  26. package/lib/cjs/IncrementalLoading/ClassParsers.js.map +1 -0
  27. package/lib/cjs/IncrementalLoading/ECSqlSchemaLocater.d.ts +211 -0
  28. package/lib/cjs/IncrementalLoading/ECSqlSchemaLocater.d.ts.map +1 -0
  29. package/lib/cjs/IncrementalLoading/ECSqlSchemaLocater.js +387 -0
  30. package/lib/cjs/IncrementalLoading/ECSqlSchemaLocater.js.map +1 -0
  31. package/lib/cjs/IncrementalLoading/FullSchemaQueries.d.ts +14 -0
  32. package/lib/cjs/IncrementalLoading/FullSchemaQueries.d.ts.map +1 -0
  33. package/lib/cjs/IncrementalLoading/FullSchemaQueries.js +609 -0
  34. package/lib/cjs/IncrementalLoading/FullSchemaQueries.js.map +1 -0
  35. package/lib/cjs/IncrementalLoading/IncrementalSchemaLocater.d.ts +109 -0
  36. package/lib/cjs/IncrementalLoading/IncrementalSchemaLocater.d.ts.map +1 -0
  37. package/lib/cjs/IncrementalLoading/IncrementalSchemaLocater.js +219 -0
  38. package/lib/cjs/IncrementalLoading/IncrementalSchemaLocater.js.map +1 -0
  39. package/lib/cjs/IncrementalLoading/IncrementalSchemaReader.d.ts +36 -0
  40. package/lib/cjs/IncrementalLoading/IncrementalSchemaReader.d.ts.map +1 -0
  41. package/lib/cjs/IncrementalLoading/IncrementalSchemaReader.js +77 -0
  42. package/lib/cjs/IncrementalLoading/IncrementalSchemaReader.js.map +1 -0
  43. package/lib/cjs/IncrementalLoading/PerformanceLogger.d.ts +60 -0
  44. package/lib/cjs/IncrementalLoading/PerformanceLogger.d.ts.map +1 -0
  45. package/lib/cjs/IncrementalLoading/PerformanceLogger.js +82 -0
  46. package/lib/cjs/IncrementalLoading/PerformanceLogger.js.map +1 -0
  47. package/lib/cjs/IncrementalLoading/SchemaItemParsers.d.ts +51 -0
  48. package/lib/cjs/IncrementalLoading/SchemaItemParsers.d.ts.map +1 -0
  49. package/lib/cjs/IncrementalLoading/SchemaItemParsers.js +122 -0
  50. package/lib/cjs/IncrementalLoading/SchemaItemParsers.js.map +1 -0
  51. package/lib/cjs/IncrementalLoading/SchemaItemQueries.d.ts +16 -0
  52. package/lib/cjs/IncrementalLoading/SchemaItemQueries.d.ts.map +1 -0
  53. package/lib/cjs/IncrementalLoading/SchemaItemQueries.js +308 -0
  54. package/lib/cjs/IncrementalLoading/SchemaItemQueries.js.map +1 -0
  55. package/lib/cjs/IncrementalLoading/SchemaParser.d.ts +42 -0
  56. package/lib/cjs/IncrementalLoading/SchemaParser.d.ts.map +1 -0
  57. package/lib/cjs/IncrementalLoading/SchemaParser.js +109 -0
  58. package/lib/cjs/IncrementalLoading/SchemaParser.js.map +1 -0
  59. package/lib/cjs/IncrementalLoading/SchemaStubQueries.d.ts +12 -0
  60. package/lib/cjs/IncrementalLoading/SchemaStubQueries.d.ts.map +1 -0
  61. package/lib/cjs/IncrementalLoading/SchemaStubQueries.js +365 -0
  62. package/lib/cjs/IncrementalLoading/SchemaStubQueries.js.map +1 -0
  63. package/lib/cjs/Metadata/Class.d.ts +5 -16
  64. package/lib/cjs/Metadata/Class.d.ts.map +1 -1
  65. package/lib/cjs/Metadata/Class.js +68 -68
  66. package/lib/cjs/Metadata/Class.js.map +1 -1
  67. package/lib/cjs/Metadata/CustomAttribute.d.ts +7 -1
  68. package/lib/cjs/Metadata/CustomAttribute.d.ts.map +1 -1
  69. package/lib/cjs/Metadata/CustomAttribute.js.map +1 -1
  70. package/lib/cjs/Metadata/CustomAttributeClass.d.ts +1 -1
  71. package/lib/cjs/Metadata/CustomAttributeClass.js +1 -1
  72. package/lib/cjs/Metadata/CustomAttributeClass.js.map +1 -1
  73. package/lib/cjs/Metadata/EntityClass.d.ts +6 -6
  74. package/lib/cjs/Metadata/EntityClass.d.ts.map +1 -1
  75. package/lib/cjs/Metadata/EntityClass.js +48 -26
  76. package/lib/cjs/Metadata/EntityClass.js.map +1 -1
  77. package/lib/cjs/Metadata/Format.d.ts +5 -0
  78. package/lib/cjs/Metadata/Format.d.ts.map +1 -1
  79. package/lib/cjs/Metadata/Format.js +7 -0
  80. package/lib/cjs/Metadata/Format.js.map +1 -1
  81. package/lib/cjs/Metadata/KindOfQuantity.js.map +1 -1
  82. package/lib/cjs/Metadata/Schema.d.ts +10 -0
  83. package/lib/cjs/Metadata/Schema.d.ts.map +1 -1
  84. package/lib/cjs/Metadata/Schema.js +13 -0
  85. package/lib/cjs/Metadata/Schema.js.map +1 -1
  86. package/lib/cjs/Metadata/SchemaItem.d.ts +10 -0
  87. package/lib/cjs/Metadata/SchemaItem.d.ts.map +1 -1
  88. package/lib/cjs/Metadata/SchemaItem.js +13 -0
  89. package/lib/cjs/Metadata/SchemaItem.js.map +1 -1
  90. package/lib/cjs/SchemaFormatsProvider.d.ts +4 -3
  91. package/lib/cjs/SchemaFormatsProvider.d.ts.map +1 -1
  92. package/lib/cjs/SchemaFormatsProvider.js +60 -17
  93. package/lib/cjs/SchemaFormatsProvider.js.map +1 -1
  94. package/lib/cjs/SchemaLoader.d.ts +4 -1
  95. package/lib/cjs/SchemaLoader.d.ts.map +1 -1
  96. package/lib/cjs/SchemaLoader.js +4 -1
  97. package/lib/cjs/SchemaLoader.js.map +1 -1
  98. package/lib/cjs/ecschema-metadata.d.ts +2 -0
  99. package/lib/cjs/ecschema-metadata.d.ts.map +1 -1
  100. package/lib/cjs/ecschema-metadata.js +2 -0
  101. package/lib/cjs/ecschema-metadata.js.map +1 -1
  102. package/lib/cjs/utils/SchemaLoadingController.d.ts +37 -0
  103. package/lib/cjs/utils/SchemaLoadingController.d.ts.map +1 -0
  104. package/lib/cjs/utils/SchemaLoadingController.js +65 -0
  105. package/lib/cjs/utils/SchemaLoadingController.js.map +1 -0
  106. package/lib/esm/Context.d.ts +1 -1
  107. package/lib/esm/Context.js +1 -1
  108. package/lib/esm/Context.js.map +1 -1
  109. package/lib/esm/Deserialization/Helper.d.ts +30 -11
  110. package/lib/esm/Deserialization/Helper.d.ts.map +1 -1
  111. package/lib/esm/Deserialization/Helper.js +124 -96
  112. package/lib/esm/Deserialization/Helper.js.map +1 -1
  113. package/lib/esm/Deserialization/SchemaGraphUtil.d.ts +12 -3
  114. package/lib/esm/Deserialization/SchemaGraphUtil.d.ts.map +1 -1
  115. package/lib/esm/Deserialization/SchemaGraphUtil.js +36 -23
  116. package/lib/esm/Deserialization/SchemaGraphUtil.js.map +1 -1
  117. package/lib/esm/Deserialization/XmlParser.d.ts.map +1 -1
  118. package/lib/esm/Deserialization/XmlParser.js +14 -5
  119. package/lib/esm/Deserialization/XmlParser.js.map +1 -1
  120. package/lib/esm/Deserialization/XmlSerializationUtils.js +1 -1
  121. package/lib/esm/Deserialization/XmlSerializationUtils.js.map +1 -1
  122. package/lib/esm/ECName.js +1 -1
  123. package/lib/esm/ECName.js.map +1 -1
  124. package/lib/esm/ECObjects.d.ts +1 -1
  125. package/lib/esm/ECObjects.js +2 -2
  126. package/lib/esm/ECObjects.js.map +1 -1
  127. package/lib/esm/IncrementalLoading/ClassParsers.d.ts +60 -0
  128. package/lib/esm/IncrementalLoading/ClassParsers.d.ts.map +1 -0
  129. package/lib/esm/IncrementalLoading/ClassParsers.js +104 -0
  130. package/lib/esm/IncrementalLoading/ClassParsers.js.map +1 -0
  131. package/lib/esm/IncrementalLoading/ECSqlSchemaLocater.d.ts +211 -0
  132. package/lib/esm/IncrementalLoading/ECSqlSchemaLocater.d.ts.map +1 -0
  133. package/lib/esm/IncrementalLoading/ECSqlSchemaLocater.js +383 -0
  134. package/lib/esm/IncrementalLoading/ECSqlSchemaLocater.js.map +1 -0
  135. package/lib/esm/IncrementalLoading/FullSchemaQueries.d.ts +14 -0
  136. package/lib/esm/IncrementalLoading/FullSchemaQueries.d.ts.map +1 -0
  137. package/lib/esm/IncrementalLoading/FullSchemaQueries.js +606 -0
  138. package/lib/esm/IncrementalLoading/FullSchemaQueries.js.map +1 -0
  139. package/lib/esm/IncrementalLoading/IncrementalSchemaLocater.d.ts +109 -0
  140. package/lib/esm/IncrementalLoading/IncrementalSchemaLocater.d.ts.map +1 -0
  141. package/lib/esm/IncrementalLoading/IncrementalSchemaLocater.js +215 -0
  142. package/lib/esm/IncrementalLoading/IncrementalSchemaLocater.js.map +1 -0
  143. package/lib/esm/IncrementalLoading/IncrementalSchemaReader.d.ts +36 -0
  144. package/lib/esm/IncrementalLoading/IncrementalSchemaReader.d.ts.map +1 -0
  145. package/lib/esm/IncrementalLoading/IncrementalSchemaReader.js +73 -0
  146. package/lib/esm/IncrementalLoading/IncrementalSchemaReader.js.map +1 -0
  147. package/lib/esm/IncrementalLoading/PerformanceLogger.d.ts +60 -0
  148. package/lib/esm/IncrementalLoading/PerformanceLogger.d.ts.map +1 -0
  149. package/lib/esm/IncrementalLoading/PerformanceLogger.js +78 -0
  150. package/lib/esm/IncrementalLoading/PerformanceLogger.js.map +1 -0
  151. package/lib/esm/IncrementalLoading/SchemaItemParsers.d.ts +51 -0
  152. package/lib/esm/IncrementalLoading/SchemaItemParsers.d.ts.map +1 -0
  153. package/lib/esm/IncrementalLoading/SchemaItemParsers.js +117 -0
  154. package/lib/esm/IncrementalLoading/SchemaItemParsers.js.map +1 -0
  155. package/lib/esm/IncrementalLoading/SchemaItemQueries.d.ts +16 -0
  156. package/lib/esm/IncrementalLoading/SchemaItemQueries.d.ts.map +1 -0
  157. package/lib/esm/IncrementalLoading/SchemaItemQueries.js +305 -0
  158. package/lib/esm/IncrementalLoading/SchemaItemQueries.js.map +1 -0
  159. package/lib/esm/IncrementalLoading/SchemaParser.d.ts +42 -0
  160. package/lib/esm/IncrementalLoading/SchemaParser.d.ts.map +1 -0
  161. package/lib/esm/IncrementalLoading/SchemaParser.js +104 -0
  162. package/lib/esm/IncrementalLoading/SchemaParser.js.map +1 -0
  163. package/lib/esm/IncrementalLoading/SchemaStubQueries.d.ts +12 -0
  164. package/lib/esm/IncrementalLoading/SchemaStubQueries.d.ts.map +1 -0
  165. package/lib/esm/IncrementalLoading/SchemaStubQueries.js +359 -0
  166. package/lib/esm/IncrementalLoading/SchemaStubQueries.js.map +1 -0
  167. package/lib/esm/Metadata/Class.d.ts +5 -16
  168. package/lib/esm/Metadata/Class.d.ts.map +1 -1
  169. package/lib/esm/Metadata/Class.js +68 -68
  170. package/lib/esm/Metadata/Class.js.map +1 -1
  171. package/lib/esm/Metadata/CustomAttribute.d.ts +7 -1
  172. package/lib/esm/Metadata/CustomAttribute.d.ts.map +1 -1
  173. package/lib/esm/Metadata/CustomAttribute.js.map +1 -1
  174. package/lib/esm/Metadata/CustomAttributeClass.d.ts +1 -1
  175. package/lib/esm/Metadata/CustomAttributeClass.js +1 -1
  176. package/lib/esm/Metadata/CustomAttributeClass.js.map +1 -1
  177. package/lib/esm/Metadata/EntityClass.d.ts +6 -6
  178. package/lib/esm/Metadata/EntityClass.d.ts.map +1 -1
  179. package/lib/esm/Metadata/EntityClass.js +48 -26
  180. package/lib/esm/Metadata/EntityClass.js.map +1 -1
  181. package/lib/esm/Metadata/Format.d.ts +5 -0
  182. package/lib/esm/Metadata/Format.d.ts.map +1 -1
  183. package/lib/esm/Metadata/Format.js +7 -0
  184. package/lib/esm/Metadata/Format.js.map +1 -1
  185. package/lib/esm/Metadata/KindOfQuantity.js.map +1 -1
  186. package/lib/esm/Metadata/Schema.d.ts +10 -0
  187. package/lib/esm/Metadata/Schema.d.ts.map +1 -1
  188. package/lib/esm/Metadata/Schema.js +13 -0
  189. package/lib/esm/Metadata/Schema.js.map +1 -1
  190. package/lib/esm/Metadata/SchemaItem.d.ts +10 -0
  191. package/lib/esm/Metadata/SchemaItem.d.ts.map +1 -1
  192. package/lib/esm/Metadata/SchemaItem.js +13 -0
  193. package/lib/esm/Metadata/SchemaItem.js.map +1 -1
  194. package/lib/esm/SchemaFormatsProvider.d.ts +4 -3
  195. package/lib/esm/SchemaFormatsProvider.d.ts.map +1 -1
  196. package/lib/esm/SchemaFormatsProvider.js +61 -18
  197. package/lib/esm/SchemaFormatsProvider.js.map +1 -1
  198. package/lib/esm/SchemaLoader.d.ts +4 -1
  199. package/lib/esm/SchemaLoader.d.ts.map +1 -1
  200. package/lib/esm/SchemaLoader.js +4 -1
  201. package/lib/esm/SchemaLoader.js.map +1 -1
  202. package/lib/esm/ecschema-metadata.d.ts +2 -0
  203. package/lib/esm/ecschema-metadata.d.ts.map +1 -1
  204. package/lib/esm/ecschema-metadata.js +2 -0
  205. package/lib/esm/ecschema-metadata.js.map +1 -1
  206. package/lib/esm/utils/SchemaLoadingController.d.ts +37 -0
  207. package/lib/esm/utils/SchemaLoadingController.d.ts.map +1 -0
  208. package/lib/esm/utils/SchemaLoadingController.js +61 -0
  209. package/lib/esm/utils/SchemaLoadingController.js.map +1 -0
  210. package/package.json +15 -10
@@ -0,0 +1,82 @@
1
+ "use strict";
2
+ /*---------------------------------------------------------------------------------------------
3
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
4
+ * See LICENSE.md in the project root for license terms and full copyright notice.
5
+ *--------------------------------------------------------------------------------------------*/
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.PerformanceLogger = void 0;
8
+ /**
9
+ * Utility class used to log query load times for Schema and
10
+ * SchemaItem queries.
11
+ * @internal
12
+ */
13
+ class PerformanceLogger {
14
+ _iModelItems = new Map();
15
+ _label;
16
+ // flag that controls if logging is enabled.
17
+ disableLogging = false;
18
+ /**
19
+ * Initializes a new PerformanceLogger instance.
20
+ * @param label Arbitrary label used to tag this logging session (ex. IModel name)
21
+ */
22
+ constructor(label) {
23
+ this._label = label || "";
24
+ }
25
+ /**
26
+ * Gets the Map of logged Schema entries. The Map key is the iModel name. The Map
27
+ * value is a second Map whose key is a Schema name and value is a SchemaLoadData
28
+ * object.
29
+ */
30
+ get logItems() {
31
+ return this._iModelItems;
32
+ }
33
+ /**
34
+ * Adds a new log entry to the Schema Map.
35
+ * @param startTime The start time of the entry to be logged (end time/duration is handled in this method).
36
+ * @param schemaName The Schema being queried.
37
+ */
38
+ logSchema(startTime, schemaName) {
39
+ if (this.disableLogging)
40
+ return;
41
+ const loadTime = new Date().getTime() - startTime;
42
+ const schemaMap = this.getSchemaMap(this._label);
43
+ const schemaLoadData = this.getSchemaLoadData(schemaMap, schemaName);
44
+ schemaLoadData.loadTime = loadTime;
45
+ }
46
+ /**
47
+ * Adds a new log entry to the SchemaItem Map.
48
+ * @param startTime The start time of the entry to be logged (end time/duration is handled in this method).
49
+ * @param schemaName The name of the Schema being queried.
50
+ * @param schemaItemType The SchemaItemType name of the type being queried.
51
+ * @param itemCount The number of items retrieved in the query.
52
+ */
53
+ logSchemaItem(startTime, schemaName, schemaItemType, itemCount) {
54
+ if (this.disableLogging)
55
+ return;
56
+ const loadTime = new Date().getTime() - startTime;
57
+ const schemaMap = this.getSchemaMap(this._label);
58
+ const schemaLoadData = this.getSchemaLoadData(schemaMap, schemaName);
59
+ if (schemaLoadData.schemaItemMap.has(schemaItemType))
60
+ throw new Error("There should not be a multiple load times for a given iModel, Schema, SchemaItemType combination.");
61
+ schemaLoadData.schemaItemMap.set(schemaItemType, { loadTime, itemCount });
62
+ }
63
+ /**
64
+ * Clears all log entries from the Map.
65
+ */
66
+ clearLogs() {
67
+ this._iModelItems.clear();
68
+ }
69
+ getSchemaMap(iModel) {
70
+ if (!this._iModelItems.has(iModel)) {
71
+ this._iModelItems.set(iModel, new Map());
72
+ }
73
+ return this._iModelItems.get(iModel);
74
+ }
75
+ getSchemaLoadData(schemaMap, schemaName) {
76
+ if (!schemaMap.has(schemaName))
77
+ schemaMap.set(schemaName, { schemaItemMap: new Map() });
78
+ return schemaMap.get(schemaName);
79
+ }
80
+ }
81
+ exports.PerformanceLogger = PerformanceLogger;
82
+ //# sourceMappingURL=PerformanceLogger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PerformanceLogger.js","sourceRoot":"","sources":["../../../src/IncrementalLoading/PerformanceLogger.ts"],"names":[],"mappings":";AAAA;;;gGAGgG;;;AAsBhG;;;;GAIG;AACH,MAAa,iBAAiB;IACpB,YAAY,GAA6C,IAAI,GAAG,EAAE,CAAC;IACnE,MAAM,CAAS;IAEvB,4CAA4C;IACrC,cAAc,GAAG,KAAK,CAAC;IAE9B;;;OAGG;IACH,YAAY,KAAc;QACxB,IAAI,CAAC,MAAM,GAAG,KAAK,IAAI,EAAE,CAAC;IAC5B,CAAC;IAED;;;;OAIG;IACH,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED;;;;OAIG;IACI,SAAS,CAAC,SAAiB,EAAE,UAAkB;QACpD,IAAI,IAAI,CAAC,cAAc;YACrB,OAAO;QAET,MAAM,QAAQ,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,GAAG,SAAS,CAAC;QAElD,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACjD,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC;QAErE,cAAc,CAAC,QAAQ,GAAG,QAAQ,CAAC;IACrC,CAAC;IAED;;;;;;OAMG;IACI,aAAa,CAAC,SAAiB,EAAE,UAAkB,EAAE,cAAsB,EAAE,SAAiB;QACnG,IAAI,IAAI,CAAC,cAAc;YACrB,OAAO;QAET,MAAM,QAAQ,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,GAAG,SAAS,CAAC;QAElD,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACjD,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAAC,SAAS,EAAE,UAAU,CAAC,CAAC;QAErE,IAAI,cAAc,CAAC,aAAa,CAAC,GAAG,CAAC,cAAc,CAAC;YAClD,MAAM,IAAI,KAAK,CAAC,mGAAmG,CAAC,CAAC;QAEvH,cAAc,CAAC,aAAa,CAAC,GAAG,CAAC,cAAc,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC,CAAC;IAC5E,CAAC;IAED;;OAEG;IACI,SAAS;QACd,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAC;IAC5B,CAAC;IAEO,YAAY,CAAC,MAAc;QACjC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC;YACnC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,GAAG,EAAE,CAAC,CAAC;QAC3C,CAAC;QAED,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAgC,CAAC;IACtE,CAAC;IAEO,iBAAiB,CAAC,SAAsC,EAAE,UAAkB;QAClF,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC;YAC5B,SAAS,CAAC,GAAG,CAAC,UAAU,EAAE,EAAE,aAAa,EAAE,IAAI,GAAG,EAAE,EAAE,CAAC,CAAA;QAEzD,OAAO,SAAS,CAAC,GAAG,CAAC,UAAU,CAAmB,CAAC;IACrD,CAAC;CACF;AApFD,8CAoFC","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\n/**\n * Contains the properties needed to track load times\n * for SchemaItem queries.\n * @internal\n */\nexport interface SchemaItemLoadData {\n loadTime: number,\n itemCount: number\n}\n\n/**\n * Contains the properties needed to track load times\n * for Schema queries.\n * @internal\n */\nexport interface SchemaLoadData {\n loadTime?: number,\n schemaItemMap: Map<string, SchemaItemLoadData>;\n}\n\n/**\n * Utility class used to log query load times for Schema and\n * SchemaItem queries.\n * @internal\n */\nexport class PerformanceLogger {\n private _iModelItems: Map<string, Map<string, SchemaLoadData>> = new Map();\n private _label: string;\n\n // flag that controls if logging is enabled.\n public disableLogging = false;\n\n /**\n * Initializes a new PerformanceLogger instance.\n * @param label Arbitrary label used to tag this logging session (ex. IModel name)\n */\n constructor(label?: string) {\n this._label = label || \"\";\n }\n\n /**\n * Gets the Map of logged Schema entries. The Map key is the iModel name. The Map\n * value is a second Map whose key is a Schema name and value is a SchemaLoadData\n * object.\n */\n public get logItems(): Map<string, Map<string, SchemaLoadData>> {\n return this._iModelItems;\n }\n\n /**\n * Adds a new log entry to the Schema Map.\n * @param startTime The start time of the entry to be logged (end time/duration is handled in this method).\n * @param schemaName The Schema being queried.\n */\n public logSchema(startTime: number, schemaName: string) {\n if (this.disableLogging)\n return;\n\n const loadTime = new Date().getTime() - startTime;\n\n const schemaMap = this.getSchemaMap(this._label);\n const schemaLoadData = this.getSchemaLoadData(schemaMap, schemaName);\n\n schemaLoadData.loadTime = loadTime;\n }\n\n /**\n * Adds a new log entry to the SchemaItem Map.\n * @param startTime The start time of the entry to be logged (end time/duration is handled in this method).\n * @param schemaName The name of the Schema being queried.\n * @param schemaItemType The SchemaItemType name of the type being queried.\n * @param itemCount The number of items retrieved in the query.\n */\n public logSchemaItem(startTime: number, schemaName: string, schemaItemType: string, itemCount: number) {\n if (this.disableLogging)\n return;\n\n const loadTime = new Date().getTime() - startTime;\n\n const schemaMap = this.getSchemaMap(this._label);\n const schemaLoadData = this.getSchemaLoadData(schemaMap, schemaName);\n\n if (schemaLoadData.schemaItemMap.has(schemaItemType))\n throw new Error(\"There should not be a multiple load times for a given iModel, Schema, SchemaItemType combination.\");\n\n schemaLoadData.schemaItemMap.set(schemaItemType, { loadTime, itemCount });\n }\n\n /**\n * Clears all log entries from the Map.\n */\n public clearLogs() {\n this._iModelItems.clear();\n }\n\n private getSchemaMap(iModel: string): Map<string, SchemaLoadData> {\n if (!this._iModelItems.has(iModel)) {\n this._iModelItems.set(iModel, new Map());\n }\n\n return this._iModelItems.get(iModel) as Map<string, SchemaLoadData>;\n }\n\n private getSchemaLoadData(schemaMap: Map<string, SchemaLoadData>, schemaName: string): SchemaLoadData {\n if (!schemaMap.has(schemaName))\n schemaMap.set(schemaName, { schemaItemMap: new Map() })\n\n return schemaMap.get(schemaName) as SchemaLoadData;\n }\n}"]}
@@ -0,0 +1,51 @@
1
+ import { SchemaContext } from "../Context";
2
+ import { AnySchemaItemProps, KindOfQuantityProps, SchemaItemProps } from "../Deserialization/JsonProps";
3
+ /**
4
+ * Parses SchemaItemProps JSON returned from an ECSql query and returns the correct SchemaItemProps JSON.
5
+ * This is necessary as a small amount information (ie. CustomAttribute data) returned from the iModelDb
6
+ * is in a different format than is required for a SchemaItemProps JSON object.
7
+ * @internal
8
+ */
9
+ export declare class SchemaItemParser {
10
+ protected _schema: string;
11
+ protected _context: SchemaContext;
12
+ /**
13
+ * Initializes a new SchemaItemParser.
14
+ * @param schemaName The name the Schema containing the SchemaItems.
15
+ * @param context The SchemaContext containing the Schema.
16
+ */
17
+ constructor(schemaName: string, context: SchemaContext);
18
+ /**
19
+ * Parses the given SchemaItemProps JSON returned from an ECSql query.
20
+ * @param data The SchemaItemProps JSON as returned from an iModelDb.
21
+ * @returns The corrected SchemaItemProps Json.
22
+ */
23
+ parse(data: AnySchemaItemProps): Promise<SchemaItemProps>;
24
+ /**
25
+ * Helper method to resolve the SchemaItem's full name from the given rawTypeName.
26
+ * If the SchemaItem is defined in the same Schema from which it is referenced,
27
+ * the rawTypeName will be SchemaItem name ('PhysicalElement'). Otherwise,
28
+ * the rawTypeName will have the schema alias ('bis:PhysicalElement').
29
+ * @param rawTypeName The name or aliased name of the SchemaItem.
30
+ * @returns The full name of the SchemaItem, ie. 'BisCore.PhysicalElement'
31
+ */
32
+ getQualifiedTypeName(rawTypeName: string): Promise<string>;
33
+ private resolveNameFromAlias;
34
+ }
35
+ /**
36
+ * Parses KindOfQuantityProps JSON returned from an ECSql query and returns the correct KindOfQuantityProps JSON.
37
+ * This is necessary as a small amount information (ie. unqualified type names of presentationUnits) returned from
38
+ * the iModelDb is in a different format than is required for a KindOfQuantityProps JSON object.
39
+ * @internal
40
+ */
41
+ export declare class KindOfQuantityParser extends SchemaItemParser {
42
+ /**
43
+ * Parses the given KindOfQuantityProps JSON returned from an ECSql query.
44
+ * @param data The KindOfQuantityProps JSON as returned from an iModelDb.
45
+ * @returns The corrected KindOfQuantityProps Json.
46
+ */
47
+ parse(data: KindOfQuantityProps): Promise<KindOfQuantityProps>;
48
+ private parsePresentationUnits;
49
+ private createOverrideFormatString;
50
+ }
51
+ //# sourceMappingURL=SchemaItemParsers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SchemaItemParsers.d.ts","sourceRoot":"","sources":["../../../src/IncrementalLoading/SchemaItemParsers.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAC3C,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAUxG;;;;;GAKG;AACH,qBAAa,gBAAgB;IAC3B,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC;IAC1B,SAAS,CAAC,QAAQ,EAAE,aAAa,CAAC;IAElC;;;;OAIG;gBACgB,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,aAAa;IAK7D;;;;OAIG;IACU,KAAK,CAAC,IAAI,EAAE,kBAAkB,GAAG,OAAO,CAAC,eAAe,CAAC;IAUtE;;;;;;;OAOG;IACU,oBAAoB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;YAgBzD,oBAAoB;CAOnC;AAMD;;;;;GAKG;AACH,qBAAa,oBAAqB,SAAQ,gBAAgB;IACxD;;;;OAIG;IACmB,KAAK,CAAC,IAAI,EAAE,mBAAmB,GAAG,OAAO,CAAC,mBAAmB,CAAC;YAWtE,sBAAsB;YActB,0BAA0B;CAmBzC"}
@@ -0,0 +1,122 @@
1
+ "use strict";
2
+ /*---------------------------------------------------------------------------------------------
3
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
4
+ * See LICENSE.md in the project root for license terms and full copyright notice.
5
+ *--------------------------------------------------------------------------------------------*/
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.KindOfQuantityParser = exports.SchemaItemParser = void 0;
8
+ const ECObjects_1 = require("../ECObjects");
9
+ const OverrideFormat_1 = require("../Metadata/OverrideFormat");
10
+ const SchemaItem_1 = require("../Metadata/SchemaItem");
11
+ const SchemaParser_1 = require("./SchemaParser");
12
+ /**
13
+ * Parses SchemaItemProps JSON returned from an ECSql query and returns the correct SchemaItemProps JSON.
14
+ * This is necessary as a small amount information (ie. CustomAttribute data) returned from the iModelDb
15
+ * is in a different format than is required for a SchemaItemProps JSON object.
16
+ * @internal
17
+ */
18
+ class SchemaItemParser {
19
+ _schema;
20
+ _context;
21
+ /**
22
+ * Initializes a new SchemaItemParser.
23
+ * @param schemaName The name the Schema containing the SchemaItems.
24
+ * @param context The SchemaContext containing the Schema.
25
+ */
26
+ constructor(schemaName, context) {
27
+ this._schema = schemaName;
28
+ this._context = context;
29
+ }
30
+ /**
31
+ * Parses the given SchemaItemProps JSON returned from an ECSql query.
32
+ * @param data The SchemaItemProps JSON as returned from an iModelDb.
33
+ * @returns The corrected SchemaItemProps Json.
34
+ */
35
+ async parse(data) {
36
+ const props = data;
37
+ props.schemaItemType = (0, ECObjects_1.parseSchemaItemType)(data.schemaItemType);
38
+ props.customAttributes = props.customAttributes ? props.customAttributes.map((attr) => { return (0, SchemaParser_1.parseCustomAttribute)(attr); }) : undefined;
39
+ if (!props.customAttributes || props.customAttributes.length === 0)
40
+ delete props.customAttributes;
41
+ return props;
42
+ }
43
+ /**
44
+ * Helper method to resolve the SchemaItem's full name from the given rawTypeName.
45
+ * If the SchemaItem is defined in the same Schema from which it is referenced,
46
+ * the rawTypeName will be SchemaItem name ('PhysicalElement'). Otherwise,
47
+ * the rawTypeName will have the schema alias ('bis:PhysicalElement').
48
+ * @param rawTypeName The name or aliased name of the SchemaItem.
49
+ * @returns The full name of the SchemaItem, ie. 'BisCore.PhysicalElement'
50
+ */
51
+ async getQualifiedTypeName(rawTypeName) {
52
+ const nameParts = rawTypeName.split(":");
53
+ if (nameParts.length !== 2) {
54
+ const [schemaName, itemName] = SchemaItem_1.SchemaItem.parseFullName(rawTypeName);
55
+ if (!schemaName || schemaName === '')
56
+ return `${this._schema}.${itemName}`;
57
+ return rawTypeName;
58
+ }
59
+ const resolvedName = await this.resolveNameFromAlias(nameParts[0].toLocaleLowerCase());
60
+ if (!resolvedName)
61
+ throw new Error(`No valid schema found for alias '${nameParts[0]}'`);
62
+ return `${resolvedName}.${nameParts[1]}`;
63
+ }
64
+ async resolveNameFromAlias(alias) {
65
+ for (const schema of this._context.getKnownSchemas()) {
66
+ if (schema.alias === alias)
67
+ return schema.schemaKey.name;
68
+ }
69
+ return undefined;
70
+ }
71
+ }
72
+ exports.SchemaItemParser = SchemaItemParser;
73
+ /**
74
+ * Parses KindOfQuantityProps JSON returned from an ECSql query and returns the correct KindOfQuantityProps JSON.
75
+ * This is necessary as a small amount information (ie. unqualified type names of presentationUnits) returned from
76
+ * the iModelDb is in a different format than is required for a KindOfQuantityProps JSON object.
77
+ * @internal
78
+ */
79
+ class KindOfQuantityParser extends SchemaItemParser {
80
+ /**
81
+ * Parses the given KindOfQuantityProps JSON returned from an ECSql query.
82
+ * @param data The KindOfQuantityProps JSON as returned from an iModelDb.
83
+ * @returns The corrected KindOfQuantityProps Json.
84
+ */
85
+ async parse(data) {
86
+ const mutableProps = await super.parse(data);
87
+ if (mutableProps.persistenceUnit) {
88
+ mutableProps.persistenceUnit = await this.getQualifiedTypeName(mutableProps.persistenceUnit);
89
+ }
90
+ mutableProps.presentationUnits = await this.parsePresentationUnits(mutableProps);
91
+ return mutableProps;
92
+ }
93
+ async parsePresentationUnits(props) {
94
+ const presentationUnits = [];
95
+ if (!props.presentationUnits)
96
+ return [];
97
+ for (const presentationUnit of props.presentationUnits) {
98
+ const presFormatOverride = OverrideFormat_1.OverrideFormat.parseFormatString(presentationUnit);
99
+ const formatString = await this.createOverrideFormatString(presFormatOverride);
100
+ presentationUnits.push(formatString);
101
+ }
102
+ ;
103
+ return presentationUnits;
104
+ }
105
+ async createOverrideFormatString(overrideFormatProps) {
106
+ let formatFullName = await this.getQualifiedTypeName(overrideFormatProps.name);
107
+ if (overrideFormatProps.precision)
108
+ formatFullName += `(${overrideFormatProps.precision.toString()})`;
109
+ if (undefined === overrideFormatProps.unitAndLabels)
110
+ return formatFullName;
111
+ for (const [unit, unitLabel] of overrideFormatProps.unitAndLabels) {
112
+ const unitFullName = await this.getQualifiedTypeName(unit);
113
+ if (undefined === unitLabel)
114
+ formatFullName += `[${unitFullName}]`;
115
+ else
116
+ formatFullName += `[${unitFullName}|${unitLabel}]`;
117
+ }
118
+ return formatFullName;
119
+ }
120
+ }
121
+ exports.KindOfQuantityParser = KindOfQuantityParser;
122
+ //# sourceMappingURL=SchemaItemParsers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SchemaItemParsers.js","sourceRoot":"","sources":["../../../src/IncrementalLoading/SchemaItemParsers.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\nimport { SchemaContext } from \"../Context\";\nimport { AnySchemaItemProps, KindOfQuantityProps, SchemaItemProps } from \"../Deserialization/JsonProps\";\nimport { parseSchemaItemType } from \"../ECObjects\";\nimport { OverrideFormat, OverrideFormatProps } from \"../Metadata/OverrideFormat\";\nimport { SchemaItem } from \"../Metadata/SchemaItem\";\nimport { parseCustomAttribute } from \"./SchemaParser\";\n\ntype MutableSchemaItemProps = {\n -readonly [K in keyof SchemaItemProps]: SchemaItemProps[K]\n};\n\n/**\n * Parses SchemaItemProps JSON returned from an ECSql query and returns the correct SchemaItemProps JSON.\n * This is necessary as a small amount information (ie. CustomAttribute data) returned from the iModelDb\n * is in a different format than is required for a SchemaItemProps JSON object.\n * @internal\n */\nexport class SchemaItemParser {\n protected _schema: string;\n protected _context: SchemaContext;\n\n /**\n * Initializes a new SchemaItemParser.\n * @param schemaName The name the Schema containing the SchemaItems.\n * @param context The SchemaContext containing the Schema.\n */\n public constructor(schemaName: string, context: SchemaContext) {\n this._schema = schemaName;\n this._context = context;\n }\n\n /**\n * Parses the given SchemaItemProps JSON returned from an ECSql query.\n * @param data The SchemaItemProps JSON as returned from an iModelDb.\n * @returns The corrected SchemaItemProps Json.\n */\n public async parse(data: AnySchemaItemProps): Promise<SchemaItemProps> {\n const props = data as MutableSchemaItemProps;\n props.schemaItemType = parseSchemaItemType((data as any).schemaItemType);\n props.customAttributes = props.customAttributes ? props.customAttributes.map((attr: any) => { return parseCustomAttribute(attr); }) : undefined;\n if (!props.customAttributes || props.customAttributes.length === 0)\n delete props.customAttributes;\n\n return props;\n }\n\n /**\n * Helper method to resolve the SchemaItem's full name from the given rawTypeName.\n * If the SchemaItem is defined in the same Schema from which it is referenced,\n * the rawTypeName will be SchemaItem name ('PhysicalElement'). Otherwise,\n * the rawTypeName will have the schema alias ('bis:PhysicalElement').\n * @param rawTypeName The name or aliased name of the SchemaItem.\n * @returns The full name of the SchemaItem, ie. 'BisCore.PhysicalElement'\n */\n public async getQualifiedTypeName(rawTypeName: string): Promise<string> {\n const nameParts = rawTypeName.split(\":\");\n if (nameParts.length !== 2) {\n const [schemaName, itemName] = SchemaItem.parseFullName(rawTypeName);\n if (!schemaName || schemaName === '')\n return `${this._schema}.${itemName}`;\n return rawTypeName;\n }\n\n const resolvedName = await this.resolveNameFromAlias(nameParts[0].toLocaleLowerCase());\n if (!resolvedName)\n throw new Error(`No valid schema found for alias '${nameParts[0]}'`);\n\n return `${resolvedName}.${nameParts[1]}`;\n }\n\n private async resolveNameFromAlias(alias: string): Promise<string | undefined> {\n for (const schema of this._context.getKnownSchemas()) {\n if (schema.alias === alias)\n return schema.schemaKey.name;\n }\n return undefined;\n }\n}\n\ntype MutableKindOfQuantityProps = {\n -readonly [K in keyof KindOfQuantityProps]: KindOfQuantityProps[K]\n};\n\n/**\n * Parses KindOfQuantityProps JSON returned from an ECSql query and returns the correct KindOfQuantityProps JSON.\n * This is necessary as a small amount information (ie. unqualified type names of presentationUnits) returned from\n * the iModelDb is in a different format than is required for a KindOfQuantityProps JSON object.\n * @internal\n */\nexport class KindOfQuantityParser extends SchemaItemParser {\n /**\n * Parses the given KindOfQuantityProps JSON returned from an ECSql query.\n * @param data The KindOfQuantityProps JSON as returned from an iModelDb.\n * @returns The corrected KindOfQuantityProps Json.\n */\n public override async parse(data: KindOfQuantityProps): Promise<KindOfQuantityProps> {\n const mutableProps = await super.parse(data) as MutableKindOfQuantityProps;\n\n if (mutableProps.persistenceUnit) {\n mutableProps.persistenceUnit = await this.getQualifiedTypeName(mutableProps.persistenceUnit);\n }\n mutableProps.presentationUnits = await this.parsePresentationUnits(mutableProps);\n\n return mutableProps;\n }\n\n private async parsePresentationUnits(props: KindOfQuantityProps): Promise<string[]> {\n const presentationUnits: string[] = [];\n if (!props.presentationUnits)\n return [];\n\n for (const presentationUnit of props.presentationUnits) {\n const presFormatOverride: OverrideFormatProps = OverrideFormat.parseFormatString(presentationUnit);\n const formatString = await this.createOverrideFormatString(presFormatOverride);\n presentationUnits.push(formatString);\n };\n\n return presentationUnits;\n }\n\n private async createOverrideFormatString(overrideFormatProps: OverrideFormatProps): Promise<string> {\n\n let formatFullName = await this.getQualifiedTypeName(overrideFormatProps.name);\n if (overrideFormatProps.precision)\n formatFullName += `(${overrideFormatProps.precision.toString()})`;\n\n if (undefined === overrideFormatProps.unitAndLabels)\n return formatFullName;\n\n for (const [unit, unitLabel] of overrideFormatProps.unitAndLabels) {\n const unitFullName = await this.getQualifiedTypeName(unit);\n\n if (undefined === unitLabel)\n formatFullName += `[${unitFullName}]`;\n else\n formatFullName += `[${unitFullName}|${unitLabel}]`;\n }\n return formatFullName;\n }\n}"]}
@@ -0,0 +1,16 @@
1
+ /**
2
+ * Queries for each SchemaItemType
3
+ * @internal
4
+ */
5
+ export declare const SchemaItemQueries: {
6
+ kindOfQuantity: (singleSchema?: boolean) => string;
7
+ propertyCategory: (singleSchema?: boolean) => string;
8
+ enumeration: (singleSchema?: boolean) => string;
9
+ unit: (singleSchema?: boolean) => string;
10
+ invertedUnit: (singleSchema?: boolean) => string;
11
+ constant: (singleSchema?: boolean) => string;
12
+ unitSystem: (singleSchema?: boolean) => string;
13
+ phenomenon: (singleSchema?: boolean) => string;
14
+ format: (singleSchema?: boolean) => string;
15
+ };
16
+ //# sourceMappingURL=SchemaItemQueries.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SchemaItemQueries.d.ts","sourceRoot":"","sources":["../../../src/IncrementalLoading/SchemaItemQueries.ts"],"names":[],"mappings":"AA2SA;;;GAGG;AAEH,eAAO,MAAM,iBAAiB;oCAlSS,OAAO;sCA8BL,OAAO;iCAuBZ,OAAO;0BAiCd,OAAO;kCAuCC,OAAO;8BAmCX,OAAO;gCAgCL,OAAO;gCAqBP,OAAO;4BAsBX,OAAO;CAiErC,CAAC"}
@@ -0,0 +1,308 @@
1
+ "use strict";
2
+ /*---------------------------------------------------------------------------------------------
3
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
4
+ * See LICENSE.md in the project root for license terms and full copyright notice.
5
+ *--------------------------------------------------------------------------------------------*/
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.SchemaItemQueries = void 0;
8
+ /************************************************************************************
9
+ * All SchemaItem queries for each SchemaItemType are defined here. These queries
10
+ * are shared for both 'partial schema' and 'full schema' queries.
11
+ ***********************************************************************************/
12
+ /**
13
+ * Query for SchemaItemType KindOfQuantity data.
14
+ * @param singleSchema Indicates if a filter and join for a single Schema should be applied.
15
+ */
16
+ const kindOfQuantity = (singleSchema) => `
17
+ SELECT
18
+ [koq].[Schema].[Id] AS [SchemaId],
19
+ json_object (
20
+ 'schemaItemType', 'KindOfQuantity',
21
+ 'name', [koq].[Name],
22
+ 'label', [koq].[DisplayLabel],
23
+ 'description', [koq].[Description]
24
+ ${singleSchema ? `
25
+ ,'relativeError', [koq].[RelativeError],
26
+ 'persistenceUnit', [koq].[PersistenceUnit],
27
+ 'presentationUnits', (
28
+ SELECT json_group_array(js."value")
29
+ FROM [meta].[KindOfQuantityDef] [koq1], json1.json_each([PresentationUnits]) js
30
+ WHERE [koq1].[ECInstanceId] = [koq].[ECInstanceId]
31
+ ) ` : ""}
32
+ ) as [item]
33
+ FROM
34
+ [meta].[KindOfQuantityDef] [koq]
35
+ ${singleSchema ? `
36
+ JOIN
37
+ [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [koq].[Schema].[Id]
38
+ WHERE [schema].[Name] = :schemaName
39
+ ` : ""}
40
+ `;
41
+ /**
42
+ * Query for SchemaItemType PropertyCategory data.
43
+ * @param singleSchema Indicates if a filter and join for a single Schema should be applied.
44
+ */
45
+ const propertyCategory = (singleSchema) => `
46
+ SELECT
47
+ [pc].[Schema].[Id] AS [SchemaId],
48
+ json_object (
49
+ 'schemaItemType', 'PropertyCategory',
50
+ 'name', [pc].[Name],
51
+ 'label', [pc].[DisplayLabel],
52
+ 'description', [pc].[Description],
53
+ 'priority', [pc].[Priority]
54
+ ) as [item]
55
+ FROM
56
+ [meta].[PropertyCategoryDef] [pc]
57
+ ${singleSchema ? `
58
+ JOIN
59
+ [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [pc].[Schema].[Id]
60
+ WHERE [schema].[Name] = :schemaName
61
+ ` : ""}
62
+ `;
63
+ /**
64
+ * Query for SchemaItemType Enumeration data.
65
+ * @param singleSchema Indicates if a filter and join for a single Schema should be applied.
66
+ */
67
+ const enumeration = (singleSchema) => `
68
+ SELECT
69
+ [ed].[Schema].[Id] AS [SchemaId],
70
+ json_object (
71
+ 'schemaItemType', 'Enumeration',
72
+ 'name', [ed].[Name],
73
+ 'label', [ed].[DisplayLabel],
74
+ 'description', [ed].[Description],
75
+ 'type', IIF([ed].[Type] = 1281, 'int', IIF([ed].[Type] = 2305, 'string', null)),
76
+ 'isStrict', IIF([ed].[IsStrict] = 1, json('true'), json('false')),
77
+ 'enumerators', (
78
+ SELECT json_group_array(json(json_object(
79
+ 'name', json_extract(js."value", '$.Name'),
80
+ 'value', IFNULL(json_extract(js."value", '$.StringValue'), (json_extract(js."value", '$.IntValue'))),
81
+ 'label', json_extract(js."value", '$.DisplayLabel'),
82
+ 'description', json_extract(js."value", '$.Description')
83
+ )))
84
+ FROM [meta].[ECEnumerationDef] [enumerationDef], json1.json_each([EnumValues]) js
85
+ WHERE [enumerationDef].[ECInstanceId] = [ed].[ECInstanceId]
86
+ )
87
+ ) as [item]
88
+ FROM
89
+ [meta].[ECEnumerationDef] [ed]
90
+ ${singleSchema ? `
91
+ JOIN
92
+ [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [ed].[Schema].[Id]
93
+ WHERE [schema].[Name] = :schemaName` : ""}
94
+ `;
95
+ /**
96
+ * Query for SchemaItemType Unit data.
97
+ * @param singleSchema Indicates if a filter and join for a single Schema should be applied.
98
+ */
99
+ const unit = (singleSchema) => `
100
+ SELECT
101
+ [ud].[Schema].[Id] AS [SchemaId],
102
+ json_object (
103
+ 'schemaItemType', 'Unit',
104
+ 'name', [ud].[Name],
105
+ 'label', [ud].[DisplayLabel],
106
+ 'description', [ud].[Description],
107
+ 'definition', [ud].[Definition],
108
+ 'numerator', IIF([ud].[Numerator] IS NULL, NULL, json(format('%.16g', [ud].[Numerator]))),
109
+ 'denominator', IIF([ud].[Denominator] IS NULL, NULL, json(format('%.16g', [ud].[Denominator]))),
110
+ 'offset', IIF([ud].[Offset] IS NULL, NULL, json(format('%!.15f', [ud].[Offset]))),
111
+ 'unitSystem', CONCAT([uss].[Name],'.', [usd].[Name]),
112
+ 'phenomenon', CONCAT([ps].[Name],'.', [pd].[Name])
113
+ ) as item
114
+ FROM
115
+ [meta].[UnitDef] [ud]
116
+ ${singleSchema ? `
117
+ JOIN
118
+ [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [ud].[Schema].[Id]` : ""}
119
+ JOIN [meta].[UnitSystemDef] [usd]
120
+ ON [usd].[ECInstanceId] = [ud].[UnitSystem].[Id]
121
+ JOIN [meta].[ECSchemaDef] [uss]
122
+ ON [uss].[ECInstanceId] = [usd].[Schema].[Id]
123
+ JOIN [meta].[PhenomenonDef] [pd]
124
+ ON [pd].[ECInstanceId] = [ud].[Phenomenon].[Id]
125
+ JOIN [meta].[ECSchemaDef] [ps]
126
+ ON [ps].[ECInstanceId] = [pd].[Schema].[Id]
127
+ WHERE
128
+ ${singleSchema ? `
129
+ [schema].[Name] = :schemaName AND` : ""}
130
+ [ud].[IsConstant] = 0 AND
131
+ [ud].[InvertingUnit] IS NULL
132
+ `;
133
+ /**
134
+ * Query for SchemaItemType InvertedUnit data.
135
+ * @param singleSchema Indicates if a filter and join for a single Schema should be applied.
136
+ */
137
+ const invertedUnit = (singleSchema) => `
138
+ SELECT
139
+ [ud].[Schema].[Id] AS [SchemaId],
140
+ json_object (
141
+ 'schemaItemType', 'InvertedUnit',
142
+ 'name', [ud].[Name],
143
+ 'label', [ud].[DisplayLabel],
144
+ 'description', [ud].[Description],
145
+ 'unitSystem', CONCAT([systemSchema].[Name],'.', [usd].[Name]),
146
+ 'invertsUnit', IIF([iud].[Name] IS NULL, null, CONCAT([ius].[Name],'.', [iud].[Name]))
147
+ ) as [item]
148
+ FROM
149
+ [meta].[UnitDef] [ud]
150
+ ${singleSchema ? `
151
+ JOIN
152
+ [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [ud].[Schema].[Id]` : ""}
153
+ JOIN [meta].[UnitSystemDef] [usd]
154
+ ON [usd].[ECInstanceId] = [ud].[UnitSystem].[Id]
155
+ JOIN [meta].[ECSchemaDef] [systemSchema]
156
+ ON [systemSchema].[ECInstanceId] = [usd].[Schema].[Id]
157
+ LEFT JOIN [meta].[UnitDef] [iud]
158
+ ON [iud].[ECInstanceId] = [ud].[InvertingUnit].[Id]
159
+ LEFT JOIN [meta].[ECSchemaDef] [ius]
160
+ ON [ius].[ECInstanceId] = [iud].[Schema].[Id]
161
+ WHERE
162
+ ${singleSchema ? `
163
+ [schema].[Name] = :schemaName AND` : ""}
164
+ [ud].[IsConstant] = 0 AND
165
+ [ud].[InvertingUnit] IS NOT NULL
166
+ `;
167
+ /**
168
+ * Query for SchemaItemType Constant data.
169
+ * @param singleSchema Indicates if a filter and join for a single Schema should be applied.
170
+ */
171
+ const constant = (singleSchema) => `
172
+ SELECT
173
+ [cd].[Schema].[Id] AS [SchemaId],
174
+ json_object(
175
+ 'schemaItemType', 'Constant',
176
+ 'name', [cd].[Name],
177
+ 'label', [cd].[DisplayLabel],
178
+ 'description', [cd].[Description],
179
+ 'definition', [cd].[Definition],
180
+ 'numerator', IIF([cd].[Numerator] IS NULL, NULL, json(format('%.16g', [cd].[Numerator]))),
181
+ 'denominator', IIF([cd].[Denominator] IS NULL, NULL, json(format('%.16g', [cd].[Denominator]))),
182
+ 'phenomenon', CONCAT([phenomSchema].[Name],'.', [phenomDef].[Name])
183
+ ) as item
184
+ FROM
185
+ [meta].[UnitDef] [cd]
186
+ ${singleSchema ? `
187
+ JOIN
188
+ [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [cd].[Schema].[Id]` : ""}
189
+ JOIN [meta].[PhenomenonDef] [phenomDef]
190
+ ON [phenomDef].[ECInstanceId] = [cd].[Phenomenon].[Id]
191
+ JOIN [meta].[ECSchemaDef] [phenomSchema]
192
+ ON [phenomSchema].[ECInstanceId] = [phenomDef].[Schema].[Id]
193
+ WHERE
194
+ ${singleSchema ? `
195
+ [schema].[Name] = :schemaName AND` : ""}
196
+ [cd].[IsConstant] = 1
197
+ `;
198
+ /**
199
+ * Query for SchemaItemType UnitSystem data.
200
+ * @param singleSchema Indicates if a filter and join for a single Schema should be applied.
201
+ */
202
+ const unitSystem = (singleSchema) => `
203
+ SELECT
204
+ [us].[Schema].[Id] AS [SchemaId],
205
+ json_object (
206
+ 'schemaItemType', 'UnitSystem',
207
+ 'name', [us].[Name],
208
+ 'label', [us].[DisplayLabel],
209
+ 'description', [us].[Description]
210
+ ) as [item]
211
+ FROM
212
+ [meta].[UnitSystemDef] [us]
213
+ ${singleSchema ? `
214
+ JOIN
215
+ [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [us].[Schema].[Id]
216
+ WHERE [schema].[Name] = :schemaName` : ""}
217
+ `;
218
+ /**
219
+ * Query for SchemaItemType Phenomenon data.
220
+ * @param singleSchema Indicates if a filter and join for a single Schema should be applied.
221
+ */
222
+ const phenomenon = (singleSchema) => `
223
+ SELECT
224
+ [pd].[Schema].[Id] AS [SchemaId],
225
+ json_object(
226
+ 'schemaItemType', 'Phenomenon',
227
+ 'name', [pd].[Name],
228
+ 'label', [pd].[DisplayLabel],
229
+ 'description', [pd].[Description],
230
+ 'definition', [pd].[Definition]
231
+ ) as [item]
232
+ FROM
233
+ [meta].[PhenomenonDef] [pd]
234
+ ${singleSchema ? `
235
+ JOIN
236
+ [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [pd].[Schema].[Id]
237
+ WHERE [schema].[Name] = :schemaName` : ""}
238
+ `;
239
+ /**
240
+ * Query for SchemaItemType Format data.
241
+ * @param singleSchema Indicates if a filter and join for a single Schema should be applied.
242
+ */
243
+ const format = (singleSchema) => `
244
+ SELECT
245
+ [fd].[Schema].[Id] AS [SchemaId],
246
+ json_object(
247
+ 'schemaItemType', 'Format',
248
+ 'name', [fd].[Name],
249
+ 'label', [fd].[DisplayLabel],
250
+ 'description', [fd].[Description],
251
+ 'type', json_extract([fd].[NumericSpec], '$.type'),
252
+ 'precision', json_extract([fd].[NumericSpec], '$.precision'),
253
+ 'roundFactor', json_extract([fd].[NumericSpec], '$.roundFactor'),
254
+ 'minWidth', json_extract([fd].[NumericSpec], '$.minWidth'),
255
+ 'showSignOption', json_extract([fd].[NumericSpec], '$.showSignOption'),
256
+ 'decimalSeparator', json_extract([fd].[NumericSpec], '$.decimalSeparator'),
257
+ 'thousandSeparator', json_extract([fd].[NumericSpec], '$.thousandSeparator'),
258
+ 'uomSeparator', json_extract([fd].[NumericSpec], '$.uomSeparator'),
259
+ 'scientificType', json_extract([fd].[NumericSpec], '$.scientificType'),
260
+ 'stationOffsetSize', json_extract([fd].[NumericSpec], '$.stationOffsetSize'),
261
+ 'stationSeparator', json_extract([fd].[NumericSpec], '$.stationSeparator'),
262
+ 'formatTraits', json_extract([fd].[NumericSpec], '$.formatTraits')
263
+ ${singleSchema ? `
264
+ ,'composite', (
265
+ SELECT
266
+ json_object(
267
+ 'spacer', json_extract([fd1].[CompositeSpec], '$.spacer'),
268
+ 'includeZero', json(IIF(json_extract([fd1].[CompositeSpec], '$.includeZero') = 1, 'true', IIF(json_extract([fd1].[CompositeSpec], '$.includeZero') = 0, 'false', null))),
269
+ 'units', (
270
+ SELECT json_group_array(json(json_object(
271
+ 'name', CONCAT([sd].[Name], '.', [ud].[Name]),
272
+ 'label', [fud].[Label]
273
+ )))
274
+ FROM [meta].[FormatDef] [fd2]
275
+ LEFT JOIN [meta].[FormatCompositeUnitDef] [fud] ON [fud].[Format].[Id] = [fd2].[ECInstanceId]
276
+ LEFT JOIN [meta].[UnitDef] [ud] ON [ud].[ECInstanceId] = [fud].[Unit].[Id]
277
+ INNER JOIN [meta].[ECSchemaDef] [sd] ON [sd].[ECInstanceId] = [ud].[Schema].[Id]
278
+ WHERE [fd2].[ECInstanceId] = [fd1].[ECInstanceId]
279
+ )
280
+ )
281
+ FROM [meta].[FormatDef] [fd1]
282
+ WHERE [fd1].[ECInstanceId]= [fd].[ECInstanceId] AND [fd1].[CompositeSpec] IS NOT NULL
283
+ )` : ""}
284
+ ) AS item
285
+ FROM
286
+ [meta].[FormatDef] [fd]
287
+ ${singleSchema ? `
288
+ JOIN
289
+ [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [fd].[Schema].[Id]
290
+ WHERE [schema].[Name] = :schemaName` : ""}
291
+ `;
292
+ /**
293
+ * Queries for each SchemaItemType
294
+ * @internal
295
+ */
296
+ // eslint-disable-next-line @typescript-eslint/naming-convention
297
+ exports.SchemaItemQueries = {
298
+ kindOfQuantity,
299
+ propertyCategory,
300
+ enumeration,
301
+ unit,
302
+ invertedUnit,
303
+ constant,
304
+ unitSystem,
305
+ phenomenon,
306
+ format
307
+ };
308
+ //# sourceMappingURL=SchemaItemQueries.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SchemaItemQueries.js","sourceRoot":"","sources":["../../../src/IncrementalLoading/SchemaItemQueries.ts"],"names":[],"mappings":";AAAA;;;gGAGgG;;;AAEhG;;;qFAGqF;AAErF;;;GAGG;AACH,MAAM,cAAc,GAAG,CAAC,YAAsB,EAAE,EAAE,CAAC;;;;;;;;MAQ7C,YAAY,CAAC,CAAC,CAAC;;;;;;;OAOd,CAAA,CAAC,CAAC,EAAE;;;;EAIT,YAAY,CAAC,CAAC,CAAC;;;;CAIhB,CAAC,CAAC,CAAC,EAAE;CACL,CAAC;AAEF;;;GAGG;AACH,MAAM,gBAAgB,GAAG,CAAC,YAAsB,EAAE,EAAE,CAAC;;;;;;;;;;;;EAYnD,YAAY,CAAC,CAAC,CAAC;;;;CAIhB,CAAC,CAAC,CAAC,EAAE;CACL,CAAC;AAEF;;;GAGG;AACH,MAAM,WAAW,GAAG,CAAC,YAAsB,EAAE,EAAE,CAAC;;;;;;;;;;;;;;;;;;;;;;;EAuB9C,YAAY,CAAC,CAAC,CAAC;;;oCAGmB,CAAC,CAAC,CAAC,EAAE;CACxC,CAAC;AAEF;;;GAGG;AACH,MAAM,IAAI,GAAG,CAAC,YAAsB,EAAE,EAAE,CAAC;;;;;;;;;;;;;;;;;EAiBvC,YAAY,CAAC,CAAC,CAAC;;gFAE+D,CAAC,CAAC,CAAC,EAAE;;;;;;;;;;IAUjF,YAAY,CAAC,CAAC,CAAC;oCACiB,CAAC,CAAC,CAAC,EAAE;;;CAGxC,CAAC;AAEF;;;GAGG;AACH,MAAM,YAAY,GAAG,CAAC,YAAsB,EAAE,EAAE,CAAC;;;;;;;;;;;;;EAa/C,YAAY,CAAC,CAAC,CAAC;;gFAE+D,CAAC,CAAC,CAAC,EAAE;;;;;;;;;;IAUjF,YAAY,CAAC,CAAC,CAAC;oCACiB,CAAC,CAAC,CAAC,EAAE;;;CAGxC,CAAC;AAEF;;;GAGG;AACH,MAAM,QAAQ,GAAG,CAAC,YAAsB,EAAE,EAAE,CAAC;;;;;;;;;;;;;;;EAe3C,YAAY,CAAC,CAAC,CAAC;;gFAE+D,CAAC,CAAC,CAAC,EAAE;;;;;;IAMjF,YAAY,CAAC,CAAC,CAAC;oCACiB,CAAC,CAAC,CAAC,EAAE;;CAExC,CAAC;AAEF;;;GAGG;AACH,MAAM,UAAU,GAAG,CAAC,YAAsB,EAAE,EAAE,CAAC;;;;;;;;;;;EAW7C,YAAY,CAAC,CAAC,CAAC;;;oCAGmB,CAAC,CAAC,CAAC,EAAE;CACxC,CAAC;AAEF;;;GAGG;AACH,MAAM,UAAU,GAAG,CAAC,YAAsB,EAAE,EAAE,CAAC;;;;;;;;;;;;EAY7C,YAAY,CAAC,CAAC,CAAC;;;oCAGmB,CAAC,CAAC,CAAC,EAAE;CACxC,CAAC;AAEF;;;GAGG;AACH,MAAM,MAAM,GAAG,CAAC,YAAsB,EAAE,EAAE,CAAC;;;;;;;;;;;;;;;;;;;;MAoBrC,YAAY,CAAC,CAAC,CAAC;;;;;;;;;;;;;;;;;;;;MAoBf,CAAC,CAAC,CAAC,EAAE;;;;EAIT,YAAY,CAAC,CAAC,CAAC;;;oCAGmB,CAAC,CAAC,CAAC,EAAE;CACxC,CAAA;AAED;;;GAGG;AACH,gEAAgE;AACnD,QAAA,iBAAiB,GAAG;IAC/B,cAAc;IACd,gBAAgB;IAChB,WAAW;IACX,IAAI;IACJ,YAAY;IACZ,QAAQ;IACR,UAAU;IACV,UAAU;IACV,MAAM;CACP,CAAC","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\n/************************************************************************************\n * All SchemaItem queries for each SchemaItemType are defined here. These queries\n * are shared for both 'partial schema' and 'full schema' queries.\n ***********************************************************************************/\n\n/**\n * Query for SchemaItemType KindOfQuantity data.\n * @param singleSchema Indicates if a filter and join for a single Schema should be applied.\n */\nconst kindOfQuantity = (singleSchema?: boolean) => `\nSELECT\n [koq].[Schema].[Id] AS [SchemaId],\n json_object (\n 'schemaItemType', 'KindOfQuantity',\n 'name', [koq].[Name],\n 'label', [koq].[DisplayLabel],\n 'description', [koq].[Description]\n ${singleSchema ? `\n ,'relativeError', [koq].[RelativeError],\n 'persistenceUnit', [koq].[PersistenceUnit],\n 'presentationUnits', (\n SELECT json_group_array(js.\"value\")\n FROM [meta].[KindOfQuantityDef] [koq1], json1.json_each([PresentationUnits]) js\n WHERE [koq1].[ECInstanceId] = [koq].[ECInstanceId]\n ) `: \"\"}\n ) as [item]\nFROM\n [meta].[KindOfQuantityDef] [koq]\n${singleSchema ? `\nJOIN\n [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [koq].[Schema].[Id]\nWHERE [schema].[Name] = :schemaName\n` : \"\"}\n`;\n\n/**\n * Query for SchemaItemType PropertyCategory data.\n * @param singleSchema Indicates if a filter and join for a single Schema should be applied.\n */\nconst propertyCategory = (singleSchema?: boolean) => `\nSELECT\n [pc].[Schema].[Id] AS [SchemaId],\n json_object (\n 'schemaItemType', 'PropertyCategory',\n 'name', [pc].[Name],\n 'label', [pc].[DisplayLabel],\n 'description', [pc].[Description],\n 'priority', [pc].[Priority]\n ) as [item]\nFROM\n [meta].[PropertyCategoryDef] [pc]\n${singleSchema ? `\nJOIN\n [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [pc].[Schema].[Id]\nWHERE [schema].[Name] = :schemaName\n` : \"\"}\n`;\n\n/**\n * Query for SchemaItemType Enumeration data.\n * @param singleSchema Indicates if a filter and join for a single Schema should be applied.\n */\nconst enumeration = (singleSchema?: boolean) => `\nSELECT\n [ed].[Schema].[Id] AS [SchemaId],\n json_object (\n 'schemaItemType', 'Enumeration',\n 'name', [ed].[Name],\n 'label', [ed].[DisplayLabel],\n 'description', [ed].[Description],\n 'type', IIF([ed].[Type] = 1281, 'int', IIF([ed].[Type] = 2305, 'string', null)),\n 'isStrict', IIF([ed].[IsStrict] = 1, json('true'), json('false')),\n 'enumerators', (\n SELECT json_group_array(json(json_object(\n 'name', json_extract(js.\"value\", '$.Name'),\n 'value', IFNULL(json_extract(js.\"value\", '$.StringValue'), (json_extract(js.\"value\", '$.IntValue'))),\n 'label', json_extract(js.\"value\", '$.DisplayLabel'),\n 'description', json_extract(js.\"value\", '$.Description')\n )))\n FROM [meta].[ECEnumerationDef] [enumerationDef], json1.json_each([EnumValues]) js\n WHERE [enumerationDef].[ECInstanceId] = [ed].[ECInstanceId]\n )\n ) as [item]\nFROM\n [meta].[ECEnumerationDef] [ed]\n${singleSchema ? `\nJOIN\n [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [ed].[Schema].[Id]\nWHERE [schema].[Name] = :schemaName` : \"\"}\n`;\n\n/**\n * Query for SchemaItemType Unit data.\n * @param singleSchema Indicates if a filter and join for a single Schema should be applied.\n */\nconst unit = (singleSchema?: boolean) => `\nSELECT\n [ud].[Schema].[Id] AS [SchemaId],\n json_object (\n 'schemaItemType', 'Unit',\n 'name', [ud].[Name],\n 'label', [ud].[DisplayLabel],\n 'description', [ud].[Description],\n 'definition', [ud].[Definition],\n 'numerator', IIF([ud].[Numerator] IS NULL, NULL, json(format('%.16g', [ud].[Numerator]))),\n 'denominator', IIF([ud].[Denominator] IS NULL, NULL, json(format('%.16g', [ud].[Denominator]))),\n 'offset', IIF([ud].[Offset] IS NULL, NULL, json(format('%!.15f', [ud].[Offset]))),\n 'unitSystem', CONCAT([uss].[Name],'.', [usd].[Name]),\n 'phenomenon', CONCAT([ps].[Name],'.', [pd].[Name])\n ) as item\nFROM\n [meta].[UnitDef] [ud]\n${singleSchema ? `\nJOIN\n [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [ud].[Schema].[Id]` : \"\"}\nJOIN [meta].[UnitSystemDef] [usd]\n ON [usd].[ECInstanceId] = [ud].[UnitSystem].[Id]\nJOIN [meta].[ECSchemaDef] [uss]\n ON [uss].[ECInstanceId] = [usd].[Schema].[Id]\nJOIN [meta].[PhenomenonDef] [pd]\n ON [pd].[ECInstanceId] = [ud].[Phenomenon].[Id]\nJOIN [meta].[ECSchemaDef] [ps]\n ON [ps].[ECInstanceId] = [pd].[Schema].[Id]\nWHERE\n ${singleSchema ? `\n [schema].[Name] = :schemaName AND` : \"\"}\n [ud].[IsConstant] = 0 AND\n [ud].[InvertingUnit] IS NULL\n`;\n\n/**\n * Query for SchemaItemType InvertedUnit data.\n * @param singleSchema Indicates if a filter and join for a single Schema should be applied.\n */\nconst invertedUnit = (singleSchema?: boolean) => `\nSELECT\n [ud].[Schema].[Id] AS [SchemaId],\n json_object (\n 'schemaItemType', 'InvertedUnit',\n 'name', [ud].[Name],\n 'label', [ud].[DisplayLabel],\n 'description', [ud].[Description],\n 'unitSystem', CONCAT([systemSchema].[Name],'.', [usd].[Name]),\n 'invertsUnit', IIF([iud].[Name] IS NULL, null, CONCAT([ius].[Name],'.', [iud].[Name]))\n ) as [item]\nFROM\n [meta].[UnitDef] [ud]\n${singleSchema ? `\nJOIN\n [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [ud].[Schema].[Id]` : \"\"}\nJOIN [meta].[UnitSystemDef] [usd]\n ON [usd].[ECInstanceId] = [ud].[UnitSystem].[Id]\nJOIN [meta].[ECSchemaDef] [systemSchema]\n ON [systemSchema].[ECInstanceId] = [usd].[Schema].[Id]\nLEFT JOIN [meta].[UnitDef] [iud]\n ON [iud].[ECInstanceId] = [ud].[InvertingUnit].[Id]\nLEFT JOIN [meta].[ECSchemaDef] [ius]\n ON [ius].[ECInstanceId] = [iud].[Schema].[Id]\nWHERE\n ${singleSchema ? `\n [schema].[Name] = :schemaName AND` : \"\"}\n [ud].[IsConstant] = 0 AND\n [ud].[InvertingUnit] IS NOT NULL\n`;\n\n/**\n * Query for SchemaItemType Constant data.\n * @param singleSchema Indicates if a filter and join for a single Schema should be applied.\n */\nconst constant = (singleSchema?: boolean) => `\nSELECT\n [cd].[Schema].[Id] AS [SchemaId],\n json_object(\n 'schemaItemType', 'Constant',\n 'name', [cd].[Name],\n 'label', [cd].[DisplayLabel],\n 'description', [cd].[Description],\n 'definition', [cd].[Definition],\n 'numerator', IIF([cd].[Numerator] IS NULL, NULL, json(format('%.16g', [cd].[Numerator]))),\n 'denominator', IIF([cd].[Denominator] IS NULL, NULL, json(format('%.16g', [cd].[Denominator]))),\n 'phenomenon', CONCAT([phenomSchema].[Name],'.', [phenomDef].[Name])\n ) as item\nFROM\n [meta].[UnitDef] [cd]\n${singleSchema ? `\nJOIN\n [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [cd].[Schema].[Id]` : \"\"}\nJOIN [meta].[PhenomenonDef] [phenomDef]\n ON [phenomDef].[ECInstanceId] = [cd].[Phenomenon].[Id]\nJOIN [meta].[ECSchemaDef] [phenomSchema]\n ON [phenomSchema].[ECInstanceId] = [phenomDef].[Schema].[Id]\nWHERE\n ${singleSchema ? `\n [schema].[Name] = :schemaName AND` : \"\"}\n [cd].[IsConstant] = 1\n`;\n\n/**\n * Query for SchemaItemType UnitSystem data.\n * @param singleSchema Indicates if a filter and join for a single Schema should be applied.\n */\nconst unitSystem = (singleSchema?: boolean) => `\nSELECT\n [us].[Schema].[Id] AS [SchemaId],\n json_object (\n 'schemaItemType', 'UnitSystem',\n 'name', [us].[Name],\n 'label', [us].[DisplayLabel],\n 'description', [us].[Description]\n ) as [item]\nFROM\n [meta].[UnitSystemDef] [us]\n${singleSchema ? `\nJOIN\n [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [us].[Schema].[Id]\nWHERE [schema].[Name] = :schemaName` : \"\"}\n`;\n\n/**\n * Query for SchemaItemType Phenomenon data.\n * @param singleSchema Indicates if a filter and join for a single Schema should be applied.\n */\nconst phenomenon = (singleSchema?: boolean) => `\nSELECT\n [pd].[Schema].[Id] AS [SchemaId],\n json_object(\n 'schemaItemType', 'Phenomenon',\n 'name', [pd].[Name],\n 'label', [pd].[DisplayLabel],\n 'description', [pd].[Description],\n 'definition', [pd].[Definition]\n ) as [item]\nFROM\n [meta].[PhenomenonDef] [pd]\n${singleSchema ? `\nJOIN\n [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [pd].[Schema].[Id]\nWHERE [schema].[Name] = :schemaName` : \"\"}\n`;\n\n/**\n * Query for SchemaItemType Format data.\n * @param singleSchema Indicates if a filter and join for a single Schema should be applied.\n */\nconst format = (singleSchema?: boolean) => `\nSELECT\n [fd].[Schema].[Id] AS [SchemaId],\n json_object(\n 'schemaItemType', 'Format',\n 'name', [fd].[Name],\n 'label', [fd].[DisplayLabel],\n 'description', [fd].[Description],\n 'type', json_extract([fd].[NumericSpec], '$.type'),\n 'precision', json_extract([fd].[NumericSpec], '$.precision'),\n 'roundFactor', json_extract([fd].[NumericSpec], '$.roundFactor'),\n 'minWidth', json_extract([fd].[NumericSpec], '$.minWidth'),\n 'showSignOption', json_extract([fd].[NumericSpec], '$.showSignOption'),\n 'decimalSeparator', json_extract([fd].[NumericSpec], '$.decimalSeparator'),\n 'thousandSeparator', json_extract([fd].[NumericSpec], '$.thousandSeparator'),\n 'uomSeparator', json_extract([fd].[NumericSpec], '$.uomSeparator'),\n 'scientificType', json_extract([fd].[NumericSpec], '$.scientificType'),\n 'stationOffsetSize', json_extract([fd].[NumericSpec], '$.stationOffsetSize'),\n 'stationSeparator', json_extract([fd].[NumericSpec], '$.stationSeparator'),\n 'formatTraits', json_extract([fd].[NumericSpec], '$.formatTraits')\n ${singleSchema ? `\n ,'composite', (\n SELECT\n json_object(\n 'spacer', json_extract([fd1].[CompositeSpec], '$.spacer'),\n 'includeZero', json(IIF(json_extract([fd1].[CompositeSpec], '$.includeZero') = 1, 'true', IIF(json_extract([fd1].[CompositeSpec], '$.includeZero') = 0, 'false', null))),\n 'units', (\n SELECT json_group_array(json(json_object(\n 'name', CONCAT([sd].[Name], '.', [ud].[Name]),\n 'label', [fud].[Label]\n )))\n FROM [meta].[FormatDef] [fd2]\n LEFT JOIN [meta].[FormatCompositeUnitDef] [fud] ON [fud].[Format].[Id] = [fd2].[ECInstanceId]\n LEFT JOIN [meta].[UnitDef] [ud] ON [ud].[ECInstanceId] = [fud].[Unit].[Id]\n INNER JOIN [meta].[ECSchemaDef] [sd] ON [sd].[ECInstanceId] = [ud].[Schema].[Id]\n WHERE [fd2].[ECInstanceId] = [fd1].[ECInstanceId]\n )\n )\n FROM [meta].[FormatDef] [fd1]\n WHERE [fd1].[ECInstanceId]= [fd].[ECInstanceId] AND [fd1].[CompositeSpec] IS NOT NULL\n )` : \"\"}\n) AS item\nFROM\n [meta].[FormatDef] [fd]\n${singleSchema ? `\nJOIN\n [meta].[ECSchemaDef] [schema] ON [schema].[ECInstanceId] = [fd].[Schema].[Id]\nWHERE [schema].[Name] = :schemaName` : \"\"}\n`\n\n/**\n * Queries for each SchemaItemType\n * @internal\n */\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SchemaItemQueries = {\n kindOfQuantity,\n propertyCategory,\n enumeration,\n unit,\n invertedUnit,\n constant,\n unitSystem,\n phenomenon,\n format\n};\n"]}