@loaders.gl/i3s 4.0.0-alpha.5 → 4.0.0-alpha.6

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 (169) hide show
  1. package/dist/arcgis-webscene-loader.d.ts +7 -0
  2. package/dist/arcgis-webscene-loader.d.ts.map +1 -0
  3. package/dist/arcgis-webscene-loader.js +28 -0
  4. package/dist/bundle.js +2 -2
  5. package/dist/dist.min.js +8804 -8547
  6. package/dist/es5/arcgis-webscene-loader.js +40 -0
  7. package/dist/es5/arcgis-webscene-loader.js.map +1 -0
  8. package/dist/es5/bundle.js +6 -0
  9. package/dist/es5/bundle.js.map +1 -0
  10. package/dist/es5/i3s-attribute-loader.js +195 -0
  11. package/dist/es5/i3s-attribute-loader.js.map +1 -0
  12. package/dist/es5/i3s-building-scene-layer-loader.js +46 -0
  13. package/dist/es5/i3s-building-scene-layer-loader.js.map +1 -0
  14. package/dist/es5/i3s-content-loader.js +57 -0
  15. package/dist/es5/i3s-content-loader.js.map +1 -0
  16. package/dist/es5/i3s-loader.js +193 -0
  17. package/dist/es5/i3s-loader.js.map +1 -0
  18. package/dist/es5/i3s-node-page-loader.js +39 -0
  19. package/dist/es5/i3s-node-page-loader.js.map +1 -0
  20. package/dist/es5/index.js +61 -0
  21. package/dist/es5/index.js.map +1 -0
  22. package/dist/es5/lib/helpers/i3s-nodepages-tiles.js +312 -0
  23. package/dist/es5/lib/helpers/i3s-nodepages-tiles.js.map +1 -0
  24. package/dist/es5/lib/parsers/constants.js +72 -0
  25. package/dist/es5/lib/parsers/constants.js.map +1 -0
  26. package/dist/es5/lib/parsers/parse-arcgis-webscene.js +158 -0
  27. package/dist/es5/lib/parsers/parse-arcgis-webscene.js.map +1 -0
  28. package/dist/es5/lib/parsers/parse-i3s-attribute.js +76 -0
  29. package/dist/es5/lib/parsers/parse-i3s-attribute.js.map +1 -0
  30. package/dist/es5/lib/parsers/parse-i3s-building-scene-layer.js +65 -0
  31. package/dist/es5/lib/parsers/parse-i3s-building-scene-layer.js.map +1 -0
  32. package/dist/es5/lib/parsers/parse-i3s-tile-content.js +510 -0
  33. package/dist/es5/lib/parsers/parse-i3s-tile-content.js.map +1 -0
  34. package/dist/es5/lib/parsers/parse-i3s.js +116 -0
  35. package/dist/es5/lib/parsers/parse-i3s.js.map +1 -0
  36. package/dist/es5/lib/utils/convert-i3s-obb-to-mbs.js +17 -0
  37. package/dist/es5/lib/utils/convert-i3s-obb-to-mbs.js.map +1 -0
  38. package/dist/es5/lib/utils/customizeColors.js +159 -0
  39. package/dist/es5/lib/utils/customizeColors.js.map +1 -0
  40. package/dist/es5/lib/utils/url-utils.js +33 -0
  41. package/dist/es5/lib/utils/url-utils.js.map +1 -0
  42. package/dist/es5/types.js +26 -0
  43. package/dist/es5/types.js.map +1 -0
  44. package/dist/es5/workers/i3s-content-nodejs-worker.js +7 -0
  45. package/dist/es5/workers/i3s-content-nodejs-worker.js.map +1 -0
  46. package/dist/es5/workers/i3s-content-worker.js +6 -0
  47. package/dist/es5/workers/i3s-content-worker.js.map +1 -0
  48. package/dist/esm/arcgis-webscene-loader.js +16 -0
  49. package/dist/esm/arcgis-webscene-loader.js.map +1 -0
  50. package/dist/esm/bundle.js +4 -0
  51. package/dist/esm/bundle.js.map +1 -0
  52. package/dist/esm/i3s-attribute-loader.js +119 -0
  53. package/dist/esm/i3s-attribute-loader.js.map +1 -0
  54. package/dist/esm/i3s-building-scene-layer-loader.js +19 -0
  55. package/dist/esm/i3s-building-scene-layer-loader.js.map +1 -0
  56. package/dist/esm/i3s-content-loader.js +31 -0
  57. package/dist/esm/i3s-content-loader.js.map +1 -0
  58. package/dist/esm/i3s-loader.js +87 -0
  59. package/dist/esm/i3s-loader.js.map +1 -0
  60. package/dist/esm/i3s-node-page-loader.js +15 -0
  61. package/dist/esm/i3s-node-page-loader.js.map +1 -0
  62. package/dist/esm/index.js +8 -0
  63. package/dist/esm/index.js.map +1 -0
  64. package/dist/esm/lib/helpers/i3s-nodepages-tiles.js +198 -0
  65. package/dist/esm/lib/helpers/i3s-nodepages-tiles.js.map +1 -0
  66. package/dist/esm/lib/parsers/constants.js +57 -0
  67. package/dist/esm/lib/parsers/constants.js.map +1 -0
  68. package/dist/esm/lib/parsers/parse-arcgis-webscene.js +70 -0
  69. package/dist/esm/lib/parsers/parse-arcgis-webscene.js.map +1 -0
  70. package/dist/esm/lib/parsers/parse-i3s-attribute.js +60 -0
  71. package/dist/esm/lib/parsers/parse-i3s-attribute.js.map +1 -0
  72. package/dist/esm/lib/parsers/parse-i3s-building-scene-layer.js +39 -0
  73. package/dist/esm/lib/parsers/parse-i3s-building-scene-layer.js.map +1 -0
  74. package/dist/esm/lib/parsers/parse-i3s-tile-content.js +435 -0
  75. package/dist/esm/lib/parsers/parse-i3s-tile-content.js.map +1 -0
  76. package/dist/esm/lib/parsers/parse-i3s.js +83 -0
  77. package/dist/esm/lib/parsers/parse-i3s.js.map +1 -0
  78. package/dist/esm/lib/utils/convert-i3s-obb-to-mbs.js +9 -0
  79. package/dist/esm/lib/utils/convert-i3s-obb-to-mbs.js.map +1 -0
  80. package/dist/esm/lib/utils/customizeColors.js +92 -0
  81. package/dist/esm/lib/utils/customizeColors.js.map +1 -0
  82. package/dist/esm/lib/utils/url-utils.js +28 -0
  83. package/dist/esm/lib/utils/url-utils.js.map +1 -0
  84. package/dist/esm/types.js +18 -0
  85. package/dist/esm/types.js.map +1 -0
  86. package/dist/esm/workers/i3s-content-nodejs-worker.js +5 -0
  87. package/dist/esm/workers/i3s-content-nodejs-worker.js.map +1 -0
  88. package/dist/esm/workers/i3s-content-worker.js +4 -0
  89. package/dist/esm/workers/i3s-content-worker.js.map +1 -0
  90. package/dist/i3s-attribute-loader.d.ts +9 -2
  91. package/dist/i3s-attribute-loader.d.ts.map +1 -1
  92. package/dist/i3s-attribute-loader.js +155 -132
  93. package/dist/i3s-building-scene-layer-loader.js +23 -18
  94. package/dist/i3s-content-loader.d.ts.map +1 -1
  95. package/dist/i3s-content-loader.js +30 -22
  96. package/dist/i3s-content-nodejs-worker.js +198 -0
  97. package/dist/i3s-content-nodejs-worker.js.map +7 -0
  98. package/dist/i3s-content-worker.js +1119 -1100
  99. package/dist/i3s-loader.d.ts +5 -0
  100. package/dist/i3s-loader.d.ts.map +1 -1
  101. package/dist/i3s-loader.js +88 -83
  102. package/dist/i3s-node-page-loader.d.ts +3 -2
  103. package/dist/i3s-node-page-loader.d.ts.map +1 -1
  104. package/dist/i3s-node-page-loader.js +20 -20
  105. package/dist/index.d.ts +4 -2
  106. package/dist/index.d.ts.map +1 -1
  107. package/dist/index.js +19 -6
  108. package/dist/lib/helpers/i3s-nodepages-tiles.d.ts +1 -0
  109. package/dist/lib/helpers/i3s-nodepages-tiles.d.ts.map +1 -1
  110. package/dist/lib/helpers/i3s-nodepages-tiles.js +231 -228
  111. package/dist/lib/parsers/constants.js +85 -63
  112. package/dist/lib/parsers/parse-arcgis-webscene.d.ts +7 -0
  113. package/dist/lib/parsers/parse-arcgis-webscene.d.ts.map +1 -0
  114. package/dist/lib/parsers/parse-arcgis-webscene.js +88 -0
  115. package/dist/lib/parsers/parse-i3s-attribute.d.ts +6 -4
  116. package/dist/lib/parsers/parse-i3s-attribute.d.ts.map +1 -1
  117. package/dist/lib/parsers/parse-i3s-attribute.js +87 -62
  118. package/dist/lib/parsers/parse-i3s-building-scene-layer.js +41 -40
  119. package/dist/lib/parsers/parse-i3s-tile-content.d.ts +2 -2
  120. package/dist/lib/parsers/parse-i3s-tile-content.d.ts.map +1 -1
  121. package/dist/lib/parsers/parse-i3s-tile-content.js +454 -454
  122. package/dist/lib/parsers/parse-i3s.d.ts +1 -1
  123. package/dist/lib/parsers/parse-i3s.d.ts.map +1 -1
  124. package/dist/lib/parsers/parse-i3s.js +92 -88
  125. package/dist/lib/utils/convert-i3s-obb-to-mbs.js +19 -8
  126. package/dist/lib/utils/customizeColors.d.ts +14 -0
  127. package/dist/lib/utils/customizeColors.d.ts.map +1 -0
  128. package/dist/lib/utils/customizeColors.js +94 -0
  129. package/dist/lib/utils/url-utils.js +41 -28
  130. package/dist/types.d.ts +518 -97
  131. package/dist/types.d.ts.map +1 -1
  132. package/dist/types.js +18 -19
  133. package/dist/workers/i3s-content-nodejs-worker.d.ts +2 -0
  134. package/dist/workers/i3s-content-nodejs-worker.d.ts.map +1 -0
  135. package/dist/workers/i3s-content-nodejs-worker.js +6 -0
  136. package/dist/workers/i3s-content-worker.js +5 -4
  137. package/package.json +15 -15
  138. package/src/arcgis-webscene-loader.ts +31 -0
  139. package/src/i3s-attribute-loader.ts +9 -9
  140. package/src/i3s-content-loader.ts +19 -6
  141. package/src/i3s-loader.ts +22 -13
  142. package/src/i3s-node-page-loader.ts +6 -10
  143. package/src/index.ts +22 -5
  144. package/src/lib/helpers/i3s-nodepages-tiles.ts +14 -3
  145. package/src/lib/parsers/constants.ts +1 -1
  146. package/src/lib/parsers/parse-arcgis-webscene.ts +102 -0
  147. package/src/lib/parsers/parse-i3s-attribute.ts +21 -14
  148. package/src/lib/parsers/parse-i3s-tile-content.ts +99 -76
  149. package/src/lib/parsers/parse-i3s.ts +8 -3
  150. package/src/lib/utils/customizeColors.ts +134 -0
  151. package/src/types.ts +482 -33
  152. package/src/workers/i3s-content-nodejs-worker.ts +5 -0
  153. package/dist/bundle.js.map +0 -1
  154. package/dist/i3s-attribute-loader.js.map +0 -1
  155. package/dist/i3s-building-scene-layer-loader.js.map +0 -1
  156. package/dist/i3s-content-loader.js.map +0 -1
  157. package/dist/i3s-loader.js.map +0 -1
  158. package/dist/i3s-node-page-loader.js.map +0 -1
  159. package/dist/index.js.map +0 -1
  160. package/dist/lib/helpers/i3s-nodepages-tiles.js.map +0 -1
  161. package/dist/lib/parsers/constants.js.map +0 -1
  162. package/dist/lib/parsers/parse-i3s-attribute.js.map +0 -1
  163. package/dist/lib/parsers/parse-i3s-building-scene-layer.js.map +0 -1
  164. package/dist/lib/parsers/parse-i3s-tile-content.js.map +0 -1
  165. package/dist/lib/parsers/parse-i3s.js.map +0 -1
  166. package/dist/lib/utils/convert-i3s-obb-to-mbs.js.map +0 -1
  167. package/dist/lib/utils/url-utils.js.map +0 -1
  168. package/dist/types.js.map +0 -1
  169. package/dist/workers/i3s-content-worker.js.map +0 -1
