@map-colonies/mc-utils 2.0.2 → 3.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (122) hide show
  1. package/README.md +67 -67
  2. package/dist/arrays/index.d.ts +1 -1
  3. package/dist/arrays/index.d.ts.map +0 -0
  4. package/dist/arrays/index.js +17 -17
  5. package/dist/arrays/index.js.map +0 -0
  6. package/dist/arrays/subGroups.d.ts +8 -8
  7. package/dist/arrays/subGroups.d.ts.map +0 -0
  8. package/dist/arrays/subGroups.js +33 -138
  9. package/dist/arrays/subGroups.js.map +1 -1
  10. package/dist/communication/http/httpClient.d.ts +29 -29
  11. package/dist/communication/http/httpClient.d.ts.map +0 -0
  12. package/dist/communication/http/httpClient.js +317 -434
  13. package/dist/communication/http/httpClient.js.map +1 -1
  14. package/dist/communication/http/index.d.ts +1 -1
  15. package/dist/communication/http/index.d.ts.map +0 -0
  16. package/dist/communication/http/index.js +17 -17
  17. package/dist/communication/http/index.js.map +0 -0
  18. package/dist/communication/index.d.ts +1 -1
  19. package/dist/communication/index.d.ts.map +0 -0
  20. package/dist/communication/index.js +17 -17
  21. package/dist/communication/index.js.map +0 -0
  22. package/dist/dateTime/getUTCDate.d.ts +1 -1
  23. package/dist/dateTime/getUTCDate.d.ts.map +0 -0
  24. package/dist/dateTime/getUTCDate.js +10 -10
  25. package/dist/dateTime/getUTCDate.js.map +1 -1
  26. package/dist/dateTime/index.d.ts +1 -1
  27. package/dist/dateTime/index.d.ts.map +0 -0
  28. package/dist/dateTime/index.js +17 -17
  29. package/dist/dateTime/index.js.map +0 -0
  30. package/dist/geo/bboxUtils.d.ts +23 -23
  31. package/dist/geo/bboxUtils.d.ts.map +0 -0
  32. package/dist/geo/bboxUtils.js +89 -89
  33. package/dist/geo/bboxUtils.js.map +1 -1
  34. package/dist/geo/geoConvertor.d.ts +18 -18
  35. package/dist/geo/geoConvertor.d.ts.map +0 -0
  36. package/dist/geo/geoConvertor.js +49 -51
  37. package/dist/geo/geoConvertor.js.map +1 -1
  38. package/dist/geo/geoHash.d.ts +24 -24
  39. package/dist/geo/geoHash.d.ts.map +1 -1
  40. package/dist/geo/geoHash.js +134 -246
  41. package/dist/geo/geoHash.js.map +1 -1
  42. package/dist/geo/geoIntersection.d.ts +19 -19
  43. package/dist/geo/geoIntersection.d.ts.map +0 -0
  44. package/dist/geo/geoIntersection.js +70 -70
  45. package/dist/geo/geoIntersection.js.map +1 -1
  46. package/dist/geo/index.d.ts +8 -8
  47. package/dist/geo/index.d.ts.map +0 -0
  48. package/dist/geo/index.js +24 -24
  49. package/dist/geo/index.js.map +0 -0
  50. package/dist/geo/tileBatcher.d.ts +8 -8
  51. package/dist/geo/tileBatcher.d.ts.map +1 -1
  52. package/dist/geo/tileBatcher.js +97 -167
  53. package/dist/geo/tileBatcher.js.map +1 -1
  54. package/dist/geo/tileRanger.d.ts +46 -46
  55. package/dist/geo/tileRanger.d.ts.map +1 -1
  56. package/dist/geo/tileRanger.js +232 -327
  57. package/dist/geo/tileRanger.js.map +1 -1
  58. package/dist/geo/tiles.d.ts +82 -82
  59. package/dist/geo/tiles.d.ts.map +0 -0
  60. package/dist/geo/tiles.js +219 -246
  61. package/dist/geo/tiles.js.map +1 -1
  62. package/dist/geo/tilesGenerator.d.ts +2 -2
  63. package/dist/geo/tilesGenerator.d.ts.map +1 -1
  64. package/dist/geo/tilesGenerator.js +17 -94
  65. package/dist/geo/tilesGenerator.js.map +1 -1
  66. package/dist/index.d.ts +6 -5
  67. package/dist/index.d.ts.map +1 -1
  68. package/dist/index.js +22 -21
  69. package/dist/index.js.map +1 -1
  70. package/dist/models/enums/gdal/dataType.d.ts +16 -16
  71. package/dist/models/enums/gdal/dataType.d.ts.map +0 -0
  72. package/dist/models/enums/gdal/dataType.js +20 -20
  73. package/dist/models/enums/gdal/dataType.js.map +0 -0
  74. package/dist/models/enums/gdal/index.d.ts +2 -2
  75. package/dist/models/enums/gdal/index.d.ts.map +0 -0
  76. package/dist/models/enums/gdal/index.js +18 -18
  77. package/dist/models/enums/gdal/index.js.map +0 -0
  78. package/dist/models/enums/gdal/resamplingMethod.d.ts +16 -16
  79. package/dist/models/enums/gdal/resamplingMethod.d.ts.map +0 -0
  80. package/dist/models/enums/gdal/resamplingMethod.js +20 -20
  81. package/dist/models/enums/gdal/resamplingMethod.js.map +0 -0
  82. package/dist/models/enums/geo/index.d.ts +1 -1
  83. package/dist/models/enums/geo/index.d.ts.map +0 -0
  84. package/dist/models/enums/geo/index.js +17 -17
  85. package/dist/models/enums/geo/index.js.map +0 -0
  86. package/dist/models/enums/geo/tileOrigin.d.ts +7 -7
  87. package/dist/models/enums/geo/tileOrigin.d.ts.map +0 -0
  88. package/dist/models/enums/geo/tileOrigin.js +11 -11
  89. package/dist/models/enums/geo/tileOrigin.js.map +0 -0
  90. package/dist/models/enums/index.d.ts +2 -2
  91. package/dist/models/enums/index.d.ts.map +0 -0
  92. package/dist/models/enums/index.js +18 -18
  93. package/dist/models/enums/index.js.map +0 -0
  94. package/dist/models/index.d.ts +2 -2
  95. package/dist/models/index.d.ts.map +0 -0
  96. package/dist/models/index.js +18 -18
  97. package/dist/models/index.js.map +0 -0
  98. package/dist/models/interfaces/geo/iPoint.d.ts +7 -7
  99. package/dist/models/interfaces/geo/iPoint.d.ts.map +0 -0
  100. package/dist/models/interfaces/geo/iPoint.js +2 -2
  101. package/dist/models/interfaces/geo/iPoint.js.map +0 -0
  102. package/dist/models/interfaces/geo/iTile.d.ts +15 -15
  103. package/dist/models/interfaces/geo/iTile.d.ts.map +0 -0
  104. package/dist/models/interfaces/geo/iTile.js +2 -2
  105. package/dist/models/interfaces/geo/iTile.js.map +0 -0
  106. package/dist/models/interfaces/geo/index.d.ts +2 -2
  107. package/dist/models/interfaces/geo/index.d.ts.map +0 -0
  108. package/dist/models/interfaces/geo/index.js +18 -18
  109. package/dist/models/interfaces/geo/index.js.map +0 -0
  110. package/dist/models/interfaces/index.d.ts +1 -1
  111. package/dist/models/interfaces/index.d.ts.map +0 -0
  112. package/dist/models/interfaces/index.js +17 -17
  113. package/dist/models/interfaces/index.js.map +0 -0
  114. package/dist/utils/index.d.ts +2 -0
  115. package/dist/utils/index.d.ts.map +1 -0
  116. package/dist/utils/index.js +18 -0
  117. package/dist/utils/index.js.map +1 -0
  118. package/dist/utils/timeout.d.ts +5 -0
  119. package/dist/utils/timeout.d.ts.map +1 -0
  120. package/dist/utils/timeout.js +23 -0
  121. package/dist/utils/timeout.js.map +1 -0
  122. package/package.json +79 -79
