styled-map-package-api 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.
- package/dist/download.cjs +100 -0
- package/dist/download.d.cts +64 -0
- package/dist/download.d.ts +64 -0
- package/dist/download.js +76 -0
- package/dist/from-mbtiles.cjs +81 -0
- package/dist/from-mbtiles.d.cts +10 -0
- package/dist/from-mbtiles.d.ts +10 -0
- package/dist/from-mbtiles.js +57 -0
- package/dist/index.cjs +46 -0
- package/dist/index.d.cts +25 -0
- package/dist/index.d.ts +25 -0
- package/dist/index.js +16 -0
- package/dist/reader.cjs +287 -0
- package/dist/reader.d.cts +68 -0
- package/dist/reader.d.ts +68 -0
- package/dist/reader.js +259 -0
- package/dist/server.cjs +73 -0
- package/dist/server.d.cts +46 -0
- package/dist/server.d.ts +46 -0
- package/dist/server.js +49 -0
- package/dist/style-downloader.cjs +314 -0
- package/dist/style-downloader.d.cts +119 -0
- package/dist/style-downloader.d.ts +119 -0
- package/dist/style-downloader.js +290 -0
- package/dist/tile-downloader.cjs +156 -0
- package/dist/tile-downloader.d.cts +83 -0
- package/dist/tile-downloader.d.ts +83 -0
- package/dist/tile-downloader.js +124 -0
- package/dist/types-CJq90eOB.d.cts +184 -0
- package/dist/types-CJq90eOB.d.ts +184 -0
- package/dist/utils/errors.cjs +41 -0
- package/dist/utils/errors.d.cts +18 -0
- package/dist/utils/errors.d.ts +18 -0
- package/dist/utils/errors.js +16 -0
- package/dist/utils/fetch.cjs +97 -0
- package/dist/utils/fetch.d.cts +50 -0
- package/dist/utils/fetch.d.ts +50 -0
- package/dist/utils/fetch.js +63 -0
- package/dist/utils/file-formats.cjs +96 -0
- package/dist/utils/file-formats.d.cts +33 -0
- package/dist/utils/file-formats.d.ts +33 -0
- package/dist/utils/file-formats.js +70 -0
- package/dist/utils/geo.cjs +84 -0
- package/dist/utils/geo.d.cts +46 -0
- package/dist/utils/geo.d.ts +46 -0
- package/dist/utils/geo.js +56 -0
- package/dist/utils/mapbox.cjs +121 -0
- package/dist/utils/mapbox.d.cts +43 -0
- package/dist/utils/mapbox.d.ts +43 -0
- package/dist/utils/mapbox.js +91 -0
- package/dist/utils/misc.cjs +39 -0
- package/dist/utils/misc.d.cts +22 -0
- package/dist/utils/misc.d.ts +22 -0
- package/dist/utils/misc.js +13 -0
- package/dist/utils/streams.cjs +99 -0
- package/dist/utils/streams.d.cts +49 -0
- package/dist/utils/streams.d.ts +49 -0
- package/dist/utils/streams.js +73 -0
- package/dist/utils/style.cjs +126 -0
- package/dist/utils/style.d.cts +67 -0
- package/dist/utils/style.d.ts +67 -0
- package/dist/utils/style.js +98 -0
- package/dist/utils/templates.cjs +124 -0
- package/dist/utils/templates.d.cts +80 -0
- package/dist/utils/templates.d.ts +80 -0
- package/dist/utils/templates.js +85 -0
- package/dist/writer.cjs +465 -0
- package/dist/writer.d.cts +5 -0
- package/dist/writer.d.ts +5 -0
- package/dist/writer.js +452 -0
- package/package.json +161 -0
|
@@ -0,0 +1,100 @@
|
|
|
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 download_exports = {};
|
|
20
|
+
__export(download_exports, {
|
|
21
|
+
download: () => download
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(download_exports);
|
|
24
|
+
var import_style_downloader = require('./style-downloader.cjs');
|
|
25
|
+
var import_streams = require('./utils/streams.cjs');
|
|
26
|
+
var import_writer = require('./writer.cjs');
|
|
27
|
+
function download({ bbox, maxzoom, styleUrl, onprogress, accessToken }) {
|
|
28
|
+
const downloader = new import_style_downloader.StyleDownloader(styleUrl, {
|
|
29
|
+
concurrency: 24,
|
|
30
|
+
mapboxAccessToken: accessToken
|
|
31
|
+
});
|
|
32
|
+
let start = Date.now();
|
|
33
|
+
let progress = {
|
|
34
|
+
tiles: { downloaded: 0, totalBytes: 0, total: 0, skipped: 0, done: false },
|
|
35
|
+
style: { done: false },
|
|
36
|
+
sprites: { downloaded: 0, done: false },
|
|
37
|
+
glyphs: { downloaded: 0, total: 0, totalBytes: 0, done: false },
|
|
38
|
+
output: { totalBytes: 0, done: false },
|
|
39
|
+
elapsedMs: 0
|
|
40
|
+
};
|
|
41
|
+
function handleProgress(update) {
|
|
42
|
+
progress = { ...progress, ...update, elapsedMs: Date.now() - start };
|
|
43
|
+
onprogress?.(progress);
|
|
44
|
+
}
|
|
45
|
+
const sizeCounter = new TransformStream({
|
|
46
|
+
transform(chunk, controller) {
|
|
47
|
+
handleProgress({
|
|
48
|
+
output: {
|
|
49
|
+
totalBytes: progress.output.totalBytes + chunk.byteLength,
|
|
50
|
+
done: false
|
|
51
|
+
}
|
|
52
|
+
});
|
|
53
|
+
controller.enqueue(chunk);
|
|
54
|
+
},
|
|
55
|
+
flush() {
|
|
56
|
+
handleProgress({ output: { ...progress.output, done: true } });
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
(async () => {
|
|
60
|
+
const style = await downloader.getStyle();
|
|
61
|
+
const writer = new import_writer.Writer(style);
|
|
62
|
+
handleProgress({ style: { done: true } });
|
|
63
|
+
writer.outputStream.pipeTo(sizeCounter.writable).catch(() => {
|
|
64
|
+
});
|
|
65
|
+
try {
|
|
66
|
+
for await (const spriteInfo of downloader.getSprites()) {
|
|
67
|
+
await writer.addSprite(spriteInfo);
|
|
68
|
+
handleProgress({
|
|
69
|
+
sprites: { downloaded: progress.sprites.downloaded + 1, done: false }
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
handleProgress({ sprites: { ...progress.sprites, done: true } });
|
|
73
|
+
const tiles = downloader.getTiles({
|
|
74
|
+
bounds: bbox,
|
|
75
|
+
maxzoom,
|
|
76
|
+
onprogress: (tileStats) => handleProgress({ tiles: { ...tileStats, done: false } })
|
|
77
|
+
});
|
|
78
|
+
await (0, import_streams.readableFromAsync)(tiles).pipeTo(
|
|
79
|
+
writer.createTileWriteStream({ concurrency: 24 })
|
|
80
|
+
);
|
|
81
|
+
handleProgress({ tiles: { ...progress.tiles, done: true } });
|
|
82
|
+
const glyphs = downloader.getGlyphs({
|
|
83
|
+
onprogress: (glyphStats) => handleProgress({ glyphs: { ...glyphStats, done: false } })
|
|
84
|
+
});
|
|
85
|
+
await (0, import_streams.readableFromAsync)(glyphs).pipeTo(writer.createGlyphWriteStream());
|
|
86
|
+
handleProgress({ glyphs: { ...progress.glyphs, done: true } });
|
|
87
|
+
writer.finish();
|
|
88
|
+
} catch (err) {
|
|
89
|
+
writer.abort(
|
|
90
|
+
/** @type {Error} */
|
|
91
|
+
err
|
|
92
|
+
);
|
|
93
|
+
}
|
|
94
|
+
})();
|
|
95
|
+
return sizeCounter.readable;
|
|
96
|
+
}
|
|
97
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
98
|
+
0 && (module.exports = {
|
|
99
|
+
download
|
|
100
|
+
});
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { GlyphDownloadStats } from './style-downloader.cjs';
|
|
2
|
+
import { TileDownloadStats } from './tile-downloader.cjs';
|
|
3
|
+
import { D as DownloadStream } from './types-CJq90eOB.cjs';
|
|
4
|
+
import { BBox } from './utils/geo.cjs';
|
|
5
|
+
import 'ky';
|
|
6
|
+
import '@maplibre/maplibre-gl-style-spec';
|
|
7
|
+
import './utils/fetch.cjs';
|
|
8
|
+
import './utils/streams.cjs';
|
|
9
|
+
import 'stream/web';
|
|
10
|
+
import 'geojson';
|
|
11
|
+
import 'type-fest';
|
|
12
|
+
import 'events';
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* @typedef {object} DownloadProgress
|
|
16
|
+
* @property {import('./tile-downloader.js').TileDownloadStats & { done: boolean }} tiles
|
|
17
|
+
* @property {{ done: boolean }} style
|
|
18
|
+
* @property {{ downloaded: number, done: boolean }} sprites
|
|
19
|
+
* @property {import('./style-downloader.js').GlyphDownloadStats & { done: boolean }} glyphs
|
|
20
|
+
* @property {{ totalBytes: number, done: boolean }} output
|
|
21
|
+
* @property {number} elapsedMs
|
|
22
|
+
*/
|
|
23
|
+
/**
|
|
24
|
+
* Download a map style and its resources for a given bounding box and max zoom
|
|
25
|
+
* level. Returns a readable stream of a "styled map package", a zip file
|
|
26
|
+
* containing all the resources needed to serve the style offline.
|
|
27
|
+
*
|
|
28
|
+
* @param {object} opts
|
|
29
|
+
* @param {import("./utils/geo.js").BBox} opts.bbox Bounding box to download tiles for
|
|
30
|
+
* @param {number} opts.maxzoom Max zoom level to download tiles for
|
|
31
|
+
* @param {string} opts.styleUrl URL of the style to download
|
|
32
|
+
* @param { (progress: DownloadProgress) => void } [opts.onprogress] Optional callback for reporting progress
|
|
33
|
+
* @param {string} [opts.accessToken]
|
|
34
|
+
* @returns {import('./types.js').DownloadStream} Readable stream of the output styled map file
|
|
35
|
+
*/
|
|
36
|
+
declare function download({ bbox, maxzoom, styleUrl, onprogress, accessToken }: {
|
|
37
|
+
bbox: BBox;
|
|
38
|
+
maxzoom: number;
|
|
39
|
+
styleUrl: string;
|
|
40
|
+
onprogress?: ((progress: DownloadProgress) => void) | undefined;
|
|
41
|
+
accessToken?: string | undefined;
|
|
42
|
+
}): DownloadStream;
|
|
43
|
+
type DownloadProgress = {
|
|
44
|
+
tiles: TileDownloadStats & {
|
|
45
|
+
done: boolean;
|
|
46
|
+
};
|
|
47
|
+
style: {
|
|
48
|
+
done: boolean;
|
|
49
|
+
};
|
|
50
|
+
sprites: {
|
|
51
|
+
downloaded: number;
|
|
52
|
+
done: boolean;
|
|
53
|
+
};
|
|
54
|
+
glyphs: GlyphDownloadStats & {
|
|
55
|
+
done: boolean;
|
|
56
|
+
};
|
|
57
|
+
output: {
|
|
58
|
+
totalBytes: number;
|
|
59
|
+
done: boolean;
|
|
60
|
+
};
|
|
61
|
+
elapsedMs: number;
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
export { type DownloadProgress, download };
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { GlyphDownloadStats } from './style-downloader.js';
|
|
2
|
+
import { TileDownloadStats } from './tile-downloader.js';
|
|
3
|
+
import { D as DownloadStream } from './types-CJq90eOB.js';
|
|
4
|
+
import { BBox } from './utils/geo.js';
|
|
5
|
+
import 'ky';
|
|
6
|
+
import '@maplibre/maplibre-gl-style-spec';
|
|
7
|
+
import './utils/fetch.js';
|
|
8
|
+
import './utils/streams.js';
|
|
9
|
+
import 'stream/web';
|
|
10
|
+
import 'geojson';
|
|
11
|
+
import 'type-fest';
|
|
12
|
+
import 'events';
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* @typedef {object} DownloadProgress
|
|
16
|
+
* @property {import('./tile-downloader.js').TileDownloadStats & { done: boolean }} tiles
|
|
17
|
+
* @property {{ done: boolean }} style
|
|
18
|
+
* @property {{ downloaded: number, done: boolean }} sprites
|
|
19
|
+
* @property {import('./style-downloader.js').GlyphDownloadStats & { done: boolean }} glyphs
|
|
20
|
+
* @property {{ totalBytes: number, done: boolean }} output
|
|
21
|
+
* @property {number} elapsedMs
|
|
22
|
+
*/
|
|
23
|
+
/**
|
|
24
|
+
* Download a map style and its resources for a given bounding box and max zoom
|
|
25
|
+
* level. Returns a readable stream of a "styled map package", a zip file
|
|
26
|
+
* containing all the resources needed to serve the style offline.
|
|
27
|
+
*
|
|
28
|
+
* @param {object} opts
|
|
29
|
+
* @param {import("./utils/geo.js").BBox} opts.bbox Bounding box to download tiles for
|
|
30
|
+
* @param {number} opts.maxzoom Max zoom level to download tiles for
|
|
31
|
+
* @param {string} opts.styleUrl URL of the style to download
|
|
32
|
+
* @param { (progress: DownloadProgress) => void } [opts.onprogress] Optional callback for reporting progress
|
|
33
|
+
* @param {string} [opts.accessToken]
|
|
34
|
+
* @returns {import('./types.js').DownloadStream} Readable stream of the output styled map file
|
|
35
|
+
*/
|
|
36
|
+
declare function download({ bbox, maxzoom, styleUrl, onprogress, accessToken }: {
|
|
37
|
+
bbox: BBox;
|
|
38
|
+
maxzoom: number;
|
|
39
|
+
styleUrl: string;
|
|
40
|
+
onprogress?: ((progress: DownloadProgress) => void) | undefined;
|
|
41
|
+
accessToken?: string | undefined;
|
|
42
|
+
}): DownloadStream;
|
|
43
|
+
type DownloadProgress = {
|
|
44
|
+
tiles: TileDownloadStats & {
|
|
45
|
+
done: boolean;
|
|
46
|
+
};
|
|
47
|
+
style: {
|
|
48
|
+
done: boolean;
|
|
49
|
+
};
|
|
50
|
+
sprites: {
|
|
51
|
+
downloaded: number;
|
|
52
|
+
done: boolean;
|
|
53
|
+
};
|
|
54
|
+
glyphs: GlyphDownloadStats & {
|
|
55
|
+
done: boolean;
|
|
56
|
+
};
|
|
57
|
+
output: {
|
|
58
|
+
totalBytes: number;
|
|
59
|
+
done: boolean;
|
|
60
|
+
};
|
|
61
|
+
elapsedMs: number;
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
export { type DownloadProgress, download };
|
package/dist/download.js
ADDED
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { StyleDownloader } from "./style-downloader.js";
|
|
2
|
+
import { readableFromAsync } from "./utils/streams.js";
|
|
3
|
+
import { Writer } from "./writer.js";
|
|
4
|
+
function download({ bbox, maxzoom, styleUrl, onprogress, accessToken }) {
|
|
5
|
+
const downloader = new StyleDownloader(styleUrl, {
|
|
6
|
+
concurrency: 24,
|
|
7
|
+
mapboxAccessToken: accessToken
|
|
8
|
+
});
|
|
9
|
+
let start = Date.now();
|
|
10
|
+
let progress = {
|
|
11
|
+
tiles: { downloaded: 0, totalBytes: 0, total: 0, skipped: 0, done: false },
|
|
12
|
+
style: { done: false },
|
|
13
|
+
sprites: { downloaded: 0, done: false },
|
|
14
|
+
glyphs: { downloaded: 0, total: 0, totalBytes: 0, done: false },
|
|
15
|
+
output: { totalBytes: 0, done: false },
|
|
16
|
+
elapsedMs: 0
|
|
17
|
+
};
|
|
18
|
+
function handleProgress(update) {
|
|
19
|
+
progress = { ...progress, ...update, elapsedMs: Date.now() - start };
|
|
20
|
+
onprogress?.(progress);
|
|
21
|
+
}
|
|
22
|
+
const sizeCounter = new TransformStream({
|
|
23
|
+
transform(chunk, controller) {
|
|
24
|
+
handleProgress({
|
|
25
|
+
output: {
|
|
26
|
+
totalBytes: progress.output.totalBytes + chunk.byteLength,
|
|
27
|
+
done: false
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
controller.enqueue(chunk);
|
|
31
|
+
},
|
|
32
|
+
flush() {
|
|
33
|
+
handleProgress({ output: { ...progress.output, done: true } });
|
|
34
|
+
}
|
|
35
|
+
});
|
|
36
|
+
(async () => {
|
|
37
|
+
const style = await downloader.getStyle();
|
|
38
|
+
const writer = new Writer(style);
|
|
39
|
+
handleProgress({ style: { done: true } });
|
|
40
|
+
writer.outputStream.pipeTo(sizeCounter.writable).catch(() => {
|
|
41
|
+
});
|
|
42
|
+
try {
|
|
43
|
+
for await (const spriteInfo of downloader.getSprites()) {
|
|
44
|
+
await writer.addSprite(spriteInfo);
|
|
45
|
+
handleProgress({
|
|
46
|
+
sprites: { downloaded: progress.sprites.downloaded + 1, done: false }
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
handleProgress({ sprites: { ...progress.sprites, done: true } });
|
|
50
|
+
const tiles = downloader.getTiles({
|
|
51
|
+
bounds: bbox,
|
|
52
|
+
maxzoom,
|
|
53
|
+
onprogress: (tileStats) => handleProgress({ tiles: { ...tileStats, done: false } })
|
|
54
|
+
});
|
|
55
|
+
await readableFromAsync(tiles).pipeTo(
|
|
56
|
+
writer.createTileWriteStream({ concurrency: 24 })
|
|
57
|
+
);
|
|
58
|
+
handleProgress({ tiles: { ...progress.tiles, done: true } });
|
|
59
|
+
const glyphs = downloader.getGlyphs({
|
|
60
|
+
onprogress: (glyphStats) => handleProgress({ glyphs: { ...glyphStats, done: false } })
|
|
61
|
+
});
|
|
62
|
+
await readableFromAsync(glyphs).pipeTo(writer.createGlyphWriteStream());
|
|
63
|
+
handleProgress({ glyphs: { ...progress.glyphs, done: true } });
|
|
64
|
+
writer.finish();
|
|
65
|
+
} catch (err) {
|
|
66
|
+
writer.abort(
|
|
67
|
+
/** @type {Error} */
|
|
68
|
+
err
|
|
69
|
+
);
|
|
70
|
+
}
|
|
71
|
+
})();
|
|
72
|
+
return sizeCounter.readable;
|
|
73
|
+
}
|
|
74
|
+
export {
|
|
75
|
+
download
|
|
76
|
+
};
|
|
@@ -0,0 +1,81 @@
|
|
|
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 from_mbtiles_exports = {};
|
|
20
|
+
__export(from_mbtiles_exports, {
|
|
21
|
+
fromMBTiles: () => fromMBTiles
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(from_mbtiles_exports);
|
|
24
|
+
var import_mbtiles_reader = require("mbtiles-reader");
|
|
25
|
+
var import_streams = require('./utils/streams.cjs');
|
|
26
|
+
var import_writer = require('./writer.cjs');
|
|
27
|
+
const SOURCE_ID = "mbtiles-source";
|
|
28
|
+
function fromMBTiles(mbtilesPath) {
|
|
29
|
+
const reader = new import_mbtiles_reader.MBTiles(mbtilesPath);
|
|
30
|
+
if (reader.metadata.format === "pbf") {
|
|
31
|
+
throw new Error("Vector MBTiles are not yet supported");
|
|
32
|
+
}
|
|
33
|
+
const style = {
|
|
34
|
+
version: 8,
|
|
35
|
+
name: reader.metadata.name,
|
|
36
|
+
sources: {
|
|
37
|
+
[SOURCE_ID]: {
|
|
38
|
+
...reader.metadata,
|
|
39
|
+
type: "raster"
|
|
40
|
+
}
|
|
41
|
+
},
|
|
42
|
+
layers: [
|
|
43
|
+
{
|
|
44
|
+
id: "background",
|
|
45
|
+
type: "background",
|
|
46
|
+
paint: {
|
|
47
|
+
"background-color": "white"
|
|
48
|
+
}
|
|
49
|
+
},
|
|
50
|
+
{
|
|
51
|
+
id: "raster",
|
|
52
|
+
type: "raster",
|
|
53
|
+
source: SOURCE_ID,
|
|
54
|
+
paint: {
|
|
55
|
+
"raster-opacity": 1
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
]
|
|
59
|
+
};
|
|
60
|
+
const writer = new import_writer.Writer(style);
|
|
61
|
+
(async () => {
|
|
62
|
+
try {
|
|
63
|
+
await (0, import_streams.readableFromAsync)(mbtilesToTileArgs(reader)).pipeTo(
|
|
64
|
+
writer.createTileWriteStream()
|
|
65
|
+
);
|
|
66
|
+
writer.finish();
|
|
67
|
+
} catch (err) {
|
|
68
|
+
writer.abort(err instanceof Error ? err : new Error(String(err)));
|
|
69
|
+
}
|
|
70
|
+
})();
|
|
71
|
+
return writer.outputStream;
|
|
72
|
+
}
|
|
73
|
+
async function* mbtilesToTileArgs(mbtiles) {
|
|
74
|
+
for (const { z, x, y, data, format } of mbtiles) {
|
|
75
|
+
yield [data, { z, x, y, format, sourceId: SOURCE_ID }];
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
79
|
+
0 && (module.exports = {
|
|
80
|
+
fromMBTiles
|
|
81
|
+
});
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Convert a MBTiles file to a styled map package, returned as a web
|
|
3
|
+
* ReadableStream.
|
|
4
|
+
*
|
|
5
|
+
* @param {string} mbtilesPath
|
|
6
|
+
* @returns {ReadableStream<Uint8Array>}
|
|
7
|
+
*/
|
|
8
|
+
declare function fromMBTiles(mbtilesPath: string): ReadableStream<Uint8Array>;
|
|
9
|
+
|
|
10
|
+
export { fromMBTiles };
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Convert a MBTiles file to a styled map package, returned as a web
|
|
3
|
+
* ReadableStream.
|
|
4
|
+
*
|
|
5
|
+
* @param {string} mbtilesPath
|
|
6
|
+
* @returns {ReadableStream<Uint8Array>}
|
|
7
|
+
*/
|
|
8
|
+
declare function fromMBTiles(mbtilesPath: string): ReadableStream<Uint8Array>;
|
|
9
|
+
|
|
10
|
+
export { fromMBTiles };
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { MBTiles } from "mbtiles-reader";
|
|
2
|
+
import { readableFromAsync } from "./utils/streams.js";
|
|
3
|
+
import { Writer } from "./writer.js";
|
|
4
|
+
const SOURCE_ID = "mbtiles-source";
|
|
5
|
+
function fromMBTiles(mbtilesPath) {
|
|
6
|
+
const reader = new MBTiles(mbtilesPath);
|
|
7
|
+
if (reader.metadata.format === "pbf") {
|
|
8
|
+
throw new Error("Vector MBTiles are not yet supported");
|
|
9
|
+
}
|
|
10
|
+
const style = {
|
|
11
|
+
version: 8,
|
|
12
|
+
name: reader.metadata.name,
|
|
13
|
+
sources: {
|
|
14
|
+
[SOURCE_ID]: {
|
|
15
|
+
...reader.metadata,
|
|
16
|
+
type: "raster"
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
layers: [
|
|
20
|
+
{
|
|
21
|
+
id: "background",
|
|
22
|
+
type: "background",
|
|
23
|
+
paint: {
|
|
24
|
+
"background-color": "white"
|
|
25
|
+
}
|
|
26
|
+
},
|
|
27
|
+
{
|
|
28
|
+
id: "raster",
|
|
29
|
+
type: "raster",
|
|
30
|
+
source: SOURCE_ID,
|
|
31
|
+
paint: {
|
|
32
|
+
"raster-opacity": 1
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
]
|
|
36
|
+
};
|
|
37
|
+
const writer = new Writer(style);
|
|
38
|
+
(async () => {
|
|
39
|
+
try {
|
|
40
|
+
await readableFromAsync(mbtilesToTileArgs(reader)).pipeTo(
|
|
41
|
+
writer.createTileWriteStream()
|
|
42
|
+
);
|
|
43
|
+
writer.finish();
|
|
44
|
+
} catch (err) {
|
|
45
|
+
writer.abort(err instanceof Error ? err : new Error(String(err)));
|
|
46
|
+
}
|
|
47
|
+
})();
|
|
48
|
+
return writer.outputStream;
|
|
49
|
+
}
|
|
50
|
+
async function* mbtilesToTileArgs(mbtiles) {
|
|
51
|
+
for (const { z, x, y, data, format } of mbtiles) {
|
|
52
|
+
yield [data, { z, x, y, format, sourceId: SOURCE_ID }];
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
export {
|
|
56
|
+
fromMBTiles
|
|
57
|
+
};
|
package/dist/index.cjs
ADDED
|
@@ -0,0 +1,46 @@
|
|
|
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 index_exports = {};
|
|
20
|
+
__export(index_exports, {
|
|
21
|
+
Reader: () => import_reader.Reader,
|
|
22
|
+
StyleDownloader: () => import_style_downloader.StyleDownloader,
|
|
23
|
+
Writer: () => import_writer.Writer,
|
|
24
|
+
createServer: () => import_server.createServer,
|
|
25
|
+
download: () => import_download.download,
|
|
26
|
+
downloadTiles: () => import_tile_downloader.downloadTiles,
|
|
27
|
+
fromMBTiles: () => import_from_mbtiles.fromMBTiles
|
|
28
|
+
});
|
|
29
|
+
module.exports = __toCommonJS(index_exports);
|
|
30
|
+
var import_reader = require('./reader.cjs');
|
|
31
|
+
var import_writer = require('./writer.cjs');
|
|
32
|
+
var import_server = require('./server.cjs');
|
|
33
|
+
var import_style_downloader = require('./style-downloader.cjs');
|
|
34
|
+
var import_tile_downloader = require('./tile-downloader.cjs');
|
|
35
|
+
var import_download = require('./download.cjs');
|
|
36
|
+
var import_from_mbtiles = require('./from-mbtiles.cjs');
|
|
37
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
38
|
+
0 && (module.exports = {
|
|
39
|
+
Reader,
|
|
40
|
+
StyleDownloader,
|
|
41
|
+
Writer,
|
|
42
|
+
createServer,
|
|
43
|
+
download,
|
|
44
|
+
downloadTiles,
|
|
45
|
+
fromMBTiles
|
|
46
|
+
});
|
package/dist/index.d.cts
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { S as SMPSource$1, a as SMPStyle$1 } from './types-CJq90eOB.cjs';
|
|
2
|
+
export { W as Writer } from './types-CJq90eOB.cjs';
|
|
3
|
+
export { Reader } from './reader.cjs';
|
|
4
|
+
export { createServer } from './server.cjs';
|
|
5
|
+
export { StyleDownloader } from './style-downloader.cjs';
|
|
6
|
+
export { downloadTiles } from './tile-downloader.cjs';
|
|
7
|
+
export { download } from './download.cjs';
|
|
8
|
+
export { fromMBTiles } from './from-mbtiles.cjs';
|
|
9
|
+
import '@maplibre/maplibre-gl-style-spec';
|
|
10
|
+
import 'geojson';
|
|
11
|
+
import 'type-fest';
|
|
12
|
+
import 'events';
|
|
13
|
+
import '@gmaclennan/zip-reader';
|
|
14
|
+
import 'itty-router';
|
|
15
|
+
import 'itty-router/IttyRouter';
|
|
16
|
+
import 'ky';
|
|
17
|
+
import './utils/geo.cjs';
|
|
18
|
+
import './utils/fetch.cjs';
|
|
19
|
+
import './utils/streams.cjs';
|
|
20
|
+
import 'stream/web';
|
|
21
|
+
|
|
22
|
+
type SMPSource = SMPSource$1;
|
|
23
|
+
type SMPStyle = SMPStyle$1;
|
|
24
|
+
|
|
25
|
+
export type { SMPSource, SMPStyle };
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { S as SMPSource$1, a as SMPStyle$1 } from './types-CJq90eOB.js';
|
|
2
|
+
export { W as Writer } from './types-CJq90eOB.js';
|
|
3
|
+
export { Reader } from './reader.js';
|
|
4
|
+
export { createServer } from './server.js';
|
|
5
|
+
export { StyleDownloader } from './style-downloader.js';
|
|
6
|
+
export { downloadTiles } from './tile-downloader.js';
|
|
7
|
+
export { download } from './download.js';
|
|
8
|
+
export { fromMBTiles } from './from-mbtiles.js';
|
|
9
|
+
import '@maplibre/maplibre-gl-style-spec';
|
|
10
|
+
import 'geojson';
|
|
11
|
+
import 'type-fest';
|
|
12
|
+
import 'events';
|
|
13
|
+
import '@gmaclennan/zip-reader';
|
|
14
|
+
import 'itty-router';
|
|
15
|
+
import 'itty-router/IttyRouter';
|
|
16
|
+
import 'ky';
|
|
17
|
+
import './utils/geo.js';
|
|
18
|
+
import './utils/fetch.js';
|
|
19
|
+
import './utils/streams.js';
|
|
20
|
+
import 'stream/web';
|
|
21
|
+
|
|
22
|
+
type SMPSource = SMPSource$1;
|
|
23
|
+
type SMPStyle = SMPStyle$1;
|
|
24
|
+
|
|
25
|
+
export type { SMPSource, SMPStyle };
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Reader } from "./reader.js";
|
|
2
|
+
import { Writer } from "./writer.js";
|
|
3
|
+
import { createServer } from "./server.js";
|
|
4
|
+
import { StyleDownloader } from "./style-downloader.js";
|
|
5
|
+
import { downloadTiles } from "./tile-downloader.js";
|
|
6
|
+
import { download } from "./download.js";
|
|
7
|
+
import { fromMBTiles } from "./from-mbtiles.js";
|
|
8
|
+
export {
|
|
9
|
+
Reader,
|
|
10
|
+
StyleDownloader,
|
|
11
|
+
Writer,
|
|
12
|
+
createServer,
|
|
13
|
+
download,
|
|
14
|
+
downloadTiles,
|
|
15
|
+
fromMBTiles
|
|
16
|
+
};
|