@@ -0,0 +1,119 @@
1
+ import { load } from '@loaders.gl/core';
2
+ import { parseI3STileAttribute } from './lib/parsers/parse-i3s-attribute';
3
+ import { getUrlWithToken } from './lib/utils/url-utils';
4
+ const VERSION = typeof "4.0.0-alpha.6" !== 'undefined' ? "4.0.0-alpha.6" : 'latest';
5
+ const EMPTY_VALUE = '';
6
+ const REJECTED_STATUS = 'rejected';
7
+ export const I3SAttributeLoader = {
8
+ name: 'I3S Attribute',
9
+ id: 'i3s-attribute',
10
+ module: 'i3s',
11
+ version: VERSION,
12
+ mimeTypes: ['application/binary'],
13
+ parse: async (arrayBuffer, options) => parseI3STileAttribute(arrayBuffer, options),
14
+ extensions: ['bin'],
15
+ options: {},
16
+ binary: true
17
+ };
18
+ export async function loadFeatureAttributes(tile, featureId) {
19
+ let options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
20
+ const {
21
+ attributeStorageInfo,
22
+ attributeUrls,
23
+ tilesetFields
24
+ } = getAttributesData(tile);
25
+ if (!attributeStorageInfo || !attributeUrls || featureId < 0) {
26
+ return null;
27
+ }
28
+ let attributes = [];
29
+ const attributeLoadPromises = [];
30
+ for (let index = 0; index < attributeStorageInfo.length; index++) {
31
+ var _options$i3s;
32
+ const url = getUrlWithToken(attributeUrls[index], (_options$i3s = options.i3s) === null || _options$i3s === void 0 ? void 0 : _options$i3s.token);
33
+ const attributeName = attributeStorageInfo[index].name;
34
+ const attributeType = getAttributeValueType(attributeStorageInfo[index]);
35
+ const loadOptions = {
36
+ ...options,
37
+ attributeName,
38
+ attributeType
39
+ };
40
+ const promise = load(url, I3SAttributeLoader, loadOptions);
41
+ attributeLoadPromises.push(promise);
42
+ }
43
+ try {
44
+ attributes = await Promise.allSettled(attributeLoadPromises);
45
+ } catch (error) {}
46
+ if (!attributes.length) {
47
+ return null;
48
+ }
49
+ return generateAttributesByFeatureId(attributes, attributeStorageInfo, featureId, tilesetFields);
50
+ }
51
+ function getAttributesData(tile) {
52
+ var _tile$tileset, _tile$tileset$tileset, _tile$header, _tile$tileset2, _tile$tileset2$tilese;
53
+ const attributeStorageInfo = (_tile$tileset = tile.tileset) === null || _tile$tileset === void 0 ? void 0 : (_tile$tileset$tileset = _tile$tileset.tileset) === null || _tile$tileset$tileset === void 0 ? void 0 : _tile$tileset$tileset.attributeStorageInfo;
54
+ const attributeUrls = (_tile$header = tile.header) === null || _tile$header === void 0 ? void 0 : _tile$header.attributeUrls;
55
+ const tilesetFields = ((_tile$tileset2 = tile.tileset) === null || _tile$tileset2 === void 0 ? void 0 : (_tile$tileset2$tilese = _tile$tileset2.tileset) === null || _tile$tileset2$tilese === void 0 ? void 0 : _tile$tileset2$tilese.fields) || [];
56
+ return {
57
+ attributeStorageInfo,
58
+ attributeUrls,
59
+ tilesetFields
60
+ };
61
+ }
62
+ export function getAttributeValueType(attribute) {
63
+ if (attribute.hasOwnProperty('objectIds')) {
64
+ return 'Oid32';
65
+ } else if (attribute.hasOwnProperty('attributeValues')) {
66
+ return attribute.attributeValues.valueType;
67
+ }
68
+ return '';
69
+ }
70
+ function getFeatureIdsAttributeName(attributeStorageInfo) {
71
+ const objectIdsAttribute = attributeStorageInfo.find(attribute => attribute.name.includes('OBJECTID'));
72
+ return objectIdsAttribute === null || objectIdsAttribute === void 0 ? void 0 : objectIdsAttribute.name;
73
+ }
74
+ function generateAttributesByFeatureId(attributes, attributeStorageInfo, featureId, tilesetFields) {
75
+ const objectIdsAttributeName = getFeatureIdsAttributeName(attributeStorageInfo);
76
+ const objectIds = attributes.find(attribute => attribute.value[objectIdsAttributeName]);
77
+ if (!objectIds) {
78
+ return null;
79
+ }
80
+ const attributeIndex = objectIds.value[objectIdsAttributeName].indexOf(featureId);
81
+ if (attributeIndex < 0) {
82
+ return null;
83
+ }
84
+ return getFeatureAttributesByIndex(attributes, attributeIndex, attributeStorageInfo, tilesetFields);
85
+ }
86
+ function getFeatureAttributesByIndex(attributes, featureIdIndex, attributeStorageInfo, tilesetFields) {
87
+ const attributesObject = {};
88
+ for (let index = 0; index < attributeStorageInfo.length; index++) {
89
+ const attributeName = attributeStorageInfo[index].name;
90
+ const codedValues = getAttributeCodedValues(attributeName, tilesetFields);
91
+ const attribute = getAttributeByIndexAndAttributeName(attributes, index, attributeName);
92
+ attributesObject[attributeName] = formatAttributeValue(attribute, featureIdIndex, codedValues);
93
+ }
94
+ return attributesObject;
95
+ }
96
+ function getAttributeCodedValues(attributeName, tilesetFields) {
97
+ var _attributeField$domai;
98
+ const attributeField = tilesetFields.find(field => field.name === attributeName || field.alias === attributeName);
99
+ return (attributeField === null || attributeField === void 0 ? void 0 : (_attributeField$domai = attributeField.domain) === null || _attributeField$domai === void 0 ? void 0 : _attributeField$domai.codedValues) || [];
100
+ }
101
+ function getAttributeByIndexAndAttributeName(attributes, index, attributesName) {
102
+ const attributeObject = attributes[index];
103
+ if (attributeObject.status === REJECTED_STATUS) {
104
+ return null;
105
+ }
106
+ return attributeObject.value[attributesName];
107
+ }
108
+ function formatAttributeValue(attribute, featureIdIndex, codedValues) {
109
+ let value = EMPTY_VALUE;
110
+ if (attribute && featureIdIndex in attribute) {
111
+ value = String(attribute[featureIdIndex]).replace(/\u0000|NaN/g, '').trim();
112
+ }
113
+ if (codedValues.length) {
114
+ const codeValue = codedValues.find(codedValue => codedValue.code === Number(value));
115
+ value = (codeValue === null || codeValue === void 0 ? void 0 : codeValue.name) || EMPTY_VALUE;
116
+ }
117
+ return value;
118
+ }
119
+ //# sourceMappingURL=i3s-attribute-loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"i3s-attribute-loader.js","names":["load","parseI3STileAttribute","getUrlWithToken","VERSION","EMPTY_VALUE","REJECTED_STATUS","I3SAttributeLoader","name","id","module","version","mimeTypes","parse","arrayBuffer","options","extensions","binary","loadFeatureAttributes","tile","featureId","arguments","length","undefined","attributeStorageInfo","attributeUrls","tilesetFields","getAttributesData","attributes","attributeLoadPromises","index","_options$i3s","url","i3s","token","attributeName","attributeType","getAttributeValueType","loadOptions","promise","push","Promise","allSettled","error","generateAttributesByFeatureId","_tile$tileset","_tile$tileset$tileset","_tile$header","_tile$tileset2","_tile$tileset2$tilese","tileset","header","fields","attribute","hasOwnProperty","attributeValues","valueType","getFeatureIdsAttributeName","objectIdsAttribute","find","includes","objectIdsAttributeName","objectIds","value","attributeIndex","indexOf","getFeatureAttributesByIndex","featureIdIndex","attributesObject","codedValues","getAttributeCodedValues","getAttributeByIndexAndAttributeName","formatAttributeValue","_attributeField$domai","attributeField","field","alias","domain","attributesName","attributeObject","status","String","replace","trim","codeValue","codedValue","code","Number"],"sources":["../../src/i3s-attribute-loader.ts"],"sourcesContent":["import type {LoaderOptions, LoaderWithParser} from '@loaders.gl/loader-utils';\nimport {load} from '@loaders.gl/core';\nimport type {I3STileAttributes} from './lib/parsers/parse-i3s-attribute';\nimport {parseI3STileAttribute} from './lib/parsers/parse-i3s-attribute';\nimport {getUrlWithToken} from './lib/utils/url-utils';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\nconst EMPTY_VALUE = '';\nconst REJECTED_STATUS = 'rejected';\n\n/**\n * Loader for I3S attributes\n */\nexport const I3SAttributeLoader: LoaderWithParser<I3STileAttributes, never, LoaderOptions> = {\n name: 'I3S Attribute',\n id: 'i3s-attribute',\n module: 'i3s',\n version: VERSION,\n mimeTypes: ['application/binary'],\n parse: async (arrayBuffer: ArrayBuffer, options?: LoaderOptions) => parseI3STileAttribute(arrayBuffer, options),\n extensions: ['bin'],\n options: {},\n binary: true\n};\n\n\n// TODO - these seem to use the loader rather than being part of the loader. Move to different file...\n\n/**\n * Load attributes based on feature id\n * @param {Object} tile\n * @param {number} featureId\n * @param {Object} options\n * @returns {Promise}\n */\n// eslint-disable-next-line complexity\nexport async function loadFeatureAttributes(tile, featureId, options = {}) {\n const {attributeStorageInfo, attributeUrls, tilesetFields} = getAttributesData(tile);\n\n if (!attributeStorageInfo || !attributeUrls || featureId < 0) {\n return null;\n }\n\n let attributes: object[] = [];\n const attributeLoadPromises: Promise<object>[] = [];\n\n for (let index = 0; index < attributeStorageInfo.length; index++) {\n // @ts-ignore\n const url = getUrlWithToken(attributeUrls[index], options.i3s?.token);\n const attributeName = attributeStorageInfo[index].name;\n const attributeType = getAttributeValueType(attributeStorageInfo[index]);\n const loadOptions = {...options, attributeName, attributeType};\n const promise = load(url, I3SAttributeLoader, loadOptions);\n\n attributeLoadPromises.push(promise);\n }\n try {\n attributes = await Promise.allSettled(attributeLoadPromises);\n } catch (error) {\n // do nothing\n }\n\n if (!attributes.length) {\n return null;\n }\n\n return generateAttributesByFeatureId(attributes, attributeStorageInfo, featureId, tilesetFields);\n}\n\n/**\n * Gets attributes data from tile.\n * @param tile \n * @returns \n */\nfunction getAttributesData(tile) {\n const attributeStorageInfo = tile.tileset?.tileset?.attributeStorageInfo;\n const attributeUrls = tile.header?.attributeUrls;\n const tilesetFields = tile.tileset?.tileset?.fields || [];\n\n return {attributeStorageInfo, attributeUrls, tilesetFields};\n}\n\n/**\n * Get attribute value type based on property names\n * @param {Object} attribute\n * @returns {String}\n */\nexport function getAttributeValueType(attribute) {\n if (attribute.hasOwnProperty('objectIds')) {\n return 'Oid32';\n } else if (attribute.hasOwnProperty('attributeValues')) {\n return attribute.attributeValues.valueType;\n }\n return '';\n}\n\n/**\n * Find in attributeStorageInfo attribute name responsible for feature ids list.\n * @param attributeStorageInfo \n * @returns Feature ids attribute name\n */\nfunction getFeatureIdsAttributeName(attributeStorageInfo) {\n const objectIdsAttribute = attributeStorageInfo.find(attribute => attribute.name.includes('OBJECTID'));\n\n return objectIdsAttribute?.name;\n}\n\n/**\n * Generates mapping featureId to feature attributes\n * @param {Array} attributes\n * @param {Object} attributeStorageInfo\n * @param {number} featureId\n * @returns {Object}\n */\nfunction generateAttributesByFeatureId(attributes, attributeStorageInfo, featureId, tilesetFields) {\n const objectIdsAttributeName = getFeatureIdsAttributeName(attributeStorageInfo);\n const objectIds = attributes.find((attribute) => attribute.value[objectIdsAttributeName]);\n\n if (!objectIds) {\n return null;\n }\n\n const attributeIndex = objectIds.value[objectIdsAttributeName].indexOf(featureId);\n\n if (attributeIndex < 0) {\n return null;\n }\n\n return getFeatureAttributesByIndex(attributes, attributeIndex, attributeStorageInfo, tilesetFields);\n}\n\n/**\n * Generates attribute object for feature mapping by feature id\n * @param {Array} attributes\n * @param {Number} featureIdIndex\n * @param {Object} attributeStorageInfo\n * @returns {Object}\n */\nfunction getFeatureAttributesByIndex(attributes, featureIdIndex, attributeStorageInfo, tilesetFields) {\n const attributesObject = {};\n\n for (let index = 0; index < attributeStorageInfo.length; index++) {\n const attributeName = attributeStorageInfo[index].name;\n const codedValues = getAttributeCodedValues(attributeName, tilesetFields);\n const attribute = getAttributeByIndexAndAttributeName(attributes, index, attributeName);\n attributesObject[attributeName] = formatAttributeValue(attribute, featureIdIndex, codedValues);\n }\n\n return attributesObject;\n}\n\n/**\n * Get coded values list from tileset.\n * @param attributeName \n * @param tilesetFields \n */\nfunction getAttributeCodedValues(attributeName, tilesetFields) {\n const attributeField = tilesetFields\n .find(field => field.name === attributeName || field.alias === attributeName);\n\n return attributeField?.domain?.codedValues || [];\n}\n\n/**\n * Return attribute value if it presents in atrributes list\n * @param {array} attributes\n * @param {number} index\n * @param {string} attributesName\n */\nfunction getAttributeByIndexAndAttributeName(attributes, index, attributesName) {\n const attributeObject = attributes[index];\n\n if (attributeObject.status === REJECTED_STATUS) {\n return null;\n }\n\n return attributeObject.value[attributesName];\n}\n\n/**\n * Do formatting of attribute values or return empty string.\n * @param {Array} attribute\n * @param {Number} featureIdIndex\n * @returns {String}\n */\nfunction formatAttributeValue(attribute, featureIdIndex, codedValues) {\n let value = EMPTY_VALUE;\n\n if (attribute && (featureIdIndex in attribute)) {\n // eslint-disable-next-line no-control-regex\n value = String(attribute[featureIdIndex]).replace(/\\u0000|NaN/g, '').trim();\n }\n\n // Check if coded values are existed. If so we use them.\n if (codedValues.length) {\n const codeValue = codedValues.find(codedValue => codedValue.code === Number(value));\n value = codeValue?.name || EMPTY_VALUE;\n }\n\n return value;\n}\n"],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ import { parseBuildingSceneLayer } from './lib/parsers/parse-i3s-building-scene-layer';
2
+ const VERSION = typeof "4.0.0-alpha.6" !== 'undefined' ? "4.0.0-alpha.6" : 'beta';
3
+ export const I3SBuildingSceneLayerLoader = {
4
+ name: 'I3S Building Scene Layer',
5
+ id: 'i3s-building-scene-layer',
6
+ module: 'i3s',
7
+ version: VERSION,
8
+ mimeTypes: ['application/json'],
9
+ parse,
10
+ extensions: ['json'],
11
+ options: {}
12
+ };
13
+ async function parse(data, options, context) {
14
+ if (!(context !== null && context !== void 0 && context.url)) {
15
+ throw new Error('Url is not provided');
16
+ }
17
+ return parseBuildingSceneLayer(data, context.url);
18
+ }
19
+ //# sourceMappingURL=i3s-building-scene-layer-loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"i3s-building-scene-layer-loader.js","names":["parseBuildingSceneLayer","VERSION","I3SBuildingSceneLayerLoader","name","id","module","version","mimeTypes","parse","extensions","options","data","context","url","Error"],"sources":["../../src/i3s-building-scene-layer-loader.ts"],"sourcesContent":["import type {LoaderWithParser, LoaderOptions, LoaderContext} from '@loaders.gl/loader-utils';\nimport type {BuildingSceneLayerTileset} from './types';\n\nimport {parseBuildingSceneLayer} from './lib/parsers/parse-i3s-building-scene-layer';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\n\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'beta';\n/**\n * Loader for I3S - Building Scene Layer\n */\nexport const I3SBuildingSceneLayerLoader: LoaderWithParser = {\n name: 'I3S Building Scene Layer',\n id: 'i3s-building-scene-layer',\n module: 'i3s',\n version: VERSION,\n mimeTypes: ['application/json'],\n parse,\n extensions: ['json'],\n options: {}\n};\n\nasync function parse(\n data: ArrayBuffer,\n options?: LoaderOptions,\n context?: LoaderContext\n): Promise<BuildingSceneLayerTileset> {\n if (!context?.url) {\n throw new Error('Url is not provided');\n }\n\n return parseBuildingSceneLayer(data, context.url);\n}\n"],"mappings":"AAGA,SAAQA,uBAAuB,QAAO,8CAA8C;AAKpF,MAAMC,OAAO,GAAG,sBAAkB,KAAK,WAAW,qBAAiB,MAAM;AAIzE,OAAO,MAAMC,2BAA6C,GAAG;EAC3DC,IAAI,EAAE,0BAA0B;EAChCC,EAAE,EAAE,0BAA0B;EAC9BC,MAAM,EAAE,KAAK;EACbC,OAAO,EAAEL,OAAO;EAChBM,SAAS,EAAE,CAAC,kBAAkB,CAAC;EAC/BC,KAAK;EACLC,UAAU,EAAE,CAAC,MAAM,CAAC;EACpBC,OAAO,EAAE,CAAC;AACZ,CAAC;AAED,eAAeF,KAAKA,CAClBG,IAAiB,EACjBD,OAAuB,EACvBE,OAAuB,EACa;EACpC,IAAI,EAACA,OAAO,aAAPA,OAAO,eAAPA,OAAO,CAAEC,GAAG,GAAE;IACjB,MAAM,IAAIC,KAAK,CAAC,qBAAqB,CAAC;EACxC;EAEA,OAAOd,uBAAuB,CAACW,IAAI,EAAEC,OAAO,CAACC,GAAG,CAAC;AACnD"}
@@ -0,0 +1,31 @@
1
+ import { isBrowser } from '@loaders.gl/worker-utils';
2
+ import { parseI3STileContent } from './lib/parsers/parse-i3s-tile-content';
3
+ const VERSION = typeof "4.0.0-alpha.6" !== 'undefined' ? "4.0.0-alpha.6" : 'beta';
4
+ export const I3SContentLoader = {
5
+ name: 'I3S Content (Indexed Scene Layers)',
6
+ id: isBrowser ? 'i3s-content' : 'i3s-content-nodejs',
7
+ module: 'i3s',
8
+ worker: true,
9
+ version: VERSION,
10
+ mimeTypes: ['application/octet-stream'],
11
+ parse,
12
+ extensions: ['bin'],
13
+ options: {
14
+ 'i3s-content': {}
15
+ }
16
+ };
17
+ async function parse(data, options, context) {
18
+ const {
19
+ tile,
20
+ _tileOptions,
21
+ tileset,
22
+ _tilesetOptions
23
+ } = (options === null || options === void 0 ? void 0 : options.i3s) || {};
24
+ const tileOptions = _tileOptions || tile;
25
+ const tilesetOptions = _tilesetOptions || tileset;
26
+ if (!tileOptions || !tilesetOptions) {
27
+ return null;
28
+ }
29
+ return await parseI3STileContent(data, tileOptions, tilesetOptions, options, context);
30
+ }
31
+ //# sourceMappingURL=i3s-content-loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"i3s-content-loader.js","names":["isBrowser","parseI3STileContent","VERSION","I3SContentLoader","name","id","module","worker","version","mimeTypes","parse","extensions","options","data","context","tile","_tileOptions","tileset","_tilesetOptions","i3s","tileOptions","tilesetOptions"],"sources":["../../src/i3s-content-loader.ts"],"sourcesContent":["import {isBrowser} from '@loaders.gl/worker-utils';\nimport type {LoaderWithParser, LoaderContext} from '@loaders.gl/loader-utils';\nimport type {I3SLoaderOptions} from './i3s-loader';\nimport {parseI3STileContent} from './lib/parsers/parse-i3s-tile-content';\nimport {I3STileOptions, I3STilesetOptions} from './types';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\n\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'beta';\n/**\n * Loader for I3S - Indexed 3D Scene Layer\n */\nexport const I3SContentLoader: LoaderWithParser = {\n name: 'I3S Content (Indexed Scene Layers)',\n id: isBrowser ? 'i3s-content' : 'i3s-content-nodejs',\n module: 'i3s',\n worker: true,\n version: VERSION,\n mimeTypes: ['application/octet-stream'],\n parse,\n extensions: ['bin'],\n options: {\n 'i3s-content': {}\n }\n};\n\nasync function parse(data, options?: I3SLoaderOptions, context?: LoaderContext) {\n const {tile, _tileOptions, tileset, _tilesetOptions} = options?.i3s || {};\n const tileOptions = _tileOptions || tile;\n const tilesetOptions = _tilesetOptions || tileset;\n if (!tileOptions || !tilesetOptions) {\n return null;\n }\n return await parseI3STileContent(\n data,\n tileOptions as I3STileOptions,\n tilesetOptions as I3STilesetOptions,\n options,\n context\n );\n}\n"],"mappings":"AAAA,SAAQA,SAAS,QAAO,0BAA0B;AAGlD,SAAQC,mBAAmB,QAAO,sCAAsC;AAMxE,MAAMC,OAAO,GAAG,sBAAkB,KAAK,WAAW,qBAAiB,MAAM;AAIzE,OAAO,MAAMC,gBAAkC,GAAG;EAChDC,IAAI,EAAE,oCAAoC;EAC1CC,EAAE,EAAEL,SAAS,GAAG,aAAa,GAAG,oBAAoB;EACpDM,MAAM,EAAE,KAAK;EACbC,MAAM,EAAE,IAAI;EACZC,OAAO,EAAEN,OAAO;EAChBO,SAAS,EAAE,CAAC,0BAA0B,CAAC;EACvCC,KAAK;EACLC,UAAU,EAAE,CAAC,KAAK,CAAC;EACnBC,OAAO,EAAE;IACP,aAAa,EAAE,CAAC;EAClB;AACF,CAAC;AAED,eAAeF,KAAKA,CAACG,IAAI,EAAED,OAA0B,EAAEE,OAAuB,EAAE;EAC9E,MAAM;IAACC,IAAI;IAAEC,YAAY;IAAEC,OAAO;IAAEC;EAAe,CAAC,GAAG,CAAAN,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEO,GAAG,KAAI,CAAC,CAAC;EACzE,MAAMC,WAAW,GAAGJ,YAAY,IAAID,IAAI;EACxC,MAAMM,cAAc,GAAGH,eAAe,IAAID,OAAO;EACjD,IAAI,CAACG,WAAW,IAAI,CAACC,cAAc,EAAE;IACnC,OAAO,IAAI;EACb;EACA,OAAO,MAAMpB,mBAAmB,CAC9BY,IAAI,EACJO,WAAW,EACXC,cAAc,EACdT,OAAO,EACPE,OACF,CAAC;AACH"}
@@ -0,0 +1,87 @@
1
+ import { parse } from '@loaders.gl/core';
2
+ import { I3SContentLoader } from './i3s-content-loader';
3
+ import { normalizeTileData, normalizeTilesetData } from './lib/parsers/parse-i3s';
4
+ import { COORDINATE_SYSTEM } from './lib/parsers/constants';
5
+ const VERSION = typeof "4.0.0-alpha.6" !== 'undefined' ? "4.0.0-alpha.6" : 'latest';
6
+ const TILESET_REGEX = /layers\/[0-9]+$/;
7
+ const TILE_HEADER_REGEX = /nodes\/([0-9-]+|root)$/;
8
+ const SLPK_HEX = '504b0304';
9
+ const POINT_CLOUD = 'PointCloud';
10
+ export const I3SLoader = {
11
+ name: 'I3S (Indexed Scene Layers)',
12
+ id: 'i3s',
13
+ module: 'i3s',
14
+ version: VERSION,
15
+ mimeTypes: ['application/octet-stream'],
16
+ parse: parseI3S,
17
+ extensions: ['bin'],
18
+ options: {
19
+ i3s: {
20
+ token: null,
21
+ isTileset: 'auto',
22
+ isTileHeader: 'auto',
23
+ tile: null,
24
+ tileset: null,
25
+ _tileOptions: null,
26
+ _tilesetOptions: null,
27
+ useDracoGeometry: true,
28
+ useCompressedTextures: true,
29
+ decodeTextures: true,
30
+ coordinateSystem: COORDINATE_SYSTEM.METER_OFFSETS,
31
+ colorsByAttribute: null
32
+ }
33
+ }
34
+ };
35
+ async function parseI3S(data) {
36
+ let options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
37
+ let context = arguments.length > 2 ? arguments[2] : undefined;
38
+ const url = context.url;
39
+ options.i3s = options.i3s || {};
40
+ const magicNumber = getMagicNumber(data);
41
+ if (magicNumber === SLPK_HEX) {
42
+ throw new Error('Files with .slpk extention currently are not supported by I3SLoader');
43
+ }
44
+ let isTileset;
45
+ if (options.i3s.isTileset === 'auto') {
46
+ isTileset = TILESET_REGEX.test(url);
47
+ } else {
48
+ isTileset = options.i3s.isTileset;
49
+ }
50
+ let isTileHeader;
51
+ if (options.isTileHeader === 'auto') {
52
+ isTileHeader = TILE_HEADER_REGEX.test(url);
53
+ } else {
54
+ isTileHeader = options.i3s.isTileHeader;
55
+ }
56
+ if (isTileset) {
57
+ data = await parseTileset(data, options, context);
58
+ } else if (isTileHeader) {
59
+ data = await parseTile(data, context);
60
+ } else {
61
+ data = await parseTileContent(data, options);
62
+ }
63
+ return data;
64
+ }
65
+ async function parseTileContent(arrayBuffer, options) {
66
+ return await parse(arrayBuffer, I3SContentLoader, options);
67
+ }
68
+ async function parseTileset(data, options, context) {
69
+ const tilesetJson = JSON.parse(new TextDecoder().decode(data));
70
+ if ((tilesetJson === null || tilesetJson === void 0 ? void 0 : tilesetJson.layerType) === POINT_CLOUD) {
71
+ throw new Error('Point Cloud layers currently are not supported by I3SLoader');
72
+ }
73
+ tilesetJson.loader = I3SLoader;
74
+ await normalizeTilesetData(tilesetJson, options, context);
75
+ return tilesetJson;
76
+ }
77
+ async function parseTile(data, context) {
78
+ data = JSON.parse(new TextDecoder().decode(data));
79
+ return normalizeTileData(data, context);
80
+ }
81
+ function getMagicNumber(data) {
82
+ if (data instanceof ArrayBuffer) {
83
+ return [...new Uint8Array(data, 0, 4)].map(value => value.toString(16).padStart(2, '0')).join('');
84
+ }
85
+ return null;
86
+ }
87
+ //# sourceMappingURL=i3s-loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"i3s-loader.js","names":["parse","I3SContentLoader","normalizeTileData","normalizeTilesetData","COORDINATE_SYSTEM","VERSION","TILESET_REGEX","TILE_HEADER_REGEX","SLPK_HEX","POINT_CLOUD","I3SLoader","name","id","module","version","mimeTypes","parseI3S","extensions","options","i3s","token","isTileset","isTileHeader","tile","tileset","_tileOptions","_tilesetOptions","useDracoGeometry","useCompressedTextures","decodeTextures","coordinateSystem","METER_OFFSETS","colorsByAttribute","data","arguments","length","undefined","context","url","magicNumber","getMagicNumber","Error","test","parseTileset","parseTile","parseTileContent","arrayBuffer","tilesetJson","JSON","TextDecoder","decode","layerType","loader","ArrayBuffer","Uint8Array","map","value","toString","padStart","join"],"sources":["../../src/i3s-loader.ts"],"sourcesContent":["import type {LoaderWithParser} from '@loaders.gl/loader-utils';\nimport {parse} from '@loaders.gl/core';\nimport {I3SContentLoader} from './i3s-content-loader';\nimport {normalizeTileData, normalizeTilesetData} from './lib/parsers/parse-i3s';\nimport {COORDINATE_SYSTEM} from './lib/parsers/constants';\nimport {I3SParseOptions} from './types';\nimport {LoaderOptions} from './../../loader-utils/src/types';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nconst TILESET_REGEX = /layers\\/[0-9]+$/;\nconst TILE_HEADER_REGEX = /nodes\\/([0-9-]+|root)$/;\nconst SLPK_HEX = '504b0304';\nconst POINT_CLOUD = 'PointCloud';\n\nexport type I3SLoaderOptions = LoaderOptions & {\n i3s?: I3SParseOptions;\n};\n\n/**\n * Loader for I3S - Indexed 3D Scene Layer\n */\nexport const I3SLoader: LoaderWithParser = {\n name: 'I3S (Indexed Scene Layers)',\n id: 'i3s',\n module: 'i3s',\n version: VERSION,\n mimeTypes: ['application/octet-stream'],\n parse: parseI3S,\n extensions: ['bin'],\n options: {\n i3s: {\n token: null,\n isTileset: 'auto',\n isTileHeader: 'auto',\n tile: null,\n tileset: null,\n _tileOptions: null,\n _tilesetOptions: null,\n useDracoGeometry: true,\n useCompressedTextures: true,\n decodeTextures: true,\n coordinateSystem: COORDINATE_SYSTEM.METER_OFFSETS,\n colorsByAttribute: null\n }\n }\n};\n\nasync function parseI3S(data, options: I3SLoaderOptions = {}, context) {\n const url = context.url;\n options.i3s = options.i3s || {};\n const magicNumber = getMagicNumber(data);\n\n // check if file is slpk\n if (magicNumber === SLPK_HEX) {\n throw new Error('Files with .slpk extention currently are not supported by I3SLoader');\n }\n\n // auto detect file type based on url\n let isTileset;\n if (options.i3s.isTileset === 'auto') {\n isTileset = TILESET_REGEX.test(url);\n } else {\n isTileset = options.i3s.isTileset;\n }\n\n let isTileHeader;\n if (options.isTileHeader === 'auto') {\n isTileHeader = TILE_HEADER_REGEX.test(url);\n } else {\n isTileHeader = options.i3s.isTileHeader;\n }\n\n if (isTileset) {\n data = await parseTileset(data, options, context);\n } else if (isTileHeader) {\n data = await parseTile(data, context);\n } else {\n data = await parseTileContent(data, options);\n }\n\n return data;\n}\n\nasync function parseTileContent(arrayBuffer, options: I3SLoaderOptions) {\n return await parse(arrayBuffer, I3SContentLoader, options);\n}\n\nasync function parseTileset(data, options: I3SLoaderOptions, context) {\n const tilesetJson = JSON.parse(new TextDecoder().decode(data));\n\n if (tilesetJson?.layerType === POINT_CLOUD) {\n throw new Error('Point Cloud layers currently are not supported by I3SLoader');\n }\n // eslint-disable-next-line no-use-before-define\n tilesetJson.loader = I3SLoader;\n await normalizeTilesetData(tilesetJson, options, context);\n\n return tilesetJson;\n}\n\nasync function parseTile(data, context) {\n data = JSON.parse(new TextDecoder().decode(data));\n return normalizeTileData(data, context);\n}\n\nfunction getMagicNumber(data) {\n if (data instanceof ArrayBuffer) {\n // slice binary data (4 bytes from the beginning) and transform it to hexadecimal numeral system\n return [...new Uint8Array(data, 0, 4)]\n .map((value) => value.toString(16).padStart(2, '0'))\n .join('');\n }\n return null;\n}\n"],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ const VERSION = typeof "4.0.0-alpha.6" !== 'undefined' ? "4.0.0-alpha.6" : 'latest';
2
+ async function parseNodePage(data, options) {
3
+ return JSON.parse(new TextDecoder().decode(data));
4
+ }
5
+ export const I3SNodePageLoader = {
6
+ name: 'I3S Node Page',
7
+ id: 'i3s-node-page',
8
+ module: 'i3s',
9
+ version: VERSION,
10
+ mimeTypes: ['application/json'],
11
+ parse: parseNodePage,
12
+ extensions: ['json'],
13
+ options: {}
14
+ };
15
+ //# sourceMappingURL=i3s-node-page-loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"i3s-node-page-loader.js","names":["VERSION","parseNodePage","data","options","JSON","parse","TextDecoder","decode","I3SNodePageLoader","name","id","module","version","mimeTypes","extensions"],"sources":["../../src/i3s-node-page-loader.ts"],"sourcesContent":["import type {LoaderOptions, LoaderWithParser} from '@loaders.gl/loader-utils';\nimport type {NodePage} from './types';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nasync function parseNodePage(data: ArrayBuffer, options?: LoaderOptions): Promise<NodePage> {\n return JSON.parse(new TextDecoder().decode(data)) as NodePage;\n}\n\n/**\n * Loader for I3S node pages\n */\nexport const I3SNodePageLoader: LoaderWithParser<NodePage, never, LoaderOptions> = {\n name: 'I3S Node Page',\n id: 'i3s-node-page',\n module: 'i3s',\n version: VERSION,\n mimeTypes: ['application/json'],\n parse: parseNodePage,\n extensions: ['json'],\n options: {}\n};\n"],"mappings":"AAKA,MAAMA,OAAO,GAAG,sBAAkB,KAAK,WAAW,qBAAiB,QAAQ;AAE3E,eAAeC,aAAaA,CAACC,IAAiB,EAAEC,OAAuB,EAAqB;EAC1F,OAAOC,IAAI,CAACC,KAAK,CAAC,IAAIC,WAAW,CAAC,CAAC,CAACC,MAAM,CAACL,IAAI,CAAC,CAAC;AACnD;AAKA,OAAO,MAAMM,iBAAmE,GAAG;EACjFC,IAAI,EAAE,eAAe;EACrBC,EAAE,EAAE,eAAe;EACnBC,MAAM,EAAE,KAAK;EACbC,OAAO,EAAEZ,OAAO;EAChBa,SAAS,EAAE,CAAC,kBAAkB,CAAC;EAC/BR,KAAK,EAAEJ,aAAa;EACpBa,UAAU,EAAE,CAAC,MAAM,CAAC;EACpBX,OAAO,EAAE,CAAC;AACZ,CAAC"}
@@ -0,0 +1,8 @@
1
+ export { COORDINATE_SYSTEM } from './lib/parsers/constants';
2
+ export { I3SLoader } from './i3s-loader';
3
+ export { I3SContentLoader } from './i3s-content-loader';
4
+ export { I3SAttributeLoader, loadFeatureAttributes } from './i3s-attribute-loader';
5
+ export { I3SNodePageLoader } from './i3s-node-page-loader';
6
+ export { I3SBuildingSceneLayerLoader } from './i3s-building-scene-layer-loader';
7
+ export { ArcGisWebSceneLoader } from './arcgis-webscene-loader';
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","names":["COORDINATE_SYSTEM","I3SLoader","I3SContentLoader","I3SAttributeLoader","loadFeatureAttributes","I3SNodePageLoader","I3SBuildingSceneLayerLoader","ArcGisWebSceneLoader"],"sources":["../../src/index.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nexport type {\n BoundingVolumes,\n Mbs,\n Obb,\n SceneLayer3D,\n AttributeStorageInfo,\n Field,\n ESRIField,\n PopupInfo,\n Node3DIndexDocument,\n LodSelection,\n NodeReference,\n Resource,\n MaxScreenThresholdSQ,\n NodeInPage,\n SharedResources,\n Attribute,\n Extent,\n FeatureAttribute,\n FieldInfo,\n I3SMaterialDefinition,\n TextureDefinitionInfo,\n MaterialDefinitionInfo,\n FullExtent,\n StatisticsInfo,\n StatsInfo,\n Histogram,\n ValueCount,\n BuildingSceneSublayer,\n DATA_TYPE,\n OperationalLayer\n} from './types';\n\nexport {COORDINATE_SYSTEM} from './lib/parsers/constants';\n\nexport {I3SLoader} from './i3s-loader';\nexport {I3SContentLoader} from './i3s-content-loader';\nexport {I3SAttributeLoader, loadFeatureAttributes} from './i3s-attribute-loader';\nexport {I3SNodePageLoader} from './i3s-node-page-loader';\nexport {I3SBuildingSceneLayerLoader} from './i3s-building-scene-layer-loader';\n\nexport {ArcGisWebSceneLoader} from './arcgis-webscene-loader';\n"],"mappings":"AAmCA,SAAQA,iBAAiB,QAAO,yBAAyB;AAEzD,SAAQC,SAAS,QAAO,cAAc;AACtC,SAAQC,gBAAgB,QAAO,sBAAsB;AACrD,SAAQC,kBAAkB,EAAEC,qBAAqB,QAAO,wBAAwB;AAChF,SAAQC,iBAAiB,QAAO,wBAAwB;AACxD,SAAQC,2BAA2B,QAAO,mCAAmC;AAE7E,SAAQC,oBAAoB,QAAO,0BAA0B"}
@@ -0,0 +1,198 @@
1
+ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
2
+ import { load } from '@loaders.gl/core';
3
+ import { getSupportedGPUTextureFormats, selectSupportedBasisFormat } from '@loaders.gl/textures';
4
+ import { I3SNodePageLoader } from '../../i3s-node-page-loader';
5
+ import { normalizeTileNonUrlData } from '../parsers/parse-i3s';
6
+ import { getUrlWithToken, generateTilesetAttributeUrls } from '../utils/url-utils';
7
+ export default class I3SNodePagesTiles {
8
+ constructor(tileset, options) {
9
+ var _tileset$nodePages, _tileset$nodePages2;
10
+ _defineProperty(this, "tileset", void 0);
11
+ _defineProperty(this, "nodePages", []);
12
+ _defineProperty(this, "pendingNodePages", []);
13
+ _defineProperty(this, "nodesPerPage", void 0);
14
+ _defineProperty(this, "options", void 0);
15
+ _defineProperty(this, "lodSelectionMetricType", void 0);
16
+ _defineProperty(this, "textureDefinitionsSelectedFormats", []);
17
+ _defineProperty(this, "nodesInNodePages", void 0);
18
+ _defineProperty(this, "textureLoaderOptions", {});
19
+ this.tileset = {
20
+ ...tileset
21
+ };
22
+ this.nodesPerPage = ((_tileset$nodePages = tileset.nodePages) === null || _tileset$nodePages === void 0 ? void 0 : _tileset$nodePages.nodesPerPage) || 64;
23
+ this.lodSelectionMetricType = (_tileset$nodePages2 = tileset.nodePages) === null || _tileset$nodePages2 === void 0 ? void 0 : _tileset$nodePages2.lodSelectionMetricType;
24
+ this.options = options;
25
+ this.nodesInNodePages = 0;
26
+ this.initSelectedFormatsForTextureDefinitions(tileset);
27
+ }
28
+ async getNodeById(id) {
29
+ const pageIndex = Math.floor(id / this.nodesPerPage);
30
+ if (!this.nodePages[pageIndex] && !this.pendingNodePages[pageIndex]) {
31
+ var _this$options$i3s;
32
+ const nodePageUrl = getUrlWithToken("".concat(this.tileset.url, "/nodepages/").concat(pageIndex), (_this$options$i3s = this.options.i3s) === null || _this$options$i3s === void 0 ? void 0 : _this$options$i3s.token);
33
+ this.pendingNodePages[pageIndex] = {
34
+ status: 'Pending',
35
+ promise: load(nodePageUrl, I3SNodePageLoader, this.options)
36
+ };
37
+ this.nodePages[pageIndex] = await this.pendingNodePages[pageIndex].promise;
38
+ this.nodesInNodePages += this.nodePages[pageIndex].nodes.length;
39
+ this.pendingNodePages[pageIndex].status = 'Done';
40
+ }
41
+ if (this.pendingNodePages[pageIndex].status === 'Pending') {
42
+ this.nodePages[pageIndex] = await this.pendingNodePages[pageIndex].promise;
43
+ }
44
+ const nodeIndex = id % this.nodesPerPage;
45
+ return this.nodePages[pageIndex].nodes[nodeIndex];
46
+ }
47
+ async formTileFromNodePages(id) {
48
+ const node = await this.getNodeById(id);
49
+ const children = [];
50
+ const childNodesPromises = [];
51
+ for (const child of node.children || []) {
52
+ childNodesPromises.push(this.getNodeById(child));
53
+ }
54
+ const childNodes = await Promise.all(childNodesPromises);
55
+ for (const childNode of childNodes) {
56
+ children.push({
57
+ id: childNode.index.toString(),
58
+ obb: childNode.obb
59
+ });
60
+ }
61
+ let contentUrl;
62
+ let textureUrl;
63
+ let materialDefinition;
64
+ let textureFormat = 'jpg';
65
+ let attributeUrls = [];
66
+ let isDracoGeometry = false;
67
+ if (node && node.mesh) {
68
+ const {
69
+ url,
70
+ isDracoGeometry: isDracoGeometryResult
71
+ } = node.mesh.geometry && this.getContentUrl(node.mesh.geometry) || {
72
+ isDracoGeometry: false
73
+ };
74
+ contentUrl = url;
75
+ isDracoGeometry = isDracoGeometryResult;
76
+ const {
77
+ textureData,
78
+ materialDefinition: nodeMaterialDefinition
79
+ } = this.getInformationFromMaterial(node.mesh.material);
80
+ materialDefinition = nodeMaterialDefinition;
81
+ textureFormat = textureData.format || textureFormat;
82
+ if (textureData.name) {
83
+ textureUrl = "".concat(this.tileset.url, "/nodes/").concat(node.mesh.material.resource, "/textures/").concat(textureData.name);
84
+ }
85
+ if (this.tileset.attributeStorageInfo) {
86
+ attributeUrls = generateTilesetAttributeUrls(this.tileset, node.mesh.attribute.resource);
87
+ }
88
+ }
89
+ const lodSelection = this.getLodSelection(node);
90
+ return normalizeTileNonUrlData({
91
+ id: id.toString(),
92
+ lodSelection,
93
+ obb: node.obb,
94
+ contentUrl,
95
+ textureUrl,
96
+ attributeUrls,
97
+ materialDefinition,
98
+ textureFormat,
99
+ textureLoaderOptions: this.textureLoaderOptions,
100
+ children,
101
+ isDracoGeometry
102
+ });
103
+ }
104
+ getContentUrl(meshGeometryData) {
105
+ let result = null;
106
+ const geometryDefinition = this.tileset.geometryDefinitions[meshGeometryData.definition];
107
+ let geometryIndex = -1;
108
+ if (this.options.i3s && this.options.i3s.useDracoGeometry) {
109
+ geometryIndex = geometryDefinition.geometryBuffers.findIndex(buffer => buffer.compressedAttributes && buffer.compressedAttributes.encoding === 'draco');
110
+ }
111
+ if (geometryIndex === -1) {
112
+ geometryIndex = geometryDefinition.geometryBuffers.findIndex(buffer => !buffer.compressedAttributes);
113
+ }
114
+ if (geometryIndex !== -1) {
115
+ const isDracoGeometry = Boolean(geometryDefinition.geometryBuffers[geometryIndex].compressedAttributes);
116
+ result = {
117
+ url: "".concat(this.tileset.url, "/nodes/").concat(meshGeometryData.resource, "/geometries/").concat(geometryIndex),
118
+ isDracoGeometry
119
+ };
120
+ }
121
+ return result;
122
+ }
123
+ getLodSelection(node) {
124
+ const lodSelection = [];
125
+ if (this.lodSelectionMetricType === 'maxScreenThresholdSQ') {
126
+ lodSelection.push({
127
+ metricType: 'maxScreenThreshold',
128
+ maxError: Math.sqrt(node.lodThreshold / (Math.PI * 0.25))
129
+ });
130
+ }
131
+ lodSelection.push({
132
+ metricType: this.lodSelectionMetricType,
133
+ maxError: node.lodThreshold
134
+ });
135
+ return lodSelection;
136
+ }
137
+ getInformationFromMaterial(material) {
138
+ const informationFromMaterial = {
139
+ textureData: {
140
+ name: null
141
+ }
142
+ };
143
+ if (material) {
144
+ var _this$tileset$materia;
145
+ const materialDefinition = (_this$tileset$materia = this.tileset.materialDefinitions) === null || _this$tileset$materia === void 0 ? void 0 : _this$tileset$materia[material.definition];
146
+ if (materialDefinition) {
147
+ var _materialDefinition$p, _materialDefinition$p2;
148
+ informationFromMaterial.materialDefinition = materialDefinition;
149
+ const textureSetDefinitionIndex = materialDefinition === null || materialDefinition === void 0 ? void 0 : (_materialDefinition$p = materialDefinition.pbrMetallicRoughness) === null || _materialDefinition$p === void 0 ? void 0 : (_materialDefinition$p2 = _materialDefinition$p.baseColorTexture) === null || _materialDefinition$p2 === void 0 ? void 0 : _materialDefinition$p2.textureSetDefinitionId;
150
+ if (typeof textureSetDefinitionIndex === 'number') {
151
+ informationFromMaterial.textureData = this.textureDefinitionsSelectedFormats[textureSetDefinitionIndex] || informationFromMaterial.textureData;
152
+ }
153
+ }
154
+ }
155
+ return informationFromMaterial;
156
+ }
157
+ initSelectedFormatsForTextureDefinitions(tileset) {
158
+ this.textureDefinitionsSelectedFormats = [];
159
+ const possibleI3sFormats = this.getSupportedTextureFormats();
160
+ const textureSetDefinitions = tileset.textureSetDefinitions || [];
161
+ for (const textureSetDefinition of textureSetDefinitions) {
162
+ const formats = textureSetDefinition && textureSetDefinition.formats || [];
163
+ let selectedFormat = null;
164
+ for (const i3sFormat of possibleI3sFormats) {
165
+ const format = formats.find(value => value.format === i3sFormat);
166
+ if (format) {
167
+ selectedFormat = format;
168
+ break;
169
+ }
170
+ }
171
+ if (selectedFormat && selectedFormat.format === 'ktx2') {
172
+ this.textureLoaderOptions.basis = {
173
+ format: selectSupportedBasisFormat(),
174
+ containerFormat: 'ktx2',
175
+ module: 'encoder'
176
+ };
177
+ }
178
+ this.textureDefinitionsSelectedFormats.push(selectedFormat);
179
+ }
180
+ }
181
+ getSupportedTextureFormats() {
182
+ const formats = [];
183
+ if (!this.options.i3s || this.options.i3s.useCompressedTextures) {
184
+ const supportedCompressedFormats = getSupportedGPUTextureFormats();
185
+ if (supportedCompressedFormats.has('etc2')) {
186
+ formats.push('ktx-etc2');
187
+ }
188
+ if (supportedCompressedFormats.has('dxt')) {
189
+ formats.push('dds');
190
+ }
191
+ formats.push('ktx2');
192
+ }
193
+ formats.push('jpg');
194
+ formats.push('png');
195
+ return formats;
196
+ }
197
+ }
198
+ //# sourceMappingURL=i3s-nodepages-tiles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"i3s-nodepages-tiles.js","names":["load","getSupportedGPUTextureFormats","selectSupportedBasisFormat","I3SNodePageLoader","normalizeTileNonUrlData","getUrlWithToken","generateTilesetAttributeUrls","I3SNodePagesTiles","constructor","tileset","options","_tileset$nodePages","_tileset$nodePages2","_defineProperty","nodesPerPage","nodePages","lodSelectionMetricType","nodesInNodePages","initSelectedFormatsForTextureDefinitions","getNodeById","id","pageIndex","Math","floor","pendingNodePages","_this$options$i3s","nodePageUrl","concat","url","i3s","token","status","promise","nodes","length","nodeIndex","formTileFromNodePages","node","children","childNodesPromises","child","push","childNodes","Promise","all","childNode","index","toString","obb","contentUrl","textureUrl","materialDefinition","textureFormat","attributeUrls","isDracoGeometry","mesh","isDracoGeometryResult","geometry","getContentUrl","textureData","nodeMaterialDefinition","getInformationFromMaterial","material","format","name","resource","attributeStorageInfo","attribute","lodSelection","getLodSelection","textureLoaderOptions","meshGeometryData","result","geometryDefinition","geometryDefinitions","definition","geometryIndex","useDracoGeometry","geometryBuffers","findIndex","buffer","compressedAttributes","encoding","Boolean","metricType","maxError","sqrt","lodThreshold","PI","informationFromMaterial","_this$tileset$materia","materialDefinitions","_materialDefinition$p","_materialDefinition$p2","textureSetDefinitionIndex","pbrMetallicRoughness","baseColorTexture","textureSetDefinitionId","textureDefinitionsSelectedFormats","possibleI3sFormats","getSupportedTextureFormats","textureSetDefinitions","textureSetDefinition","formats","selectedFormat","i3sFormat","find","value","basis","containerFormat","module","useCompressedTextures","supportedCompressedFormats","has"],"sources":["../../../../src/lib/helpers/i3s-nodepages-tiles.ts"],"sourcesContent":["import {load} from '@loaders.gl/core';\nimport {getSupportedGPUTextureFormats, selectSupportedBasisFormat} from '@loaders.gl/textures';\nimport {I3SNodePageLoader} from '../../i3s-node-page-loader';\nimport {normalizeTileNonUrlData} from '../parsers/parse-i3s';\nimport {getUrlWithToken, generateTilesetAttributeUrls} from '../utils/url-utils';\nimport type {LoaderOptions} from '@loaders.gl/loader-utils';\nimport {\n I3STilesetHeader,\n LodSelection,\n NodePage,\n NodeInPage,\n Obb,\n MeshMaterial,\n I3SMaterialDefinition,\n I3STextureFormat,\n MeshGeometry,\n I3STileHeader\n} from '../../types';\n\n/**\n * class I3SNodePagesTiles - loads nodePages and form i3s tiles from them\n */\nexport default class I3SNodePagesTiles {\n tileset: I3STilesetHeader;\n nodePages: NodePage[] = [];\n pendingNodePages: {promise: Promise<NodePage>; status: 'Pending' | 'Done'}[] = [];\n nodesPerPage: number;\n options: LoaderOptions;\n lodSelectionMetricType?: string;\n textureDefinitionsSelectedFormats: ({format: I3STextureFormat; name: string} | null)[] = [];\n nodesInNodePages: number;\n private textureLoaderOptions: {[key: string]: any} = {};\n\n /**\n * @constructs\n * Create a I3SNodePagesTiles instance.\n * @param tileset - i3s tileset header ('layers/0')\n * @param options - i3s loader options\n */\n constructor(tileset: I3STilesetHeader, options: LoaderOptions) {\n this.tileset = {...tileset}; // spread the tileset to avoid circular reference\n this.nodesPerPage = tileset.nodePages?.nodesPerPage || 64;\n this.lodSelectionMetricType = tileset.nodePages?.lodSelectionMetricType;\n this.options = options;\n this.nodesInNodePages = 0;\n\n this.initSelectedFormatsForTextureDefinitions(tileset);\n }\n\n /**\n * Loads some nodePage and return a particular node from it\n * @param id - id of node through all node pages\n */\n async getNodeById(id: number): Promise<NodeInPage> {\n const pageIndex = Math.floor(id / this.nodesPerPage);\n if (!this.nodePages[pageIndex] && !this.pendingNodePages[pageIndex]) {\n const nodePageUrl = getUrlWithToken(\n `${this.tileset.url}/nodepages/${pageIndex}`,\n // @ts-expect-error this.options is not properly typed\n this.options.i3s?.token\n );\n this.pendingNodePages[pageIndex] = {\n status: 'Pending',\n promise: load(nodePageUrl, I3SNodePageLoader, this.options)\n };\n this.nodePages[pageIndex] = await this.pendingNodePages[pageIndex].promise;\n this.nodesInNodePages += this.nodePages[pageIndex].nodes.length;\n this.pendingNodePages[pageIndex].status = 'Done';\n }\n if (this.pendingNodePages[pageIndex].status === 'Pending') {\n this.nodePages[pageIndex] = await this.pendingNodePages[pageIndex].promise;\n }\n const nodeIndex = id % this.nodesPerPage;\n return this.nodePages[pageIndex].nodes[nodeIndex];\n }\n\n /**\n * Forms tile header using node and tileset data\n * @param id - id of node through all node pages\n */\n // eslint-disable-next-line complexity, max-statements\n async formTileFromNodePages(id: number): Promise<I3STileHeader> {\n const node: NodeInPage = await this.getNodeById(id);\n const children: {id: string; obb: Obb}[] = [];\n const childNodesPromises: Promise<NodeInPage>[] = [];\n for (const child of node.children || []) {\n childNodesPromises.push(this.getNodeById(child));\n }\n\n const childNodes = await Promise.all(childNodesPromises);\n for (const childNode of childNodes) {\n children.push({\n id: childNode.index.toString(),\n obb: childNode.obb\n });\n }\n\n let contentUrl: string | undefined;\n let textureUrl: string | undefined;\n let materialDefinition: I3SMaterialDefinition | undefined;\n let textureFormat: I3STextureFormat = 'jpg';\n let attributeUrls: string[] = [];\n let isDracoGeometry: boolean = false;\n\n if (node && node.mesh) {\n // Get geometry resource URL and type (compressed / non-compressed)\n const {url, isDracoGeometry: isDracoGeometryResult} = (node.mesh.geometry &&\n this.getContentUrl(node.mesh.geometry)) || {isDracoGeometry: false};\n contentUrl = url;\n isDracoGeometry = isDracoGeometryResult;\n\n const {textureData, materialDefinition: nodeMaterialDefinition} =\n this.getInformationFromMaterial(node.mesh.material);\n materialDefinition = nodeMaterialDefinition;\n textureFormat = textureData.format || textureFormat;\n if (textureData.name) {\n textureUrl = `${this.tileset.url}/nodes/${node.mesh.material.resource}/textures/${textureData.name}`;\n }\n\n if (this.tileset.attributeStorageInfo) {\n attributeUrls = generateTilesetAttributeUrls(this.tileset, node.mesh.attribute.resource);\n }\n }\n\n const lodSelection = this.getLodSelection(node);\n\n return normalizeTileNonUrlData({\n id: id.toString(),\n lodSelection,\n obb: node.obb,\n contentUrl,\n textureUrl,\n attributeUrls,\n materialDefinition,\n textureFormat,\n textureLoaderOptions: this.textureLoaderOptions,\n children,\n isDracoGeometry\n });\n }\n\n /**\n * Forms url and type of geometry resource by nodepage's data and `geometryDefinitions` in the tileset\n * @param - data about the node's mesh from the nodepage\n * @returns -\n * {string} url - url to the geometry resource\n * {boolean} isDracoGeometry - whether the geometry resource contain DRACO compressed geometry\n */\n private getContentUrl(meshGeometryData: MeshGeometry) {\n let result: {url: string; isDracoGeometry: boolean} | null = null;\n // @ts-ignore\n const geometryDefinition = this.tileset.geometryDefinitions[meshGeometryData.definition];\n let geometryIndex = -1;\n // Try to find DRACO geometryDefinition of `useDracoGeometry` option is set\n // @ts-expect-error this.options is not properly typed\n if (this.options.i3s && this.options.i3s.useDracoGeometry) {\n geometryIndex = geometryDefinition.geometryBuffers.findIndex(\n (buffer) => buffer.compressedAttributes && buffer.compressedAttributes.encoding === 'draco'\n );\n }\n // If DRACO geometry is not applicable try to select non-compressed geometry\n if (geometryIndex === -1) {\n geometryIndex = geometryDefinition.geometryBuffers.findIndex(\n (buffer) => !buffer.compressedAttributes\n );\n }\n if (geometryIndex !== -1) {\n const isDracoGeometry = Boolean(\n geometryDefinition.geometryBuffers[geometryIndex].compressedAttributes\n );\n result = {\n url: `${this.tileset.url}/nodes/${meshGeometryData.resource}/geometries/${geometryIndex}`,\n isDracoGeometry\n };\n }\n return result;\n }\n\n /**\n * Forms 1.6 compatible LOD selection object from a nodepage's node data\n * @param node - a node from nodepage\n * @returns- Array of LodSelection\n */\n private getLodSelection(node: NodeInPage): LodSelection[] {\n const lodSelection: LodSelection[] = [];\n if (this.lodSelectionMetricType === 'maxScreenThresholdSQ') {\n lodSelection.push({\n metricType: 'maxScreenThreshold',\n // @ts-ignore\n maxError: Math.sqrt(node.lodThreshold / (Math.PI * 0.25))\n });\n }\n lodSelection.push({\n metricType: this.lodSelectionMetricType,\n // @ts-ignore\n maxError: node.lodThreshold\n });\n return lodSelection;\n }\n\n /**\n * Returns information about texture and material from `materialDefinitions`\n * @param material - material data from nodepage\n * @returns - Couple {textureData, materialDefinition}\n * {string} textureData.name - path name of the texture\n * {string} textureData.format - format of the texture\n * materialDefinition - PBR-like material definition from `materialDefinitions`\n */\n private getInformationFromMaterial(material: MeshMaterial) {\n const informationFromMaterial: {\n textureData: {name: string | null; format?: I3STextureFormat};\n materialDefinition?: I3SMaterialDefinition;\n } = {textureData: {name: null}};\n\n if (material) {\n const materialDefinition = this.tileset.materialDefinitions?.[material.definition];\n if (materialDefinition) {\n informationFromMaterial.materialDefinition = materialDefinition;\n const textureSetDefinitionIndex =\n materialDefinition?.pbrMetallicRoughness?.baseColorTexture?.textureSetDefinitionId;\n\n if (typeof textureSetDefinitionIndex === 'number') {\n informationFromMaterial.textureData =\n this.textureDefinitionsSelectedFormats[textureSetDefinitionIndex] ||\n informationFromMaterial.textureData;\n }\n }\n }\n return informationFromMaterial;\n }\n\n /**\n * Sets preferable and supported format for each textureDefinition of the tileset\n * @param tileset - I3S layer data\n * @returns\n */\n private initSelectedFormatsForTextureDefinitions(tileset: I3STilesetHeader): void {\n this.textureDefinitionsSelectedFormats = [];\n const possibleI3sFormats = this.getSupportedTextureFormats();\n const textureSetDefinitions = tileset.textureSetDefinitions || [];\n for (const textureSetDefinition of textureSetDefinitions) {\n const formats = (textureSetDefinition && textureSetDefinition.formats) || [];\n let selectedFormat: {name: string; format: I3STextureFormat} | null = null;\n for (const i3sFormat of possibleI3sFormats) {\n const format = formats.find((value) => value.format === i3sFormat);\n if (format) {\n selectedFormat = format;\n break;\n }\n }\n // For I3S 1.8 need to define basis target format to decode\n if (selectedFormat && selectedFormat.format === 'ktx2') {\n this.textureLoaderOptions.basis = {\n format: selectSupportedBasisFormat(),\n containerFormat: 'ktx2',\n module: 'encoder'\n };\n }\n\n this.textureDefinitionsSelectedFormats.push(selectedFormat);\n }\n }\n\n /**\n * Returns the array of supported texture format\n * @returns list of format strings\n */\n private getSupportedTextureFormats(): I3STextureFormat[] {\n const formats: I3STextureFormat[] = [];\n // @ts-expect-error this.options is not properly typed\n if (!this.options.i3s || this.options.i3s.useCompressedTextures) {\n // I3S 1.7 selection\n const supportedCompressedFormats = getSupportedGPUTextureFormats();\n // List of possible in i3s formats:\n // https://github.com/Esri/i3s-spec/blob/master/docs/1.7/textureSetDefinitionFormat.cmn.md\n if (supportedCompressedFormats.has('etc2')) {\n formats.push('ktx-etc2');\n }\n if (supportedCompressedFormats.has('dxt')) {\n formats.push('dds');\n }\n\n // I3S 1.8 selection\n // ktx2 wraps basis texture which at the edge case can be decoded as uncompressed image\n formats.push('ktx2');\n }\n\n formats.push('jpg');\n formats.push('png');\n return formats;\n }\n}\n"],"mappings":"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"}