@@ -1,71 +1,71 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.featureCollectionBooleanEqual = exports.multiIntersect = void 0;
7
- var turf_1 = require("@turf/turf");
8
- var lodash_1 = __importDefault(require("lodash"));
9
- var featuresCustomizer = function (objectValue, otherValue) {
10
- // compare features
11
- // https://lodash.com/docs/4.17.15#find
12
- if (!lodash_1.default.isEqual(objectValue.length, otherValue.length)) {
13
- return false;
14
- }
15
- for (var i = 0; i < objectValue.length; i++) {
16
- var isFeatureContained = lodash_1.default.find(otherValue, objectValue[i]);
17
- if (isFeatureContained === undefined) {
18
- return false;
19
- }
20
- }
21
- for (var i = 0; i < otherValue.length; i++) {
22
- var isFeatureContained = lodash_1.default.find(objectValue, otherValue[i]);
23
- if (isFeatureContained === undefined) {
24
- return false;
25
- }
26
- }
27
- return true;
28
- };
29
- var featureCollectionCustomized = function (objectValue, otherValue) {
30
- // compare type
31
- if (!lodash_1.default.isEqual(objectValue.type, otherValue.type)) {
32
- return false;
33
- }
34
- // compare features
35
- var isFeaturesEqual = lodash_1.default.isEqualWith(objectValue.features, otherValue.features, featuresCustomizer);
36
- return isFeaturesEqual;
37
- };
38
- /**
39
- * return the intersection footprint of all specified footprints or null when there is no intersection
40
- * @param footprints footprint list to intersect
41
- * @returns intersection footprint or null
42
- */
43
- var multiIntersect = function (footprints) {
44
- if (footprints.length === 0) {
45
- return null;
46
- }
47
- else if (footprints.length === 1) {
48
- return footprints[0];
49
- }
50
- var intersection = footprints[0];
51
- for (var i = 1; i < footprints.length; i++) {
52
- var curIntersection = (0, turf_1.intersect)(intersection, footprints[i]);
53
- if (curIntersection === null) {
54
- return null;
55
- }
56
- intersection = curIntersection;
57
- }
58
- return intersection;
59
- };
60
- exports.multiIntersect = multiIntersect;
61
- /**
62
- * indicates if 2 object of type FeatureCollection are equal by validating properties and features array (order not important)
63
- * @param fc1 first featureCollection to compare equal
64
- * @param fc2 second featureCollection to compare equal
65
- * @returns true if same featureCollection, false if not
66
- */
67
- var featureCollectionBooleanEqual = function (fc1, fc2) {
68
- return lodash_1.default.isEqualWith(fc1, fc2, featureCollectionCustomized);
69
- };
70
- exports.featureCollectionBooleanEqual = featureCollectionBooleanEqual;
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.featureCollectionBooleanEqual = exports.multiIntersect = void 0;
7
+ const turf_1 = require("@turf/turf");
8
+ const lodash_1 = __importDefault(require("lodash"));
9
+ const featuresCustomizer = (objectValue, otherValue) => {
10
+ // compare features
11
+ // https://lodash.com/docs/4.17.15#find
12
+ if (!lodash_1.default.isEqual(objectValue.length, otherValue.length)) {
13
+ return false;
14
+ }
15
+ for (let i = 0; i < objectValue.length; i++) {
16
+ const isFeatureContained = lodash_1.default.find(otherValue, objectValue[i]);
17
+ if (isFeatureContained === undefined) {
18
+ return false;
19
+ }
20
+ }
21
+ for (let i = 0; i < otherValue.length; i++) {
22
+ const isFeatureContained = lodash_1.default.find(objectValue, otherValue[i]);
23
+ if (isFeatureContained === undefined) {
24
+ return false;
25
+ }
26
+ }
27
+ return true;
28
+ };
29
+ const featureCollectionCustomized = (objectValue, otherValue) => {
30
+ // compare type
31
+ if (!lodash_1.default.isEqual(objectValue.type, otherValue.type)) {
32
+ return false;
33
+ }
34
+ // compare features
35
+ const isFeaturesEqual = lodash_1.default.isEqualWith(objectValue.features, otherValue.features, featuresCustomizer);
36
+ return isFeaturesEqual;
37
+ };
38
+ /**
39
+ * return the intersection footprint of all specified footprints or null when there is no intersection
40
+ * @param footprints footprint list to intersect
41
+ * @returns intersection footprint or null
42
+ */
43
+ const multiIntersect = (footprints) => {
44
+ if (footprints.length === 0) {
45
+ return null;
46
+ }
47
+ else if (footprints.length === 1) {
48
+ return footprints[0];
49
+ }
50
+ let intersection = footprints[0];
51
+ for (let i = 1; i < footprints.length; i++) {
52
+ const curIntersection = (0, turf_1.intersect)(intersection, footprints[i]);
53
+ if (curIntersection === null) {
54
+ return null;
55
+ }
56
+ intersection = curIntersection;
57
+ }
58
+ return intersection;
59
+ };
60
+ exports.multiIntersect = multiIntersect;
61
+ /**
62
+ * indicates if 2 object of type FeatureCollection are equal by validating properties and features array (order not important)
63
+ * @param fc1 first featureCollection to compare equal
64
+ * @param fc2 second featureCollection to compare equal
65
+ * @returns true if same featureCollection, false if not
66
+ */
67
+ const featureCollectionBooleanEqual = (fc1, fc2) => {
68
+ return lodash_1.default.isEqualWith(fc1, fc2, featureCollectionCustomized);
69
+ };
70
+ exports.featureCollectionBooleanEqual = featureCollectionBooleanEqual;
71
71
  //# sourceMappingURL=geoIntersection.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"geoIntersection.js","sourceRoot":"","sources":["../../src/geo/geoIntersection.ts"],"names":[],"mappings":";;;;;;AAAA,mCAA0F;AAC1F,kDAAuB;AAOvB,IAAM,kBAAkB,GAAG,UAAC,WAAsB,EAAE,UAAqB;IACvE,mBAAmB;IACnB,uCAAuC;IAEvC,IAAI,CAAC,gBAAC,CAAC,OAAO,CAAC,WAAW,CAAC,MAAM,EAAE,UAAU,CAAC,MAAM,CAAC,EAAE;QACrD,OAAO,KAAK,CAAC;KACd;IACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAC3C,IAAM,kBAAkB,GAAG,gBAAC,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9D,IAAI,kBAAkB,KAAK,SAAS,EAAE;YACpC,OAAO,KAAK,CAAC;SACd;KACF;IACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAC1C,IAAM,kBAAkB,GAAG,gBAAC,CAAC,IAAI,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9D,IAAI,kBAAkB,KAAK,SAAS,EAAE;YACpC,OAAO,KAAK,CAAC;SACd;KACF;IACD,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAEF,IAAM,2BAA2B,GAAG,UAAC,WAA8B,EAAE,UAA6B;IAChG,eAAe;IACf,IAAI,CAAC,gBAAC,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,EAAE,UAAU,CAAC,IAAI,CAAC,EAAE;QACjD,OAAO,KAAK,CAAC;KACd;IACD,mBAAmB;IACnB,IAAM,eAAe,GAAG,gBAAC,CAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,EAAE,UAAU,CAAC,QAAQ,EAAE,kBAAkB,CAAC,CAAC;IACrG,OAAO,eAAe,CAAC;AACzB,CAAC,CAAC;AAEF;;;;GAIG;AACH,IAAM,cAAc,GAAG,UAAC,UAAuB;IAC7C,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE;QAC3B,OAAO,IAAI,CAAC;KACb;SAAM,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE;QAClC,OAAO,UAAU,CAAC,CAAC,CAAC,CAAC;KACtB;IACD,IAAI,YAAY,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;IACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAC1C,IAAM,eAAe,GAAG,IAAA,gBAAS,EAAC,YAAY,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/D,IAAI,eAAe,KAAK,IAAI,EAAE;YAC5B,OAAO,IAAI,CAAC;SACb;QACD,YAAY,GAAG,eAAe,CAAC;KAChC;IACD,OAAO,YAAY,CAAC;AACtB,CAAC,CAAC;AAYO,wCAAc;AAVvB;;;;;GAKG;AACH,IAAM,6BAA6B,GAAG,UAAC,GAAsB,EAAE,GAAsB;IACnF,OAAO,gBAAC,CAAC,WAAW,CAAC,GAAG,EAAE,GAAG,EAAE,2BAA2B,CAAC,CAAC;AAC9D,CAAC,CAAC;AAEuB,sEAA6B"}
