Files
iD/js/id/renderer/style.js
2012-12-06 17:54:32 -05:00

68 lines
1.7 KiB
JavaScript

iD.Style = {};
// all styling that is done outside of CSS in iD.
//
// Since SVG does not support z-index, we sort roads manually with d3's `sort`
// and the `waystack` fn.
//
// This also chooses kosher CSS classes for ways, and marker images for POIs
iD.Style.highway_stack = {
motorway: 0,
motorway_link: 1,
trunk: 2,
trunk_link: 3,
primary: 4,
primary_link: 5,
secondary: 6,
tertiary: 7,
unclassified: 8,
residential: 9,
service: 10,
footway: 11
};
iD.Style.waystack = function(a, b) {
if (!a || !b) return 0;
if (a.tags.layer !== undefined && b.tags.layer !== undefined) {
return a.tags.layer - b.tags.layer;
}
if (a.tags.bridge) return 1;
if (b.tags.bridge) return -1;
var as = 0, bs = 0;
if (a.tags.highway && b.tags.highway) {
as -= iD.Style.highway_stack[a.tags.highway];
bs -= iD.Style.highway_stack[b.tags.highway];
}
return as - bs;
};
iD.Style.markerimage = function(d) {
// TODO: optimize
for (var k in d.tags) {
var key = k + '=' + d.tags[k];
if (iD._markertable[key]) {
return 'icons/' + iD._markertable[key] + '.png';
}
}
return 'icons/unknown.png';
};
iD.Style.TAG_CLASSES = iD.util.trueObj([
'highway', 'railway', 'motorway', 'amenity', 'natural',
'landuse', 'building', 'oneway', 'bridge'
]);
iD.Style.styleClasses = function(pre) {
return function(d) {
var tags = d.tags;
var c = [pre];
for (var k in tags) {
if (!iD.Style.TAG_CLASSES[k]) continue;
c.push(k + '-' + tags[k]);
c.push(k);
}
return c.join(' ');
};
};