styled-map-package 4.0.1 → 5.0.0-pre.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 (85) hide show
  1. package/bin/smp-download.js +10 -6
  2. package/bin/smp-mbtiles.js +5 -7
  3. package/bin/smp-view.js +34 -26
  4. package/lib/reporters.js +92 -0
  5. package/package.json +8 -187
  6. package/LICENSE.md +0 -7
  7. package/README.md +0 -28
  8. package/dist/download.cjs +0 -101
  9. package/dist/download.d.cts +0 -65
  10. package/dist/download.d.ts +0 -65
  11. package/dist/download.js +0 -77
  12. package/dist/from-mbtiles.cjs +0 -91
  13. package/dist/from-mbtiles.d.cts +0 -17
  14. package/dist/from-mbtiles.d.ts +0 -17
  15. package/dist/from-mbtiles.js +0 -57
  16. package/dist/index.cjs +0 -49
  17. package/dist/index.d.cts +0 -27
  18. package/dist/index.d.ts +0 -27
  19. package/dist/index.js +0 -18
  20. package/dist/reader-watch.cjs +0 -135
  21. package/dist/reader-watch.d.cts +0 -24
  22. package/dist/reader-watch.d.ts +0 -24
  23. package/dist/reader-watch.js +0 -101
  24. package/dist/reader.cjs +0 -167
  25. package/dist/reader.d.cts +0 -62
  26. package/dist/reader.d.ts +0 -62
  27. package/dist/reader.js +0 -138
  28. package/dist/reporters.cjs +0 -122
  29. package/dist/reporters.d.cts +0 -10
  30. package/dist/reporters.d.ts +0 -10
  31. package/dist/reporters.js +0 -88
  32. package/dist/server.cjs +0 -78
  33. package/dist/server.d.cts +0 -48
  34. package/dist/server.d.ts +0 -48
  35. package/dist/server.js +0 -54
  36. package/dist/style-downloader.cjs +0 -312
  37. package/dist/style-downloader.d.cts +0 -120
  38. package/dist/style-downloader.d.ts +0 -120
  39. package/dist/style-downloader.js +0 -288
  40. package/dist/tile-downloader.cjs +0 -158
  41. package/dist/tile-downloader.d.cts +0 -84
  42. package/dist/tile-downloader.d.ts +0 -84
  43. package/dist/tile-downloader.js +0 -126
  44. package/dist/types-B4Xn1F9K.d.cts +0 -189
  45. package/dist/types-B4Xn1F9K.d.ts +0 -189
  46. package/dist/utils/errors.cjs +0 -41
  47. package/dist/utils/errors.d.cts +0 -18
  48. package/dist/utils/errors.d.ts +0 -18
  49. package/dist/utils/errors.js +0 -16
  50. package/dist/utils/fetch.cjs +0 -96
  51. package/dist/utils/fetch.d.cts +0 -51
  52. package/dist/utils/fetch.d.ts +0 -51
  53. package/dist/utils/fetch.js +0 -62
  54. package/dist/utils/file-formats.cjs +0 -98
  55. package/dist/utils/file-formats.d.cts +0 -35
  56. package/dist/utils/file-formats.d.ts +0 -35
  57. package/dist/utils/file-formats.js +0 -62
  58. package/dist/utils/geo.cjs +0 -84
  59. package/dist/utils/geo.d.cts +0 -46
  60. package/dist/utils/geo.d.ts +0 -46
  61. package/dist/utils/geo.js +0 -56
  62. package/dist/utils/mapbox.cjs +0 -121
  63. package/dist/utils/mapbox.d.cts +0 -43
  64. package/dist/utils/mapbox.d.ts +0 -43
  65. package/dist/utils/mapbox.js +0 -91
  66. package/dist/utils/misc.cjs +0 -39
  67. package/dist/utils/misc.d.cts +0 -22
  68. package/dist/utils/misc.d.ts +0 -22
  69. package/dist/utils/misc.js +0 -13
  70. package/dist/utils/streams.cjs +0 -130
  71. package/dist/utils/streams.d.cts +0 -73
  72. package/dist/utils/streams.d.ts +0 -73
  73. package/dist/utils/streams.js +0 -103
  74. package/dist/utils/style.cjs +0 -126
  75. package/dist/utils/style.d.cts +0 -69
  76. package/dist/utils/style.d.ts +0 -69
  77. package/dist/utils/style.js +0 -98
  78. package/dist/utils/templates.cjs +0 -114
  79. package/dist/utils/templates.d.cts +0 -78
  80. package/dist/utils/templates.d.ts +0 -78
  81. package/dist/utils/templates.js +0 -79
  82. package/dist/writer.cjs +0 -401
  83. package/dist/writer.d.cts +0 -7
  84. package/dist/writer.d.ts +0 -7
  85. package/dist/writer.js +0 -374