1
+ {"version":3,"file":"geoIntersection.js","sourceRoot":"","sources":["../../src/geo/geoIntersection.ts"],"names":[],"mappings":";;;;;;AAAA,qCAA0F;AAC1F,oDAAuB;AAOvB,MAAM,kBAAkB,GAAG,CAAC,WAAsB,EAAE,UAAqB,EAAW,EAAE;IACpF,mBAAmB;IACnB,uCAAuC;IAEvC,IAAI,CAAC,gBAAC,CAAC,OAAO,CAAC,WAAW,CAAC,MAAM,EAAE,UAAU,CAAC,MAAM,CAAC,EAAE;QACrD,OAAO,KAAK,CAAC;KACd;IACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAC3C,MAAM,kBAAkB,GAAG,gBAAC,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9D,IAAI,kBAAkB,KAAK,SAAS,EAAE;YACpC,OAAO,KAAK,CAAC;SACd;KACF;IACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAC1C,MAAM,kBAAkB,GAAG,gBAAC,CAAC,IAAI,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9D,IAAI,kBAAkB,KAAK,SAAS,EAAE;YACpC,OAAO,KAAK,CAAC;SACd;KACF;IACD,OAAO,IAAI,CAAC;AACd,CAAC,CAAC;AAEF,MAAM,2BAA2B,GAAG,CAAC,WAA8B,EAAE,UAA6B,EAAW,EAAE;IAC7G,eAAe;IACf,IAAI,CAAC,gBAAC,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,EAAE,UAAU,CAAC,IAAI,CAAC,EAAE;QACjD,OAAO,KAAK,CAAC;KACd;IACD,mBAAmB;IACnB,MAAM,eAAe,GAAG,gBAAC,CAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,EAAE,UAAU,CAAC,QAAQ,EAAE,kBAAkB,CAAC,CAAC;IACrG,OAAO,eAAe,CAAC;AACzB,CAAC,CAAC;AAEF;;;;GAIG;AACH,MAAM,cAAc,GAAG,CAAC,UAAuB,EAAoB,EAAE;IACnE,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE;QAC3B,OAAO,IAAI,CAAC;KACb;SAAM,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE;QAClC,OAAO,UAAU,CAAC,CAAC,CAAC,CAAC;KACtB;IACD,IAAI,YAAY,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;IACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAC1C,MAAM,eAAe,GAAG,IAAA,gBAAS,EAAC,YAAY,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/D,IAAI,eAAe,KAAK,IAAI,EAAE;YAC5B,OAAO,IAAI,CAAC;SACb;QACD,YAAY,GAAG,eAAe,CAAC;KAChC;IACD,OAAO,YAAY,CAAC;AACtB,CAAC,CAAC;AAYO,wCAAc;AAVvB;;;;;GAKG;AACH,MAAM,6BAA6B,GAAG,CAAC,GAAsB,EAAE,GAAsB,EAAW,EAAE;IAChG,OAAO,gBAAC,CAAC,WAAW,CAAC,GAAG,EAAE,GAAG,EAAE,2BAA2B,CAAC,CAAC;AAC9D,CAAC,CAAC;AAEuB,sEAA6B"}
@@ -1,9 +1,9 @@
1
- export * from './bboxUtils';
2
- export * from './geoConvertor';
3
- export * from './geoHash';
4
- export * from './geoIntersection';
5
- export * from './tileBatcher';
6
- export * from './tileRanger';
7
- export * from './tiles';
8
- export * from './tilesGenerator';
1
+ export * from './bboxUtils';
2
+ export * from './geoConvertor';
3
+ export * from './geoHash';
4
+ export * from './geoIntersection';
5
+ export * from './tileBatcher';
6
+ export * from './tileRanger';
7
+ export * from './tiles';
8
+ export * from './tilesGenerator';
9
9
  //# sourceMappingURL=index.d.ts.map
