diff options
author | Christopher Baines <cb15g11@soton.ac.uk> | 2014-02-21 12:19:10 +0000 |
---|---|---|
committer | Christopher Baines <cb15g11@soton.ac.uk> | 2014-02-21 12:19:10 +0000 |
commit | 5addce86274887ea9549498f08929f7007244017 (patch) | |
tree | 7a905a7d327593987ec4058e75ef0f399a52fd7b /create-data.js | |
parent | e4d1c918444c15e2e1480ecb332e61ec8feb7629 (diff) | |
download | leaflet-soton-5addce86274887ea9549498f08929f7007244017.tar leaflet-soton-5addce86274887ea9549498f08929f7007244017.tar.gz |
Add support for a building part to span mutiple levels
Diffstat (limited to 'create-data.js')
-rwxr-xr-x | create-data.js | 18 |
1 files changed, 14 insertions, 4 deletions
diff --git a/create-data.js b/create-data.js index e236a99..1a9fa2e 100755 --- a/create-data.js +++ b/create-data.js @@ -309,12 +309,18 @@ function createRooms(buildings, workstations, callback) { }); }, function(err) { - osmIDToLevel = {}; + osmIDToLevels = {}; async.each(levelRelations, function(level, callback) { getBuildingPartMemberRefs(level, function(err, refs) { for (var i=0; i<refs.length; i++) { - osmIDToLevel[refs[i]] = parseInt(level.tags.level, 10); + var ref = refs[i]; + + if (!(ref in osmIDToLevels)) { + osmIDToLevels[ref] = []; + } + + osmIDToLevels[refs[i]].push(parseInt(level.tags.level, 10)); } callback(); }); @@ -322,8 +328,12 @@ function createRooms(buildings, workstations, callback) { for (var i=0; i<buildingParts.length; i++) { var part = buildingParts[i]; - if (part.id in osmIDToLevel) { - part.properties.level = osmIDToLevel[part.id]; + if (part.id in osmIDToLevels) { + part.properties.level = osmIDToLevels[part.id]; + + if (part.properties.level.length === 1) { + part.properties.level = part.properties.level[0]; + } } else { console.log("unknown level"); console.log(JSON.stringify(part, null, 4)); |