fix
This commit is contained in:
+42
-16
@@ -121,13 +121,13 @@ function start(opts) {
|
|||||||
success = serve_style.add(options, serving.styles, item, id, opts.publicUrl,
|
success = serve_style.add(options, serving.styles, item, id, opts.publicUrl,
|
||||||
(mbtiles, fromData) => {
|
(mbtiles, fromData) => {
|
||||||
let dataItemId;
|
let dataItemId;
|
||||||
for (const id of Object.keys(data)) {
|
for (const id of Object.keys(serving.data)) {
|
||||||
if (fromData) {
|
if (fromData) {
|
||||||
if (id === mbtiles) {
|
if (id === mbtiles) {
|
||||||
dataItemId = id;
|
dataItemId = id;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (data[id].mbtiles === mbtiles) {
|
if (serving.data[id].mbtiles === mbtiles) {
|
||||||
dataItemId = id;
|
dataItemId = id;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -140,7 +140,7 @@ function start(opts) {
|
|||||||
return undefined;
|
return undefined;
|
||||||
} else {
|
} else {
|
||||||
let id = mbtiles.substr(0, mbtiles.lastIndexOf('.')) || mbtiles;
|
let id = mbtiles.substr(0, mbtiles.lastIndexOf('.')) || mbtiles;
|
||||||
while (data[id]) id += '_';
|
//while (data[id]) id += '_';
|
||||||
data[id] = {
|
data[id] = {
|
||||||
'mbtiles': mbtiles
|
'mbtiles': mbtiles
|
||||||
};
|
};
|
||||||
@@ -172,6 +172,11 @@ function start(opts) {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
let addData = (id, item) => {
|
||||||
|
console.log(`Add data ${id}`);
|
||||||
|
Promise.all([serve_data.add(options, serving.data, item, id, opts.publicUrl)]);
|
||||||
|
};
|
||||||
|
|
||||||
for (const id of Object.keys(config.styles || {})) {
|
for (const id of Object.keys(config.styles || {})) {
|
||||||
const item = config.styles[id];
|
const item = config.styles[id];
|
||||||
if (!item.style || item.style.length === 0) {
|
if (!item.style || item.style.length === 0) {
|
||||||
@@ -201,6 +206,21 @@ function start(opts) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (options.serveAllStyles) {
|
if (options.serveAllStyles) {
|
||||||
|
fs.readdir(options.paths.mbtiles, {withFileTypes: true}, (err, files) => {
|
||||||
|
if (err) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
for (const file of files) {
|
||||||
|
if (file.isFile() && path.extname(file.name).toLowerCase() == '.mbtiles') {
|
||||||
|
let id = path.basename(file.name, '.mbtiles');
|
||||||
|
let item = {
|
||||||
|
mbtiles: file.name
|
||||||
|
};
|
||||||
|
addData(id, item);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
fs.readdir(options.paths.styles, {withFileTypes: true}, (err, files) => {
|
fs.readdir(options.paths.styles, {withFileTypes: true}, (err, files) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
return;
|
return;
|
||||||
@@ -212,7 +232,24 @@ function start(opts) {
|
|||||||
let item = {
|
let item = {
|
||||||
style: file.name
|
style: file.name
|
||||||
};
|
};
|
||||||
addStyle(id, item, false, false);
|
addStyle(id, item, true, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
const watcherData = chokidar.watch(path.join(options.paths.mbtiles, '*.mbtiles'),
|
||||||
|
{
|
||||||
|
});
|
||||||
|
watcherData.on('all', (eventType, filename) => {
|
||||||
|
if (filename) {
|
||||||
|
let id = path.basename(filename, '.mbtiles');
|
||||||
|
console.log(`Data "${id}" added`);
|
||||||
|
|
||||||
|
if (eventType == "add") {
|
||||||
|
let item = {
|
||||||
|
mbtiles: filename
|
||||||
|
};
|
||||||
|
addData(id, item);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@@ -235,7 +272,7 @@ function start(opts) {
|
|||||||
let item = {
|
let item = {
|
||||||
style: filename
|
style: filename
|
||||||
};
|
};
|
||||||
addStyle(id, item, false, false);
|
addStyle(id, item, true, true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@@ -256,17 +293,6 @@ function start(opts) {
|
|||||||
res.send(result);
|
res.send(result);
|
||||||
});
|
});
|
||||||
|
|
||||||
app.get('/process', (req, res, next) => {
|
|
||||||
const result = {};
|
|
||||||
const id = req.query.style || '';
|
|
||||||
const item = {
|
|
||||||
'style': id + '.json'
|
|
||||||
};
|
|
||||||
result[id] = true;
|
|
||||||
addStyle(id, item, true, true);
|
|
||||||
res.send(serving.styles);
|
|
||||||
});
|
|
||||||
|
|
||||||
const addTileJSONs = (arr, req, type) => {
|
const addTileJSONs = (arr, req, type) => {
|
||||||
for (const id of Object.keys(serving[type])) {
|
for (const id of Object.keys(serving[type])) {
|
||||||
const info = clone(serving[type][id].tileJSON);
|
const info = clone(serving[type][id].tileJSON);
|
||||||
|
|||||||
Reference in New Issue
Block a user