File without changes
package/dist/geo/index.js CHANGED
@@ -1,25 +1,25 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./bboxUtils"), exports);
18
- __exportStar(require("./geoConvertor"), exports);
19
- __exportStar(require("./geoHash"), exports);
20
- __exportStar(require("./geoIntersection"), exports);
21
- __exportStar(require("./tileBatcher"), exports);
22
- __exportStar(require("./tileRanger"), exports);
23
- __exportStar(require("./tiles"), exports);
24
- __exportStar(require("./tilesGenerator"), exports);
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./bboxUtils"), exports);
18
+ __exportStar(require("./geoConvertor"), exports);
19
+ __exportStar(require("./geoHash"), exports);
20
+ __exportStar(require("./geoIntersection"), exports);
21
+ __exportStar(require("./tileBatcher"), exports);
22
+ __exportStar(require("./tileRanger"), exports);
23
+ __exportStar(require("./tiles"), exports);
24
+ __exportStar(require("./tilesGenerator"), exports);
25
25
  //# sourceMappingURL=index.js.map
File without changes
@@ -1,9 +1,9 @@
1
- import { ITileRange } from '../models/interfaces/geo/iTile';
2
- /**
3
- * split collection of tile ranges to batches based on tile count
4
- * @param batchSize amount of tile per batch
5
- * @param ranges iterable collection of tile ranges
6
- */
7
- declare function tileBatchGenerator(batchSize: number, ranges: Iterable<ITileRange>): Generator<ITileRange[]>;
8
- export { tileBatchGenerator };
1
+ import { ITileRange } from '../models/interfaces/geo/iTile';
2
+ /**
3
+ * split collection of tile ranges to batches based on tile count
4
+ * @param batchSize amount of tile per batch
5
+ * @param ranges iterable collection of tile ranges
6
+ */
7
+ declare function tileBatchGenerator(batchSize: number, ranges: AsyncGenerator<ITileRange>): AsyncGenerator<ITileRange[]>;
8
+ export { tileBatchGenerator };
9
9
  //# sourceMappingURL=tileBatcher.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"tileBatcher.d.ts","sourceRoot":"","sources":["../../src/geo/tileBatcher.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAE5D;;;;GAIG;AACH,iBAAU,kBAAkB,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,CAAC,UAAU,CAAC,GAAG,SAAS,CAAC,UAAU,EAAE,CAAC,CAmFrG;AAED,OAAO,EAAE,kBAAkB,EAAE,CAAC"}
