@loaders.gl/wms 3.4.0-alpha.2 → 3.4.0-alpha.4

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 (208) hide show
  1. package/dist/dist.min.js +412 -176
  2. package/dist/es5/csw-capabilities-loader.js +7 -11
  3. package/dist/es5/csw-capabilities-loader.js.map +1 -1
  4. package/dist/es5/csw-domain-loader.js +7 -10
  5. package/dist/es5/csw-domain-loader.js.map +1 -1
  6. package/dist/es5/csw-records-loader.js +7 -10
  7. package/dist/es5/csw-records-loader.js.map +1 -1
  8. package/dist/es5/gml-loader.js +7 -10
  9. package/dist/es5/gml-loader.js.map +1 -1
  10. package/dist/es5/index.js +0 -7
  11. package/dist/es5/index.js.map +1 -1
  12. package/dist/es5/lerc-loader.js +17 -22
  13. package/dist/es5/lerc-loader.js.map +1 -1
  14. package/dist/es5/lib/create-image-source.js +1 -2
  15. package/dist/es5/lib/create-image-source.js.map +1 -1
  16. package/dist/es5/lib/parsers/csw/parse-csw-capabilities.js.map +1 -1
  17. package/dist/es5/lib/parsers/csw/parse-csw-domain.js +1 -1
  18. package/dist/es5/lib/parsers/csw/parse-csw-domain.js.map +1 -1
  19. package/dist/es5/lib/parsers/csw/parse-csw-records.js +1 -2
  20. package/dist/es5/lib/parsers/csw/parse-csw-records.js.map +1 -1
  21. package/dist/es5/lib/parsers/csw/parse-exception-report.js +0 -2
  22. package/dist/es5/lib/parsers/csw/parse-exception-report.js.map +1 -1
  23. package/dist/es5/lib/parsers/gml/deep-strict-equal.js +0 -8
  24. package/dist/es5/lib/parsers/gml/deep-strict-equal.js.map +1 -1
  25. package/dist/es5/lib/parsers/gml/parse-gml.js +1 -13
  26. package/dist/es5/lib/parsers/gml/parse-gml.js.map +1 -1
  27. package/dist/es5/lib/parsers/wms/parse-wms-capabilities.js +197 -54
  28. package/dist/es5/lib/parsers/wms/parse-wms-capabilities.js.map +1 -1
  29. package/dist/es5/lib/parsers/wms/parse-wms-error.js +0 -1
  30. package/dist/es5/lib/parsers/wms/parse-wms-error.js.map +1 -1
  31. package/dist/es5/lib/parsers/wms/parse-wms-features.js +0 -1
  32. package/dist/es5/lib/parsers/wms/parse-wms-features.js.map +1 -1
  33. package/dist/es5/lib/parsers/wms/parse-wms-layer-description.js +0 -1
  34. package/dist/es5/lib/parsers/wms/parse-wms-layer-description.js.map +1 -1
  35. package/dist/es5/lib/parsers/xml/parse-xml-helpers.js +67 -0
  36. package/dist/es5/lib/parsers/xml/parse-xml-helpers.js.map +1 -0
  37. package/dist/es5/lib/services/arcgis/arcgis-image-service.js +36 -60
  38. package/dist/es5/lib/services/arcgis/arcgis-image-service.js.map +1 -1
  39. package/dist/es5/lib/services/arcgis/arcgis-server.js +50 -54
  40. package/dist/es5/lib/services/arcgis/arcgis-server.js.map +1 -1
  41. package/dist/es5/lib/services/generic/image-service.js +28 -42
  42. package/dist/es5/lib/services/generic/image-service.js.map +1 -1
  43. package/dist/es5/lib/services/ogc/csw-service.js +161 -188
  44. package/dist/es5/lib/services/ogc/csw-service.js.map +1 -1
  45. package/dist/es5/lib/services/ogc/wms-service.js +325 -245
  46. package/dist/es5/lib/services/ogc/wms-service.js.map +1 -1
  47. package/dist/es5/lib/sources/data-source.js +36 -13
  48. package/dist/es5/lib/sources/data-source.js.map +1 -1
  49. package/dist/es5/lib/sources/image-source.js.map +1 -1
  50. package/dist/es5/lib/sources/tile-source.js.map +1 -1
  51. package/dist/es5/lib/sources/utils/utils.js +0 -4
  52. package/dist/es5/lib/sources/utils/utils.js.map +1 -1
  53. package/dist/es5/wip/arcgis-feature-service.js +2 -7
  54. package/dist/es5/wip/arcgis-feature-service.js.map +1 -1
  55. package/dist/es5/wip/data-source.js +0 -2
  56. package/dist/es5/wip/lib/wcs/parse-wcs-capabilities.js.map +1 -1
  57. package/dist/es5/wip/lib/wfs/parse-wfs-capabilities.js.map +1 -1
  58. package/dist/es5/wip/lib/wmts/parse-wmts-capabilities.js.map +1 -1
  59. package/dist/es5/wip/wcs-capabilities-loader.js +7 -10
  60. package/dist/es5/wip/wcs-capabilities-loader.js.map +1 -1
  61. package/dist/es5/wip/wfs-capabilities-loader.js +7 -10
  62. package/dist/es5/wip/wfs-capabilities-loader.js.map +1 -1
  63. package/dist/es5/wip/wms-feature-info-loader.js +6 -8
  64. package/dist/es5/wip/wms-feature-info-loader.js.map +1 -1
  65. package/dist/es5/wip/wms-layer-description-loader.js +6 -8
  66. package/dist/es5/wip/wms-layer-description-loader.js.map +1 -1
  67. package/dist/es5/wip/wmts-capabilities-loader.js +7 -16
  68. package/dist/es5/wip/wmts-capabilities-loader.js.map +1 -1
  69. package/dist/es5/wms-capabilities-loader.js +8 -12
  70. package/dist/es5/wms-capabilities-loader.js.map +1 -1
  71. package/dist/es5/wms-error-loader.js +7 -9
  72. package/dist/es5/wms-error-loader.js.map +1 -1
  73. package/dist/esm/bundle.js +0 -2
  74. package/dist/esm/bundle.js.map +1 -1
  75. package/dist/esm/csw-capabilities-loader.js +1 -5
  76. package/dist/esm/csw-capabilities-loader.js.map +1 -1
  77. package/dist/esm/csw-domain-loader.js +1 -4
  78. package/dist/esm/csw-domain-loader.js.map +1 -1
  79. package/dist/esm/csw-records-loader.js +1 -4
  80. package/dist/esm/csw-records-loader.js.map +1 -1
  81. package/dist/esm/gml-loader.js +1 -4
  82. package/dist/esm/gml-loader.js.map +1 -1
  83. package/dist/esm/index.js +0 -11
  84. package/dist/esm/index.js.map +1 -1
  85. package/dist/esm/lerc-loader.js +1 -4
  86. package/dist/esm/lerc-loader.js.map +1 -1
  87. package/dist/esm/lib/create-image-source.js +0 -3
  88. package/dist/esm/lib/create-image-source.js.map +1 -1
  89. package/dist/esm/lib/parsers/csw/parse-csw-capabilities.js +0 -3
  90. package/dist/esm/lib/parsers/csw/parse-csw-capabilities.js.map +1 -1
  91. package/dist/esm/lib/parsers/csw/parse-csw-domain.js +0 -3
  92. package/dist/esm/lib/parsers/csw/parse-csw-domain.js.map +1 -1
  93. package/dist/esm/lib/parsers/csw/parse-csw-records.js +0 -3
  94. package/dist/esm/lib/parsers/csw/parse-csw-records.js.map +1 -1
  95. package/dist/esm/lib/parsers/csw/parse-exception-report.js +0 -3
  96. package/dist/esm/lib/parsers/csw/parse-exception-report.js.map +1 -1
  97. package/dist/esm/lib/parsers/gml/deep-strict-equal.js +0 -9
  98. package/dist/esm/lib/parsers/gml/deep-strict-equal.js.map +1 -1
  99. package/dist/esm/lib/parsers/gml/parse-gml.js +0 -14
  100. package/dist/esm/lib/parsers/gml/parse-gml.js.map +1 -1
  101. package/dist/esm/lib/parsers/wms/parse-wms-capabilities.js +151 -42
  102. package/dist/esm/lib/parsers/wms/parse-wms-capabilities.js.map +1 -1
  103. package/dist/esm/lib/parsers/wms/parse-wms-error.js +0 -3
  104. package/dist/esm/lib/parsers/wms/parse-wms-error.js.map +1 -1
  105. package/dist/esm/lib/parsers/wms/parse-wms-features.js +0 -3
  106. package/dist/esm/lib/parsers/wms/parse-wms-features.js.map +1 -1
  107. package/dist/esm/lib/parsers/wms/parse-wms-layer-description.js +0 -3
  108. package/dist/esm/lib/parsers/wms/parse-wms-layer-description.js.map +1 -1
  109. package/dist/esm/lib/parsers/xml/parse-xml-helpers.js +53 -0
  110. package/dist/esm/lib/parsers/xml/parse-xml-helpers.js.map +1 -0
  111. package/dist/esm/lib/services/arcgis/arcgis-image-service.js +0 -11
  112. package/dist/esm/lib/services/arcgis/arcgis-image-service.js.map +1 -1
  113. package/dist/esm/lib/services/arcgis/arcgis-server.js +0 -2
  114. package/dist/esm/lib/services/arcgis/arcgis-server.js.map +1 -1
  115. package/dist/esm/lib/services/generic/image-service.js +0 -7
  116. package/dist/esm/lib/services/generic/image-service.js.map +1 -1
  117. package/dist/esm/lib/services/ogc/csw-service.js +0 -13
  118. package/dist/esm/lib/services/ogc/csw-service.js.map +1 -1
  119. package/dist/esm/lib/services/ogc/wms-service.js +135 -86
  120. package/dist/esm/lib/services/ogc/wms-service.js.map +1 -1
  121. package/dist/esm/lib/sources/data-source.js +20 -6
  122. package/dist/esm/lib/sources/data-source.js.map +1 -1
  123. package/dist/esm/lib/sources/image-source.js +0 -3
  124. package/dist/esm/lib/sources/image-source.js.map +1 -1
  125. package/dist/esm/lib/sources/tile-source.js +0 -3
  126. package/dist/esm/lib/sources/tile-source.js.map +1 -1
  127. package/dist/esm/lib/sources/utils/utils.js +0 -5
  128. package/dist/esm/lib/sources/utils/utils.js.map +1 -1
  129. package/dist/esm/wip/arcgis-feature-service.js +0 -3
  130. package/dist/esm/wip/arcgis-feature-service.js.map +1 -1
  131. package/dist/esm/wip/lib/wcs/parse-wcs-capabilities.js +0 -3
  132. package/dist/esm/wip/lib/wcs/parse-wcs-capabilities.js.map +1 -1
  133. package/dist/esm/wip/lib/wfs/parse-wfs-capabilities.js +0 -3
  134. package/dist/esm/wip/lib/wfs/parse-wfs-capabilities.js.map +1 -1
  135. package/dist/esm/wip/lib/wmts/parse-wmts-capabilities.js +0 -3
  136. package/dist/esm/wip/lib/wmts/parse-wmts-capabilities.js.map +1 -1
  137. package/dist/esm/wip/wcs-capabilities-loader.js +1 -4
  138. package/dist/esm/wip/wcs-capabilities-loader.js.map +1 -1
  139. package/dist/esm/wip/wfs-capabilities-loader.js +1 -4
  140. package/dist/esm/wip/wfs-capabilities-loader.js.map +1 -1
  141. package/dist/esm/wip/wms-feature-info-loader.js +0 -2
  142. package/dist/esm/wip/wms-feature-info-loader.js.map +1 -1
  143. package/dist/esm/wip/wms-layer-description-loader.js +0 -2
  144. package/dist/esm/wip/wms-layer-description-loader.js.map +1 -1
  145. package/dist/esm/wip/wmts-capabilities-loader.js +1 -6
  146. package/dist/esm/wip/wmts-capabilities-loader.js.map +1 -1
  147. package/dist/esm/wms-capabilities-loader.js +3 -7
  148. package/dist/esm/wms-capabilities-loader.js.map +1 -1
  149. package/dist/esm/wms-error-loader.js +1 -4
  150. package/dist/esm/wms-error-loader.js.map +1 -1
  151. package/dist/index.d.ts +0 -3
  152. package/dist/index.d.ts.map +1 -1
  153. package/dist/index.js +3 -5
  154. package/dist/lib/create-image-source.d.ts +1 -1
  155. package/dist/lib/create-image-source.d.ts.map +1 -1
  156. package/dist/lib/parsers/wms/parse-wms-capabilities.d.ts +78 -62
  157. package/dist/lib/parsers/wms/parse-wms-capabilities.d.ts.map +1 -1
  158. package/dist/lib/parsers/wms/parse-wms-capabilities.js +166 -1935
  159. package/dist/lib/parsers/xml/parse-xml-helpers.d.ts +11 -0
  160. package/dist/lib/parsers/xml/parse-xml-helpers.d.ts.map +1 -0
  161. package/dist/lib/parsers/xml/parse-xml-helpers.js +68 -0
  162. package/dist/lib/services/arcgis/arcgis-image-service.d.ts +1 -2
  163. package/dist/lib/services/arcgis/arcgis-image-service.d.ts.map +1 -1
  164. package/dist/lib/services/arcgis/arcgis-image-service.js +1 -2
  165. package/dist/lib/services/generic/image-service.d.ts +2 -3
  166. package/dist/lib/services/generic/image-service.d.ts.map +1 -1
  167. package/dist/lib/services/generic/image-service.js +1 -2
  168. package/dist/lib/services/ogc/csw-service.d.ts +2 -3
  169. package/dist/lib/services/ogc/csw-service.d.ts.map +1 -1
  170. package/dist/lib/services/ogc/csw-service.js +1 -2
  171. package/dist/lib/services/ogc/wms-service.d.ts +128 -72
  172. package/dist/lib/services/ogc/wms-service.d.ts.map +1 -1
  173. package/dist/lib/services/ogc/wms-service.js +154 -73
  174. package/dist/lib/sources/data-source.d.ts +12 -2
  175. package/dist/lib/sources/data-source.d.ts.map +1 -1
  176. package/dist/lib/sources/data-source.js +22 -0
  177. package/dist/lib/sources/image-source.d.ts +9 -15
  178. package/dist/lib/sources/image-source.d.ts.map +1 -1
  179. package/dist/lib/sources/tile-source.d.ts +4 -2
  180. package/dist/lib/sources/tile-source.d.ts.map +1 -1
  181. package/dist/wip/wmts-capabilities-loader.d.ts +3 -4
  182. package/dist/wip/wmts-capabilities-loader.d.ts.map +1 -1
  183. package/dist/wip/wmts-capabilities-loader.js +1 -0
  184. package/dist/wms-capabilities-loader.d.ts +6 -1
  185. package/dist/wms-capabilities-loader.d.ts.map +1 -1
  186. package/dist/wms-capabilities-loader.js +2 -2
  187. package/package.json +6 -6
  188. package/src/index.ts +3 -4
  189. package/src/lib/create-image-source.ts +1 -1
  190. package/src/lib/parsers/wms/parse-wms-capabilities.ts +294 -2004
  191. package/src/lib/parsers/xml/parse-xml-helpers.ts +65 -0
  192. package/src/lib/services/arcgis/arcgis-image-service.ts +1 -4
  193. package/src/lib/services/generic/image-service.ts +2 -5
  194. package/src/lib/services/ogc/csw-service.ts +2 -4
  195. package/src/lib/services/ogc/wms-service.ts +290 -125
  196. package/src/lib/sources/data-source.ts +29 -2
  197. package/src/lib/sources/image-source.ts +9 -15
  198. package/src/lib/sources/tile-source.ts +4 -2
  199. package/src/wip/wmts-capabilities-loader.ts +2 -2
  200. package/src/wms-capabilities-loader.ts +9 -3
  201. package/dist/es5/lib/services/generic/tile-service.js +0 -2
  202. package/dist/es5/lib/services/generic/tile-service.js.map +0 -1
  203. package/dist/esm/lib/services/generic/tile-service.js +0 -2
  204. package/dist/esm/lib/services/generic/tile-service.js.map +0 -1
  205. package/dist/lib/services/generic/tile-service.d.ts +0 -1
  206. package/dist/lib/services/generic/tile-service.d.ts.map +0 -1
  207. package/dist/lib/services/generic/tile-service.js +0 -1
  208. package/src/lib/services/generic/tile-service.ts +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"deep-strict-equal.js","names":["deepStrictEqual","actual","expected","strict","Date","getTime","RegExp","source","global","multiline","lastIndex","ignoreCase","objEquiv","pSlice","Array","prototype","slice","isPrimitive","arg","isArguments","object","Object","toString","call","a","b","undefined","getPrototypeOf","aIsArgs","bIsArgs","ka","keys","kb","key","i","length","sort"],"sources":["../../../../../src/lib/parsers/gml/deep-strict-equal.ts"],"sourcesContent":["// https://github.com/nodejs/node/commit/c1d82ac2ff15594840e2a1b9531b506ae067ed27;\n\n// http://wiki.commonjs.org/wiki/Unit_Testing/1.0\n//\n// THIS IS NOT TESTED NOR LIKELY TO WORK OUTSIDE V8!\n//\n// Originally from narwhal.js (http://narwhaljs.org)\n// Copyright (c) 2009 Thomas Robinson <280north.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the 'Software'), to\n// deal in the Software without restriction, including without limitation the\n// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n// sell copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN\n// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION\n// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n/** @todo replace this ridiculous choice of deepStrictEqual */\n// eslint-disable-next-line complexity\nexport function deepStrictEqual(actual: unknown, expected: unknown, strict?: boolean) {\n // 7.1. All identical values are equivalent, as determined by ===.\n if (actual === expected) {\n return true;\n // } else if (actual instanceof Buffer && expected instanceof Buffer) {\n // return compare(actual, expected) === 0;\n\n // // 7.2. If the expected value is a Date object, the actual value is\n // // equivalent if it is also a Date object that refers to the same time.\n } else if (actual instanceof Date && expected instanceof Date) {\n return actual.getTime() === expected.getTime();\n\n // 7.3 If the expected value is a RegExp object, the actual value is\n // equivalent if it is also a RegExp object with the same source and\n // properties (`global`, `multiline`, `lastIndex`, `ignoreCase`).\n } else if (actual instanceof RegExp && expected instanceof RegExp) {\n return (\n actual.source === expected.source &&\n actual.global === expected.global &&\n actual.multiline === expected.multiline &&\n actual.lastIndex === expected.lastIndex &&\n actual.ignoreCase === expected.ignoreCase\n );\n\n // 7.4. Other pairs that do not both pass typeof value == 'object',\n // equivalence is determined by ==.\n } else if (\n (actual === null || typeof actual !== 'object') &&\n (expected === null || typeof expected !== 'object')\n ) {\n // eslint-disable-next-line eqeqeq\n return strict ? actual === expected : actual == expected;\n\n // 7.5 For all other Object pairs, including Array objects, equivalence is\n // determined by having the same number of owned properties (as verified\n // with Object.prototype.hasOwnProperty.call), the same set of keys\n // (although not necessarily the same order), equivalent values for every\n // corresponding key, and an identical 'prototype' property. Note: this\n // accounts for both named and indexed properties on Arrays.\n }\n return objEquiv(actual, expected, strict);\n}\n\n// eslint-disable-next-line @typescript-eslint/unbound-method\nconst pSlice = Array.prototype.slice;\n\nfunction isPrimitive(arg) {\n return arg === null || (typeof arg !== 'object' && typeof arg !== 'function');\n}\n\nfunction isArguments(object) {\n // eslint-disable-next-line eqeqeq\n return Object.prototype.toString.call(object) == '[object Arguments]';\n}\n\n// eslint-disable-next-line complexity\nfunction objEquiv(a: unknown, b: unknown, strict) {\n if (a === null || a === undefined || b === null || b === undefined) return false;\n // if one is a primitive, the other must be same\n if (isPrimitive(a) || isPrimitive(b)) return a === b;\n if (strict && Object.getPrototypeOf(a) !== Object.getPrototypeOf(b)) return false;\n const aIsArgs = isArguments(a);\n const bIsArgs = isArguments(b);\n if ((aIsArgs && !bIsArgs) || (!aIsArgs && bIsArgs)) return false;\n if (aIsArgs) {\n a = pSlice.call(a);\n b = pSlice.call(b);\n return deepStrictEqual(a, b, strict);\n }\n const ka = Object.keys(a);\n const kb = Object.keys(b);\n let key;\n let i;\n // having the same number of owned properties (keys incorporates\n // hasOwnProperty)\n if (ka.length !== kb.length) return false;\n // the same set of keys (although not necessarily the same order),\n ka.sort();\n kb.sort();\n // ~~~cheap key test\n for (i = ka.length - 1; i >= 0; i--) {\n if (ka[i] !== kb[i]) return false;\n }\n // equivalent values for every corresponding key, and\n // ~~~possibly expensive deep test\n for (i = ka.length - 1; i >= 0; i--) {\n key = ka[i];\n if (!deepStrictEqual(a[key], b[key], strict)) return false;\n }\n return true;\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"deep-strict-equal.js","names":["deepStrictEqual","actual","expected","strict","Date","getTime","RegExp","source","global","multiline","lastIndex","ignoreCase","_typeof2","default","objEquiv","pSlice","Array","prototype","slice","isPrimitive","arg","isArguments","object","Object","toString","call","a","b","undefined","getPrototypeOf","aIsArgs","bIsArgs","ka","keys","kb","key","i","length","sort"],"sources":["../../../../../src/lib/parsers/gml/deep-strict-equal.ts"],"sourcesContent":["// https://github.com/nodejs/node/commit/c1d82ac2ff15594840e2a1b9531b506ae067ed27;\n\n// http://wiki.commonjs.org/wiki/Unit_Testing/1.0\n//\n// THIS IS NOT TESTED NOR LIKELY TO WORK OUTSIDE V8!\n//\n// Originally from narwhal.js (http://narwhaljs.org)\n// Copyright (c) 2009 Thomas Robinson <280north.com>\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the 'Software'), to\n// deal in the Software without restriction, including without limitation the\n// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n// sell copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN\n// ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION\n// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n/** @todo replace this ridiculous choice of deepStrictEqual */\n// eslint-disable-next-line complexity\nexport function deepStrictEqual(actual: unknown, expected: unknown, strict?: boolean) {\n // 7.1. All identical values are equivalent, as determined by ===.\n if (actual === expected) {\n return true;\n // } else if (actual instanceof Buffer && expected instanceof Buffer) {\n // return compare(actual, expected) === 0;\n\n // // 7.2. If the expected value is a Date object, the actual value is\n // // equivalent if it is also a Date object that refers to the same time.\n } else if (actual instanceof Date && expected instanceof Date) {\n return actual.getTime() === expected.getTime();\n\n // 7.3 If the expected value is a RegExp object, the actual value is\n // equivalent if it is also a RegExp object with the same source and\n // properties (`global`, `multiline`, `lastIndex`, `ignoreCase`).\n } else if (actual instanceof RegExp && expected instanceof RegExp) {\n return (\n actual.source === expected.source &&\n actual.global === expected.global &&\n actual.multiline === expected.multiline &&\n actual.lastIndex === expected.lastIndex &&\n actual.ignoreCase === expected.ignoreCase\n );\n\n // 7.4. Other pairs that do not both pass typeof value == 'object',\n // equivalence is determined by ==.\n } else if (\n (actual === null || typeof actual !== 'object') &&\n (expected === null || typeof expected !== 'object')\n ) {\n // eslint-disable-next-line eqeqeq\n return strict ? actual === expected : actual == expected;\n\n // 7.5 For all other Object pairs, including Array objects, equivalence is\n // determined by having the same number of owned properties (as verified\n // with Object.prototype.hasOwnProperty.call), the same set of keys\n // (although not necessarily the same order), equivalent values for every\n // corresponding key, and an identical 'prototype' property. Note: this\n // accounts for both named and indexed properties on Arrays.\n }\n return objEquiv(actual, expected, strict);\n}\n\n// eslint-disable-next-line @typescript-eslint/unbound-method\nconst pSlice = Array.prototype.slice;\n\nfunction isPrimitive(arg) {\n return arg === null || (typeof arg !== 'object' && typeof arg !== 'function');\n}\n\nfunction isArguments(object) {\n // eslint-disable-next-line eqeqeq\n return Object.prototype.toString.call(object) == '[object Arguments]';\n}\n\n// eslint-disable-next-line complexity\nfunction objEquiv(a: unknown, b: unknown, strict) {\n if (a === null || a === undefined || b === null || b === undefined) return false;\n // if one is a primitive, the other must be same\n if (isPrimitive(a) || isPrimitive(b)) return a === b;\n if (strict && Object.getPrototypeOf(a) !== Object.getPrototypeOf(b)) return false;\n const aIsArgs = isArguments(a);\n const bIsArgs = isArguments(b);\n if ((aIsArgs && !bIsArgs) || (!aIsArgs && bIsArgs)) return false;\n if (aIsArgs) {\n a = pSlice.call(a);\n b = pSlice.call(b);\n return deepStrictEqual(a, b, strict);\n }\n const ka = Object.keys(a);\n const kb = Object.keys(b);\n let key;\n let i;\n // having the same number of owned properties (keys incorporates\n // hasOwnProperty)\n if (ka.length !== kb.length) return false;\n // the same set of keys (although not necessarily the same order),\n ka.sort();\n kb.sort();\n // ~~~cheap key test\n for (i = ka.length - 1; i >= 0; i--) {\n if (ka[i] !== kb[i]) return false;\n }\n // equivalent values for every corresponding key, and\n // ~~~possibly expensive deep test\n for (i = ka.length - 1; i >= 0; i--) {\n key = ka[i];\n if (!deepStrictEqual(a[key], b[key], strict)) return false;\n }\n return true;\n}\n"],"mappings":"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"}
@@ -26,7 +26,7 @@ var _deepStrictEqual = require("./deep-strict-equal");
26
26
  var _rewind = _interopRequireDefault(require("@turf/rewind"));
27
27
  function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
28
28
  function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
29
- function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
29
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
30
30
  function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
31
31
  function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
32
32
  function noTransform() {
@@ -44,7 +44,6 @@ function parseGML(text, options) {
44
44
  var context = createChildContext(parsedXML, options, {});
45
45
  return parseGMLToGeometry(parsedXML, options, context);
46
46
  }
47
-
48
47
  function parseGMLToGeometry(inputXML, options, context) {
49
48
  var childContext = createChildContext(inputXML, options, context);
50
49
  var geometry = null;
@@ -53,14 +52,12 @@ function parseGMLToGeometry(inputXML, options, context) {
53
52
  name = _getFirstKeyValue2[0],
54
53
  xml = _getFirstKeyValue2[1];
55
54
  switch (name) {
56
-
57
55
  case 'gml:LineString':
58
56
  geometry = {
59
57
  type: 'LineString',
60
58
  coordinates: parseLinearRingOrLineString(xml, options, childContext)
61
59
  };
62
60
  break;
63
-
64
61
  case 'gml:Polygon':
65
62
  case 'gml:Rectangle':
66
63
  geometry = {
@@ -83,15 +80,12 @@ function parseGMLToGeometry(inputXML, options, context) {
83
80
  default:
84
81
  return null;
85
82
  }
86
-
87
83
  return (0, _rewind.default)(geometry, {
88
84
  mutate: true
89
85
  });
90
86
  }
91
-
92
87
  function parseCoords(s, options, context) {
93
88
  var stride = context.srsDimension || options.stride || 2;
94
-
95
89
  var coords = s.replace(/\s+/g, ' ').trim().split(' ');
96
90
  if (coords.length === 0 || coords.length % stride !== 0) {
97
91
  throw new Error("invalid coordinates list (stride ".concat(stride, ")"));
@@ -126,7 +120,6 @@ function parsePos(xml, options, context) {
126
120
  }
127
121
  function parsePoint(xml, options, context) {
128
122
  var childContext = createChildContext(xml, options, context);
129
-
130
123
  var pos = findIn(xml, 'gml:pos');
131
124
  if (!pos) {
132
125
  throw new Error('invalid gml:Point element, expected a gml:pos subelement');
@@ -170,7 +163,6 @@ function parseCurveSegments(xml, options, context) {
170
163
  switch (childName) {
171
164
  case 'gml:LineStringSegment':
172
165
  var points2 = parseLinearRingOrLineString(childXML, options, context);
173
-
174
166
  var end = points[points.length - 1];
175
167
  var start = points2[0];
176
168
  if (end && start && (0, _deepStrictEqual.deepStrictEqual)(end, start)) {
@@ -207,7 +199,6 @@ function parseRing(xml, options, context) {
207
199
  }
208
200
  points2 = parseCurveSegments(segments, options, childContext);
209
201
  }
210
-
211
202
  var end = points[points.length - 1];
212
203
  var start = points2[0];
213
204
  if (end && start && (0, _deepStrictEqual.deepStrictEqual)(end, start)) {
@@ -365,7 +356,6 @@ function parseSurfaceMember(xml, options, context) {
365
356
  }
366
357
  throw new Error("".concat(childName, " must have polygons"));
367
358
  }
368
-
369
359
  function textOf(el) {
370
360
  if (typeof el !== 'string') {
371
361
  throw new Error('expected string');
@@ -387,7 +377,6 @@ function findIn(root) {
387
377
  }
388
378
  return el;
389
379
  }
390
-
391
380
  function getFirstKeyValue(object) {
392
381
  if (object && (0, _typeof2.default)(object) === 'object') {
393
382
  for (var _i9 = 0, _Object$entries8 = Object.entries(object); _i9 < _Object$entries8.length; _i9++) {
@@ -399,7 +388,6 @@ function getFirstKeyValue(object) {
399
388
  }
400
389
  return ['', null];
401
390
  }
402
-
403
391
  function createChildContext(xml, options, context) {
404
392
  var srsDimensionAttribute = xml.attributes && xml.attributes.srsDimension;
405
393
  if (srsDimensionAttribute) {
@@ -1 +1 @@
1
- {"version":3,"file":"parse-gml.js","names":["noTransform","coords","parseGML","text","options","parsedXML","XMLLoader","parseTextSync","transformCoords","stride","context","createChildContext","parseGMLToGeometry","inputXML","childContext","geometry","getFirstKeyValue","name","xml","type","coordinates","parseLinearRingOrLineString","parsePolygonOrRectangle","parseSurface","parseMultiSurface","rewind","mutate","parseCoords","s","srsDimension","replace","trim","split","length","Error","points","i","point","slice","map","parseFloat","push","parsePosList","textOf","parsePos","parsePoint","pos","findIn","posList","Object","entries","childName","childXML","parseCurveSegments","points2","end","start","deepStrictEqual","shift","parseRing","lineString","segments","parseExteriorOrInterior","linearRing","ring","exterior","pointLists","patches","polygons","parseCompositeSurface","c2Name","c2Xml","el","surfaceMembers","polygons2","polygons3","parseSurfaceMember","polygonXML","surfaceMemberXML","childXml","root","tags","tag","child","object","key","value","srsDimensionAttribute","attributes","parseInt","Number","isNaN","create"],"sources":["../../../../../src/lib/parsers/gml/parse-gml.ts"],"sourcesContent":["// loaders.gl, MIT license\n\n// Forked from https://github.com/derhuerst/parse-gml-polygon/blob/master/index.js\n// under ISC license\n\n/* eslint-disable no-continue, default-case */\n\nimport type {\n // GeoJSON,\n // Feature,\n // FeatureCollection,\n Geometry,\n Position\n // GeoJsonProperties,\n // Point,\n // MultiPoint,\n // LineString,\n // MultiLineString,\n // Polygon,\n // MultiPolygon,\n // GeometryCollection\n} from '@loaders.gl/schema';\n\nimport {XMLLoader} from '@loaders.gl/xml';\nimport {deepStrictEqual} from './deep-strict-equal';\nimport rewind from '@turf/rewind';\n\nfunction noTransform(...coords) {\n return coords;\n}\n\nexport type ParseGMLOptions = {\n transformCoords?: Function;\n stride?: 2 | 3 | 4;\n};\n\nexport type ParseGMLContext = {\n srsDimension?: number;\n [key: string]: any;\n};\n\n/**\n * Parses a typed data structure from raw XML for GML features\n * @note Error handlings is fairly weak\n */\nexport function parseGML(text: string, options) {\n // GeoJSON | null {\n const parsedXML = XMLLoader.parseTextSync(text, options);\n\n options = {transformCoords: noTransform, stride: 2, ...options};\n const context = createChildContext(parsedXML, options, {});\n\n return parseGMLToGeometry(parsedXML, options, context);\n}\n\n/** Parse a GeoJSON geometry from GML XML */\nexport function parseGMLToGeometry(\n inputXML: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Geometry | null {\n const childContext = createChildContext(inputXML, options, context);\n\n let geometry: Geometry | null = null;\n\n const [name, xml] = getFirstKeyValue(inputXML);\n\n switch (name) {\n // case 'gml:MultiPoint':\n // geometry = {\n // type: 'MultiPoint',\n // coordinates: parseMultiPoint(xml, options, childContext)\n // };\n // break;\n\n case 'gml:LineString':\n geometry = {\n type: 'LineString',\n coordinates: parseLinearRingOrLineString(xml, options, childContext)\n };\n break;\n\n // case 'gml:MultiLineString':\n // geometry = {\n // type: 'MultiLineString',\n // coordinates: parseMultiLineString(xml, options, childContext)\n // };\n // break;\n\n case 'gml:Polygon':\n case 'gml:Rectangle':\n geometry = {\n type: 'Polygon',\n coordinates: parsePolygonOrRectangle(xml, options, childContext)\n };\n break;\n case 'gml:Surface':\n geometry = {\n type: 'MultiPolygon',\n coordinates: parseSurface(xml, options, childContext)\n };\n break;\n case 'gml:MultiSurface':\n geometry = {\n type: 'MultiPolygon',\n coordinates: parseMultiSurface(xml, options, childContext)\n };\n break;\n\n default:\n return null;\n }\n\n // todo\n return rewind(geometry, {mutate: true});\n}\n\n/** Parse a list of coordinates from a string */\nfunction parseCoords(s: string, options: ParseGMLOptions, context: ParseGMLContext): Position[] {\n const stride = context.srsDimension || options.stride || 2;\n\n // Handle white space\n const coords = s.replace(/\\s+/g, ' ').trim().split(' ');\n\n if (coords.length === 0 || coords.length % stride !== 0) {\n throw new Error(`invalid coordinates list (stride ${stride})`);\n }\n\n const points: Position[] = [];\n for (let i = 0; i < coords.length - 1; i += stride) {\n const point = coords.slice(i, i + stride).map(parseFloat);\n points.push(options.transformCoords?.(...point) || point);\n }\n\n return points;\n}\n\nexport function parsePosList(xml: any, options: ParseGMLOptions, context: ParseGMLContext) {\n const childContext = createChildContext(xml, options, context);\n\n const coords = textOf(xml);\n if (!coords) {\n throw new Error('invalid gml:posList element');\n }\n\n return parseCoords(coords, options, childContext);\n}\n\nexport function parsePos(xml: any, options: ParseGMLOptions, context: ParseGMLContext): Position {\n const childContext = createChildContext(xml, options, context);\n\n const coords = textOf(xml);\n if (!coords) {\n throw new Error('invalid gml:pos element');\n }\n\n const points = parseCoords(coords, options, childContext);\n if (points.length !== 1) {\n throw new Error('gml:pos must have 1 point');\n }\n return points[0];\n}\n\nexport function parsePoint(xml: any, options: ParseGMLOptions, context: ParseGMLContext): number[] {\n const childContext = createChildContext(xml, options, context);\n\n // TODO AV: Parse other gml:Point options\n const pos = findIn(xml, 'gml:pos');\n if (!pos) {\n throw new Error('invalid gml:Point element, expected a gml:pos subelement');\n }\n return parsePos(pos, options, childContext);\n}\n\nexport function parseLinearRingOrLineString(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n // or a LineStringSegment\n const childContext = createChildContext(xml, options, context);\n\n let points: Position[] = [];\n\n const posList = findIn(xml, 'gml:posList');\n if (posList) {\n points = parsePosList(posList, options, childContext);\n } else {\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:Point':\n points.push(parsePoint(childXML, options, childContext));\n break;\n case 'gml:pos':\n points.push(parsePos(childXML, options, childContext));\n break;\n default:\n continue;\n }\n }\n }\n\n if (points.length === 0) {\n throw new Error(`${xml.name} must have > 0 points`);\n }\n return points;\n}\n\nexport function parseCurveSegments(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const points: Position[] = [];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:LineStringSegment':\n const points2 = parseLinearRingOrLineString(childXML, options, context);\n\n // remove overlapping\n const end = points[points.length - 1];\n const start = points2[0];\n if (end && start && deepStrictEqual(end, start)) {\n points2.shift();\n }\n\n points.push(...points2);\n break;\n default:\n continue;\n }\n }\n\n if (points.length === 0) {\n throw new Error('gml:Curve > gml:segments must have > 0 points');\n }\n return points;\n}\n\nexport function parseRing(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const childContext = createChildContext(xml, options, context);\n\n const points: Position[] = [];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:curveMember':\n let points2;\n\n const lineString = findIn(childXML, 'gml:LineString');\n if (lineString) {\n points2 = parseLinearRingOrLineString(lineString, options, childContext);\n } else {\n const segments = findIn(childXML, 'gml:Curve', 'gml:segments');\n if (!segments) {\n throw new Error(`invalid ${childName} element`);\n }\n\n points2 = parseCurveSegments(segments, options, childContext);\n }\n\n // remove overlapping\n const end = points[points.length - 1];\n const start = points2[0];\n if (end && start && deepStrictEqual(end, start)) {\n points2.shift();\n }\n\n points.push(...points2);\n\n break;\n }\n }\n\n if (points.length < 4) {\n throw new Error(`${xml.name} must have >= 4 points`);\n }\n return points;\n}\n\nexport function parseExteriorOrInterior(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const linearRing = findIn(xml, 'gml:LinearRing');\n if (linearRing) {\n return parseLinearRingOrLineString(linearRing, options, context);\n }\n\n const ring = findIn(xml, 'gml:Ring');\n if (!ring) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n return parseRing(ring, options, context);\n}\n\nexport function parsePolygonOrRectangle(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][] {\n // or PolygonPatch\n const childContext = createChildContext(xml, options, context);\n\n const exterior = findIn(xml, 'gml:exterior');\n if (!exterior) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n const pointLists: Position[][] = [parseExteriorOrInterior(exterior, options, childContext)];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:interior':\n pointLists.push(parseExteriorOrInterior(childXML, options, childContext));\n break;\n }\n }\n\n return pointLists;\n}\n\nexport function parseSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const childContext = createChildContext(xml, options, context);\n\n const patches = findIn(xml, 'gml:patches');\n if (!patches) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:PolygonPatch':\n case 'gml:Rectangle':\n polygons.push(parsePolygonOrRectangle(childXML, options, childContext));\n break;\n\n default:\n continue;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n\n return polygons;\n}\n\nexport function parseCompositeSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const childContext = createChildContext(xml, options, context);\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:surfaceMember':\n case 'gml:surfaceMembers':\n const [c2Name, c2Xml] = getFirstKeyValue(childXML);\n switch (c2Name) {\n case 'gml:Surface':\n polygons.push(...parseSurface(c2Xml, options, childContext));\n break;\n case 'gml:Polygon':\n polygons.push(parsePolygonOrRectangle(c2Xml, options, childContext));\n break;\n }\n break;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n return polygons;\n}\n\nexport function parseMultiSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n let el = xml;\n\n const surfaceMembers = findIn(xml, 'gml:LinearRing');\n if (surfaceMembers) {\n el = surfaceMembers;\n }\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(el)) {\n switch (childName) {\n case 'gml:Surface':\n const polygons2 = parseSurface(childXML, options, context);\n polygons.push(...polygons2);\n break;\n case 'gml:surfaceMember':\n const polygons3 = parseSurfaceMember(childXML, options, context);\n polygons.push(...polygons3);\n break;\n\n case 'gml:surfaceMembers':\n const polygonXML = findIn(childXML, 'gml:Polygon');\n for (const surfaceMemberXML of polygonXML as []) {\n const polygons3 = parseSurfaceMember(surfaceMemberXML, options, context);\n polygons.push(...polygons3);\n }\n break;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n\n return polygons;\n}\n\nfunction parseSurfaceMember(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const [childName, childXml] = getFirstKeyValue(xml);\n switch (childName) {\n case 'gml:CompositeSurface':\n return parseCompositeSurface(childXml, options, context);\n case 'gml:Surface':\n return parseSurface(childXml, options, context);\n case 'gml:Polygon':\n return [parsePolygonOrRectangle(childXml, options, context)];\n }\n throw new Error(`${childName} must have polygons`);\n}\n\n// Helpers\n\nfunction textOf(el: any): string {\n if (typeof el !== 'string') {\n throw new Error('expected string');\n }\n return el;\n}\n\nfunction findIn(root: any, ...tags: string[]): any {\n let el = root;\n for (const tag of tags) {\n const child = el[tag];\n if (!child) {\n return null;\n }\n el = child;\n }\n return el;\n}\n\n/** @returns the first [key, value] pair in an object, or ['', null] if empty object */\nfunction getFirstKeyValue(object: any): [string, any] {\n if (object && typeof object === 'object') {\n for (const [key, value] of Object.entries(object)) {\n return [key, value];\n }\n }\n return ['', null];\n}\n\n/** A bit heavyweight for just tracking dimension? */\nfunction createChildContext(xml, options, context): ParseGMLContext {\n const srsDimensionAttribute = xml.attributes && xml.attributes.srsDimension;\n\n if (srsDimensionAttribute) {\n const srsDimension = parseInt(srsDimensionAttribute);\n if (Number.isNaN(srsDimension) || srsDimension <= 0) {\n throw new Error(\n `invalid srsDimension attribute value \"${srsDimensionAttribute}\", expected a positive integer`\n );\n }\n\n const childContext = Object.create(context);\n childContext.srsDimension = srsDimension;\n return childContext;\n }\n\n return context;\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"parse-gml.js","names":["_xml","require","_deepStrictEqual","_rewind","_interopRequireDefault","_createForOfIteratorHelper","o","allowArrayLike","it","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","i","F","s","n","done","value","e","_e","f","TypeError","normalCompletion","didErr","err","call","step","next","_e2","return","minLen","_arrayLikeToArray","Object","prototype","toString","slice","constructor","name","from","test","arr","len","arr2","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","arguments","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","noTransform","_len","coords","_key","parseGML","text","options","parsedXML","XMLLoader","parseTextSync","transformCoords","stride","context","createChildContext","parseGMLToGeometry","inputXML","childContext","geometry","_getFirstKeyValue","getFirstKeyValue","_getFirstKeyValue2","_slicedToArray2","xml","type","coordinates","parseLinearRingOrLineString","parsePolygonOrRectangle","parseSurface","parseMultiSurface","rewind","mutate","parseCoords","srsDimension","replace","trim","split","Error","concat","points","_options$transformCoo","_options$transformCoo2","point","map","parseFloat","_toConsumableArray2","parsePosList","textOf","parsePos","parsePoint","pos","findIn","posList","_i","_Object$entries","entries","_Object$entries$_i","childName","childXML","parseCurveSegments","_i2","_Object$entries2","_Object$entries2$_i","points2","end","start","deepStrictEqual","shift","parseRing","_i3","_Object$entries3","_Object$entries3$_i","lineString","segments","parseExteriorOrInterior","linearRing","ring","exterior","pointLists","_i4","_Object$entries4","_Object$entries4$_i","patches","polygons","_i5","_Object$entries5","_Object$entries5$_i","parseCompositeSurface","_i6","_Object$entries6","_Object$entries6$_i","_getFirstKeyValue3","_getFirstKeyValue4","c2Name","c2Xml","el","surfaceMembers","_i7","_Object$entries7","_Object$entries7$_i","polygons2","polygons3","parseSurfaceMember","polygonXML","_iterator","_step","surfaceMemberXML","_getFirstKeyValue5","_getFirstKeyValue6","childXml","root","_len2","tags","_key2","_i8","_tags","tag","child","_typeof2","_i9","_Object$entries8","_Object$entries8$_i","srsDimensionAttribute","attributes","parseInt","Number","isNaN","create"],"sources":["../../../../../src/lib/parsers/gml/parse-gml.ts"],"sourcesContent":["// loaders.gl, MIT license\n\n// Forked from https://github.com/derhuerst/parse-gml-polygon/blob/master/index.js\n// under ISC license\n\n/* eslint-disable no-continue, default-case */\n\nimport type {\n // GeoJSON,\n // Feature,\n // FeatureCollection,\n Geometry,\n Position\n // GeoJsonProperties,\n // Point,\n // MultiPoint,\n // LineString,\n // MultiLineString,\n // Polygon,\n // MultiPolygon,\n // GeometryCollection\n} from '@loaders.gl/schema';\n\nimport {XMLLoader} from '@loaders.gl/xml';\nimport {deepStrictEqual} from './deep-strict-equal';\nimport rewind from '@turf/rewind';\n\nfunction noTransform(...coords) {\n return coords;\n}\n\nexport type ParseGMLOptions = {\n transformCoords?: Function;\n stride?: 2 | 3 | 4;\n};\n\nexport type ParseGMLContext = {\n srsDimension?: number;\n [key: string]: any;\n};\n\n/**\n * Parses a typed data structure from raw XML for GML features\n * @note Error handlings is fairly weak\n */\nexport function parseGML(text: string, options) {\n // GeoJSON | null {\n const parsedXML = XMLLoader.parseTextSync(text, options);\n\n options = {transformCoords: noTransform, stride: 2, ...options};\n const context = createChildContext(parsedXML, options, {});\n\n return parseGMLToGeometry(parsedXML, options, context);\n}\n\n/** Parse a GeoJSON geometry from GML XML */\nexport function parseGMLToGeometry(\n inputXML: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Geometry | null {\n const childContext = createChildContext(inputXML, options, context);\n\n let geometry: Geometry | null = null;\n\n const [name, xml] = getFirstKeyValue(inputXML);\n\n switch (name) {\n // case 'gml:MultiPoint':\n // geometry = {\n // type: 'MultiPoint',\n // coordinates: parseMultiPoint(xml, options, childContext)\n // };\n // break;\n\n case 'gml:LineString':\n geometry = {\n type: 'LineString',\n coordinates: parseLinearRingOrLineString(xml, options, childContext)\n };\n break;\n\n // case 'gml:MultiLineString':\n // geometry = {\n // type: 'MultiLineString',\n // coordinates: parseMultiLineString(xml, options, childContext)\n // };\n // break;\n\n case 'gml:Polygon':\n case 'gml:Rectangle':\n geometry = {\n type: 'Polygon',\n coordinates: parsePolygonOrRectangle(xml, options, childContext)\n };\n break;\n case 'gml:Surface':\n geometry = {\n type: 'MultiPolygon',\n coordinates: parseSurface(xml, options, childContext)\n };\n break;\n case 'gml:MultiSurface':\n geometry = {\n type: 'MultiPolygon',\n coordinates: parseMultiSurface(xml, options, childContext)\n };\n break;\n\n default:\n return null;\n }\n\n // todo\n return rewind(geometry, {mutate: true});\n}\n\n/** Parse a list of coordinates from a string */\nfunction parseCoords(s: string, options: ParseGMLOptions, context: ParseGMLContext): Position[] {\n const stride = context.srsDimension || options.stride || 2;\n\n // Handle white space\n const coords = s.replace(/\\s+/g, ' ').trim().split(' ');\n\n if (coords.length === 0 || coords.length % stride !== 0) {\n throw new Error(`invalid coordinates list (stride ${stride})`);\n }\n\n const points: Position[] = [];\n for (let i = 0; i < coords.length - 1; i += stride) {\n const point = coords.slice(i, i + stride).map(parseFloat);\n points.push(options.transformCoords?.(...point) || point);\n }\n\n return points;\n}\n\nexport function parsePosList(xml: any, options: ParseGMLOptions, context: ParseGMLContext) {\n const childContext = createChildContext(xml, options, context);\n\n const coords = textOf(xml);\n if (!coords) {\n throw new Error('invalid gml:posList element');\n }\n\n return parseCoords(coords, options, childContext);\n}\n\nexport function parsePos(xml: any, options: ParseGMLOptions, context: ParseGMLContext): Position {\n const childContext = createChildContext(xml, options, context);\n\n const coords = textOf(xml);\n if (!coords) {\n throw new Error('invalid gml:pos element');\n }\n\n const points = parseCoords(coords, options, childContext);\n if (points.length !== 1) {\n throw new Error('gml:pos must have 1 point');\n }\n return points[0];\n}\n\nexport function parsePoint(xml: any, options: ParseGMLOptions, context: ParseGMLContext): number[] {\n const childContext = createChildContext(xml, options, context);\n\n // TODO AV: Parse other gml:Point options\n const pos = findIn(xml, 'gml:pos');\n if (!pos) {\n throw new Error('invalid gml:Point element, expected a gml:pos subelement');\n }\n return parsePos(pos, options, childContext);\n}\n\nexport function parseLinearRingOrLineString(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n // or a LineStringSegment\n const childContext = createChildContext(xml, options, context);\n\n let points: Position[] = [];\n\n const posList = findIn(xml, 'gml:posList');\n if (posList) {\n points = parsePosList(posList, options, childContext);\n } else {\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:Point':\n points.push(parsePoint(childXML, options, childContext));\n break;\n case 'gml:pos':\n points.push(parsePos(childXML, options, childContext));\n break;\n default:\n continue;\n }\n }\n }\n\n if (points.length === 0) {\n throw new Error(`${xml.name} must have > 0 points`);\n }\n return points;\n}\n\nexport function parseCurveSegments(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const points: Position[] = [];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:LineStringSegment':\n const points2 = parseLinearRingOrLineString(childXML, options, context);\n\n // remove overlapping\n const end = points[points.length - 1];\n const start = points2[0];\n if (end && start && deepStrictEqual(end, start)) {\n points2.shift();\n }\n\n points.push(...points2);\n break;\n default:\n continue;\n }\n }\n\n if (points.length === 0) {\n throw new Error('gml:Curve > gml:segments must have > 0 points');\n }\n return points;\n}\n\nexport function parseRing(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const childContext = createChildContext(xml, options, context);\n\n const points: Position[] = [];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:curveMember':\n let points2;\n\n const lineString = findIn(childXML, 'gml:LineString');\n if (lineString) {\n points2 = parseLinearRingOrLineString(lineString, options, childContext);\n } else {\n const segments = findIn(childXML, 'gml:Curve', 'gml:segments');\n if (!segments) {\n throw new Error(`invalid ${childName} element`);\n }\n\n points2 = parseCurveSegments(segments, options, childContext);\n }\n\n // remove overlapping\n const end = points[points.length - 1];\n const start = points2[0];\n if (end && start && deepStrictEqual(end, start)) {\n points2.shift();\n }\n\n points.push(...points2);\n\n break;\n }\n }\n\n if (points.length < 4) {\n throw new Error(`${xml.name} must have >= 4 points`);\n }\n return points;\n}\n\nexport function parseExteriorOrInterior(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const linearRing = findIn(xml, 'gml:LinearRing');\n if (linearRing) {\n return parseLinearRingOrLineString(linearRing, options, context);\n }\n\n const ring = findIn(xml, 'gml:Ring');\n if (!ring) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n return parseRing(ring, options, context);\n}\n\nexport function parsePolygonOrRectangle(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][] {\n // or PolygonPatch\n const childContext = createChildContext(xml, options, context);\n\n const exterior = findIn(xml, 'gml:exterior');\n if (!exterior) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n const pointLists: Position[][] = [parseExteriorOrInterior(exterior, options, childContext)];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:interior':\n pointLists.push(parseExteriorOrInterior(childXML, options, childContext));\n break;\n }\n }\n\n return pointLists;\n}\n\nexport function parseSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const childContext = createChildContext(xml, options, context);\n\n const patches = findIn(xml, 'gml:patches');\n if (!patches) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:PolygonPatch':\n case 'gml:Rectangle':\n polygons.push(parsePolygonOrRectangle(childXML, options, childContext));\n break;\n\n default:\n continue;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n\n return polygons;\n}\n\nexport function parseCompositeSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const childContext = createChildContext(xml, options, context);\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:surfaceMember':\n case 'gml:surfaceMembers':\n const [c2Name, c2Xml] = getFirstKeyValue(childXML);\n switch (c2Name) {\n case 'gml:Surface':\n polygons.push(...parseSurface(c2Xml, options, childContext));\n break;\n case 'gml:Polygon':\n polygons.push(parsePolygonOrRectangle(c2Xml, options, childContext));\n break;\n }\n break;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n return polygons;\n}\n\nexport function parseMultiSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n let el = xml;\n\n const surfaceMembers = findIn(xml, 'gml:LinearRing');\n if (surfaceMembers) {\n el = surfaceMembers;\n }\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(el)) {\n switch (childName) {\n case 'gml:Surface':\n const polygons2 = parseSurface(childXML, options, context);\n polygons.push(...polygons2);\n break;\n case 'gml:surfaceMember':\n const polygons3 = parseSurfaceMember(childXML, options, context);\n polygons.push(...polygons3);\n break;\n\n case 'gml:surfaceMembers':\n const polygonXML = findIn(childXML, 'gml:Polygon');\n for (const surfaceMemberXML of polygonXML as []) {\n const polygons3 = parseSurfaceMember(surfaceMemberXML, options, context);\n polygons.push(...polygons3);\n }\n break;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n\n return polygons;\n}\n\nfunction parseSurfaceMember(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const [childName, childXml] = getFirstKeyValue(xml);\n switch (childName) {\n case 'gml:CompositeSurface':\n return parseCompositeSurface(childXml, options, context);\n case 'gml:Surface':\n return parseSurface(childXml, options, context);\n case 'gml:Polygon':\n return [parsePolygonOrRectangle(childXml, options, context)];\n }\n throw new Error(`${childName} must have polygons`);\n}\n\n// Helpers\n\nfunction textOf(el: any): string {\n if (typeof el !== 'string') {\n throw new Error('expected string');\n }\n return el;\n}\n\nfunction findIn(root: any, ...tags: string[]): any {\n let el = root;\n for (const tag of tags) {\n const child = el[tag];\n if (!child) {\n return null;\n }\n el = child;\n }\n return el;\n}\n\n/** @returns the first [key, value] pair in an object, or ['', null] if empty object */\nfunction getFirstKeyValue(object: any): [string, any] {\n if (object && typeof object === 'object') {\n for (const [key, value] of Object.entries(object)) {\n return [key, value];\n }\n }\n return ['', null];\n}\n\n/** A bit heavyweight for just tracking dimension? */\nfunction createChildContext(xml, options, context): ParseGMLContext {\n const srsDimensionAttribute = xml.attributes && xml.attributes.srsDimension;\n\n if (srsDimensionAttribute) {\n const srsDimension = parseInt(srsDimensionAttribute);\n if (Number.isNaN(srsDimension) || srsDimension <= 0) {\n throw new Error(\n `invalid srsDimension attribute value \"${srsDimensionAttribute}\", expected a positive integer`\n );\n }\n\n const childContext = Object.create(context);\n childContext.srsDimension = srsDimension;\n return childContext;\n }\n\n return context;\n}\n"],"mappings":"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"}
@@ -5,90 +5,233 @@ Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
7
  exports.parseWMSCapabilities = parseWMSCapabilities;
8
+ var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
8
9
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
9
10
  var _xml = require("@loaders.gl/xml");
11
+ var _parseXmlHelpers = require("../xml/parse-xml-helpers");
10
12
  function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
11
13
  function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
12
- function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
13
-
14
- function parseWMSCapabilities(text, options) {
15
- var parsedXML = _xml.XMLLoader.parseTextSync(text, options);
14
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
15
+ function parseWMSCapabilities(xmlText, options) {
16
+ var parsedXML = _xml.XMLLoader.parseTextSync(xmlText, options);
16
17
  var xmlCapabilities = parsedXML.WMT_MS_Capabilities || parsedXML.WMS_Capabilities || parsedXML;
17
- return extractCapabilities(xmlCapabilities);
18
+ var capabilities = extractCapabilities(xmlCapabilities);
19
+ if (options !== null && options !== void 0 && options.inheritedLayerProps) {
20
+ var _iterator = _createForOfIteratorHelper(capabilities.layers),
21
+ _step;
22
+ try {
23
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
24
+ var layer = _step.value;
25
+ addInheritedLayerProps(layer, null);
26
+ }
27
+ } catch (err) {
28
+ _iterator.e(err);
29
+ } finally {
30
+ _iterator.f();
31
+ }
32
+ }
33
+ if (options !== null && options !== void 0 && options.includeRawData || options !== null && options !== void 0 && options.raw) {
34
+ capabilities.raw = xmlCapabilities;
35
+ }
36
+ if (options !== null && options !== void 0 && options.includeXMLText) {
37
+ capabilities.xml = xmlText;
38
+ }
39
+ return capabilities;
18
40
  }
19
-
20
41
  function extractCapabilities(xml) {
21
- var _xml$Service, _xml$Service2, _xml$Capability, _xml$Service3, _xml$Service3$Keyword;
42
+ var _xml$Service, _xml$Service2, _xml$Service3, _xml$Service4, _xml$Service5, _xml$Service6, _xml$Service6$Keyword, _xml$Service7, _xml$Service8, _xml$Service9, _xml$Service10, _xml$Service11, _xml$Service12, _xml$Service13, _xml$Capability, _xml$Capability2;
22
43
  var capabilities = {
23
- name: ((_xml$Service = xml.Service) === null || _xml$Service === void 0 ? void 0 : _xml$Service.Name) || 'unnamed',
24
- title: (_xml$Service2 = xml.Service) === null || _xml$Service2 === void 0 ? void 0 : _xml$Service2.Title,
25
- keywords: [],
26
- requests: {},
27
- layer: extractLayer((_xml$Capability = xml.Capability) === null || _xml$Capability === void 0 ? void 0 : _xml$Capability.Layer),
28
- raw: xml
44
+ version: String(xml.version || ''),
45
+ name: String(((_xml$Service = xml.Service) === null || _xml$Service === void 0 ? void 0 : _xml$Service.Name) || 'unnamed'),
46
+ title: (_xml$Service2 = xml.Service) !== null && _xml$Service2 !== void 0 && _xml$Service2.Title ? String((_xml$Service3 = xml.Service) === null || _xml$Service3 === void 0 ? void 0 : _xml$Service3.Title) : undefined,
47
+ abstract: (_xml$Service4 = xml.Service) !== null && _xml$Service4 !== void 0 && _xml$Service4.Abstract ? String((_xml$Service5 = xml.Service) === null || _xml$Service5 === void 0 ? void 0 : _xml$Service5.Abstract) : undefined,
48
+ keywords: (0, _parseXmlHelpers.getXMLStringArray)((_xml$Service6 = xml.Service) === null || _xml$Service6 === void 0 ? void 0 : (_xml$Service6$Keyword = _xml$Service6.KeywordList) === null || _xml$Service6$Keyword === void 0 ? void 0 : _xml$Service6$Keyword.Keyword),
49
+ fees: (_xml$Service7 = xml.Service) !== null && _xml$Service7 !== void 0 && _xml$Service7.Fees ? JSON.stringify((_xml$Service8 = xml.Service) === null || _xml$Service8 === void 0 ? void 0 : _xml$Service8.Fees) : undefined,
50
+ accessConstraints: (_xml$Service9 = xml.Service) !== null && _xml$Service9 !== void 0 && _xml$Service9.AccessConstraints ? JSON.stringify((_xml$Service10 = xml.Service) === null || _xml$Service10 === void 0 ? void 0 : _xml$Service10.AccessConstraints) : undefined,
51
+ layerLimit: (0, _parseXmlHelpers.getXMLInteger)((_xml$Service11 = xml.Service) === null || _xml$Service11 === void 0 ? void 0 : _xml$Service11.LayerLimit),
52
+ maxWidth: (0, _parseXmlHelpers.getXMLInteger)((_xml$Service12 = xml.Service) === null || _xml$Service12 === void 0 ? void 0 : _xml$Service12.maxWidth),
53
+ maxHeight: (0, _parseXmlHelpers.getXMLInteger)((_xml$Service13 = xml.Service) === null || _xml$Service13 === void 0 ? void 0 : _xml$Service13.maxHeight),
54
+ layers: [],
55
+ requests: extractRequests((_xml$Capability = xml.Capability) === null || _xml$Capability === void 0 ? void 0 : _xml$Capability.Request),
56
+ exceptions: extractExceptions(xml.Exception)
29
57
  };
30
- var _iterator = _createForOfIteratorHelper(((_xml$Service3 = xml.Service) === null || _xml$Service3 === void 0 ? void 0 : (_xml$Service3$Keyword = _xml$Service3.KeywordList) === null || _xml$Service3$Keyword === void 0 ? void 0 : _xml$Service3$Keyword.Keyword) || []),
31
- _step;
58
+ var xmlLayers = (0, _parseXmlHelpers.getXMLArray)((_xml$Capability2 = xml.Capability) === null || _xml$Capability2 === void 0 ? void 0 : _xml$Capability2.Layer);
59
+ var _iterator2 = _createForOfIteratorHelper(xmlLayers),
60
+ _step2;
32
61
  try {
33
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
34
- var keyword = _step.value;
35
- capabilities.keywords.push(keyword);
62
+ for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
63
+ var xmlSubLayer = _step2.value;
64
+ capabilities.layers.push(extractLayer(xmlSubLayer));
36
65
  }
37
66
  } catch (err) {
38
- _iterator.e(err);
67
+ _iterator2.e(err);
39
68
  } finally {
40
- _iterator.f();
69
+ _iterator2.f();
41
70
  }
42
- for (var _i = 0, _Object$entries = Object.entries(((_xml$Capability2 = xml.Capability) === null || _xml$Capability2 === void 0 ? void 0 : _xml$Capability2.Request) || {}); _i < _Object$entries.length; _i++) {
43
- var _xml$Capability2;
71
+ for (var _i = 0, _Object$entries = Object.entries(capabilities); _i < _Object$entries.length; _i++) {
44
72
  var _Object$entries$_i = (0, _slicedToArray2.default)(_Object$entries[_i], 2),
45
- name = _Object$entries$_i[0],
46
- xmlRequest = _Object$entries$_i[1];
47
- capabilities.requests[name] = extractRequest(name, xmlRequest);
73
+ key = _Object$entries$_i[0],
74
+ value = _Object$entries$_i[1];
75
+ if (value === undefined) {
76
+ delete capabilities[key];
77
+ }
48
78
  }
49
79
  return capabilities;
50
80
  }
51
-
52
- function extractRequest(name, xmlRequest) {
53
- var format = xmlRequest === null || xmlRequest === void 0 ? void 0 : xmlRequest.Format;
54
- var mimeTypes = Array.isArray(format) ? format : [format];
55
- return {
56
- name: name,
57
- mimeTypes: mimeTypes
58
- };
81
+ function extractRequests(xmlRequests) {
82
+ var requests = {};
83
+ var _iterator3 = _createForOfIteratorHelper(Object.entries(xmlRequests || {})),
84
+ _step3;
85
+ try {
86
+ for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) {
87
+ var _step3$value = (0, _slicedToArray2.default)(_step3.value, 2),
88
+ name = _step3$value[0],
89
+ xmlRequest = _step3$value[1];
90
+ var mimeTypes = (0, _parseXmlHelpers.getXMLStringArray)(xmlRequest === null || xmlRequest === void 0 ? void 0 : xmlRequest.Format);
91
+ requests[name] = {
92
+ mimeTypes: mimeTypes
93
+ };
94
+ }
95
+ } catch (err) {
96
+ _iterator3.e(err);
97
+ } finally {
98
+ _iterator3.f();
99
+ }
100
+ return requests;
101
+ }
102
+ function extractExceptions(xmlException) {
103
+ var xmlExceptionFormats = (0, _parseXmlHelpers.getXMLArray)(xmlException === null || xmlException === void 0 ? void 0 : xmlException.Format);
104
+ if (xmlExceptionFormats.length > 0) {
105
+ return {
106
+ mimeTypes: (0, _parseXmlHelpers.getXMLStringArray)(xmlException)
107
+ };
108
+ }
109
+ return undefined;
59
110
  }
60
-
61
111
  function extractLayer(xmlLayer) {
112
+ var _xmlLayer$KeywordList;
62
113
  var layer = {
63
- name: xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.Name,
64
- title: xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.Title,
65
- srs: (xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.SRS) || [],
66
- layers: []
114
+ title: String((xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.Title) || ''),
115
+ name: String(xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.Name),
116
+ abstract: String(xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.Abstract),
117
+ keywords: (0, _parseXmlHelpers.getXMLStringArray)((_xmlLayer$KeywordList = xmlLayer.KeywordList) === null || _xmlLayer$KeywordList === void 0 ? void 0 : _xmlLayer$KeywordList.Keyword)
67
118
  };
68
-
69
- var xmlLayers = getXMLArray(xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.Layer);
70
- var _iterator2 = _createForOfIteratorHelper(xmlLayers),
71
- _step2;
119
+ var crs = (xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.CRS) || (xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.SRS);
120
+ if (crs && Array.isArray(crs) && crs.every(function (_) {
121
+ return typeof _ === 'string';
122
+ })) {
123
+ layer.crs = crs;
124
+ }
125
+ var geographicBoundingBox = (xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.EX_GeographicBoundingBox) && extractEXBoundingBox(xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.EX_GeographicBoundingBox);
126
+ if (geographicBoundingBox) {
127
+ layer.geographicBoundingBox = geographicBoundingBox;
128
+ }
129
+ geographicBoundingBox = (xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.LatLonBoundingBox) && extractLatLonBoundingBox(xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.LatLonBoundingBox);
130
+ if (geographicBoundingBox) {
131
+ layer.geographicBoundingBox = geographicBoundingBox;
132
+ }
133
+ var boundingBoxes = (xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.BoundingBox) && extractWMSBoundingBoxes(xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.BoundingBox);
134
+ if (boundingBoxes && boundingBoxes.length > 0) {
135
+ layer.boundingBoxes = boundingBoxes;
136
+ }
137
+ if (xmlLayer !== null && xmlLayer !== void 0 && xmlLayer.opaque) {
138
+ layer.opaque = (0, _parseXmlHelpers.getXMLBoolean)(xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.opaque);
139
+ }
140
+ if (xmlLayer !== null && xmlLayer !== void 0 && xmlLayer.cascaded) {
141
+ layer.cascaded = (0, _parseXmlHelpers.getXMLBoolean)(xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.cascaded);
142
+ }
143
+ if (xmlLayer !== null && xmlLayer !== void 0 && xmlLayer.queryable) {
144
+ layer.queryable = (0, _parseXmlHelpers.getXMLBoolean)(xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.queryable);
145
+ }
146
+ var xmlLayers = (0, _parseXmlHelpers.getXMLArray)(xmlLayer === null || xmlLayer === void 0 ? void 0 : xmlLayer.Layer);
147
+ var layers = [];
148
+ var _iterator4 = _createForOfIteratorHelper(xmlLayers),
149
+ _step4;
72
150
  try {
73
- for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
74
- var _layer$layers;
75
- var xmlSubLayer = _step2.value;
76
- (_layer$layers = layer.layers) === null || _layer$layers === void 0 ? void 0 : _layer$layers.push(extractLayer(xmlSubLayer));
151
+ for (_iterator4.s(); !(_step4 = _iterator4.n()).done;) {
152
+ var xmlSubLayer = _step4.value;
153
+ layers.push(extractLayer(xmlSubLayer));
77
154
  }
78
155
  } catch (err) {
79
- _iterator2.e(err);
156
+ _iterator4.e(err);
80
157
  } finally {
81
- _iterator2.f();
158
+ _iterator4.f();
159
+ }
160
+ if (layers.length > 0) {
161
+ layer.layers = layers;
162
+ }
163
+ for (var _i2 = 0, _Object$entries2 = Object.entries(layer); _i2 < _Object$entries2.length; _i2++) {
164
+ var _Object$entries2$_i = (0, _slicedToArray2.default)(_Object$entries2[_i2], 2),
165
+ key = _Object$entries2$_i[0],
166
+ value = _Object$entries2$_i[1];
167
+ if (value === undefined) {
168
+ delete layer[key];
169
+ }
82
170
  }
83
171
  return layer;
84
172
  }
85
- function getXMLArray(xmlValue) {
86
- if (Array.isArray(xmlValue)) {
87
- return xmlValue;
173
+ function extractEXBoundingBox(xmlBoundingBox) {
174
+ var w = xmlBoundingBox.westBoundLongitude,
175
+ n = xmlBoundingBox.northBoundLatitude,
176
+ e = xmlBoundingBox.eastBoundLongitude,
177
+ s = xmlBoundingBox.southBoundLatitude;
178
+ return [[w, s], [e, n]];
179
+ }
180
+ function extractLatLonBoundingBox(xmlBoundingBox) {
181
+ var minx = xmlBoundingBox.minx,
182
+ miny = xmlBoundingBox.miny,
183
+ maxx = xmlBoundingBox.maxx,
184
+ maxy = xmlBoundingBox.maxy;
185
+ return [[minx, miny], [maxx, maxy]];
186
+ }
187
+ function extractWMSBoundingBoxes(xmlBoundingBoxes) {
188
+ var xmlBoxes = (0, _parseXmlHelpers.getXMLArray)(xmlBoundingBoxes);
189
+ return xmlBoxes.map(function (xmlBox) {
190
+ return extractWMSBoundingBox(xmlBox);
191
+ });
192
+ }
193
+ function extractWMSBoundingBox(xmlBoundingBox) {
194
+ var CRS = xmlBoundingBox.CRS,
195
+ SRS = xmlBoundingBox.SRS,
196
+ minx = xmlBoundingBox.minx,
197
+ miny = xmlBoundingBox.miny,
198
+ maxx = xmlBoundingBox.maxx,
199
+ maxy = xmlBoundingBox.maxy,
200
+ resx = xmlBoundingBox.resx,
201
+ resy = xmlBoundingBox.resy;
202
+ var boundingBox = {
203
+ crs: CRS || SRS,
204
+ boundingBox: [[(0, _parseXmlHelpers.getXMLFloat)(minx), (0, _parseXmlHelpers.getXMLFloat)(miny)], [(0, _parseXmlHelpers.getXMLFloat)(maxx), (0, _parseXmlHelpers.getXMLFloat)(maxy)]]
205
+ };
206
+ if (resx) {
207
+ boundingBox.xResolution = resx;
208
+ }
209
+ if (resy) {
210
+ boundingBox.yResolution = resy;
211
+ }
212
+ return boundingBox;
213
+ }
214
+ function addInheritedLayerProps(layer, parent) {
215
+ if (parent && parent.geographicBoundingBox && !layer.geographicBoundingBox) {
216
+ layer.geographicBoundingBox = (0, _toConsumableArray2.default)(parent.geographicBoundingBox);
88
217
  }
89
- if (xmlValue) {
90
- return [xmlValue];
218
+ if (parent && parent.crs && !layer.crs) {
219
+ layer.crs = (0, _toConsumableArray2.default)(parent.crs);
220
+ }
221
+ if (parent && parent.boundingBoxes && !layer.boundingBoxes) {
222
+ layer.boundingBoxes = (0, _toConsumableArray2.default)(parent.boundingBoxes);
223
+ }
224
+ var _iterator5 = _createForOfIteratorHelper(layer.layers || []),
225
+ _step5;
226
+ try {
227
+ for (_iterator5.s(); !(_step5 = _iterator5.n()).done;) {
228
+ var subLayer = _step5.value;
229
+ addInheritedLayerProps(subLayer, layer);
230
+ }
231
+ } catch (err) {
232
+ _iterator5.e(err);
233
+ } finally {
234
+ _iterator5.f();
91
235
  }
92
- return [];
93
236
  }
94
237
  //# sourceMappingURL=parse-wms-capabilities.js.map