mirror of
https://github.com/FoggedLens/iD.git
synced 2026-05-27 02:12:24 +02:00
Flag and upgrade deprecated tags in a semicolon-delimited tag value (close #6038)
This commit is contained in:
@@ -8,8 +8,17 @@ export function actionUpgradeTags(entityId, oldTags, replaceTags) {
|
||||
for (var oldTagKey in oldTags) {
|
||||
if (oldTags[oldTagKey] === '*') {
|
||||
transferValue = tags[oldTagKey];
|
||||
delete tags[oldTagKey];
|
||||
} else {
|
||||
var vals = tags[oldTagKey].split(';').filter(Boolean);
|
||||
var oldIndex = vals.indexOf(oldTags[oldTagKey]);
|
||||
if (vals.length === 1 || oldIndex === -1) {
|
||||
delete tags[oldTagKey];
|
||||
} else {
|
||||
vals.splice(oldIndex, 1);
|
||||
tags[oldTagKey] = vals.join(';');
|
||||
}
|
||||
}
|
||||
delete tags[oldTagKey];
|
||||
}
|
||||
if (replaceTags) {
|
||||
for (var replaceKey in replaceTags) {
|
||||
|
||||
@@ -173,7 +173,12 @@ osmEntity.prototype = {
|
||||
var deprecated = [];
|
||||
dataDeprecated.forEach(function(d) {
|
||||
var matchesDeprecatedTags = _every(Object.keys(d.old), function(key) {
|
||||
return tags[key] && (d.old[key] === tags[key] || d.old[key] === '*');
|
||||
if (!tags[key]) return false;
|
||||
if (d.old[key] === '*') return true;
|
||||
|
||||
var vals = tags[key].split(';').filter(Boolean);
|
||||
if (!vals.length) return false;
|
||||
return vals.indexOf(d.old[key]) !== -1;
|
||||
});
|
||||
if (matchesDeprecatedTags) {
|
||||
deprecated.push(d);
|
||||
|
||||
Reference in New Issue
Block a user