1
+ {"version":3,"file":"tileBatcher.d.ts","sourceRoot":"","sources":["../../src/geo/tileBatcher.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,gCAAgC,CAAC;AAG5D;;;;GAIG;AACH,iBAAgB,kBAAkB,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,cAAc,CAAC,UAAU,CAAC,GAAG,cAAc,CAAC,UAAU,EAAE,CAAC,CAoFtH;AAED,OAAO,EAAE,kBAAkB,EAAE,CAAC"}
@@ -1,168 +1,98 @@
1
- "use strict";
2
- var __generator = (this && this.__generator) || function (thisArg, body) {
3
- var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
4
- return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
5
- function verb(n) { return function (v) { return step([n, v]); }; }
6
- function step(op) {
7
- if (f) throw new TypeError("Generator is already executing.");
8
- while (_) try {
9
- if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
10
- if (y = 0, t) op = [op[0] & 2, t.value];
11
- switch (op[0]) {
12
- case 0: case 1: t = op; break;
13
- case 4: _.label++; return { value: op[1], done: false };
14
- case 5: _.label++; y = op[1]; op = [0]; continue;
15
- case 7: op = _.ops.pop(); _.trys.pop(); continue;
16
- default:
17
- if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
18
- if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
19
- if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
20
- if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
21
- if (t[2]) _.ops.pop();
22
- _.trys.pop(); continue;
23
- }
24
- op = body.call(thisArg, _);
25
- } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
26
- if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
27
- }
28
- };
29
- var __values = (this && this.__values) || function(o) {
30
- var s = typeof Symbol === "function" && Symbol.iterator, m = s && o[s], i = 0;
31
- if (m) return m.call(o);
32
- if (o && typeof o.length === "number") return {
33
- next: function () {
34
- if (o && i >= o.length) o = void 0;
35
- return { value: o && o[i++], done: !o };
36
- }
37
- };
38
- throw new TypeError(s ? "Object is not iterable." : "Symbol.iterator is not defined.");
39
- };
40
- Object.defineProperty(exports, "__esModule", { value: true });
41
- exports.tileBatchGenerator = void 0;
42
- /**
43
- * split collection of tile ranges to batches based on tile count
44
- * @param batchSize amount of tile per batch
45
- * @param ranges iterable collection of tile ranges
46
- */
47
- function tileBatchGenerator(batchSize, ranges) {
48
- var targetRanges, requiredForFullBatch, ranges_1, ranges_1_1, range, dx, dy, reminderX, remaining, requiredLines, yRange, endX, e_1_1;
49
- var e_1, _a;
50
- return __generator(this, function (_b) {
51
- switch (_b.label) {
52
- case 0:
53
- targetRanges = [];
54
- requiredForFullBatch = batchSize;
55
- _b.label = 1;
56
- case 1:
57
- _b.trys.push([1, 11, 12, 13]);
58
- ranges_1 = __values(ranges), ranges_1_1 = ranges_1.next();
59
- _b.label = 2;
60
- case 2:
61
- if (!!ranges_1_1.done) return [3 /*break*/, 10];
62
- range = ranges_1_1.value;
63
- dx = range.maxX - range.minX;
64
- dy = range.maxY - range.minY;
65
- if (dx === 0 || dy === 0) {
66
- return [3 /*break*/, 9];
67
- }
68
- reminderX = range.maxX;
69
- _b.label = 3;
70
- case 3:
71
- if (!(range.minY < range.maxY)) return [3 /*break*/, 9];
72
- if (!(reminderX < range.maxX)) return [3 /*break*/, 6];
73
- remaining = range.maxX - reminderX;
74
- if (!(remaining > requiredForFullBatch)) return [3 /*break*/, 5];
75
- targetRanges.push({
76
- minX: reminderX,
77
- maxX: reminderX + requiredForFullBatch,
78
- minY: range.minY,
79
- maxY: range.minY + 1,
80
- zoom: range.zoom,
81
- });
82
- return [4 /*yield*/, targetRanges];
83
- case 4:
84
- _b.sent();
85
- reminderX += requiredForFullBatch;
86
- targetRanges = [];
87
- requiredForFullBatch = batchSize;
88
- return [3 /*break*/, 3];
89
- case 5:
90
- targetRanges.push({
91
- minX: reminderX,
92
- maxX: reminderX + remaining,
93
- minY: range.minY,
94
- maxY: range.minY + 1,
95
- zoom: range.zoom,
96
- });
97
- range.minY++;
98
- reminderX += remaining;
99
- requiredForFullBatch -= remaining;
100
- dy--;
101
- _b.label = 6;
102
- case 6:
103
- requiredLines = Math.floor(requiredForFullBatch / dx);
104
- yRange = Math.min(requiredLines, dy);
105
- if (yRange > 0) {
106
- targetRanges.push({
107
- minX: range.minX,
108
- maxX: range.maxX,
109
- minY: range.minY,
110
- maxY: range.minY + yRange,
111
- zoom: range.zoom,
112
- });
113
- range.minY += yRange;
114
- dy -= yRange;
115
- requiredForFullBatch -= yRange * dx;
116
- }
117
- //add partial lines beginning
118
- if (requiredForFullBatch > 0 && range.minY < range.maxY) {
119
- endX = Math.min(range.minX + requiredForFullBatch, range.maxX);
120
- targetRanges.push({
121
- minX: range.minX,
122
- maxX: endX,
123
- minY: range.minY,
124
- maxY: range.minY + 1,
125
- zoom: range.zoom,
126
- });
127
- requiredForFullBatch -= endX - range.minX;
128
- if (endX < range.maxX) {
129
- reminderX = endX;
130
- }
131
- else {
132
- range.minY++;
133
- }
134
- }
135
- if (!(requiredForFullBatch === 0)) return [3 /*break*/, 8];
136
- return [4 /*yield*/, targetRanges];
137
- case 7:
138
- _b.sent();
139
- targetRanges = [];
140
- requiredForFullBatch = batchSize;
141
- _b.label = 8;
142
- case 8: return [3 /*break*/, 3];
143
- case 9:
144
- ranges_1_1 = ranges_1.next();
145
- return [3 /*break*/, 2];
146
- case 10: return [3 /*break*/, 13];
147
- case 11:
148
- e_1_1 = _b.sent();
149
- e_1 = { error: e_1_1 };
150
- return [3 /*break*/, 13];
151
- case 12:
152
- try {
153
- if (ranges_1_1 && !ranges_1_1.done && (_a = ranges_1.return)) _a.call(ranges_1);
154
- }
155
- finally { if (e_1) throw e_1.error; }
156
- return [7 /*endfinally*/];
157
- case 13:
158
- if (!(targetRanges.length > 0)) return [3 /*break*/, 15];
159
- return [4 /*yield*/, targetRanges];
160
- case 14:
161
- _b.sent();
162
- _b.label = 15;
163
- case 15: return [2 /*return*/];
164
- }
165
- });
166
- }
167
- exports.tileBatchGenerator = tileBatchGenerator;
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.tileBatchGenerator = void 0;
4
+ const timeout_1 = require("../utils/timeout");
5
+ /**
6
+ * split collection of tile ranges to batches based on tile count
7
+ * @param batchSize amount of tile per batch
8
+ * @param ranges iterable collection of tile ranges
9
+ */
10
+ async function* tileBatchGenerator(batchSize, ranges) {
11
+ let targetRanges = [];
12
+ let requiredForFullBatch = batchSize;
13
+ for await (const range of ranges) {
14
+ const dx = range.maxX - range.minX;
15
+ let dy = range.maxY - range.minY;
16
+ if (dx === 0 || dy === 0) {
17
+ continue;
18
+ }
19
+ let reminderX = range.maxX;
20
+ while (range.minY < range.maxY) {
21
+ //remaining tiles in batch row row
22
+ if (reminderX < range.maxX) {
23
+ const remaining = range.maxX - reminderX;
24
+ if (remaining > requiredForFullBatch) {
25
+ targetRanges.push({
26
+ minX: reminderX,
27
+ maxX: reminderX + requiredForFullBatch,
28
+ minY: range.minY,
29
+ maxY: range.minY + 1,
30
+ zoom: range.zoom,
31
+ });
32
+ yield await Promise.resolve(targetRanges);
33
+ reminderX += requiredForFullBatch;
34
+ targetRanges = [];
35
+ requiredForFullBatch = batchSize;
36
+ continue;
37
+ }
38
+ else {
39
+ targetRanges.push({
40
+ minX: reminderX,
41
+ maxX: reminderX + remaining,
42
+ minY: range.minY,
43
+ maxY: range.minY + 1,
44
+ zoom: range.zoom,
45
+ });
46
+ range.minY++;
47
+ reminderX += remaining;
48
+ requiredForFullBatch -= remaining;
49
+ dy--;
50
+ }
51
+ }
52
+ //add max full lines
53
+ const requiredLines = Math.floor(requiredForFullBatch / dx);
54
+ const yRange = Math.min(requiredLines, dy);
55
+ if (yRange > 0) {
56
+ targetRanges.push({
57
+ minX: range.minX,
58
+ maxX: range.maxX,
59
+ minY: range.minY,
60
+ maxY: range.minY + yRange,
61
+ zoom: range.zoom,
62
+ });
63
+ range.minY += yRange;
64
+ dy -= yRange;
65
+ requiredForFullBatch -= yRange * dx;
66
+ }
67
+ //add partial lines beginning
68
+ if (requiredForFullBatch > 0 && range.minY < range.maxY) {
69
+ const endX = Math.min(range.minX + requiredForFullBatch, range.maxX);
70
+ targetRanges.push({
71
+ minX: range.minX,
72
+ maxX: endX,
73
+ minY: range.minY,
74
+ maxY: range.minY + 1,
75
+ zoom: range.zoom,
76
+ });
77
+ requiredForFullBatch -= endX - range.minX;
78
+ if (endX < range.maxX) {
79
+ reminderX = endX;
80
+ }
81
+ else {
82
+ range.minY++;
83
+ }
84
+ }
85
+ if (requiredForFullBatch === 0) {
86
+ yield await Promise.resolve(targetRanges);
87
+ targetRanges = [];
88
+ requiredForFullBatch = batchSize;
89
+ }
90
+ }
91
+ await (0, timeout_1.timeout)(0); // TODO: * This is a hot fix to keep work async and handle concurrency requests while handling the task batch merging, remove this when moving to the new utils package ! *
92
+ }
93
+ if (targetRanges.length > 0) {
94
+ yield await Promise.resolve(targetRanges);
95
+ }
96
+ }
97
+ exports.tileBatchGenerator = tileBatchGenerator;
168
98
  //# sourceMappingURL=tileBatcher.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"tileBatcher.js","sourceRoot":"","sources":["../../src/geo/tileBatcher.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"tileBatcher.js","sourceRoot":"","sources":["../../src/geo/tileBatcher.ts"],"names":[],"mappings":";;;AACA,8CAA2C;AAE3C;;;;GAIG;AACH,KAAK,SAAS,CAAC,CAAC,kBAAkB,CAAC,SAAiB,EAAE,MAAkC;IACtF,IAAI,YAAY,GAAiB,EAAE,CAAC;IACpC,IAAI,oBAAoB,GAAG,SAAS,CAAC;IACrC,IAAI,KAAK,EAAE,MAAM,KAAK,IAAI,MAAM,EAAE;QAChC,MAAM,EAAE,GAAG,KAAK,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;QACnC,IAAI,EAAE,GAAG,KAAK,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;QACjC,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE;YACxB,SAAS;SACV;QACD,IAAI,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC;QAC3B,OAAO,KAAK,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,EAAE;YAC9B,kCAAkC;YAClC,IAAI,SAAS,GAAG,KAAK,CAAC,IAAI,EAAE;gBAC1B,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,GAAG,SAAS,CAAC;gBACzC,IAAI,SAAS,GAAG,oBAAoB,EAAE;oBACpC,YAAY,CAAC,IAAI,CAAC;wBAChB,IAAI,EAAE,SAAS;wBACf,IAAI,EAAE,SAAS,GAAG,oBAAoB;wBACtC,IAAI,EAAE,KAAK,CAAC,IAAI;wBAChB,IAAI,EAAE,KAAK,CAAC,IAAI,GAAG,CAAC;wBACpB,IAAI,EAAE,KAAK,CAAC,IAAI;qBACjB,CAAC,CAAC;oBACH,MAAM,MAAM,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;oBAC1C,SAAS,IAAI,oBAAoB,CAAC;oBAClC,YAAY,GAAG,EAAE,CAAC;oBAClB,oBAAoB,GAAG,SAAS,CAAC;oBACjC,SAAS;iBACV;qBAAM;oBACL,YAAY,CAAC,IAAI,CAAC;wBAChB,IAAI,EAAE,SAAS;wBACf,IAAI,EAAE,SAAS,GAAG,SAAS;wBAC3B,IAAI,EAAE,KAAK,CAAC,IAAI;wBAChB,IAAI,EAAE,KAAK,CAAC,IAAI,GAAG,CAAC;wBACpB,IAAI,EAAE,KAAK,CAAC,IAAI;qBACjB,CAAC,CAAC;oBACH,KAAK,CAAC,IAAI,EAAE,CAAC;oBACb,SAAS,IAAI,SAAS,CAAC;oBACvB,oBAAoB,IAAI,SAAS,CAAC;oBAClC,EAAE,EAAE,CAAC;iBACN;aACF;YACD,oBAAoB;YACpB,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,oBAAoB,GAAG,EAAE,CAAC,CAAC;YAC5D,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,EAAE,CAAC,CAAC;YAC3C,IAAI,MAAM,GAAG,CAAC,EAAE;gBACd,YAAY,CAAC,IAAI,CAAC;oBAChB,IAAI,EAAE,KAAK,CAAC,IAAI;oBAChB,IAAI,EAAE,KAAK,CAAC,IAAI;oBAChB,IAAI,EAAE,KAAK,CAAC,IAAI;oBAChB,IAAI,EAAE,KAAK,CAAC,IAAI,GAAG,MAAM;oBACzB,IAAI,EAAE,KAAK,CAAC,IAAI;iBACjB,CAAC,CAAC;gBACH,KAAK,CAAC,IAAI,IAAI,MAAM,CAAC;gBACrB,EAAE,IAAI,MAAM,CAAC;gBACb,oBAAoB,IAAI,MAAM,GAAG,EAAE,CAAC;aACrC;YACD,6BAA6B;YAC7B,IAAI,oBAAoB,GAAG,CAAC,IAAI,KAAK,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,EAAE;gBACvD,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,GAAG,oBAAoB,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;gBACrE,YAAY,CAAC,IAAI,CAAC;oBAChB,IAAI,EAAE,KAAK,CAAC,IAAI;oBAChB,IAAI,EAAE,IAAI;oBACV,IAAI,EAAE,KAAK,CAAC,IAAI;oBAChB,IAAI,EAAE,KAAK,CAAC,IAAI,GAAG,CAAC;oBACpB,IAAI,EAAE,KAAK,CAAC,IAAI;iBACjB,CAAC,CAAC;gBACH,oBAAoB,IAAI,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;gBAC1C,IAAI,IAAI,GAAG,KAAK,CAAC,IAAI,EAAE;oBACrB,SAAS,GAAG,IAAI,CAAC;iBAClB;qBAAM;oBACL,KAAK,CAAC,IAAI,EAAE,CAAC;iBACd;aACF;YACD,IAAI,oBAAoB,KAAK,CAAC,EAAE;gBAC9B,MAAM,MAAM,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;gBAC1C,YAAY,GAAG,EAAE,CAAC;gBAClB,oBAAoB,GAAG,SAAS,CAAC;aAClC;SACF;QACD,MAAM,IAAA,iBAAO,EAAC,CAAC,CAAC,CAAC,CAAC,2KAA2K;KAC9L;IACD,IAAI,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE;QAC3B,MAAM,MAAM,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;KAC3C;AACH,CAAC;AAEQ,gDAAkB"}
@@ -1,47 +1,47 @@
1
- import { BBox2d } from '@turf/helpers/dist/js/lib/geojson';
2
- import { Feature, MultiPolygon, Polygon } from '@turf/turf';
3
- import { ITile, ITileRange } from '../models/interfaces/geo/iTile';
4
- /**
5
- * class for generating and decoding tile hashes
6
- */
7
- export declare class TileRanger {
8
- /**
9
- * converts tile to tile range of specified zoom level
10
- * @param tile
11
- * @param zoom target tile range zoom
12
- * @returns
13
- */
14
- tileToRange(tile: ITile, zoom: number): ITileRange;
15
- /**
16
- * generate tile hashes
17
- * @param footprint footprint to cover with generated tile hashes
18
- * @param zoom max hash zoom
19
- * @returns
20
- */
21
- encodeFootprint(footprint: Polygon | Feature<Polygon | MultiPolygon>, zoom: number, verbose?: boolean): Generator<ITileRange>;
22
- /**
23
- * generate tile
24
- * @param bbox bbox to cover with generated tiles
25
- * @param zoom target tiles zoom level
26
- */
27
- generateTiles(bbox: BBox2d, zoom: number): Generator<ITile>;
28
- /**
29
- * generate tile
30
- * @param footprint footprint to cover with generated tiles
31
- * @param zoom target tiles zoom level
32
- */
33
- generateTiles(footprint: Polygon | Feature<Polygon | MultiPolygon>, zoom: number): Generator<ITile>;
34
- private generateRanges;
35
- /**
36
- * generate tile
37
- * @param tile tile to get all intersecting tiles from
38
- * @param targetZoom target tiles zoom level
39
- * @param intersectionTarget original zoom level and footprint to intersect
40
- * @param intersectionFunction the intersection function to be called
41
- */
42
- private optimizeHash;
43
- private generateSubTiles;
44
- private readonly tileFootprintIntersection;
45
- private isBbox;
46
- }
1
+ import { BBox2d } from '@turf/helpers/dist/js/lib/geojson';
2
+ import { Feature, MultiPolygon, Polygon } from '@turf/turf';
3
+ import { ITile, ITileRange } from '../models/interfaces/geo/iTile';
4
+ /**
5
+ * class for generating and decoding tile hashes
6
+ */
7
+ export declare class TileRanger {
8
+ /**
9
+ * converts tile to tile range of specified zoom level
10
+ * @param tile
11
+ * @param zoom target tile range zoom
12
+ * @returns
13
+ */
14
+ tileToRange(tile: ITile, zoom: number): ITileRange;
15
+ /**
16
+ * generate tile hashes
17
+ * @param footprint footprint to cover with generated tile hashes
18
+ * @param zoom max hash zoom
19
+ * @returns
20
+ */
21
+ encodeFootprint(footprint: Polygon | Feature<Polygon | MultiPolygon>, zoom: number, verbose?: boolean): AsyncGenerator<ITileRange>;
22
+ /**
23
+ * generate tile
24
+ * @param bbox bbox to cover with generated tiles
25
+ * @param zoom target tiles zoom level
26
+ */
27
+ generateTiles(bbox: BBox2d, zoom: number): AsyncGenerator<ITile>;
28
+ /**
29
+ * generate tile
30
+ * @param footprint footprint to cover with generated tiles
31
+ * @param zoom target tiles zoom level
32
+ */
33
+ generateTiles(footprint: Polygon | Feature<Polygon | MultiPolygon>, zoom: number): AsyncGenerator<ITile>;
34
+ private generateRanges;
35
+ /**
36
+ * generate tile
37
+ * @param tile tile to get all intersecting tiles from
38
+ * @param targetZoom target tiles zoom level
39
+ * @param intersectionTarget original zoom level and footprint to intersect
40
+ * @param intersectionFunction the intersection function to be called
41
+ */
42
+ private optimizeHash;
43
+ private generateSubTiles;
44
+ private readonly tileFootprintIntersection;
45
+ private isBbox;
46
+ }
47
47
  //# sourceMappingURL=tileRanger.d.ts.map