@@ -1,46 +0,0 @@
1
- /**
2
- * @typedef {[number, number, number, number]} BBox
3
- */
4
- /**
5
- * Return the bounding box for the given tile.
6
- *
7
- * @param {{ x: number, y: number, z: number }} tile
8
- * @returns {BBox} Bounding Box [w, s, e, n]
9
- */
10
- declare function tileToBBox({ x, y, z }: {
11
- x: number;
12
- y: number;
13
- z: number;
14
- }): BBox;
15
- /**
16
- * @param {{ x: number, y: number, z: number }} tile
17
- */
18
- declare function getQuadkey({ x, y, z }: {
19
- x: number;
20
- y: number;
21
- z: number;
22
- }): string;
23
- /**
24
- * From an array of tile URL templates, get the URL for the given tile.
25
- *
26
- * @param {string[]} urls
27
- * @param {{ x: number, y: number, z: number, scheme?: 'xyz' | 'tms' }} opts
28
- */
29
- declare function getTileUrl(urls: string[], { x, y, z, scheme }: {
30
- x: number;
31
- y: number;
32
- z: number;
33
- scheme?: "xyz" | "tms";
34
- }): string;
35
- /**
36
- * Returns a bbox that is the smallest bounding box that contains all the input bboxes.
37
- *
38
- * @param {[BBox, ...BBox[]]} bboxes
39
- * @returns {BBox} Bounding Box [w, s, e, n]
40
- */
41
- declare function unionBBox(bboxes: [BBox, ...BBox[]]): BBox;
42
- /** Spherical Mercator max bounds, rounded to 6 decimal places */
43
- declare const MAX_BOUNDS: BBox;
44
- type BBox = [number, number, number, number];
45
-
46
- export { type BBox, MAX_BOUNDS, getQuadkey, getTileUrl, tileToBBox, unionBBox };
@@ -1,46 +0,0 @@
1
- /**
2
- * @typedef {[number, number, number, number]} BBox
3
- */
4
- /**
5
- * Return the bounding box for the given tile.
6
- *
7
- * @param {{ x: number, y: number, z: number }} tile
8
- * @returns {BBox} Bounding Box [w, s, e, n]
9
- */
10
- declare function tileToBBox({ x, y, z }: {
11
- x: number;
12
- y: number;
13
- z: number;
14
- }): BBox;
15
- /**
16
- * @param {{ x: number, y: number, z: number }} tile
17
- */
18
- declare function getQuadkey({ x, y, z }: {
19
- x: number;
20
- y: number;
21
- z: number;
22
- }): string;
23
- /**
24
- * From an array of tile URL templates, get the URL for the given tile.
25
- *
26
- * @param {string[]} urls
27
- * @param {{ x: number, y: number, z: number, scheme?: 'xyz' | 'tms' }} opts
28
- */
29
- declare function getTileUrl(urls: string[], { x, y, z, scheme }: {
30
- x: number;
31
- y: number;
32
- z: number;
33
- scheme?: "xyz" | "tms";
34
- }): string;
35
- /**
36
- * Returns a bbox that is the smallest bounding box that contains all the input bboxes.
37
- *
38
- * @param {[BBox, ...BBox[]]} bboxes
39
- * @returns {BBox} Bounding Box [w, s, e, n]
40
- */
41
- declare function unionBBox(bboxes: [BBox, ...BBox[]]): BBox;
42
- /** Spherical Mercator max bounds, rounded to 6 decimal places */
43
- declare const MAX_BOUNDS: BBox;
44
- type BBox = [number, number, number, number];
45
-
46
- export { type BBox, MAX_BOUNDS, getQuadkey, getTileUrl, tileToBBox, unionBBox };
package/dist/utils/geo.js DELETED
@@ -1,56 +0,0 @@
1
- const r2d = 180 / Math.PI;
2
- const MAX_BOUNDS = (
3
- /** @type {BBox} */
4
- [
5
- -180,
6
- -85.051129,
7
- 180,
8
- 85.051129
9
- ]
10
- );
11
- function tileToBBox({ x, y, z }) {
12
- const e = tile2lon({ x: x + 1, z });
13
- const w = tile2lon({ x, z });
14
- const s = tile2lat({ y: y + 1, z });
15
- const n = tile2lat({ y, z });
16
- return [w, s, e, n];
17
- }
18
- function getQuadkey({ x, y, z }) {
19
- let quadkey = "";
20
- let mask;
21
- for (let i = z; i > 0; i--) {
22
- mask = 1 << i - 1;
23
- quadkey += (x & mask ? 1 : 0) + (y & mask ? 2 : 0);
24
- }
25
- return quadkey;
26
- }
27
- function getTileUrl(urls, { x, y, z, scheme = "xyz" }) {
28
- const bboxEspg3857 = tileToBBox({ x, y: Math.pow(2, z) - y - 1, z });
29
- const quadkey = getQuadkey({ x, y, z });
30
- return urls[(x + y) % urls.length].replace("{prefix}", (x % 16).toString(16) + (y % 16).toString(16)).replace(/{z}/g, String(z)).replace(/{x}/g, String(x)).replace(/{y}/g, String(scheme === "tms" ? Math.pow(2, z) - y - 1 : y)).replace("{quadkey}", quadkey).replace("{bbox-epsg-3857}", bboxEspg3857.join(","));
31
- }
32
- function unionBBox(bboxes) {
33
- let [w, s, e, n] = bboxes[0];
34
- for (let i = 1; i < bboxes.length; i++) {
35
- const [w1, s1, e1, n1] = bboxes[i];
36
- w = Math.min(w, w1);
37
- s = Math.min(s, s1);
38
- e = Math.max(e, e1);
39
- n = Math.max(n, n1);
40
- }
41
- return [w, s, e, n];
42
- }
43
- function tile2lon({ x, z }) {
44
- return x / Math.pow(2, z) * 360 - 180;
45
- }
46
- function tile2lat({ y, z }) {
47
- const n = Math.PI - 2 * Math.PI * y / Math.pow(2, z);
48
- return r2d * Math.atan(0.5 * (Math.exp(n) - Math.exp(-n)));
49
- }
50
- export {
51
- MAX_BOUNDS,
52
- getQuadkey,
53
- getTileUrl,
54
- tileToBBox,
55
- unionBBox
56
- };
@@ -1,121 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
- var mapbox_exports = {};
20
- __export(mapbox_exports, {
21
- API_URL: () => API_URL,
22
- isMapboxURL: () => isMapboxURL,
23
- normalizeGlyphsURL: () => normalizeGlyphsURL,
24
- normalizeSourceURL: () => normalizeSourceURL,
25
- normalizeSpriteURL: () => normalizeSpriteURL,
26
- normalizeStyleURL: () => normalizeStyleURL,
27
- normalizeTileURL: () => normalizeTileURL
28
- });
29
- module.exports = __toCommonJS(mapbox_exports);
30
- const API_URL = "https://api.mapbox.com";
31
- const HELP = "See https://www.mapbox.com/api-documentation/#access-tokens";
32
- function makeAPIURL(urlObject, accessToken) {
33
- const apiUrlObject = parseUrl(API_URL);
34
- urlObject.protocol = apiUrlObject.protocol;
35
- urlObject.authority = apiUrlObject.authority;
36
- if (!accessToken) {
37
- throw new Error(
38
- `An API access token is required to use a Mapbox style. ${HELP}`
39
- );
40
- }
41
- if (accessToken[0] === "s") {
42
- throw new Error(
43
- `Use a public access token (pk.*) not a secret access token (sk.*). ${HELP}`
44
- );
45
- }
46
- urlObject.params.push(`access_token=${accessToken}`);
47
- return formatUrl(urlObject);
48
- }
49
- function isMapboxURL(url) {
50
- return url.indexOf("mapbox:") === 0;
51
- }
52
- function normalizeStyleURL(url, accessToken) {
53
- if (!isMapboxURL(url)) return url;
54
- if (!accessToken) throw new Error("Mapbox styles require an access token");
55
- const urlObject = parseUrl(url);
56
- urlObject.path = `/styles/v1${urlObject.path}`;
57
- return makeAPIURL(urlObject, accessToken);
58
- }
59
- function normalizeGlyphsURL(url, accessToken) {
60
- if (!isMapboxURL(url)) return url;
61
- if (!accessToken) throw new Error("Mapbox styles require an access token");
62
- const urlObject = parseUrl(url);
63
- urlObject.path = `/fonts/v1${urlObject.path}`;
64
- return makeAPIURL(urlObject, accessToken);
65
- }
66
- function normalizeSourceURL(url, accessToken) {
67
- if (!isMapboxURL(url)) return url;
68
- if (!accessToken) throw new Error("Mapbox styles require an access token");
69
- const urlObject = parseUrl(url);
70
- urlObject.path = `/v4/${urlObject.authority}.json`;
71
- urlObject.params.push("secure");
72
- return makeAPIURL(urlObject, accessToken);
73
- }
74
- function normalizeSpriteURL(url, format, extension, accessToken) {
75
- const urlObject = parseUrl(url);
76
- if (!isMapboxURL(url)) {
77
- urlObject.path += `${format}${extension}`;
78
- return formatUrl(urlObject);
79
- }
80
- urlObject.path = `/styles/v1${urlObject.path}/sprite${format}${extension}`;
81
- return makeAPIURL(urlObject, accessToken);
82
- }
83
- const imageExtensionRe = /(\.(png|jpg)\d*)(?=$)/;
84
- function normalizeTileURL(tileURL, sourceURL, tileSize, { devicePixelRatio = 1, supportsWebp = false } = {}) {
85
- if (!sourceURL || !isMapboxURL(sourceURL)) return tileURL;
86
- const urlObject = parseUrl(tileURL);
87
- const suffix = devicePixelRatio >= 2 || tileSize === 512 ? "@2x" : "";
88
- const extension = supportsWebp ? ".webp" : "$1";
89
- urlObject.path = urlObject.path.replace(
90
- imageExtensionRe,
91
- `${suffix}${extension}`
92
- );
93
- return formatUrl(urlObject);
94
- }
95
- const urlRe = /^(\w+):\/\/([^/?]*)(\/[^?]+)?\??(.+)?/;
96
- function parseUrl(url) {
97
- const parts = url.match(urlRe);
98
- if (!parts) {
99
- throw new Error("Unable to parse URL object");
100
- }
101
- return {
102
- protocol: parts[1],
103
- authority: parts[2],
104
- path: parts[3] || "/",
105
- params: parts[4] ? parts[4].split("&") : []
106
- };
107
- }
108
- function formatUrl(obj) {
109
- const params = obj.params.length ? `?${obj.params.join("&")}` : "";
110
- return `${obj.protocol}://${obj.authority}${obj.path}${params}`;
111
- }
112
- // Annotate the CommonJS export names for ESM import in node:
113
- 0 && (module.exports = {
114
- API_URL,
115
- isMapboxURL,
116
- normalizeGlyphsURL,
117
- normalizeSourceURL,
118
- normalizeSpriteURL,
119
- normalizeStyleURL,
120
- normalizeTileURL
121
- });
@@ -1,43 +0,0 @@
1
- /** @param {string} url */
2
- declare function isMapboxURL(url: string): boolean;
3
- /**
4
- * @param {string} url
5
- * @param {string} [accessToken]
6
- */
7
- declare function normalizeStyleURL(url: string, accessToken?: string): string;
8
- /**
9
- * @param {string} url
10
- * @param {string} [accessToken]
11
- */
12
- declare function normalizeGlyphsURL(url: string, accessToken?: string): string;
13
- /**
14
- * @param {string} url
15
- * @param {string} [accessToken]
16
- */
17
- declare function normalizeSourceURL(url: string, accessToken?: string): string;
18
- /**
19
- * @param {string} url
20
- * @param {'' | '@2x'} format
21
- * @param {'.png' | '.json'} extension
22
- * @param {string} [accessToken]
23
- */
24
- declare function normalizeSpriteURL(url: string, format: "" | "@2x", extension: ".png" | ".json", accessToken?: string): string;
25
- /**
26
- * @param {any} tileURL
27
- * @param {string} sourceURL
28
- * @param {256 | 512} [tileSize]
29
- * @param {{ devicePixelRatio?: number; supportsWebp?: boolean; }} [opts]
30
- */
31
- declare function normalizeTileURL(tileURL: any, sourceURL: string, tileSize?: 256 | 512, { devicePixelRatio, supportsWebp }?: {
32
- devicePixelRatio?: number;
33
- supportsWebp?: boolean;
34
- }): any;
35
- declare const API_URL: "https://api.mapbox.com";
36
- type URLObject = {
37
- protocol: string;
38
- authority: string;
39
- path: string;
40
- params: string[];
41
- };
42
-
43
- export { API_URL, type URLObject, isMapboxURL, normalizeGlyphsURL, normalizeSourceURL, normalizeSpriteURL, normalizeStyleURL, normalizeTileURL };
@@ -1,43 +0,0 @@
1
- /** @param {string} url */
2
- declare function isMapboxURL(url: string): boolean;
3
- /**
4
- * @param {string} url
5
- * @param {string} [accessToken]
6
- */
7
- declare function normalizeStyleURL(url: string, accessToken?: string): string;
8
- /**
9
- * @param {string} url
10
- * @param {string} [accessToken]
11
- */
12
- declare function normalizeGlyphsURL(url: string, accessToken?: string): string;
13
- /**
14
- * @param {string} url
15
- * @param {string} [accessToken]
16
- */
17
- declare function normalizeSourceURL(url: string, accessToken?: string): string;
18
- /**
19
- * @param {string} url
20
- * @param {'' | '@2x'} format
21
- * @param {'.png' | '.json'} extension
22
- * @param {string} [accessToken]
23
- */
24
- declare function normalizeSpriteURL(url: string, format: "" | "@2x", extension: ".png" | ".json", accessToken?: string): string;
25
- /**
26
- * @param {any} tileURL
27
- * @param {string} sourceURL
28
- * @param {256 | 512} [tileSize]
29
- * @param {{ devicePixelRatio?: number; supportsWebp?: boolean; }} [opts]
30
- */
31
- declare function normalizeTileURL(tileURL: any, sourceURL: string, tileSize?: 256 | 512, { devicePixelRatio, supportsWebp }?: {
32
- devicePixelRatio?: number;
33
- supportsWebp?: boolean;
34
- }): any;
35
- declare const API_URL: "https://api.mapbox.com";
36
- type URLObject = {
37
- protocol: string;
38
- authority: string;
39
- path: string;
40
- params: string[];
41
- };
42
-
43
- export { API_URL, type URLObject, isMapboxURL, normalizeGlyphsURL, normalizeSourceURL, normalizeSpriteURL, normalizeStyleURL, normalizeTileURL };
@@ -1,91 +0,0 @@
1
- const API_URL = "https://api.mapbox.com";
2
- const HELP = "See https://www.mapbox.com/api-documentation/#access-tokens";
3
- function makeAPIURL(urlObject, accessToken) {
4
- const apiUrlObject = parseUrl(API_URL);
5
- urlObject.protocol = apiUrlObject.protocol;
6
- urlObject.authority = apiUrlObject.authority;
7
- if (!accessToken) {
8
- throw new Error(
9
- `An API access token is required to use a Mapbox style. ${HELP}`
10
- );
11
- }
12
- if (accessToken[0] === "s") {
13
- throw new Error(
14
- `Use a public access token (pk.*) not a secret access token (sk.*). ${HELP}`
15
- );
16
- }
17
- urlObject.params.push(`access_token=${accessToken}`);
18
- return formatUrl(urlObject);
19
- }
20
- function isMapboxURL(url) {
21
- return url.indexOf("mapbox:") === 0;
22
- }
23
- function normalizeStyleURL(url, accessToken) {
24
- if (!isMapboxURL(url)) return url;
25
- if (!accessToken) throw new Error("Mapbox styles require an access token");
26
- const urlObject = parseUrl(url);
27
- urlObject.path = `/styles/v1${urlObject.path}`;
28
- return makeAPIURL(urlObject, accessToken);
29
- }
30
- function normalizeGlyphsURL(url, accessToken) {
31
- if (!isMapboxURL(url)) return url;
32
- if (!accessToken) throw new Error("Mapbox styles require an access token");
33
- const urlObject = parseUrl(url);
34
- urlObject.path = `/fonts/v1${urlObject.path}`;
35
- return makeAPIURL(urlObject, accessToken);
36
- }
37
- function normalizeSourceURL(url, accessToken) {
38
- if (!isMapboxURL(url)) return url;
39
- if (!accessToken) throw new Error("Mapbox styles require an access token");
40
- const urlObject = parseUrl(url);
41
- urlObject.path = `/v4/${urlObject.authority}.json`;
42
- urlObject.params.push("secure");
43
- return makeAPIURL(urlObject, accessToken);
44
- }
45
- function normalizeSpriteURL(url, format, extension, accessToken) {
46
- const urlObject = parseUrl(url);
47
- if (!isMapboxURL(url)) {
48
- urlObject.path += `${format}${extension}`;
49
- return formatUrl(urlObject);
50
- }
51
- urlObject.path = `/styles/v1${urlObject.path}/sprite${format}${extension}`;
52
- return makeAPIURL(urlObject, accessToken);
53
- }
54
- const imageExtensionRe = /(\.(png|jpg)\d*)(?=$)/;
55
- function normalizeTileURL(tileURL, sourceURL, tileSize, { devicePixelRatio = 1, supportsWebp = false } = {}) {
56
- if (!sourceURL || !isMapboxURL(sourceURL)) return tileURL;
57
- const urlObject = parseUrl(tileURL);
58
- const suffix = devicePixelRatio >= 2 || tileSize === 512 ? "@2x" : "";
59
- const extension = supportsWebp ? ".webp" : "$1";
60
- urlObject.path = urlObject.path.replace(
61
- imageExtensionRe,
62
- `${suffix}${extension}`
63
- );
64
- return formatUrl(urlObject);
65
- }
66
- const urlRe = /^(\w+):\/\/([^/?]*)(\/[^?]+)?\??(.+)?/;
67
- function parseUrl(url) {
68
- const parts = url.match(urlRe);
69
- if (!parts) {
70
- throw new Error("Unable to parse URL object");
71
- }
72
- return {
73
- protocol: parts[1],
74
- authority: parts[2],
75
- path: parts[3] || "/",
76
- params: parts[4] ? parts[4].split("&") : []
77
- };
78
- }
79
- function formatUrl(obj) {
80
- const params = obj.params.length ? `?${obj.params.join("&")}` : "";
81
- return `${obj.protocol}://${obj.authority}${obj.path}${params}`;
82
- }
83
- export {
84
- API_URL,
85
- isMapboxURL,
86
- normalizeGlyphsURL,
87
- normalizeSourceURL,
88
- normalizeSpriteURL,
89
- normalizeStyleURL,
90
- normalizeTileURL
91
- };
@@ -1,39 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
- var misc_exports = {};
20
- __export(misc_exports, {
21
- clone: () => clone,
22
- hasOwn: () => hasOwn,
23
- noop: () => noop
24
- });
25
- module.exports = __toCommonJS(misc_exports);
26
- function clone(obj) {
27
- return JSON.parse(JSON.stringify(obj));
28
- }
29
- function noop() {
30
- }
31
- function hasOwn(obj, key) {
32
- return Object.hasOwn(obj, key);
33
- }
34
- // Annotate the CommonJS export names for ESM import in node:
35
- 0 && (module.exports = {
36
- clone,
37
- hasOwn,
38
- noop
39
- });
@@ -1,22 +0,0 @@
1
- /**
2
- * Dumb and quick clone an object. Won't keep undefined properties. Types could
3
- * be tighted so that return type excludes undefined properties, but not really
4
- * needed.
5
- *
6
- * @template T
7
- * @param {T} obj
8
- * @returns {T}
9
- */
10
- declare function clone<T>(obj: T): T;
11
- declare function noop(): void;
12
- /**
13
- * Like `Object.hasOwn`, but refines the type of `key`.
14
- *
15
- * @template {Record<string, unknown>} T
16
- * @param {T} obj
17
- * @param {string} key
18
- * @returns {key is (keyof T)}
19
- */
20
- declare function hasOwn<T extends Record<string, unknown>>(obj: T, key: string): key is (keyof T);
21
-
22
- export { clone, hasOwn, noop };
@@ -1,22 +0,0 @@
1
- /**
2
- * Dumb and quick clone an object. Won't keep undefined properties. Types could
3
- * be tighted so that return type excludes undefined properties, but not really
4
- * needed.
5
- *
6
- * @template T
7
- * @param {T} obj
8
- * @returns {T}
9
- */
10
- declare function clone<T>(obj: T): T;
11
- declare function noop(): void;
12
- /**
13
- * Like `Object.hasOwn`, but refines the type of `key`.
14
- *
15
- * @template {Record<string, unknown>} T
16
- * @param {T} obj
17
- * @param {string} key
18
- * @returns {key is (keyof T)}
19
- */
20
- declare function hasOwn<T extends Record<string, unknown>>(obj: T, key: string): key is (keyof T);
21
-
22
- export { clone, hasOwn, noop };
@@ -1,13 +0,0 @@
1
- function clone(obj) {
2
- return JSON.parse(JSON.stringify(obj));
3
- }
4
- function noop() {
5
- }
6
- function hasOwn(obj, key) {
7
- return Object.hasOwn(obj, key);
8
- }
9
- export {
10
- clone,
11
- hasOwn,
12
- noop
13
- };
@@ -1,130 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
- var streams_exports = {};
20
- __export(streams_exports, {
21
- ProgressStream: () => ProgressStream,
22
- fromWebReadableStream: () => fromWebReadableStream,
23
- isWebReadableStream: () => isWebReadableStream,
24
- writeStreamFromAsync: () => writeStreamFromAsync
25
- });
26
- module.exports = __toCommonJS(streams_exports);
27
- var import_readable_stream = require("readable-stream");
28
- function writeStreamFromAsync(fn, { concurrency = 16 } = {}) {
29
- return new import_readable_stream.Writable({
30
- highWaterMark: concurrency,
31
- objectMode: true,
32
- write(chunk, encoding, callback) {
33
- fn.apply(null, chunk).then(() => callback(), callback);
34
- }
35
- });
36
- }
37
- function fromWebReadableStream(readableStream, options = {}) {
38
- if (!isWebReadableStream(readableStream)) {
39
- throw new Error("First argument must be a ReadableStream");
40
- }
41
- const { highWaterMark, encoding, objectMode = false, signal } = options;
42
- if (encoding !== void 0 && !Buffer.isEncoding(encoding))
43
- throw new Error("Invalid encoding");
44
- const reader = readableStream.getReader();
45
- let closed = false;
46
- const readable = new import_readable_stream.Readable({
47
- objectMode,
48
- highWaterMark,
49
- encoding,
50
- // @ts-ignore
51
- signal,
52
- read() {
53
- reader.read().then(
54
- (chunk) => {
55
- if (chunk.done) {
56
- readable.push(null);
57
- } else {
58
- readable.push(chunk.value);
59
- }
60
- },
61
- (error) => readable.destroy(error)
62
- );
63
- },
64
- destroy(error, callback) {
65
- function done() {
66
- try {
67
- callback(error);
68
- } catch (error2) {
69
- process.nextTick(() => {
70
- throw error2;
71
- });
72
- }
73
- }
74
- if (!closed) {
75
- reader.cancel(error).then(done, done);
76
- return;
77
- }
78
- done();
79
- }
80
- });
81
- reader.closed.then(
82
- () => {
83
- closed = true;
84
- },
85
- (error) => {
86
- closed = true;
87
- readable.destroy(error);
88
- }
89
- );
90
- return readable;
91
- }
92
- function isWebReadableStream(obj) {
93
- return !!(typeof obj === "object" && obj !== null && "pipeThrough" in obj && typeof obj.pipeThrough === "function" && "getReader" in obj && typeof obj.getReader === "function" && "cancel" in obj && typeof obj.cancel === "function");
94
- }
95
- class ProgressStream extends import_readable_stream.Transform {
96
- #onprogress;
97
- #byteLength = 0;
98
- /**
99
- * @param {ProgressStreamOptions} [opts]
100
- */
101
- constructor({ onprogress, ...opts } = {}) {
102
- super(opts);
103
- this.#onprogress = onprogress;
104
- }
105
- /** Total bytes that have passed through this stream */
106
- get byteLength() {
107
- return this.#byteLength;
108
- }
109
- /**
110
- * @override
111
- * @param {Buffer | Uint8Array} chunk
112
- * @param {Parameters<Transform['_transform']>[1]} encoding
113
- * @param {Parameters<Transform['_transform']>[2]} callback
114
- */
115
- _transform(chunk, encoding, callback) {
116
- this.#byteLength += chunk.length;
117
- this.#onprogress?.({
118
- totalBytes: this.#byteLength,
119
- chunkBytes: chunk.length
120
- });
121
- callback(null, chunk);
122
- }
123
- }
124
- // Annotate the CommonJS export names for ESM import in node:
125
- 0 && (module.exports = {
126
- ProgressStream,
127
- fromWebReadableStream,
128
- isWebReadableStream,
129
- writeStreamFromAsync
130
- });