(function () {
var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
+ function getDefaultExportFromCjs (x) {
+ return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, 'default') ? x['default'] : x;
+ }
+
function createCommonjsModule(fn, basedir, module) {
return module = {
path: basedir,
}, fn(module, module.exports), module.exports;
}
- function getCjsExportFromNamespace (n) {
- return n && n['default'] || n;
- }
-
function commonjsRequire () {
throw new Error('Dynamic requires are not currently supported by @rollup/plugin-commonjs');
}
var isImplemented = function () {
var set, iterator, result;
- if (typeof Set !== 'function') return false;
+ if (typeof Set !== 'function') { return false; }
set = new Set(['raz', 'dwa', 'trzy']);
- if (String(set) !== '[object Set]') return false;
- if (set.size !== 3) return false;
- if (typeof set.add !== 'function') return false;
- if (typeof set.clear !== 'function') return false;
- if (typeof set.delete !== 'function') return false;
- if (typeof set.entries !== 'function') return false;
- if (typeof set.forEach !== 'function') return false;
- if (typeof set.has !== 'function') return false;
- if (typeof set.keys !== 'function') return false;
- if (typeof set.values !== 'function') return false;
+ if (String(set) !== '[object Set]') { return false; }
+ if (set.size !== 3) { return false; }
+ if (typeof set.add !== 'function') { return false; }
+ if (typeof set.clear !== 'function') { return false; }
+ if (typeof set.delete !== 'function') { return false; }
+ if (typeof set.entries !== 'function') { return false; }
+ if (typeof set.forEach !== 'function') { return false; }
+ if (typeof set.has !== 'function') { return false; }
+ if (typeof set.keys !== 'function') { return false; }
+ if (typeof set.values !== 'function') { return false; }
iterator = set.values();
result = iterator.next();
- if (result.done !== false) return false;
- if (result.value !== 'raz') return false;
+ if (result.done !== false) { return false; }
+ if (result.value !== 'raz') { return false; }
return true;
};
var isValue = function (val) { return val !== _undefined && val !== null; };
var validValue = function (value) {
- if (!isValue(value)) throw new TypeError("Cannot use null or undefined");
+ if (!isValue(value)) { throw new TypeError("Cannot use null or undefined"); }
return value;
};
var isImplemented$1 = function () {
var numberIsNaN = Number.isNaN;
- if (typeof numberIsNaN !== "function") return false;
+ if (typeof numberIsNaN !== "function") { return false; }
return !numberIsNaN({}) && numberIsNaN(NaN) && !numberIsNaN(34);
};
var isImplemented$2 = function () {
var sign = Math.sign;
- if (typeof sign !== "function") return false;
+ if (typeof sign !== "function") { return false; }
return sign(10) === 1 && sign(-20) === -1;
};
var shim$1 = function (value) {
value = Number(value);
- if (isNaN(value) || value === 0) return value;
+ if (isNaN(value) || value === 0) { return value; }
return value > 0 ? 1 : -1;
};
, floor = Math.floor;
var toInteger = function (value) {
- if (isNaN(value)) return 0;
+ if (isNaN(value)) { return 0; }
value = Number(value);
- if (value === 0 || !isFinite(value)) return value;
+ if (value === 0 || !isFinite(value)) { return value; }
return sign(value) * floor(abs(value));
};
var eIndexOf = function (searchElement/*, fromIndex*/) {
var i, length, fromIndex, val;
- if (!isNan(searchElement)) return indexOf.apply(this, arguments);
+ if (!isNan(searchElement)) { return indexOf.apply(this, arguments); }
length = toPosInteger(validValue(this).length);
fromIndex = arguments[1];
- if (isNaN(fromIndex)) fromIndex = 0;
- else if (fromIndex >= 0) fromIndex = floor$1(fromIndex);
- else fromIndex = toPosInteger(this.length) - floor$1(abs$1(fromIndex));
+ if (isNaN(fromIndex)) { fromIndex = 0; }
+ else if (fromIndex >= 0) { fromIndex = floor$1(fromIndex); }
+ else { fromIndex = toPosInteger(this.length) - floor$1(abs$1(fromIndex)); }
for (i = fromIndex; i < length; ++i) {
if (objHasOwnProperty.call(this, i)) {
val = this[i];
- if (isNan(val)) return i; // Jslint: ignore
+ if (isNan(val)) { return i; } // Jslint: ignore
}
}
return -1;
var isImplemented$3 = function (/* CustomCreate*/) {
var setPrototypeOf = Object.setPrototypeOf, customCreate = arguments[0] || create;
- if (typeof setPrototypeOf !== "function") return false;
+ if (typeof setPrototypeOf !== "function") { return false; }
return getPrototypeOf(setPrototypeOf(customCreate(null), plainObject)) === plainObject;
};
var create_1 = (function () {
var nullObject, polyProps, desc;
- if (!shim$2) return create$1;
- if (shim$2.level !== 1) return create$1;
+ if (!shim$2) { return create$1; }
+ if (shim$2.level !== 1) { return create$1; }
nullObject = {};
polyProps = {};
validate = function (obj, prototype) {
validValue(obj);
- if (prototype === null || isObject(prototype)) return obj;
+ if (prototype === null || isObject(prototype)) { return obj; }
throw new TypeError("Prototype must be null or an object");
};
var shim$3 = (function (status) {
var fn, set;
- if (!status) return null;
+ if (!status) { return null; }
if (status.level === 2) {
if (status.set) {
set = status.set;
var isNullBase;
validate(obj, prototype);
isNullBase = objIsPrototypeOf.call(self.nullPolyfill, obj);
- if (isNullBase) delete self.nullPolyfill.__proto__;
- if (prototype === null) prototype = self.nullPolyfill;
+ if (isNullBase) { delete self.nullPolyfill.__proto__; }
+ if (prototype === null) { prototype = self.nullPolyfill; }
obj.__proto__ = prototype;
- if (isNullBase) defineProperty(self.nullPolyfill, "__proto__", nullDesc);
+ if (isNullBase) { defineProperty(self.nullPolyfill, "__proto__", nullDesc); }
return obj;
};
}
set = desc.set; // Opera crashes at this point
set.call(tmpObj1, tmpObj2);
} catch (ignore) {}
- if (Object.getPrototypeOf(tmpObj1) === tmpObj2) return { set: set, level: 2 };
+ if (Object.getPrototypeOf(tmpObj1) === tmpObj2) { return { set: set, level: 2 }; }
}
tmpObj1.__proto__ = tmpObj2;
- if (Object.getPrototypeOf(tmpObj1) === tmpObj2) return { level: 2 };
+ if (Object.getPrototypeOf(tmpObj1) === tmpObj2) { return { level: 2 }; }
tmpObj1 = {};
tmpObj1.__proto__ = tmpObj2;
- if (Object.getPrototypeOf(tmpObj1) === tmpObj2) return { level: 1 };
+ if (Object.getPrototypeOf(tmpObj1) === tmpObj2) { return { level: 1 }; }
return false;
})()
var setPrototypeOf = isImplemented$3() ? Object.setPrototypeOf : shim$3;
var validCallable = function (fn) {
- if (typeof fn !== "function") throw new TypeError(fn + " is not a function");
+ if (typeof fn !== "function") { throw new TypeError(fn + " is not a function"); }
return fn;
};
var possibleTypes = { "object": true, "function": true, "undefined": true /* document.all */ };
var is$1 = function (value) {
- if (!is(value)) return false;
+ if (!is(value)) { return false; }
return hasOwnProperty.call(possibleTypes, typeof value);
};
var is$2 = function (value) {
- if (!is$1(value)) return false;
+ if (!is$1(value)) { return false; }
try {
- if (!value.constructor) return false;
+ if (!value.constructor) { return false; }
return value.constructor.prototype === value;
} catch (error) {
return false;
};
var is$3 = function (value) {
- if (typeof value !== "function") return false;
+ if (typeof value !== "function") { return false; }
- if (!hasOwnProperty.call(value, "length")) return false;
+ if (!hasOwnProperty.call(value, "length")) { return false; }
try {
- if (typeof value.length !== "number") return false;
- if (typeof value.call !== "function") return false;
- if (typeof value.apply !== "function") return false;
+ if (typeof value.length !== "number") { return false; }
+ if (typeof value.call !== "function") { return false; }
+ if (typeof value.apply !== "function") { return false; }
} catch (error) {
return false;
}
var classRe = /^\s*class[\s{/}]/, functionToString = Function.prototype.toString;
var is$4 = function (value) {
- if (!is$3(value)) return false;
- if (classRe.test(functionToString.call(value))) return false;
+ if (!is$3(value)) { return false; }
+ if (classRe.test(functionToString.call(value))) { return false; }
return true;
};
var isImplemented$4 = function () {
var assign = Object.assign, obj;
- if (typeof assign !== "function") return false;
+ if (typeof assign !== "function") { return false; }
obj = { foo: "raz" };
assign(obj, { bar: "dwa" }, { trzy: "trzy" });
return obj.foo + obj.bar + obj.trzy === "razdwatrzy";
var max$1 = Math.max;
var shim$5 = function (dest, src/*, …srcn*/) {
+ var arguments$1 = arguments;
+
var error, i, length = max$1(arguments.length, 2), assign;
dest = Object(validValue(dest));
assign = function (key) {
try {
dest[key] = src[key];
} catch (e) {
- if (!error) error = e;
+ if (!error) { error = e; }
}
};
for (i = 1; i < length; ++i) {
- src = arguments[i];
+ src = arguments$1[i];
keys$1(src).forEach(assign);
}
- if (error !== undefined) throw error;
+ if (error !== undefined) { throw error; }
return dest;
};
var process$1 = function (src, obj) {
var key;
- for (key in src) obj[key] = src[key];
+ for (key in src) { obj[key] = src[key]; }
};
// eslint-disable-next-line no-unused-vars
var normalizeOptions = function (opts1/*, …options*/) {
var result = create$2(null);
forEach.call(arguments, function (options) {
- if (!isValue(options)) return;
+ if (!isValue(options)) { return; }
process$1(Object(options), result);
});
return result;
var str = "razdwatrzy";
var isImplemented$6 = function () {
- if (typeof str.contains !== "function") return false;
+ if (typeof str.contains !== "function") { return false; }
return str.contains("dwa") === true && str.contains("foo") === false;
};
} else {
data = this.__ee__;
}
- if (!data[type]) data[type] = listener;
- else if (typeof data[type] === 'object') data[type].push(listener);
- else data[type] = [data[type], listener];
+ if (!data[type]) { data[type] = listener; }
+ else if (typeof data[type] === 'object') { data[type].push(listener); }
+ else { data[type] = [data[type], listener]; }
return this;
};
validCallable(listener);
- if (!hasOwnProperty.call(this, '__ee__')) return this;
+ if (!hasOwnProperty.call(this, '__ee__')) { return this; }
data = this.__ee__;
- if (!data[type]) return this;
+ if (!data[type]) { return this; }
listeners = data[type];
if (typeof listeners === 'object') {
for (i = 0; (candidate = listeners[i]); ++i) {
if ((candidate === listener) ||
(candidate.__eeOnceListener__ === listener)) {
- if (listeners.length === 2) data[type] = listeners[i ? 0 : 1];
- else listeners.splice(i, 1);
+ if (listeners.length === 2) { data[type] = listeners[i ? 0 : 1]; }
+ else { listeners.splice(i, 1); }
}
}
} else {
};
emit = function (type) {
+ var arguments$1 = arguments;
+
var i, l, listener, listeners, args;
- if (!hasOwnProperty.call(this, '__ee__')) return;
+ if (!hasOwnProperty.call(this, '__ee__')) { return; }
listeners = this.__ee__[type];
- if (!listeners) return;
+ if (!listeners) { return; }
if (typeof listeners === 'object') {
l = arguments.length;
args = new Array(l - 1);
- for (i = 1; i < l; ++i) args[i - 1] = arguments[i];
+ for (i = 1; i < l; ++i) { args[i - 1] = arguments$1[i]; }
listeners = listeners.slice();
for (i = 0; (listener = listeners[i]); ++i) {
l = arguments.length;
args = new Array(l - 1);
for (i = 1; i < l; ++i) {
- args[i - 1] = arguments[i];
+ args[i - 1] = arguments$1[i];
}
apply.call(listeners, this, args);
}
var isImplemented$7 = function () {
var symbol;
- if (typeof Symbol !== 'function') return false;
+ if (typeof Symbol !== 'function') { return false; }
symbol = Symbol('test symbol');
try { String(symbol); } catch (e) { return false; }
// Return 'true' also for polyfills
- if (!validTypes[typeof Symbol.iterator]) return false;
- if (!validTypes[typeof Symbol.toPrimitive]) return false;
- if (!validTypes[typeof Symbol.toStringTag]) return false;
+ if (!validTypes[typeof Symbol.iterator]) { return false; }
+ if (!validTypes[typeof Symbol.toPrimitive]) { return false; }
+ if (!validTypes[typeof Symbol.toStringTag]) { return false; }
return true;
};
var isSymbol = function (x) {
- if (!x) return false;
- if (typeof x === 'symbol') return true;
- if (!x.constructor) return false;
- if (x.constructor.name !== 'Symbol') return false;
+ if (!x) { return false; }
+ if (typeof x === 'symbol') { return true; }
+ if (!x.constructor) { return false; }
+ if (x.constructor.name !== 'Symbol') { return false; }
return (x[x.constructor.toStringTag] === 'Symbol');
};
var validateSymbol = function (value) {
- if (!isSymbol(value)) throw new TypeError(value + " is not a symbol");
+ if (!isSymbol(value)) { throw new TypeError(value + " is not a symbol"); }
return value;
};
var created = create$3(null);
return function (desc) {
var postfix = 0, name, ie11BugWorkaround;
- while (created[desc + (postfix || '')]) ++postfix;
+ while (created[desc + (postfix || '')]) { ++postfix; }
desc += (postfix || '');
created[desc] = true;
name = '@@' + desc;
// https://connect.microsoft.com/IE/feedbackdetail/view/1928508/
// ie11-broken-getters-on-dom-objects
// https://github.com/medikoo/es6-symbol/issues/12
- if (ie11BugWorkaround) return;
+ if (ie11BugWorkaround) { return; }
ie11BugWorkaround = true;
defineProperty$1(this, name, d_1(value));
ie11BugWorkaround = false;
// Internal constructor (not one exposed) for creating Symbol instances.
// This one is used to ensure that `someSymbol instanceof Symbol` always return false
HiddenSymbol = function Symbol(description) {
- if (this instanceof HiddenSymbol) throw new TypeError('Symbol is not a constructor');
+ if (this instanceof HiddenSymbol) { throw new TypeError('Symbol is not a constructor'); }
return SymbolPolyfill(description);
};
// (returns instances of HiddenSymbol)
var polyfill = SymbolPolyfill = function Symbol(description) {
var symbol;
- if (this instanceof Symbol) throw new TypeError('Symbol is not a constructor');
- if (isNativeSafe) return NativeSymbol(description);
+ if (this instanceof Symbol) { throw new TypeError('Symbol is not a constructor'); }
+ if (isNativeSafe) { return NativeSymbol(description); }
symbol = create$3(HiddenSymbol.prototype);
description = (description === undefined ? '' : String(description));
return defineProperties(symbol, {
};
defineProperties(SymbolPolyfill, {
for: d_1(function (key) {
- if (globalSymbols[key]) return globalSymbols[key];
+ if (globalSymbols[key]) { return globalSymbols[key]; }
return (globalSymbols[key] = SymbolPolyfill(String(key)));
}),
keyFor: d_1(function (s) {
var key;
validateSymbol(s);
- for (key in globalSymbols) if (globalSymbols[key] === s) return key;
+ for (key in globalSymbols) { if (globalSymbols[key] === s) { return key; } }
}),
// To ensure proper interoperability with other native functions (e.g. Array.from)
});
defineProperty$1(SymbolPolyfill.prototype, SymbolPolyfill.toPrimitive, d_1('', function () {
var symbol = validateSymbol(this);
- if (typeof symbol === 'symbol') return symbol;
+ if (typeof symbol === 'symbol') { return symbol; }
return symbol.toString();
}));
defineProperty$1(SymbolPolyfill.prototype, SymbolPolyfill.toStringTag, d_1('c', 'Symbol'));
};
var isImplemented$8 = function () {
- if (typeof globalThis !== "object") return false;
- if (!globalThis) return false;
+ if (typeof globalThis !== "object") { return false; }
+ if (!globalThis) { return false; }
return globalThis.Array === Array;
};
var naiveFallback = function () {
- if (typeof self === "object" && self) return self;
- if (typeof window === "object" && window) return window;
+ if (typeof self === "object" && self) { return self; }
+ if (typeof window === "object" && window) { return window; }
throw new Error("Unable to resolve global `this`");
};
var implementation = (function () {
- if (this) return this;
+ if (this) { return this; }
// Unexpected strict mode (may happen if e.g. bundled into ESM module)
}
try {
// Safari case (window.__global__ is resolved with global context, but __global__ does not)
- if (!__global__) return naiveFallback();
+ if (!__global__) { return naiveFallback(); }
return __global__;
} finally {
delete Object.prototype.__global__;
var isImplemented$9 = function () {
var Symbol = globalThis_1.Symbol;
var symbol;
- if (typeof Symbol !== "function") return false;
+ if (typeof Symbol !== "function") { return false; }
symbol = Symbol("test symbol");
try { String(symbol); }
catch (e) { return false; }
// Return 'true' also for polyfills
- if (!validTypes$1[typeof Symbol.iterator]) return false;
- if (!validTypes$1[typeof Symbol.toPrimitive]) return false;
- if (!validTypes$1[typeof Symbol.toStringTag]) return false;
+ if (!validTypes$1[typeof Symbol.iterator]) { return false; }
+ if (!validTypes$1[typeof Symbol.toPrimitive]) { return false; }
+ if (!validTypes$1[typeof Symbol.toStringTag]) { return false; }
return true;
};
var isSymbol$1 = function (value) {
- if (!value) return false;
- if (typeof value === "symbol") return true;
- if (!value.constructor) return false;
- if (value.constructor.name !== "Symbol") return false;
+ if (!value) { return false; }
+ if (typeof value === "symbol") { return true; }
+ if (!value.constructor) { return false; }
+ if (value.constructor.name !== "Symbol") { return false; }
return value[value.constructor.toStringTag] === "Symbol";
};
var validateSymbol$1 = function (value) {
- if (!isSymbol$1(value)) throw new TypeError(value + " is not a symbol");
+ if (!isSymbol$1(value)) { throw new TypeError(value + " is not a symbol"); }
return value;
};
var created = create$4(null);
var generateName$1 = function (desc) {
var postfix = 0, name, ie11BugWorkaround;
- while (created[desc + (postfix || "")]) ++postfix;
+ while (created[desc + (postfix || "")]) { ++postfix; }
desc += postfix || "";
created[desc] = true;
name = "@@" + desc;
// https://connect.microsoft.com/IE/feedbackdetail/view/1928508/
// ie11-broken-getters-on-dom-objects
// https://github.com/medikoo/es6-symbol/issues/12
- if (ie11BugWorkaround) return;
+ if (ie11BugWorkaround) { return; }
ie11BugWorkaround = true;
defineProperty$2(this, name, d_1(value));
ie11BugWorkaround = false;
var symbolRegistry = function (SymbolPolyfill) {
return Object.defineProperties(SymbolPolyfill, {
for: d_1(function (key) {
- if (registry[key]) return registry[key];
+ if (registry[key]) { return registry[key]; }
return (registry[key] = SymbolPolyfill(String(key)));
}),
keyFor: d_1(function (symbol) {
var key;
validateSymbol$1(symbol);
for (key in registry) {
- if (registry[key] === symbol) return key;
+ if (registry[key] === symbol) { return key; }
}
return undefined;
})
// Internal constructor (not one exposed) for creating Symbol instances.
// This one is used to ensure that `someSymbol instanceof Symbol` always return false
HiddenSymbol$1 = function Symbol(description) {
- if (this instanceof HiddenSymbol$1) throw new TypeError("Symbol is not a constructor");
+ if (this instanceof HiddenSymbol$1) { throw new TypeError("Symbol is not a constructor"); }
return SymbolPolyfill$1(description);
};
// (returns instances of HiddenSymbol)
var polyfill$1 = SymbolPolyfill$1 = function Symbol(description) {
var symbol;
- if (this instanceof Symbol) throw new TypeError("Symbol is not a constructor");
- if (isNativeSafe$1) return NativeSymbol$2(description);
+ if (this instanceof Symbol) { throw new TypeError("Symbol is not a constructor"); }
+ if (isNativeSafe$1) { return NativeSymbol$2(description); }
symbol = create$5(HiddenSymbol$1.prototype);
description = description === undefined ? "" : String(description);
return defineProperties$1(symbol, {
SymbolPolyfill$1.toPrimitive,
d_1("", function () {
var symbol = validateSymbol$1(this);
- if (typeof symbol === "symbol") return symbol;
+ if (typeof symbol === "symbol") { return symbol; }
return symbol.toString();
})
);
, isArray = Array.isArray;
var isIterable = function (value) {
- if (!isValue(value)) return false;
- if (isArray(value)) return true;
- if (isString(value)) return true;
- if (isArguments(value)) return true;
+ if (!isValue(value)) { return false; }
+ if (isArray(value)) { return true; }
+ if (isString(value)) { return true; }
+ if (isArguments(value)) { return true; }
return typeof value[iteratorSymbol] === "function";
};
var validIterable = function (value) {
- if (!isIterable(value)) throw new TypeError(value + " is not iterable");
+ if (!isIterable(value)) { throw new TypeError(value + " is not iterable"); }
return value;
};
var objectToString = Object.prototype.toString;
var coerce = function (value) {
- if (!is(value)) return null;
+ if (!is(value)) { return null; }
if (is$1(value)) {
// Reject Object.prototype.toString coercion
var valueToString = value.toString;
- if (typeof valueToString !== "function") return null;
- if (valueToString === objectToString) return null;
+ if (typeof valueToString !== "function") { return null; }
+ if (valueToString === objectToString) { return null; }
// Note: It can be object coming from other realm, still as there's no ES3 and CSP compliant
// way to resolve its realm's Object.prototype.toString it's left as not addressed edge case
}
var toShortString = function (value) {
var string = safeToString(value);
- if (string === null) return "<Non-coercible to string value>";
+ if (string === null) { return "<Non-coercible to string value>"; }
// Trim if too long
- if (string.length > 100) string = string.slice(0, 99) + "…";
+ if (string.length > 100) { string = string.slice(0, 99) + "…"; }
// Replace eventual new lines
string = string.replace(reNewLine, function (char) {
switch (char) {
};
var resolveException = function (value, defaultMessage, inputOptions) {
- if (!is$1(inputOptions)) throw new TypeError(resolveMessage(defaultMessage, value));
+ if (!is$1(inputOptions)) { throw new TypeError(resolveMessage(defaultMessage, value)); }
if (!is(value)) {
- if ("default" in inputOptions) return inputOptions["default"];
- if (inputOptions.isOptional) return null;
+ if ("default" in inputOptions) { return inputOptions["default"]; }
+ if (inputOptions.isOptional) { return null; }
}
var errorMessage = coerce(inputOptions.errorMessage);
- if (!is(errorMessage)) errorMessage = defaultMessage;
+ if (!is(errorMessage)) { errorMessage = defaultMessage; }
throw new TypeError(resolveMessage(errorMessage, value));
};
var ensure = function (value/*, options*/) {
- if (is(value)) return value;
+ if (is(value)) { return value; }
return resolveException(value, "Cannot use %v", arguments[1]);
};
var ensure$1 = function (value/*, options*/) {
- if (is$4(value)) return value;
+ if (is$4(value)) { return value; }
return resolveException(value, "%v is not a plain function", arguments[1]);
};
var isImplemented$a = function () {
var from = Array.from, arr, result;
- if (typeof from !== "function") return false;
+ if (typeof from !== "function") { return false; }
arr = ["raz", "dwa"];
result = from(arr);
return Boolean(result && result !== arr && result[1] === "dwa");
arrayLike = Object(validValue(arrayLike));
- if (isValue(mapFn)) validCallable(mapFn);
+ if (isValue(mapFn)) { validCallable(mapFn); }
if (!this || this === Array || !isFunction(this)) {
// Result: Plain array
if (!mapFn) {
if (isArguments(arrayLike)) {
// Source: Arguments
length = arrayLike.length;
- if (length !== 1) return Array.apply(null, arrayLike);
+ if (length !== 1) { return Array.apply(null, arrayLike); }
arr = new Array(1);
arr[0] = arrayLike[0];
return arr;
if (isArray$1(arrayLike)) {
// Source: Array
arr = new Array((length = arrayLike.length));
- for (i = 0; i < length; ++i) arr[i] = arrayLike[i];
+ for (i = 0; i < length; ++i) { arr[i] = arrayLike[i]; }
return arr;
}
}
if ((getIterator = arrayLike[iteratorSymbol$1]) !== undefined) {
// Source: Iterator
iterator = validCallable(getIterator).call(arrayLike);
- if (Context) arr = new Context();
+ if (Context) { arr = new Context(); }
result = iterator.next();
i = 0;
while (!result.done) {
} else if (isString(arrayLike)) {
// Source: String
length = arrayLike.length;
- if (Context) arr = new Context();
+ if (Context) { arr = new Context(); }
for (i = 0, j = 0; i < length; ++i) {
value = arrayLike[i];
if (i + 1 < length) {
code = value.charCodeAt(0);
// eslint-disable-next-line max-depth
- if (code >= 0xd800 && code <= 0xdbff) value += arrayLike[++i];
+ if (code >= 0xd800 && code <= 0xdbff) { value += arrayLike[++i]; }
}
value = mapFn ? call.call(mapFn, thisArg, value, j) : value;
if (Context) {
if (length === undefined) {
// Source: array or array-like
length = toPosInteger(arrayLike.length);
- if (Context) arr = new Context(length);
+ if (Context) { arr = new Context(length); }
for (i = 0; i < length; ++i) {
value = mapFn ? call.call(mapFn, thisArg, arrayLike[i], i) : arrayLike[i];
if (Context) {
var copy = function (obj/*, propertyNames, options*/) {
var copy = Object(validValue(obj)), propertyNames = arguments[1], options = Object(arguments[2]);
- if (copy !== obj && !propertyNames) return copy;
+ if (copy !== obj && !propertyNames) { return copy; }
var result = {};
if (propertyNames) {
from_1(propertyNames, function (propertyName) {
- if (options.ensure || propertyName in obj) result[propertyName] = obj[propertyName];
+ if (options.ensure || propertyName in obj) { result[propertyName] = obj[propertyName]; }
});
} else {
assign(result, obj);
if (compareFn) {
list.sort(typeof compareFn === "function" ? bind.call(compareFn, obj) : undefined);
}
- if (typeof method !== "function") method = list[method];
+ if (typeof method !== "function") { method = list[method]; }
return call$1.call(method, list, function (key, index) {
- if (!objPropertyIsEnumerable.call(obj, key)) return defVal;
+ if (!objPropertyIsEnumerable.call(obj, key)) { return defVal; }
return call$1.call(cb, thisArg, obj[key], key, obj, index);
});
};
delete dgs.writable;
delete dgs.value;
dgs.get = function () {
- if (!options.overwriteDefinition && hasOwnProperty$1.call(this, name)) return value;
+ if (!options.overwriteDefinition && hasOwnProperty$1.call(this, name)) { return value; }
desc.value = bind$1.call(value, options.resolveContext ? options.resolveContext(this) : this);
defineProperty$5(this, name, desc);
return this[name];
var autoBind = function (props/*, options*/) {
var options = normalizeOptions(arguments[1]);
- if (is(options.resolveContext)) ensure$1(options.resolveContext);
+ if (is(options.resolveContext)) { ensure$1(options.resolveContext); }
return map$1(props, function (desc, name) { return define(name, desc, options); });
};
var defineProperty$6 = Object.defineProperty, defineProperties$2 = Object.defineProperties, Iterator;
var es6Iterator = Iterator = function (list, context) {
- if (!(this instanceof Iterator)) throw new TypeError("Constructor requires 'new'");
+ if (!(this instanceof Iterator)) { throw new TypeError("Constructor requires 'new'"); }
defineProperties$2(this, {
__list__: d_1("w", validValue(list)),
__context__: d_1("w", context),
__nextIndex__: d_1("w", 0)
});
- if (!context) return;
+ if (!context) { return; }
validCallable(context.on);
context.on("_add", this._onAdd);
context.on("_delete", this._onDelete);
{
_next: d_1(function () {
var i;
- if (!this.__list__) return undefined;
+ if (!this.__list__) { return undefined; }
if (this.__redo__) {
i = this.__redo__.shift();
- if (i !== undefined) return i;
+ if (i !== undefined) { return i; }
}
- if (this.__nextIndex__ < this.__list__.length) return this.__nextIndex__++;
+ if (this.__nextIndex__ < this.__list__.length) { return this.__nextIndex__++; }
this._unBind();
return undefined;
}),
return this._createResult(this._next());
}),
_createResult: d_1(function (i) {
- if (i === undefined) return { done: true, value: undefined };
+ if (i === undefined) { return { done: true, value: undefined }; }
return { done: false, value: this._resolve(i) };
}),
_resolve: d_1(function (i) {
_unBind: d_1(function () {
this.__list__ = null;
delete this.__redo__;
- if (!this.__context__) return;
+ if (!this.__context__) { return; }
this.__context__.off("_add", this._onAdd);
this.__context__.off("_delete", this._onDelete);
this.__context__.off("_clear", this._onClear);
},
autoBind({
_onAdd: d_1(function (index) {
- if (index >= this.__nextIndex__) return;
+ if (index >= this.__nextIndex__) { return; }
++this.__nextIndex__;
if (!this.__redo__) {
defineProperty$6(this, "__redo__", d_1("c", [index]));
return;
}
this.__redo__.forEach(function (redo, i) {
- if (redo >= index) this.__redo__[i] = ++redo;
+ if (redo >= index) { this.__redo__[i] = ++redo; }
}, this);
this.__redo__.push(index);
}),
_onDelete: d_1(function (index) {
var i;
- if (index >= this.__nextIndex__) return;
+ if (index >= this.__nextIndex__) { return; }
--this.__nextIndex__;
- if (!this.__redo__) return;
+ if (!this.__redo__) { return; }
i = this.__redo__.indexOf(index);
- if (i !== -1) this.__redo__.splice(i, 1);
+ if (i !== -1) { this.__redo__.splice(i, 1); }
this.__redo__.forEach(function (redo, j) {
- if (redo > index) this.__redo__[j] = --redo;
+ if (redo > index) { this.__redo__[j] = --redo; }
}, this);
}),
_onClear: d_1(function () {
- if (this.__redo__) clear.call(this.__redo__);
+ if (this.__redo__) { clear.call(this.__redo__); }
this.__nextIndex__ = 0;
})
})
var defineProperty = Object.defineProperty, ArrayIterator;
ArrayIterator = module.exports = function (arr, kind) {
- if (!(this instanceof ArrayIterator)) throw new TypeError("Constructor requires 'new'");
+ if (!(this instanceof ArrayIterator)) { throw new TypeError("Constructor requires 'new'"); }
es6Iterator.call(this, arr);
- if (!kind) kind = "value";
- else if (contains.call(kind, "key+value")) kind = "key+value";
- else if (contains.call(kind, "key")) kind = "key";
- else kind = "value";
+ if (!kind) { kind = "value"; }
+ else if (contains.call(kind, "key+value")) { kind = "key+value"; }
+ else if (contains.call(kind, "key")) { kind = "key"; }
+ else { kind = "value"; }
defineProperty(this, "__kind__", d_1("", kind));
};
- if (setPrototypeOf) setPrototypeOf(ArrayIterator, es6Iterator);
+ if (setPrototypeOf) { setPrototypeOf(ArrayIterator, es6Iterator); }
// Internal %ArrayIteratorPrototype% doesn't expose its constructor
delete ArrayIterator.prototype.constructor;
ArrayIterator.prototype = Object.create(es6Iterator.prototype, {
_resolve: d_1(function (i) {
- if (this.__kind__ === "value") return this.__list__[i];
- if (this.__kind__ === "key+value") return [i, this.__list__[i]];
+ if (this.__kind__ === "value") { return this.__list__[i]; }
+ if (this.__kind__ === "key+value") { return [i, this.__list__[i]]; }
return i;
})
});
var defineProperty = Object.defineProperty, StringIterator;
StringIterator = module.exports = function (str) {
- if (!(this instanceof StringIterator)) throw new TypeError("Constructor requires 'new'");
+ if (!(this instanceof StringIterator)) { throw new TypeError("Constructor requires 'new'"); }
str = String(str);
es6Iterator.call(this, str);
defineProperty(this, "__length__", d_1("", str.length));
};
- if (setPrototypeOf) setPrototypeOf(StringIterator, es6Iterator);
+ if (setPrototypeOf) { setPrototypeOf(StringIterator, es6Iterator); }
// Internal %ArrayIteratorPrototype% doesn't expose its constructor
delete StringIterator.prototype.constructor;
StringIterator.prototype = Object.create(es6Iterator.prototype, {
_next: d_1(function () {
- if (!this.__list__) return undefined;
- if (this.__nextIndex__ < this.__length__) return this.__nextIndex__++;
+ if (!this.__list__) { return undefined; }
+ if (this.__nextIndex__ < this.__length__) { return this.__nextIndex__++; }
this._unBind();
return undefined;
}),
_resolve: d_1(function (i) {
var char = this.__list__[i], code;
- if (this.__nextIndex__ === this.__length__) return char;
+ if (this.__nextIndex__ === this.__length__) { return char; }
code = char.charCodeAt(0);
- if (code >= 0xd800 && code <= 0xdbff) return char + this.__list__[this.__nextIndex__++];
+ if (code >= 0xd800 && code <= 0xdbff) { return char + this.__list__[this.__nextIndex__++]; }
return char;
})
});
var iteratorSymbol$2 = es6Symbol$1.iterator;
var get = function (obj) {
- if (typeof validIterable(obj)[iteratorSymbol$2] === "function") return obj[iteratorSymbol$2]();
- if (isArguments(obj)) return new array(obj);
- if (isString(obj)) return new string(obj);
+ if (typeof validIterable(obj)[iteratorSymbol$2] === "function") { return obj[iteratorSymbol$2](); }
+ if (isArguments(obj)) { return new array(obj); }
+ if (isString(obj)) { return new string(obj); }
return new array(obj);
};
var forOf = function (iterable, cb /*, thisArg*/) {
var mode, thisArg = arguments[2], result, doBreak, broken, i, length, char, code;
- if (isArray$2(iterable) || isArguments(iterable)) mode = "array";
- else if (isString(iterable)) mode = "string";
- else iterable = get(iterable);
+ if (isArray$2(iterable) || isArguments(iterable)) { mode = "array"; }
+ else if (isString(iterable)) { mode = "string"; }
+ else { iterable = get(iterable); }
validCallable(cb);
doBreak = function () {
char = iterable[i];
if (i + 1 < length) {
code = char.charCodeAt(0);
- if (code >= 0xd800 && code <= 0xdbff) char += iterable[++i];
+ if (code >= 0xd800 && code <= 0xdbff) { char += iterable[++i]; }
}
call$3.call(cb, thisArg, char, doBreak);
- if (broken) break;
+ if (broken) { break; }
}
return;
}
while (!result.done) {
call$3.call(cb, thisArg, result.value, doBreak);
- if (broken) return;
+ if (broken) { return; }
result = iterable.next();
}
};
, SetIterator;
SetIterator = module.exports = function (set, kind) {
- if (!(this instanceof SetIterator)) return new SetIterator(set, kind);
+ if (!(this instanceof SetIterator)) { return new SetIterator(set, kind); }
es6Iterator.call(this, set.__setData__, set);
- if (!kind) kind = 'value';
- else if (contains.call(kind, 'key+value')) kind = 'key+value';
- else kind = 'value';
+ if (!kind) { kind = 'value'; }
+ else if (contains.call(kind, 'key+value')) { kind = 'key+value'; }
+ else { kind = 'value'; }
defineProperty(this, '__kind__', d_1('', kind));
};
- if (setPrototypeOf) setPrototypeOf(SetIterator, es6Iterator);
+ if (setPrototypeOf) { setPrototypeOf(SetIterator, es6Iterator); }
SetIterator.prototype = Object.create(es6Iterator.prototype, {
constructor: d_1(SetIterator),
_resolve: d_1(function (i) {
- if (this.__kind__ === 'value') return this.__list__[i];
+ if (this.__kind__ === 'value') { return this.__list__[i]; }
return [this.__list__[i], this.__list__[i]];
}),
toString: d_1(function () { return '[object Set Iterator]'; })
// Exports true if environment provides native `Set` implementation,
var isNativeImplemented = (function () {
- if (typeof Set === 'undefined') return false;
+ if (typeof Set === 'undefined') { return false; }
return (Object.prototype.toString.call(Set.prototype) === '[object Set]');
}());
, defineProperty$7 = Object.defineProperty, getPrototypeOf$1 = Object.getPrototypeOf
, SetPoly, getValues, NativeSet;
- if (isNativeImplemented) NativeSet = Set;
+ if (isNativeImplemented) { NativeSet = Set; }
var polyfill$2 = SetPoly = function Set(/*iterable*/) {
var iterable = arguments[0], self;
- if (!(this instanceof SetPoly)) throw new TypeError('Constructor requires \'new\'');
- if (isNativeImplemented && setPrototypeOf) self = setPrototypeOf(new NativeSet(), getPrototypeOf$1(this));
- else self = this;
- if (iterable != null) iterator$1(iterable);
+ if (!(this instanceof SetPoly)) { throw new TypeError('Constructor requires \'new\''); }
+ if (isNativeImplemented && setPrototypeOf) { self = setPrototypeOf(new NativeSet(), getPrototypeOf$1(this)); }
+ else { self = this; }
+ if (iterable != null) { iterator$1(iterable); }
defineProperty$7(self, '__setData__', d_1('c', []));
- if (!iterable) return self;
+ if (!iterable) { return self; }
forOf(iterable, function (value) {
- if (eIndexOf.call(this, value) !== -1) return;
+ if (eIndexOf.call(this, value) !== -1) { return; }
this.push(value);
}, self.__setData__);
return self;
};
if (isNativeImplemented) {
- if (setPrototypeOf) setPrototypeOf(SetPoly, NativeSet);
+ if (setPrototypeOf) { setPrototypeOf(SetPoly, NativeSet); }
SetPoly.prototype = Object.create(NativeSet.prototype, { constructor: d_1(SetPoly) });
}
eventEmitter(Object.defineProperties(SetPoly.prototype, {
add: d_1(function (value) {
- if (this.has(value)) return this;
+ if (this.has(value)) { return this; }
this.emit('_add', this.__setData__.push(value) - 1, value);
return this;
}),
clear: d_1(function () {
- if (!this.__setData__.length) return;
+ if (!this.__setData__.length) { return; }
clear.call(this.__setData__);
this.emit('_clear');
}),
delete: d_1(function (value) {
var index = eIndexOf.call(this.__setData__, value);
- if (index === -1) return false;
+ if (index === -1) { return false; }
this.__setData__.splice(index, 1);
this.emit('_delete', index, value);
return true;
var isImplemented$b = function () {
var map, iterator, result;
- if (typeof Map !== 'function') return false;
+ if (typeof Map !== 'function') { return false; }
try {
// WebKit doesn't support arguments and crashes
map = new Map([['raz', 'one'], ['dwa', 'two'], ['trzy', 'three']]);
} catch (e) {
return false;
}
- if (String(map) !== '[object Map]') return false;
- if (map.size !== 3) return false;
- if (typeof map.clear !== 'function') return false;
- if (typeof map.delete !== 'function') return false;
- if (typeof map.entries !== 'function') return false;
- if (typeof map.forEach !== 'function') return false;
- if (typeof map.get !== 'function') return false;
- if (typeof map.has !== 'function') return false;
- if (typeof map.keys !== 'function') return false;
- if (typeof map.set !== 'function') return false;
- if (typeof map.values !== 'function') return false;
+ if (String(map) !== '[object Map]') { return false; }
+ if (map.size !== 3) { return false; }
+ if (typeof map.clear !== 'function') { return false; }
+ if (typeof map.delete !== 'function') { return false; }
+ if (typeof map.entries !== 'function') { return false; }
+ if (typeof map.forEach !== 'function') { return false; }
+ if (typeof map.get !== 'function') { return false; }
+ if (typeof map.has !== 'function') { return false; }
+ if (typeof map.keys !== 'function') { return false; }
+ if (typeof map.set !== 'function') { return false; }
+ if (typeof map.values !== 'function') { return false; }
iterator = map.entries();
result = iterator.next();
- if (result.done !== false) return false;
- if (!result.value) return false;
- if (result.value[0] !== 'raz') return false;
- if (result.value[1] !== 'one') return false;
+ if (result.done !== false) { return false; }
+ if (!result.value) { return false; }
+ if (result.value[0] !== 'raz') { return false; }
+ if (result.value[1] !== 'one') { return false; }
return true;
};
, MapIterator;
MapIterator = module.exports = function (map, kind) {
- if (!(this instanceof MapIterator)) return new MapIterator(map, kind);
+ if (!(this instanceof MapIterator)) { return new MapIterator(map, kind); }
es6Iterator.call(this, map.__mapKeysData__, map);
- if (!kind || !iteratorKinds[kind]) kind = 'key+value';
+ if (!kind || !iteratorKinds[kind]) { kind = 'key+value'; }
defineProperties(this, {
__kind__: d_1('', kind),
__values__: d_1('w', map.__mapValuesData__)
});
};
- if (setPrototypeOf) setPrototypeOf(MapIterator, es6Iterator);
+ if (setPrototypeOf) { setPrototypeOf(MapIterator, es6Iterator); }
MapIterator.prototype = Object.create(es6Iterator.prototype, {
constructor: d_1(MapIterator),
_resolve: d_1(function (i) {
- if (this.__kind__ === 'value') return this.__values__[i];
- if (this.__kind__ === 'key') return this.__list__[i];
+ if (this.__kind__ === 'value') { return this.__values__[i]; }
+ if (this.__kind__ === 'key') { return this.__list__[i]; }
return [this.__list__[i], this.__values__[i]];
}),
_unBind: d_1(function () {
// Exports true if environment provides native `Map` implementation,
var isNativeImplemented$1 = (function () {
- if (typeof Map === 'undefined') return false;
+ if (typeof Map === 'undefined') { return false; }
return (Object.prototype.toString.call(new Map()) === '[object Map]');
}());
var polyfill$3 = MapPoly = function (/*iterable*/) {
var iterable = arguments[0], keys, values, self;
- if (!(this instanceof MapPoly)) throw new TypeError('Constructor requires \'new\'');
+ if (!(this instanceof MapPoly)) { throw new TypeError('Constructor requires \'new\''); }
if (isNativeImplemented$1 && setPrototypeOf && (Map !== MapPoly)) {
self = setPrototypeOf(new Map(), getPrototypeOf$2(this));
} else {
self = this;
}
- if (iterable != null) iterator$3(iterable);
+ if (iterable != null) { iterator$3(iterable); }
defineProperties$3(self, {
__mapKeysData__: d_1('c', keys = []),
__mapValuesData__: d_1('c', values = [])
});
- if (!iterable) return self;
+ if (!iterable) { return self; }
forOf(iterable, function (value) {
var key = validValue(value)[0];
value = value[1];
- if (eIndexOf.call(keys, key) !== -1) return;
+ if (eIndexOf.call(keys, key) !== -1) { return; }
keys.push(key);
values.push(value);
}, self);
};
if (isNativeImplemented$1) {
- if (setPrototypeOf) setPrototypeOf(MapPoly, Map);
+ if (setPrototypeOf) { setPrototypeOf(MapPoly, Map); }
MapPoly.prototype = Object.create(Map.prototype, {
constructor: d_1(MapPoly)
});
eventEmitter(defineProperties$3(MapPoly.prototype, {
clear: d_1(function () {
- if (!this.__mapKeysData__.length) return;
+ if (!this.__mapKeysData__.length) { return; }
clear.call(this.__mapKeysData__);
clear.call(this.__mapValuesData__);
this.emit('_clear');
}),
delete: d_1(function (key) {
var index = eIndexOf.call(this.__mapKeysData__, key);
- if (index === -1) return false;
+ if (index === -1) { return false; }
this.__mapKeysData__.splice(index, 1);
this.__mapValuesData__.splice(index, 1);
this.emit('_delete', index, key);
}),
get: d_1(function (key) {
var index = eIndexOf.call(this.__mapKeysData__, key);
- if (index === -1) return;
+ if (index === -1) { return; }
return this.__mapValuesData__[index];
}),
has: d_1(function (key) {
emit = true;
}
this.__mapValuesData__[index] = value;
- if (emit) this.emit('_add', index, key);
+ if (emit) { this.emit('_add', index, key); }
return this;
}),
size: d_1.gs(function () { return this.__mapKeysData__.length; }),
return true;
}
}
- } catch (e) {
+ } catch (e$1) {
return true;
}
}
return String(obj);
}
- if (!opts) opts = {};
+ if (!opts) { opts = {}; }
var maxDepth = typeof opts.depth === 'undefined' ? 5 : opts.depth;
- if (typeof depth === 'undefined') depth = 0;
+ if (typeof depth === 'undefined') { depth = 0; }
if (depth >= maxDepth && maxDepth > 0 && typeof obj === 'object') {
return '[Object]';
}
- if (typeof seen === 'undefined') seen = [];
+ if (typeof seen === 'undefined') { seen = []; }
else if (indexOf$2(seen, obj) >= 0) {
return '[Circular]';
}
s += ' ' + attrs[i].name + '="' + quote(attrs[i].value) + '"';
}
s += '>';
- if (obj.childNodes && obj.childNodes.length) s += '...';
+ if (obj.childNodes && obj.childNodes.length) { s += '...'; }
s += '</' + String(obj.nodeName).toLowerCase() + '>';
return s;
}
if (isArray$3(obj)) {
- if (obj.length === 0) return '[]';
+ if (obj.length === 0) { return '[]'; }
return '[ ' + arrObjKeys(obj, inspect).join(', ') + ' ]';
}
if (isError(obj)) {
var parts = arrObjKeys(obj, inspect);
- if (parts.length === 0) return '[' + String(obj) + ']';
+ if (parts.length === 0) { return '[' + String(obj) + ']'; }
return '{ [' + String(obj) + '] ' + parts.join(', ') + ' }';
}
if (typeof obj === 'object' && typeof obj.inspect === 'function') {
}
if (!isDate(obj) && !isRegExp(obj)) {
var xs = arrObjKeys(obj, inspect);
- if (xs.length === 0) return '{}';
+ if (xs.length === 0) { return '{}'; }
return '{ ' + xs.join(', ') + ' }';
}
return String(obj);
}
function nameOf (f) {
- if (f.name) return f.name;
+ if (f.name) { return f.name; }
var m = String(f).match(/^function\s*([\w$]+)/);
- if (m) return m[1];
+ if (m) { return m[1]; }
}
function indexOf$2 (xs, x) {
- if (xs.indexOf) return xs.indexOf(x);
+ if (xs.indexOf) { return xs.indexOf(x); }
for (var i = 0, l = xs.length; i < l; i++) {
- if (xs[i] === x) return i;
+ if (xs[i] === x) { return i; }
}
return -1;
}
}
function isElement (x) {
- if (!x || typeof x !== 'object') return false;
+ if (!x || typeof x !== 'object') { return false; }
if (typeof HTMLElement !== 'undefined' && x instanceof HTMLElement) {
return true;
}
function lowbyte (c) {
var n = c.charCodeAt(0);
var x = { 8: 'b', 9: 't', 10: 'n', 12: 'f', 13: 'r' }[n];
- if (x) return '\\' + x;
+ if (x) { return '\\' + x; }
return '\\x' + (n < 0x10 ? '0' : '') + n.toString(16);
}
}
}
for (var key in obj) {
- if (!has$1(obj, key)) continue;
- if (isArr && String(Number(key)) === key && key < obj.length) continue;
+ if (!has$1(obj, key)) { continue; }
+ if (isArr && String(Number(key)) === key && key < obj.length) { continue; }
if (/[^\w$]/.test(key)) {
xs.push(inspect(key, obj) + ': ' + inspect(obj[key], obj));
} else {
}
}
return x instanceof $Map; // core-js workaround, pre-v2.5.0
- } catch (e) {}
+ } catch (e$1) {}
return false;
};
}
}
return x instanceof $Set$1; // core-js workaround, pre-v2.5.0
- } catch (e) {}
+ } catch (e$1) {}
return false;
};
var originalGetSymbols = hasSymbols$5 ? Object.getOwnPropertySymbols : null;
var implementation$7 = function assign(target, source1) {
+ var arguments$1 = arguments;
+
if (!canBeObject(target)) { throw new TypeError('target must be an object'); }
var objTarget = toObject(target);
var s, source, i, props, syms, value, key;
for (s = 1; s < arguments.length; ++s) {
- source = toObject(arguments[s]);
+ source = toObject(arguments$1[s]);
props = objectKeys(source);
var getSymbols = hasSymbols$5 && (Object.getOwnPropertySymbols || originalGetSymbols);
if (getSymbols) {
*/
function Promise$1(fn) {
if (!(this instanceof Promise$1))
- throw new TypeError('Promises must be constructed via new');
- if (typeof fn !== 'function') throw new TypeError('not a function');
+ { throw new TypeError('Promises must be constructed via new'); }
+ if (typeof fn !== 'function') { throw new TypeError('not a function'); }
/** @type {!number} */
this._state = 0;
/** @type {!boolean} */
try {
// Promise Resolution Procedure: https://github.com/promises-aplus/promises-spec#the-promise-resolution-procedure
if (newValue === self)
- throw new TypeError('A promise cannot be resolved with itself.');
+ { throw new TypeError('A promise cannot be resolved with itself.'); }
if (
newValue &&
(typeof newValue === 'object' || typeof newValue === 'function')
try {
fn(
function(value) {
- if (done) return;
+ if (done) { return; }
done = true;
resolve(self, value);
},
function(reason) {
- if (done) return;
+ if (done) { return; }
done = true;
reject(self, reason);
}
);
} catch (ex) {
- if (done) return;
+ if (done) { return; }
done = true;
reject(self, ex);
}
}
var args = Array.prototype.slice.call(arr);
- if (args.length === 0) return resolve([]);
+ if (args.length === 0) { return resolve([]); }
var remaining = args.length;
function res(i, val) {
var StringFromCharCodeSpread = callBind.apply(String.fromCharCode, null);
var implementation$8 = function fromCodePoint(_ /* fromCodePoint.length is 1 */) {
+ var arguments$1 = arguments;
+
var MAX_SIZE = 0x4000;
var codeUnits = [];
var highSurrogate;
}
var result = '';
while (++index < length) {
- var codePoint = ToNumber$1(arguments[index]);
+ var codePoint = ToNumber$1(arguments$1[index]);
if (
!IsInteger(codePoint) ||
codePoint < 0 || codePoint > 0x10FFFF // not a valid Unicode code point
var descriptor = props[i];
descriptor.enumerable = descriptor.enumerable || false;
descriptor.configurable = true;
- if ("value" in descriptor) descriptor.writable = true;
+ if ("value" in descriptor) { descriptor.writable = true; }
Object.defineProperty(target, descriptor.key, descriptor);
}
}
function _createClass(Constructor, protoProps, staticProps) {
- if (protoProps) _defineProperties(Constructor.prototype, protoProps);
- if (staticProps) _defineProperties(Constructor, staticProps);
+ if (protoProps) { _defineProperties(Constructor.prototype, protoProps); }
+ if (staticProps) { _defineProperties(Constructor, staticProps); }
return Constructor;
}
configurable: true
}
});
- if (superClass) _setPrototypeOf(subClass, superClass);
+ if (superClass) { _setPrototypeOf(subClass, superClass); }
}
function _getPrototypeOf(o) {
function _superPropBase(object, property) {
while (!Object.prototype.hasOwnProperty.call(object, property)) {
object = _getPrototypeOf(object);
- if (object === null) break;
+ if (object === null) { break; }
}
return object;
_get = function _get(target, property, receiver) {
var base = _superPropBase(target, property);
- if (!base) return;
+ if (!base) { return; }
var desc = Object.getOwnPropertyDescriptor(base, property);
if (desc.get) {
function reverseValue(key, value, includeAbsolute) {
- if (ignoreKey.test(key)) return value;
+ if (ignoreKey.test(key)) { return value; }
// Turn lanes are left/right to key (not way) direction - #5674
if (turn_lanes.test(key)) {
return onewayReplacements[value] || value;
} else if (includeAbsolute && directionKey.test(key)) {
- if (compassReplacements[value]) return compassReplacements[value];
+ if (compassReplacements[value]) { return compassReplacements[value]; }
var degrees = parseFloat(value);
if (typeof degrees === 'number' && !isNaN(degrees)) {
function reverseNodeTags(graph, nodeIDs) {
for (var i = 0; i < nodeIDs.length; i++) {
var node = graph.hasEntity(nodeIDs[i]);
- if (!node || !Object.keys(node.tags).length) continue;
+ if (!node || !Object.keys(node.tags).length) { continue; }
var tags = {};
for (var key in node.tags) {
action.disabled = function(graph) {
var entity = graph.hasEntity(entityID);
- if (!entity || entity.type === 'way') return false;
+ if (!entity || entity.type === 'way') { return false; }
for (var key in entity.tags) {
var value = entity.tags[key];
// returns an object with the tag from `tags` that implies an area geometry, if any
function osmTagSuggestingArea(tags) {
- if (tags.area === 'yes') return { area: 'yes' };
- if (tags.area === 'no') return null;
+ if (tags.area === 'yes') { return { area: 'yes' }; }
+ if (tags.area === 'no') { return null; }
// `highway` and `railway` are typically linear features, but there
// are a few exceptions that should be treated as areas, even in the
geometries.vertex = true;
}
// break early if both are already supported
- if (geometries.point && geometries.vertex) break;
+ if (geometries.point && geometries.vertex) { break; }
}
return geometries;
}
add: function(y) {
add(temp, y, this.t);
add(this, temp.s, this.s);
- if (this.s) this.t += temp.t;
- else this.s = temp.t;
+ if (this.s) { this.t += temp.t; }
+ else { this.s = temp.t; }
},
valueOf: function() {
return this.s;
},
FeatureCollection: function(object, stream) {
var features = object.features, i = -1, n = features.length;
- while (++i < n) streamGeometry(features[i].geometry, stream);
+ while (++i < n) { streamGeometry(features[i].geometry, stream); }
}
};
},
MultiPoint: function(object, stream) {
var coordinates = object.coordinates, i = -1, n = coordinates.length;
- while (++i < n) object = coordinates[i], stream.point(object[0], object[1], object[2]);
+ while (++i < n) { object = coordinates[i], stream.point(object[0], object[1], object[2]); }
},
LineString: function(object, stream) {
streamLine(object.coordinates, stream, 0);
},
MultiLineString: function(object, stream) {
var coordinates = object.coordinates, i = -1, n = coordinates.length;
- while (++i < n) streamLine(coordinates[i], stream, 0);
+ while (++i < n) { streamLine(coordinates[i], stream, 0); }
},
Polygon: function(object, stream) {
streamPolygon(object.coordinates, stream);
},
MultiPolygon: function(object, stream) {
var coordinates = object.coordinates, i = -1, n = coordinates.length;
- while (++i < n) streamPolygon(coordinates[i], stream);
+ while (++i < n) { streamPolygon(coordinates[i], stream); }
},
GeometryCollection: function(object, stream) {
var geometries = object.geometries, i = -1, n = geometries.length;
- while (++i < n) streamGeometry(geometries[i], stream);
+ while (++i < n) { streamGeometry(geometries[i], stream); }
}
};
function streamLine(coordinates, stream, closed) {
var i = -1, n = coordinates.length - closed, coordinate;
stream.lineStart();
- while (++i < n) coordinate = coordinates[i], stream.point(coordinate[0], coordinate[1], coordinate[2]);
+ while (++i < n) { coordinate = coordinates[i], stream.point(coordinate[0], coordinate[1], coordinate[2]); }
stream.lineEnd();
}
function streamPolygon(coordinates, stream) {
var i = -1, n = coordinates.length;
stream.polygonStart();
- while (++i < n) streamLine(coordinates[i], stream, 1);
+ while (++i < n) { streamLine(coordinates[i], stream, 1); }
stream.polygonEnd();
}
boundsStream.point = boundsPoint;
boundsStream.lineStart = boundsLineStart;
boundsStream.lineEnd = boundsLineEnd;
- if (areaRingSum < 0) lambda0$1 = -(lambda1 = 180), phi0 = -(phi1 = 90);
- else if (deltaSum > epsilon) phi1 = 90;
- else if (deltaSum < -epsilon) phi0 = -90;
+ if (areaRingSum < 0) { lambda0$1 = -(lambda1 = 180), phi0 = -(phi1 = 90); }
+ else if (deltaSum > epsilon) { phi1 = 90; }
+ else if (deltaSum < -epsilon) { phi0 = -90; }
range[0] = lambda0$1, range[1] = lambda1;
},
sphere: function() {
function boundsPoint(lambda, phi) {
ranges.push(range = [lambda0$1 = lambda, lambda1 = lambda]);
- if (phi < phi0) phi0 = phi;
- if (phi > phi1) phi1 = phi;
+ if (phi < phi0) { phi0 = phi; }
+ if (phi > phi1) { phi1 = phi; }
}
function linePoint(lambda, phi) {
antimeridian = abs$2(delta) > 180;
if (antimeridian ^ (sign * lambda2 < lambdai && lambdai < sign * lambda)) {
phii = inflection[1] * degrees;
- if (phii > phi1) phi1 = phii;
+ if (phii > phi1) { phi1 = phii; }
} else if (lambdai = (lambdai + 360) % 360 - 180, antimeridian ^ (sign * lambda2 < lambdai && lambdai < sign * lambda)) {
phii = -inflection[1] * degrees;
- if (phii < phi0) phi0 = phii;
+ if (phii < phi0) { phi0 = phii; }
} else {
- if (phi < phi0) phi0 = phi;
- if (phi > phi1) phi1 = phi;
+ if (phi < phi0) { phi0 = phi; }
+ if (phi > phi1) { phi1 = phi; }
}
if (antimeridian) {
if (lambda < lambda2) {
- if (angle(lambda0$1, lambda) > angle(lambda0$1, lambda1)) lambda1 = lambda;
+ if (angle(lambda0$1, lambda) > angle(lambda0$1, lambda1)) { lambda1 = lambda; }
} else {
- if (angle(lambda, lambda1) > angle(lambda0$1, lambda1)) lambda0$1 = lambda;
+ if (angle(lambda, lambda1) > angle(lambda0$1, lambda1)) { lambda0$1 = lambda; }
}
} else {
if (lambda1 >= lambda0$1) {
- if (lambda < lambda0$1) lambda0$1 = lambda;
- if (lambda > lambda1) lambda1 = lambda;
+ if (lambda < lambda0$1) { lambda0$1 = lambda; }
+ if (lambda > lambda1) { lambda1 = lambda; }
} else {
if (lambda > lambda2) {
- if (angle(lambda0$1, lambda) > angle(lambda0$1, lambda1)) lambda1 = lambda;
+ if (angle(lambda0$1, lambda) > angle(lambda0$1, lambda1)) { lambda1 = lambda; }
} else {
- if (angle(lambda, lambda1) > angle(lambda0$1, lambda1)) lambda0$1 = lambda;
+ if (angle(lambda, lambda1) > angle(lambda0$1, lambda1)) { lambda0$1 = lambda; }
}
}
}
} else {
ranges.push(range = [lambda0$1 = lambda, lambda1 = lambda]);
}
- if (phi < phi0) phi0 = phi;
- if (phi > phi1) phi1 = phi;
+ if (phi < phi0) { phi0 = phi; }
+ if (phi > phi1) { phi1 = phi; }
p0 = p, lambda2 = lambda;
}
function boundsRingEnd() {
boundsRingPoint(lambda00$1, phi00$1);
areaStream.lineEnd();
- if (abs$2(deltaSum) > epsilon) lambda0$1 = -(lambda1 = 180);
+ if (abs$2(deltaSum) > epsilon) { lambda0$1 = -(lambda1 = 180); }
range[0] = lambda0$1, range[1] = lambda1;
p0 = null;
}
for (i = 1, a = ranges[0], merged = [a]; i < n; ++i) {
b = ranges[i];
if (rangeContains(a, b[0]) || rangeContains(a, b[1])) {
- if (angle(a[0], b[1]) > angle(a[0], a[1])) a[1] = b[1];
- if (angle(b[0], a[1]) > angle(a[0], a[1])) a[0] = b[0];
+ if (angle(a[0], b[1]) > angle(a[0], a[1])) { a[1] = b[1]; }
+ if (angle(b[0], a[1]) > angle(a[0], a[1])) { a[0] = b[0]; }
} else {
merged.push(a = b);
}
// The final bounding box will be the inverse of this gap.
for (deltaMax = -Infinity, n = merged.length - 1, i = 0, a = merged[n]; i <= n; a = b, ++i) {
b = merged[i];
- if ((delta = angle(a[1], b[0])) > deltaMax) deltaMax = delta, lambda0$1 = b[0], lambda1 = a[1];
+ if ((delta = angle(a[1], b[0])) > deltaMax) { deltaMax = delta, lambda0$1 = b[0], lambda1 = a[1]; }
}
}
if (m < epsilon2) {
x = X1, y = Y1, z = Z1;
// If the feature has zero length, fall back to arithmetic mean of point vectors.
- if (W1 < epsilon) x = X0, y = Y0, z = Z0;
+ if (W1 < epsilon) { x = X0, y = Y0, z = Z0; }
m = x * x + y * y + z * z;
// If the feature still has an undefined ccentroid, then return.
- if (m < epsilon2) return [NaN, NaN];
+ if (m < epsilon2) { return [NaN, NaN]; }
}
return [atan2(y, x) * degrees, asin(z / sqrt(m)) * degrees];
return x = a(x, y), b(x[0], x[1]);
}
- if (a.invert && b.invert) compose.invert = function(x, y) {
+ if (a.invert && b.invert) { compose.invert = function(x, y) {
return x = b.invert(x, y), x && a.invert(x[0], x[1]);
- };
+ }; }
return compose;
}
// Generates a circle centered at [0°, 0°], with a given radius and precision.
function circleStream(stream, radius, delta, direction, t0, t1) {
- if (!delta) return;
+ if (!delta) { return; }
var cosRadius = cos(radius),
sinRadius = sin(radius),
step = direction * delta;
} else {
t0 = circleRadius(cosRadius, t0);
t1 = circleRadius(cosRadius, t1);
- if (direction > 0 ? t0 < t1 : t0 > t1) t0 += direction * tau;
+ if (direction > 0 ? t0 < t1 : t0 > t1) { t0 += direction * tau; }
}
for (var point, t = t0; direction > 0 ? t > t1 : t < t1; t -= step) {
point = spherical([cosRadius, -sinRadius * cos(t), -sinRadius * sin(t)]);
},
lineEnd: noop$2,
rejoin: function() {
- if (lines.length > 1) lines.push(lines.pop().concat(lines.shift()));
+ if (lines.length > 1) { lines.push(lines.pop().concat(lines.shift())); }
},
result: function() {
var result = lines;
n;
segments.forEach(function(segment) {
- if ((n = segment.length - 1) <= 0) return;
+ if ((n = segment.length - 1) <= 0) { return; }
var n, p0 = segment[0], p1 = segment[n], x;
if (pointEqual(p0, p1)) {
if (!p0[2] && !p1[2]) {
stream.lineStart();
- for (i = 0; i < n; ++i) stream.point((p0 = segment[i])[0], p0[1]);
+ for (i = 0; i < n; ++i) { stream.point((p0 = segment[i])[0], p0[1]); }
stream.lineEnd();
return;
}
clip.push(x.o = new Intersection(p1, null, x, true));
});
- if (!subject.length) return;
+ if (!subject.length) { return; }
clip.sort(compareIntersection);
link(subject);
// Find first unvisited intersection.
var current = start,
isSubject = true;
- while (current.v) if ((current = current.n) === start) return;
+ while (current.v) { if ((current = current.n) === start) { return; } }
points = current.z;
stream.lineStart();
do {
current.v = current.o.v = true;
if (current.e) {
if (isSubject) {
- for (i = 0, n = points.length; i < n; ++i) stream.point((point = points[i])[0], point[1]);
+ for (i = 0, n = points.length; i < n; ++i) { stream.point((point = points[i])[0], point[1]); }
} else {
interpolate(current.x, current.n.x, 1, stream);
}
} else {
if (isSubject) {
points = current.p.z;
- for (i = points.length - 1; i >= 0; --i) stream.point((point = points[i])[0], point[1]);
+ for (i = points.length - 1; i >= 0; --i) { stream.point((point = points[i])[0], point[1]); }
} else {
interpolate(current.x, current.p.x, -1, stream);
}
}
function link(array) {
- if (!(n = array.length)) return;
+ if (!(n = array.length)) { return; }
var n,
i = 0,
a = array[0],
function longitude(point) {
if (abs$2(point[0]) <= pi)
- return point[0];
+ { return point[0]; }
else
- return sign$2(point[0]) * ((abs$2(point[0]) + pi) % tau - pi);
+ { return sign$2(point[0]) * ((abs$2(point[0]) + pi) % tau - pi); }
}
function polygonContains(polygon, point) {
sum.reset();
- if (sinPhi === 1) phi = halfPi + epsilon;
- else if (sinPhi === -1) phi = -halfPi - epsilon;
+ if (sinPhi === 1) { phi = halfPi + epsilon; }
+ else if (sinPhi === -1) { phi = -halfPi - epsilon; }
for (var i = 0, n = polygon.length; i < n; ++i) {
- if (!(m = (ring = polygon[i]).length)) continue;
+ if (!(m = (ring = polygon[i]).length)) { continue; }
var ring,
m,
point0 = ring[m - 1],
}
function d3_bisector(compare) {
- if (compare.length === 1) compare = ascendingComparator(compare);
+ if (compare.length === 1) { compare = ascendingComparator(compare); }
return {
left: function(a, x, lo, hi) {
- if (lo == null) lo = 0;
- if (hi == null) hi = a.length;
+ if (lo == null) { lo = 0; }
+ if (hi == null) { hi = a.length; }
while (lo < hi) {
var mid = lo + hi >>> 1;
- if (compare(a[mid], x) < 0) lo = mid + 1;
- else hi = mid;
+ if (compare(a[mid], x) < 0) { lo = mid + 1; }
+ else { hi = mid; }
}
return lo;
},
right: function(a, x, lo, hi) {
- if (lo == null) lo = 0;
- if (hi == null) hi = a.length;
+ if (lo == null) { lo = 0; }
+ if (hi == null) { hi = a.length; }
while (lo < hi) {
var mid = lo + hi >>> 1;
- if (compare(a[mid], x) > 0) hi = mid;
- else lo = mid + 1;
+ if (compare(a[mid], x) > 0) { hi = mid; }
+ else { lo = mid + 1; }
}
return lo;
}
step;
stop = +stop, start = +start, count = +count;
- if (start === stop && count > 0) return [start];
- if (reverse = stop < start) n = start, start = stop, stop = n;
- if ((step = tickIncrement(start, stop, count)) === 0 || !isFinite(step)) return [];
+ if (start === stop && count > 0) { return [start]; }
+ if (reverse = stop < start) { n = start, start = stop, stop = n; }
+ if ((step = tickIncrement(start, stop, count)) === 0 || !isFinite(step)) { return []; }
if (step > 0) {
start = Math.ceil(start / step);
stop = Math.floor(stop / step);
ticks = new Array(n = Math.ceil(stop - start + 1));
- while (++i < n) ticks[i] = (start + i) * step;
+ while (++i < n) { ticks[i] = (start + i) * step; }
} else {
start = Math.floor(start * step);
stop = Math.ceil(stop * step);
ticks = new Array(n = Math.ceil(start - stop + 1));
- while (++i < n) ticks[i] = (start - i) / step;
+ while (++i < n) { ticks[i] = (start - i) / step; }
}
- if (reverse) ticks.reverse();
+ if (reverse) { ticks.reverse(); }
return ticks;
}
var step0 = Math.abs(stop - start) / Math.max(0, count),
step1 = Math.pow(10, Math.floor(Math.log(step0) / Math.LN10)),
error = step0 / step1;
- if (error >= e10) step1 *= 10;
- else if (error >= e5) step1 *= 5;
- else if (error >= e2) step1 *= 2;
+ if (error >= e10) { step1 *= 10; }
+ else if (error >= e5) { step1 *= 5; }
+ else if (error >= e2) { step1 *= 2; }
return stop < start ? -step1 : step1;
}
function threshold(values, p, valueof) {
- if (valueof == null) valueof = number;
- if (!(n = values.length)) return;
- if ((p = +p) <= 0 || n < 2) return +valueof(values[0], 0, values);
- if (p >= 1) return +valueof(values[n - 1], n - 1, values);
+ if (valueof == null) { valueof = number; }
+ if (!(n = values.length)) { return; }
+ if ((p = +p) <= 0 || n < 2) { return +valueof(values[0], 0, values); }
+ if (p >= 1) { return +valueof(values[n - 1], n - 1, values); }
var n,
i = (n - 1) * p,
i0 = Math.floor(i),
merged,
array;
- while (++i < n) j += arrays[i].length;
+ while (++i < n) { j += arrays[i].length; }
merged = new Array(j);
while (--n >= 0) {
segments = merge(segments);
var startInside = polygonContains(polygon, start);
if (segments.length) {
- if (!polygonStarted) sink.polygonStart(), polygonStarted = true;
+ if (!polygonStarted) { sink.polygonStart(), polygonStarted = true; }
clipRejoin(segments, compareIntersection, startInside, interpolate, sink);
} else if (startInside) {
- if (!polygonStarted) sink.polygonStart(), polygonStarted = true;
+ if (!polygonStarted) { sink.polygonStart(), polygonStarted = true; }
sink.lineStart();
interpolate(null, null, 1, sink);
sink.lineEnd();
}
- if (polygonStarted) sink.polygonEnd(), polygonStarted = false;
+ if (polygonStarted) { sink.polygonEnd(), polygonStarted = false; }
segments = polygon = null;
},
sphere: function() {
};
function point(lambda, phi) {
- if (pointVisible(lambda, phi)) sink.point(lambda, phi);
+ if (pointVisible(lambda, phi)) { sink.point(lambda, phi); }
}
function pointLine(lambda, phi) {
polygon.push(ring);
ring = null;
- if (!n) return;
+ if (!n) { return; }
// No intersections.
if (clean & 1) {
segment = ringSegments[0];
if ((m = segment.length - 1) > 0) {
- if (!polygonStarted) sink.polygonStart(), polygonStarted = true;
+ if (!polygonStarted) { sink.polygonStart(), polygonStarted = true; }
sink.lineStart();
- for (i = 0; i < m; ++i) sink.point((point = segment[i])[0], point[1]);
+ for (i = 0; i < m; ++i) { sink.point((point = segment[i])[0], point[1]); }
sink.lineEnd();
}
return;
// Rejoin connected segments.
// TODO reuse ringBuffer.rejoin()?
- if (n > 1 && clean & 2) ringSegments.push(ringSegments.pop().concat(ringSegments.shift()));
+ if (n > 1 && clean & 2) { ringSegments.push(ringSegments.pop().concat(ringSegments.shift())); }
segments.push(ringSegments.filter(validSegment));
}
stream.point(lambda1, phi0);
clean = 0;
} else if (sign0 !== sign1 && delta >= pi) { // line crosses antimeridian
- if (abs$2(lambda0 - sign0) < epsilon) lambda0 -= sign0 * epsilon; // handle degeneracies
- if (abs$2(lambda1 - sign1) < epsilon) lambda1 -= sign1 * epsilon;
+ if (abs$2(lambda0 - sign0) < epsilon) { lambda0 -= sign0 * epsilon; } // handle degeneracies
+ if (abs$2(lambda1 - sign1) < epsilon) { lambda1 -= sign1 * epsilon; }
phi0 = clipAntimeridianIntersect(lambda0, phi0, lambda1, phi1);
stream.point(sign0, phi0);
stream.lineEnd();
c = smallRadius
? v ? 0 : code(lambda, phi)
: v ? code(lambda + (lambda < 0 ? pi : -pi), phi) : 0;
- if (!point0 && (v00 = v0 = v)) stream.lineStart();
+ if (!point0 && (v00 = v0 = v)) { stream.lineStart(); }
if (v !== v0) {
point2 = intersect(point0, point1);
if (!point2 || pointEqual(point0, point2) || pointEqual(point1, point2))
- point1[2] = 1;
+ { point1[2] = 1; }
}
if (v !== v0) {
clean = 0;
point0 = point1, v0 = v, c0 = c;
},
lineEnd: function() {
- if (v0) stream.lineEnd();
+ if (v0) { stream.lineEnd(); }
point0 = null;
},
// Rejoin first and last segments if there were intersections and the first
determinant = n2n2 - n1n2 * n1n2;
// Two polar points.
- if (!determinant) return !two && a;
+ if (!determinant) { return !two && a; }
var c1 = cr * n2n2 / determinant,
c2 = -cr * n1n2 / determinant,
uu = cartesianDot(u, u),
t2 = w * w - uu * (cartesianDot(A, A) - 1);
- if (t2 < 0) return;
+ if (t2 < 0) { return; }
var t = sqrt(t2),
q = cartesianScale(u, (-w - t) / uu);
cartesianAddInPlace(q, A);
q = spherical(q);
- if (!two) return q;
+ if (!two) { return q; }
// Two intersection points.
var lambda0 = a[0],
phi1 = b[1],
z;
- if (lambda1 < lambda0) z = lambda0, lambda0 = lambda1, lambda1 = z;
+ if (lambda1 < lambda0) { z = lambda0, lambda0 = lambda1, lambda1 = z; }
var delta = lambda1 - lambda0,
polar = abs$2(delta - pi) < epsilon,
meridian = polar || delta < epsilon;
- if (!polar && phi1 < phi0) z = phi0, phi0 = phi1, phi1 = z;
+ if (!polar && phi1 < phi0) { z = phi0, phi0 = phi1, phi1 = z; }
// Check that the first point is between a and b.
if (meridian
function code(lambda, phi) {
var r = smallRadius ? radius : pi - radius,
code = 0;
- if (lambda < -r) code |= 1; // left
- else if (lambda > r) code |= 2; // right
- if (phi < -r) code |= 4; // below
- else if (phi > r) code |= 8; // above
+ if (lambda < -r) { code |= 1; } // left
+ else if (lambda > r) { code |= 2; } // right
+ if (phi < -r) { code |= 4; } // below
+ else if (phi > r) { code |= 8; } // above
return code;
}
r;
r = x0 - ax;
- if (!dx && r > 0) return;
+ if (!dx && r > 0) { return; }
r /= dx;
if (dx < 0) {
- if (r < t0) return;
- if (r < t1) t1 = r;
+ if (r < t0) { return; }
+ if (r < t1) { t1 = r; }
} else if (dx > 0) {
- if (r > t1) return;
- if (r > t0) t0 = r;
+ if (r > t1) { return; }
+ if (r > t0) { t0 = r; }
}
r = x1 - ax;
- if (!dx && r < 0) return;
+ if (!dx && r < 0) { return; }
r /= dx;
if (dx < 0) {
- if (r > t1) return;
- if (r > t0) t0 = r;
+ if (r > t1) { return; }
+ if (r > t0) { t0 = r; }
} else if (dx > 0) {
- if (r < t0) return;
- if (r < t1) t1 = r;
+ if (r < t0) { return; }
+ if (r < t1) { t1 = r; }
}
r = y0 - ay;
- if (!dy && r > 0) return;
+ if (!dy && r > 0) { return; }
r /= dy;
if (dy < 0) {
- if (r < t0) return;
- if (r < t1) t1 = r;
+ if (r < t0) { return; }
+ if (r < t1) { t1 = r; }
} else if (dy > 0) {
- if (r > t1) return;
- if (r > t0) t0 = r;
+ if (r > t1) { return; }
+ if (r > t0) { t0 = r; }
}
r = y1 - ay;
- if (!dy && r < 0) return;
+ if (!dy && r < 0) { return; }
r /= dy;
if (dy < 0) {
- if (r > t1) return;
- if (r > t0) t0 = r;
+ if (r > t1) { return; }
+ if (r > t0) { t0 = r; }
} else if (dy > 0) {
- if (r < t0) return;
- if (r < t1) t1 = r;
+ if (r < t0) { return; }
+ if (r < t1) { t1 = r; }
}
- if (t0 > 0) a[0] = ax + t0 * dx, a[1] = ay + t0 * dy;
- if (t1 < 1) b[0] = ax + t1 * dx, b[1] = ay + t1 * dy;
+ if (t0 > 0) { a[0] = ax + t0 * dx, a[1] = ay + t0 * dy; }
+ if (t1 < 1) { b[0] = ax + t1 * dx, b[1] = ay + t1 * dy; }
return true;
}
if (from == null
|| (a = corner(from, direction)) !== (a1 = corner(to, direction))
|| comparePoint(from, to) < 0 ^ direction > 0) {
- do stream.point(a === 0 || a === 3 ? x0 : x1, a > 1 ? y1 : y0);
+ do { stream.point(a === 0 || a === 3 ? x0 : x1, a > 1 ? y1 : y0); }
while ((a = (a + direction + 4) % 4) !== a1);
} else {
stream.point(to[0], to[1]);
};
function point(x, y) {
- if (visible(x, y)) activeStream.point(x, y);
+ if (visible(x, y)) { activeStream.point(x, y); }
}
function polygonInside() {
for (var i = 0, n = polygon.length; i < n; ++i) {
for (var ring = polygon[i], j = 1, m = ring.length, point = ring[0], a0, a1, b0 = point[0], b1 = point[1]; j < m; ++j) {
a0 = b0, a1 = b1, point = ring[j], b0 = point[0], b1 = point[1];
- if (a1 <= y1) { if (b1 > y1 && (b0 - a0) * (y1 - a1) > (b1 - a1) * (x0 - a0)) ++winding; }
- else { if (b1 <= y1 && (b0 - a0) * (y1 - a1) < (b1 - a1) * (x0 - a0)) --winding; }
+ if (a1 <= y1) { if (b1 > y1 && (b0 - a0) * (y1 - a1) > (b1 - a1) * (x0 - a0)) { ++winding; } }
+ else { if (b1 <= y1 && (b0 - a0) * (y1 - a1) < (b1 - a1) * (x0 - a0)) { --winding; } }
}
}
function lineStart() {
clipStream.point = linePoint;
- if (polygon) polygon.push(ring = []);
+ if (polygon) { polygon.push(ring = []); }
first = true;
v_ = false;
x_ = y_ = NaN;
function lineEnd() {
if (segments) {
linePoint(x__, y__);
- if (v__ && v_) bufferStream.rejoin();
+ if (v__ && v_) { bufferStream.rejoin(); }
segments.push(bufferStream.result());
}
clipStream.point = point;
- if (v_) activeStream.lineEnd();
+ if (v_) { activeStream.lineEnd(); }
}
function linePoint(x, y) {
var v = visible(x, y);
- if (polygon) ring.push([x, y]);
+ if (polygon) { ring.push([x, y]); }
if (first) {
x__ = x, y__ = y, v__ = v;
first = false;
activeStream.point(x, y);
}
} else {
- if (v && v_) activeStream.point(x, y);
+ if (v && v_) { activeStream.point(x, y); }
else {
var a = [x_ = Math.max(clipMin, Math.min(clipMax, x_)), y_ = Math.max(clipMin, Math.min(clipMax, y_))],
b = [x = Math.max(clipMin, Math.min(clipMax, x)), y = Math.max(clipMin, Math.min(clipMax, y))];
activeStream.point(a[0], a[1]);
}
activeStream.point(b[0], b[1]);
- if (!v) activeStream.lineEnd();
+ if (!v) { activeStream.lineEnd(); }
clean = false;
} else if (v) {
activeStream.lineStart();
};
function boundsPoint$1(x, y) {
- if (x < x0$2) x0$2 = x;
- if (x > x1) x1 = x;
- if (y < y0$2) y0$2 = y;
- if (y > y1) y1 = y;
+ if (x < x0$2) { x0$2 = x; }
+ if (x > x1) { x1 = x; }
+ if (y < y0$2) { y0$2 = y; }
+ if (y > y1) { y1 = y; }
}
// TODO Enforce positive area for exterior, negative area for interior?
this._point = 0;
},
lineEnd: function() {
- if (this._line === 0) this._context.closePath();
+ if (this._line === 0) { this._context.closePath(); }
this._point = NaN;
},
point: function(x, y) {
lengthStream$1.point = lengthPointFirst$1;
},
lineEnd: function() {
- if (lengthRing) lengthPoint$1(x00$2, y00$2);
+ if (lengthRing) { lengthPoint$1(x00$2, y00$2); }
lengthStream$1.point = noop$2;
},
polygonStart: function() {
_radius: 4.5,
_circle: circle(4.5),
pointRadius: function(_) {
- if ((_ = +_) !== this._radius) this._radius = _, this._circle = null;
+ if ((_ = +_) !== this._radius) { this._radius = _, this._circle = null; }
return this;
},
polygonStart: function() {
this._point = 0;
},
lineEnd: function() {
- if (this._line === 0) this._string.push("Z");
+ if (this._line === 0) { this._string.push("Z"); }
this._point = NaN;
},
point: function(x, y) {
break;
}
default: {
- if (this._circle == null) this._circle = circle(this._radius);
+ if (this._circle == null) { this._circle = circle(this._radius); }
this._string.push("M", x, ",", y, this._circle);
break;
}
function path(object) {
if (object) {
- if (typeof pointRadius === "function") contextStream.pointRadius(+pointRadius.apply(this, arguments));
+ if (typeof pointRadius === "function") { contextStream.pointRadius(+pointRadius.apply(this, arguments)); }
d3_geoStream(object, projectionStream(contextStream));
}
return contextStream.result();
};
path.context = function(_) {
- if (!arguments.length) return context;
+ if (!arguments.length) { return context; }
contextStream = _ == null ? (context = null, new PathString) : new PathContext(context = _);
- if (typeof pointRadius !== "function") contextStream.pointRadius(pointRadius);
+ if (typeof pointRadius !== "function") { contextStream.pointRadius(pointRadius); }
return path;
};
path.pointRadius = function(_) {
- if (!arguments.length) return pointRadius;
+ if (!arguments.length) { return pointRadius; }
pointRadius = typeof _ === "function" ? _ : (contextStream.pointRadius(+_), +_);
return path;
};
function transformer(methods) {
return function(stream) {
var s = new TransformStream;
- for (var key in methods) s[key] = methods[key];
+ for (var key in methods) { s[key] = methods[key]; }
s.stream = stream;
return s;
};
function fit(projection, fitBounds, object) {
var clip = projection.clipExtent && projection.clipExtent();
projection.scale(150).translate([0, 0]);
- if (clip != null) projection.clipExtent(null);
+ if (clip != null) { projection.clipExtent(null); }
d3_geoStream(object, projection.stream(boundsStream$1));
fitBounds(boundsStream$1.result());
- if (clip != null) projection.clipExtent(clip);
+ if (clip != null) { projection.clipExtent(clip); }
return projection;
}
extend: function(obj) {
- if (!(obj instanceof geoExtent)) obj = new geoExtent(obj);
+ if (!(obj instanceof geoExtent)) { obj = new geoExtent(obj); }
return geoExtent(
[Math.min(obj[0][0], this[0][0]), Math.min(obj[0][1], this[0][1])],
[Math.max(obj[1][0], this[1][0]), Math.max(obj[1][1], this[1][1])]
contains: function(obj) {
- if (!(obj instanceof geoExtent)) obj = new geoExtent(obj);
+ if (!(obj instanceof geoExtent)) { obj = new geoExtent(obj); }
return obj[0][0] >= this[0][0] &&
obj[0][1] >= this[0][1] &&
obj[1][0] <= this[1][0] &&
intersects: function(obj) {
- if (!(obj instanceof geoExtent)) obj = new geoExtent(obj);
+ if (!(obj instanceof geoExtent)) { obj = new geoExtent(obj); }
return obj[0][0] <= this[1][0] &&
obj[0][1] <= this[1][1] &&
obj[1][0] >= this[0][0] &&
intersection: function(obj) {
- if (!this.intersects(obj)) return new geoExtent();
+ if (!this.intersects(obj)) { return new geoExtent(); }
return new geoExtent(
[Math.max(obj[0][0], this[0][0]), Math.max(obj[0][1], this[0][1])],
[Math.min(obj[1][0], this[1][0]), Math.min(obj[1][1], this[1][1])]
percentContainedIn: function(obj) {
- if (!(obj instanceof geoExtent)) obj = new geoExtent(obj);
+ if (!(obj instanceof geoExtent)) { obj = new geoExtent(obj); }
var a1 = this.intersection(obj).area();
var a2 = this.area();
size = 2;
for (var i = 2; i < n; ++i) {
- while (size > 1 && cross(points[indexes[size - 2]], points[indexes[size - 1]], points[i]) <= 0) --size;
+ while (size > 1 && cross(points[indexes[size - 2]], points[indexes[size - 1]], points[i]) <= 0) { --size; }
indexes[size++] = i;
}
}
function d3_polygonHull(points) {
- if ((n = points.length) < 3) return null;
+ if ((n = points.length) < 3) { return null; }
var i,
n,
sortedPoints = new Array(n),
flippedPoints = new Array(n);
- for (i = 0; i < n; ++i) sortedPoints[i] = [+points[i][0], +points[i][1], i];
+ for (i = 0; i < n; ++i) { sortedPoints[i] = [+points[i][0], +points[i][1], i]; }
sortedPoints.sort(lexicographicOrder);
- for (i = 0; i < n; ++i) flippedPoints[i] = [sortedPoints[i][0], -sortedPoints[i][1]];
+ for (i = 0; i < n; ++i) { flippedPoints[i] = [sortedPoints[i][0], -sortedPoints[i][1]]; }
var upperIndexes = computeUpperHullIndexes(sortedPoints),
lowerIndexes = computeUpperHullIndexes(flippedPoints);
// Add upper hull in right-to-l order.
// Then add lower hull in left-to-right order.
- for (i = upperIndexes.length - 1; i >= 0; --i) hull.push(points[sortedPoints[upperIndexes[i]][2]]);
- for (i = +skipLeft; i < lowerIndexes.length - skipRight; ++i) hull.push(points[sortedPoints[lowerIndexes[i]][2]]);
+ for (i = upperIndexes.length - 1; i >= 0; --i) { hull.push(points[sortedPoints[upperIndexes[i]][2]]); }
+ for (i = +skipLeft; i < lowerIndexes.length - skipRight; ++i) { hull.push(points[sortedPoints[lowerIndexes[i]][2]]); }
return hull;
}
var loc;
for (var i = 0; i < points.length - 1; i++) {
- if (ids[i] === activeID || ids[i + 1] === activeID) continue;
+ if (ids[i] === activeID || ids[i + 1] === activeID) { continue; }
var o = points[i];
var s = geoVecSubtract(points[i + 1], o);
var intersect = ((yi > y) !== (yj > y)) &&
(x < (xj - xi) * (y - yi) / (yj - yi) + xi);
- if (intersect) inside = !inside;
+ if (intersect) { inside = !inside; }
}
return inside;
var y = 0;
if (point[0] > dimensions[0] - pad[1])
- x = -10;
+ { x = -10; }
if (point[0] < pad[3])
- x = 10;
+ { x = 10; }
if (point[1] > dimensions[1] - pad[2])
- y = -10;
+ { y = -10; }
if (point[1] < pad[0])
- y = 10;
+ { y = 10; }
if (x || y) {
return [x, y];
var noop$3 = {value: function() {}};
function dispatch() {
+ var arguments$1 = arguments;
+
for (var i = 0, n = arguments.length, _ = {}, t; i < n; ++i) {
- if (!(t = arguments[i] + "") || (t in _) || /[\s.]/.test(t)) throw new Error("illegal type: " + t);
+ if (!(t = arguments$1[i] + "") || (t in _) || /[\s.]/.test(t)) { throw new Error("illegal type: " + t); }
_[t] = [];
}
return new Dispatch(_);
function parseTypenames(typenames, types) {
return typenames.trim().split(/^|\s+/).map(function(t) {
var name = "", i = t.indexOf(".");
- if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);
- if (t && !types.hasOwnProperty(t)) throw new Error("unknown type: " + t);
+ if (i >= 0) { name = t.slice(i + 1), t = t.slice(0, i); }
+ if (t && !types.hasOwnProperty(t)) { throw new Error("unknown type: " + t); }
return {type: t, name: name};
});
}
// If no callback was specified, return the callback of the given type and name.
if (arguments.length < 2) {
- while (++i < n) if ((t = (typename = T[i]).type) && (t = get$1(_[t], typename.name))) return t;
+ while (++i < n) { if ((t = (typename = T[i]).type) && (t = get$1(_[t], typename.name))) { return t; } }
return;
}
// If a type was specified, set the callback for the given type and name.
// Otherwise, if a null callback was specified, remove callbacks of the given name.
- if (callback != null && typeof callback !== "function") throw new Error("invalid callback: " + callback);
+ if (callback != null && typeof callback !== "function") { throw new Error("invalid callback: " + callback); }
while (++i < n) {
- if (t = (typename = T[i]).type) _[t] = set(_[t], typename.name, callback);
- else if (callback == null) for (t in _) _[t] = set(_[t], typename.name, null);
+ if (t = (typename = T[i]).type) { _[t] = set(_[t], typename.name, callback); }
+ else if (callback == null) { for (t in _) { _[t] = set(_[t], typename.name, null); } }
}
return this;
},
copy: function() {
var copy = {}, _ = this._;
- for (var t in _) copy[t] = _[t].slice();
+ for (var t in _) { copy[t] = _[t].slice(); }
return new Dispatch(copy);
},
call: function(type, that) {
- if ((n = arguments.length - 2) > 0) for (var args = new Array(n), i = 0, n, t; i < n; ++i) args[i] = arguments[i + 2];
- if (!this._.hasOwnProperty(type)) throw new Error("unknown type: " + type);
- for (t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);
+ var arguments$1 = arguments;
+
+ if ((n = arguments.length - 2) > 0) { for (var args = new Array(n), i = 0, n, t; i < n; ++i) { args[i] = arguments$1[i + 2]; } }
+ if (!this._.hasOwnProperty(type)) { throw new Error("unknown type: " + type); }
+ for (t = this._[type], i = 0, n = t.length; i < n; ++i) { t[i].value.apply(that, args); }
},
apply: function(type, that, args) {
- if (!this._.hasOwnProperty(type)) throw new Error("unknown type: " + type);
- for (var t = this._[type], i = 0, n = t.length; i < n; ++i) t[i].value.apply(that, args);
+ if (!this._.hasOwnProperty(type)) { throw new Error("unknown type: " + type); }
+ for (var t = this._[type], i = 0, n = t.length; i < n; ++i) { t[i].value.apply(that, args); }
}
};
break;
}
}
- if (callback != null) type.push({name: name, value: callback});
+ if (callback != null) { type.push({name: name, value: callback}); }
return type;
}
function namespace(name) {
var prefix = name += "", i = prefix.indexOf(":");
- if (i >= 0 && (prefix = name.slice(0, i)) !== "xmlns") name = name.slice(i + 1);
+ if (i >= 0 && (prefix = name.slice(0, i)) !== "xmlns") { name = name.slice(i + 1); }
return namespaces.hasOwnProperty(prefix) ? {space: namespaces[prefix], local: name} : name;
}
}
function selection_select(select) {
- if (typeof select !== "function") select = selector(select);
+ if (typeof select !== "function") { select = selector(select); }
for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {
for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {
if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {
- if ("__data__" in node) subnode.__data__ = node.__data__;
+ if ("__data__" in node) { subnode.__data__ = node.__data__; }
subgroup[i] = subnode;
}
}
}
function selection_selectAll(select) {
- if (typeof select !== "function") select = selectorAll(select);
+ if (typeof select !== "function") { select = selectorAll(select); }
for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {
for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {
}
function selection_filter(match) {
- if (typeof match !== "function") match = matcher(match);
+ if (typeof match !== "function") { match = matcher(match); }
for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {
for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {
parents = this._parents,
groups = this._groups;
- if (typeof value !== "function") value = constant(value);
+ if (typeof value !== "function") { value = constant(value); }
for (var m = groups.length, update = new Array(m), enter = new Array(m), exit = new Array(m), j = 0; j < m; ++j) {
var parent = parents[j],
// rather than at the end of the parent node.
for (var i0 = 0, i1 = 0, previous, next; i0 < dataLength; ++i0) {
if (previous = enterGroup[i0]) {
- if (i0 >= i1) i1 = i0 + 1;
- while (!(next = updateGroup[i1]) && ++i1 < dataLength);
+ if (i0 >= i1) { i1 = i0 + 1; }
+ while (!(next = updateGroup[i1]) && ++i1 < dataLength){ }
previous._next = next || null;
}
}
function selection_join(onenter, onupdate, onexit) {
var enter = this.enter(), update = this, exit = this.exit();
enter = typeof onenter === "function" ? onenter(enter) : enter.append(onenter + "");
- if (onupdate != null) update = onupdate(update);
- if (onexit == null) exit.remove(); else onexit(exit);
+ if (onupdate != null) { update = onupdate(update); }
+ if (onexit == null) { exit.remove(); } else { onexit(exit); }
return enter && update ? enter.merge(update).order() : update;
}
for (var groups = this._groups, j = -1, m = groups.length; ++j < m;) {
for (var group = groups[j], i = group.length - 1, next = group[i], node; --i >= 0;) {
if (node = group[i]) {
- if (next && node.compareDocumentPosition(next) ^ 4) next.parentNode.insertBefore(node, next);
+ if (next && node.compareDocumentPosition(next) ^ 4) { next.parentNode.insertBefore(node, next); }
next = node;
}
}
}
function selection_sort(compare) {
- if (!compare) compare = ascending;
+ if (!compare) { compare = ascending; }
function compareNode(a, b) {
return a && b ? compare(a.__data__, b.__data__) : !a - !b;
for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {
for (var group = groups[j], i = 0, n = group.length; i < n; ++i) {
var node = group[i];
- if (node) return node;
+ if (node) { return node; }
}
}
for (var groups = this._groups, j = 0, m = groups.length; j < m; ++j) {
for (var group = groups[j], i = 0, n = group.length, node; i < n; ++i) {
- if (node = group[i]) callback.call(node, node.__data__, i, group);
+ if (node = group[i]) { callback.call(node, node.__data__, i, group); }
}
}
function attrFunction(name, value) {
return function() {
var v = value.apply(this, arguments);
- if (v == null) this.removeAttribute(name);
- else this.setAttribute(name, v);
+ if (v == null) { this.removeAttribute(name); }
+ else { this.setAttribute(name, v); }
};
}
function attrFunctionNS(fullname, value) {
return function() {
var v = value.apply(this, arguments);
- if (v == null) this.removeAttributeNS(fullname.space, fullname.local);
- else this.setAttributeNS(fullname.space, fullname.local, v);
+ if (v == null) { this.removeAttributeNS(fullname.space, fullname.local); }
+ else { this.setAttributeNS(fullname.space, fullname.local, v); }
};
}
function styleFunction(name, value, priority) {
return function() {
var v = value.apply(this, arguments);
- if (v == null) this.style.removeProperty(name);
- else this.style.setProperty(name, v, priority);
+ if (v == null) { this.style.removeProperty(name); }
+ else { this.style.setProperty(name, v, priority); }
};
}
function propertyFunction(name, value) {
return function() {
var v = value.apply(this, arguments);
- if (v == null) delete this[name];
- else this[name] = v;
+ if (v == null) { delete this[name]; }
+ else { this[name] = v; }
};
}
function classedAdd(node, names) {
var list = classList(node), i = -1, n = names.length;
- while (++i < n) list.add(names[i]);
+ while (++i < n) { list.add(names[i]); }
}
function classedRemove(node, names) {
var list = classList(node), i = -1, n = names.length;
- while (++i < n) list.remove(names[i]);
+ while (++i < n) { list.remove(names[i]); }
}
function classedTrue(names) {
if (arguments.length < 2) {
var list = classList(this.node()), i = -1, n = names.length;
- while (++i < n) if (!list.contains(names[i])) return false;
+ while (++i < n) { if (!list.contains(names[i])) { return false; } }
return true;
}
}
function raise() {
- if (this.nextSibling) this.parentNode.appendChild(this);
+ if (this.nextSibling) { this.parentNode.appendChild(this); }
}
function selection_raise() {
}
function lower() {
- if (this.previousSibling) this.parentNode.insertBefore(this, this.parentNode.firstChild);
+ if (this.previousSibling) { this.parentNode.insertBefore(this, this.parentNode.firstChild); }
}
function selection_lower() {
function remove() {
var parent = this.parentNode;
- if (parent) parent.removeChild(this);
+ if (parent) { parent.removeChild(this); }
}
function selection_remove() {
function parseTypenames$1(typenames) {
return typenames.trim().split(/^|\s+/).map(function(t) {
var name = "", i = t.indexOf(".");
- if (i >= 0) name = t.slice(i + 1), t = t.slice(0, i);
+ if (i >= 0) { name = t.slice(i + 1), t = t.slice(0, i); }
return {type: t, name: name};
});
}
function onRemove(typename) {
return function() {
var on = this.__on;
- if (!on) return;
+ if (!on) { return; }
for (var j = 0, i = -1, m = on.length, o; j < m; ++j) {
if (o = on[j], (!typename.type || o.type === typename.type) && o.name === typename.name) {
this.removeEventListener(o.type, o.listener, o.capture);
on[++i] = o;
}
}
- if (++i) on.length = i;
- else delete this.__on;
+ if (++i) { on.length = i; }
+ else { delete this.__on; }
};
}
var wrap = filterEvents.hasOwnProperty(typename.type) ? filterContextListener : contextListener;
return function(d, i, group) {
var on = this.__on, o, listener = wrap(value, i, group);
- if (on) for (var j = 0, m = on.length; j < m; ++j) {
+ if (on) { for (var j = 0, m = on.length; j < m; ++j) {
if ((o = on[j]).type === typename.type && o.name === typename.name) {
this.removeEventListener(o.type, o.listener, o.capture);
this.addEventListener(o.type, o.listener = listener, o.capture = capture);
o.value = value;
return;
}
- }
+ } }
this.addEventListener(typename.type, listener, capture);
o = {type: typename.type, name: typename.name, value: value, listener: listener, capture: capture};
- if (!on) this.__on = [o];
- else on.push(o);
+ if (!on) { this.__on = [o]; }
+ else { on.push(o); }
};
}
if (arguments.length < 2) {
var on = this.node().__on;
- if (on) for (var j = 0, m = on.length, o; j < m; ++j) {
+ if (on) { for (var j = 0, m = on.length, o; j < m; ++j) {
for (i = 0, o = on[j]; i < n; ++i) {
if ((t = typenames[i]).type === o.type && t.name === o.name) {
return o.value;
}
}
- }
+ } }
return;
}
on = value ? onAdd : onRemove;
- if (capture == null) capture = false;
- for (i = 0; i < n; ++i) this.each(on(typenames[i], value, capture));
+ if (capture == null) { capture = false; }
+ for (i = 0; i < n; ++i) { this.each(on(typenames[i], value, capture)); }
return this;
}
event = new event(type, params);
} else {
event = window.document.createEvent("Event");
- if (params) event.initEvent(type, params.bubbles, params.cancelable), event.detail = params.detail;
- else event.initEvent(type, false, false);
+ if (params) { event.initEvent(type, params.bubbles, params.cancelable), event.detail = params.detail; }
+ else { event.initEvent(type, false, false); }
}
node.dispatchEvent(event);
function sourceEvent() {
var current = event, source;
- while (source = current.sourceEvent) current = source;
+ while (source = current.sourceEvent) { current = source; }
return current;
}
function mouse(node) {
var event = sourceEvent();
- if (event.changedTouches) event = event.changedTouches[0];
+ if (event.changedTouches) { event = event.changedTouches[0]; }
return point(node, event);
}
}
function touch(node, touches, identifier) {
- if (arguments.length < 3) identifier = touches, touches = sourceEvent().changedTouches;
+ if (arguments.length < 3) { identifier = touches, touches = sourceEvent().changedTouches; }
for (var i = 0, n = touches ? touches.length : 0, touch; i < n; ++i) {
if ((touch = touches[i]).identifier === identifier) {
}
function mousedowned() {
- if (touchending || !filter.apply(this, arguments)) return;
+ if (touchending || !filter.apply(this, arguments)) { return; }
var gesture = beforestart("mouse", container.apply(this, arguments), mouse, this, arguments);
- if (!gesture) return;
+ if (!gesture) { return; }
select(event.view).on("mousemove.drag", mousemoved, true).on("mouseup.drag", mouseupped, true);
dragDisable(event.view);
nopropagation();
}
function touchstarted() {
- if (!filter.apply(this, arguments)) return;
+ var arguments$1 = arguments;
+
+ if (!filter.apply(this, arguments)) { return; }
var touches = event.changedTouches,
c = container.apply(this, arguments),
n = touches.length, i, gesture;
for (i = 0; i < n; ++i) {
- if (gesture = beforestart(touches[i].identifier, c, touch, this, arguments)) {
+ if (gesture = beforestart(touches[i].identifier, c, touch, this, arguments$1)) {
nopropagation();
gesture("start");
}
var touches = event.changedTouches,
n = touches.length, i, gesture;
- if (touchending) clearTimeout(touchending);
+ if (touchending) { clearTimeout(touchending); }
touchending = setTimeout(function() { touchending = null; }, 500); // Ghost clicks are delayed!
for (i = 0; i < n; ++i) {
if (gesture = gestures[touches[i].identifier]) {
sublisteners = listeners.copy();
if (!customEvent(new DragEvent(drag, "beforestart", s, id, active, p[0], p[1], 0, 0, sublisteners), function() {
- if ((event.subject = s = subject.apply(that, args)) == null) return false;
+ if ((event.subject = s = subject.apply(that, args)) == null) { return false; }
dx = s.x - p[0] || 0;
dy = s.y - p[1] || 0;
return true;
- })) return;
+ })) { return; }
return function gesture(type) {
var p0 = p, n;
function extend(parent, definition) {
var prototype = Object.create(parent.prototype);
- for (var key in definition) prototype[key] = definition[key];
+ for (var key in definition) { prototype[key] = definition[key]; }
return prototype;
}
}
function rgba(r, g, b, a) {
- if (a <= 0) r = g = b = NaN;
+ if (a <= 0) { r = g = b = NaN; }
return new Rgb(r, g, b, a);
}
function rgbConvert(o) {
- if (!(o instanceof Color)) o = color(o);
- if (!o) return new Rgb;
+ if (!(o instanceof Color)) { o = color(o); }
+ if (!o) { return new Rgb; }
o = o.rgb();
return new Rgb(o.r, o.g, o.b, o.opacity);
}
}
function hsla(h, s, l, a) {
- if (a <= 0) h = s = l = NaN;
- else if (l <= 0 || l >= 1) h = s = NaN;
- else if (s <= 0) h = NaN;
+ if (a <= 0) { h = s = l = NaN; }
+ else if (l <= 0 || l >= 1) { h = s = NaN; }
+ else if (s <= 0) { h = NaN; }
return new Hsl(h, s, l, a);
}
function hslConvert(o) {
- if (o instanceof Hsl) return new Hsl(o.h, o.s, o.l, o.opacity);
- if (!(o instanceof Color)) o = color(o);
- if (!o) return new Hsl;
- if (o instanceof Hsl) return o;
+ if (o instanceof Hsl) { return new Hsl(o.h, o.s, o.l, o.opacity); }
+ if (!(o instanceof Color)) { o = color(o); }
+ if (!o) { return new Hsl; }
+ if (o instanceof Hsl) { return o; }
o = o.rgb();
var r = o.r / 255,
g = o.g / 255,
s = max - min,
l = (max + min) / 2;
if (s) {
- if (r === max) h = (g - b) / s + (g < b) * 6;
- else if (g === max) h = (b - r) / s + 2;
- else h = (r - g) / s + 4;
+ if (r === max) { h = (g - b) / s + (g < b) * 6; }
+ else if (g === max) { h = (b - r) / s + 2; }
+ else { h = (r - g) / s + 4; }
s /= l < 0.5 ? max + min : 2 - max - min;
h *= 60;
} else {
})(1);
function numberArray(a, b) {
- if (!b) b = [];
+ if (!b) { b = []; }
var n = a ? Math.min(b.length, a.length) : 0,
c = b.slice(),
i;
return function(t) {
- for (i = 0; i < n; ++i) c[i] = a[i] * (1 - t) + b[i] * t;
+ for (i = 0; i < n; ++i) { c[i] = a[i] * (1 - t) + b[i] * t; }
return c;
};
}
c = new Array(nb),
i;
- for (i = 0; i < na; ++i) x[i] = interpolate(a[i], b[i]);
- for (; i < nb; ++i) c[i] = b[i];
+ for (i = 0; i < na; ++i) { x[i] = interpolate(a[i], b[i]); }
+ for (; i < nb; ++i) { c[i] = b[i]; }
return function(t) {
- for (i = 0; i < na; ++i) c[i] = x[i](t);
+ for (i = 0; i < na; ++i) { c[i] = x[i](t); }
return c;
};
}
c = {},
k;
- if (a === null || typeof a !== "object") a = {};
- if (b === null || typeof b !== "object") b = {};
+ if (a === null || typeof a !== "object") { a = {}; }
+ if (b === null || typeof b !== "object") { b = {}; }
for (k in b) {
if (k in a) {
}
return function(t) {
- for (k in i) c[k] = i[k](t);
+ for (k in i) { c[k] = i[k](t); }
return c;
};
}
&& (bm = reB.exec(b))) {
if ((bs = bm.index) > bi) { // a string precedes the next number in b
bs = b.slice(bi, bs);
- if (s[i]) s[i] += bs; // coalesce with previous string
- else s[++i] = bs;
+ if (s[i]) { s[i] += bs; } // coalesce with previous string
+ else { s[++i] = bs; }
}
if ((am = am[0]) === (bm = bm[0])) { // numbers in a & b match
- if (s[i]) s[i] += bm; // coalesce with previous string
- else s[++i] = bm;
+ if (s[i]) { s[i] += bm; } // coalesce with previous string
+ else { s[++i] = bm; }
} else { // interpolate non-matching numbers
s[++i] = null;
q.push({i: i, x: d3_interpolateNumber(am, bm)});
// Add remains of b.
if (bi < b.length) {
bs = b.slice(bi);
- if (s[i]) s[i] += bs; // coalesce with previous string
- else s[++i] = bs;
+ if (s[i]) { s[i] += bs; } // coalesce with previous string
+ else { s[++i] = bs; }
}
// Special optimization for only a single match.
? one(q[0].x)
: zero(b))
: (b = q.length, function(t) {
- for (var i = 0, o; i < b; ++i) s[(o = q[i]).i] = o.x(t);
+ for (var i = 0, o; i < b; ++i) { s[(o = q[i]).i] = o.x(t); }
return s.join("");
});
}
function decompose(a, b, c, d, e, f) {
var scaleX, scaleY, skewX;
- if (scaleX = Math.sqrt(a * a + b * b)) a /= scaleX, b /= scaleX;
- if (skewX = a * c + b * d) c -= a * skewX, d -= b * skewX;
- if (scaleY = Math.sqrt(c * c + d * d)) c /= scaleY, d /= scaleY, skewX /= scaleY;
- if (a * d < b * c) a = -a, b = -b, skewX = -skewX, scaleX = -scaleX;
+ if (scaleX = Math.sqrt(a * a + b * b)) { a /= scaleX, b /= scaleX; }
+ if (skewX = a * c + b * d) { c -= a * skewX, d -= b * skewX; }
+ if (scaleY = Math.sqrt(c * c + d * d)) { c /= scaleY, d /= scaleY, skewX /= scaleY; }
+ if (a * d < b * c) { a = -a, b = -b, skewX = -skewX, scaleX = -scaleX; }
return {
translateX: e,
translateY: f,
svgNode;
function parseCss(value) {
- if (value === "none") return identity$1;
- if (!cssNode) cssNode = document.createElement("DIV"), cssRoot = document.documentElement, cssView = document.defaultView;
+ if (value === "none") { return identity$1; }
+ if (!cssNode) { cssNode = document.createElement("DIV"), cssRoot = document.documentElement, cssView = document.defaultView; }
cssNode.style.transform = value;
value = cssView.getComputedStyle(cssRoot.appendChild(cssNode), null).getPropertyValue("transform");
cssRoot.removeChild(cssNode);
}
function parseSvg(value) {
- if (value == null) return identity$1;
- if (!svgNode) svgNode = document.createElementNS("http://www.w3.org/2000/svg", "g");
+ if (value == null) { return identity$1; }
+ if (!svgNode) { svgNode = document.createElementNS("http://www.w3.org/2000/svg", "g"); }
svgNode.setAttribute("transform", value);
- if (!(value = svgNode.transform.baseVal.consolidate())) return identity$1;
+ if (!(value = svgNode.transform.baseVal.consolidate())) { return identity$1; }
value = value.matrix;
return decompose(value.a, value.b, value.c, value.d, value.e, value.f);
}
function rotate(a, b, s, q) {
if (a !== b) {
- if (a - b > 180) b += 360; else if (b - a > 180) a += 360; // shortest path
+ if (a - b > 180) { b += 360; } else if (b - a > 180) { a += 360; } // shortest path
q.push({i: s.push(pop(s) + "rotate(", null, degParen) - 2, x: d3_interpolateNumber(a, b)});
} else if (b) {
s.push(pop(s) + "rotate(" + b + degParen);
a = b = null; // gc
return function(t) {
var i = -1, n = q.length, o;
- while (++i < n) s[(o = q[i]).i] = o.x(t);
+ while (++i < n) { s[(o = q[i]).i] = o.x(t); }
return s.join("");
};
};
function d3_quantize(interpolator, n) {
var samples = new Array(n);
- for (var i = 0; i < n; ++i) samples[i] = interpolator(i / (n - 1));
+ for (var i = 0; i < n; ++i) { samples[i] = interpolator(i / (n - 1)); }
return samples;
}
Timer.prototype = timer.prototype = {
constructor: Timer,
restart: function(callback, delay, time) {
- if (typeof callback !== "function") throw new TypeError("callback is not a function");
+ if (typeof callback !== "function") { throw new TypeError("callback is not a function"); }
time = (time == null ? now() : +time) + (delay == null ? 0 : +delay);
if (!this._next && taskTail !== this) {
- if (taskTail) taskTail._next = this;
- else taskHead = this;
+ if (taskTail) { taskTail._next = this; }
+ else { taskHead = this; }
taskTail = this;
}
this._call = callback;
++frame; // Pretend we’ve set an alarm, if we haven’t already.
var t = taskHead, e;
while (t) {
- if ((e = clockNow - t._time) >= 0) t._call.call(null, e);
+ if ((e = clockNow - t._time) >= 0) { t._call.call(null, e); }
t = t._next;
}
--frame;
function poke() {
var now = clock.now(), delay = now - clockLast;
- if (delay > pokeDelay) clockSkew -= delay, clockLast = now;
+ if (delay > pokeDelay) { clockSkew -= delay, clockLast = now; }
}
function nap() {
var t0, t1 = taskHead, t2, time = Infinity;
while (t1) {
if (t1._call) {
- if (time > t1._time) time = t1._time;
+ if (time > t1._time) { time = t1._time; }
t0 = t1, t1 = t1._next;
} else {
t2 = t1._next, t1._next = null;
}
function sleep(time) {
- if (frame) return; // Soonest alarm already set, or will be.
- if (timeout) timeout = clearTimeout(timeout);
+ if (frame) { return; } // Soonest alarm already set, or will be.
+ if (timeout) { timeout = clearTimeout(timeout); }
var delay = time - clockNow; // Strictly less than if we recomputed clockNow.
if (delay > 24) {
- if (time < Infinity) timeout = setTimeout(wake, time - clock.now() - clockSkew);
- if (interval) interval = clearInterval(interval);
+ if (time < Infinity) { timeout = setTimeout(wake, time - clock.now() - clockSkew); }
+ if (interval) { interval = clearInterval(interval); }
} else {
- if (!interval) clockLast = clock.now(), interval = setInterval(poke, pokeDelay);
+ if (!interval) { clockLast = clock.now(), interval = setInterval(poke, pokeDelay); }
frame = 1, setFrame(wake);
}
}
function schedule(node, name, id, index, group, timing) {
var schedules = node.__transition;
- if (!schedules) node.__transition = {};
- else if (id in schedules) return;
+ if (!schedules) { node.__transition = {}; }
+ else if (id in schedules) { return; }
create$7(node, id, {
name: name,
index: index, // For context during callback.
function init(node, id) {
var schedule = get$2(node, id);
- if (schedule.state > CREATED) throw new Error("too late; already scheduled");
+ if (schedule.state > CREATED) { throw new Error("too late; already scheduled"); }
return schedule;
}
function set$1(node, id) {
var schedule = get$2(node, id);
- if (schedule.state > STARTED) throw new Error("too late; already running");
+ if (schedule.state > STARTED) { throw new Error("too late; already running"); }
return schedule;
}
function get$2(node, id) {
var schedule = node.__transition;
- if (!schedule || !(schedule = schedule[id])) throw new Error("transition not found");
+ if (!schedule || !(schedule = schedule[id])) { throw new Error("transition not found"); }
return schedule;
}
self.timer.restart(start, self.delay, self.time);
// If the elapsed delay is less than our first sleep, start immediately.
- if (self.delay <= elapsed) start(elapsed - self.delay);
+ if (self.delay <= elapsed) { start(elapsed - self.delay); }
}
function start(elapsed) {
var i, j, n, o;
// If the state is not SCHEDULED, then we previously errored on start.
- if (self.state !== SCHEDULED) return stop();
+ if (self.state !== SCHEDULED) { return stop(); }
for (i in schedules) {
o = schedules[i];
- if (o.name !== self.name) continue;
+ if (o.name !== self.name) { continue; }
// While this element already has a starting transition during this frame,
// defer starting an interrupting transition until that transition has a
// chance to tick (and possibly end); see d3/d3-transition#54!
- if (o.state === STARTED) return d3_timeout(start);
+ if (o.state === STARTED) { return d3_timeout(start); }
// Interrupt the active transition, if any.
if (o.state === RUNNING) {
// Note this must be done before the tween are initialized.
self.state = STARTING;
self.on.call("start", node, node.__data__, self.index, self.group);
- if (self.state !== STARTING) return; // interrupted
+ if (self.state !== STARTING) { return; } // interrupted
self.state = STARTED;
// Initialize the tween, deleting null tween.
self.state = ENDED;
self.timer.stop();
delete schedules[id];
- for (var i in schedules) return; // eslint-disable-line no-unused-vars
+ for (var i in schedules) { return; } // eslint-disable-line no-unused-vars
delete node.__transition;
}
}
empty = true,
i;
- if (!schedules) return;
+ if (!schedules) { return; }
name = name == null ? null : name + "";
delete schedules[i];
}
- if (empty) delete node.__transition;
+ if (empty) { delete node.__transition; }
}
function selection_interrupt(name) {
function tweenFunction(id, name, value) {
var tween0, tween1;
- if (typeof value !== "function") throw new Error;
+ if (typeof value !== "function") { throw new Error; }
return function() {
var schedule = set$1(this, id),
tween = schedule.tween;
break;
}
}
- if (i === n) tween1.push(t);
+ if (i === n) { tween1.push(t); }
}
schedule.tween = tween1;
interpolate0;
return function() {
var string0, value1 = value(this), string1;
- if (value1 == null) return void this.removeAttribute(name);
+ if (value1 == null) { return void this.removeAttribute(name); }
string0 = this.getAttribute(name);
string1 = value1 + "";
return string0 === string1 ? null
interpolate0;
return function() {
var string0, value1 = value(this), string1;
- if (value1 == null) return void this.removeAttributeNS(fullname.space, fullname.local);
+ if (value1 == null) { return void this.removeAttributeNS(fullname.space, fullname.local); }
string0 = this.getAttributeNS(fullname.space, fullname.local);
string1 = value1 + "";
return string0 === string1 ? null
var t0, i0;
function tween() {
var i = value.apply(this, arguments);
- if (i !== i0) t0 = (i0 = i) && attrInterpolateNS(fullname, i);
+ if (i !== i0) { t0 = (i0 = i) && attrInterpolateNS(fullname, i); }
return t0;
}
tween._value = value;
var t0, i0;
function tween() {
var i = value.apply(this, arguments);
- if (i !== i0) t0 = (i0 = i) && attrInterpolate(name, i);
+ if (i !== i0) { t0 = (i0 = i) && attrInterpolate(name, i); }
return t0;
}
tween._value = value;
function transition_attrTween(name, value) {
var key = "attr." + name;
- if (arguments.length < 2) return (key = this.tween(key)) && key._value;
- if (value == null) return this.tween(key, null);
- if (typeof value !== "function") throw new Error;
+ if (arguments.length < 2) { return (key = this.tween(key)) && key._value; }
+ if (value == null) { return this.tween(key, null); }
+ if (typeof value !== "function") { throw new Error; }
var fullname = namespace(name);
return this.tween(key, (fullname.local ? attrTweenNS : attrTween)(fullname, value));
}
}
function easeConstant(id, value) {
- if (typeof value !== "function") throw new Error;
+ if (typeof value !== "function") { throw new Error; }
return function() {
set$1(this, id).ease = value;
};
}
function transition_filter(match) {
- if (typeof match !== "function") match = matcher(match);
+ if (typeof match !== "function") { match = matcher(match); }
for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {
for (var group = groups[j], n = group.length, subgroup = subgroups[j] = [], node, i = 0; i < n; ++i) {
}
function transition_merge(transition) {
- if (transition._id !== this._id) throw new Error;
+ if (transition._id !== this._id) { throw new Error; }
for (var groups0 = this._groups, groups1 = transition._groups, m0 = groups0.length, m1 = groups1.length, m = Math.min(m0, m1), merges = new Array(m0), j = 0; j < m; ++j) {
for (var group0 = groups0[j], group1 = groups1[j], n = group0.length, merge = merges[j] = new Array(n), node, i = 0; i < n; ++i) {
function start(name) {
return (name + "").trim().split(/^|\s+/).every(function(t) {
var i = t.indexOf(".");
- if (i >= 0) t = t.slice(0, i);
+ if (i >= 0) { t = t.slice(0, i); }
return !t || t === "start";
});
}
// If this node shared a dispatch with the previous node,
// just assign the updated shared dispatch and we’re done!
// Otherwise, copy-on-write.
- if (on !== on0) (on1 = (on0 = on).copy()).on(name, listener);
+ if (on !== on0) { (on1 = (on0 = on).copy()).on(name, listener); }
schedule.on = on1;
};
function removeFunction(id) {
return function() {
var parent = this.parentNode;
- for (var i in this.__transition) if (+i !== id) return;
- if (parent) parent.removeChild(this);
+ for (var i in this.__transition) { if (+i !== id) { return; } }
+ if (parent) { parent.removeChild(this); }
};
}
var name = this._name,
id = this._id;
- if (typeof select !== "function") select = selector(select);
+ if (typeof select !== "function") { select = selector(select); }
for (var groups = this._groups, m = groups.length, subgroups = new Array(m), j = 0; j < m; ++j) {
for (var group = groups[j], n = group.length, subgroup = subgroups[j] = new Array(n), node, subnode, i = 0; i < n; ++i) {
if ((node = group[i]) && (subnode = select.call(node, node.__data__, i, group))) {
- if ("__data__" in node) subnode.__data__ = node.__data__;
+ if ("__data__" in node) { subnode.__data__ = node.__data__; }
subgroup[i] = subnode;
schedule(subgroup[i], name, id, i, subgroup, get$2(node, id));
}
var name = this._name,
id = this._id;
- if (typeof select !== "function") select = selectorAll(select);
+ if (typeof select !== "function") { select = selectorAll(select); }
for (var groups = this._groups, m = groups.length, subgroups = [], parents = [], j = 0; j < m; ++j) {
for (var group = groups[j], n = group.length, node, i = 0; i < n; ++i) {
var string0 = styleValue(this, name),
value1 = value(this),
string1 = value1 + "";
- if (value1 == null) string1 = value1 = (this.style.removeProperty(name), styleValue(this, name));
+ if (value1 == null) { string1 = value1 = (this.style.removeProperty(name), styleValue(this, name)); }
return string0 === string1 ? null
: string0 === string00 && string1 === string10 ? interpolate0
: (string10 = string1, interpolate0 = interpolate(string00 = string0, value1));
// If this node shared a dispatch with the previous node,
// just assign the updated shared dispatch and we’re done!
// Otherwise, copy-on-write.
- if (on !== on0 || listener0 !== listener) (on1 = (on0 = on).copy()).on(event, listener0 = listener);
+ if (on !== on0 || listener0 !== listener) { (on1 = (on0 = on).copy()).on(event, listener0 = listener); }
schedule.on = on1;
};
var t, i0;
function tween() {
var i = value.apply(this, arguments);
- if (i !== i0) t = (i0 = i) && styleInterpolate(name, i, priority);
+ if (i !== i0) { t = (i0 = i) && styleInterpolate(name, i, priority); }
return t;
}
tween._value = value;
function transition_styleTween(name, value, priority) {
var key = "style." + (name += "");
- if (arguments.length < 2) return (key = this.tween(key)) && key._value;
- if (value == null) return this.tween(key, null);
- if (typeof value !== "function") throw new Error;
+ if (arguments.length < 2) { return (key = this.tween(key)) && key._value; }
+ if (value == null) { return this.tween(key, null); }
+ if (typeof value !== "function") { throw new Error; }
return this.tween(key, styleTween(name, value, priority == null ? "" : priority));
}
var t0, i0;
function tween() {
var i = value.apply(this, arguments);
- if (i !== i0) t0 = (i0 = i) && textInterpolate(i);
+ if (i !== i0) { t0 = (i0 = i) && textInterpolate(i); }
return t0;
}
tween._value = value;
function transition_textTween(value) {
var key = "text";
- if (arguments.length < 1) return (key = this.tween(key)) && key._value;
- if (value == null) return this.tween(key, null);
- if (typeof value !== "function") throw new Error;
+ if (arguments.length < 1) { return (key = this.tween(key)) && key._value; }
+ if (value == null) { return this.tween(key, null); }
+ if (typeof value !== "function") { throw new Error; }
return this.tween(key, textTween(value));
}
var on0, on1, that = this, id = that._id, size = that.size();
return new Promise(function(resolve, reject) {
var cancel = {value: reject},
- end = {value: function() { if (--size === 0) resolve(); }};
+ end = {value: function() { if (--size === 0) { resolve(); } }};
that.each(function() {
var schedule = set$1(this, id),
b = typeof transform === "function" ? transform.apply(that, args) : transform,
i = interpolate(a.invert(p).concat(w / a.k), b.invert(p).concat(w / b.k));
return function(t) {
- if (t === 1) t = b; // Avoid rounding error on end.
+ if (t === 1) { t = b; } // Avoid rounding error on end.
else { var l = i(t), k = w / l[2]; t = new Transform(k, p[0] - l[0] * k, p[1] - l[1] * k); }
g.zoom(null, t);
};
return this;
},
zoom: function(key, transform) {
- if (this.mouse && key !== "mouse") this.mouse[1] = transform.invert(this.mouse[0]);
- if (this.touch0 && key !== "touch") this.touch0[1] = transform.invert(this.touch0[0]);
- if (this.touch1 && key !== "touch") this.touch1[1] = transform.invert(this.touch1[0]);
+ if (this.mouse && key !== "mouse") { this.mouse[1] = transform.invert(this.mouse[0]); }
+ if (this.touch0 && key !== "touch") { this.touch0[1] = transform.invert(this.touch0[0]); }
+ if (this.touch1 && key !== "touch") { this.touch1[1] = transform.invert(this.touch1[0]); }
this.that.__zoom = transform;
this.emit("zoom");
return this;
};
function wheeled() {
- if (!filter.apply(this, arguments)) return;
+ if (!filter.apply(this, arguments)) { return; }
var g = gesture(this, arguments),
t = this.__zoom,
k = Math.max(scaleExtent[0], Math.min(scaleExtent[1], t.k * Math.pow(2, wheelDelta.apply(this, arguments)))),
}
// If this wheel event won’t trigger a transform change, ignore it.
- else if (t.k === k) return;
+ else if (t.k === k) { return; }
// Otherwise, capture the mouse point and location at the start.
else {
}
function mousedowned() {
- if (touchending || !filter.apply(this, arguments)) return;
+ if (touchending || !filter.apply(this, arguments)) { return; }
var g = gesture(this, arguments, true),
v = select(event.view).on("mousemove.zoom", mousemoved, true).on("mouseup.zoom", mouseupped, true),
p = mouse(this),
}
function dblclicked() {
- if (!filter.apply(this, arguments)) return;
+ if (!filter.apply(this, arguments)) { return; }
var t0 = this.__zoom,
p0 = mouse(this),
p1 = t0.invert(p0),
t1 = constrain(translate(scale(t0, k1), p0, p1), extent.apply(this, arguments), translateExtent);
noevent$1();
- if (duration > 0) select(this).transition().duration(duration).call(schedule, t1, p0);
- else select(this).call(zoom.transform, t1);
+ if (duration > 0) { select(this).transition().duration(duration).call(schedule, t1, p0); }
+ else { select(this).call(zoom.transform, t1); }
}
function touchstarted() {
- if (!filter.apply(this, arguments)) return;
+ if (!filter.apply(this, arguments)) { return; }
var touches = event.touches,
n = touches.length,
g = gesture(this, arguments, event.changedTouches.length === n),
for (i = 0; i < n; ++i) {
t = touches[i], p = touch(this, touches, t.identifier);
p = [p, this.__zoom.invert(p), t.identifier];
- if (!g.touch0) g.touch0 = p, started = true, g.taps = 1 + !!touchstarting;
- else if (!g.touch1 && g.touch0[2] !== p[2]) g.touch1 = p, g.taps = 0;
+ if (!g.touch0) { g.touch0 = p, started = true, g.taps = 1 + !!touchstarting; }
+ else if (!g.touch1 && g.touch0[2] !== p[2]) { g.touch1 = p, g.taps = 0; }
}
- if (touchstarting) touchstarting = clearTimeout(touchstarting);
+ if (touchstarting) { touchstarting = clearTimeout(touchstarting); }
if (started) {
- if (g.taps < 2) touchstarting = setTimeout(function() { touchstarting = null; }, touchDelay);
+ if (g.taps < 2) { touchstarting = setTimeout(function() { touchstarting = null; }, touchDelay); }
interrupt(this);
g.start();
}
}
function touchmoved() {
- if (!this.__zooming) return;
+ if (!this.__zooming) { return; }
var g = gesture(this, arguments),
touches = event.changedTouches,
n = touches.length, i, t, p, l;
noevent$1();
- if (touchstarting) touchstarting = clearTimeout(touchstarting);
+ if (touchstarting) { touchstarting = clearTimeout(touchstarting); }
g.taps = 0;
for (i = 0; i < n; ++i) {
t = touches[i], p = touch(this, touches, t.identifier);
- if (g.touch0 && g.touch0[2] === t.identifier) g.touch0[0] = p;
- else if (g.touch1 && g.touch1[2] === t.identifier) g.touch1[0] = p;
+ if (g.touch0 && g.touch0[2] === t.identifier) { g.touch0[0] = p; }
+ else if (g.touch1 && g.touch1[2] === t.identifier) { g.touch1[0] = p; }
}
t = g.that.__zoom;
if (g.touch1) {
p = [(p0[0] + p1[0]) / 2, (p0[1] + p1[1]) / 2];
l = [(l0[0] + l1[0]) / 2, (l0[1] + l1[1]) / 2];
}
- else if (g.touch0) p = g.touch0[0], l = g.touch0[1];
- else return;
+ else if (g.touch0) { p = g.touch0[0], l = g.touch0[1]; }
+ else { return; }
g.zoom("touch", constrain(translate(t, p, l), g.extent, translateExtent));
}
function touchended() {
- if (!this.__zooming) return;
+ if (!this.__zooming) { return; }
var g = gesture(this, arguments),
touches = event.changedTouches,
n = touches.length, i, t;
nopropagation$1();
- if (touchending) clearTimeout(touchending);
+ if (touchending) { clearTimeout(touchending); }
touchending = setTimeout(function() { touchending = null; }, touchDelay);
for (i = 0; i < n; ++i) {
t = touches[i];
- if (g.touch0 && g.touch0[2] === t.identifier) delete g.touch0;
- else if (g.touch1 && g.touch1[2] === t.identifier) delete g.touch1;
+ if (g.touch0 && g.touch0[2] === t.identifier) { delete g.touch0; }
+ else if (g.touch1 && g.touch1[2] === t.identifier) { delete g.touch1; }
}
- if (g.touch1 && !g.touch0) g.touch0 = g.touch1, delete g.touch1;
- if (g.touch0) g.touch0[1] = this.__zoom.invert(g.touch0[0]);
+ if (g.touch1 && !g.touch0) { g.touch0 = g.touch1, delete g.touch1; }
+ if (g.touch0) { g.touch0[1] = this.__zoom.invert(g.touch0[0]); }
else {
g.end();
// If this was a dbltap, reroute to the (optional) dblclick.zoom handler.
if (g.taps === 2) {
var p = select(this).on("dblclick.zoom");
- if (p) p.apply(this, arguments);
+ if (p) { p.apply(this, arguments); }
}
}
}
projection.scale = function(_) {
- if (!arguments.length) return k;
+ if (!arguments.length) { return k; }
k = +_;
return projection;
};
projection.translate = function(_) {
- if (!arguments.length) return [x, y];
+ if (!arguments.length) { return [x, y]; }
x = +_[0];
y = +_[1];
return projection;
projection.clipExtent = function(_) {
- if (!arguments.length) return clipExtent;
+ if (!arguments.length) { return clipExtent; }
clipExtent = _;
return projection;
};
projection.transform = function(obj) {
- if (!arguments.length) return identity$2.translate(x, y).scale(k);
+ if (!arguments.length) { return identity$2.translate(x, y).scale(k); }
x = +obj.x;
y = +obj.y;
k = +obj.k;
var b = coords[(i + 1) % coords.length];
var dotp = geoOrthoFilterDotProduct(geoOrthoNormalizedDotProduct(a, b, origin), epsilon, lowerThreshold, upperThreshold);
- if (dotp === null) continue; // ignore vertex
+ if (dotp === null) { continue; } // ignore vertex
score = score + 2.0 * Math.min(Math.abs(dotp - 1.0), Math.min(Math.abs(dotp), Math.abs(dotp + 1)));
}
var angle = Math.acos(Math.abs(normalizedDotP)) * 180 / Math.PI;
- if (angle > 45) angle = 90 - angle;
+ if (angle > 45) { angle = 90 - angle; }
- if (angle >= lessThan) continue;
+ if (angle >= lessThan) { continue; }
- if (angle > max) max = angle;
+ if (angle > max) { max = angle; }
}
- if (max === -Infinity) return null;
+ if (max === -Infinity) { return null; }
return max;
}
var b = coords[(i + 1) % coords.length];
var dotp = geoOrthoFilterDotProduct(geoOrthoNormalizedDotProduct(a, b, origin), epsilon, lowerThreshold, upperThreshold, allowStraightAngles);
- if (dotp === null) continue; // ignore vertex
- if (Math.abs(dotp) > 0) return 1; // something to do
+ if (dotp === null) { continue; } // ignore vertex
+ if (Math.abs(dotp) > 0) { return 1; } // something to do
score = 0; // already square
}
// Returns true if a and b have the same elements at the same indices.
function utilArrayIdentical(a, b) {
// an array is always identical to itself
- if (a === b) return true;
+ if (a === b) { return true; }
var i = a.length;
- if (i !== b.length) return false;
+ if (i !== b.length) { return false; }
while (i--) {
- if (a[i] !== b[i]) return false;
+ if (a[i] !== b[i]) { return false; }
}
return true;
}
// utilArrayChunk(a, 3);
// [[1,2,3],[4,5,6],[7]];
function utilArrayChunk(a, chunkSize) {
- if (!chunkSize || chunkSize < 0) return [a.slice()];
+ if (!chunkSize || chunkSize < 0) { return [a.slice()]; }
var result = new Array(Math.ceil(a.length / chunkSize));
return Array.from(result, function(item, i) {
var isArabic_1 = createCommonjsModule(function (module, exports) {
Object.defineProperty(exports, "__esModule", { value: true });
- const arabicBlocks = [
+ var arabicBlocks = [
[0x0600, 0x06FF],
[0x0750, 0x077F],
[0x08A0, 0x08FF],
// allow the newer chars?
throw new Error('isArabic works on only one-character strings');
}
- let code = char.charCodeAt(0);
- for (let i = 0; i < arabicBlocks.length; i++) {
- let block = arabicBlocks[i];
+ var code = char.charCodeAt(0);
+ for (var i = 0; i < arabicBlocks.length; i++) {
+ var block = arabicBlocks[i];
if (code >= block[0] && code <= block[1]) {
return true;
}
// allow the newer chars?
throw new Error('isMath works on only one-character strings');
}
- let code = char.charCodeAt(0);
+ var code = char.charCodeAt(0);
return ((code >= 0x660 && code <= 0x66C) || (code >= 0x6F0 && code <= 0x6F9));
}
exports.isMath = isMath;
var unicodeArabic = createCommonjsModule(function (module, exports) {
Object.defineProperty(exports, "__esModule", { value: true });
- const arabicReference = {
+ var arabicReference = {
"alef": {
"normal": [
"\u0627"
var unicodeLigatures = createCommonjsModule(function (module, exports) {
Object.defineProperty(exports, "__esModule", { value: true });
- const ligatureReference = {
+ var ligatureReference = {
"\u0626\u0627": {
"isolated": "\uFBEA",
"final": "\uFBEB"
Object.defineProperty(exports, "__esModule", { value: true });
- const letterList = Object.keys(unicodeArabic.default);
+ var letterList = Object.keys(unicodeArabic.default);
exports.letterList = letterList;
- const ligatureList = Object.keys(unicodeLigatures.default);
+ var ligatureList = Object.keys(unicodeLigatures.default);
exports.ligatureList = ligatureList;
- const ligatureWordList = Object.keys(unicodeLigatures.default.words);
+ var ligatureWordList = Object.keys(unicodeLigatures.default.words);
exports.ligatureWordList = ligatureWordList;
- const lams = '\u0644\u06B5\u06B6\u06B7\u06B8';
+ var lams = '\u0644\u06B5\u06B6\u06B7\u06B8';
exports.lams = lams;
- const alefs = '\u0627\u0622\u0623\u0625\u0671\u0672\u0673\u0675\u0773\u0774';
+ var alefs = '\u0627\u0622\u0623\u0625\u0671\u0672\u0673\u0675\u0773\u0774';
exports.alefs = alefs;
// for (var l = 1; l < lams.length; l++) {
// console.log('-');
// console.log(a + ': ' + lams[l] + alefs[a]);
// }
// }
- let tashkeel = '\u0605\u0640\u0670\u0674\u06DF\u06E7\u06E8';
+ var tashkeel = '\u0605\u0640\u0670\u0674\u06DF\u06E7\u06E8';
exports.tashkeel = tashkeel;
function addToTashkeel(start, finish) {
for (var i = start; i <= finish; i++) {
addToTashkeel(0x08D3, 0x08E1);
addToTashkeel(0x08E3, 0x08FF);
addToTashkeel(0xFE70, 0xFE7F);
- let lineBreakers = '\u0627\u0629\u0648\u06C0\u06CF\u06FD\u06FE\u076B\u076C\u0771\u0773\u0774\u0778\u0779\u08E2\u08B1\u08B2\u08B9';
+ var lineBreakers = '\u0627\u0629\u0648\u06C0\u06CF\u06FD\u06FE\u076B\u076C\u0771\u0773\u0774\u0778\u0779\u08E2\u08B1\u08B2\u08B9';
exports.lineBreakers = lineBreakers;
function addToLineBreakers(start, finish) {
for (var i = start; i <= finish; i++) {
function GlyphSplitter(word) {
- let letters = [];
- let lastLetter = '';
- word.split('').forEach((letter) => {
+ var letters = [];
+ var lastLetter = '';
+ word.split('').forEach(function (letter) {
if (isArabic_1.isArabic(letter)) {
if (reference.tashkeel.indexOf(letter) > -1) {
letters[letters.length - 1] += letter;
function BaselineSplitter(word) {
- let letters = [];
- let lastLetter = '';
- word.split('').forEach((letter) => {
+ var letters = [];
+ var lastLetter = '';
+ word.split('').forEach(function (letter) {
if (isArabic_1.isArabic(letter) && isArabic_1.isArabic(lastLetter)) {
if (lastLetter.length && reference.tashkeel.indexOf(letter) > -1) {
letters[letters.length - 1] += letter;
if (typeof breakPresentationForm === 'undefined') {
breakPresentationForm = true;
}
- let returnable = '';
- word.split('').forEach((letter) => {
+ var returnable = '';
+ word.split('').forEach(function (letter) {
if (!isArabic_1.isArabic(letter)) {
returnable += letter;
return;
}
- for (let w = 0; w < reference.letterList.length; w++) {
+ for (var w = 0; w < reference.letterList.length; w++) {
// ok so we are checking this potential lettertron
- let letterForms = unicodeArabic.default[reference.letterList[w]];
- let versions = Object.keys(letterForms);
- for (let v = 0; v < versions.length; v++) {
- let localVersion = letterForms[versions[v]];
+ var letterForms = unicodeArabic.default[reference.letterList[w]];
+ var versions = Object.keys(letterForms);
+ for (var v = 0; v < versions.length; v++) {
+ var localVersion = letterForms[versions[v]];
if (typeof localVersion === 'object' && typeof localVersion.indexOf === 'undefined') {
// look at this embedded object
- let embeddedForms = Object.keys(localVersion);
- for (let ef = 0; ef < embeddedForms.length; ef++) {
- let form = localVersion[embeddedForms[ef]];
+ var embeddedForms = Object.keys(localVersion);
+ for (var ef = 0; ef < embeddedForms.length; ef++) {
+ var form = localVersion[embeddedForms[ef]];
if (form === letter || (typeof form === 'object' && form.indexOf && form.indexOf(letter) > -1)) {
// match
// console.log('embedded match');
}
}
// try ligatures
- for (let v2 = 0; v2 < reference.ligatureList.length; v2++) {
- let normalForm = reference.ligatureList[v2];
+ for (var v2 = 0; v2 < reference.ligatureList.length; v2++) {
+ var normalForm = reference.ligatureList[v2];
if (normalForm !== 'words') {
- let ligForms = Object.keys(unicodeLigatures.default[normalForm]);
- for (let f = 0; f < ligForms.length; f++) {
+ var ligForms = Object.keys(unicodeLigatures.default[normalForm]);
+ for (var f = 0; f < ligForms.length; f++) {
if (unicodeLigatures.default[normalForm][ligForms[f]] === letter) {
returnable += normalForm;
return;
}
}
// try words ligatures
- for (let v3 = 0; v3 < reference.ligatureWordList.length; v3++) {
- let normalForm = reference.ligatureWordList[v3];
- if (unicodeLigatures.default.words[normalForm] === letter) {
- returnable += normalForm;
+ for (var v3 = 0; v3 < reference.ligatureWordList.length; v3++) {
+ var normalForm$1 = reference.ligatureWordList[v3];
+ if (unicodeLigatures.default.words[normalForm$1] === letter) {
+ returnable += normalForm$1;
return;
}
}
// hamza alone
return "\u0621";
}
- for (let w = 0; w < reference.letterList.length; w++) {
+ for (var w = 0; w < reference.letterList.length; w++) {
// ok so we are checking this potential lettertron
- let letterForms = unicodeArabic.default[reference.letterList[w]];
- let versions = Object.keys(letterForms);
- for (let v = 0; v < versions.length; v++) {
- let localVersion = letterForms[versions[v]];
+ var letterForms = unicodeArabic.default[reference.letterList[w]];
+ var versions = Object.keys(letterForms);
+ for (var v = 0; v < versions.length; v++) {
+ var localVersion = letterForms[versions[v]];
if ((localVersion === letter) ||
(typeof localVersion === 'object' && localVersion.indexOf && localVersion.indexOf(letter) > -1)) {
if (versions.indexOf(form) > -1) {
}
else if (typeof localVersion === 'object' && typeof localVersion.indexOf === 'undefined') {
// check embedded
- let embeddedVersions = Object.keys(localVersion);
- for (let ev = 0; ev < embeddedVersions.length; ev++) {
+ var embeddedVersions = Object.keys(localVersion);
+ for (var ev = 0; ev < embeddedVersions.length; ev++) {
if ((localVersion[embeddedVersions[ev]] === letter) ||
(typeof localVersion[embeddedVersions[ev]] === 'object' && localVersion[embeddedVersions[ev]].indexOf && localVersion[embeddedVersions[ev]].indexOf(letter) > -1)) {
if (embeddedVersions.indexOf(form) > -1) {
function WordShaper(word) {
- let state = 'initial';
- let output = '';
- for (let w = 0; w < word.length; w++) {
- let nextLetter = ' ';
- for (let nxw = w + 1; nxw < word.length; nxw++) {
+ var state = 'initial';
+ var output = '';
+ for (var w = 0; w < word.length; w++) {
+ var nextLetter = ' ';
+ for (var nxw = w + 1; nxw < word.length; nxw++) {
if (!isArabic_1.isArabic(word[nxw])) {
break;
}
if (!isArabic_1.isArabic(letter)) {
throw new Error('Not an Arabic letter');
}
- for (let w = 0; w < reference.letterList.length; w++) {
+ for (var w = 0; w < reference.letterList.length; w++) {
// ok so we are checking this potential lettertron
- let letterForms = unicodeArabic.default[reference.letterList[w]];
- let versions = Object.keys(letterForms);
- for (let v = 0; v < versions.length; v++) {
- let localVersion = letterForms[versions[v]];
+ var letterForms = unicodeArabic.default[reference.letterList[w]];
+ var versions = Object.keys(letterForms);
+ for (var v = 0; v < versions.length; v++) {
+ var localVersion = letterForms[versions[v]];
if (typeof localVersion === 'object' && typeof localVersion.indexOf === 'undefined') {
// look at this embedded object
- let embeddedForms = Object.keys(localVersion);
- for (let ef = 0; ef < embeddedForms.length; ef++) {
- let form = localVersion[embeddedForms[ef]];
+ var embeddedForms = Object.keys(localVersion);
+ for (var ef = 0; ef < embeddedForms.length; ef++) {
+ var form = localVersion[embeddedForms[ef]];
if (form === letter || (typeof form === 'object' && form.indexOf && form.indexOf(letter) > -1)) {
// match
return localVersion;
if (!isArabic_1.isArabic(letter)) {
throw new Error('Not an Arabic letter');
}
- for (let w = 0; w < reference.letterList.length; w++) {
+ for (var w = 0; w < reference.letterList.length; w++) {
// ok so we are checking this potential lettertron
- let letterForms = unicodeArabic.default[reference.letterList[w]];
- let versions = Object.keys(letterForms);
- for (let v = 0; v < versions.length; v++) {
- let localVersion = letterForms[versions[v]];
+ var letterForms = unicodeArabic.default[reference.letterList[w]];
+ var versions = Object.keys(letterForms);
+ for (var v = 0; v < versions.length; v++) {
+ var localVersion = letterForms[versions[v]];
if (typeof localVersion === 'object' && typeof localVersion.indexOf === 'undefined') {
// look at this embedded object
- let embeddedForms = Object.keys(localVersion);
- for (let ef = 0; ef < embeddedForms.length; ef++) {
- let form = localVersion[embeddedForms[ef]];
+ var embeddedForms = Object.keys(localVersion);
+ for (var ef = 0; ef < embeddedForms.length; ef++) {
+ var form = localVersion[embeddedForms[ef]];
if (form === letter || (typeof form === 'object' && form.indexOf && form.indexOf(letter) > -1)) {
// match
return letterForms;
// https://github.com/openstreetmap/iD/issues/772
// http://mathiasbynens.be/notes/localstorage-pattern#comment-9
- let _storage;
+ var _storage;
try { _storage = localStorage; } catch (e) {} // eslint-disable-line no-empty
- _storage = _storage || (() => {
- let s = {};
+ _storage = _storage || (function () {
+ var s = {};
return {
- getItem: (k) => s[k],
- setItem: (k, v) => s[k] = v,
- removeItem: (k) => delete s[k]
+ getItem: function (k) { return s[k]; },
+ setItem: function (k, v) { return s[k] = v; },
+ removeItem: function (k) { return delete s[k]; }
};
})();
function corePreferences(k, v) {
try {
- if (arguments.length === 1) return _storage.getItem(k);
- else if (v === null) _storage.removeItem(k);
- else _storage.setItem(k, v);
+ if (arguments.length === 1) { return _storage.getItem(k); }
+ else if (v === null) { _storage.removeItem(k); }
+ else { _storage.setItem(k, v); }
} catch (e) {
/* eslint-disable no-console */
if (typeof console !== 'undefined') {
}
function responseText(response) {
- if (!response.ok) throw new Error(response.status + " " + response.statusText);
+ if (!response.ok) { throw new Error(response.status + " " + response.statusText); }
return response.text();
}
}
function responseJson(response) {
- if (!response.ok) throw new Error(response.status + " " + response.statusText);
- if (response.status === 204 || response.status === 205) return;
+ if (!response.ok) { throw new Error(response.status + " " + response.statusText); }
+ if (response.status === 204 || response.status === 205) { return; }
return response.json();
}
var svg = parser("image/svg+xml");
- let _mainFileFetcher = coreFileFetcher(); // singleton
+ var _mainFileFetcher = coreFileFetcher(); // singleton
//
// coreFileFetcher asynchronously fetches data from JSON files
//
function coreFileFetcher() {
- let _this = {};
- let _inflight = {};
- let _fileMap = {
+ var _this = {};
+ var _inflight = {};
+ var _fileMap = {
'address_formats': 'data/address_formats.min.json',
'deprecated': 'data/deprecated.min.json',
'discarded': 'data/discarded.min.json',
'wmf_sitematrix': 'https://cdn.jsdelivr.net/npm/wmf-sitematrix@0.1/wikipedia.min.json'
};
- let _cachedData = {};
+ var _cachedData = {};
// expose the cache; useful for tests
- _this.cache = () => _cachedData;
+ _this.cache = function () { return _cachedData; };
// Returns a Promise to fetch data
// (resolved with the data if we have it already)
- _this.get = (which) => {
+ _this.get = function (which) {
if (_cachedData[which]) {
return Promise.resolve(_cachedData[which]);
}
- const file = _fileMap[which];
- const url = file && _this.asset(file);
+ var file = _fileMap[which];
+ var url = file && _this.asset(file);
if (!url) {
- return Promise.reject(`Unknown data file for "${which}"`);
+ return Promise.reject(("Unknown data file for \"" + which + "\""));
}
- let prom = _inflight[url];
+ var prom = _inflight[url];
if (!prom) {
_inflight[url] = prom = d3_json(url)
- .then(result => {
+ .then(function (result) {
delete _inflight[url];
if (!result) {
- throw new Error(`No data loaded for "${which}"`);
+ throw new Error(("No data loaded for \"" + which + "\""));
}
_cachedData[which] = result;
return result;
})
- .catch(err => {
+ .catch(function (err) {
delete _inflight[url];
throw err;
});
// Accessor for the file map
_this.fileMap = function(val) {
- if (!arguments.length) return _fileMap;
+ if (!arguments.length) { return _fileMap; }
_fileMap = val;
return _this;
};
- let _assetPath = '';
+ var _assetPath = '';
_this.assetPath = function(val) {
- if (!arguments.length) return _assetPath;
+ if (!arguments.length) { return _assetPath; }
_assetPath = val;
return _this;
};
- let _assetMap = {};
+ var _assetMap = {};
_this.assetMap = function(val) {
- if (!arguments.length) return _assetMap;
+ if (!arguments.length) { return _assetMap; }
_assetMap = val;
return _this;
};
- _this.asset = (val) => {
- if (/^http(s)?:\/\//i.test(val)) return val;
- const filename = _assetPath + val;
+ _this.asset = function (val) {
+ if (/^http(s)?:\/\//i.test(val)) { return val; }
+ var filename = _assetPath + val;
return _assetMap[filename] || filename;
};
return _this;
}
- let _detected;
+ var _detected;
function utilDetect(refresh) {
- if (_detected && !refresh) return _detected;
+ if (_detected && !refresh) { return _detected; }
_detected = {};
- const ua = navigator.userAgent;
- let m = null;
+ var ua = navigator.userAgent;
+ var m = null;
/* Browser */
m = ua.match(/(edge)\/?\s*(\.?\d+(\.\d+)*)/i); // Edge
_detected.browser = m[1];
_detected.version = m[2];
m = ua.match(/version\/([\.\d]+)/i);
- if (m !== null) _detected.version = m[1];
+ if (m !== null) { _detected.version = m[1]; }
}
}
if (!_detected.browser) {
/* Host */
- const loc = window.top.location;
- let origin = loc.origin;
+ var loc = window.top.location;
+ var origin = loc.origin;
if (!origin) { // for unpatched IE11
origin = loc.protocol + '//' + loc.hostname + (loc.port ? ':' + loc.port: '');
}
// To generate a random key: window.crypto.getRandomValues(new Uint8Array(16));
// This default signing key is built into iD and can be used to mask/unmask sensitive values.
- const DEFAULT_128 = [250, 157, 60, 79, 142, 134, 229, 129, 138, 126, 210, 129, 29, 71, 160, 208];
+ var DEFAULT_128 = [250, 157, 60, 79, 142, 134, 229, 129, 138, 126, 210, 129, 29, 71, 160, 208];
function utilAesEncrypt(text, key) {
key = key || DEFAULT_128;
- const textBytes = aesJs.utils.utf8.toBytes(text);
- const aesCtr = new aesJs.ModeOfOperation.ctr(key);
- const encryptedBytes = aesCtr.encrypt(textBytes);
- const encryptedHex = aesJs.utils.hex.fromBytes(encryptedBytes);
+ var textBytes = aesJs.utils.utf8.toBytes(text);
+ var aesCtr = new aesJs.ModeOfOperation.ctr(key);
+ var encryptedBytes = aesCtr.encrypt(textBytes);
+ var encryptedHex = aesJs.utils.hex.fromBytes(encryptedBytes);
return encryptedHex;
}
function utilAesDecrypt(encryptedHex, key) {
key = key || DEFAULT_128;
- const encryptedBytes = aesJs.utils.hex.toBytes(encryptedHex);
- const aesCtr = new aesJs.ModeOfOperation.ctr(key);
- const decryptedBytes = aesCtr.decrypt(encryptedBytes);
- const text = aesJs.utils.utf8.fromBytes(decryptedBytes);
+ var encryptedBytes = aesJs.utils.hex.toBytes(encryptedHex);
+ var aesCtr = new aesJs.ModeOfOperation.ctr(key);
+ var decryptedBytes = aesCtr.decrypt(encryptedBytes);
+ var text = aesJs.utils.utf8.fromBytes(decryptedBytes);
return text;
}
function utilCleanTags(tags) {
var out = {};
for (var k in tags) {
- if (!k) continue;
+ if (!k) { continue; }
var v = tags[k];
if (v !== undefined) {
out[k] = cleanValue(k, v);
return /^(description|note|fixme)$/.test(k);
}
- if (skip(k)) return v;
+ if (skip(k)) { return v; }
var cleaned = v
.split(';')
// priority match shifted keybindings first
for (i = 0; i < bindings.length; i++) {
binding = bindings[i];
- if (!binding.event.modifiers.shiftKey) continue; // no shift
- if (!!binding.capture !== isCapturing) continue;
+ if (!binding.event.modifiers.shiftKey) { continue; } // no shift
+ if (!!binding.capture !== isCapturing) { continue; }
if (matches(binding, true)) {
binding.callback();
didMatch = true;
}
// then unshifted keybindings
- if (didMatch) return;
+ if (didMatch) { return; }
for (i = 0; i < bindings.length; i++) {
binding = bindings[i];
- if (binding.event.modifiers.shiftKey) continue; // shift
- if (!!binding.capture !== isCapturing) continue;
+ if (binding.event.modifiers.shiftKey) { continue; } // shift
+ if (!!binding.capture !== isCapturing) { continue; }
if (matches(binding, false)) {
binding.callback();
}
isMatch = false;
} else if (Array.isArray(binding.event.key)) {
if (binding.event.key.map(function(s) { return s.toLowerCase(); }).indexOf(event$1.key.toLowerCase()) === -1)
- isMatch = false;
+ { isMatch = false; }
} else {
if (event$1.key.toLowerCase() !== binding.event.key.toLowerCase())
- isMatch = false;
+ { isMatch = false; }
}
}
isMatch = (event$1.keyCode === binding.event.keyCode);
}
- if (!isMatch) return false;
+ if (!isMatch) { return false; }
// test modifier keys
if (!(event$1.ctrlKey && event$1.altKey)) { // if both are set, assume AltGr and skip it - #4096
- if (event$1.ctrlKey !== binding.event.modifiers.ctrlKey) return false;
- if (event$1.altKey !== binding.event.modifiers.altKey) return false;
+ if (event$1.ctrlKey !== binding.event.modifiers.ctrlKey) { return false; }
+ if (event$1.altKey !== binding.event.modifiers.altKey) { return false; }
}
- if (event$1.metaKey !== binding.event.modifiers.metaKey) return false;
- if (testShift && event$1.shiftKey !== binding.event.modifiers.shiftKey) return false;
+ if (event$1.metaKey !== binding.event.modifiers.metaKey) { return false; }
+ if (testShift && event$1.shiftKey !== binding.event.modifiers.shiftKey) { return false; }
return true;
}
var matches = arr[i].toLowerCase().match(/(?:(?:[^+⇧⌃⌥⌘])+|[⇧⌃⌥⌘]|\+\+|^\+$)/g);
for (var j = 0; j < matches.length; j++) {
// Normalise matching errors
- if (matches[j] === '++') matches[j] = '+';
+ if (matches[j] === '++') { matches[j] = '+'; }
if (matches[j] in utilKeybinding.modifierCodes) {
var prop = utilKeybinding.modifierProperties[utilKeybinding.modifierCodes[matches[j]]];
// Copies a variable number of methods from source to target.
function utilRebind(target, source) {
+ var arguments$1 = arguments;
+
var i = 1, n = arguments.length, method;
while (++i < n) {
- target[method = arguments[i]] = d3_rebind(target, source, source[method]);
+ target[method = arguments$1[i]] = d3_rebind(target, source, source[method]);
}
return target;
}
}
mutex.lock = function () {
- if (intervalID) return true;
+ if (intervalID) { return true; }
var cookie = document.cookie.replace(new RegExp('(?:(?:^|.*;)\\s*' + name + '\\s*\\=\\s*([^;]*).*$)|^.*$'), '$1');
- if (cookie) return false;
+ if (cookie) { return false; }
renew();
intervalID = window.setInterval(renew, 4000);
return true;
};
mutex.unlock = function () {
- if (!intervalID) return;
+ if (!intervalID) { return; }
document.cookie = name + '=; expires=Thu, 01 Jan 1970 00:00:00 GMT; sameSite=strict';
clearInterval(intervalID);
intervalID = null;
tiler.tileSize = function(val) {
- if (!arguments.length) return _tileSize;
+ if (!arguments.length) { return _tileSize; }
_tileSize = val;
return tiler;
};
tiler.zoomExtent = function(val) {
- if (!arguments.length) return _zoomExtent;
+ if (!arguments.length) { return _zoomExtent; }
_zoomExtent = val;
return tiler;
};
tiler.size = function(val) {
- if (!arguments.length) return _size;
+ if (!arguments.length) { return _size; }
_size = val;
return tiler;
};
tiler.scale = function(val) {
- if (!arguments.length) return _scale;
+ if (!arguments.length) { return _scale; }
_scale = val;
return tiler;
};
tiler.translate = function(val) {
- if (!arguments.length) return _translate;
+ if (!arguments.length) { return _translate; }
_translate = val;
return tiler;
};
// number to extend the rows/columns beyond those covering the viewport
tiler.margin = function(val) {
- if (!arguments.length) return _margin;
+ if (!arguments.length) { return _margin; }
_margin = +val;
return tiler;
};
tiler.skipNullIsland = function(val) {
- if (!arguments.length) return _skipNullIsland;
+ if (!arguments.length) { return _skipNullIsland; }
_skipNullIsland = val;
return tiler;
};
});
}
- let _mainLocalizer = coreLocalizer(); // singleton
- let _t = _mainLocalizer.t;
+ var _mainLocalizer = coreLocalizer(); // singleton
+ var _t = _mainLocalizer.t;
//
// coreLocalizer manages language and locale parameters including translated strings
//
function coreLocalizer() {
- let localizer = {};
+ var localizer = {};
- let _dataLanguages = {};
+ var _dataLanguages = {};
// `localeData` is an object containing all _supported_ locale codes -> language info.
// {
// de: { rtl: false, languageNames: {…}, scriptNames: {…} },
// …
// }
- let _dataLocales = {};
+ var _dataLocales = {};
// `localeStrings` is an object containing all _loaded_ locale codes -> string data.
// {
// de: { icons: {…}, toolbar: {…}, modes: {…}, operations: {…}, … },
// …
// }
- let _localeStrings = {};
+ var _localeStrings = {};
// the current locale parameters
- let _localeCode = 'en-US';
- let _languageCode = 'en';
- let _textDirection = 'ltr';
- let _usesMetric = false;
- let _languageNames = {};
- let _scriptNames = {};
+ var _localeCode = 'en-US';
+ var _languageCode = 'en';
+ var _textDirection = 'ltr';
+ var _usesMetric = false;
+ var _languageNames = {};
+ var _scriptNames = {};
// getters for the current locale parameters
- localizer.localeCode = () => _localeCode;
- localizer.languageCode = () => _languageCode;
- localizer.textDirection = () => _textDirection;
- localizer.usesMetric = () => _usesMetric;
- localizer.languageNames = () => _languageNames;
- localizer.scriptNames = () => _scriptNames;
+ localizer.localeCode = function () { return _localeCode; };
+ localizer.languageCode = function () { return _languageCode; };
+ localizer.textDirection = function () { return _textDirection; };
+ localizer.usesMetric = function () { return _usesMetric; };
+ localizer.languageNames = function () { return _languageNames; };
+ localizer.scriptNames = function () { return _scriptNames; };
+
+
+ // The client app may want to manually set the locale, regardless of the
+ // settings provided by the browser
+ var _preferredLocaleCodes = [];
+ localizer.preferredLocaleCodes = function(codes) {
+ if (!arguments.length) { return _preferredLocaleCodes; }
+ if (typeof codes === 'string') {
+ // be generous and accept delimited strings as input
+ _preferredLocaleCodes = codes.split(/,|;| /gi).filter(Boolean);
+ } else {
+ _preferredLocaleCodes = codes;
+ }
+ return localizer;
+ };
var _loadPromise;
- localizer.ensureLoaded = () => {
+ localizer.ensureLoaded = function () {
- if (_loadPromise) return _loadPromise;
+ if (_loadPromise) { return _loadPromise; }
return _loadPromise = Promise.all([
- // load the list of langauges
+ // load the list of languages
_mainFileFetcher.get('languages'),
// load the list of supported locales
_mainFileFetcher.get('locales')
])
- .then(results => {
+ .then(function (results) {
_dataLanguages = results[0];
_dataLocales = results[1];
})
- .then(() => {
- const hash = utilStringQs(window.location.hash);
-
- if (hash.locale && _dataLocales[hash.locale]) {
- // the locale can be manually set in the URL hash
- _localeCode = hash.locale;
- } else {
- // otherwise use the locale specified by the browser
- _localeCode = supportedBrowserLocale();
- }
+ .then(function () {
+ var requestedLocales = (_preferredLocaleCodes || [])
+ // list of locales preferred by the browser in priority order
+ .concat(utilDetect().browserLocales);
+ _localeCode = bestSupportedLocale(requestedLocales);
return Promise.all([
// always load the English locale strings as fallbacks
localizer.loadLocale(_localeCode)
]);
})
- .then(() => {
+ .then(function () {
updateForCurrentLocale();
})
- .catch(err => console.error(err)); // eslint-disable-line
+ .catch(function (err) { return console.error(err); }); // eslint-disable-line
};
- // Returns the best locale requested by the browser supported by iD, if any
- function supportedBrowserLocale() {
- // list of locales preferred by the browser in priority order
- let browserLocales = utilDetect().browserLocales;
- let supportedLocales = _dataLocales;
+ // Returns the best locale from `locales` supported by iD, if any
+ function bestSupportedLocale(locales) {
+ var supportedLocales = _dataLocales;
- for (let i in browserLocales) {
- let browserLocale = browserLocales[i];
- if (browserLocale.includes('-')) { // full locale ('es-ES')
+ var loop = function ( i ) {
+ var locale = locales[i];
+ if (locale.includes('-')) { // full locale ('es-ES')
- if (supportedLocales[browserLocale]) return browserLocale;
+ if (supportedLocales[locale]) { return { v: locale }; }
// If full locale not supported ('es-FAKE'), fallback to the base ('es')
- let langPart = browserLocale.split('-')[0];
- if (supportedLocales[langPart]) return langPart;
+ var langPart = locale.split('-')[0];
+ if (supportedLocales[langPart]) { return { v: langPart }; }
} else { // base locale ('es')
// prefer a lower-priority full locale with this base ('es' < 'es-ES')
- let fullLocale = browserLocales.find((locale, index) => {
+ var fullLocale = locales.find(function (locale2, index) {
return index > i &&
- locale !== browserLocale &&
- locale.split('-')[0] === browserLocale &&
- supportedLocales[locale];
+ locale2 !== locale &&
+ locale2.split('-')[0] === locale &&
+ supportedLocales[locale2];
});
- if (fullLocale) return fullLocale;
+ if (fullLocale) { return { v: fullLocale }; }
- if (supportedLocales[browserLocale]) return browserLocale;
+ if (supportedLocales[locale]) { return { v: locale }; }
}
+ };
+
+ for (var i in locales) {
+ var returned = loop( i );
+
+ if ( returned ) return returned.v;
}
return null;
}
function updateForCurrentLocale() {
- if (!_localeCode) return;
+ if (!_localeCode) { return; }
_languageCode = _localeCode.split('-')[0];
- const currentData = _dataLocales[_localeCode] || _dataLocales[_languageCode];
+ var currentData = _dataLocales[_localeCode] || _dataLocales[_languageCode];
- const hash = utilStringQs(window.location.hash);
+ var hash = utilStringQs(window.location.hash);
if (hash.rtl === 'true') {
_textDirection = 'rtl';
/* Locales */
// Returns a Promise to load the strings for the requested locale
- localizer.loadLocale = (requested) => {
+ localizer.loadLocale = function (requested) {
if (!_dataLocales) {
return Promise.reject('loadLocale called before init');
}
- let locale = requested;
+ var locale = requested;
// US English is the default
- if (locale.toLowerCase() === 'en-us') locale = 'en';
+ if (locale.toLowerCase() === 'en-us') { locale = 'en'; }
if (!_dataLocales[locale]) {
- return Promise.reject(`Unsupported locale: ${requested}`);
+ return Promise.reject(("Unsupported locale: " + requested));
}
if (_localeStrings[locale]) { // already loaded
return Promise.resolve(locale);
}
- let fileMap = _mainFileFetcher.fileMap();
- const key = `locale_${locale}`;
- fileMap[key] = `locales/${locale}.json`;
+ var fileMap = _mainFileFetcher.fileMap();
+ var key = "locale_" + locale;
+ fileMap[key] = "locales/" + locale + ".json";
return _mainFileFetcher.get(key)
- .then(d => {
+ .then(function (d) {
_localeStrings[locale] = d[locale];
return locale;
});
locale = locale || _localeCode;
// US English is the default
- if (locale.toLowerCase() === 'en-us') locale = 'en';
+ if (locale.toLowerCase() === 'en-us') { locale = 'en'; }
- let path = s
+ var path = s
.split('.')
- .map(s => s.replace(/<TX_DOT>/g, '.'))
+ .map(function (s) { return s.replace(/<TX_DOT>/g, '.'); })
.reverse();
- let result = _localeStrings[locale];
+ var result = _localeStrings[locale];
while (result !== undefined && path.length) {
result = result[path.pop()];
if (result !== undefined) {
if (replacements) {
- for (let k in replacements) {
- const token = `{${k}}`;
- const regex = new RegExp(token, 'g');
+ for (var k in replacements) {
+ var token = "{" + k + "}";
+ var regex = new RegExp(token, 'g');
result = result.replace(regex, replacements[k]);
}
}
return replacements.default; // fallback - replacements.default
}
- const missing = `Missing ${locale} translation: ${s}`;
- if (typeof console !== 'undefined') console.error(missing); // eslint-disable-line
+ var missing = "Missing " + locale + " translation: " + s;
+ if (typeof console !== 'undefined') { console.error(missing); } // eslint-disable-line
return missing;
};
- localizer.languageName = (code, options) => {
+ localizer.languageName = function (code, options) {
- if (_languageNames[code]) { // name in locale langauge
+ if (_languageNames[code]) { // name in locale language
// e.g. "German"
return _languageNames[code];
}
// sometimes we only want the local name
- if (options && options.localOnly) return null;
+ if (options && options.localOnly) { return null; }
- const langInfo = _dataLanguages[code];
+ var langInfo = _dataLanguages[code];
if (langInfo) {
if (langInfo.nativeName) { // name in native language
// e.g. "Deutsch (de)"
return localizer.t('translate.language_and_code', { language: langInfo.nativeName, code: code });
} else if (langInfo.base && langInfo.script) {
- const base = langInfo.base; // the code of the langauge this is based on
+ var base = langInfo.base; // the code of the language this is based on
- if (_languageNames[base]) { // base language name in locale langauge
- const scriptCode = langInfo.script;
- const script = _scriptNames[scriptCode] || scriptCode;
+ if (_languageNames[base]) { // base language name in locale language
+ var scriptCode = langInfo.script;
+ var script = _scriptNames[scriptCode] || scriptCode;
// e.g. "Serbian (Cyrillic)"
return localizer.t('translate.language_and_code', { language: _languageNames[base], code: script });
// and decorated with some extra methods for searching and matching geometry
//
function presetCollection(collection) {
- const MAXRESULTS = 50;
- let _this = {};
- let _memo = {};
+ var MAXRESULTS = 50;
+ var _this = {};
+ var _memo = {};
_this.collection = collection;
- _this.item = (id) => {
- if (_memo[id]) return _memo[id];
- const found = _this.collection.find(d => d.id === id);
- if (found) _memo[id] = found;
+ _this.item = function (id) {
+ if (_memo[id]) { return _memo[id]; }
+ var found = _this.collection.find(function (d) { return d.id === id; });
+ if (found) { _memo[id] = found; }
return found;
};
- _this.index = (id) => _this.collection.findIndex(d => d.id === id);
+ _this.index = function (id) { return _this.collection.findIndex(function (d) { return d.id === id; }); };
- _this.matchGeometry = (geometry) => {
+ _this.matchGeometry = function (geometry) {
return presetCollection(
- _this.collection.filter(d => d.matchGeometry(geometry))
+ _this.collection.filter(function (d) { return d.matchGeometry(geometry); })
);
};
- _this.matchAllGeometry = (geometries) => {
+ _this.matchAllGeometry = function (geometries) {
return presetCollection(
- _this.collection.filter(d => d && d.matchAllGeometry(geometries))
+ _this.collection.filter(function (d) { return d && d.matchAllGeometry(geometries); })
);
};
- _this.matchAnyGeometry = (geometries) => {
+ _this.matchAnyGeometry = function (geometries) {
return presetCollection(
- _this.collection.filter(d => geometries.some(geom => d.matchGeometry(geom)))
+ _this.collection.filter(function (d) { return geometries.some(function (geom) { return d.matchGeometry(geom); }); })
);
};
- _this.fallback = (geometry) => {
- let id = geometry;
- if (id === 'vertex') id = 'point';
+ _this.fallback = function (geometry) {
+ var id = geometry;
+ if (id === 'vertex') { id = 'point'; }
return _this.item(id);
};
- _this.search = (value, geometry, countryCode) => {
- if (!value) return _this;
+ _this.search = function (value, geometry, countryCode) {
+ if (!value) { return _this; }
value = value.toLowerCase().trim();
// match at name beginning or just after a space (e.g. "office" -> match "Law Office")
function leading(a) {
- const index = a.indexOf(value);
+ var index = a.indexOf(value);
return index === 0 || a[index - 1] === ' ';
}
// match at name beginning only
function leadingStrict(a) {
- const index = a.indexOf(value);
+ var index = a.indexOf(value);
return index === 0;
}
function sortNames(a, b) {
- let aCompare = (a.suggestion ? a.originalName : a.name()).toLowerCase();
- let bCompare = (b.suggestion ? b.originalName : b.name()).toLowerCase();
+ var aCompare = (a.suggestion ? a.originalName : a.name()).toLowerCase();
+ var bCompare = (b.suggestion ? b.originalName : b.name()).toLowerCase();
// priority if search string matches preset name exactly - #4325
- if (value === aCompare) return -1;
- if (value === bCompare) return 1;
+ if (value === aCompare) { return -1; }
+ if (value === bCompare) { return 1; }
// priority for higher matchScore
- let i = b.originalScore - a.originalScore;
- if (i !== 0) return i;
+ var i = b.originalScore - a.originalScore;
+ if (i !== 0) { return i; }
// priority if search string appears earlier in preset name
i = aCompare.indexOf(value) - bCompare.indexOf(value);
- if (i !== 0) return i;
+ if (i !== 0) { return i; }
// priority for shorter preset names
return aCompare.length - bCompare.length;
}
- let pool = _this.collection;
+ var pool = _this.collection;
if (countryCode) {
- pool = pool.filter(a => {
- if (a.countryCodes && a.countryCodes.indexOf(countryCode) === -1) return false;
- if (a.notCountryCodes && a.notCountryCodes.indexOf(countryCode) !== -1) return false;
+ pool = pool.filter(function (a) {
+ if (a.countryCodes && a.countryCodes.indexOf(countryCode) === -1) { return false; }
+ if (a.notCountryCodes && a.notCountryCodes.indexOf(countryCode) !== -1) { return false; }
return true;
});
}
- const searchable = pool.filter(a => a.searchable !== false && a.suggestion !== true);
- const suggestions = pool.filter(a => a.suggestion === true);
+ var searchable = pool.filter(function (a) { return a.searchable !== false && a.suggestion !== true; });
+ var suggestions = pool.filter(function (a) { return a.suggestion === true; });
// matches value to preset.name
- const leading_name = searchable
- .filter(a => leading(a.name().toLowerCase()))
+ var leading_name = searchable
+ .filter(function (a) { return leading(a.name().toLowerCase()); })
.sort(sortNames);
// matches value to preset suggestion name (original name is unhyphenated)
- const leading_suggestions = suggestions
- .filter(a => leadingStrict(a.originalName.toLowerCase()))
+ var leading_suggestions = suggestions
+ .filter(function (a) { return leadingStrict(a.originalName.toLowerCase()); })
.sort(sortNames);
// matches value to preset.terms values
- const leading_terms = searchable
- .filter(a => (a.terms() || []).some(leading));
+ var leading_terms = searchable
+ .filter(function (a) { return (a.terms() || []).some(leading); });
// matches value to preset.tags values
- const leading_tag_values = searchable
- .filter(a => Object.values(a.tags || {}).filter(val => val !== '*').some(leading));
+ var leading_tag_values = searchable
+ .filter(function (a) { return Object.values(a.tags || {}).filter(function (val) { return val !== '*'; }).some(leading); });
// finds close matches to value in preset.name
- const similar_name = searchable
- .map(a => ({ preset: a, dist: utilEditDistance(value, a.name()) }))
- .filter(a => a.dist + Math.min(value.length - a.preset.name().length, 0) < 3)
- .sort((a, b) => a.dist - b.dist)
- .map(a => a.preset);
+ var similar_name = searchable
+ .map(function (a) { return ({ preset: a, dist: utilEditDistance(value, a.name()) }); })
+ .filter(function (a) { return a.dist + Math.min(value.length - a.preset.name().length, 0) < 3; })
+ .sort(function (a, b) { return a.dist - b.dist; })
+ .map(function (a) { return a.preset; });
// finds close matches to value to preset suggestion name (original name is unhyphenated)
- const similar_suggestions = suggestions
- .map(a => ({ preset: a, dist: utilEditDistance(value, a.originalName.toLowerCase()) }))
- .filter(a => a.dist + Math.min(value.length - a.preset.originalName.length, 0) < 1)
- .sort((a, b) => a.dist - b.dist)
- .map(a => a.preset);
+ var similar_suggestions = suggestions
+ .map(function (a) { return ({ preset: a, dist: utilEditDistance(value, a.originalName.toLowerCase()) }); })
+ .filter(function (a) { return a.dist + Math.min(value.length - a.preset.originalName.length, 0) < 1; })
+ .sort(function (a, b) { return a.dist - b.dist; })
+ .map(function (a) { return a.preset; });
// finds close matches to value in preset.terms
- const similar_terms = searchable
- .filter(a => {
- return (a.terms() || []).some(b => {
+ var similar_terms = searchable
+ .filter(function (a) {
+ return (a.terms() || []).some(function (b) {
return utilEditDistance(value, b) + Math.min(value.length - b.length, 0) < 3;
});
});
- let results = leading_name.concat(
+ var results = leading_name.concat(
leading_suggestions,
leading_terms,
leading_tag_values,
if (typeof geometry === 'string') {
results.push(_this.fallback(geometry));
} else {
- geometry.forEach(geom => results.push(_this.fallback(geom)));
+ geometry.forEach(function (geom) { return results.push(_this.fallback(geom)); });
}
}
// decorated with some extra methods for searching and matching geometry
//
function presetCategory(categoryID, category, all) {
- let _this = Object.assign({}, category); // shallow copy
+ var _this = Object.assign({}, category); // shallow copy
_this.id = categoryID;
_this.members = presetCollection(
- category.members.map(presetID => all.item(presetID)).filter(Boolean)
+ category.members.map(function (presetID) { return all.item(presetID); }).filter(Boolean)
);
_this.geometry = _this.members.collection
- .reduce((acc, preset) => {
- for (let i in preset.geometry) {
- const geometry = preset.geometry[i];
+ .reduce(function (acc, preset) {
+ for (var i in preset.geometry) {
+ var geometry = preset.geometry[i];
if (acc.indexOf(geometry) === -1) {
acc.push(geometry);
}
return acc;
}, []);
- _this.matchGeometry = (geom) => _this.geometry.indexOf(geom) >= 0;
+ _this.matchGeometry = function (geom) { return _this.geometry.indexOf(geom) >= 0; };
- _this.matchAllGeometry = (geometries) => _this.members.collection
- .some(preset => preset.matchAllGeometry(geometries));
+ _this.matchAllGeometry = function (geometries) { return _this.members.collection
+ .some(function (preset) { return preset.matchAllGeometry(geometries); }); };
- _this.matchScore = () => -1;
+ _this.matchScore = function () { return -1; };
- _this.name = () => _t(`presets.categories.${categoryID}.name`, { 'default': categoryID });
+ _this.name = function () { return _t(("presets.categories." + categoryID + ".name"), { 'default': categoryID }); };
- _this.terms = () => [];
+ _this.terms = function () { return []; };
return _this;
// with some extra methods for searching and matching geometry
//
function presetField(fieldID, field) {
- let _this = Object.assign({}, field); // shallow copy
+ var _this = Object.assign({}, field); // shallow copy
_this.id = fieldID;
// for use in classes, element ids, css selectors
_this.safeid = utilSafeClassName(fieldID);
- _this.matchGeometry = (geom) => !_this.geometry || _this.geometry.indexOf(geom) !== -1;
+ _this.matchGeometry = function (geom) { return !_this.geometry || _this.geometry.indexOf(geom) !== -1; };
- _this.matchAllGeometry = (geometries) => {
- return !_this.geometry || geometries.every(geom => _this.geometry.indexOf(geom) !== -1);
+ _this.matchAllGeometry = function (geometries) {
+ return !_this.geometry || geometries.every(function (geom) { return _this.geometry.indexOf(geom) !== -1; });
};
- _this.t = (scope, options) => _t(`presets.fields.${fieldID}.${scope}`, options);
+ _this.t = function (scope, options) { return _t(("presets.fields." + fieldID + "." + scope), options); };
- _this.label = () => _this.overrideLabel || _this.t('label', { 'default': fieldID });
+ _this.label = function () { return _this.overrideLabel || _this.t('label', { 'default': fieldID }); };
- const _placeholder = _this.placeholder;
- _this.placeholder = () => _this.t('placeholder', { 'default': _placeholder });
+ var _placeholder = _this.placeholder;
+ _this.placeholder = function () { return _this.t('placeholder', { 'default': _placeholder }); };
_this.originalTerms = (_this.terms || []).join();
- _this.terms = () => _this.t('terms', { 'default': _this.originalTerms })
- .toLowerCase().trim().split(/\s*,+\s*/);
+ _this.terms = function () { return _this.t('terms', { 'default': _this.originalTerms })
+ .toLowerCase().trim().split(/\s*,+\s*/); };
return _this;
function presetPreset(presetID, preset, addable, allFields, allPresets) {
allFields = allFields || {};
allPresets = allPresets || {};
- let _this = Object.assign({}, preset); // shallow copy
- let _addable = addable || false;
- let _resolvedFields; // cache
- let _resolvedMoreFields; // cache
+ var _this = Object.assign({}, preset); // shallow copy
+ var _addable = addable || false;
+ var _resolvedFields; // cache
+ var _resolvedMoreFields; // cache
_this.id = presetID;
_this.originalMoreFields = (_this.moreFields || []);
- _this.fields = () => _resolvedFields || (_resolvedFields = resolve('fields'));
+ _this.fields = function () { return _resolvedFields || (_resolvedFields = resolve('fields')); };
- _this.moreFields = () => _resolvedMoreFields || (_resolvedMoreFields = resolve('moreFields'));
+ _this.moreFields = function () { return _resolvedMoreFields || (_resolvedMoreFields = resolve('moreFields')); };
- _this.resetFields = () => _resolvedFields = _resolvedMoreFields = null;
+ _this.resetFields = function () { return _resolvedFields = _resolvedMoreFields = null; };
_this.tags = _this.tags || {};
_this.geometry = (_this.geometry || []);
- _this.matchGeometry = (geom) => _this.geometry.indexOf(geom) >= 0;
+ _this.matchGeometry = function (geom) { return _this.geometry.indexOf(geom) >= 0; };
- _this.matchAllGeometry = (geoms) => geoms.every(_this.matchGeometry);
+ _this.matchAllGeometry = function (geoms) { return geoms.every(_this.matchGeometry); };
- _this.matchScore = (entityTags) => {
- const tags = _this.tags;
- let seen = {};
- let score = 0;
+ _this.matchScore = function (entityTags) {
+ var tags = _this.tags;
+ var seen = {};
+ var score = 0;
// match on tags
- for (let k in tags) {
+ for (var k in tags) {
seen[k] = true;
if (entityTags[k] === tags[k]) {
score += _this.originalScore;
}
// boost score for additional matches in addTags - #6802
- const addTags = _this.addTags;
- for (let k in addTags) {
- if (!seen[k] && entityTags[k] === addTags[k]) {
+ var addTags = _this.addTags;
+ for (var k$1 in addTags) {
+ if (!seen[k$1] && entityTags[k$1] === addTags[k$1]) {
score += _this.originalScore;
}
}
};
- let _textCache = {};
- _this.t = (scope, options) => {
- const textID = `presets.presets.${presetID}.${scope}`;
- if (_textCache[textID]) return _textCache[textID];
+ var _textCache = {};
+ _this.t = function (scope, options) {
+ var textID = "presets.presets." + presetID + "." + scope;
+ if (_textCache[textID]) { return _textCache[textID]; }
return _textCache[textID] = _t(textID, options);
};
- _this.name = () => {
+ _this.name = function () {
if (_this.suggestion) {
- let path = presetID.split('/');
+ var path = presetID.split('/');
path.pop(); // remove brand name
- // NOTE: insert an en-dash, not a hypen (to avoid conflict with fr - nl names in Brussels etc)
+ // NOTE: insert an en-dash, not a hyphen (to avoid conflict with fr - nl names in Brussels etc)
return _this.originalName + ' – ' + _t('presets.presets.' + path.join('/') + '.name');
}
return _this.t('name', { 'default': _this.originalName });
};
- _this.terms = () => _this.t('terms', { 'default': _this.originalTerms })
- .toLowerCase().trim().split(/\s*,+\s*/);
+ _this.terms = function () { return _this.t('terms', { 'default': _this.originalTerms })
+ .toLowerCase().trim().split(/\s*,+\s*/); };
- _this.isFallback = () => {
- const tagCount = Object.keys(_this.tags).length;
+ _this.isFallback = function () {
+ var tagCount = Object.keys(_this.tags).length;
return tagCount === 0 || (tagCount === 1 && _this.tags.hasOwnProperty('area'));
};
_this.addable = function(val) {
- if (!arguments.length) return _addable;
+ if (!arguments.length) { return _addable; }
_addable = val;
return _this;
};
- _this.reference = (geom) => {
+ _this.reference = function () {
// Lookup documentation on Wikidata...
- const qid = _this.tags.wikidata || _this.tags['brand:wikidata'] || _this.tags['operator:wikidata'];
+ var qid = _this.tags.wikidata || _this.tags['brand:wikidata'] || _this.tags['operator:wikidata'];
if (qid) {
return { qid: qid };
}
// Lookup documentation on OSM Wikibase...
- let key = _this.originalReference.key || Object.keys(utilObjectOmit(_this.tags, 'name'))[0];
- let value = _this.originalReference.value || _this.tags[key];
-
- if (geom === 'relation' && key === 'type') {
- if (value in _this.tags) {
- key = value;
- value = _this.tags[key];
- } else {
- return { rtype: value };
- }
- }
+ var key = _this.originalReference.key || Object.keys(utilObjectOmit(_this.tags, 'name'))[0];
+ var value = _this.originalReference.value || _this.tags[key];
if (value === '*') {
return { key: key };
};
- _this.unsetTags = (tags, geometry, skipFieldDefaults) => {
+ _this.unsetTags = function (tags, geometry, skipFieldDefaults) {
tags = utilObjectOmit(tags, Object.keys(_this.removeTags));
if (geometry && !skipFieldDefaults) {
- _this.fields().forEach(field => {
+ _this.fields().forEach(function (field) {
if (field.matchGeometry(geometry) && field.key && field.default === tags[field.key]) {
delete tags[field.key];
}
};
- _this.setTags = (tags, geometry, skipFieldDefaults) => {
- const addTags = _this.addTags;
+ _this.setTags = function (tags, geometry, skipFieldDefaults) {
+ var addTags = _this.addTags;
tags = Object.assign({}, tags); // shallow copy
- for (let k in addTags) {
+ for (var k in addTags) {
if (addTags[k] === '*') {
tags[k] = 'yes';
} else {
if (!addTags.hasOwnProperty('area')) {
delete tags.area;
if (geometry === 'area') {
- let needsAreaTag = true;
+ var needsAreaTag = true;
if (_this.geometry.indexOf('line') === -1) {
- for (let k in addTags) {
- if (k in osmAreaKeys) {
+ for (var k$1 in addTags) {
+ if (k$1 in osmAreaKeys) {
needsAreaTag = false;
break;
}
}
if (geometry && !skipFieldDefaults) {
- _this.fields().forEach(field => {
+ _this.fields().forEach(function (field) {
if (field.matchGeometry(geometry) && field.key && !tags[field.key] && field.default) {
tags[field.key] = field.default;
}
// For a preset without fields, use the fields of the parent preset.
// Replace {preset} placeholders with the fields of the specified presets.
function resolve(which) {
- const fieldIDs = (which === 'fields' ? _this.originalFields : _this.originalMoreFields);
- let resolved = [];
+ var fieldIDs = (which === 'fields' ? _this.originalFields : _this.originalMoreFields);
+ var resolved = [];
- fieldIDs.forEach(fieldID => {
- const match = fieldID.match(/\{(.*)\}/);
+ fieldIDs.forEach(function (fieldID) {
+ var match = fieldID.match(/\{(.*)\}/);
if (match !== null) { // a presetID wrapped in braces {}
resolved = resolved.concat(inheritFields(match[1], which));
} else if (allFields[fieldID]) { // a normal fieldID
resolved.push(allFields[fieldID]);
} else {
- console.log(`Cannot resolve "${fieldID}" found in ${_this.id}.${which}`); // eslint-disable-line no-console
+ console.log(("Cannot resolve \"" + fieldID + "\" found in " + (_this.id) + "." + which)); // eslint-disable-line no-console
}
});
// no fields resolved, so use the parent's if possible
if (!resolved.length) {
- const endIndex = _this.id.lastIndexOf('/');
- const parentID = endIndex && _this.id.substring(0, endIndex);
+ var endIndex = _this.id.lastIndexOf('/');
+ var parentID = endIndex && _this.id.substring(0, endIndex);
if (parentID) {
resolved = inheritFields(parentID, which);
}
// returns an array of fields to inherit from the given presetID, if found
function inheritFields(presetID, which) {
- const parent = allPresets[presetID];
- if (!parent) return [];
+ var parent = allPresets[presetID];
+ if (!parent) { return []; }
if (which === 'fields') {
return parent.fields().filter(shouldInherit);
if (f.key && _this.tags[f.key] !== undefined &&
// inherit anyway if multiple values are allowed or just a checkbox
f.type !== 'multiCombo' && f.type !== 'semiCombo' && f.type !== 'check'
- ) return false;
+ ) { return false; }
return true;
}
return _this;
}
- let _mainPresetIndex = presetIndex(); // singleton
+ var _mainPresetIndex = presetIndex(); // singleton
//
// `presetIndex` wraps a `presetCollection`
// with methods for loading new data and returning defaults
//
function presetIndex() {
- const dispatch$1 = dispatch('favoritePreset', 'recentsChange');
- const MAXRECENTS = 30;
+ var dispatch$1 = dispatch('favoritePreset', 'recentsChange');
+ var MAXRECENTS = 30;
// seed the preset lists with geometry fallbacks
- const POINT = presetPreset('point', { name: 'Point', tags: {}, geometry: ['point', 'vertex'], matchScore: 0.1 } );
- const LINE = presetPreset('line', { name: 'Line', tags: {}, geometry: ['line'], matchScore: 0.1 } );
- const AREA = presetPreset('area', { name: 'Area', tags: { area: 'yes' }, geometry: ['area'], matchScore: 0.1 } );
- const RELATION = presetPreset('relation', { name: 'Relation', tags: {}, geometry: ['relation'], matchScore: 0.1 } );
+ var POINT = presetPreset('point', { name: 'Point', tags: {}, geometry: ['point', 'vertex'], matchScore: 0.1 } );
+ var LINE = presetPreset('line', { name: 'Line', tags: {}, geometry: ['line'], matchScore: 0.1 } );
+ var AREA = presetPreset('area', { name: 'Area', tags: { area: 'yes' }, geometry: ['area'], matchScore: 0.1 } );
+ var RELATION = presetPreset('relation', { name: 'Relation', tags: {}, geometry: ['relation'], matchScore: 0.1 } );
- let _this = presetCollection([POINT, LINE, AREA, RELATION]);
- let _presets = { point: POINT, line: LINE, area: AREA, relation: RELATION };
+ var _this = presetCollection([POINT, LINE, AREA, RELATION]);
+ var _presets = { point: POINT, line: LINE, area: AREA, relation: RELATION };
- let _defaults = {
+ var _defaults = {
point: presetCollection([POINT]),
vertex: presetCollection([POINT]),
line: presetCollection([LINE]),
relation: presetCollection([RELATION])
};
- let _fields = {};
- let _categories = {};
- let _universal = [];
- let _addablePresetIDs = null; // Set of preset IDs that the user can add
- let _recents;
- let _favorites;
+ var _fields = {};
+ var _categories = {};
+ var _universal = [];
+ var _addablePresetIDs = null; // Set of preset IDs that the user can add
+ var _recents;
+ var _favorites;
// Index of presets by (geometry, tag key).
- let _geometryIndex = { point: {}, vertex: {}, line: {}, area: {}, relation: {} };
+ var _geometryIndex = { point: {}, vertex: {}, line: {}, area: {}, relation: {} };
- let _loadPromise;
+ var _loadPromise;
- _this.ensureLoaded = () => {
- if (_loadPromise) return _loadPromise;
+ _this.ensureLoaded = function () {
+ if (_loadPromise) { return _loadPromise; }
return _loadPromise = Promise.all([
_mainFileFetcher.get('preset_categories'),
_mainFileFetcher.get('preset_presets'),
_mainFileFetcher.get('preset_fields')
])
- .then(vals => {
+ .then(function (vals) {
_this.merge({
categories: vals[0],
defaults: vals[1],
};
- _this.merge = (d) => {
+ _this.merge = function (d) {
// Merge Fields
if (d.fields) {
- Object.keys(d.fields).forEach(fieldID => {
- const f = d.fields[fieldID];
+ Object.keys(d.fields).forEach(function (fieldID) {
+ var f = d.fields[fieldID];
if (f) { // add or replace
_fields[fieldID] = presetField(fieldID, f);
} else { // remove
// Merge Presets
if (d.presets) {
- Object.keys(d.presets).forEach(presetID => {
- const p = d.presets[presetID];
+ Object.keys(d.presets).forEach(function (presetID) {
+ var p = d.presets[presetID];
if (p) { // add or replace
- const isAddable = !_addablePresetIDs || _addablePresetIDs.has(presetID);
+ var isAddable = !_addablePresetIDs || _addablePresetIDs.has(presetID);
_presets[presetID] = presetPreset(presetID, p, isAddable, _fields, _presets);
} else { // remove (but not if it's a fallback)
- const existing = _presets[presetID];
+ var existing = _presets[presetID];
if (existing && !existing.isFallback()) {
delete _presets[presetID];
}
// Merge Categories
if (d.categories) {
- Object.keys(d.categories).forEach(categoryID => {
- const c = d.categories[categoryID];
+ Object.keys(d.categories).forEach(function (categoryID) {
+ var c = d.categories[categoryID];
if (c) { // add or replace
_categories[categoryID] = presetCategory(categoryID, c, _this);
} else { // remove
// Merge Defaults
if (d.defaults) {
- Object.keys(d.defaults).forEach(geometry => {
- const def = d.defaults[geometry];
+ Object.keys(d.defaults).forEach(function (geometry) {
+ var def = d.defaults[geometry];
if (Array.isArray(def)) { // add or replace
_defaults[geometry] = presetCollection(
- def.map(id => _presets[id] || _categories[id]).filter(Boolean)
+ def.map(function (id) { return _presets[id] || _categories[id]; }).filter(Boolean)
);
} else { // remove
delete _defaults[geometry];
}
// Rebuild universal fields array
- _universal = Object.values(_fields).filter(field => field.universal);
+ _universal = Object.values(_fields).filter(function (field) { return field.universal; });
// Reset all the preset fields - they'll need to be resolved again
- Object.values(_presets).forEach(preset => preset.resetFields());
+ Object.values(_presets).forEach(function (preset) { return preset.resetFields(); });
// Rebuild geometry index
_geometryIndex = { point: {}, vertex: {}, line: {}, area: {}, relation: {} };
- _this.collection.forEach(preset => {
- (preset.geometry || []).forEach(geometry => {
- let g = _geometryIndex[geometry];
- for (let key in preset.tags) {
+ _this.collection.forEach(function (preset) {
+ (preset.geometry || []).forEach(function (geometry) {
+ var g = _geometryIndex[geometry];
+ for (var key in preset.tags) {
(g[key] = g[key] || []).push(preset);
}
});
};
- _this.match = (entity, resolver) => {
- return resolver.transient(entity, 'presetMatch', () => {
- let geometry = entity.geometry(resolver);
+ _this.match = function (entity, resolver) {
+ return resolver.transient(entity, 'presetMatch', function () {
+ var geometry = entity.geometry(resolver);
// Treat entities on addr:interpolation lines as points, not vertices - #3241
if (geometry === 'vertex' && entity.isOnAddressLine(resolver)) {
geometry = 'point';
};
- _this.matchTags = (tags, geometry) => {
- const geometryMatches = _geometryIndex[geometry];
- let address;
- let best = -1;
- let match;
+ _this.matchTags = function (tags, geometry) {
+ var geometryMatches = _geometryIndex[geometry];
+ var address;
+ var best = -1;
+ var match;
- for (let k in tags) {
+ for (var k in tags) {
// If any part of an address is present, allow fallback to "Address" preset - #4353
if (/^addr:/.test(k) && geometryMatches['addr:*']) {
address = geometryMatches['addr:*'][0];
}
- const keyMatches = geometryMatches[k];
- if (!keyMatches) continue;
+ var keyMatches = geometryMatches[k];
+ if (!keyMatches) { continue; }
- for (let i = 0; i < keyMatches.length; i++) {
- const score = keyMatches[i].matchScore(tags);
+ for (var i = 0; i < keyMatches.length; i++) {
+ var score = keyMatches[i].matchScore(tags);
if (score > best) {
best = score;
match = keyMatches[i];
};
- _this.allowsVertex = (entity, resolver) => {
- if (entity.type !== 'node') return false;
- if (Object.keys(entity.tags).length === 0) return true;
+ _this.allowsVertex = function (entity, resolver) {
+ if (entity.type !== 'node') { return false; }
+ if (Object.keys(entity.tags).length === 0) { return true; }
- return resolver.transient(entity, 'vertexMatch', () => {
+ return resolver.transient(entity, 'vertexMatch', function () {
// address lines allow vertices to act as standalone points
- if (entity.isOnAddressLine(resolver)) return true;
+ if (entity.isOnAddressLine(resolver)) { return true; }
- const geometries = osmNodeGeometriesForTags(entity.tags);
- if (geometries.vertex) return true;
- if (geometries.point) return false;
+ var geometries = osmNodeGeometriesForTags(entity.tags);
+ if (geometries.vertex) { return true; }
+ if (geometries.point) { return false; }
// allow vertices for unspecified points
return true;
});
// with a tag (k, v) is considered to be an area if `k in L && !(v in L[k])`
// (see `Way#isArea()`). In other words, the keys of L form the keeplist,
// and the subkeys form the discardlist.
- _this.areaKeys = () => {
+ _this.areaKeys = function () {
// The ignore list is for keys that imply lines. (We always add `area=yes` for exceptions)
- const ignore = ['barrier', 'highway', 'footway', 'railway', 'junction', 'type'];
- let areaKeys = {};
+ var ignore = ['barrier', 'highway', 'footway', 'railway', 'junction', 'type'];
+ var areaKeys = {};
// ignore name-suggestion-index and deprecated presets
- const presets = _this.collection.filter(p => !p.suggestion && !p.replacement);
+ var presets = _this.collection.filter(function (p) { return !p.suggestion && !p.replacement; });
// keeplist
- presets.forEach(p => {
- let key;
- for (key in p.tags) break; // pick the first tag
- if (!key) return;
- if (ignore.indexOf(key) !== -1) return;
+ presets.forEach(function (p) {
+ var key;
+ for (key in p.tags) { break; } // pick the first tag
+ if (!key) { return; }
+ if (ignore.indexOf(key) !== -1) { return; }
if (p.geometry.indexOf('area') !== -1) { // probably an area..
areaKeys[key] = areaKeys[key] || {};
});
// discardlist
- presets.forEach(p => {
- let key;
+ presets.forEach(function (p) {
+ var key;
for (key in p.addTags) {
// examine all addTags to get a better sense of what can be tagged on lines - #6800
- const value = p.addTags[key];
+ var value = p.addTags[key];
if (key in areaKeys && // probably an area...
p.geometry.indexOf('line') !== -1 && // but sometimes a line
value !== '*') {
};
- _this.pointTags = () => {
- return _this.collection.reduce((pointTags, d) => {
+ _this.pointTags = function () {
+ return _this.collection.reduce(function (pointTags, d) {
// ignore name-suggestion-index, deprecated, and generic presets
- if (d.suggestion || d.replacement || d.searchable === false) return pointTags;
+ if (d.suggestion || d.replacement || d.searchable === false) { return pointTags; }
// only care about the primary tag
- let key;
- for (key in d.tags) break; // pick the first tag
- if (!key) return pointTags;
+ var key;
+ for (key in d.tags) { break; } // pick the first tag
+ if (!key) { return pointTags; }
// if this can be a point
if (d.geometry.indexOf('point') !== -1) {
};
- _this.vertexTags = () => {
- return _this.collection.reduce((vertexTags, d) => {
+ _this.vertexTags = function () {
+ return _this.collection.reduce(function (vertexTags, d) {
// ignore name-suggestion-index, deprecated, and generic presets
- if (d.suggestion || d.replacement || d.searchable === false) return vertexTags;
+ if (d.suggestion || d.replacement || d.searchable === false) { return vertexTags; }
// only care about the primary tag
- let key;
- for (key in d.tags) break; // pick the first tag
- if (!key) return vertexTags;
+ var key;
+ for (key in d.tags) { break; } // pick the first tag
+ if (!key) { return vertexTags; }
// if this can be a vertex
if (d.geometry.indexOf('vertex') !== -1) {
};
- _this.field = (id) => _fields[id];
+ _this.field = function (id) { return _fields[id]; };
- _this.universal = () => _universal;
+ _this.universal = function () { return _universal; };
- _this.defaults = (geometry, n, startWithRecents) => {
- let recents = [];
+ _this.defaults = function (geometry, n, startWithRecents) {
+ var recents = [];
if (startWithRecents) {
recents = _this.recent().matchGeometry(geometry).collection.slice(0, 4);
}
- let defaults;
+ var defaults;
if (_addablePresetIDs) {
defaults = Array.from(_addablePresetIDs).map(function(id) {
var preset = _this.item(id);
- if (preset && preset.matchGeometry(geometry)) return preset;
+ if (preset && preset.matchGeometry(geometry)) { return preset; }
return null;
}).filter(Boolean);
} else {
// pass a Set of addable preset ids
_this.addablePresetIDs = function(val) {
- if (!arguments.length) return _addablePresetIDs;
+ if (!arguments.length) { return _addablePresetIDs; }
// accept and convert arrays
- if (Array.isArray(val)) val = new Set(val);
+ if (Array.isArray(val)) { val = new Set(val); }
_addablePresetIDs = val;
if (_addablePresetIDs) { // reset all presets
- _this.collection.forEach(p => {
+ _this.collection.forEach(function (p) {
// categories aren't addable
- if (p.addable) p.addable(_addablePresetIDs.has(p.id));
+ if (p.addable) { p.addable(_addablePresetIDs.has(p.id)); }
});
} else {
- _this.collection.forEach(p => {
- if (p.addable) p.addable(true);
+ _this.collection.forEach(function (p) {
+ if (p.addable) { p.addable(true); }
});
}
};
- _this.recent = () => {
+ _this.recent = function () {
return presetCollection(
- utilArrayUniq(_this.getRecents().map(d => d.preset))
+ utilArrayUniq(_this.getRecents().map(function (d) { return d.preset; }))
);
};
function RibbonItem(preset, source) {
- let item = {};
+ var item = {};
item.preset = preset;
item.source = source;
- item.isFavorite = () => item.source === 'favorite';
- item.isRecent = () => item.source === 'recent';
- item.matches = (preset) => item.preset.id === preset.id;
- item.minified = () => ({ pID: item.preset.id });
+ item.isFavorite = function () { return item.source === 'favorite'; };
+ item.isRecent = function () { return item.source === 'recent'; };
+ item.matches = function (preset) { return item.preset.id === preset.id; };
+ item.minified = function () { return ({ pID: item.preset.id }); };
return item;
}
function ribbonItemForMinified(d, source) {
if (d && d.pID) {
- const preset = _this.item(d.pID);
- if (!preset) return null;
+ var preset = _this.item(d.pID);
+ if (!preset) { return null; }
return RibbonItem(preset, source);
}
return null;
}
- _this.getGenericRibbonItems = () => {
- return ['point', 'line', 'area'].map(id => RibbonItem(_this.item(id), 'generic'));
+ _this.getGenericRibbonItems = function () {
+ return ['point', 'line', 'area'].map(function (id) { return RibbonItem(_this.item(id), 'generic'); });
};
- _this.getAddable = () => {
- if (!_addablePresetIDs) return [];
+ _this.getAddable = function () {
+ if (!_addablePresetIDs) { return []; }
- return _addablePresetIDs.map((id) => {
- const preset = _this.item(id);
+ return _addablePresetIDs.map(function (id) {
+ var preset = _this.item(id);
if (preset) {
return RibbonItem(preset, 'addable');
}
function setRecents(items) {
_recents = items;
- const minifiedItems = items.map(d => d.minified());
+ var minifiedItems = items.map(function (d) { return d.minified(); });
corePreferences('preset_recents', JSON.stringify(minifiedItems));
dispatch$1.call('recentsChange');
}
- _this.getRecents = () => {
+ _this.getRecents = function () {
if (!_recents) {
// fetch from local storage
_recents = (JSON.parse(corePreferences('preset_recents')) || [])
- .reduce((acc, d) => {
- let item = ribbonItemForMinified(d, 'recent');
- if (item && item.preset.addable()) acc.push(item);
+ .reduce(function (acc, d) {
+ var item = ribbonItemForMinified(d, 'recent');
+ if (item && item.preset.addable()) { acc.push(item); }
return acc;
}, []);
}
};
- _this.addRecent = (preset, besidePreset, after) => {
- const recents = _this.getRecents();
+ _this.addRecent = function (preset, besidePreset, after) {
+ var recents = _this.getRecents();
- const beforeItem = _this.recentMatching(besidePreset);
- let toIndex = recents.indexOf(beforeItem);
- if (after) toIndex += 1;
+ var beforeItem = _this.recentMatching(besidePreset);
+ var toIndex = recents.indexOf(beforeItem);
+ if (after) { toIndex += 1; }
- const newItem = RibbonItem(preset, 'recent');
+ var newItem = RibbonItem(preset, 'recent');
recents.splice(toIndex, 0, newItem);
setRecents(recents);
};
- _this.removeRecent = (preset) => {
- const item = _this.recentMatching(preset);
+ _this.removeRecent = function (preset) {
+ var item = _this.recentMatching(preset);
if (item) {
- let items = _this.getRecents();
+ var items = _this.getRecents();
items.splice(items.indexOf(item), 1);
setRecents(items);
}
};
- _this.recentMatching = (preset) => {
- const items = _this.getRecents();
- for (let i in items) {
+ _this.recentMatching = function (preset) {
+ var items = _this.getRecents();
+ for (var i in items) {
if (items[i].matches(preset)) {
return items[i];
}
};
- _this.moveItem = (items, fromIndex, toIndex) => {
+ _this.moveItem = function (items, fromIndex, toIndex) {
if (fromIndex === toIndex ||
fromIndex < 0 || toIndex < 0 ||
fromIndex >= items.length || toIndex >= items.length
- ) return null;
+ ) { return null; }
items.splice(toIndex, 0, items.splice(fromIndex, 1)[0]);
return items;
};
- _this.moveRecent = (item, beforeItem) => {
- const recents = _this.getRecents();
- const fromIndex = recents.indexOf(item);
- const toIndex = recents.indexOf(beforeItem);
- const items = _this.moveItem(recents, fromIndex, toIndex);
- if (items) setRecents(items);
+ _this.moveRecent = function (item, beforeItem) {
+ var recents = _this.getRecents();
+ var fromIndex = recents.indexOf(item);
+ var toIndex = recents.indexOf(beforeItem);
+ var items = _this.moveItem(recents, fromIndex, toIndex);
+ if (items) { setRecents(items); }
};
- _this.setMostRecent = (preset) => {
- if (preset.searchable === false) return;
+ _this.setMostRecent = function (preset) {
+ if (preset.searchable === false) { return; }
- let items = _this.getRecents();
- let item = _this.recentMatching(preset);
+ var items = _this.getRecents();
+ var item = _this.recentMatching(preset);
if (item) {
items.splice(items.indexOf(item), 1);
} else {
function setFavorites(items) {
_favorites = items;
- const minifiedItems = items.map(d => d.minified());
+ var minifiedItems = items.map(function (d) { return d.minified(); });
corePreferences('preset_favorites', JSON.stringify(minifiedItems));
// call update
dispatch$1.call('favoritePreset');
}
- _this.addFavorite = (preset, besidePreset, after) => {
- const favorites = _this.getFavorites();
+ _this.addFavorite = function (preset, besidePreset, after) {
+ var favorites = _this.getFavorites();
- const beforeItem = _this.favoriteMatching(besidePreset);
- let toIndex = favorites.indexOf(beforeItem);
- if (after) toIndex += 1;
+ var beforeItem = _this.favoriteMatching(besidePreset);
+ var toIndex = favorites.indexOf(beforeItem);
+ if (after) { toIndex += 1; }
- const newItem = RibbonItem(preset, 'favorite');
+ var newItem = RibbonItem(preset, 'favorite');
favorites.splice(toIndex, 0, newItem);
setFavorites(favorites);
};
- _this.toggleFavorite = (preset) => {
- const favs = _this.getFavorites();
- const favorite = _this.favoriteMatching(preset);
+ _this.toggleFavorite = function (preset) {
+ var favs = _this.getFavorites();
+ var favorite = _this.favoriteMatching(preset);
if (favorite) {
favs.splice(favs.indexOf(favorite), 1);
} else {
};
- _this.removeFavorite = (preset) => {
- const item = _this.favoriteMatching(preset);
+ _this.removeFavorite = function (preset) {
+ var item = _this.favoriteMatching(preset);
if (item) {
- const items = _this.getFavorites();
+ var items = _this.getFavorites();
items.splice(items.indexOf(item), 1);
setFavorites(items);
}
};
- _this.getFavorites = () => {
+ _this.getFavorites = function () {
if (!_favorites) {
// fetch from local storage
- let rawFavorites = JSON.parse(corePreferences('preset_favorites'));
+ var rawFavorites = JSON.parse(corePreferences('preset_favorites'));
if (!rawFavorites) {
rawFavorites = [];
corePreferences('preset_favorites', JSON.stringify(rawFavorites));
}
- _favorites = rawFavorites.reduce((output, d) => {
- const item = ribbonItemForMinified(d, 'favorite');
- if (item && item.preset.addable()) output.push(item);
+ _favorites = rawFavorites.reduce(function (output, d) {
+ var item = ribbonItemForMinified(d, 'favorite');
+ if (item && item.preset.addable()) { output.push(item); }
return output;
}, []);
}
};
- _this.favoriteMatching = (preset) => {
- const favs = _this.getFavorites();
- for (let index in favs) {
+ _this.favoriteMatching = function (preset) {
+ var favs = _this.getFavorites();
+ for (var index in favs) {
if (favs[index].matches(preset)) {
return favs[index];
}
function collectShallowDescendants(id) {
var entity = graph.hasEntity(id);
- if (!entity || entity.type !== 'relation') return;
+ if (!entity || entity.type !== 'relation') { return; }
entity.members
.map(function(member) { return member.id; })
return Array.from(seen);
function collectDeepDescendants(id) {
- if (seen.has(id)) return;
+ if (seen.has(id)) { return; }
seen.add(id);
var entity = graph.hasEntity(id);
- if (!entity || entity.type !== 'relation') return;
+ if (!entity || entity.type !== 'relation') { return; }
entity.members
.map(function(member) { return member.id; })
return utilEntitySelector(Array.from(returners));
function collectDeepDescendants(id) {
- if (seen.has(id)) return;
+ if (seen.has(id)) { return; }
seen.add(id);
if (!idsSet.has(id)) {
}
var entity = graph.hasEntity(id);
- if (!entity || entity.type !== 'relation') return;
- if (skipMultipolgonMembers && entity.isMultipolygon()) return;
+ if (!entity || entity.type !== 'relation') { return; }
+ if (skipMultipolgonMembers && entity.isMultipolygon()) { return; }
entity.members
.map(function(member) { return member.id; })
.forEach(collectDeepDescendants); // recurse
return Array.from(nodes);
function collectNodes(id) {
- if (seen.has(id)) return;
+ if (seen.has(id)) { return; }
seen.add(id);
var entity = graph.hasEntity(id);
- if (!entity) return;
+ if (!entity) { return; }
if (entity.type === 'node') {
nodes.add(entity);
}
var tagHash = key + '=' + value;
- if (!tagCounts[tagHash]) tagCounts[tagHash] = 0;
+ if (!tagCounts[tagHash]) { tagCounts[tagHash] = 0; }
tagCounts[tagHash] += 1;
});
});
for (var key in tags) {
- if (!Array.isArray(tags[key])) continue;
+ if (!Array.isArray(tags[key])) { continue; }
// sort values by frequency then alphabetically
tags[key] = tags[key].sort(function(val1, val2) {
function utilStringQs(str) {
var i = 0; // advance past any leading '?' or '#' characters
- while (i < str.length && (str[i] === '?' || str[i] === '#')) i++;
+ while (i < str.length && (str[i] === '?' || str[i] === '#')) { i++; }
str = str.slice(i);
return str.split('&').reduce(function(obj, pair){
var s = document.body;
if (property in s)
- return property;
+ { return property; }
property = property.substr(0, 1).toUpperCase() + property.substr(1);
function utilEditDistance(a, b) {
a = remove$1(a.toLowerCase());
b = remove$1(b.toLowerCase());
- if (a.length === 0) return b.length;
- if (b.length === 0) return a.length;
+ if (a.length === 0) { return b.length; }
+ if (b.length === 0) { return a.length; }
var matrix = [];
for (var i = 0; i <= b.length; i++) { matrix[i] = [i]; }
for (var j = 0; j <= a.length; j++) { matrix[0][j] = j; }
errors[i] = err;
results[i] = data;
remaining--;
- if (!remaining) callback(errors, results);
+ if (!remaining) { callback(errors, results); }
});
});
}
* @returns {Function} a function that returns that value or the value if it's a function
*/
function utilFunctor(value) {
- if (typeof value === 'function') return value;
+ if (typeof value === 'function') { return value; }
return function() {
return value;
};
function osmEntity(attrs) {
// For prototypal inheritance.
- if (this instanceof osmEntity) return;
+ if (this instanceof osmEntity) { return; }
// Create the appropriate subtype.
if (attrs && attrs.type) {
copy: function(resolver, copies) {
if (copies[this.id])
- return copies[this.id];
+ { return copies[this.id]; }
var copy = osmEntity(this, { id: undefined, user: undefined, version: undefined });
copies[this.id] = copy;
var tags = this.tags;
// if there are no tags, none can be deprecated
- if (Object.keys(tags).length === 0) return [];
+ if (Object.keys(tags).length === 0) { return []; }
var deprecated = [];
dataDeprecated.forEach(function(d) {
var oldKeys = Object.keys(d.old);
var matchesDeprecatedTags = oldKeys.every(function(oldKey) {
- if (!tags[oldKey]) return false;
- if (d.old[oldKey] === '*') return true;
+ if (!tags[oldKey]) { return false; }
+ if (d.old[oldKey] === '*') { return true; }
var vals = tags[oldKey].split(';').filter(Boolean);
if (vals.length === 0) {
};
function osmLanes(entity) {
- if (entity.type !== 'way') return null;
- if (!entity.tags.highway) return null;
+ if (entity.type !== 'way') { return null; }
+ if (!entity.tags.highway) { return null; }
var tags = entity.tags;
var isOneWay = entity.isOneWay();
function parseMaxspeed(tags) {
var maxspeed = tags.maxspeed;
- if (!maxspeed) return;
+ if (!maxspeed) { return; }
var maxspeedRegex = /^([0-9][\.0-9]+?)(?:[ ]?(?:km\/h|kmh|kph|mph|knots))?$/;
- if (!maxspeedRegex.test(maxspeed)) return;
+ if (!maxspeedRegex.test(maxspeed)) { return; }
return parseInt(maxspeed, 10);
}
function parseTurnLanes(tag){
- if (!tag) return;
+ if (!tag) { return; }
var validValues = [
'left', 'slight_left', 'sharp_left', 'through', 'right', 'slight_right',
return tag.split('|')
.map(function (s) {
- if (s === '') s = 'none';
+ if (s === '') { s = 'none'; }
return s.split(';')
.map(function (d) {
return validValues.indexOf(d) === -1 ? 'unknown': d;
function parseMaxspeedLanes(tag, maxspeed) {
- if (!tag) return;
+ if (!tag) { return; }
return tag.split('|')
.map(function (s) {
- if (s === 'none') return s;
+ if (s === 'none') { return s; }
var m = parseInt(s, 10);
- if (s === '' || m === maxspeed) return null;
+ if (s === '' || m === maxspeed) { return null; }
return isNaN(m) ? 'unknown': m;
});
}
function parseMiscLanes(tag) {
- if (!tag) return;
+ if (!tag) { return; }
var validValues = [
'yes', 'no', 'designated'
return tag.split('|')
.map(function (s) {
- if (s === '') s = 'no';
+ if (s === '') { s = 'no'; }
return validValues.indexOf(s) === -1 ? 'unknown': s;
});
}
function parseBicycleWay(tag) {
- if (!tag) return;
+ if (!tag) { return; }
var validValues = [
'yes', 'no', 'designated', 'lane'
return tag.split('|')
.map(function (s) {
- if (s === '') s = 'no';
+ if (s === '') { s = 'no'; }
return validValues.indexOf(s) === -1 ? 'unknown': s;
});
}
function mapToLanesObj(lanesObj, data, key) {
- if (data.forward) data.forward.forEach(function(l, i) {
- if (!lanesObj.forward[i]) lanesObj.forward[i] = {};
+ if (data.forward) { data.forward.forEach(function(l, i) {
+ if (!lanesObj.forward[i]) { lanesObj.forward[i] = {}; }
lanesObj.forward[i][key] = l;
- });
- if (data.backward) data.backward.forEach(function(l, i) {
- if (!lanesObj.backward[i]) lanesObj.backward[i] = {};
+ }); }
+ if (data.backward) { data.backward.forEach(function(l, i) {
+ if (!lanesObj.backward[i]) { lanesObj.backward[i] = {}; }
lanesObj.backward[i][key] = l;
- });
- if (data.unspecified) data.unspecified.forEach(function(l, i) {
- if (!lanesObj.unspecified[i]) lanesObj.unspecified[i] = {};
+ }); }
+ if (data.unspecified) { data.unspecified.forEach(function(l, i) {
+ if (!lanesObj.unspecified[i]) { lanesObj.unspecified[i] = {}; }
lanesObj.unspecified[i][key] = l;
- });
+ }); }
}
function osmWay() {
copy: function(resolver, copies) {
- if (copies[this.id]) return copies[this.id];
+ if (copies[this.id]) { return copies[this.id]; }
var copy = osmEntity.prototype.copy.call(this, resolver, copies);
affix: function(node) {
- if (this.nodes[0] === node) return 'prefix';
- if (this.nodes[this.nodes.length - 1] === node) return 'suffix';
+ if (this.nodes[0] === node) { return 'prefix'; }
+ if (this.nodes[this.nodes.length - 1] === node) { return 'suffix'; }
},
}
// implied layer tag..
- if (this.tags.covered === 'yes') return -1;
- if (this.tags.location === 'overground') return 1;
- if (this.tags.location === 'underground') return -1;
- if (this.tags.location === 'underwater') return -10;
-
- if (this.tags.power === 'line') return 10;
- if (this.tags.power === 'minor_line') return 10;
- if (this.tags.aerialway) return 10;
- if (this.tags.bridge) return 1;
- if (this.tags.cutting) return -1;
- if (this.tags.tunnel) return -1;
- if (this.tags.waterway) return -1;
- if (this.tags.man_made === 'pipeline') return -10;
- if (this.tags.boundary) return -10;
+ if (this.tags.covered === 'yes') { return -1; }
+ if (this.tags.location === 'overground') { return 1; }
+ if (this.tags.location === 'underground') { return -1; }
+ if (this.tags.location === 'underwater') { return -10; }
+
+ if (this.tags.power === 'line') { return 10; }
+ if (this.tags.power === 'minor_line') { return 10; }
+ if (this.tags.aerialway) { return 10; }
+ if (this.tags.bridge) { return 1; }
+ if (this.tags.cutting) { return -1; }
+ if (this.tags.tunnel) { return -1; }
+ if (this.tags.waterway) { return -1; }
+ if (this.tags.man_made === 'pipeline') { return -10; }
+ if (this.tags.boundary) { return -10; }
return 0;
},
var width = averageWidths[key][this.tags[key]];
if (key === 'highway') {
var laneCount = this.tags.lanes && parseInt(this.tags.lanes, 10);
- if (!laneCount) laneCount = this.isOneWay() ? 1 : 2;
+ if (!laneCount) { laneCount = this.isOneWay() ? 1 : 2; }
return width * laneCount;
}
// implied oneway tag..
for (var key in this.tags) {
if (key in osmOneWayTags && (this.tags[key] in osmOneWayTags[key]))
- return true;
+ { return true; }
}
return false;
},
isConvex: function(resolver) {
- if (!this.isClosed() || this.isDegenerate()) return null;
+ if (!this.isClosed() || this.isDegenerate()) { return null; }
var nodes = utilArrayUniq(resolver.childNodes(this));
var coords = nodes.map(function(n) { return n.loc; });
isArea: function() {
if (this.tags.area === 'yes')
- return true;
+ { return true; }
if (!this.isClosed() || this.tags.area === 'no')
- return false;
+ { return false; }
return this.tagSuggestingArea() !== null;
},
areAdjacent: function(n1, n2) {
for (var i = 0; i < this.nodes.length; i++) {
if (this.nodes[i] === n1) {
- if (this.nodes[i - 1] === n2) return true;
- if (this.nodes[i + 1] === n2) return true;
+ if (this.nodes[i - 1] === n2) { return true; }
+ if (this.nodes[i + 1] === n2) { return true; }
}
}
return false;
// If this way is not closed, append the beginning node to the end of the nodelist to close it.
close: function() {
- if (this.isClosed() || !this.nodes.length) return this;
+ if (this.isClosed() || !this.nodes.length) { return this; }
var nodes = this.nodes.slice();
nodes = nodes.filter(noRepeatNodes);
// If this way is closed, remove any connector nodes from the end of the nodelist to unclose it.
unclose: function() {
- if (!this.isClosed()) return this;
+ if (!this.isClosed()) { return this; }
var nodes = this.nodes.slice();
var connector = this.first();
var i = 1;
while (i < nodes.length && nodes.length > 2 && nodes[i] === connector) {
nodes.splice(i, 1);
- if (index > i) index--;
+ if (index > i) { index--; }
}
// trailing connectors..
i = nodes.length - 1;
while (i > 0 && nodes.length > 1 && nodes[i] === connector) {
nodes.splice(i, 1);
- if (index > i) index--;
+ if (index > i) { index--; }
i = nodes.length - 1;
}
}
var i = 1;
while (i < nodes.length && nodes.length > 2 && nodes[i] === connector) {
nodes.splice(i, 1);
- if (index > i) index--;
+ if (index > i) { index--; }
}
// trailing connectors..
i = nodes.length - 1;
while (i > 0 && nodes.length > 1 && nodes[i] === connector) {
nodes.splice(i, 1);
- if (index === i) index = 0; // update leading connector instead
+ if (index === i) { index = 0; } // update leading connector instead
i = nodes.length - 1;
}
}
for (var memberIndex in entity.members) {
var member = entity.members[memberIndex];
if (!member.role || member.role === 'outer') {
- if (outerMember) return false;
- if (member.type !== 'way') return false;
- if (!graph.hasEntity(member.id)) return false;
+ if (outerMember) { return false; }
+ if (member.type !== 'way') { return false; }
+ if (!graph.hasEntity(member.id)) { return false; }
outerMember = graph.entity(member.id);
// https://github.com/openstreetmap/iD/issues/613
function osmIsOldMultipolygonOuterMember(entity, graph) {
if (entity.type !== 'way' || Object.keys(entity.tags).filter(osmIsInterestingTag).length === 0)
- return false;
+ { return false; }
var parents = graph.parentRelations(entity);
if (parents.length !== 1)
- return false;
+ { return false; }
var parent = parents[0];
if (!parent.isMultipolygon() || Object.keys(parent.tags).filter(osmIsInterestingTag).length > 1)
- return false;
+ { return false; }
var members = parent.members, member;
for (var i = 0; i < members.length; i++) {
member = members[i];
if (member.id === entity.id && member.role && member.role !== 'outer')
- return false; // Not outer member
+ { return false; } // Not outer member
if (member.id !== entity.id && (!member.role || member.role === 'outer'))
- return false; // Not a simple multipolygon
+ { return false; } // Not a simple multipolygon
}
return parent;
function osmOldMultipolygonOuterMember(entity, graph) {
if (entity.type !== 'way')
- return false;
+ { return false; }
var parents = graph.parentRelations(entity);
if (parents.length !== 1)
- return false;
+ { return false; }
var parent = parents[0];
if (!parent.isMultipolygon() || Object.keys(parent.tags).filter(osmIsInterestingTag).length > 1)
- return false;
+ { return false; }
var members = parent.members, member, outerMember;
for (var i = 0; i < members.length; i++) {
member = members[i];
if (!member.role || member.role === 'outer') {
if (outerMember)
- return false; // Not a simple multipolygon
+ { return false; } // Not a simple multipolygon
outerMember = member;
}
}
if (!outerMember)
- return false;
+ { return false; }
var outerEntity = graph.hasEntity(outerMember.id);
if (!outerEntity || !Object.keys(outerEntity.tags).filter(osmIsInterestingTag).length)
- return false;
+ { return false; }
return outerEntity;
}
var wayMembers = [];
for (i = 0; i < members.length; i++) {
item = members[i];
- if (item.index === -1) continue;
+ if (item.index === -1) { continue; }
if (item.pair) {
wayMembers.push(item.pair[0]);
var geometry = entity.geometry(graph);
var tags = entity.tags;
- if (oldPreset) tags = oldPreset.unsetTags(tags, geometry);
- if (newPreset) tags = newPreset.setTags(tags, geometry, skipFieldDefaults);
+ if (oldPreset) { tags = oldPreset.unsetTags(tags, geometry); }
+ if (newPreset) { tags = newPreset.setTags(tags, geometry, skipFieldDefaults); }
return graph.replace(entity.update({tags: tags}));
};
}
}
- if (val === '') return [];
+ if (val === '') { return []; }
var cardinal = {
north: 0, n: 0,
var lookForward =
(this.tags['traffic_sign:forward'] || v === 'forward' || v === 'both' || v === 'all');
- if (!lookForward && !lookBackward) return;
+ if (!lookForward && !lookBackward) { return; }
var nodeIds = {};
resolver.parentWays(this).forEach(function(parent) {
// vertex is connected to multiple parent ways
for (var i in parents) {
if (parents[i].geometry(resolver) === 'line' &&
- parents[i].hasInterestingTags()) return true;
+ parents[i].hasInterestingTags()) { return true; }
}
} else if (parents.length === 1) {
var way = parents[0];
}, this)
}
};
- if (changeset_id) r.node['@changeset'] = changeset_id;
+ if (changeset_id) { r.node['@changeset'] = changeset_id; }
return r;
},
var action = function(graph, t) {
- if (t === null || !isFinite(t)) t = 1;
+ if (t === null || !isFinite(t)) { t = 1; }
t = Math.min(Math.max(+t, 0), 1);
var way = graph.entity(wayId);
var origNodes = {};
graph.childNodes(way).forEach(function(node) {
- if (!origNodes[node.id]) origNodes[node.id] = node;
+ if (!origNodes[node.id]) { origNodes[node.id] = node; }
});
if (!way.isConvex(graph)) {
var sign = d3_polygonArea(points) > 0 ? 1 : -1;
var ids, i, j, k;
- // we need atleast two key nodes for the algorithm to work
+ // we need at least two key nodes for the algorithm to work
if (!keyNodes.length) {
keyNodes = [nodes[0]];
keyPoints = [points[0]];
}
// key points and nodes are those connected to the ways,
- // they are projected onto the circle, inbetween nodes are moved
- // to constant intervals between key nodes, extra inbetween nodes are
+ // they are projected onto the circle, in between nodes are moved
+ // to constant intervals between key nodes, extra in between nodes are
// added if necessary.
for (i = 0; i < keyPoints.length; i++) {
var nextKeyNodeIndex = (i + 1) % keyNodes.length;
graph = graph.replace(node);
}
- // add new inbetween nodes if necessary
+ // add new in between nodes if necessary
for (j = 0; j < numberNewPoints; j++) {
angle = startAngle + (indexRange + j) * eachAngle;
loc = projection.invert([
// Check for other ways that share these keyNodes..
// If keyNodes are adjacent in both ways,
- // we can add inBetween nodes to that shared way too..
+ // we can add inBetweenNodes to that shared way too..
if (indexRange === 1 && inBetweenNodes.length) {
var startIndex1 = way.nodes.lastIndexOf(startNode.id);
var endIndex1 = way.nodes.lastIndexOf(endNode.id);
var parentWays = graph.parentWays(keyNodes[i]);
for (j = 0; j < parentWays.length; j++) {
var sharedWay = parentWays[j];
- if (sharedWay === way) continue;
+ if (sharedWay === way) { continue; }
if (sharedWay.areAdjacent(startNode.id, endNode.id)) {
var startIndex2 = sharedWay.nodes.lastIndexOf(startNode.id);
function canDeleteNode(node, graph) {
// don't delete nodes still attached to ways or relations
if (graph.parentWays(node).length ||
- graph.parentRelations(node).length) return false;
+ graph.parentRelations(node).length) { return false; }
var geometries = osmNodeGeometriesForTags(node.tags);
// don't delete if this node can be a standalone point
- if (geometries.point) return false;
+ if (geometries.point) { return false; }
// delete if this node only be a vertex
- if (geometries.vertex) return true;
+ if (geometries.vertex) { return true; }
// iD doesn't know if this should be a point or vertex,
// so only delete if there are no interesting tags
var action = function(graph) {
ids.forEach(function(id) {
- if (graph.hasEntity(id)) { // It may have been deleted aready.
+ if (graph.hasEntity(id)) { // It may have been deleted already.
graph = actions[graph.entity(id).type](id)(graph);
}
});
// Choose a survivor node, prefer an existing (not new) node - #4974
for (i = 0; i < nodeIDs.length; i++) {
survivor = graph.entity(nodeIDs[i]);
- if (survivor.version) break; // found one
+ if (survivor.version) { break; } // found one
}
// Replace all non-surviving nodes with the survivor and merge tags.
for (i = 0; i < nodeIDs.length; i++) {
node = graph.entity(nodeIDs[i]);
- if (node.id === survivor.id) continue;
+ if (node.id === survivor.id) { continue; }
parents = graph.parentWays(node);
for (j = 0; j < parents.length; j++) {
// Choose a survivor node, prefer an existing (not new) node - #4974
for (i = 0; i < nodeIDs.length; i++) {
survivor = graph.entity(nodeIDs[i]);
- if (survivor.version) break; // found one
+ if (survivor.version) { break; } // found one
}
// 1. disable if the nodes being connected have conflicting relation roles
restrictionIDs = utilArrayUniq(restrictionIDs);
for (i = 0; i < restrictionIDs.length; i++) {
relation = graph.entity(restrictionIDs[i]);
- if (!relation.isComplete(graph)) continue;
+ if (!relation.isComplete(graph)) { continue; }
var memberWays = relation.members
.filter(function(m) { return m.type === 'way'; })
for (j = 0; j < memberWays.length; j++) {
way = memberWays[j].update({}); // make copy
for (k = 0; k < nodeIDs.length; k++) {
- if (nodeIDs[k] === survivor.id) continue;
+ if (nodeIDs[k] === survivor.id) { continue; }
if (way.areAdjacent(nodeIDs[k], survivor.id)) {
way = way.removeNode(nodeIDs[k]);
function collectNodes(member, collection) {
var entity = graph.hasEntity(member.id);
- if (!entity) return;
+ if (!entity) { return; }
var role = member.role || '';
if (!collection[role]) {
graph = graph.replace(relation);
if (relation.isDegenerate())
- graph = actionDeleteRelation(relation.id)(graph);
+ { graph = actionDeleteRelation(relation.id)(graph); }
return graph;
};
function actionDiscardTags(difference, discardTags) {
discardTags = discardTags || {};
- return (graph) => {
+ return function (graph) {
difference.modified().forEach(checkTags);
difference.created().forEach(checkTags);
return graph;
function checkTags(entity) {
- const keys = Object.keys(entity.tags);
- let didDiscard = false;
- let tags = {};
+ var keys = Object.keys(entity.tags);
+ var didDiscard = false;
+ var tags = {};
- for (let i = 0; i < keys.length; i++) {
- const k = keys[i];
+ for (var i = 0; i < keys.length; i++) {
+ var k = keys[i];
if (discardTags[k] || !entity.tags[k]) {
didDiscard = true;
} else {
};
}
- // Disconect the ways at the given node.
+ // Disconnect the ways at the given node.
//
// Optionally, disconnect only the given ways.
//
action.disabled = function(graph) {
var connections = action.connections(graph);
if (connections.length === 0)
- return 'not_connected';
+ { return 'not_connected'; }
var parentWays = graph.parentWays(graph.entity(nodeId));
var seenRelationIds = {};
});
if (sharedRelation)
- return 'relation';
+ { return 'relation'; }
};
action.limitWays = function(val) {
- if (!arguments.length) return wayIds;
+ if (!arguments.length) { return wayIds; }
wayIds = val;
return action;
};
extractedLoc = entity.extent(graph).center();
}
- var isBuilding = entity.tags.building && entity.tags.building !== 'no';
+ var indoorAreaValues = {
+ area: true,
+ corridor: true,
+ elevator: true,
+ level: true,
+ room: true
+ };
+
+ var isBuilding = (entity.tags.building && entity.tags.building !== 'no') ||
+ (entity.tags['building:part'] && entity.tags['building:part'] !== 'no');
+
+ var isIndoorArea = fromGeometry === 'area' && entity.tags.indoor && indoorAreaValues[entity.tags.indoor];
var entityTags = Object.assign({}, entity.tags); // shallow copy
var pointTags = {};
// don't transfer building-related tags
if (buildingKeysToRetain.indexOf(key) !== -1 ||
key.match(/^building:.{1,}/) ||
- key.match(/^roof:.{1,}/)) continue;
+ key.match(/^roof:.{1,}/)) { continue; }
+ }
+ // leave `indoor` tag on the area
+ if (isIndoorArea && key === 'indoor') {
+ continue;
}
// copy the tag from the entity to the point
if (keysToCopyAndRetain.indexOf(key) !== -1 ||
key.match(/^addr:.{1,}/)) {
continue;
+ } else if (isIndoorArea && key === 'level') {
+ // leave `level` on both features
+ continue;
}
// remove the tag from the entity
delete entityTags[key];
}
- if (!isBuilding && fromGeometry === 'area') {
+ if (!isBuilding && !isIndoorArea && fromGeometry === 'area') {
// ensure that areas keep area geometry
entityTags.area = 'yes';
}
graph = graph.replace(survivor);
joined.forEach(function(way) {
- if (way.id === survivorID) return;
+ if (way.id === survivorID) { return; }
graph.parentRelations(way).forEach(function(parent) {
graph = graph.replace(parent.replaceMember(way, survivor));
// Finds if the join created a single-member multipolygon,
// and if so turns it into a basic area instead
function checkForSimpleMultipolygon() {
- if (!survivor.isClosed()) return;
+ if (!survivor.isClosed()) { return; }
var multipolygons = graph.parentMultipolygons(survivor).filter(function(multipolygon) {
// find multipolygons where the survivor is the only member
});
// skip if this is the single member of multiple multipolygons
- if (multipolygons.length !== 1) return;
+ if (multipolygons.length !== 1) { return; }
var multipolygon = multipolygons[0];
for (var key in survivor.tags) {
if (multipolygon.tags[key] &&
// don't collapse if tags cannot be cleanly merged
- multipolygon.tags[key] !== survivor.tags[key]) return;
+ multipolygon.tags[key] !== survivor.tags[key]) { return; }
}
survivor = survivor.mergeTags(multipolygon.tags);
// If there is a single "interesting" node, use that as the location.
// Otherwise return the average location of all the nodes.
function chooseLoc(graph) {
- if (!nodeIDs.length) return null;
+ if (!nodeIDs.length) { return null; }
var sum = [0,0];
var interestingCount = 0;
var interestingLoc;
var action = function(graph) {
- if (nodeIDs.length < 2) return graph;
+ if (nodeIDs.length < 2) { return graph; }
var toLoc = loc;
if (!toLoc) {
toLoc = chooseLoc(graph);
action.disabled = function(graph) {
- if (nodeIDs.length < 2) return 'not_eligible';
+ if (nodeIDs.length < 2) { return 'not_eligible'; }
for (var i = 0; i < nodeIDs.length; i++) {
var entity = graph.entity(nodeIDs[i]);
- if (entity.type !== 'node') return 'not_eligible';
+ if (entity.type !== 'node') { return 'not_eligible'; }
}
return actionConnect(nodeIDs).disabled(graph);
var groups = {};
for (var i = 0; i < x.length; i++) {
var tagName = Object.keys(x[i])[0];
- if (!groups[tagName]) groups[tagName] = [];
+ if (!groups[tagName]) { groups[tagName] = []; }
groups[tagName].push(x[i][tagName]);
}
var ordered = {};
order.forEach(function(o) {
- if (groups[o]) ordered[o] = groups[o];
+ if (groups[o]) { ordered[o] = groups[o]; }
});
return ordered;
}
var sorted = {};
var relations = changes.relation;
- if (!relations) return changes;
+ if (!relations) { return changes; }
for (var i = 0; i < relations.length; i++) {
var relation = relations[i];
var aId = parseInt(osmEntity.id.toOSM(a.id), 10);
var bId = parseInt(osmEntity.id.toOSM(b.id), 10);
- if (aId < 0 || bId < 0) return aId - bId;
+ if (aId < 0 || bId < 0) { return aId - bId; }
return bId - aId;
};
copy: function(resolver, copies) {
- if (copies[this.id]) return copies[this.id];
+ if (copies[this.id]) { return copies[this.id]; }
var copy = osmEntity.prototype.copy.call(this, resolver, copies);
extent: function(resolver, memo) {
return resolver.transient(this, 'extent', function() {
- if (memo && memo[this.id]) return geoExtent();
+ if (memo && memo[this.id]) { return geoExtent(); }
memo = memo || {};
memo[this.id] = true;
// By default, adding a duplicate member (by id and role) is prevented.
// Return an updated relation.
replaceMember: function(needle, replacement, keepDuplicates) {
- if (!this.memberById(needle.id)) return this;
+ if (!this.memberById(needle.id)) { return this; }
var members = [];
isValidRestriction: function() {
- if (!this.isRestriction()) return false;
+ if (!this.isRestriction()) { return false; }
var froms = this.members.filter(function(m) { return m.role === 'from'; });
var vias = this.members.filter(function(m) { return m.role === 'via'; });
var tos = this.members.filter(function(m) { return m.role === 'to'; });
- if (froms.length !== 1 && this.tags.restriction !== 'no_entry') return false;
- if (froms.some(function(m) { return m.type !== 'way'; })) return false;
+ if (froms.length !== 1 && this.tags.restriction !== 'no_entry') { return false; }
+ if (froms.some(function(m) { return m.type !== 'way'; })) { return false; }
- if (tos.length !== 1 && this.tags.restriction !== 'no_exit') return false;
- if (tos.some(function(m) { return m.type !== 'way'; })) return false;
+ if (tos.length !== 1 && this.tags.restriction !== 'no_exit') { return false; }
+ if (tos.some(function(m) { return m.type !== 'way'; })) { return false; }
- if (vias.length === 0) return false;
- if (vias.length > 1 && vias.some(function(m) { return m.type !== 'way'; })) return false;
+ if (vias.length === 0) { return false; }
+ if (vias.length > 1 && vias.some(function(m) { return m.type !== 'way'; })) { return false; }
return true;
},
for (o = 0; o < outers.length; o++) {
outer = outers[o];
if (geoPolygonContainsPolygon(outer, inner))
- return o;
+ { return o; }
}
for (o = 0; o < outers.length; o++) {
outer = outers[o];
if (geoPolygonIntersectsPolygon(outer, inner, false))
- return o;
+ { return o; }
}
}
}
});
- class QAItem {
- constructor(loc, service, itemType, id, props) {
- // Store required properties
- this.loc = loc;
- this.service = service.title;
- this.itemType = itemType;
-
- // All issues must have an ID for selection, use generic if none specified
- this.id = id ? id : `${QAItem.id()}`;
+ var QAItem = function QAItem(loc, service, itemType, id, props) {
+ // Store required properties
+ this.loc = loc;
+ this.service = service.title;
+ this.itemType = itemType;
- this.update(props);
+ // All issues must have an ID for selection, use generic if none specified
+ this.id = id ? id : ("" + (QAItem.id()));
- // Some QA services have marker icons to differentiate issues
- if (service && typeof service.getIcon === 'function') {
- this.icon = service.getIcon(itemType);
- }
+ this.update(props);
- return this;
+ // Some QA services have marker icons to differentiate issues
+ if (service && typeof service.getIcon === 'function') {
+ this.icon = service.getIcon(itemType);
}
- update(props) {
- // You can't override this inital information
- const { loc, service, itemType, id } = this;
+ return this;
+ };
- Object.keys(props).forEach(prop => this[prop] = props[prop]);
+ QAItem.prototype.update = function update (props) {
+ var this$1 = this;
- this.loc = loc;
- this.service = service;
- this.itemType = itemType;
- this.id = id;
+ // You can't override this initial information
+ var ref = this;
+ var loc = ref.loc;
+ var service = ref.service;
+ var itemType = ref.itemType;
+ var id = ref.id;
- return this;
- }
+ Object.keys(props).forEach(function (prop) { return this$1[prop] = props[prop]; });
- // Generic handling for newly created QAItems
- static id() {
- return this.nextId--;
- }
- }
+ this.loc = loc;
+ this.service = service;
+ this.itemType = itemType;
+ this.id = id;
+
+ return this;
+ };
+
+ // Generic handling for newly created QAItems
+ QAItem.id = function id () {
+ return this.nextId--;
+ };
QAItem.nextId = -1;
// Split a way at the given node.
return parents.filter(function(parent) {
if (_wayIDs && _wayIDs.indexOf(parent.id) === -1)
- return false;
+ { return false; }
if (!_wayIDs && hasLines && parent.geometry(graph) !== 'line')
- return false;
+ { return false; }
if (parent.isClosed()) {
return true;
action.limitWays = function(val) {
- if (!arguments.length) return _wayIDs;
+ if (!arguments.length) { return _wayIDs; }
_wayIDs = val;
return action;
};
}
function coreGraph(other, mutable) {
- if (!(this instanceof coreGraph)) return new coreGraph(other, mutable);
+ if (!(this instanceof coreGraph)) { return new coreGraph(other, mutable); }
if (other instanceof coreGraph) {
var base = other.base();
childNodes: function(entity) {
- if (this._childNodes[entity.id]) return this._childNodes[entity.id];
- if (!entity.nodes) return [];
+ if (this._childNodes[entity.id]) { return this._childNodes[entity.id]; }
+ if (!entity.nodes) { return []; }
var nodes = [];
for (var i = 0; i < entity.nodes.length; i++) {
var entity = entities[i];
if (!entity.visible || (!force && base.entities[entity.id]))
- continue;
+ { continue; }
// Merging data into the base graph
base.entities[entity.id] = entity;
replace: function(entity) {
- if (this.entities[entity.id] === entity) return this;
+ if (this.entities[entity.id] === entity) { return this; }
return this.update(function() {
this._updateCalculated(this.entities[entity.id], entity);
revert: function(id) {
var baseEntity = this.base().entities[id];
var headEntity = this.entities[id];
- if (headEntity === baseEntity) return this;
+ if (headEntity === baseEntity) { return this; }
return this.update(function() {
this._updateCalculated(headEntity, baseEntity);
update: function() {
+ var arguments$1 = arguments;
+
var graph = this.frozen ? coreGraph(this, true) : this;
for (var i = 0; i < arguments.length; i++) {
- arguments[i].call(graph, graph);
+ arguments$1[i].call(graph, graph);
}
- if (this.frozen) graph.frozen = true;
+ if (this.frozen) { graph.frozen = true; }
return graph;
},
}
function isRoad(way) {
- if (way.isArea() || way.isDegenerate()) return false;
+ if (way.isArea() || way.isDegenerate()) { return false; }
var roads = {
'motorway': true,
'motorway_link': true,
var hasWays = false;
for (i = 0; i < checkWays.length; i++) {
way = checkWays[i];
- if (!isRoad(way) && !memberOfRestriction(way)) continue;
+ if (!isRoad(way) && !memberOfRestriction(way)) { continue; }
ways.push(way); // it's a road, or it's already in a turn restriction
hasWays = true;
nodes = utilArrayUniq(graph.childNodes(way));
for (j = 0; j < nodes.length; j++) {
node = nodes[j];
- if (node === vertex) continue; // same thing
- if (vertices.indexOf(node) !== -1) continue; // seen it already
- if (geoSphericalDistance(node.loc, startNode.loc) > maxDistance) continue; // too far from start
+ if (node === vertex) { continue; } // same thing
+ if (vertices.indexOf(node) !== -1) { continue; } // seen it already
+ if (geoSphericalDistance(node.loc, startNode.loc) > maxDistance) { continue; } // too far from start
// a key vertex will have parents that are also roads
var hasParents = false;
parents = graph.parentWays(node);
for (k = 0; k < parents.length; k++) {
parent = parents[k];
- if (parent === way) continue; // same thing
- if (ways.indexOf(parent) !== -1) continue; // seen it already
- if (!isRoad(parent)) continue; // not a road
+ if (parent === way) { continue; } // same thing
+ if (ways.indexOf(parent) !== -1) { continue; } // seen it already
+ if (!isRoad(parent)) { continue; } // not a road
hasParents = true;
break;
}
// For each path found, generate and return a `osmTurn` datastructure.
//
intersection.turns = function(fromWayId, maxViaWay) {
- if (!fromWayId) return [];
- if (!maxViaWay) maxViaWay = 0;
+ if (!fromWayId) { return []; }
+ if (!maxViaWay) { maxViaWay = 0; }
var vgraph = intersection.graph;
var keyVertexIds = intersection.vertices.map(function(v) { return v.id; });
var start = vgraph.entity(fromWayId);
- if (!start || !(start.__from || start.__via)) return [];
+ if (!start || !(start.__from || start.__via)) { return []; }
// maxViaWay=0 from-*-to (0 vias)
// maxViaWay=1 from-*-via-*-to (1 via max)
// traverse the intersection graph and find all the valid paths
function step(entity, currPath, currRestrictions, matchedRestriction) {
currPath = (currPath || []).slice(); // shallow copy
- if (currPath.length >= maxPathLength) return;
+ if (currPath.length >= maxPathLength) { return; }
currPath.push(entity.id);
currRestrictions = (currRestrictions || []).slice(); // shallow copy
var i, j;
var way = parents[i];
// if next way is a oneway incoming to this vertex, skip
- if (way.__oneWay && way.nodes[0] !== entity.id) continue;
+ if (way.__oneWay && way.nodes[0] !== entity.id) { continue; }
// if we have seen it before (allowing for an initial u-turn), skip
- if (currPath.indexOf(way.id) !== -1 && currPath.length >= 3) continue;
+ if (currPath.indexOf(way.id) !== -1 && currPath.length >= 3) { continue; }
// Check all "current" restrictions (where we've already walked the `FROM`)
var restrict = undefined;
// stop looking if we find a "direct" restriction (matching FROM, VIA, TO)
if (restrict && restrict.direct)
- break;
+ { break; }
}
nextWays.push({ way: way, restrict: restrict });
turns.push(osmTurn(turn));
}
- if (currPath[0] === currPath[2]) return; // if we made a u-turn - stop here
+ if (currPath[0] === currPath[2]) { return; } // if we made a u-turn - stop here
}
- if (matchedRestriction && matchedRestriction.end) return; // don't advance any further
+ if (matchedRestriction && matchedRestriction.end) { return; } // don't advance any further
// which nodes can we step into?
var n1 = vgraph.entity(entity.first());
var nextNodes = [];
if (currPath.length > 1) {
- if (dist > maxDistance) return; // the next node is too far
- if (!entity.__via) return; // this way is a leaf / can't be a via
+ if (dist > maxDistance) { return; } // the next node is too far
+ if (!entity.__via) { return; } // this way is a leaf / can't be a via
}
if (!entity.__oneWay && // bidirectional..
nextNodes.forEach(function(nextNode) {
// gather restrictions FROM this way
var fromRestrictions = vgraph.parentRelations(entity).filter(function(r) {
- if (!r.isRestriction()) return false;
+ if (!r.isRestriction()) { return false; }
var f = r.memberByRole('from');
- if (!f || f.id !== entity.id) return false;
+ if (!f || f.id !== entity.id) { return false; }
var isOnly = /^only_/.test(r.tags.restriction);
- if (!isOnly) return true;
+ if (!isOnly) { return true; }
// `only_` restrictions only matter along the direction of the VIA - #4849
var isOnlyVia = false;
isOnlyVia = (v[0].id === nextNode.id);
} else { // via way(s)
for (var i = 0; i < v.length; i++) {
- if (v[i].type !== 'way') continue;
+ if (v[i].type !== 'way') { continue; }
var viaWay = vgraph.entity(v[i].id);
if (viaWay.first() === nextNode.id || viaWay.last() === nextNode.id) {
isOnlyVia = true;
// assumes path is alternating way-node-way of odd length
function pathToTurn(path) {
- if (path.length < 3) return;
+ if (path.length < 3) { return; }
var fromWayId, fromNodeId, fromVertexId;
var toWayId, toNodeId, toVertexId;
var viaWayIds, viaNodeId, isUturn;
if (path.length === 3 && fromWayId === toWayId) { // u turn
var way = vgraph.entity(fromWayId);
- if (way.__oneWay) return null;
+ if (way.__oneWay) { return null; }
isUturn = true;
viaNodeId = fromVertexId = toVertexId = path[1];
geoAngle(toVertex, toNode, projection)) * 180 / Math.PI;
while (angle < 0)
- angle += 360;
+ { angle += 360; }
if (fromNode === toNode)
- return 'no_u_turn';
+ { return 'no_u_turn'; }
if ((angle < 23 || angle > 336) && fromOneWay && toOneWay)
- return 'no_u_turn'; // wider tolerance for u-turn if both ways are oneway
+ { return 'no_u_turn'; } // wider tolerance for u-turn if both ways are oneway
if ((angle < 40 || angle > 319) && fromOneWay && toOneWay && turn.from.vertex !== turn.to.vertex)
- return 'no_u_turn'; // even wider tolerance for u-turn if there is a via way (from !== to)
+ { return 'no_u_turn'; } // even wider tolerance for u-turn if there is a via way (from !== to)
if (angle < 158)
- return 'no_right_turn';
+ { return 'no_right_turn'; }
if (angle > 202)
- return 'no_left_turn';
+ { return 'no_left_turn'; }
return 'no_straight_on';
}
// contained by the kth way.
var contained = polygons.map(function(w, i) {
return polygons.map(function(d, n) {
- if (i === n) return null;
+ if (i === n) { return null; }
return geoPolygonContainsPolygon(
d.nodes.map(function(n) { return n.loc; }),
w.nodes.map(function(n) { return n.loc; })
var fastDeepEqual = function equal(a, b) {
- if (a === b) return true;
+ if (a === b) { return true; }
if (a && b && typeof a == 'object' && typeof b == 'object') {
- if (a.constructor !== b.constructor) return false;
+ if (a.constructor !== b.constructor) { return false; }
var length, i, keys;
if (Array.isArray(a)) {
length = a.length;
- if (length != b.length) return false;
+ if (length != b.length) { return false; }
for (i = length; i-- !== 0;)
- if (!equal(a[i], b[i])) return false;
+ { if (!equal(a[i], b[i])) { return false; } }
return true;
}
- if (a.constructor === RegExp) return a.source === b.source && a.flags === b.flags;
- if (a.valueOf !== Object.prototype.valueOf) return a.valueOf() === b.valueOf();
- if (a.toString !== Object.prototype.toString) return a.toString() === b.toString();
+ if (a.constructor === RegExp) { return a.source === b.source && a.flags === b.flags; }
+ if (a.valueOf !== Object.prototype.valueOf) { return a.valueOf() === b.valueOf(); }
+ if (a.toString !== Object.prototype.toString) { return a.toString() === b.toString(); }
keys = Object.keys(a);
length = keys.length;
- if (length !== Object.keys(b).length) return false;
+ if (length !== Object.keys(b).length) { return false; }
for (i = length; i-- !== 0;)
- if (!Object.prototype.hasOwnProperty.call(b, keys[i])) return false;
+ { if (!Object.prototype.hasOwnProperty.call(b, keys[i])) { return false; } }
for (i = length; i-- !== 0;) {
var key = keys[i];
- if (!equal(a[key], b[key])) return false;
+ if (!equal(a[key], b[key])) { return false; }
}
return true;
// Expects two arrays, finds longest common sequence
function LCS(buffer1, buffer2) {
- let equivalenceClasses = {};
- for (let j = 0; j < buffer2.length; j++) {
- const item = buffer2[j];
+ var equivalenceClasses = {};
+ for (var j = 0; j < buffer2.length; j++) {
+ var item = buffer2[j];
if (equivalenceClasses[item]) {
equivalenceClasses[item].push(j);
} else {
}
}
- const NULLRESULT = { buffer1index: -1, buffer2index: -1, chain: null };
- let candidates = [NULLRESULT];
+ var NULLRESULT = { buffer1index: -1, buffer2index: -1, chain: null };
+ var candidates = [NULLRESULT];
- for (let i = 0; i < buffer1.length; i++) {
- const item = buffer1[i];
- const buffer2indices = equivalenceClasses[item] || [];
- let r = 0;
- let c = candidates[0];
+ for (var i = 0; i < buffer1.length; i++) {
+ var item$1 = buffer1[i];
+ var buffer2indices = equivalenceClasses[item$1] || [];
+ var r = 0;
+ var c = candidates[0];
- for (let jx = 0; jx < buffer2indices.length; jx++) {
- const j = buffer2indices[jx];
+ for (var jx = 0; jx < buffer2indices.length; jx++) {
+ var j$1 = buffer2indices[jx];
- let s;
+ var s = (void 0);
for (s = r; s < candidates.length; s++) {
- if ((candidates[s].buffer2index < j) && ((s === candidates.length - 1) || (candidates[s + 1].buffer2index > j))) {
+ if ((candidates[s].buffer2index < j$1) && ((s === candidates.length - 1) || (candidates[s + 1].buffer2index > j$1))) {
break;
}
}
if (s < candidates.length) {
- const newCandidate = { buffer1index: i, buffer2index: j, chain: candidates[s] };
+ var newCandidate = { buffer1index: i, buffer2index: j$1, chain: candidates[s] };
if (r === candidates.length) {
candidates.push(c);
} else {
// offsets and lengths of mismatched chunks in the input
// buffers. This is used by diff3MergeRegions.
function diffIndices(buffer1, buffer2) {
- const lcs = LCS(buffer1, buffer2);
- let result = [];
- let tail1 = buffer1.length;
- let tail2 = buffer2.length;
-
- for (let candidate = lcs; candidate !== null; candidate = candidate.chain) {
- const mismatchLength1 = tail1 - candidate.buffer1index - 1;
- const mismatchLength2 = tail2 - candidate.buffer2index - 1;
+ var lcs = LCS(buffer1, buffer2);
+ var result = [];
+ var tail1 = buffer1.length;
+ var tail2 = buffer2.length;
+
+ for (var candidate = lcs; candidate !== null; candidate = candidate.chain) {
+ var mismatchLength1 = tail1 - candidate.buffer1index - 1;
+ var mismatchLength2 = tail2 - candidate.buffer2index - 1;
tail1 = candidate.buffer1index;
tail2 = candidate.buffer2index;
// "hunks" are array subsets where `a` or `b` are different from `o`
// https://www.gnu.org/software/diffutils/manual/html_node/diff3-Hunks.html
- let hunks = [];
+ var hunks = [];
function addHunk(h, ab) {
hunks.push({
ab: ab,
});
}
- diffIndices(o, a).forEach(item => addHunk(item, 'a'));
- diffIndices(o, b).forEach(item => addHunk(item, 'b'));
- hunks.sort((x,y) => x.oStart - y.oStart);
+ diffIndices(o, a).forEach(function (item) { return addHunk(item, 'a'); });
+ diffIndices(o, b).forEach(function (item) { return addHunk(item, 'b'); });
+ hunks.sort(function (x,y) { return x.oStart - y.oStart; });
- let results = [];
- let currOffset = 0;
+ var results = [];
+ var currOffset = 0;
function advanceTo(endOffset) {
if (endOffset > currOffset) {
}
while (hunks.length) {
- let hunk = hunks.shift();
- let regionStart = hunk.oStart;
- let regionEnd = hunk.oStart + hunk.oLength;
- let regionHunks = [hunk];
+ var hunk = hunks.shift();
+ var regionStart = hunk.oStart;
+ var regionEnd = hunk.oStart + hunk.oLength;
+ var regionHunks = [hunk];
advanceTo(regionStart);
// Try to pull next overlapping hunk into this region
while (hunks.length) {
- const nextHunk = hunks[0];
- const nextHunkStart = nextHunk.oStart;
- if (nextHunkStart > regionEnd) break; // no overlap
+ var nextHunk = hunks[0];
+ var nextHunkStart = nextHunk.oStart;
+ if (nextHunkStart > regionEnd) { break; } // no overlap
regionEnd = Math.max(regionEnd, nextHunkStart + nextHunk.oLength);
regionHunks.push(hunks.shift());
// Only one hunk touches this region, meaning that there is no conflict here.
// Either `a` or `b` is inserting into a region of `o` unchanged by the other.
if (hunk.abLength > 0) {
- const buffer = (hunk.ab === 'a' ? a : b);
+ var buffer = (hunk.ab === 'a' ? a : b);
results.push({
stable: true,
buffer: hunk.ab,
// Effectively merge all the `a` hunks into one giant hunk, then do the
// same for the `b` hunks; then, correct for skew in the regions of `o`
// that each side changed, and report appropriate spans for the three sides.
- let bounds = {
+ var bounds = {
a: [a.length, -1, o.length, -1],
b: [b.length, -1, o.length, -1]
};
while (regionHunks.length) {
hunk = regionHunks.shift();
- const oStart = hunk.oStart;
- const oEnd = oStart + hunk.oLength;
- const abStart = hunk.abStart;
- const abEnd = abStart + hunk.abLength;
- let b = bounds[hunk.ab];
- b[0] = Math.min(abStart, b[0]);
- b[1] = Math.max(abEnd, b[1]);
- b[2] = Math.min(oStart, b[2]);
- b[3] = Math.max(oEnd, b[3]);
- }
-
- const aStart = bounds.a[0] + (regionStart - bounds.a[2]);
- const aEnd = bounds.a[1] + (regionEnd - bounds.a[3]);
- const bStart = bounds.b[0] + (regionStart - bounds.b[2]);
- const bEnd = bounds.b[1] + (regionEnd - bounds.b[3]);
-
- let result = {
+ var oStart = hunk.oStart;
+ var oEnd = oStart + hunk.oLength;
+ var abStart = hunk.abStart;
+ var abEnd = abStart + hunk.abLength;
+ var b$1 = bounds[hunk.ab];
+ b$1[0] = Math.min(abStart, b$1[0]);
+ b$1[1] = Math.max(abEnd, b$1[1]);
+ b$1[2] = Math.min(oStart, b$1[2]);
+ b$1[3] = Math.max(oEnd, b$1[3]);
+ }
+
+ var aStart = bounds.a[0] + (regionStart - bounds.a[2]);
+ var aEnd = bounds.a[1] + (regionEnd - bounds.a[3]);
+ var bStart = bounds.b[0] + (regionStart - bounds.b[2]);
+ var bEnd = bounds.b[1] + (regionEnd - bounds.b[3]);
+
+ var result = {
stable: false,
aStart: aStart,
aLength: aEnd - aStart,
// between 'ok' and 'conflict' blocks.
// A "false conflict" is where `a` and `b` both change the same from `o`
function diff3Merge(a, o, b, options) {
- let defaults = {
+ var defaults = {
excludeFalseConflicts: true,
stringSeparator: /\s+/
};
options = Object.assign(defaults, options);
- const aString = (typeof a === 'string');
- const oString = (typeof o === 'string');
- const bString = (typeof b === 'string');
+ var aString = (typeof a === 'string');
+ var oString = (typeof o === 'string');
+ var bString = (typeof b === 'string');
- if (aString) a = a.split(options.stringSeparator);
- if (oString) o = o.split(options.stringSeparator);
- if (bString) b = b.split(options.stringSeparator);
+ if (aString) { a = a.split(options.stringSeparator); }
+ if (oString) { o = o.split(options.stringSeparator); }
+ if (bString) { b = b.split(options.stringSeparator); }
- let results = [];
- const regions = diff3MergeRegions(a, o, b);
+ var results = [];
+ var regions = diff3MergeRegions(a, o, b);
- let okBuffer = [];
+ var okBuffer = [];
function flushOk() {
if (okBuffer.length) {
results.push({ ok: okBuffer });
}
function isFalseConflict(a, b) {
- if (a.length !== b.length) return false;
- for (let i = 0; i < a.length; i++) {
- if (a[i] !== b[i]) return false;
+ if (a.length !== b.length) { return false; }
+ for (var i = 0; i < a.length; i++) {
+ if (a[i] !== b[i]) { return false; }
}
return true;
}
- regions.forEach(region => {
+ regions.forEach(function (region) {
if (region.stable) {
- okBuffer.push(...region.bufferContent);
+ okBuffer.push.apply(okBuffer, region.bufferContent);
} else {
if (options.excludeFalseConflicts && isFalseConflict(region.aContent, region.bContent)) {
- okBuffer.push(...region.aContent);
+ okBuffer.push.apply(okBuffer, region.aContent);
} else {
flushOk();
results.push({
_conflicts.push(_t('merge_remote_changes.conflict.deleted', { user: user(remote.user) }));
}
- if (_conflicts.length !== ccount) break;
+ if (_conflicts.length !== ccount) { break; }
updates.replacements.push(target);
}
}
function setupCache(graph) {
function canMove(nodeID) {
// Allow movement of any node that is in the selectedIDs list..
- if (moveIDs.indexOf(nodeID) !== -1) return true;
+ if (moveIDs.indexOf(nodeID) !== -1) { return true; }
// Allow movement of a vertex where 2 ways meet..
var parents = graph.parentWays(graph.entity(nodeID));
- if (parents.length < 3) return true;
+ if (parents.length < 3) { return true; }
// Restrict movement of a vertex where >2 ways meet, unless all parentWays are moving too..
var parentsMoving = parents.every(function(way) { return cache.moving[way.id]; });
- if (!parentsMoving) delete cache.moving[nodeID];
+ if (!parentsMoving) { delete cache.moving[nodeID]; }
return parentsMoving;
}
function cacheEntities(ids) {
for (var i = 0; i < ids.length; i++) {
var id = ids[i];
- if (cache.moving[id]) continue;
+ if (cache.moving[id]) { continue; }
cache.moving[id] = true;
var entity = graph.hasEntity(id);
- if (!entity) continue;
+ if (!entity) { continue; }
if (entity.type === 'node') {
cache.nodes.push(id);
for (var j = 0; j < childNodes.length; j++) {
var node = childNodes[j];
var parents = graph.parentWays(node);
- if (parents.length !== 2) continue;
+ if (parents.length !== 2) { continue; }
var moved = graph.entity(id);
var unmoved = null;
break;
}
}
- if (!unmoved) continue;
+ if (!unmoved) { continue; }
// exclude ways that are overly connected..
- if (utilArrayIntersection(moved.nodes, unmoved.nodes).length > 2) continue;
- if (moved.isArea() || unmoved.isArea()) continue;
+ if (utilArrayIntersection(moved.nodes, unmoved.nodes).length > 2) { continue; }
+ if (moved.isArea() || unmoved.isArea()) { continue; }
cache.intersections.push({
nodeId: node.id,
var next = graph.hasEntity(way.nodes[nextIndex]);
// Don't add orig vertex at endpoint..
- if (!prev || !next) return graph;
+ if (!prev || !next) { return graph; }
var key = wayId + '_' + nodeId;
var orig = cache.replacedVertex[key];
geoAngle(orig, next, projection)) * 180 / Math.PI;
// Don't add orig vertex if it would just make a straight line..
- if (angle > 175 && angle < 185) return graph;
+ if (angle > 175 && angle < 185) { return graph; }
// moving forward or backward along way?
var p1 = [prev.loc, orig.loc, moved.loc, next.loc].map(projection);
var insertAt = (d1 <= d2) ? movedIndex : nextIndex;
// moving around closed loop?
- if (way.isClosed() && insertAt === 0) insertAt = len;
+ if (way.isClosed() && insertAt === 0) { insertAt = len; }
way = way.addNode(orig.id, insertAt);
return graph.replace(orig).replace(way);
var isEP2 = intersection.unmovedIsEP;
// don't move the vertex if it is the endpoint of both ways.
- if (isEP1 && isEP2) return graph;
+ if (isEP1 && isEP2) { return graph; }
var nodes1 = graph.childNodes(way1).filter(function(n) { return n !== vertex; });
var nodes2 = graph.childNodes(way2).filter(function(n) { return n !== vertex; });
- if (way1.isClosed() && way1.first() === vertex.id) nodes1.push(nodes1[0]);
- if (way2.isClosed() && way2.first() === vertex.id) nodes2.push(nodes2[0]);
+ if (way1.isClosed() && way1.first() === vertex.id) { nodes1.push(nodes1[0]); }
+ if (way2.isClosed() && way2.first() === vertex.id) { nodes2.push(nodes2[0]); }
var edge1 = !isEP1 && geoChooseEdge(nodes1, projection(vertex.loc), projection);
var edge2 = !isEP2 && geoChooseEdge(nodes2, projection(vertex.loc), projection);
loc = geoVecInterp(edge1.loc, edge2.loc, 0.5);
edge1 = geoChooseEdge(nodes1, projection(loc), projection);
edge2 = geoChooseEdge(nodes2, projection(loc), projection);
- if (Math.abs(edge1.distance - edge2.distance) < epsilon) break;
+ if (Math.abs(edge1.distance - edge2.distance) < epsilon) { break; }
}
} else if (!isEP1) {
loc = edge1.loc;
var obj = cache.intersections[i];
// Don't limit movement if this is vertex joins 2 endpoints..
- if (obj.movedIsEP && obj.unmovedIsEP) continue;
+ if (obj.movedIsEP && obj.unmovedIsEP) { continue; }
// Don't limit movement if this vertex is not an endpoint anyway..
- if (!obj.movedIsEP) continue;
+ if (!obj.movedIsEP) { continue; }
var node = graph.entity(obj.nodeId);
var start = projection(node.loc);
var hits = geoPathIntersections(movedPath, unmovedPath);
for (var j = 0; i < hits.length; i++) {
- if (geoVecEqual(hits[j], end)) continue;
+ if (geoVecEqual(hits[j], end)) { continue; }
var edge = geoChooseEdge(unmovedNodes, end, projection);
_delta = geoVecSubtract(projection(edge.loc), start);
}
var action = function(graph) {
- if (_delta[0] === 0 && _delta[1] === 0) return graph;
+ if (_delta[0] === 0 && _delta[1] === 0) { return graph; }
setupCache(graph);
function actionMoveNode(nodeID, toLoc) {
var action = function(graph, t) {
- if (t === null || !isFinite(t)) t = 1;
+ if (t === null || !isFinite(t)) { t = 1; }
t = Math.min(Math.max(+t, 0), 1);
var node = graph.entity(nodeID);
var action = function(graph, t) {
- if (t === null || !isFinite(t)) t = 1;
+ if (t === null || !isFinite(t)) { t = 1; }
t = Math.min(Math.max(+t, 0), 1);
var way = graph.entity(wayID);
var isClosed = way.isClosed();
var nodes = graph.childNodes(way).slice(); // shallow copy
- if (isClosed) nodes.pop();
+ if (isClosed) { nodes.pop(); }
if (vertexID !== undefined) {
nodes = nodeSubset(nodes, vertexID, isClosed);
- if (nodes.length !== 3) return graph;
+ if (nodes.length !== 3) { return graph; }
}
// note: all geometry functions here use the unclosed node/point/coord list
}
var bestCoords = bestPoints.map(function(p) { return p.coord; });
- if (isClosed) bestCoords.push(bestCoords[0]);
+ if (isClosed) { bestCoords.push(bestCoords[0]); }
// move the nodes that should move
for (i = 0; i < bestPoints.length; i++) {
// move the nodes along straight segments
for (i = 0; i < straights.length; i++) {
point = straights[i];
- if (nodeCount[point.id] > 1) continue; // skip self-intersections
+ if (nodeCount[point.id] > 1) { continue; } // skip self-intersections
node = graph.entity(point.id);
function calcMotion(point, i, array) {
// don't try to move the endpoints of a non-closed way.
- if (!isClosed && (i === 0 || i === array.length - 1)) return [0, 0];
+ if (!isClosed && (i === 0 || i === array.length - 1)) { return [0, 0]; }
// don't try to move a node that appears more than once (self intersection)
- if (nodeCount[array[i].id] > 1) return [0, 0];
+ if (nodeCount[array[i].id] > 1) { return [0, 0]; }
var a = array[(i - 1 + array.length) % array.length].coord;
var origin = point.coord;
var isClosed = way.isClosed();
var nodes = graph.childNodes(way).slice(); // shallow copy
- if (isClosed) nodes.pop();
+ if (isClosed) { nodes.pop(); }
var allowStraightAngles = false;
if (vertexID !== undefined) {
allowStraightAngles = true;
nodes = nodeSubset(nodes, vertexID, isClosed);
- if (nodes.length !== 3) return 'end_vertex';
+ if (nodes.length !== 3) { return 'end_vertex'; }
}
var coords = nodes.map(function(n) { return projection(n.loc); });
var action = function(graph, t) {
- if (t === null || !isFinite(t)) t = 1;
+ if (t === null || !isFinite(t)) { t = 1; }
t = Math.min(Math.max(+t, 0), 1);
var nodes = nodeIDs.map(function(id) { return graph.entity(id); });
var action = function(graph, t) {
- if (t === null || !isFinite(t)) t = 1;
+ if (t === null || !isFinite(t)) { t = 1; }
t = Math.min(Math.max(+t, 0), 1);
var nodes = allNodes(graph);
var action = function(graph, t) {
- if (t === null || !isFinite(t)) t = 1;
+ if (t === null || !isFinite(t)) { t = 1; }
t = Math.min(Math.max(+t, 0), 1);
var nodes = utilGetAllNodes(reflectIds, graph);
action.useLongAxis = function(val) {
- if (!arguments.length) return _useLongAxis;
+ if (!arguments.length) { return _useLongAxis; }
_useLongAxis = val;
return action;
};
function eventTarget() {
var datum = event.target && event.target.__data__;
- if (typeof datum !== 'object') return null;
+ if (typeof datum !== 'object') { return null; }
if (!(datum instanceof osmEntity) && datum.properties && (datum.properties.entity instanceof osmEntity)) {
return datum.properties.entity;
}
// ignore mouse hovers with buttons pressed unless dragging
if (context.mode().id.indexOf('drag') === -1 &&
(!event.pointerType || event.pointerType === 'mouse') &&
- event.buttons) return;
+ event.buttons) { return; }
var target = eventTarget();
if (target && _targets.indexOf(target) === -1) {
behavior.altDisables = function(val) {
- if (!arguments.length) return _altDisables;
+ if (!arguments.length) { return _altDisables; }
_altDisables = val;
return behavior;
};
behavior.ignoreVertex = function(val) {
- if (!arguments.length) return _ignoreVertex;
+ if (!arguments.length) { return _ignoreVertex; }
_ignoreVertex = val;
return behavior;
};
function datum() {
var mode = context.mode();
var isNote = mode && (mode.id.indexOf('note') !== -1);
- if (event.altKey || isNote) return {};
+ if (event.altKey || isNote) { return {}; }
var element;
if (event.type === 'keydown') {
function pointerdown() {
- if (_downPointer) return;
+ if (_downPointer) { return; }
var pointerLocGetter = utilFastMouse(this);
_downPointer = {
function pointerup() {
- if (!_downPointer || _downPointer.id !== (event.pointerId || 'mouse')) return;
+ if (!_downPointer || _downPointer.id !== (event.pointerId || 'mouse')) { return; }
var downPointer = _downPointer;
_downPointer = null;
_lastPointerUpEvent = event;
- if (downPointer.isCancelled) return;
+ if (downPointer.isCancelled) { return; }
var t2 = +new Date();
var p2 = downPointer.pointerLocGetter(event);
if ((event.pointerType && event.pointerType !== 'mouse') ||
event.buttons ||
- _downPointer) return;
+ _downPointer) { return; }
// HACK: Mobile Safari likes to send one or more `mouse` type pointermove
// events immediately after non-mouse pointerup events; detect and ignore them.
if (_lastPointerUpEvent &&
_lastPointerUpEvent.pointerType !== 'mouse' &&
- event.timeStamp - _lastPointerUpEvent.timeStamp < 100) return;
+ event.timeStamp - _lastPointerUpEvent.timeStamp < 100) { return; }
_lastMouse = event;
dispatch$1.call('move', this, datum());
}
}
- if (_disableSpace || _mouseLeave || !_lastMouse) return;
+ if (_disableSpace || _mouseLeave || !_lastMouse) { return; }
// user must move mouse or release space bar to allow another click
_lastSpace = currSpace;
return property in this && delete this[property];
},
clear: function() {
- for (var property in this) if (property[0] === prefix) delete this[property];
+ for (var property in this) { if (property[0] === prefix) { delete this[property]; } }
},
keys: function() {
var keys = [];
- for (var property in this) if (property[0] === prefix) keys.push(property.slice(1));
+ for (var property in this) { if (property[0] === prefix) { keys.push(property.slice(1)); } }
return keys;
},
values: function() {
var values = [];
- for (var property in this) if (property[0] === prefix) values.push(this[property]);
+ for (var property in this) { if (property[0] === prefix) { values.push(this[property]); } }
return values;
},
entries: function() {
var entries = [];
- for (var property in this) if (property[0] === prefix) entries.push({key: property.slice(1), value: this[property]});
+ for (var property in this) { if (property[0] === prefix) { entries.push({key: property.slice(1), value: this[property]}); } }
return entries;
},
size: function() {
var size = 0;
- for (var property in this) if (property[0] === prefix) ++size;
+ for (var property in this) { if (property[0] === prefix) { ++size; } }
return size;
},
empty: function() {
- for (var property in this) if (property[0] === prefix) return false;
+ for (var property in this) { if (property[0] === prefix) { return false; } }
return true;
},
each: function(f) {
- for (var property in this) if (property[0] === prefix) f(this[property], property.slice(1), this);
+ for (var property in this) { if (property[0] === prefix) { f(this[property], property.slice(1), this); } }
}
};
var map = new Map$1;
// Copy constructor.
- if (object instanceof Map$1) object.each(function(value, key) { map.set(key, value); });
+ if (object instanceof Map$1) { object.each(function(value, key) { map.set(key, value); }); }
// Index array by numeric index or specified key function.
else if (Array.isArray(object)) {
n = object.length,
o;
- if (f == null) while (++i < n) map.set(i, object[i]);
- else while (++i < n) map.set(f(o = object[i], i, object), o);
+ if (f == null) { while (++i < n) { map.set(i, object[i]); } }
+ else { while (++i < n) { map.set(f(o = object[i], i, object), o); } }
}
// Convert object to map.
- else if (object) for (var key in object) map.set(key, object[key]);
+ else if (object) { for (var key in object) { map.set(key, object[key]); } }
return map;
}
var set = new Set$1;
// Copy constructor.
- if (object instanceof Set$1) object.each(function(value) { set.add(value); });
+ if (object instanceof Set$1) { object.each(function(value) { set.add(value); }); }
// Otherwise, assume it’s an array.
else if (object) {
var i = -1, n = object.length;
- if (f == null) while (++i < n) set.add(object[i]);
- else while (++i < n) set.add(f(object[i], i, object));
+ if (f == null) { while (++i < n) { set.add(object[i]); } }
+ else { while (++i < n) { set.add(f(object[i], i, object)); } }
}
return set;
function clamper(domain) {
var a = domain[0], b = domain[domain.length - 1], t;
- if (a > b) t = a, a = b, b = t;
+ if (a > b) { t = a, a = b, b = t; }
return function(x) { return Math.max(a, Math.min(b, x)); };
}
// interpolate(a, b)(t) takes a parameter t in [0,1] and returns the corresponding range value x in [a,b].
function bimap(domain, range, interpolate) {
var d0 = domain[0], d1 = domain[1], r0 = range[0], r1 = range[1];
- if (d1 < d0) d0 = normalize(d1, d0), r0 = interpolate(r1, r0);
- else d0 = normalize(d0, d1), r0 = interpolate(r0, r1);
+ if (d1 < d0) { d0 = normalize(d1, d0), r0 = interpolate(r1, r0); }
+ else { d0 = normalize(d0, d1), r0 = interpolate(r0, r1); }
return function(x) { return r0(d0(x)); };
}
// significant digits p, where x is positive and p is in [1, 21] or undefined.
// For example, formatDecimal(1.23) returns ["123", 0].
function formatDecimal(x, p) {
- if ((i = (x = p ? x.toExponential(p - 1) : x.toExponential()).indexOf("e")) < 0) return null; // NaN, ±Infinity
+ if ((i = (x = p ? x.toExponential(p - 1) : x.toExponential()).indexOf("e")) < 0) { return null; } // NaN, ±Infinity
var i, coefficient = x.slice(0, i);
// The string returned by toExponential either has the form \d\.\d+e[-+]\d+
length = 0;
while (i > 0 && g > 0) {
- if (length + g + 1 > width) g = Math.max(1, width - length);
+ if (length + g + 1 > width) { g = Math.max(1, width - length); }
t.push(value.substring(i -= g, i + g));
- if ((length += g + 1) > width) break;
+ if ((length += g + 1) > width) { break; }
g = grouping[j = (j + 1) % grouping.length];
}
var re = /^(?:(.)?([<>=^]))?([+\-( ])?([$#])?(0)?(\d+)?(,)?(\.\d+)?(~)?([a-z%])?$/i;
function formatSpecifier(specifier) {
- if (!(match = re.exec(specifier))) throw new Error("invalid format: " + specifier);
+ if (!(match = re.exec(specifier))) { throw new Error("invalid format: " + specifier); }
var match;
return new FormatSpecifier({
fill: match[1],
out: for (var n = s.length, i = 1, i0 = -1, i1; i < n; ++i) {
switch (s[i]) {
case ".": i0 = i1 = i; break;
- case "0": if (i0 === 0) i0 = i; i1 = i; break;
- default: if (!+s[i]) break out; if (i0 > 0) i0 = 0; break;
+ case "0": if (i0 === 0) { i0 = i; } i1 = i; break;
+ default: if (!+s[i]) { break out; } if (i0 > 0) { i0 = 0; } break;
}
}
return i0 > 0 ? s.slice(0, i0) + s.slice(i1 + 1) : s;
function formatPrefixAuto(x, p) {
var d = formatDecimal(x, p);
- if (!d) return x + "";
+ if (!d) { return x + ""; }
var coefficient = d[0],
exponent = d[1],
i = exponent - (prefixExponent = Math.max(-8, Math.min(8, Math.floor(exponent / 3))) * 3) + 1,
function formatRounded(x, p) {
var d = formatDecimal(x, p);
- if (!d) return x + "";
+ if (!d) { return x + ""; }
var coefficient = d[0],
exponent = d[1];
return exponent < 0 ? "0." + new Array(-exponent).join("0") + coefficient
type = specifier.type;
// The "n" type is an alias for ",g".
- if (type === "n") comma = true, type = "g";
+ if (type === "n") { comma = true, type = "g"; }
// The "" type, and any invalid type, is an alias for ".12~g".
- else if (!formatTypes[type]) precision === undefined && (precision = 12), trim = true, type = "g";
+ else if (!formatTypes[type]) { precision === undefined && (precision = 12), trim = true, type = "g"; }
// If zero fill is specified, padding goes after sign and before digits.
- if (zero || (fill === "0" && align === "=")) zero = true, fill = "0", align = "=";
+ if (zero || (fill === "0" && align === "=")) { zero = true, fill = "0", align = "="; }
// Compute the prefix and suffix.
// For SI-prefix, the suffix is lazily computed.
value = isNaN(value) ? nan : formatType(Math.abs(value), precision);
// Trim insignificant zeros.
- if (trim) value = formatTrim(value);
+ if (trim) { value = formatTrim(value); }
// If a negative value rounds to zero after formatting, and no explicit positive sign is requested, hide the sign.
- if (valueNegative && +value === 0 && sign !== "+") valueNegative = false;
+ if (valueNegative && +value === 0 && sign !== "+") { valueNegative = false; }
// Compute the prefix and suffix.
valuePrefix = (valueNegative ? (sign === "(" ? sign : minus) : sign === "-" || sign === "(" ? "" : sign) + valuePrefix;
}
// If the fill character is not "0", grouping is applied before padding.
- if (comma && !zero) value = group(value, Infinity);
+ if (comma && !zero) { value = group(value, Infinity); }
// Compute the padding.
var length = valuePrefix.length + value.length + valueSuffix.length,
padding = length < width ? new Array(width - length + 1).join(fill) : "";
// If the fill character is "0", grouping is applied after padding.
- if (comma && zero) value = group(padding + value, padding.length ? width - valueSuffix.length : Infinity), padding = "";
+ if (comma && zero) { value = group(padding + value, padding.length ? width - valueSuffix.length : Infinity), padding = ""; }
// Reconstruct the final output based on the desired alignment.
switch (align) {
switch (specifier.type) {
case "s": {
var value = Math.max(Math.abs(start), Math.abs(stop));
- if (specifier.precision == null && !isNaN(precision = precisionPrefix(step, value))) specifier.precision = precision;
+ if (specifier.precision == null && !isNaN(precision = precisionPrefix(step, value))) { specifier.precision = precision; }
return formatPrefix(specifier, value);
}
case "":
case "g":
case "p":
case "r": {
- if (specifier.precision == null && !isNaN(precision = precisionRound(step, Math.max(Math.abs(start), Math.abs(stop))))) specifier.precision = precision - (specifier.type === "e");
+ if (specifier.precision == null && !isNaN(precision = precisionRound(step, Math.max(Math.abs(start), Math.abs(stop))))) { specifier.precision = precision - (specifier.type === "e"); }
break;
}
case "f":
case "%": {
- if (specifier.precision == null && !isNaN(precision = precisionFixed(step))) specifier.precision = precision - (specifier.type === "%") * 2;
+ if (specifier.precision == null && !isNaN(precision = precisionFixed(step))) { specifier.precision = precision - (specifier.type === "%") * 2; }
break;
}
}
};
scale.nice = function(count) {
- if (count == null) count = 10;
+ if (count == null) { count = 10; }
var d = domain(),
i0 = 0,
function rescale() {
var i = -1;
domain = new Array(n);
- while (++i < n) domain[i] = ((i + 1) * x1 - (i - n) * x0) / (n + 1);
+ while (++i < n) { domain[i] = ((i + 1) * x1 - (i - n) * x0) / (n + 1); }
return scale;
}
function keypress() {
// prevent operations during low zoom selection
- if (!context.map().withinEditableZoom()) return;
+ if (!context.map().withinEditableZoom()) { return; }
+
+ if (_operation.availableForKeypress && !_operation.availableForKeypress()) { return; }
event.preventDefault();
+
var disabled = _operation.disabled();
if (disabled) {
.iconClass('operation')
.text(_operation.annotation() || _operation.title)();
- if (_operation.point) _operation.point(null);
+ if (_operation.point) { _operation.point(null); }
_operation();
}
}
behavior.which = function (_) {
- if (!arguments.length) return _operation;
+ if (!arguments.length) { return _operation; }
_operation = _;
return behavior;
};
var entity = context.entity(entityID);
- if (entity.type !== 'way' || new Set(entity.nodes).size <= 1) return null;
+ if (entity.type !== 'way' || new Set(entity.nodes).size <= 1) { return null; }
if (!_extent) {
_extent = entity.extent(context.graph());
}
var operation = function() {
- if (!_actions.length) return;
+ if (!_actions.length) { return; }
var combinedAction = function(graph, t) {
_actions.forEach(function(action) {
// don't cache this because the visible extent could change
operation.disabled = function() {
- if (!_actions.length) return '';
+ if (!_actions.length) { return ''; }
var actionDisableds = _actions.map(function(action) {
return action.disabled(context.graph());
function someMissing() {
- if (context.inIntro()) return false;
+ if (context.inIntro()) { return false; }
var osm = context.connection();
if (osm) {
var missing = _coords.filter(function(loc) { return !osm.isDataLoaded(loc); });
}
if (detected.os === 'win') {
- if (code === '⌘⇧Z') return 'Ctrl+Y';
+ if (code === '⌘⇧Z') { return 'Ctrl+Y'; }
}
var result = '',
// return a display-focused string for a given keyboard code
uiCmd.display = function(code) {
- if (code.length !== 1) return code;
+ if (code.length !== 1) { return code; }
var detected = utilDetect();
var mac = (detected.os === 'mac');
function someMissing() {
- if (context.inIntro()) return false;
+ if (context.inIntro()) { return false; }
var osm = context.connection();
if (osm) {
var missing = coords.filter(function(loc) { return !osm.isDataLoaded(loc); });
function protectedMember(id) {
var entity = context.entity(id);
- if (entity.type !== 'way') return false;
+ if (entity.type !== 'way') { return false; }
var parents = context.graph().parentRelations(entity);
for (var i = 0; i < parents.length; i++) {
// square a line/area
if (entity.type === 'way' && new Set(entity.nodes).size > 2 ) {
- if (_type && _type !== 'feature') return null;
+ if (_type && _type !== 'feature') { return null; }
_type = 'feature';
return actionOrthogonalize(entityID, context.projection);
// square a single vertex
} else if (geometry === 'vertex') {
- if (_type && _type !== 'corner') return null;
+ if (_type && _type !== 'corner') { return null; }
_type = 'corner';
var graph = context.graph();
var parents = graph.parentWays(entity);
var operation = function() {
- if (!_actions.length) return;
+ if (!_actions.length) { return; }
var combinedAction = function(graph, t) {
_actions.forEach(function(action) {
// don't cache this because the visible extent could change
operation.disabled = function() {
- if (!_actions.length) return '';
+ if (!_actions.length) { return ''; }
var actionDisableds = _actions.map(function(action) {
return action.disabled(context.graph());
function someMissing() {
- if (context.inIntro()) return false;
+ if (context.inIntro()) { return false; }
var osm = context.connection();
if (osm) {
var missing = _coords.filter(function(loc) { return !osm.isDataLoaded(loc); });
function someMissing() {
- if (context.inIntro()) return false;
+ if (context.inIntro()) { return false; }
var osm = context.connection();
if (osm) {
var missing = coords.filter(function(loc) { return !osm.isDataLoaded(loc); });
function someMissing() {
- if (context.inIntro()) return false;
+ if (context.inIntro()) { return false; }
var osm = context.connection();
if (osm) {
var missing = coords.filter(function(loc) { return !osm.isDataLoaded(loc); });
var currMouse = context.map().mouse();
var currAngle = Math.atan2(currMouse[1] - _pivot[1], currMouse[0] - _pivot[0]);
- if (typeof _prevAngle === 'undefined') _prevAngle = currAngle;
+ if (typeof _prevAngle === 'undefined') { _prevAngle = currAngle; }
var delta = currAngle - _prevAngle;
fn(actionRotate(entityIDs, _pivot, delta, projection));
mode.selectedIDs = function() {
- if (!arguments.length) return entityIDs;
+ if (!arguments.length) { return entityIDs; }
// no assign
return mode;
};
function someMissing() {
- if (context.inIntro()) return false;
+ if (context.inIntro()) { return false; }
var osm = context.connection();
if (osm) {
var missing = coords.filter(function(loc) { return !osm.isDataLoaded(loc); });
function startNudge(nudge) {
- if (_nudgeInterval) window.clearInterval(_nudgeInterval);
+ if (_nudgeInterval) { window.clearInterval(_nudgeInterval); }
_nudgeInterval = window.setInterval(function() {
context.map().pan(nudge);
doMove(nudge);
function cancel() {
if (baseGraph) {
- while (context.graph() !== baseGraph) context.pop();
+ while (context.graph() !== baseGraph) { context.pop(); }
context.enter(modeBrowse(context));
} else {
context.pop();
mode.selectedIDs = function() {
- if (!arguments.length) return entityIDs;
+ if (!arguments.length) { return entityIDs; }
// no assign
return mode;
};
function doPaste() {
// prevent paste during low zoom selection
- if (!context.map().withinEditableZoom()) return;
+ if (!context.map().withinEditableZoom()) { return; }
event.preventDefault();
var projection = context.projection;
var viewport = geoExtent(projection.clipExtent()).polygon();
- if (!geoPointInPolygon(mouse, viewport)) return;
+ if (!geoPointInPolygon(mouse, viewport)) { return; }
var oldIDs = context.copyIDs();
- if (!oldIDs.length) return;
+ if (!oldIDs.length) { return; }
var extent = geoExtent();
var oldGraph = context.copyGraph();
function pointerdown() {
- if (_pointerId) return;
+ if (_pointerId) { return; }
_pointerId = event.pointerId || 'mouse';
function pointermove() {
- if (_pointerId !== (event.pointerId || 'mouse')) return;
+ if (_pointerId !== (event.pointerId || 'mouse')) { return; }
var p = pointerLocGetter(event);
var dist = geoVecLength(startOrigin, p);
var tolerance = event.pointerType === 'pen' ? _penTolerancePx : _tolerancePx;
// don't start until the drag has actually moved somewhat
- if (dist < tolerance) return;
+ if (dist < tolerance) { return; }
started = true;
_event({ type: 'start' });
function pointerup() {
- if (_pointerId !== (event.pointerId || 'mouse')) return;
+ if (_pointerId !== (event.pointerId || 'mouse')) { return; }
_pointerId = null;
function behavior(selection) {
- _pointerId = null;
var matchesSelector = utilPrefixDOMProperty('matchesSelector');
var delegate = pointerdown;
behavior.selector = function(_) {
- if (!arguments.length) return _selector;
+ if (!arguments.length) { return _selector; }
_selector = _;
return behavior;
};
behavior.origin = function(_) {
- if (!arguments.length) return _origin;
+ if (!arguments.length) { return _origin; }
_origin = _;
return behavior;
};
behavior.target = function() {
- if (!arguments.length) return _target;
+ if (!arguments.length) { return _target; }
_target = arguments[0];
_event = eventOf(_target, Array.prototype.slice.call(arguments, 1));
return behavior;
behavior.surface = function() {
- if (!arguments.length) return _surface;
+ if (!arguments.length) { return _surface; }
_surface = arguments[0];
return behavior;
};
function startNudge(entity, nudge) {
- if (_nudgeInterval) window.clearInterval(_nudgeInterval);
+ if (_nudgeInterval) { window.clearInterval(_nudgeInterval); }
_nudgeInterval = window.setInterval(function() {
context.map().pan(nudge);
doMove(entity, nudge);
function shouldSnapToNode(target) {
- if (!_activeEntity) return false;
+ if (!_activeEntity) { return false; }
return _activeEntity.geometry(context.graph()) !== 'vertex' ||
(target.geometry(context.graph()) === 'vertex' || _mainPresetIndex.allowsVertex(target, context.graph()));
}
// test any parent multipolygons for valid geometry
var relations = graph.parentRelations(parent);
for (j = 0; j < relations.length; j++) {
- if (!relations[j].isMultipolygon()) continue;
+ if (!relations[j].isMultipolygon()) { continue; }
var rings = osmJoinWays(relations[j].members, graph);
// test active ring for intersections with other rings in the multipolygon
for (k = 0; k < rings.length; k++) {
- if (k === activeIndex) continue;
+ if (k === activeIndex) { continue; }
- // make sure active ring doesnt cross passive rings
+ // make sure active ring doesn't cross passive rings
if (geoHasLineIntersections(rings[activeIndex].nodes, rings[k].nodes, entity.id)) {
return 'multipolygonRing';
}
function move(entity) {
- if (_isCancelled) return;
+ if (_isCancelled) { return; }
event.sourceEvent.stopPropagation();
context.surface().classed('nope-disabled', event.sourceEvent.altKey);
}
function end(entity) {
- if (_isCancelled) return;
+ if (_isCancelled) { return; }
var wasPoint = entity.geometry(context.graph()) === 'point';
var action = function(graph, t) {
// last time through, pop off the bounceback perform.
// it will then overwrite the initial perform with a moveNode that does nothing
- if (t === 1) context.pop();
+ if (t === 1) { context.pop(); }
return moveNode(graph, t);
};
action.transitionable = true;
mode.selectedIDs = function() {
- if (!arguments.length) return _activeEntity ? [_activeEntity.id] : [];
+ if (!arguments.length) { return _activeEntity ? [_activeEntity.id] : []; }
// no assign
return mode;
};
mode.activeID = function() {
- if (!arguments.length) return _activeEntity && _activeEntity.id;
+ if (!arguments.length) { return _activeEntity && _activeEntity.id; }
// no assign
return mode;
};
mode.restoreSelectedIDs = function(_) {
- if (!arguments.length) return _restoreSelectedIDs;
+ if (!arguments.length) { return _restoreSelectedIDs; }
_restoreSelectedIDs = _;
return mode;
};
var j = right;
swap(arr, left, k);
- if (compare(arr[right], t) > 0) swap(arr, left, right);
+ if (compare(arr[right], t) > 0) { swap(arr, left, right); }
while (i < j) {
swap(arr, i, j);
i++;
j--;
- while (compare(arr[i], t) < 0) i++;
- while (compare(arr[j], t) > 0) j--;
+ while (compare(arr[i], t) < 0) { i++; }
+ while (compare(arr[j], t) > 0) { j--; }
}
- if (compare(arr[left], t) === 0) swap(arr, left, j);
+ if (compare(arr[left], t) === 0) { swap(arr, left, j); }
else {
j++;
swap(arr, j, right);
}
- if (j <= k) left = j + 1;
- if (k <= j) right = j - 1;
+ if (j <= k) { left = j + 1; }
+ if (k <= j) { right = j - 1; }
}
}
return a < b ? -1 : a > b ? 1 : 0;
}
- class RBush {
- constructor(maxEntries = 9) {
- // max entries in a node is 9 by default; min node fill is 40% for best performance
- this._maxEntries = Math.max(4, maxEntries);
- this._minEntries = Math.max(2, Math.ceil(this._maxEntries * 0.4));
- this.clear();
- }
+ var RBush = function RBush(maxEntries) {
+ if ( maxEntries === void 0 ) maxEntries = 9;
- all() {
- return this._all(this.data, []);
- }
+ // max entries in a node is 9 by default; min node fill is 40% for best performance
+ this._maxEntries = Math.max(4, maxEntries);
+ this._minEntries = Math.max(2, Math.ceil(this._maxEntries * 0.4));
+ this.clear();
+ };
- search(bbox) {
- let node = this.data;
- const result = [];
+ RBush.prototype.all = function all () {
+ return this._all(this.data, []);
+ };
- if (!intersects(bbox, node)) return result;
+ RBush.prototype.search = function search (bbox) {
+ var node = this.data;
+ var result = [];
- const toBBox = this.toBBox;
- const nodesToSearch = [];
+ if (!intersects(bbox, node)) { return result; }
- while (node) {
- for (let i = 0; i < node.children.length; i++) {
- const child = node.children[i];
- const childBBox = node.leaf ? toBBox(child) : child;
-
- if (intersects(bbox, childBBox)) {
- if (node.leaf) result.push(child);
- else if (contains$1(bbox, childBBox)) this._all(child, result);
- else nodesToSearch.push(child);
- }
+ var toBBox = this.toBBox;
+ var nodesToSearch = [];
+
+ while (node) {
+ for (var i = 0; i < node.children.length; i++) {
+ var child = node.children[i];
+ var childBBox = node.leaf ? toBBox(child) : child;
+
+ if (intersects(bbox, childBBox)) {
+ if (node.leaf) { result.push(child); }
+ else if (contains$1(bbox, childBBox)) { this._all(child, result); }
+ else { nodesToSearch.push(child); }
}
- node = nodesToSearch.pop();
}
-
- return result;
+ node = nodesToSearch.pop();
}
- collides(bbox) {
- let node = this.data;
+ return result;
+ };
- if (!intersects(bbox, node)) return false;
+ RBush.prototype.collides = function collides (bbox) {
+ var node = this.data;
- const nodesToSearch = [];
- while (node) {
- for (let i = 0; i < node.children.length; i++) {
- const child = node.children[i];
- const childBBox = node.leaf ? this.toBBox(child) : child;
+ if (!intersects(bbox, node)) { return false; }
- if (intersects(bbox, childBBox)) {
- if (node.leaf || contains$1(bbox, childBBox)) return true;
- nodesToSearch.push(child);
- }
+ var nodesToSearch = [];
+ while (node) {
+ for (var i = 0; i < node.children.length; i++) {
+ var child = node.children[i];
+ var childBBox = node.leaf ? this.toBBox(child) : child;
+
+ if (intersects(bbox, childBBox)) {
+ if (node.leaf || contains$1(bbox, childBBox)) { return true; }
+ nodesToSearch.push(child);
}
- node = nodesToSearch.pop();
}
-
- return false;
+ node = nodesToSearch.pop();
}
- load(data) {
- if (!(data && data.length)) return this;
+ return false;
+ };
- if (data.length < this._minEntries) {
- for (let i = 0; i < data.length; i++) {
- this.insert(data[i]);
- }
- return this;
- }
+ RBush.prototype.load = function load (data) {
+ if (!(data && data.length)) { return this; }
- // recursively build the tree with the given data from scratch using OMT algorithm
- let node = this._build(data.slice(), 0, data.length - 1, 0);
+ if (data.length < this._minEntries) {
+ for (var i = 0; i < data.length; i++) {
+ this.insert(data[i]);
+ }
+ return this;
+ }
- if (!this.data.children.length) {
- // save as is if tree is empty
- this.data = node;
+ // recursively build the tree with the given data from scratch using OMT algorithm
+ var node = this._build(data.slice(), 0, data.length - 1, 0);
- } else if (this.data.height === node.height) {
- // split root if trees have the same height
- this._splitRoot(this.data, node);
+ if (!this.data.children.length) {
+ // save as is if tree is empty
+ this.data = node;
- } else {
- if (this.data.height < node.height) {
- // swap trees if inserted one is bigger
- const tmpNode = this.data;
- this.data = node;
- node = tmpNode;
- }
+ } else if (this.data.height === node.height) {
+ // split root if trees have the same height
+ this._splitRoot(this.data, node);
- // insert the small tree into the large tree at appropriate level
- this._insert(node, this.data.height - node.height - 1, true);
+ } else {
+ if (this.data.height < node.height) {
+ // swap trees if inserted one is bigger
+ var tmpNode = this.data;
+ this.data = node;
+ node = tmpNode;
}
- return this;
+ // insert the small tree into the large tree at appropriate level
+ this._insert(node, this.data.height - node.height - 1, true);
}
- insert(item) {
- if (item) this._insert(item, this.data.height - 1);
- return this;
- }
+ return this;
+ };
- clear() {
- this.data = createNode([]);
- return this;
- }
+ RBush.prototype.insert = function insert (item) {
+ if (item) { this._insert(item, this.data.height - 1); }
+ return this;
+ };
- remove(item, equalsFn) {
- if (!item) return this;
+ RBush.prototype.clear = function clear () {
+ this.data = createNode([]);
+ return this;
+ };
- let node = this.data;
- const bbox = this.toBBox(item);
- const path = [];
- const indexes = [];
- let i, parent, goingUp;
+ RBush.prototype.remove = function remove (item, equalsFn) {
+ if (!item) { return this; }
- // depth-first iterative tree traversal
- while (node || path.length) {
+ var node = this.data;
+ var bbox = this.toBBox(item);
+ var path = [];
+ var indexes = [];
+ var i, parent, goingUp;
- if (!node) { // go up
- node = path.pop();
- parent = path[path.length - 1];
- i = indexes.pop();
- goingUp = true;
- }
+ // depth-first iterative tree traversal
+ while (node || path.length) {
- if (node.leaf) { // check current node
- const index = findItem(item, node.children, equalsFn);
+ if (!node) { // go up
+ node = path.pop();
+ parent = path[path.length - 1];
+ i = indexes.pop();
+ goingUp = true;
+ }
- if (index !== -1) {
- // item found, remove the item and condense tree upwards
- node.children.splice(index, 1);
- path.push(node);
- this._condense(path);
- return this;
- }
- }
+ if (node.leaf) { // check current node
+ var index = findItem(item, node.children, equalsFn);
- if (!goingUp && !node.leaf && contains$1(node, bbox)) { // go down
+ if (index !== -1) {
+ // item found, remove the item and condense tree upwards
+ node.children.splice(index, 1);
path.push(node);
- indexes.push(i);
- i = 0;
- parent = node;
- node = node.children[0];
+ this._condense(path);
+ return this;
+ }
+ }
- } else if (parent) { // go right
- i++;
- node = parent.children[i];
- goingUp = false;
+ if (!goingUp && !node.leaf && contains$1(node, bbox)) { // go down
+ path.push(node);
+ indexes.push(i);
+ i = 0;
+ parent = node;
+ node = node.children[0];
- } else node = null; // nothing found
- }
+ } else if (parent) { // go right
+ i++;
+ node = parent.children[i];
+ goingUp = false;
- return this;
+ } else { node = null; } // nothing found
}
- toBBox(item) { return item; }
+ return this;
+ };
- compareMinX(a, b) { return a.minX - b.minX; }
- compareMinY(a, b) { return a.minY - b.minY; }
+ RBush.prototype.toBBox = function toBBox (item) { return item; };
- toJSON() { return this.data; }
+ RBush.prototype.compareMinX = function compareMinX (a, b) { return a.minX - b.minX; };
+ RBush.prototype.compareMinY = function compareMinY (a, b) { return a.minY - b.minY; };
- fromJSON(data) {
- this.data = data;
- return this;
- }
+ RBush.prototype.toJSON = function toJSON () { return this.data; };
- _all(node, result) {
- const nodesToSearch = [];
- while (node) {
- if (node.leaf) result.push(...node.children);
- else nodesToSearch.push(...node.children);
+ RBush.prototype.fromJSON = function fromJSON (data) {
+ this.data = data;
+ return this;
+ };
- node = nodesToSearch.pop();
- }
- return result;
+ RBush.prototype._all = function _all (node, result) {
+ var nodesToSearch = [];
+ while (node) {
+ if (node.leaf) { result.push.apply(result, node.children); }
+ else { nodesToSearch.push.apply(nodesToSearch, node.children); }
+
+ node = nodesToSearch.pop();
}
+ return result;
+ };
- _build(items, left, right, height) {
+ RBush.prototype._build = function _build (items, left, right, height) {
- const N = right - left + 1;
- let M = this._maxEntries;
- let node;
+ var N = right - left + 1;
+ var M = this._maxEntries;
+ var node;
- if (N <= M) {
- // reached leaf level; return leaf
- node = createNode(items.slice(left, right + 1));
- calcBBox(node, this.toBBox);
- return node;
- }
+ if (N <= M) {
+ // reached leaf level; return leaf
+ node = createNode(items.slice(left, right + 1));
+ calcBBox(node, this.toBBox);
+ return node;
+ }
- if (!height) {
- // target height of the bulk-loaded tree
- height = Math.ceil(Math.log(N) / Math.log(M));
+ if (!height) {
+ // target height of the bulk-loaded tree
+ height = Math.ceil(Math.log(N) / Math.log(M));
- // target number of root entries to maximize storage utilization
- M = Math.ceil(N / Math.pow(M, height - 1));
- }
+ // target number of root entries to maximize storage utilization
+ M = Math.ceil(N / Math.pow(M, height - 1));
+ }
- node = createNode([]);
- node.leaf = false;
- node.height = height;
+ node = createNode([]);
+ node.leaf = false;
+ node.height = height;
- // split the items into M mostly square tiles
+ // split the items into M mostly square tiles
- const N2 = Math.ceil(N / M);
- const N1 = N2 * Math.ceil(Math.sqrt(M));
+ var N2 = Math.ceil(N / M);
+ var N1 = N2 * Math.ceil(Math.sqrt(M));
- multiSelect(items, left, right, N1, this.compareMinX);
+ multiSelect(items, left, right, N1, this.compareMinX);
- for (let i = left; i <= right; i += N1) {
+ for (var i = left; i <= right; i += N1) {
- const right2 = Math.min(i + N1 - 1, right);
+ var right2 = Math.min(i + N1 - 1, right);
- multiSelect(items, i, right2, N2, this.compareMinY);
+ multiSelect(items, i, right2, N2, this.compareMinY);
- for (let j = i; j <= right2; j += N2) {
+ for (var j = i; j <= right2; j += N2) {
- const right3 = Math.min(j + N2 - 1, right2);
+ var right3 = Math.min(j + N2 - 1, right2);
- // pack each entry recursively
- node.children.push(this._build(items, j, right3, height - 1));
- }
+ // pack each entry recursively
+ node.children.push(this._build(items, j, right3, height - 1));
}
+ }
- calcBBox(node, this.toBBox);
+ calcBBox(node, this.toBBox);
- return node;
- }
+ return node;
+ };
- _chooseSubtree(bbox, node, level, path) {
- while (true) {
- path.push(node);
+ RBush.prototype._chooseSubtree = function _chooseSubtree (bbox, node, level, path) {
+ while (true) {
+ path.push(node);
- if (node.leaf || path.length - 1 === level) break;
+ if (node.leaf || path.length - 1 === level) { break; }
- let minArea = Infinity;
- let minEnlargement = Infinity;
- let targetNode;
+ var minArea = Infinity;
+ var minEnlargement = Infinity;
+ var targetNode = (void 0);
- for (let i = 0; i < node.children.length; i++) {
- const child = node.children[i];
- const area = bboxArea(child);
- const enlargement = enlargedArea(bbox, child) - area;
+ for (var i = 0; i < node.children.length; i++) {
+ var child = node.children[i];
+ var area = bboxArea(child);
+ var enlargement = enlargedArea(bbox, child) - area;
- // choose entry with the least area enlargement
- if (enlargement < minEnlargement) {
- minEnlargement = enlargement;
- minArea = area < minArea ? area : minArea;
- targetNode = child;
+ // choose entry with the least area enlargement
+ if (enlargement < minEnlargement) {
+ minEnlargement = enlargement;
+ minArea = area < minArea ? area : minArea;
+ targetNode = child;
- } else if (enlargement === minEnlargement) {
- // otherwise choose one with the smallest area
- if (area < minArea) {
- minArea = area;
- targetNode = child;
- }
+ } else if (enlargement === minEnlargement) {
+ // otherwise choose one with the smallest area
+ if (area < minArea) {
+ minArea = area;
+ targetNode = child;
}
}
-
- node = targetNode || node.children[0];
}
- return node;
+ node = targetNode || node.children[0];
}
- _insert(item, level, isNode) {
- const bbox = isNode ? item : this.toBBox(item);
- const insertPath = [];
+ return node;
+ };
- // find the best node for accommodating the item, saving all nodes along the path too
- const node = this._chooseSubtree(bbox, this.data, level, insertPath);
+ RBush.prototype._insert = function _insert (item, level, isNode) {
+ var bbox = isNode ? item : this.toBBox(item);
+ var insertPath = [];
- // put the item into the node
- node.children.push(item);
- extend$1(node, bbox);
+ // find the best node for accommodating the item, saving all nodes along the path too
+ var node = this._chooseSubtree(bbox, this.data, level, insertPath);
- // split on node overflow; propagate upwards if necessary
- while (level >= 0) {
- if (insertPath[level].children.length > this._maxEntries) {
- this._split(insertPath, level);
- level--;
- } else break;
- }
+ // put the item into the node
+ node.children.push(item);
+ extend$1(node, bbox);
- // adjust bboxes along the insertion path
- this._adjustParentBBoxes(bbox, insertPath, level);
+ // split on node overflow; propagate upwards if necessary
+ while (level >= 0) {
+ if (insertPath[level].children.length > this._maxEntries) {
+ this._split(insertPath, level);
+ level--;
+ } else { break; }
}
- // split overflowed node into two
- _split(insertPath, level) {
- const node = insertPath[level];
- const M = node.children.length;
- const m = this._minEntries;
+ // adjust bboxes along the insertion path
+ this._adjustParentBBoxes(bbox, insertPath, level);
+ };
- this._chooseSplitAxis(node, m, M);
+ // split overflowed node into two
+ RBush.prototype._split = function _split (insertPath, level) {
+ var node = insertPath[level];
+ var M = node.children.length;
+ var m = this._minEntries;
- const splitIndex = this._chooseSplitIndex(node, m, M);
+ this._chooseSplitAxis(node, m, M);
- const newNode = createNode(node.children.splice(splitIndex, node.children.length - splitIndex));
- newNode.height = node.height;
- newNode.leaf = node.leaf;
+ var splitIndex = this._chooseSplitIndex(node, m, M);
- calcBBox(node, this.toBBox);
- calcBBox(newNode, this.toBBox);
+ var newNode = createNode(node.children.splice(splitIndex, node.children.length - splitIndex));
+ newNode.height = node.height;
+ newNode.leaf = node.leaf;
- if (level) insertPath[level - 1].children.push(newNode);
- else this._splitRoot(node, newNode);
- }
+ calcBBox(node, this.toBBox);
+ calcBBox(newNode, this.toBBox);
- _splitRoot(node, newNode) {
- // split root node
- this.data = createNode([node, newNode]);
- this.data.height = node.height + 1;
- this.data.leaf = false;
- calcBBox(this.data, this.toBBox);
- }
+ if (level) { insertPath[level - 1].children.push(newNode); }
+ else { this._splitRoot(node, newNode); }
+ };
- _chooseSplitIndex(node, m, M) {
- let index;
- let minOverlap = Infinity;
- let minArea = Infinity;
+ RBush.prototype._splitRoot = function _splitRoot (node, newNode) {
+ // split root node
+ this.data = createNode([node, newNode]);
+ this.data.height = node.height + 1;
+ this.data.leaf = false;
+ calcBBox(this.data, this.toBBox);
+ };
- for (let i = m; i <= M - m; i++) {
- const bbox1 = distBBox(node, 0, i, this.toBBox);
- const bbox2 = distBBox(node, i, M, this.toBBox);
+ RBush.prototype._chooseSplitIndex = function _chooseSplitIndex (node, m, M) {
+ var index;
+ var minOverlap = Infinity;
+ var minArea = Infinity;
- const overlap = intersectionArea(bbox1, bbox2);
- const area = bboxArea(bbox1) + bboxArea(bbox2);
+ for (var i = m; i <= M - m; i++) {
+ var bbox1 = distBBox(node, 0, i, this.toBBox);
+ var bbox2 = distBBox(node, i, M, this.toBBox);
- // choose distribution with minimum overlap
- if (overlap < minOverlap) {
- minOverlap = overlap;
- index = i;
+ var overlap = intersectionArea(bbox1, bbox2);
+ var area = bboxArea(bbox1) + bboxArea(bbox2);
- minArea = area < minArea ? area : minArea;
+ // choose distribution with minimum overlap
+ if (overlap < minOverlap) {
+ minOverlap = overlap;
+ index = i;
- } else if (overlap === minOverlap) {
- // otherwise choose distribution with minimum area
- if (area < minArea) {
- minArea = area;
- index = i;
- }
+ minArea = area < minArea ? area : minArea;
+
+ } else if (overlap === minOverlap) {
+ // otherwise choose distribution with minimum area
+ if (area < minArea) {
+ minArea = area;
+ index = i;
}
}
-
- return index || M - m;
}
- // sorts node children by the best axis for split
- _chooseSplitAxis(node, m, M) {
- const compareMinX = node.leaf ? this.compareMinX : compareNodeMinX;
- const compareMinY = node.leaf ? this.compareMinY : compareNodeMinY;
- const xMargin = this._allDistMargin(node, m, M, compareMinX);
- const yMargin = this._allDistMargin(node, m, M, compareMinY);
+ return index || M - m;
+ };
- // if total distributions margin value is minimal for x, sort by minX,
- // otherwise it's already sorted by minY
- if (xMargin < yMargin) node.children.sort(compareMinX);
- }
+ // sorts node children by the best axis for split
+ RBush.prototype._chooseSplitAxis = function _chooseSplitAxis (node, m, M) {
+ var compareMinX = node.leaf ? this.compareMinX : compareNodeMinX;
+ var compareMinY = node.leaf ? this.compareMinY : compareNodeMinY;
+ var xMargin = this._allDistMargin(node, m, M, compareMinX);
+ var yMargin = this._allDistMargin(node, m, M, compareMinY);
- // total margin of all possible split distributions where each node is at least m full
- _allDistMargin(node, m, M, compare) {
- node.children.sort(compare);
+ // if total distributions margin value is minimal for x, sort by minX,
+ // otherwise it's already sorted by minY
+ if (xMargin < yMargin) { node.children.sort(compareMinX); }
+ };
- const toBBox = this.toBBox;
- const leftBBox = distBBox(node, 0, m, toBBox);
- const rightBBox = distBBox(node, M - m, M, toBBox);
- let margin = bboxMargin(leftBBox) + bboxMargin(rightBBox);
+ // total margin of all possible split distributions where each node is at least m full
+ RBush.prototype._allDistMargin = function _allDistMargin (node, m, M, compare) {
+ node.children.sort(compare);
- for (let i = m; i < M - m; i++) {
- const child = node.children[i];
- extend$1(leftBBox, node.leaf ? toBBox(child) : child);
- margin += bboxMargin(leftBBox);
- }
+ var toBBox = this.toBBox;
+ var leftBBox = distBBox(node, 0, m, toBBox);
+ var rightBBox = distBBox(node, M - m, M, toBBox);
+ var margin = bboxMargin(leftBBox) + bboxMargin(rightBBox);
- for (let i = M - m - 1; i >= m; i--) {
- const child = node.children[i];
- extend$1(rightBBox, node.leaf ? toBBox(child) : child);
- margin += bboxMargin(rightBBox);
- }
+ for (var i = m; i < M - m; i++) {
+ var child = node.children[i];
+ extend$1(leftBBox, node.leaf ? toBBox(child) : child);
+ margin += bboxMargin(leftBBox);
+ }
- return margin;
+ for (var i$1 = M - m - 1; i$1 >= m; i$1--) {
+ var child$1 = node.children[i$1];
+ extend$1(rightBBox, node.leaf ? toBBox(child$1) : child$1);
+ margin += bboxMargin(rightBBox);
}
- _adjustParentBBoxes(bbox, path, level) {
- // adjust bboxes along the given tree path
- for (let i = level; i >= 0; i--) {
- extend$1(path[i], bbox);
- }
+ return margin;
+ };
+
+ RBush.prototype._adjustParentBBoxes = function _adjustParentBBoxes (bbox, path, level) {
+ // adjust bboxes along the given tree path
+ for (var i = level; i >= 0; i--) {
+ extend$1(path[i], bbox);
}
+ };
- _condense(path) {
- // go through the path, removing empty nodes and updating bboxes
- for (let i = path.length - 1, siblings; i >= 0; i--) {
- if (path[i].children.length === 0) {
- if (i > 0) {
- siblings = path[i - 1].children;
- siblings.splice(siblings.indexOf(path[i]), 1);
+ RBush.prototype._condense = function _condense (path) {
+ // go through the path, removing empty nodes and updating bboxes
+ for (var i = path.length - 1, siblings = (void 0); i >= 0; i--) {
+ if (path[i].children.length === 0) {
+ if (i > 0) {
+ siblings = path[i - 1].children;
+ siblings.splice(siblings.indexOf(path[i]), 1);
- } else this.clear();
+ } else { this.clear(); }
- } else calcBBox(path[i], this.toBBox);
- }
+ } else { calcBBox(path[i], this.toBBox); }
}
- }
+ };
function findItem(item, items, equalsFn) {
- if (!equalsFn) return items.indexOf(item);
+ if (!equalsFn) { return items.indexOf(item); }
- for (let i = 0; i < items.length; i++) {
- if (equalsFn(item, items[i])) return i;
+ for (var i = 0; i < items.length; i++) {
+ if (equalsFn(item, items[i])) { return i; }
}
return -1;
}
// min bounding rectangle of node children from k to p-1
function distBBox(node, k, p, toBBox, destNode) {
- if (!destNode) destNode = createNode(null);
+ if (!destNode) { destNode = createNode(null); }
destNode.minX = Infinity;
destNode.minY = Infinity;
destNode.maxX = -Infinity;
destNode.maxY = -Infinity;
- for (let i = k; i < p; i++) {
- const child = node.children[i];
+ for (var i = k; i < p; i++) {
+ var child = node.children[i];
extend$1(destNode, node.leaf ? toBBox(child) : child);
}
}
function intersectionArea(a, b) {
- const minX = Math.max(a.minX, b.minX);
- const minY = Math.max(a.minY, b.minY);
- const maxX = Math.min(a.maxX, b.maxX);
- const maxY = Math.min(a.maxY, b.maxY);
+ var minX = Math.max(a.minX, b.minX);
+ var minY = Math.max(a.minY, b.minY);
+ var maxX = Math.min(a.maxX, b.maxX);
+ var maxY = Math.min(a.maxY, b.maxY);
return Math.max(0, maxX - minX) *
Math.max(0, maxY - minY);
function createNode(children) {
return {
- children,
+ children: children,
height: 1,
leaf: true,
minX: Infinity,
// combines selection algorithm with binary divide & conquer approach
function multiSelect(arr, left, right, n, compare) {
- const stack = [left, right];
+ var stack = [left, right];
while (stack.length) {
right = stack.pop();
left = stack.pop();
- if (right - left <= n) continue;
+ if (right - left <= n) { continue; }
- const mid = left + Math.ceil((right - left) / n / 2) * n;
+ var mid = left + Math.ceil((right - left) / n / 2) * n;
quickselect(arr, mid, left, right, compare);
stack.push(left, mid, mid, right);
}
}
- const tiler = utilTiler();
- const dispatch$1 = dispatch('loaded');
- const _tileZoom = 14;
- const _krUrlRoot = 'https://www.keepright.at';
- let _krData = { errorTypes: {}, localizeStrings: {} };
+ var tiler = utilTiler();
+ var dispatch$1 = dispatch('loaded');
+ var _tileZoom = 14;
+ var _krUrlRoot = 'https://www.keepright.at';
+ var _krData = { errorTypes: {}, localizeStrings: {} };
// This gets reassigned if reset
- let _cache;
+ var _cache;
- const _krRuleset = [
+ var _krRuleset = [
// no 20 - multiple node on same spot - these are mostly boundaries overlapping roads
30, 40, 50, 60, 70, 90, 100, 110, 120, 130, 150, 160, 170, 180,
190, 191, 192, 193, 194, 195, 196, 197, 198,
}
function abortUnwantedRequests(cache, tiles) {
- Object.keys(cache.inflightTile).forEach(k => {
- const wanted = tiles.find(tile => k === tile.id);
+ Object.keys(cache.inflightTile).forEach(function (k) {
+ var wanted = tiles.find(function (tile) { return k === tile.id; });
if (!wanted) {
abortRequest(cache.inflightTile[k]);
delete cache.inflightTile[k];
// Replace or remove QAItem from rtree
function updateRtree(item, replace) {
- _cache.rtree.remove(item, (a, b) => a.data.id === b.data.id);
+ _cache.rtree.remove(item, function (a, b) { return a.data.id === b.data.id; });
if (replace) {
_cache.rtree.insert(item);
function tokenReplacements(d) {
- if (!(d instanceof QAItem)) return;
+ if (!(d instanceof QAItem)) { return; }
- const htmlRegex = new RegExp(/<\/[a-z][\s\S]*>/);
- const replacements = {};
+ var htmlRegex = new RegExp(/<\/[a-z][\s\S]*>/);
+ var replacements = {};
- const issueTemplate = _krData.errorTypes[d.whichType];
+ var issueTemplate = _krData.errorTypes[d.whichType];
if (!issueTemplate) {
/* eslint-disable no-console */
console.log('No Template: ', d.whichType);
}
// some descriptions are just fixed text
- if (!issueTemplate.regex) return;
+ if (!issueTemplate.regex) { return; }
// regex pattern should match description with variable details captured
- const errorRegex = new RegExp(issueTemplate.regex, 'i');
- const errorMatch = errorRegex.exec(d.description);
+ var errorRegex = new RegExp(issueTemplate.regex, 'i');
+ var errorMatch = errorRegex.exec(d.description);
if (!errorMatch) {
/* eslint-disable no-console */
console.log('Unmatched: ', d.whichType);
return;
}
- for (let i = 1; i < errorMatch.length; i++) { // skip first
- let capture = errorMatch[i];
- let idType;
+ for (var i = 1; i < errorMatch.length; i++) { // skip first
+ var capture = errorMatch[i];
+ var idType = (void 0);
idType = 'IDs' in issueTemplate ? issueTemplate.IDs[i-1] : '';
if (idType && capture) { // link IDs if present in the capture
} else if (htmlRegex.test(capture)) { // escape any html in non-IDs
capture = '\\' + capture + '\\';
} else {
- const compare = capture.toLowerCase();
+ var compare = capture.toLowerCase();
if (_krData.localizeStrings[compare]) { // some replacement strings can be localized
capture = _t('QA.keepRight.error_parts.' + _krData.localizeStrings[compare]);
}
function parseError(capture, idType) {
- const compare = capture.toLowerCase();
+ var compare = capture.toLowerCase();
if (_krData.localizeStrings[compare]) { // some replacement strings can be localized
capture = _t('QA.keepRight.error_parts.' + _krData.localizeStrings[compare]);
}
function linkErrorObject(d) {
- return `<a class="error_object_link">${d}</a>`;
+ return ("<a class=\"error_object_link\">" + d + "</a>");
}
function linkEntity(d) {
- return `<a class="error_entity_link">${d}</a>`;
+ return ("<a class=\"error_entity_link\">" + d + "</a>");
}
function linkURL(d) {
- return `<a class="kr_external_link" target="_blank" href="${d}">${d}</a>`;
+ return ("<a class=\"kr_external_link\" target=\"_blank\" href=\"" + d + "\">" + d + "</a>");
}
// arbitrary node list of form: #ID, #ID, #ID...
function parse211(capture) {
- let newList = [];
- const items = capture.split(', ');
+ var newList = [];
+ var items = capture.split(', ');
- items.forEach(item => {
+ items.forEach(function (item) {
// ID has # at the front
- let id = linkEntity('n' + item.slice(1));
+ var id = linkEntity('n' + item.slice(1));
newList.push(id);
});
// arbitrary way list of form: #ID(layer),#ID(layer),#ID(layer)...
function parse231(capture) {
- let newList = [];
+ var newList = [];
// unfortunately 'layer' can itself contain commas, so we split on '),'
- const items = capture.split('),');
+ var items = capture.split('),');
- items.forEach(item => {
- const match = item.match(/\#(\d+)\((.+)\)?/);
+ items.forEach(function (item) {
+ var match = item.match(/\#(\d+)\((.+)\)?/);
if (match !== null && match.length > 2) {
newList.push(linkEntity('w' + match[1]) + ' ' +
_t('QA.keepRight.errorTypes.231.layer', { layer: match[2] })
// arbitrary node/relation list of form: from node #ID,to relation #ID,to node #ID...
function parse294(capture) {
- let newList = [];
- const items = capture.split(',');
+ var newList = [];
+ var items = capture.split(',');
- items.forEach(item => {
+ items.forEach(function (item) {
// item of form "from/to node/relation #ID"
item = item.split(' ');
// to/from role is more clear in quotes
- const role = `"${item[0]}"`;
+ var role = "\"" + (item[0]) + "\"";
// first letter of node/relation provides the type
- const idType = item[1].slice(0,1);
+ var idType = item[1].slice(0,1);
// ID has # at the front
- let id = item[2].slice(1);
+ var id = item[2].slice(1);
id = linkEntity(idType + id);
- newList.push(`${role} ${item[1]} ${id}`);
+ newList.push((role + " " + (item[1]) + " " + id));
});
return newList.join(', ');
// may or may not include the string "(including the name 'name')"
function parse370(capture) {
- if (!capture) return '';
+ if (!capture) { return ''; }
- const match = capture.match(/\(including the name (\'.+\')\)/);
+ var match = capture.match(/\(including the name (\'.+\')\)/);
if (match && match.length) {
return _t('QA.keepRight.errorTypes.370.including_the_name', { name: match[1] });
}
// arbitrary node list of form: #ID,#ID,#ID...
function parse20(capture) {
- let newList = [];
- const items = capture.split(',');
+ var newList = [];
+ var items = capture.split(',');
- items.forEach(item => {
+ items.forEach(function (item) {
// ID has # at the front
- const id = linkEntity('n' + item.slice(1));
+ var id = linkEntity('n' + item.slice(1));
newList.push(id);
});
var serviceKeepRight = {
title: 'keepRight',
- init() {
+ init: function init() {
_mainFileFetcher.get('keepRight')
- .then(d => _krData = d);
+ .then(function (d) { return _krData = d; });
if (!_cache) {
this.reset();
this.event = utilRebind(this, dispatch$1, 'on');
},
- reset() {
+ reset: function reset() {
if (_cache) {
Object.values(_cache.inflightTile).forEach(abortRequest);
}
// KeepRight API: http://osm.mueschelsoft.de/keepright/interfacing.php
- loadIssues(projection) {
- const options = {
+ loadIssues: function loadIssues(projection) {
+ var this$1 = this;
+
+ var options = {
format: 'geojson',
ch: _krRuleset
};
// determine the needed tiles to cover the view
- const tiles = tiler
+ var tiles = tiler
.zoomExtent([_tileZoom, _tileZoom])
.getTiles(projection);
abortUnwantedRequests(_cache, tiles);
// issue new requests..
- tiles.forEach(tile => {
- if (_cache.loadedTile[tile.id] || _cache.inflightTile[tile.id]) return;
-
- const [ left, top, right, bottom ] = tile.extent.rectangle();
- const params = Object.assign({}, options, { left, bottom, right, top });
- const url = `${_krUrlRoot}/export.php?` + utilQsString(params);
- const controller = new AbortController();
+ tiles.forEach(function (tile) {
+ if (_cache.loadedTile[tile.id] || _cache.inflightTile[tile.id]) { return; }
+
+ var ref = tile.extent.rectangle();
+ var left = ref[0];
+ var top = ref[1];
+ var right = ref[2];
+ var bottom = ref[3];
+ var params = Object.assign({}, options, { left: left, bottom: bottom, right: right, top: top });
+ var url = _krUrlRoot + "/export.php?" + utilQsString(params);
+ var controller = new AbortController();
_cache.inflightTile[tile.id] = controller;
d3_json(url, { signal: controller.signal })
- .then(data => {
+ .then(function (data) {
delete _cache.inflightTile[tile.id];
_cache.loadedTile[tile.id] = true;
if (!data || !data.features || !data.features.length) {
throw new Error('No Data');
}
- data.features.forEach(feature => {
- const {
- properties: {
- error_type: itemType,
- error_id: id,
- comment = null,
- object_id: objectId,
- object_type: objectType,
- schema,
- title
- }
- } = feature;
- let {
- geometry: { coordinates: loc },
- properties: { description = '' }
- } = feature;
+ data.features.forEach(function (feature) {
+ var feature_properties = feature.properties;
+ var itemType = feature_properties.error_type;
+ var id = feature_properties.error_id;
+ var comment = feature_properties.comment; if ( comment === void 0 ) comment = null;
+ var objectId = feature_properties.object_id;
+ var objectType = feature_properties.object_type;
+ var schema = feature_properties.schema;
+ var title = feature_properties.title;
+ var loc = feature.geometry.coordinates;
+ var description = feature.properties.description; if ( description === void 0 ) description = '';
// if there is a parent, save its error type e.g.:
// Error 191 = "highway-highway"
// Error 190 = "intersections without junctions" (parent)
- const issueTemplate = _krData.errorTypes[itemType];
- const parentIssueType = (Math.floor(itemType / 10) * 10).toString();
+ var issueTemplate = _krData.errorTypes[itemType];
+ var parentIssueType = (Math.floor(itemType / 10) * 10).toString();
// try to handle error type directly, fallback to parent error type.
- const whichType = issueTemplate ? itemType : parentIssueType;
- const whichTemplate = _krData.errorTypes[whichType];
+ var whichType = issueTemplate ? itemType : parentIssueType;
+ var whichTemplate = _krData.errorTypes[whichType];
// Rewrite a few of the errors at this point..
// This is done to make them easier to linkify and translate.
switch (whichType) {
case '170':
- description = `This feature has a FIXME tag: ${description}`;
+ description = "This feature has a FIXME tag: " + description;
break;
case '292':
case '293':
case '296':
case '297':
case '298':
- description = `This turn-restriction~${description}`;
+ description = "This turn-restriction~" + description;
break;
case '300':
description = 'This highway is missing a maxspeed tag';
case '411':
case '412':
case '413':
- description = `This feature~${description}`;
+ description = "This feature~" + description;
break;
}
// move markers slightly so it doesn't obscure the geometry,
// then move markers away from other coincident markers
- let coincident = false;
+ var coincident = false;
do {
// first time, move marker up. after that, move marker right.
- let delta = coincident ? [0.00001, 0] : [0, 0.00001];
+ var delta = coincident ? [0.00001, 0] : [0, 0.00001];
loc = geoVecAdd(loc, delta);
- let bbox = geoExtent(loc).bbox();
+ var bbox = geoExtent(loc).bbox();
coincident = _cache.rtree.search(bbox).length;
} while (coincident);
- let d = new QAItem(loc, this, itemType, id, {
- comment,
- description,
- whichType,
- parentIssueType,
+ var d = new QAItem(loc, this$1, itemType, id, {
+ comment: comment,
+ description: description,
+ whichType: whichType,
+ parentIssueType: parentIssueType,
severity: whichTemplate.severity || 'error',
- objectId,
- objectType,
- schema,
- title
+ objectId: objectId,
+ objectType: objectType,
+ schema: schema,
+ title: title
});
d.replacements = tokenReplacements(d);
dispatch$1.call('loaded');
})
- .catch(() => {
+ .catch(function () {
delete _cache.inflightTile[tile.id];
_cache.loadedTile[tile.id] = true;
});
},
- postUpdate(d, callback) {
+ postUpdate: function postUpdate(d, callback) {
+ var this$1 = this;
+
if (_cache.inflightPost[d.id]) {
return callback({ message: 'Error update already inflight', status: -2 }, d);
}
- const params = { schema: d.schema, id: d.id };
+ var params = { schema: d.schema, id: d.id };
if (d.newStatus) {
params.st = d.newStatus;
// NOTE: This throws a CORS err, but it seems successful.
// We don't care too much about the response, so this is fine.
- const url = `${_krUrlRoot}/comment.php?` + utilQsString(params);
- const controller = new AbortController();
+ var url = _krUrlRoot + "/comment.php?" + utilQsString(params);
+ var controller = new AbortController();
_cache.inflightPost[d.id] = controller;
// Since this is expected to throw an error just continue as if it worked
// (worst case scenario the request truly fails and issue will show up if iD restarts)
d3_json(url, { signal: controller.signal })
- .finally(() => {
+ .finally(function () {
delete _cache.inflightPost[d.id];
if (d.newStatus === 'ignore') {
// ignore permanently (false positive)
- this.removeItem(d);
+ this$1.removeItem(d);
} else if (d.newStatus === 'ignore_t') {
// ignore temporarily (error fixed)
- this.removeItem(d);
- _cache.closed[`${d.schema}:${d.id}`] = true;
+ this$1.removeItem(d);
+ _cache.closed[((d.schema) + ":" + (d.id))] = true;
} else {
- d = this.replaceItem(d.update({
+ d = this$1.replaceItem(d.update({
comment: d.newComment,
newComment: undefined,
newState: undefined
}));
}
- if (callback) callback(null, d);
+ if (callback) { callback(null, d); }
});
},
// Get all cached QAItems covering the viewport
- getItems(projection) {
- const viewport = projection.clipExtent();
- const min = [viewport[0][0], viewport[1][1]];
- const max = [viewport[1][0], viewport[0][1]];
- const bbox = geoExtent(projection.invert(min), projection.invert(max)).bbox();
+ getItems: function getItems(projection) {
+ var viewport = projection.clipExtent();
+ var min = [viewport[0][0], viewport[1][1]];
+ var max = [viewport[1][0], viewport[0][1]];
+ var bbox = geoExtent(projection.invert(min), projection.invert(max)).bbox();
- return _cache.rtree.search(bbox).map(d => d.data);
+ return _cache.rtree.search(bbox).map(function (d) { return d.data; });
},
// Get a QAItem from cache
// NOTE: Don't change method name until UI v3 is merged
- getError(id) {
+ getError: function getError(id) {
return _cache.data[id];
},
// Replace a single QAItem in the cache
- replaceItem(item) {
- if (!(item instanceof QAItem) || !item.id) return;
+ replaceItem: function replaceItem(item) {
+ if (!(item instanceof QAItem) || !item.id) { return; }
_cache.data[item.id] = item;
updateRtree(encodeIssueRtree(item), true); // true = replace
},
// Remove a single QAItem from the cache
- removeItem(item) {
- if (!(item instanceof QAItem) || !item.id) return;
+ removeItem: function removeItem(item) {
+ if (!(item instanceof QAItem) || !item.id) { return; }
delete _cache.data[item.id];
updateRtree(encodeIssueRtree(item), false); // false = remove
},
- issueURL(item) {
- return `${_krUrlRoot}/report_map.php?schema=${item.schema}&error=${item.id}`;
+ issueURL: function issueURL(item) {
+ return (_krUrlRoot + "/report_map.php?schema=" + (item.schema) + "&error=" + (item.id));
},
// Get an array of issues closed during this session.
// Used to populate `closed:keepright` changeset tag
- getClosedIDs() {
+ getClosedIDs: function getClosedIDs() {
return Object.keys(_cache.closed).sort();
}
};
- const tiler$1 = utilTiler();
- const dispatch$2 = dispatch('loaded');
- const _tileZoom$1 = 14;
- const _impOsmUrls = {
+ var tiler$1 = utilTiler();
+ var dispatch$2 = dispatch('loaded');
+ var _tileZoom$1 = 14;
+ var _impOsmUrls = {
ow: 'https://grab.community.improve-osm.org/directionOfFlowService',
mr: 'https://grab.community.improve-osm.org/missingGeoService',
tr: 'https://grab.community.improve-osm.org/turnRestrictionService'
};
- let _impOsmData = { icons: {} };
+ var _impOsmData = { icons: {} };
// This gets reassigned if reset
- let _cache$1;
+ var _cache$1;
function abortRequest$1(i) {
- Object.values(i).forEach(controller => {
+ Object.values(i).forEach(function (controller) {
if (controller) {
controller.abort();
}
}
function abortUnwantedRequests$1(cache, tiles) {
- Object.keys(cache.inflightTile).forEach(k => {
- const wanted = tiles.find(tile => k === tile.id);
+ Object.keys(cache.inflightTile).forEach(function (k) {
+ var wanted = tiles.find(function (tile) { return k === tile.id; });
if (!wanted) {
abortRequest$1(cache.inflightTile[k]);
delete cache.inflightTile[k];
// Replace or remove QAItem from rtree
function updateRtree$1(item, replace) {
- _cache$1.rtree.remove(item, (a, b) => a.data.id === b.data.id);
+ _cache$1.rtree.remove(item, function (a, b) { return a.data.id === b.data.id; });
if (replace) {
_cache$1.rtree.insert(item);
}
function linkErrorObject(d) {
- return `<a class="error_object_link">${d}</a>`;
+ return ("<a class=\"error_object_link\">" + d + "</a>");
}
function linkEntity(d) {
- return `<a class="error_entity_link">${d}</a>`;
+ return ("<a class=\"error_entity_link\">" + d + "</a>");
}
function pointAverage(points) {
if (points.length) {
- const sum = points.reduce(
- (acc, point) => geoVecAdd(acc, [point.lon, point.lat]),
+ var sum = points.reduce(
+ function (acc, point) { return geoVecAdd(acc, [point.lon, point.lat]); },
[0,0]
);
return geoVecScale(sum, 1 / points.length);
}
function relativeBearing(p1, p2) {
- let angle = Math.atan2(p2.lon - p1.lon, p2.lat - p1.lat);
+ var angle = Math.atan2(p2.lon - p1.lon, p2.lat - p1.lat);
if (angle < 0) {
angle += 2 * Math.PI;
}
// Assuming range [0,360)
function cardinalDirection(bearing) {
- const dir = 45 * Math.round(bearing / 45);
- const compass = {
+ var dir = 45 * Math.round(bearing / 45);
+ var compass = {
0: 'north',
45: 'northeast',
90: 'east',
360: 'north'
};
- return _t(`QA.improveOSM.directions.${compass[dir]}`);
+ return _t(("QA.improveOSM.directions." + (compass[dir])));
}
- // Errors shouldn't obscure eachother
+ // Errors shouldn't obscure each other
function preventCoincident(loc, bumpUp) {
- let coincident = false;
+ var coincident = false;
do {
// first time, move marker up. after that, move marker right.
- let delta = coincident ? [0.00001, 0] : (bumpUp ? [0, 0.00001] : [0, 0]);
+ var delta = coincident ? [0.00001, 0] : (bumpUp ? [0, 0.00001] : [0, 0]);
loc = geoVecAdd(loc, delta);
- let bbox = geoExtent(loc).bbox();
+ var bbox = geoExtent(loc).bbox();
coincident = _cache$1.rtree.search(bbox).length;
} while (coincident);
var serviceImproveOSM = {
title: 'improveOSM',
- init() {
+ init: function init() {
_mainFileFetcher.get('qa_data')
- .then(d => _impOsmData = d.improveOSM);
+ .then(function (d) { return _impOsmData = d.improveOSM; });
if (!_cache$1) {
this.reset();
this.event = utilRebind(this, dispatch$2, 'on');
},
- reset() {
+ reset: function reset() {
if (_cache$1) {
Object.values(_cache$1.inflightTile).forEach(abortRequest$1);
}
};
},
- loadIssues(projection) {
- const options = {
+ loadIssues: function loadIssues(projection) {
+ var this$1 = this;
+
+ var options = {
client: 'iD',
status: 'OPEN',
zoom: '19' // Use a high zoom so that clusters aren't returned
};
// determine the needed tiles to cover the view
- const tiles = tiler$1
+ var tiles = tiler$1
.zoomExtent([_tileZoom$1, _tileZoom$1])
.getTiles(projection);
abortUnwantedRequests$1(_cache$1, tiles);
// issue new requests..
- tiles.forEach(tile => {
- if (_cache$1.loadedTile[tile.id] || _cache$1.inflightTile[tile.id]) return;
+ tiles.forEach(function (tile) {
+ if (_cache$1.loadedTile[tile.id] || _cache$1.inflightTile[tile.id]) { return; }
- const [ east, north, west, south ] = tile.extent.rectangle();
- const params = Object.assign({}, options, { east, south, west, north });
+ var ref = tile.extent.rectangle();
+ var east = ref[0];
+ var north = ref[1];
+ var west = ref[2];
+ var south = ref[3];
+ var params = Object.assign({}, options, { east: east, south: south, west: west, north: north });
// 3 separate requests to store for each tile
- const requests = {};
+ var requests = {};
- Object.keys(_impOsmUrls).forEach(k => {
+ Object.keys(_impOsmUrls).forEach(function (k) {
// We exclude WATER from missing geometry as it doesn't seem useful
// We use most confident one-way and turn restrictions only, still have false positives
- const kParams = Object.assign({},
+ var kParams = Object.assign({},
params,
(k === 'mr') ? { type: 'PARKING,ROAD,BOTH,PATH' } : { confidenceLevel: 'C1' }
);
- const url = `${_impOsmUrls[k]}/search?` + utilQsString(kParams);
- const controller = new AbortController();
+ var url = (_impOsmUrls[k]) + "/search?" + utilQsString(kParams);
+ var controller = new AbortController();
requests[k] = controller;
d3_json(url, { signal: controller.signal })
- .then(data => {
+ .then(function (data) {
delete _cache$1.inflightTile[tile.id][k];
if (!Object.keys(_cache$1.inflightTile[tile.id]).length) {
delete _cache$1.inflightTile[tile.id];
// Road segments at high zoom == oneways
if (data.roadSegments) {
- data.roadSegments.forEach(feature => {
+ data.roadSegments.forEach(function (feature) {
// Position error at the approximate middle of the segment
- const { points, wayId, fromNodeId, toNodeId } = feature;
- const itemId = `${wayId}${fromNodeId}${toNodeId}`;
- let mid = points.length / 2;
- let loc;
+ var points = feature.points;
+ var wayId = feature.wayId;
+ var fromNodeId = feature.fromNodeId;
+ var toNodeId = feature.toNodeId;
+ var itemId = "" + wayId + fromNodeId + toNodeId;
+ var mid = points.length / 2;
+ var loc;
// Even number of points, find midpoint of the middle two
// Odd number of points, use position of very middle point
// One-ways can land on same segment in opposite direction
loc = preventCoincident(loc, false);
- let d = new QAItem(loc, this, k, itemId, {
+ var d = new QAItem(loc, this$1, k, itemId, {
issueKey: k, // used as a category
identifier: { // used to post changes
- wayId,
- fromNodeId,
- toNodeId
+ wayId: wayId,
+ fromNodeId: fromNodeId,
+ toNodeId: toNodeId
},
objectId: wayId,
objectType: 'way'
// Tiles at high zoom == missing roads
if (data.tiles) {
- data.tiles.forEach(feature => {
- const { type, x, y, numberOfTrips } = feature;
- const geoType = type.toLowerCase();
- const itemId = `${geoType}${x}${y}${numberOfTrips}`;
+ data.tiles.forEach(function (feature) {
+ var type = feature.type;
+ var x = feature.x;
+ var y = feature.y;
+ var numberOfTrips = feature.numberOfTrips;
+ var geoType = type.toLowerCase();
+ var itemId = "" + geoType + x + y + numberOfTrips;
// Average of recorded points should land on the missing geometry
// Missing geometry could happen to land on another error
- let loc = pointAverage(feature.points);
+ var loc = pointAverage(feature.points);
loc = preventCoincident(loc, false);
- let d = new QAItem(loc, this, `${k}-${geoType}`, itemId, {
+ var d = new QAItem(loc, this$1, (k + "-" + geoType), itemId, {
issueKey: k,
- identifier: { x, y }
+ identifier: { x: x, y: y }
});
d.replacements = {
num_trips: numberOfTrips,
- geometry_type: _t(`QA.improveOSM.geometry_types.${geoType}`)
+ geometry_type: _t(("QA.improveOSM.geometry_types." + geoType))
};
// -1 trips indicates data came from a 3rd party
// Entities at high zoom == turn restrictions
if (data.entities) {
- data.entities.forEach(feature => {
- const { point, id, segments, numberOfPasses, turnType } = feature;
- const itemId = `${id.replace(/[,:+#]/g, '_')}`;
+ data.entities.forEach(function (feature) {
+ var point = feature.point;
+ var id = feature.id;
+ var segments = feature.segments;
+ var numberOfPasses = feature.numberOfPasses;
+ var turnType = feature.turnType;
+ var itemId = "" + (id.replace(/[,:+#]/g, '_'));
// Turn restrictions could be missing at same junction
// We also want to bump the error up so node is accessible
- const loc = preventCoincident([point.lon, point.lat], true);
+ var loc = preventCoincident([point.lon, point.lat], true);
// Elements are presented in a strange way
- const ids = id.split(',');
- const from_way = ids[0];
- const via_node = ids[3];
- const to_way = ids[2].split(':')[1];
+ var ids = id.split(',');
+ var from_way = ids[0];
+ var via_node = ids[3];
+ var to_way = ids[2].split(':')[1];
- let d = new QAItem(loc, this, k, itemId, {
+ var d = new QAItem(loc, this$1, k, itemId, {
issueKey: k,
identifier: id,
objectId: via_node,
});
// Travel direction along from_way clarifies the turn restriction
- const [ p1, p2 ] = segments[0].points;
- const dir_of_travel = cardinalDirection(relativeBearing(p1, p2));
+ var ref = segments[0].points;
+ var p1 = ref[0];
+ var p2 = ref[1];
+ var dir_of_travel = cardinalDirection(relativeBearing(p1, p2));
// Variables used in the description
d.replacements = {
});
}
})
- .catch(() => {
+ .catch(function () {
delete _cache$1.inflightTile[tile.id][k];
if (!Object.keys(_cache$1.inflightTile[tile.id]).length) {
delete _cache$1.inflightTile[tile.id];
});
},
- getComments(item) {
+ getComments: function getComments(item) {
+ var this$1 = this;
+
// If comments already retrieved no need to do so again
if (item.comments) {
return Promise.resolve(item);
}
- const key = item.issueKey;
- let qParams = {};
+ var key = item.issueKey;
+ var qParams = {};
if (key === 'ow') {
qParams = item.identifier;
qParams.targetId = item.identifier;
}
- const url = `${_impOsmUrls[key]}/retrieveComments?` + utilQsString(qParams);
- const cacheComments = data => {
+ var url = (_impOsmUrls[key]) + "/retrieveComments?" + utilQsString(qParams);
+ var cacheComments = function (data) {
// Assign directly for immediate use afterwards
// comments are served newest to oldest
item.comments = data.comments ? data.comments.reverse() : [];
- this.replaceItem(item);
+ this$1.replaceItem(item);
};
- return d3_json(url).then(cacheComments).then(() => item);
+ return d3_json(url).then(cacheComments).then(function () { return item; });
},
- postUpdate(d, callback) {
+ postUpdate: function postUpdate(d, callback) {
if (!serviceOsm.authenticated()) { // Username required in payload
return callback({ message: 'Not Authenticated', status: -3}, d);
}
serviceOsm.userDetails(sendPayload.bind(this));
function sendPayload(err, user) {
+ var this$1 = this;
+
if (err) { return callback(err, d); }
- const key = d.issueKey;
- const url = `${_impOsmUrls[key]}/comment`;
- const payload = {
+ var key = d.issueKey;
+ var url = (_impOsmUrls[key]) + "/comment";
+ var payload = {
username: user.display_name,
targetIds: [ d.identifier ]
};
payload.text = d.newComment;
}
- const controller = new AbortController();
+ var controller = new AbortController();
_cache$1.inflightPost[d.id] = controller;
- const options = {
+ var options = {
method: 'POST',
signal: controller.signal,
body: JSON.stringify(payload)
};
d3_json(url, options)
- .then(() => {
+ .then(function () {
delete _cache$1.inflightPost[d.id];
// Just a comment, update error in cache
if (!d.newStatus) {
- const now = new Date();
- let comments = d.comments ? d.comments : [];
+ var now = new Date();
+ var comments = d.comments ? d.comments : [];
comments.push({
username: payload.username,
timestamp: now.getTime() / 1000
});
- this.replaceItem(d.update({
+ this$1.replaceItem(d.update({
comments: comments,
newComment: undefined
}));
} else {
- this.removeItem(d);
+ this$1.removeItem(d);
if (d.newStatus === 'SOLVED') {
// Keep track of the number of issues closed per type to tag the changeset
if (!(d.issueKey in _cache$1.closed)) {
_cache$1.closed[d.issueKey] += 1;
}
}
- if (callback) callback(null, d);
+ if (callback) { callback(null, d); }
})
- .catch(err => {
+ .catch(function (err) {
delete _cache$1.inflightPost[d.id];
- if (callback) callback(err.message);
+ if (callback) { callback(err.message); }
});
}
},
// Get all cached QAItems covering the viewport
- getItems(projection) {
- const viewport = projection.clipExtent();
- const min = [viewport[0][0], viewport[1][1]];
- const max = [viewport[1][0], viewport[0][1]];
- const bbox = geoExtent(projection.invert(min), projection.invert(max)).bbox();
+ getItems: function getItems(projection) {
+ var viewport = projection.clipExtent();
+ var min = [viewport[0][0], viewport[1][1]];
+ var max = [viewport[1][0], viewport[0][1]];
+ var bbox = geoExtent(projection.invert(min), projection.invert(max)).bbox();
- return _cache$1.rtree.search(bbox).map(d => d.data);
+ return _cache$1.rtree.search(bbox).map(function (d) { return d.data; });
},
// Get a QAItem from cache
// NOTE: Don't change method name until UI v3 is merged
- getError(id) {
+ getError: function getError(id) {
return _cache$1.data[id];
},
// get the name of the icon to display for this item
- getIcon(itemType) {
+ getIcon: function getIcon(itemType) {
return _impOsmData.icons[itemType];
},
// Replace a single QAItem in the cache
- replaceItem(issue) {
- if (!(issue instanceof QAItem) || !issue.id) return;
+ replaceItem: function replaceItem(issue) {
+ if (!(issue instanceof QAItem) || !issue.id) { return; }
_cache$1.data[issue.id] = issue;
updateRtree$1(encodeIssueRtree$1(issue), true); // true = replace
},
// Remove a single QAItem from the cache
- removeItem(issue) {
- if (!(issue instanceof QAItem) || !issue.id) return;
+ removeItem: function removeItem(issue) {
+ if (!(issue instanceof QAItem) || !issue.id) { return; }
delete _cache$1.data[issue.id];
updateRtree$1(encodeIssueRtree$1(issue), false); // false = remove
},
// Used to populate `closed:improveosm:*` changeset tags
- getClosedCounts() {
+ getClosedCounts: function getClosedCounts() {
return _cache$1.closed;
}
};
module.exports = {
defaults: getDefaults(),
- getDefaults,
- changeDefaults
+ getDefaults: getDefaults,
+ changeDefaults: changeDefaults
};
});
/**
* Helpers
*/
- const escapeTest = /[&<>"']/;
- const escapeReplace = /[&<>"']/g;
- const escapeTestNoEncode = /[<>"']|&(?!#?\w+;)/;
- const escapeReplaceNoEncode = /[<>"']|&(?!#?\w+;)/g;
- const escapeReplacements = {
+ var escapeTest = /[&<>"']/;
+ var escapeReplace = /[&<>"']/g;
+ var escapeTestNoEncode = /[<>"']|&(?!#?\w+;)/;
+ var escapeReplaceNoEncode = /[<>"']|&(?!#?\w+;)/g;
+ var escapeReplacements = {
'&': '&',
'<': '<',
'>': '>',
'"': '"',
"'": '''
};
- const getEscapeReplacement = (ch) => escapeReplacements[ch];
+ var getEscapeReplacement = function (ch) { return escapeReplacements[ch]; };
function escape$1(html, encode) {
if (encode) {
if (escapeTest.test(html)) {
return html;
}
- const unescapeTest = /&(#(?:\d+)|(?:#x[0-9A-Fa-f]+)|(?:\w+));?/ig;
+ var unescapeTest = /&(#(?:\d+)|(?:#x[0-9A-Fa-f]+)|(?:\w+));?/ig;
function unescape$1(html) {
// explicitly match decimal, hex, and named HTML entities
- return html.replace(unescapeTest, (_, n) => {
+ return html.replace(unescapeTest, function (_, n) {
n = n.toLowerCase();
- if (n === 'colon') return ':';
+ if (n === 'colon') { return ':'; }
if (n.charAt(0) === '#') {
return n.charAt(1) === 'x'
? String.fromCharCode(parseInt(n.substring(2), 16))
});
}
- const caret = /(^|[^\[])\^/g;
+ var caret = /(^|[^\[])\^/g;
function edit(regex, opt) {
regex = regex.source || regex;
opt = opt || '';
- const obj = {
- replace: (name, val) => {
+ var obj = {
+ replace: function (name, val) {
val = val.source || val;
val = val.replace(caret, '$1');
regex = regex.replace(name, val);
return obj;
},
- getRegex: () => {
+ getRegex: function () {
return new RegExp(regex, opt);
}
};
return obj;
}
- const nonWordAndColonTest = /[^\w:]/g;
- const originIndependentUrl = /^$|^[a-z][a-z0-9+.-]*:|^[?#]/i;
+ var nonWordAndColonTest = /[^\w:]/g;
+ var originIndependentUrl = /^$|^[a-z][a-z0-9+.-]*:|^[?#]/i;
function cleanUrl(sanitize, base, href) {
if (sanitize) {
- let prot;
+ var prot;
try {
prot = decodeURIComponent(unescape$1(href))
.replace(nonWordAndColonTest, '')
}
try {
href = encodeURI(href).replace(/%25/g, '%');
- } catch (e) {
+ } catch (e$1) {
return null;
}
return href;
}
- const baseUrls = {};
- const justDomain = /^[^:]+:\/*[^/]*$/;
- const protocol = /^([^:]+:)[\s\S]*$/;
- const domain = /^([^:]+:\/*[^/]*)[\s\S]*$/;
+ var baseUrls = {};
+ var justDomain = /^[^:]+:\/*[^/]*$/;
+ var protocol = /^([^:]+:)[\s\S]*$/;
+ var domain = /^([^:]+:\/*[^/]*)[\s\S]*$/;
function resolveUrl(base, href) {
if (!baseUrls[' ' + base]) {
}
}
base = baseUrls[' ' + base];
- const relativeBase = base.indexOf(':') === -1;
+ var relativeBase = base.indexOf(':') === -1;
if (href.substring(0, 2) === '//') {
if (relativeBase) {
}
}
- const noopTest = { exec: function noopTest() {} };
+ var noopTest = { exec: function noopTest() {} };
function merge$1(obj) {
- let i = 1,
+ var arguments$1 = arguments;
+
+ var i = 1,
target,
key;
for (; i < arguments.length; i++) {
- target = arguments[i];
+ target = arguments$1[i];
for (key in target) {
if (Object.prototype.hasOwnProperty.call(target, key)) {
obj[key] = target[key];
function splitCells(tableRow, count) {
// ensure that every cell-delimiting pipe has a space
// before it to distinguish it from an escaped pipe
- const row = tableRow.replace(/\|/g, (match, offset, str) => {
- let escaped = false,
+ var row = tableRow.replace(/\|/g, function (match, offset, str) {
+ var escaped = false,
curr = offset;
- while (--curr >= 0 && str[curr] === '\\') escaped = !escaped;
+ while (--curr >= 0 && str[curr] === '\\') { escaped = !escaped; }
if (escaped) {
// odd number of slashes means | is escaped
// so we leave it alone
}
}),
cells = row.split(/ \|/);
- let i = 0;
+ var i = 0;
if (cells.length > count) {
cells.splice(count);
} else {
- while (cells.length < count) cells.push('');
+ while (cells.length < count) { cells.push(''); }
}
for (; i < cells.length; i++) {
// /c*$/ is vulnerable to REDOS.
// invert: Remove suffix of non-c chars instead. Default falsey.
function rtrim(str, c, invert) {
- const l = str.length;
+ var l = str.length;
if (l === 0) {
return '';
}
// Length of suffix matching the invert condition.
- let suffLen = 0;
+ var suffLen = 0;
// Step left until we fail to match the invert condition.
while (suffLen < l) {
- const currChar = str.charAt(l - suffLen - 1);
+ var currChar = str.charAt(l - suffLen - 1);
if (currChar === c && !invert) {
suffLen++;
} else if (currChar !== c && invert) {
if (str.indexOf(b[1]) === -1) {
return -1;
}
- const l = str.length;
- let level = 0,
+ var l = str.length;
+ var level = 0,
i = 0;
for (; i < l; i++) {
if (str[i] === '\\') {
var helpers = {
escape: escape$1,
unescape: unescape$1,
- edit,
- cleanUrl,
- resolveUrl,
- noopTest,
+ edit: edit,
+ cleanUrl: cleanUrl,
+ resolveUrl: resolveUrl,
+ noopTest: noopTest,
merge: merge$1,
- splitCells,
- rtrim,
- findClosingBracket,
- checkSanitizeDeprecation
+ splitCells: splitCells,
+ rtrim: rtrim,
+ findClosingBracket: findClosingBracket,
+ checkSanitizeDeprecation: checkSanitizeDeprecation
};
- const { defaults: defaults$1 } = defaults;
- const {
- rtrim: rtrim$1,
- splitCells: splitCells$1,
- escape: escape$2,
- findClosingBracket: findClosingBracket$1
- } = helpers;
+ var defaults$1 = defaults.defaults;
+ var rtrim$1 = helpers.rtrim;
+ var splitCells$1 = helpers.splitCells;
+ var escape$2 = helpers.escape;
+ var findClosingBracket$1 = helpers.findClosingBracket;
function outputLink(cap, link, raw) {
- const href = link.href;
- const title = link.title ? escape$2(link.title) : null;
+ var href = link.href;
+ var title = link.title ? escape$2(link.title) : null;
if (cap[0].charAt(0) !== '!') {
return {
type: 'link',
- raw,
- href,
- title,
+ raw: raw,
+ href: href,
+ title: title,
text: cap[1]
};
} else {
return {
type: 'image',
- raw,
+ raw: raw,
text: escape$2(cap[1]),
- href,
- title
+ href: href,
+ title: title
};
}
}
/**
* Tokenizer
*/
- var Tokenizer_1 = class Tokenizer {
- constructor(options) {
+ var Tokenizer_1 = /*@__PURE__*/(function () {
+ function Tokenizer(options) {
this.options = options || defaults$1;
}
- space(src) {
- const cap = this.rules.block.newline.exec(src);
+ Tokenizer.prototype.space = function space (src) {
+ var cap = this.rules.block.newline.exec(src);
if (cap) {
if (cap[0].length > 1) {
return {
}
return { raw: '\n' };
}
- }
+ };
- code(src, tokens) {
- const cap = this.rules.block.code.exec(src);
+ Tokenizer.prototype.code = function code (src, tokens) {
+ var cap = this.rules.block.code.exec(src);
if (cap) {
- const lastToken = tokens[tokens.length - 1];
+ var lastToken = tokens[tokens.length - 1];
// An indented code block cannot interrupt a paragraph.
if (lastToken && lastToken.type === 'paragraph') {
tokens.pop();
lastToken.raw += '\n' + cap[0];
return lastToken;
} else {
- const text = cap[0].replace(/^ {4}/gm, '');
+ var text = cap[0].replace(/^ {4}/gm, '');
return {
type: 'code',
raw: cap[0],
};
}
}
- }
+ };
- fences(src) {
- const cap = this.rules.block.fences.exec(src);
+ Tokenizer.prototype.fences = function fences (src) {
+ var cap = this.rules.block.fences.exec(src);
if (cap) {
return {
type: 'code',
text: cap[3] || ''
};
}
- }
+ };
- heading(src) {
- const cap = this.rules.block.heading.exec(src);
+ Tokenizer.prototype.heading = function heading (src) {
+ var cap = this.rules.block.heading.exec(src);
if (cap) {
return {
type: 'heading',
text: cap[2]
};
}
- }
+ };
- nptable(src) {
- const cap = this.rules.block.nptable.exec(src);
+ Tokenizer.prototype.nptable = function nptable (src) {
+ var cap = this.rules.block.nptable.exec(src);
if (cap) {
- const item = {
+ var item = {
type: 'table',
header: splitCells$1(cap[1].replace(/^ *| *\| *$/g, '')),
align: cap[2].replace(/^ *|\| *$/g, '').split(/ *\| */),
};
if (item.header.length === item.align.length) {
- let l = item.align.length;
- let i;
+ var l = item.align.length;
+ var i;
for (i = 0; i < l; i++) {
if (/^ *-+: *$/.test(item.align[i])) {
item.align[i] = 'right';
return item;
}
}
- }
+ };
- hr(src) {
- const cap = this.rules.block.hr.exec(src);
+ Tokenizer.prototype.hr = function hr (src) {
+ var cap = this.rules.block.hr.exec(src);
if (cap) {
return {
type: 'hr',
raw: cap[0]
};
}
- }
+ };
- blockquote(src) {
- const cap = this.rules.block.blockquote.exec(src);
+ Tokenizer.prototype.blockquote = function blockquote (src) {
+ var cap = this.rules.block.blockquote.exec(src);
if (cap) {
- const text = cap[0].replace(/^ *> ?/gm, '');
+ var text = cap[0].replace(/^ *> ?/gm, '');
return {
type: 'blockquote',
raw: cap[0],
- text
+ text: text
};
}
- }
+ };
- list(src) {
- const cap = this.rules.block.list.exec(src);
+ Tokenizer.prototype.list = function list (src) {
+ var cap = this.rules.block.list.exec(src);
if (cap) {
- let raw = cap[0];
- const bull = cap[2];
- const isordered = bull.length > 1;
+ var raw = cap[0];
+ var bull = cap[2];
+ var isordered = bull.length > 1;
- const list = {
+ var list = {
type: 'list',
- raw,
+ raw: raw,
ordered: isordered,
start: isordered ? +bull : '',
loose: false,
};
// Get each top-level item.
- const itemMatch = cap[0].match(this.rules.block.item);
+ var itemMatch = cap[0].match(this.rules.block.item);
- let next = false,
+ var next = false,
item,
space,
b,
istask,
ischecked;
- const l = itemMatch.length;
- for (let i = 0; i < l; i++) {
+ var l = itemMatch.length;
+ for (var i = 0; i < l; i++) {
item = itemMatch[i];
raw = item;
loose = next || /\n\n(?!\s*$)/.test(item);
if (i !== l - 1) {
next = item.charAt(item.length - 1) === '\n';
- if (!loose) loose = next;
+ if (!loose) { loose = next; }
}
if (loose) {
}
list.items.push({
- raw,
+ raw: raw,
task: istask,
checked: ischecked,
loose: loose,
return list;
}
- }
+ };
- html(src) {
- const cap = this.rules.block.html.exec(src);
+ Tokenizer.prototype.html = function html (src) {
+ var cap = this.rules.block.html.exec(src);
if (cap) {
return {
type: this.options.sanitize
text: this.options.sanitize ? (this.options.sanitizer ? this.options.sanitizer(cap[0]) : escape$2(cap[0])) : cap[0]
};
}
- }
+ };
- def(src) {
- const cap = this.rules.block.def.exec(src);
+ Tokenizer.prototype.def = function def (src) {
+ var cap = this.rules.block.def.exec(src);
if (cap) {
- if (cap[3]) cap[3] = cap[3].substring(1, cap[3].length - 1);
- const tag = cap[1].toLowerCase().replace(/\s+/g, ' ');
+ if (cap[3]) { cap[3] = cap[3].substring(1, cap[3].length - 1); }
+ var tag = cap[1].toLowerCase().replace(/\s+/g, ' ');
return {
- tag,
+ tag: tag,
raw: cap[0],
href: cap[2],
title: cap[3]
};
}
- }
+ };
- table(src) {
- const cap = this.rules.block.table.exec(src);
+ Tokenizer.prototype.table = function table (src) {
+ var cap = this.rules.block.table.exec(src);
if (cap) {
- const item = {
+ var item = {
type: 'table',
header: splitCells$1(cap[1].replace(/^ *| *\| *$/g, '')),
align: cap[2].replace(/^ *|\| *$/g, '').split(/ *\| */),
if (item.header.length === item.align.length) {
item.raw = cap[0];
- let l = item.align.length;
- let i;
+ var l = item.align.length;
+ var i;
for (i = 0; i < l; i++) {
if (/^ *-+: *$/.test(item.align[i])) {
item.align[i] = 'right';
return item;
}
}
- }
+ };
- lheading(src) {
- const cap = this.rules.block.lheading.exec(src);
+ Tokenizer.prototype.lheading = function lheading (src) {
+ var cap = this.rules.block.lheading.exec(src);
if (cap) {
return {
type: 'heading',
text: cap[1]
};
}
- }
+ };
- paragraph(src) {
- const cap = this.rules.block.paragraph.exec(src);
+ Tokenizer.prototype.paragraph = function paragraph (src) {
+ var cap = this.rules.block.paragraph.exec(src);
if (cap) {
return {
type: 'paragraph',
: cap[1]
};
}
- }
+ };
- text(src) {
- const cap = this.rules.block.text.exec(src);
+ Tokenizer.prototype.text = function text (src) {
+ var cap = this.rules.block.text.exec(src);
if (cap) {
return {
type: 'text',
text: cap[0]
};
}
- }
+ };
- escape(src) {
- const cap = this.rules.inline.escape.exec(src);
+ Tokenizer.prototype.escape = function escape$1 (src) {
+ var cap = this.rules.inline.escape.exec(src);
if (cap) {
return {
type: 'escape',
text: escape$2(cap[1])
};
}
- }
+ };
- tag(src, inLink, inRawBlock) {
- const cap = this.rules.inline.tag.exec(src);
+ Tokenizer.prototype.tag = function tag (src, inLink, inRawBlock) {
+ var cap = this.rules.inline.tag.exec(src);
if (cap) {
if (!inLink && /^<a /i.test(cap[0])) {
inLink = true;
? 'text'
: 'html',
raw: cap[0],
- inLink,
- inRawBlock,
+ inLink: inLink,
+ inRawBlock: inRawBlock,
text: this.options.sanitize
? (this.options.sanitizer
? this.options.sanitizer(cap[0])
: cap[0]
};
}
- }
+ };
- link(src) {
- const cap = this.rules.inline.link.exec(src);
+ Tokenizer.prototype.link = function link (src) {
+ var cap = this.rules.inline.link.exec(src);
if (cap) {
- const lastParenIndex = findClosingBracket$1(cap[2], '()');
+ var lastParenIndex = findClosingBracket$1(cap[2], '()');
if (lastParenIndex > -1) {
- const start = cap[0].indexOf('!') === 0 ? 5 : 4;
- const linkLen = start + cap[1].length + lastParenIndex;
+ var start = cap[0].indexOf('!') === 0 ? 5 : 4;
+ var linkLen = start + cap[1].length + lastParenIndex;
cap[2] = cap[2].substring(0, lastParenIndex);
cap[0] = cap[0].substring(0, linkLen).trim();
cap[3] = '';
}
- let href = cap[2];
- let title = '';
+ var href = cap[2];
+ var title = '';
if (this.options.pedantic) {
- const link = /^([^'"]*[^\s])\s+(['"])(.*)\2/.exec(href);
+ var link = /^([^'"]*[^\s])\s+(['"])(.*)\2/.exec(href);
if (link) {
href = link[1];
title = cap[3] ? cap[3].slice(1, -1) : '';
}
href = href.trim().replace(/^<([\s\S]*)>$/, '$1');
- const token = outputLink(cap, {
+ var token = outputLink(cap, {
href: href ? href.replace(this.rules.inline._escapes, '$1') : href,
title: title ? title.replace(this.rules.inline._escapes, '$1') : title
}, cap[0]);
return token;
}
- }
+ };
- reflink(src, links) {
- let cap;
+ Tokenizer.prototype.reflink = function reflink (src, links) {
+ var cap;
if ((cap = this.rules.inline.reflink.exec(src))
|| (cap = this.rules.inline.nolink.exec(src))) {
- let link = (cap[2] || cap[1]).replace(/\s+/g, ' ');
+ var link = (cap[2] || cap[1]).replace(/\s+/g, ' ');
link = links[link.toLowerCase()];
if (!link || !link.href) {
- const text = cap[0].charAt(0);
+ var text = cap[0].charAt(0);
return {
type: 'text',
raw: text,
- text
+ text: text
};
}
- const token = outputLink(cap, link, cap[0]);
+ var token = outputLink(cap, link, cap[0]);
return token;
}
- }
+ };
- strong(src) {
- const cap = this.rules.inline.strong.exec(src);
+ Tokenizer.prototype.strong = function strong (src) {
+ var cap = this.rules.inline.strong.exec(src);
if (cap) {
return {
type: 'strong',
text: cap[4] || cap[3] || cap[2] || cap[1]
};
}
- }
+ };
- em(src) {
- const cap = this.rules.inline.em.exec(src);
+ Tokenizer.prototype.em = function em (src) {
+ var cap = this.rules.inline.em.exec(src);
if (cap) {
return {
type: 'em',
text: cap[6] || cap[5] || cap[4] || cap[3] || cap[2] || cap[1]
};
}
- }
+ };
- codespan(src) {
- const cap = this.rules.inline.code.exec(src);
+ Tokenizer.prototype.codespan = function codespan (src) {
+ var cap = this.rules.inline.code.exec(src);
if (cap) {
return {
type: 'codespan',
text: escape$2(cap[2].trim(), true)
};
}
- }
+ };
- br(src) {
- const cap = this.rules.inline.br.exec(src);
+ Tokenizer.prototype.br = function br (src) {
+ var cap = this.rules.inline.br.exec(src);
if (cap) {
return {
type: 'br',
raw: cap[0]
};
}
- }
+ };
- del(src) {
- const cap = this.rules.inline.del.exec(src);
+ Tokenizer.prototype.del = function del (src) {
+ var cap = this.rules.inline.del.exec(src);
if (cap) {
return {
type: 'del',
text: cap[1]
};
}
- }
+ };
- autolink(src, mangle) {
- const cap = this.rules.inline.autolink.exec(src);
+ Tokenizer.prototype.autolink = function autolink (src, mangle) {
+ var cap = this.rules.inline.autolink.exec(src);
if (cap) {
- let text, href;
+ var text, href;
if (cap[2] === '@') {
text = escape$2(this.options.mangle ? mangle(cap[1]) : cap[1]);
href = 'mailto:' + text;
return {
type: 'link',
raw: cap[0],
- text,
- href,
+ text: text,
+ href: href,
tokens: [
{
type: 'text',
raw: text,
- text
+ text: text
}
]
};
}
- }
+ };
- url(src, mangle) {
- let cap;
+ Tokenizer.prototype.url = function url (src, mangle) {
+ var cap;
if (cap = this.rules.inline.url.exec(src)) {
- let text, href;
+ var text, href;
if (cap[2] === '@') {
text = escape$2(this.options.mangle ? mangle(cap[0]) : cap[0]);
href = 'mailto:' + text;
} else {
// do extended autolink path validation
- let prevCapZero;
+ var prevCapZero;
do {
prevCapZero = cap[0];
cap[0] = this.rules.inline._backpedal.exec(cap[0])[0];
return {
type: 'link',
raw: cap[0],
- text,
- href,
+ text: text,
+ href: href,
tokens: [
{
type: 'text',
raw: text,
- text
+ text: text
}
]
};
}
- }
+ };
- inlineText(src, inRawBlock, smartypants) {
- const cap = this.rules.inline.text.exec(src);
+ Tokenizer.prototype.inlineText = function inlineText (src, inRawBlock, smartypants) {
+ var cap = this.rules.inline.text.exec(src);
if (cap) {
- let text;
+ var text;
if (inRawBlock) {
text = this.options.sanitize ? (this.options.sanitizer ? this.options.sanitizer(cap[0]) : escape$2(cap[0])) : cap[0];
} else {
return {
type: 'text',
raw: cap[0],
- text
+ text: text
};
}
- }
- };
+ };
+
+ return Tokenizer;
+ }());
- const {
- noopTest: noopTest$1,
- edit: edit$1,
- merge: merge$2
- } = helpers;
+ var noopTest$1 = helpers.noopTest;
+ var edit$1 = helpers.edit;
+ var merge$2 = helpers.merge;
/**
* Block-Level Grammar
*/
- const block = {
+ var block = {
newline: /^\n+/,
code: /^( {4}[^\n]+\n*)+/,
fences: /^ {0,3}(`{3,}(?=[^`\n]*\n)|~{3,})([^\n]*)\n(?:|([\s\S]*?)\n)(?: {0,3}\1[~`]* *(?:\n+|$)|$)/,
/**
* Inline-Level Grammar
*/
- const inline = {
+ var inline = {
escape: /^\\([!"#$%&'()*+,\-./:;<=>?@\[\]\\^_`{|}~])/,
autolink: /^<(scheme:[^\s\x00-\x1f<>]*|email)>/,
url: noopTest$1,
});
var rules = {
- block,
- inline
+ block: block,
+ inline: inline
};
- const { defaults: defaults$2 } = defaults;
- const { block: block$1, inline: inline$1 } = rules;
+ var defaults$2 = defaults.defaults;
+ var block$1 = rules.block;
+ var inline$1 = rules.inline;
/**
* smartypants text replacement
* mangle email addresses
*/
function mangle(text) {
- let out = '',
+ var out = '',
i,
ch;
- const l = text.length;
+ var l = text.length;
for (i = 0; i < l; i++) {
ch = text.charCodeAt(i);
if (Math.random() > 0.5) {
/**
* Block Lexer
*/
- var Lexer_1 = class Lexer {
- constructor(options) {
+ var Lexer_1 = /*@__PURE__*/(function () {
+ function Lexer(options) {
this.tokens = [];
this.tokens.links = Object.create(null);
this.options = options || defaults$2;
this.tokenizer = this.options.tokenizer;
this.tokenizer.options = this.options;
- const rules = {
+ var rules = {
block: block$1.normal,
inline: inline$1.normal
};
this.tokenizer.rules = rules;
}
+ var staticAccessors = { rules: { configurable: true } };
+
/**
* Expose Rules
*/
- static get rules() {
+ staticAccessors.rules.get = function () {
return {
block: block$1,
inline: inline$1
};
- }
+ };
/**
* Static Lex Method
*/
- static lex(src, options) {
- const lexer = new Lexer(options);
+ Lexer.lex = function lex (src, options) {
+ var lexer = new Lexer(options);
return lexer.lex(src);
- }
+ };
/**
* Preprocessing
*/
- lex(src) {
+ Lexer.prototype.lex = function lex (src) {
src = src
.replace(/\r\n|\r/g, '\n')
.replace(/\t/g, ' ');
this.inline(this.tokens);
return this.tokens;
- }
+ };
/**
* Lexing
*/
- blockTokens(src, tokens = [], top = true) {
+ Lexer.prototype.blockTokens = function blockTokens (src, tokens, top) {
+ if ( tokens === void 0 ) tokens = [];
+ if ( top === void 0 ) top = true;
+
src = src.replace(/^ +$/gm, '');
- let token, i, l;
+ var token, i, l;
while (src) {
// newline
}
if (src) {
- const errMsg = 'Infinite loop on byte: ' + src.charCodeAt(0);
+ var errMsg = 'Infinite loop on byte: ' + src.charCodeAt(0);
if (this.options.silent) {
console.error(errMsg);
break;
}
return tokens;
- }
+ };
- inline(tokens) {
- let i,
+ Lexer.prototype.inline = function inline (tokens) {
+ var i,
j,
k,
l2,
row,
token;
- const l = tokens.length;
+ var l = tokens.length;
for (i = 0; i < l; i++) {
token = tokens[i];
switch (token.type) {
}
return tokens;
- }
+ };
/**
* Lexing/Compiling
*/
- inlineTokens(src, tokens = [], inLink = false, inRawBlock = false) {
- let token;
+ Lexer.prototype.inlineTokens = function inlineTokens (src, tokens, inLink, inRawBlock) {
+ if ( tokens === void 0 ) tokens = [];
+ if ( inLink === void 0 ) inLink = false;
+ if ( inRawBlock === void 0 ) inRawBlock = false;
+
+ var token;
while (src) {
// escape
}
if (src) {
- const errMsg = 'Infinite loop on byte: ' + src.charCodeAt(0);
+ var errMsg = 'Infinite loop on byte: ' + src.charCodeAt(0);
if (this.options.silent) {
console.error(errMsg);
break;
}
return tokens;
- }
- };
+ };
+
+ Object.defineProperties( Lexer, staticAccessors );
- const { defaults: defaults$3 } = defaults;
- const {
- cleanUrl: cleanUrl$1,
- escape: escape$3
- } = helpers;
+ return Lexer;
+ }());
+
+ var defaults$3 = defaults.defaults;
+ var cleanUrl$1 = helpers.cleanUrl;
+ var escape$3 = helpers.escape;
/**
* Renderer
*/
- var Renderer_1 = class Renderer {
- constructor(options) {
+ var Renderer_1 = /*@__PURE__*/(function () {
+ function Renderer(options) {
this.options = options || defaults$3;
}
- code(code, infostring, escaped) {
- const lang = (infostring || '').match(/\S*/)[0];
+ Renderer.prototype.code = function code (code$1, infostring, escaped) {
+ var lang = (infostring || '').match(/\S*/)[0];
if (this.options.highlight) {
- const out = this.options.highlight(code, lang);
- if (out != null && out !== code) {
+ var out = this.options.highlight(code$1, lang);
+ if (out != null && out !== code$1) {
escaped = true;
- code = out;
+ code$1 = out;
}
}
if (!lang) {
return '<pre><code>'
- + (escaped ? code : escape$3(code, true))
+ + (escaped ? code$1 : escape$3(code$1, true))
+ '</code></pre>';
}
+ this.options.langPrefix
+ escape$3(lang, true)
+ '">'
- + (escaped ? code : escape$3(code, true))
+ + (escaped ? code$1 : escape$3(code$1, true))
+ '</code></pre>\n';
- }
+ };
- blockquote(quote) {
+ Renderer.prototype.blockquote = function blockquote (quote) {
return '<blockquote>\n' + quote + '</blockquote>\n';
- }
+ };
- html(html) {
- return html;
- }
+ Renderer.prototype.html = function html (html$1) {
+ return html$1;
+ };
- heading(text, level, raw, slugger) {
+ Renderer.prototype.heading = function heading (text, level, raw, slugger) {
if (this.options.headerIds) {
return '<h'
+ level
}
// ignore IDs
return '<h' + level + '>' + text + '</h' + level + '>\n';
- }
+ };
- hr() {
+ Renderer.prototype.hr = function hr () {
return this.options.xhtml ? '<hr/>\n' : '<hr>\n';
- }
+ };
- list(body, ordered, start) {
- const type = ordered ? 'ol' : 'ul',
+ Renderer.prototype.list = function list (body, ordered, start) {
+ var type = ordered ? 'ol' : 'ul',
startatt = (ordered && start !== 1) ? (' start="' + start + '"') : '';
return '<' + type + startatt + '>\n' + body + '</' + type + '>\n';
- }
+ };
- listitem(text) {
+ Renderer.prototype.listitem = function listitem (text) {
return '<li>' + text + '</li>\n';
- }
+ };
- checkbox(checked) {
+ Renderer.prototype.checkbox = function checkbox (checked) {
return '<input '
+ (checked ? 'checked="" ' : '')
+ 'disabled="" type="checkbox"'
+ (this.options.xhtml ? ' /' : '')
+ '> ';
- }
+ };
- paragraph(text) {
+ Renderer.prototype.paragraph = function paragraph (text) {
return '<p>' + text + '</p>\n';
- }
+ };
- table(header, body) {
- if (body) body = '<tbody>' + body + '</tbody>';
+ Renderer.prototype.table = function table (header, body) {
+ if (body) { body = '<tbody>' + body + '</tbody>'; }
return '<table>\n'
+ '<thead>\n'
+ '</thead>\n'
+ body
+ '</table>\n';
- }
+ };
- tablerow(content) {
+ Renderer.prototype.tablerow = function tablerow (content) {
return '<tr>\n' + content + '</tr>\n';
- }
+ };
- tablecell(content, flags) {
- const type = flags.header ? 'th' : 'td';
- const tag = flags.align
+ Renderer.prototype.tablecell = function tablecell (content, flags) {
+ var type = flags.header ? 'th' : 'td';
+ var tag = flags.align
? '<' + type + ' align="' + flags.align + '">'
: '<' + type + '>';
return tag + content + '</' + type + '>\n';
- }
+ };
// span level renderer
- strong(text) {
+ Renderer.prototype.strong = function strong (text) {
return '<strong>' + text + '</strong>';
- }
+ };
- em(text) {
+ Renderer.prototype.em = function em (text) {
return '<em>' + text + '</em>';
- }
+ };
- codespan(text) {
+ Renderer.prototype.codespan = function codespan (text) {
return '<code>' + text + '</code>';
- }
+ };
- br() {
+ Renderer.prototype.br = function br () {
return this.options.xhtml ? '<br/>' : '<br>';
- }
+ };
- del(text) {
+ Renderer.prototype.del = function del (text) {
return '<del>' + text + '</del>';
- }
+ };
- link(href, title, text) {
+ Renderer.prototype.link = function link (href, title, text) {
href = cleanUrl$1(this.options.sanitize, this.options.baseUrl, href);
if (href === null) {
return text;
}
- let out = '<a href="' + escape$3(href) + '"';
+ var out = '<a href="' + escape$3(href) + '"';
if (title) {
out += ' title="' + title + '"';
}
out += '>' + text + '</a>';
return out;
- }
+ };
- image(href, title, text) {
+ Renderer.prototype.image = function image (href, title, text) {
href = cleanUrl$1(this.options.sanitize, this.options.baseUrl, href);
if (href === null) {
return text;
}
- let out = '<img src="' + href + '" alt="' + text + '"';
+ var out = '<img src="' + href + '" alt="' + text + '"';
if (title) {
out += ' title="' + title + '"';
}
out += this.options.xhtml ? '/>' : '>';
return out;
- }
+ };
- text(text) {
- return text;
- }
- };
+ Renderer.prototype.text = function text (text$1) {
+ return text$1;
+ };
+
+ return Renderer;
+ }());
/**
* TextRenderer
* returns only the textual part of the token
*/
- var TextRenderer_1 = class TextRenderer {
- // no need for block level renderers
- strong(text) {
- return text;
- }
+ var TextRenderer_1 = /*@__PURE__*/(function () {
+ function TextRenderer () {}
- em(text) {
+ TextRenderer.prototype.strong = function strong (text) {
return text;
- }
+ };
- codespan(text) {
+ TextRenderer.prototype.em = function em (text) {
return text;
- }
+ };
- del(text) {
+ TextRenderer.prototype.codespan = function codespan (text) {
return text;
- }
+ };
- html(text) {
+ TextRenderer.prototype.del = function del (text) {
return text;
- }
+ };
- text(text) {
+ TextRenderer.prototype.html = function html (text) {
return text;
- }
+ };
- link(href, title, text) {
+ TextRenderer.prototype.text = function text (text$1) {
+ return text$1;
+ };
+
+ TextRenderer.prototype.link = function link (href, title, text) {
return '' + text;
- }
+ };
- image(href, title, text) {
+ TextRenderer.prototype.image = function image (href, title, text) {
return '' + text;
- }
+ };
- br() {
+ TextRenderer.prototype.br = function br () {
return '';
- }
- };
+ };
+
+ return TextRenderer;
+ }());
/**
* Slugger generates header id
*/
- var Slugger_1 = class Slugger {
- constructor() {
+ var Slugger_1 = /*@__PURE__*/(function () {
+ function Slugger() {
this.seen = {};
}
/**
* Convert string to unique id
*/
- slug(value) {
- let slug = value
+ Slugger.prototype.slug = function slug (value) {
+ var slug = value
.toLowerCase()
.trim()
// remove html tags
.replace(/\s/g, '-');
if (this.seen.hasOwnProperty(slug)) {
- const originalSlug = slug;
+ var originalSlug = slug;
do {
this.seen[originalSlug]++;
slug = originalSlug + '-' + this.seen[originalSlug];
this.seen[slug] = 0;
return slug;
- }
- };
+ };
+
+ return Slugger;
+ }());
- const { defaults: defaults$4 } = defaults;
- const {
- unescape: unescape$2
- } = helpers;
+ var defaults$4 = defaults.defaults;
+ var unescape$2 = helpers.unescape;
/**
* Parsing & Compiling
*/
- var Parser_1 = class Parser {
- constructor(options) {
+ var Parser_1 = /*@__PURE__*/(function () {
+ function Parser(options) {
this.options = options || defaults$4;
this.options.renderer = this.options.renderer || new Renderer_1();
this.renderer = this.options.renderer;
/**
* Static Parse Method
*/
- static parse(tokens, options) {
- const parser = new Parser(options);
+ Parser.parse = function parse (tokens, options) {
+ var parser = new Parser(options);
return parser.parse(tokens);
- }
+ };
/**
* Parse Loop
*/
- parse(tokens, top = true) {
- let out = '',
+ Parser.prototype.parse = function parse (tokens, top) {
+ if ( top === void 0 ) top = true;
+
+ var out = '',
i,
j,
k,
task,
checkbox;
- const l = tokens.length;
+ var l = tokens.length;
for (i = 0; i < l; i++) {
token = tokens[i];
switch (token.type) {
continue;
}
default: {
- const errMsg = 'Token with "' + token.type + '" type was not found.';
+ var errMsg = 'Token with "' + token.type + '" type was not found.';
if (this.options.silent) {
console.error(errMsg);
return;
}
return out;
- }
+ };
/**
* Parse Inline Tokens
*/
- parseInline(tokens, renderer) {
+ Parser.prototype.parseInline = function parseInline (tokens, renderer) {
renderer = renderer || this.renderer;
- let out = '',
+ var out = '',
i,
token;
- const l = tokens.length;
+ var l = tokens.length;
for (i = 0; i < l; i++) {
token = tokens[i];
switch (token.type) {
break;
}
default: {
- const errMsg = 'Token with "' + token.type + '" type was not found.';
+ var errMsg = 'Token with "' + token.type + '" type was not found.';
if (this.options.silent) {
console.error(errMsg);
return;
}
}
return out;
- }
- };
+ };
- const {
- merge: merge$3,
- checkSanitizeDeprecation: checkSanitizeDeprecation$1,
- escape: escape$4
- } = helpers;
- const {
- getDefaults,
- changeDefaults,
- defaults: defaults$5
- } = defaults;
+ return Parser;
+ }());
+
+ var merge$3 = helpers.merge;
+ var checkSanitizeDeprecation$1 = helpers.checkSanitizeDeprecation;
+ var escape$4 = helpers.escape;
+ var getDefaults = defaults.getDefaults;
+ var changeDefaults = defaults.changeDefaults;
+ var defaults$5 = defaults.defaults;
/**
* Marked
opt = merge$3({}, marked.defaults, opt || {});
checkSanitizeDeprecation$1(opt);
- const highlight = opt.highlight;
- let tokens,
+ var highlight = opt.highlight;
+ var tokens,
pending,
i = 0;
pending = tokens.length;
- const done = function(err) {
+ var done = function(err) {
if (err) {
opt.highlight = highlight;
return callback(err);
}
- let out;
+ var out;
try {
out = Parser_1.parse(tokens, opt);
delete opt.highlight;
- if (!pending) return done();
+ if (!pending) { return done(); }
for (; i < tokens.length; i++) {
(function(token) {
return --pending || done();
}
return highlight(token.text, token.lang, function(err, code) {
- if (err) return done(err);
+ if (err) { return done(err); }
if (code == null || code === token.text) {
return --pending || done();
}
opt = merge$3({}, marked.defaults, opt || {});
checkSanitizeDeprecation$1(opt);
return Parser_1.parse(Lexer_1.lex(src, opt), opt);
- } catch (e) {
- e.message += '\nPlease report this to https://github.com/markedjs/marked.';
+ } catch (e$1) {
+ e$1.message += '\nPlease report this to https://github.com/markedjs/marked.';
if ((opt || marked.defaults).silent) {
return '<p>An error occurred:</p><pre>'
- + escape$4(e.message + '', true)
+ + escape$4(e$1.message + '', true)
+ '</pre>';
}
- throw e;
+ throw e$1;
}
}
*/
marked.use = function(extension) {
- const opts = merge$3({}, extension);
+ var opts = merge$3({}, extension);
if (extension.renderer) {
- const renderer = marked.defaults.renderer || new Renderer_1();
- for (const prop in extension.renderer) {
- const prevRenderer = renderer[prop];
- renderer[prop] = (...args) => {
- let ret = extension.renderer[prop].apply(renderer, args);
+ var renderer = marked.defaults.renderer || new Renderer_1();
+ var loop = function ( prop ) {
+ var prevRenderer = renderer[prop];
+ renderer[prop] = function () {
+ var args = [], len = arguments.length;
+ while ( len-- ) args[ len ] = arguments[ len ];
+
+ var ret = extension.renderer[prop].apply(renderer, args);
if (ret === false) {
ret = prevRenderer.apply(renderer, args);
}
return ret;
};
- }
+ };
+
+ for (var prop in extension.renderer) loop( prop );
opts.renderer = renderer;
}
if (extension.tokenizer) {
- const tokenizer = marked.defaults.tokenizer || new Tokenizer_1();
- for (const prop in extension.tokenizer) {
- const prevTokenizer = tokenizer[prop];
- tokenizer[prop] = (...args) => {
- let ret = extension.tokenizer[prop].apply(tokenizer, args);
+ var tokenizer = marked.defaults.tokenizer || new Tokenizer_1();
+ var loop$1 = function ( prop ) {
+ var prevTokenizer = tokenizer[prop$1];
+ tokenizer[prop$1] = function () {
+ var args = [], len = arguments.length;
+ while ( len-- ) args[ len ] = arguments[ len ];
+
+ var ret = extension.tokenizer[prop$1].apply(tokenizer, args);
if (ret === false) {
ret = prevTokenizer.apply(tokenizer, args);
}
return ret;
};
- }
+ };
+
+ for (var prop$1 in extension.tokenizer) loop$1( prop );
opts.tokenizer = tokenizer;
}
marked.setOptions(opts);
var marked_1 = marked;
- const tiler$2 = utilTiler();
- const dispatch$3 = dispatch('loaded');
- const _tileZoom$2 = 14;
- const _osmoseUrlRoot = 'https://osmose.openstreetmap.fr/api/0.3';
- let _osmoseData = { icons: {}, items: [] };
+ var tiler$2 = utilTiler();
+ var dispatch$3 = dispatch('loaded');
+ var _tileZoom$2 = 14;
+ var _osmoseUrlRoot = 'https://osmose.openstreetmap.fr/api/0.3';
+ var _osmoseData = { icons: {}, items: [] };
// This gets reassigned if reset
- let _cache$2;
+ var _cache$2;
function abortRequest$2(controller) {
if (controller) {
}
function abortUnwantedRequests$2(cache, tiles) {
- Object.keys(cache.inflightTile).forEach(k => {
- let wanted = tiles.find(tile => k === tile.id);
+ Object.keys(cache.inflightTile).forEach(function (k) {
+ var wanted = tiles.find(function (tile) { return k === tile.id; });
if (!wanted) {
abortRequest$2(cache.inflightTile[k]);
delete cache.inflightTile[k];
// Replace or remove QAItem from rtree
function updateRtree$2(item, replace) {
- _cache$2.rtree.remove(item, (a, b) => a.data.id === b.data.id);
+ _cache$2.rtree.remove(item, function (a, b) { return a.data.id === b.data.id; });
if (replace) {
_cache$2.rtree.insert(item);
}
}
- // Issues shouldn't obscure eachother
+ // Issues shouldn't obscure each other
function preventCoincident$1(loc) {
- let coincident = false;
+ var coincident = false;
do {
// first time, move marker up. after that, move marker right.
- let delta = coincident ? [0.00001, 0] : [0, 0.00001];
+ var delta = coincident ? [0.00001, 0] : [0, 0.00001];
loc = geoVecAdd(loc, delta);
- let bbox = geoExtent(loc).bbox();
+ var bbox = geoExtent(loc).bbox();
coincident = _cache$2.rtree.search(bbox).length;
} while (coincident);
var serviceOsmose = {
title: 'osmose',
- init() {
+ init: function init() {
_mainFileFetcher.get('qa_data')
- .then(d => {
+ .then(function (d) {
_osmoseData = d.osmose;
_osmoseData.items = Object.keys(d.osmose.icons)
- .map(s => s.split('-')[0])
- .reduce((unique, item) => unique.indexOf(item) !== -1 ? unique : [...unique, item], []);
+ .map(function (s) { return s.split('-')[0]; })
+ .reduce(function (unique, item) { return unique.indexOf(item) !== -1 ? unique : unique.concat( [item]); }, []);
});
if (!_cache$2) {
this.event = utilRebind(this, dispatch$3, 'on');
},
- reset() {
- let _strings = {};
- let _colors = {};
+ reset: function reset() {
+ var _strings = {};
+ var _colors = {};
if (_cache$2) {
Object.values(_cache$2.inflightTile).forEach(abortRequest$2);
// Strings and colors are static and should not be re-populated
};
},
- loadIssues(projection) {
- let params = {
+ loadIssues: function loadIssues(projection) {
+ var this$1 = this;
+
+ var params = {
// Tiles return a maximum # of issues
// So we want to filter our request for only types iD supports
item: _osmoseData.items
};
// determine the needed tiles to cover the view
- let tiles = tiler$2
+ var tiles = tiler$2
.zoomExtent([_tileZoom$2, _tileZoom$2])
.getTiles(projection);
abortUnwantedRequests$2(_cache$2, tiles);
// issue new requests..
- tiles.forEach(tile => {
- if (_cache$2.loadedTile[tile.id] || _cache$2.inflightTile[tile.id]) return;
+ tiles.forEach(function (tile) {
+ if (_cache$2.loadedTile[tile.id] || _cache$2.inflightTile[tile.id]) { return; }
- let [ x, y, z ] = tile.xyz;
- let url = `${_osmoseUrlRoot}/issues/${z}/${x}/${y}.json?` + utilQsString(params);
+ var ref = tile.xyz;
+ var x = ref[0];
+ var y = ref[1];
+ var z = ref[2];
+ var url = _osmoseUrlRoot + "/issues/" + z + "/" + x + "/" + y + ".json?" + utilQsString(params);
- let controller = new AbortController();
+ var controller = new AbortController();
_cache$2.inflightTile[tile.id] = controller;
d3_json(url, { signal: controller.signal })
- .then(data => {
+ .then(function (data) {
delete _cache$2.inflightTile[tile.id];
_cache$2.loadedTile[tile.id] = true;
if (data.features) {
- data.features.forEach(issue => {
- const { item, class: cl, uuid: id } = issue.properties;
+ data.features.forEach(function (issue) {
+ var ref = issue.properties;
+ var item = ref.item;
+ var cl = ref.class;
+ var id = ref.uuid;
/* Osmose issues are uniquely identified by a unique
`item` and `class` combination (both integer values) */
- const itemType = `${item}-${cl}`;
+ var itemType = item + "-" + cl;
// Filter out unsupported issue types (some are too specific or advanced)
if (itemType in _osmoseData.icons) {
- let loc = issue.geometry.coordinates; // lon, lat
+ var loc = issue.geometry.coordinates; // lon, lat
loc = preventCoincident$1(loc);
- let d = new QAItem(loc, this, itemType, id, { item });
+ var d = new QAItem(loc, this$1, itemType, id, { item: item });
// Setting elems here prevents UI detail requests
if (item === 8300 || item === 8360) {
dispatch$3.call('loaded');
})
- .catch(() => {
+ .catch(function () {
delete _cache$2.inflightTile[tile.id];
_cache$2.loadedTile[tile.id] = true;
});
});
},
- loadIssueDetail(issue) {
+ loadIssueDetail: function loadIssueDetail(issue) {
+ var this$1 = this;
+
// Issue details only need to be fetched once
if (issue.elems !== undefined) {
return Promise.resolve(issue);
}
- const url = `${_osmoseUrlRoot}/issue/${issue.id}?langs=${_mainLocalizer.localeCode()}`;
- const cacheDetails = data => {
+ var url = _osmoseUrlRoot + "/issue/" + (issue.id) + "?langs=" + (_mainLocalizer.localeCode());
+ var cacheDetails = function (data) {
// Associated elements used for highlighting
// Assign directly for immediate use in the callback
- issue.elems = data.elems.map(e => e.type.substring(0,1) + e.id);
+ issue.elems = data.elems.map(function (e) { return e.type.substring(0,1) + e.id; });
// Some issues have instance specific detail in a subtitle
issue.detail = data.subtitle ? marked_1(data.subtitle.auto) : '';
- this.replaceItem(issue);
+ this$1.replaceItem(issue);
};
- return d3_json(url).then(cacheDetails).then(() => issue);
+ return d3_json(url).then(cacheDetails).then(function () { return issue; });
},
- loadStrings(locale=_mainLocalizer.localeCode()) {
- const items = Object.keys(_osmoseData.icons);
+ loadStrings: function loadStrings(locale) {
+ if ( locale === void 0 ) locale=_mainLocalizer.localeCode();
+
+ var items = Object.keys(_osmoseData.icons);
if (
locale in _cache$2.strings
// Only need to cache strings for supported issue types
// Using multiple individual item + class requests to reduce fetched data size
- const allRequests = items.map(itemType => {
+ var allRequests = items.map(function (itemType) {
// No need to request data we already have
- if (itemType in _cache$2.strings[locale]) return;
+ if (itemType in _cache$2.strings[locale]) { return; }
- const cacheData = data => {
+ var cacheData = function (data) {
// Bunch of nested single value arrays of objects
- const [ cat = {items:[]} ] = data.categories;
- const [ item = {class:[]} ] = cat.items;
- const [ cl = null ] = item.class;
+ var ref = data.categories;
+ var cat = ref[0]; if ( cat === void 0 ) cat = {items:[]};
+ var ref$1 = cat.items;
+ var item = ref$1[0]; if ( item === void 0 ) item = {class:[]};
+ var ref$2 = item.class;
+ var cl = ref$2[0]; if ( cl === void 0 ) cl = null;
// If null default value is reached, data wasn't as expected (or was empty)
if (!cl) {
/* eslint-disable no-console */
- console.log(`Osmose strings request (${itemType}) had unexpected data`);
+ console.log(("Osmose strings request (" + itemType + ") had unexpected data"));
/* eslint-enable no-console */
return;
}
// Cache served item colors to automatically style issue markers later
- const { item: itemInt, color } = item;
+ var itemInt = item.item;
+ var color = item.color;
if (/^#[A-Fa-f0-9]{6}|[A-Fa-f0-9]{3}/.test(color)) {
_cache$2.colors[itemInt] = color;
}
// Value of root key will be null if no string exists
// If string exists, value is an object with key 'auto' for string
- const { title, detail, fix, trap } = cl;
+ var title = cl.title;
+ var detail = cl.detail;
+ var fix = cl.fix;
+ var trap = cl.trap;
// Osmose titles shouldn't contain markdown
- let issueStrings = {};
- if (title) issueStrings.title = title.auto;
- if (detail) issueStrings.detail = marked_1(detail.auto);
- if (trap) issueStrings.trap = marked_1(trap.auto);
- if (fix) issueStrings.fix = marked_1(fix.auto);
+ var issueStrings = {};
+ if (title) { issueStrings.title = title.auto; }
+ if (detail) { issueStrings.detail = marked_1(detail.auto); }
+ if (trap) { issueStrings.trap = marked_1(trap.auto); }
+ if (fix) { issueStrings.fix = marked_1(fix.auto); }
_cache$2.strings[locale][itemType] = issueStrings;
};
- const [ item, cl ] = itemType.split('-');
+ var ref = itemType.split('-');
+ var item = ref[0];
+ var cl = ref[1];
// Osmose API falls back to English strings where untranslated or if locale doesn't exist
- const url = `${_osmoseUrlRoot}/items/${item}/class/${cl}?langs=${locale}`;
+ var url = _osmoseUrlRoot + "/items/" + item + "/class/" + cl + "?langs=" + locale;
return d3_json(url).then(cacheData);
});
- return Promise.all(allRequests).then(() => _cache$2.strings[locale]);
+ return Promise.all(allRequests).then(function () { return _cache$2.strings[locale]; });
},
- getStrings(itemType, locale=_mainLocalizer.localeCode()) {
+ getStrings: function getStrings(itemType, locale) {
+ if ( locale === void 0 ) locale=_mainLocalizer.localeCode();
+
// No need to fallback to English, Osmose API handles this for us
return (locale in _cache$2.strings) ? _cache$2.strings[locale][itemType] : {};
},
- getColor(itemType) {
+ getColor: function getColor(itemType) {
return (itemType in _cache$2.colors) ? _cache$2.colors[itemType] : '#FFFFFF';
},
- postUpdate(issue, callback) {
+ postUpdate: function postUpdate(issue, callback) {
+ var this$1 = this;
+
if (_cache$2.inflightPost[issue.id]) {
return callback({ message: 'Issue update already inflight', status: -2 }, issue);
}
// UI sets the status to either 'done' or 'false'
- const url = `${_osmoseUrlRoot}/issue/${issue.id}/${issue.newStatus}`;
- const controller = new AbortController();
- const after = () => {
+ var url = _osmoseUrlRoot + "/issue/" + (issue.id) + "/" + (issue.newStatus);
+ var controller = new AbortController();
+ var after = function () {
delete _cache$2.inflightPost[issue.id];
- this.removeItem(issue);
+ this$1.removeItem(issue);
if (issue.newStatus === 'done') {
// Keep track of the number of issues closed per `item` to tag the changeset
if (!(issue.item in _cache$2.closed)) {
}
_cache$2.closed[issue.item] += 1;
}
- if (callback) callback(null, issue);
+ if (callback) { callback(null, issue); }
};
_cache$2.inflightPost[issue.id] = controller;
fetch(url, { signal: controller.signal })
.then(after)
- .catch(err => {
+ .catch(function (err) {
delete _cache$2.inflightPost[issue.id];
- if (callback) callback(err.message);
+ if (callback) { callback(err.message); }
});
},
// Get all cached QAItems covering the viewport
- getItems(projection) {
- const viewport = projection.clipExtent();
- const min = [viewport[0][0], viewport[1][1]];
- const max = [viewport[1][0], viewport[0][1]];
- const bbox = geoExtent(projection.invert(min), projection.invert(max)).bbox();
+ getItems: function getItems(projection) {
+ var viewport = projection.clipExtent();
+ var min = [viewport[0][0], viewport[1][1]];
+ var max = [viewport[1][0], viewport[0][1]];
+ var bbox = geoExtent(projection.invert(min), projection.invert(max)).bbox();
- return _cache$2.rtree.search(bbox).map(d => d.data);
+ return _cache$2.rtree.search(bbox).map(function (d) { return d.data; });
},
// Get a QAItem from cache
// NOTE: Don't change method name until UI v3 is merged
- getError(id) {
+ getError: function getError(id) {
return _cache$2.data[id];
},
// get the name of the icon to display for this item
- getIcon(itemType) {
+ getIcon: function getIcon(itemType) {
return _osmoseData.icons[itemType];
},
// Replace a single QAItem in the cache
- replaceItem(item) {
- if (!(item instanceof QAItem) || !item.id) return;
+ replaceItem: function replaceItem(item) {
+ if (!(item instanceof QAItem) || !item.id) { return; }
_cache$2.data[item.id] = item;
updateRtree$2(encodeIssueRtree$2(item), true); // true = replace
},
// Remove a single QAItem from the cache
- removeItem(item) {
- if (!(item instanceof QAItem) || !item.id) return;
+ removeItem: function removeItem(item) {
+ if (!(item instanceof QAItem) || !item.id) { return; }
delete _cache$2.data[item.id];
updateRtree$2(encodeIssueRtree$2(item), false); // false = remove
},
// Used to populate `closed:osmose:*` changeset tags
- getClosedCounts() {
+ getClosedCounts: function getClosedCounts() {
return _cache$2.closed;
},
- itemURL(item) {
- return `https://osmose.openstreetmap.fr/en/error/${item.id}`;
+ itemURL: function itemURL(item) {
+ return ("https://osmose.openstreetmap.fr/en/error/" + (item.id));
}
};
function maxPageAtZoom(z) {
- if (z < 15) return 2;
- if (z === 15) return 5;
- if (z === 16) return 10;
- if (z === 17) return 20;
- if (z === 18) return 40;
- if (z > 18) return 80;
+ if (z < 15) { return 2; }
+ if (z === 15) { return 5; }
+ if (z === 16) { return 10; }
+ if (z === 17) { return 20; }
+ if (z === 18) { return 40; }
+ if (z > 18) { return 80; }
}
bbox: [rect[0], rect[1], rect[2], rect[3]].join(','),
});
- if (nextPage > maxPages) return;
+ if (nextPage > maxPages) { return; }
var id = tile.id + ',' + String(nextPage);
- if (cache.loaded[id] || cache.inflight[id]) return;
+ if (cache.loaded[id] || cache.inflight[id]) { return; }
var controller = new AbortController();
cache.inflight[id] = controller;
}
var viewer = context.container().select('.photoviewer');
- if (!viewer.empty()) viewer.datum(null);
+ if (!viewer.empty()) { viewer.datum(null); }
viewer
.classed('hide', true)
updateViewer: function(context, imageKey) {
- if (!imageKey) return this;
+ if (!imageKey) { return this; }
if (!_mlyViewer) {
this.initViewer(context, imageKey);
//
// There is some logic here to batch up clicks into a _mlyClicks array
// because the user might click on a lot of markers quickly and nodechanged
- // may be called out of order asychronously.
+ // may be called out of order asynchronously.
//
// Clicks are added to the array in `selectedImage` and removed here.
//
var d = _mlyCache.images.forImageKey[imageKey];
var viewer = context.container().select('.photoviewer');
- if (!viewer.empty()) viewer.datum(d);
+ if (!viewer.empty()) { viewer.datum(d); }
imageKey = (d && d.key) || imageKey;
if (!fromViewer && imageKey) {
updateDetections: function(d) {
- if (!_mlyViewer || _mlyFallback) return;
+ if (!_mlyViewer || _mlyFallback) { return; }
var imageKey = d && d.key;
- if (!imageKey) return;
+ if (!imageKey) { return; }
var detections = _mlyCache.image_detections.forImageKey[imageKey] || [];
detections.forEach(function(data) {
function makeTag(data) {
var valueParts = data.value.split('--');
- if (valueParts.length !== 3) return;
+ if (valueParts.length !== 3) { return; }
var text = valueParts[1].replace(/-/g, ' ');
var tag;
);
if (cached.length > 0) {
- if (callback) callback(null, cached[0].data);
+ if (callback) { callback(null, cached[0].data); }
return;
}
var params = { zoom: 13, format: 'json', addressdetails: 1, lat: loc[1], lon: loc[0] };
var url = apibase$1 + 'reverse?' + utilQsString(params);
- if (_inflight[url]) return;
+ if (_inflight[url]) { return; }
var controller = new AbortController();
_inflight[url] = controller;
}
var extent = geoExtent(loc).padByMeters(200);
_nominatimCache.insert(Object.assign(extent.bbox(), {data: result}));
- if (callback) callback(null, result);
+ if (callback) { callback(null, result); }
})
.catch(function(err) {
delete _inflight[url];
- if (err.name === 'AbortError') return;
- if (callback) callback(err.message);
+ if (err.name === 'AbortError') { return; }
+ if (callback) { callback(err.message); }
});
},
var searchVal = encodeURIComponent(val);
var url = apibase$1 + 'search/' + searchVal + '?limit=10&format=json';
- if (_inflight[url]) return;
+ if (_inflight[url]) { return; }
var controller = new AbortController();
_inflight[url] = controller;
if (result && result.error) {
throw new Error(result.error);
}
- if (callback) callback(null, result);
+ if (callback) { callback(null, result); }
})
.catch(function(err) {
delete _inflight[url];
- if (err.name === 'AbortError') return;
- if (callback) callback(err.message);
+ if (err.name === 'AbortError') { return; }
+ if (callback) { callback(err.message); }
});
}
function maxPageAtZoom$1(z) {
- if (z < 15) return 2;
- if (z === 15) return 5;
- if (z === 16) return 10;
- if (z === 17) return 20;
- if (z === 18) return 40;
- if (z > 18) return 80;
+ if (z < 15) { return 2; }
+ if (z === 15) { return 5; }
+ if (z === 16) { return 10; }
+ if (z === 17) { return 20; }
+ if (z === 18) { return 40; }
+ if (z > 18) { return 80; }
}
bbBottomRight: [bbox.minY, bbox.maxX].join(',')
}, true);
- if (nextPage > maxPages) return;
+ if (nextPage > maxPages) { return; }
var id = tile.id + ',' + String(nextPage);
- if (cache.loaded[id] || cache.inflight[id]) return;
+ if (cache.loaded[id] || cache.inflight[id]) { return; }
var controller = new AbortController();
cache.inflight[id] = controller;
function rotate(deg) {
return function() {
- if (!_oscSelectedImage) return;
+ if (!_oscSelectedImage) { return; }
var sequenceKey = _oscSelectedImage.sequence_id;
var sequence = _oscCache.sequences[sequenceKey];
- if (!sequence) return;
+ if (!sequence) { return; }
var r = sequence.rotation || 0;
r += deg;
- if (r > 180) r -= 360;
- if (r < -180) r += 360;
+ if (r > 180) { r -= 360; }
+ if (r < -180) { r += 360; }
sequence.rotation = r;
var wrap = context.container().select('.photoviewer .osc-wrapper');
function step(stepBy) {
return function() {
- if (!_oscSelectedImage) return;
+ if (!_oscSelectedImage) { return; }
var sequenceKey = _oscSelectedImage.sequence_id;
var sequence = _oscCache.sequences[sequenceKey];
- if (!sequence) return;
+ if (!sequence) { return; }
var nextIndex = _oscSelectedImage.sequence_index + stepBy;
var nextImage = sequence.images[nextIndex];
- if (!nextImage) return;
+ if (!nextImage) { return; }
context.map().centerEase(nextImage.loc);
_oscSelectedImage = null;
var viewer = context.container().select('.photoviewer');
- if (!viewer.empty()) viewer.datum(null);
+ if (!viewer.empty()) { viewer.datum(null); }
viewer
.classed('hide', true)
function localeDateString(s) {
- if (!s) return null;
+ if (!s) { return null; }
var options = { day: 'numeric', month: 'short', year: 'numeric' };
var d = new Date(s);
- if (isNaN(d.getTime())) return null;
+ if (isNaN(d.getTime())) { return null; }
return d.toLocaleDateString(_mainLocalizer.localeCode(), options);
}
},
selectImage: function(context, d) {
_oscSelectedImage = d;
var viewer = context.container().select('.photoviewer');
- if (!viewer.empty()) viewer.datum(d);
+ if (!viewer.empty()) { viewer.datum(d); }
this.setStyles(context, null, true);
var hasOwnProperty$3 = Object.prototype.hasOwnProperty;
function extend$2() {
+ var arguments$1 = arguments;
+
var target = {};
for (var i = 0; i < arguments.length; i++) {
- var source = arguments[i];
+ var source = arguments$1[i];
for (var key in source) {
if (hasOwnProperty$3.call(source, key)) {
twoHundred = /^20\d$/;
xhr.onreadystatechange = function() {
if (4 === xhr.readyState && 0 !== xhr.status) {
- if (twoHundred.test(xhr.status)) callback(null, xhr);
- else return callback(xhr, null);
+ if (twoHundred.test(xhr.status)) { callback(null, xhr); }
+ else { return callback(xhr, null); }
}
};
xhr.onerror = function(e) { return callback(e, null); };
xhr.open(method, url, true);
- for (var h in headers) xhr.setRequestHeader(h, headers[h]);
+ for (var h in headers) { xhr.setRequestHeader(h, headers[h]); }
xhr.send(data);
return xhr;
};
};
ohauth.baseString = function(method, url, params) {
- if (params.oauth_signature) delete params.oauth_signature;
+ if (params.oauth_signature) { delete params.oauth_signature; }
return [
method,
ohauth.percentEncode(url),
oauth_nonce: ohauth.nonce()
};
- if (token) oauth_params.oauth_token = token;
+ if (token) { oauth_params.oauth_token = token; }
var all_params = immutable({}, oauth_params, query_params, extra_params),
base_str = ohauth.baseString(method, base_uri, all_params);
}(commonjsGlobal, function() {
function resolveUrl(/* ...urls */) {
+ var arguments$1 = arguments;
+
var numUrls = arguments.length;
if (numUrls === 0) {
var resolved;
for (var index = 1; index < numUrls; index++) {
- a.href = arguments[index];
+ a.href = arguments$1[index];
resolved = a.href;
base.href = resolved;
}
return Object.assign
} else {
return function shimAssign(obj, props1, props2, etc) {
+ var arguments$1 = arguments;
+
for (var i = 1; i < arguments.length; i++) {
- each(Object(arguments[i]), function(val, key) {
+ each(Object(arguments$1[i]), function(val, key) {
obj[key] = val;
});
}
// TODO: detect lack of click event
oauth.authenticate = function(callback) {
- if (oauth.authenticated()) return callback();
+ if (oauth.authenticated()) { return callback(); }
oauth.logout();
return x.join('=');
}).join(','),
popup = window.open('about:blank', 'oauth_window', settings);
+
+ oauth.popupWindow = popup;
+
+ if (!popup) {
+ var error = new Error('Popup was blocked');
+ error.status = 'popup-blocked';
+ throw error;
+ }
}
// Request a request token. When this is complete, the popup
function reqTokenDone(err, xhr) {
o.done();
- if (err) return callback(err);
+ if (err) { return callback(err); }
var resp = ohauth_1.stringQs(xhr.response);
token('oauth_request_token_secret', resp.oauth_token_secret);
var authorize_url = o.url + '/oauth/authorize?' + ohauth_1.qsString({
function accessTokenDone(err, xhr) {
o.done();
- if (err) return callback(err);
+ if (err) { return callback(err); }
var access_token = ohauth_1.stringQs(xhr.response);
token('oauth_token', access_token.oauth_token);
token('oauth_token_secret', access_token.oauth_token_secret);
}
};
+ oauth.bringPopupWindowToFront = function() {
+ var brougtPopupToFront = false;
+ try {
+ // This may cause a cross-origin error:
+ // `DOMException: Blocked a frame with origin "..." from accessing a cross-origin frame.`
+ if (oauth.popupWindow && !oauth.popupWindow.closed) {
+ oauth.popupWindow.focus();
+ brougtPopupToFront = true;
+ }
+ } catch (err) {
+ // Bringing popup window to front failed (probably because of the cross-origin error mentioned above)
+ }
+ return brougtPopupToFront;
+ };
+
oauth.bootstrapToken = function(oauth_token, callback) {
// ## Getting an request token
// At this point we have an `oauth_token`, brought in from a function
function accessTokenDone(err, xhr) {
o.done();
- if (err) return callback(err);
+ if (err) { return callback(err); }
var access_token = ohauth_1.stringQs(xhr.response);
token('oauth_token', access_token.oauth_token);
token('oauth_token_secret', access_token.oauth_token_secret);
}
function done(err, xhr) {
- if (err) return callback(err);
- else if (xhr.responseXML) return callback(err, xhr.responseXML);
- else return callback(err, xhr.response);
+ if (err) { return callback(err); }
+ else if (xhr.responseXML) { return callback(err, xhr.responseXML); }
+ else { return callback(err, xhr.response); }
}
};
// pre-authorize this object, if we can just get a token and token_secret
// from the start
oauth.preauth = function(c) {
- if (!c) return;
- if (c.oauth_token) token('oauth_token', c.oauth_token);
- if (c.oauth_token_secret) token('oauth_token_secret', c.oauth_token_secret);
+ if (!c) { return; }
+ if (c.oauth_token) { token('oauth_token', c.oauth_token); }
+ if (c.oauth_token_secret) { token('oauth_token_secret', c.oauth_token_secret); }
return oauth;
};
oauth.options = function(_) {
- if (!arguments.length) return o;
+ if (!arguments.length) { return o; }
o = _;
o.url = o.url || 'https://www.openstreetmap.org';
if (store_legacy.enabled) {
token = function (x, y) {
- if (arguments.length === 1) return store_legacy.get(o.url + x);
- else if (arguments.length === 2) return store_legacy.set(o.url + x, y);
+ if (arguments.length === 1) { return store_legacy.get(o.url + x); }
+ else if (arguments.length === 2) { return store_legacy.set(o.url + x, y); }
};
} else {
var storage = {};
token = function (x, y) {
- if (arguments.length === 1) return storage[o.url + x];
- else if (arguments.length === 2) return storage[o.url + x] = y;
+ if (arguments.length === 1) { return storage[o.url + x]; }
+ else if (arguments.length === 2) { return storage[o.url + x] = y; }
};
}
loading: authLoading,
done: authDone
});
-
- var _blacklists = ['.*\.google(apis)?\..*/(vt|kh)[\?/].*([xyz]=.*){3}.*'];
+ // hardcode default block of Google Maps
+ var _imageryBlocklists = [/.*\.google(apis)?\..*\/(vt|kh)[\?\/].*([xyz]=.*){3}.*/];
var _tileCache = { toLoad: {}, loaded: {}, inflight: {}, seen: {}, rtree: new RBush() };
var _noteCache = { toLoad: {}, loaded: {}, inflight: {}, inflightPost: {}, note: {}, closed: {}, rtree: new RBush() };
var _userCache = { toLoad: {}, user: {} };
function abortUnwantedRequests$3(cache, visibleTiles) {
Object.keys(cache.inflight).forEach(function(k) {
- if (cache.toLoad[k]) return;
- if (visibleTiles.find(function(tile) { return k === tile.id; })) return;
+ if (cache.toLoad[k]) { return; }
+ if (visibleTiles.find(function(tile) { return k === tile.id; })) { return; }
abortRequest$5(cache.inflight[k]);
delete cache.inflight[k];
for (var j = 0; j < childNodes.length; j++) {
var node = childNodes[j];
var nodeName = node.nodeName;
- if (nodeName === '#text') continue;
+ if (nodeName === '#text') { continue; }
parsedComment[nodeName] = node.textContent;
if (nodeName === 'uid') {
return new osmNode({
id: uid,
visible: typeof obj.visible === 'boolean' ? obj.visible : true,
- version: obj.version.toString(),
- changeset: obj.changeset.toString(),
+ version: obj.version && obj.version.toString(),
+ changeset: obj.changeset && obj.changeset.toString(),
timestamp: obj.timestamp,
user: obj.user,
- uid: obj.uid.toString(),
+ uid: obj.uid && obj.uid.toString(),
loc: [parseFloat(obj.lon), parseFloat(obj.lat)],
tags: obj.tags
});
return new osmWay({
id: uid,
visible: typeof obj.visible === 'boolean' ? obj.visible : true,
- version: obj.version.toString(),
- changeset: obj.changeset.toString(),
+ version: obj.version && obj.version.toString(),
+ changeset: obj.changeset && obj.changeset.toString(),
timestamp: obj.timestamp,
user: obj.user,
- uid: obj.uid.toString(),
+ uid: obj.uid && obj.uid.toString(),
tags: obj.tags,
nodes: getNodesJSON(obj)
});
return new osmRelation({
id: uid,
visible: typeof obj.visible === 'boolean' ? obj.visible : true,
- version: obj.version.toString(),
- changeset: obj.changeset.toString(),
+ version: obj.version && obj.version.toString(),
+ changeset: obj.changeset && obj.changeset.toString(),
timestamp: obj.timestamp,
user: obj.user,
- uid: obj.uid.toString(),
+ uid: obj.uid && obj.uid.toString(),
tags: obj.tags,
members: getMembersJSON(obj)
});
var json = payload;
if (typeof json !== 'object')
- json = JSON.parse(payload);
+ { json = JSON.parse(payload); }
if (!json.elements)
- return callback({ message: 'No JSON', status: -1 });
+ { return callback({ message: 'No JSON', status: -1 }); }
var children = json.elements;
var result;
for (var i = 0; i < children.length; i++) {
result = parseChild(children[i]);
- if (result) results.push(result);
+ if (result) { results.push(result); }
}
callback(null, results);
});
function parseChild(child) {
var parser = jsonparsers[child.type];
- if (!parser) return null;
+ if (!parser) { return null; }
var uid;
uid = osmEntity.id.fromOSM(child.type, child.id);
if (options.skipSeen) {
- if (_tileCache.seen[uid]) return null; // avoid reparsing a "seen" entity
+ if (_tileCache.seen[uid]) { return null; } // avoid reparsing a "seen" entity
_tileCache.seen[uid] = true;
}
for (var i = 0; i < childNodes.length; i++) {
var node = childNodes[i];
var nodeName = node.nodeName;
- if (nodeName === '#text') continue;
+ if (nodeName === '#text') { continue; }
// if the element is comments, parse the comments
if (nodeName === 'comments') {
var result;
for (var i = 0; i < children.length; i++) {
result = parseChild(children[i]);
- if (result) results.push(result);
+ if (result) { results.push(result); }
}
callback(null, results);
});
function parseChild(child) {
var parser = parsers[child.nodeName];
- if (!parser) return null;
+ if (!parser) { return null; }
var uid;
if (child.nodeName === 'user') {
} else {
uid = osmEntity.id.fromOSM(child.nodeName, child.attributes.id.value);
if (options.skipSeen) {
- if (_tileCache.seen[uid]) return null; // avoid reparsing a "seen" entity
+ if (_tileCache.seen[uid]) { return null; } // avoid reparsing a "seen" entity
_tileCache.seen[uid] = true;
}
}
Object.values(_tileCache.inflight).forEach(abortRequest$5);
Object.values(_noteCache.inflight).forEach(abortRequest$5);
Object.values(_noteCache.inflightPost).forEach(abortRequest$5);
- if (_changeset.inflight) abortRequest$5(_changeset.inflight);
+ if (_changeset.inflight) { abortRequest$5(_changeset.inflight); }
_tileCache = { toLoad: {}, loaded: {}, inflight: {}, seen: {}, rtree: new RBush() };
_noteCache = { toLoad: {}, loaded: {}, inflight: {}, inflightPost: {}, note: {}, closed: {}, rtree: new RBush() };
function done(err, payload) {
if (that.getConnectionId() !== cid) {
- if (callback) callback({ message: 'Connection Switched', status: -1 });
+ if (callback) { callback({ message: 'Connection Switched', status: -1 }); }
return;
}
done(null, data);
})
.catch(function(err) {
- if (err.name === 'AbortError') return;
+ if (err.name === 'AbortError') { return; }
// d3-fetch includes status in the error message,
// but we can't access the response itself
// https://github.com/d3/d3-fetch/issues/27
this.loadFromAPI(
'/api/0.6/' + type + '/' + osmID + (type !== 'node' ? '/full' : '') + '.json',
function(err, entities) {
- if (callback) callback(err, { data: entities });
+ if (callback) { callback(err, { data: entities }); }
},
options
);
this.loadFromAPI(
'/api/0.6/' + type + '/' + osmID + '/' + version + '.json',
function(err, entities) {
- if (callback) callback(err, { data: entities });
+ if (callback) { callback(err, { data: entities }); }
},
options
);
that.loadFromAPI(
'/api/0.6/' + type + '.json?' + type + '=' + arr.join(),
function(err, entities) {
- if (callback) callback(err, { data: entities });
+ if (callback) { callback(err, { data: entities }); }
},
options
);
function uploadedChangeset(err) {
_changeset.inflight = null;
- if (err) return callback(err, changeset);
+ if (err) { return callback(err, changeset); }
// Upload was successful, safe to call the callback.
// Add delay to allow for postgres replication #1646 #2678
if (cached.length || !this.authenticated()) {
callback(undefined, cached);
- if (!this.authenticated()) return; // require auth
+ if (!this.authenticated()) { return; } // require auth
}
utilArrayChunk(toLoad, 150).forEach(function(arr) {
return callback(err, null);
}
- // update blacklists
+ // update blocklists
var elements = xml.getElementsByTagName('blacklist');
var regexes = [];
for (var i = 0; i < elements.length; i++) {
- var regex = elements[i].getAttribute('regex'); // needs unencode?
- if (regex) {
- regexes.push(regex);
+ var regexString = elements[i].getAttribute('regex'); // needs unencode?
+ if (regexString) {
+ try {
+ var regex = new RegExp(regexString);
+ regexes.push(regex);
+ } catch (e) {
+ /* noop */
+ }
}
}
if (regexes.length) {
- _blacklists = regexes;
+ _imageryBlocklists = regexes;
}
if (_rateLimitError) {
} else {
var waynodes = xml.getElementsByTagName('waynodes');
var maxWayNodes = waynodes.length && parseInt(waynodes[0].getAttribute('maximum'), 10);
- if (maxWayNodes && isFinite(maxWayNodes)) _maxWayNodes = maxWayNodes;
+ if (maxWayNodes && isFinite(maxWayNodes)) { _maxWayNodes = maxWayNodes; }
var apiStatus = xml.getElementsByTagName('status');
var val = apiStatus[0].getAttribute('api');
// Calls `status` and dispatches an `apiStatusChange` event if the returned
// status differs from the cached status.
reloadApiStatus: function() {
- // throttle to avoid unncessary API calls
+ // throttle to avoid unnecessary API calls
if (!this.throttledReloadApiStatus) {
var that = this;
this.throttledReloadApiStatus = throttle(function() {
// Load data (entities) from the API in tiles
// GET /api/0.6/map?bbox=
loadTiles: function(projection, callback) {
- if (_off) return;
+ if (_off) { return; }
// determine the needed tiles to cover the view
var tiles = tiler$5.zoomExtent([_tileZoom$3, _tileZoom$3]).getTiles(projection);
// Load a single data tile
// GET /api/0.6/map?bbox=
loadTile: function(tile, callback) {
- if (_off) return;
- if (_tileCache.loaded[tile.id] || _tileCache.inflight[tile.id]) return;
+ if (_off) { return; }
+ if (_tileCache.loaded[tile.id] || _tileCache.inflight[tile.id]) { return; }
if (!hasInflightRequests(_tileCache)) {
dispatch$6.call('loading'); // start the spinner
// Back off if the toLoad queue is filling up.. re #6417
// (Currently `loadTileAtLoc` requests are considered low priority - used by operations to
// let users safely edit geometries which extend to unloaded tiles. We can drop some.)
- if (Object.keys(_tileCache.toLoad).length > 50) return;
+ if (Object.keys(_tileCache.toLoad).length > 50) { return; }
var k = geoZoomToScale(_tileZoom$3 + 1);
var offset = geoRawMercator().scale(k)(loc);
var tiles = tiler$5.zoomExtent([_tileZoom$3, _tileZoom$3]).getTiles(projection);
tiles.forEach(function(tile) {
- if (_tileCache.toLoad[tile.id] || _tileCache.loaded[tile.id] || _tileCache.inflight[tile.id]) return;
+ if (_tileCache.toLoad[tile.id] || _tileCache.loaded[tile.id] || _tileCache.inflight[tile.id]) { return; }
_tileCache.toLoad[tile.id] = true;
this.loadTile(tile, callback);
// GET /api/0.6/notes?bbox=
loadNotes: function(projection, noteOptions) {
noteOptions = Object.assign({ limit: 10000, closed: 7 }, noteOptions);
- if (_off) return;
+ if (_off) { return; }
var that = this;
var path = '/api/0.6/notes?limit=' + noteOptions.limit + '&closed=' + noteOptions.closed + '&bbox=';
var throttleLoadUsers = throttle(function() {
var uids = Object.keys(_userCache.toLoad);
- if (!uids.length) return;
+ if (!uids.length) { return; }
that.loadUsers(uids, function() {}); // eagerly load user details
}, 750);
// issue new requests..
tiles.forEach(function(tile) {
- if (_noteCache.loaded[tile.id] || _noteCache.inflight[tile.id]) return;
+ if (_noteCache.loaded[tile.id] || _noteCache.inflight[tile.id]) { return; }
var options = { skipSeen: false };
_noteCache.inflight[tile.id] = that.loadFromAPI(
return callback({ message: 'Note update already inflight', status: -2 }, note);
}
- if (!note.loc[0] || !note.loc[1] || !note.newComment) return; // location & description required
+ if (!note.loc[0] || !note.loc[1] || !note.newComment) { return; } // location & description required
var comment = note.newComment;
if (note.newCategory && note.newCategory !== 'None') { comment += ' #' + note.newCategory; }
action = 'reopen';
} else {
action = 'comment';
- if (!note.newComment) return; // when commenting, comment required
+ if (!note.newComment) { return; } // when commenting, comment required
}
var path = '/api/0.6/notes/' + note.id + '/' + action;
function done(err, res) {
if (err) {
- if (callback) callback(err);
+ if (callback) { callback(err); }
return;
}
if (that.getConnectionId() !== cid) {
- if (callback) callback({ message: 'Connection Switched', status: -1 });
+ if (callback) { callback({ message: 'Connection Switched', status: -1 }); }
return;
}
_rateLimitError = undefined;
dispatch$6.call('change');
- if (callback) callback(err, res);
+ if (callback) { callback(err, res); }
that.userChangesets(function() {}); // eagerly load user details/changesets
}
},
- imageryBlacklists: function() {
- return _blacklists;
+ imageryBlocklists: function() {
+ return _imageryBlocklists;
},
tileZoom: function(val) {
- if (!arguments.length) return _tileZoom$3;
+ if (!arguments.length) { return _tileZoom$3; }
_tileZoom$3 = val;
return this;
},
// remove a single note from the cache
removeNote: function(note) {
- if (!(note instanceof osmNote) || !note.id) return;
+ if (!(note instanceof osmNote) || !note.id) { return; }
delete _noteCache.note[note.id];
updateRtree$3(encodeNoteRtree(note), false); // false = remove
// replace a single note in the cache
replaceNote: function(note) {
- if (!(note instanceof osmNote) || !note.id) return;
+ if (!(note instanceof osmNote) || !note.id) { return; }
_noteCache.note[note.id] = note;
updateRtree$3(encodeNoteRtree(note), true); // true = replace
var debouncedRequest = debounce(request, 500, { leading: false });
function request(url, callback) {
- if (_inflight$1[url]) return;
+ if (_inflight$1[url]) { return; }
var controller = new AbortController();
_inflight$1[url] = controller;
d3_json(url, { signal: controller.signal })
.then(function(result) {
delete _inflight$1[url];
- if (callback) callback(null, result);
+ if (callback) { callback(null, result); }
})
.catch(function(err) {
delete _inflight$1[url];
- if (err.name === 'AbortError') return;
- if (callback) callback(err.message);
+ if (err.name === 'AbortError') { return; }
+ if (callback) { callback(err.message); }
});
}
* @param langCode string e.g. 'fr' for French
*/
claimToValue: function(entity, property, langCode) {
- if (!entity.claims[property]) return undefined;
+ if (!entity.claims[property]) { return undefined; }
var locale = _localeIDs[langCode];
var preferredPick, localePick;
* @param property string e.g. 'P31' for monolingual wiki page title
*/
monolingualClaimToValueObj: function(entity, property) {
- if (!entity || !entity.claims[property]) return undefined;
+ if (!entity || !entity.claims[property]) { return undefined; }
return entity.claims[property].reduce(function(acc, obj) {
var value = obj.mainsnak.datavalue.value;
// {
// key: 'string',
// value: 'string',
- // rtype: 'string',
// langCode: 'string'
// }
//
var that = this;
var titles = [];
var result = {};
- var rtypeSitelink = params.rtype ? ('Relation:' + params.rtype).replace(/_/g, ' ').trim() : false;
+ var rtypeSitelink = (params.key === 'type' && params.value) ? ('Relation:' + params.value).replace(/_/g, ' ').trim() : false;
var keySitelink = params.key ? this.toSitelink(params.key) : false;
var tagSitelink = (params.key && params.value) ? this.toSitelink(params.key, params.value) : false;
var localeSitelink;
// key: 'string', // required
// value: 'string' // optional
// }
- // -or-
- // {
- // rtype: 'rtype' // relation type (e.g. 'multipolygon')
- // }
//
// Get an result object used to display tag documentation
// {
apibase: function(val) {
- if (!arguments.length) return apibase$3;
+ if (!arguments.length) { return apibase$3; }
apibase$3 = val;
return this;
}
var chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz';
var c = '';
var i = -1;
- while (++i < 15) c += chars.charAt(Math.floor(Math.random() * 52));
+ while (++i < 15) { c += chars.charAt(Math.floor(Math.random() * 52)); }
return c;
}
return request;
}
- const bubbleApi = 'https://dev.virtualearth.net/mapcontrol/HumanScaleServices/GetBubbles.ashx?';
- const streetsideImagesApi = 'https://t.ssl.ak.tiles.virtualearth.net/tiles/';
- const bubbleAppKey = 'AuftgJsO0Xs8Ts4M1xZUQJQXJNsvmh3IV8DkNieCiy3tCwCUMq76-WpkrBtNAuEm';
- const pannellumViewerCSS = 'pannellum-streetside/pannellum.css';
- const pannellumViewerJS = 'pannellum-streetside/pannellum.js';
- const maxResults$2 = 2000;
- const tileZoom$2 = 16.5;
- const tiler$6 = utilTiler().zoomExtent([tileZoom$2, tileZoom$2]).skipNullIsland(true);
- const dispatch$7 = dispatch('loadedBubbles', 'viewerChanged');
- const minHfov = 10; // zoom in degrees: 20, 10, 5
- const maxHfov = 90; // zoom out degrees
- const defaultHfov = 45;
-
- let _hires = false;
- let _resolution = 512; // higher numbers are slower - 512, 1024, 2048, 4096
- let _currScene = 0;
- let _ssCache;
- let _pannellumViewer;
- let _sceneOptions;
- let _dataUrlArray = [];
+ var bubbleApi = 'https://dev.virtualearth.net/mapcontrol/HumanScaleServices/GetBubbles.ashx?';
+ var streetsideImagesApi = 'https://t.ssl.ak.tiles.virtualearth.net/tiles/';
+ var bubbleAppKey = 'AuftgJsO0Xs8Ts4M1xZUQJQXJNsvmh3IV8DkNieCiy3tCwCUMq76-WpkrBtNAuEm';
+ var pannellumViewerCSS = 'pannellum-streetside/pannellum.css';
+ var pannellumViewerJS = 'pannellum-streetside/pannellum.js';
+ var maxResults$2 = 2000;
+ var tileZoom$2 = 16.5;
+ var tiler$6 = utilTiler().zoomExtent([tileZoom$2, tileZoom$2]).skipNullIsland(true);
+ var dispatch$7 = dispatch('loadedBubbles', 'viewerChanged');
+ var minHfov = 10; // zoom in degrees: 20, 10, 5
+ var maxHfov = 90; // zoom out degrees
+ var defaultHfov = 45;
+
+ var _hires = false;
+ var _resolution = 512; // higher numbers are slower - 512, 1024, 2048, 4096
+ var _currScene = 0;
+ var _ssCache;
+ var _pannellumViewer;
+ var _sceneOptions;
+ var _dataUrlArray = [];
/**
* localeTimeStamp().
*/
function localeTimestamp(s) {
- if (!s) return null;
- const options = { day: 'numeric', month: 'short', year: 'numeric' };
- const d = new Date(s);
- if (isNaN(d.getTime())) return null;
+ if (!s) { return null; }
+ var options = { day: 'numeric', month: 'short', year: 'numeric' };
+ var d = new Date(s);
+ if (isNaN(d.getTime())) { return null; }
return d.toLocaleString(_mainLocalizer.localeCode(), options);
}
* loadTiles() wraps the process of generating tiles and then fetching image points for each tile.
*/
function loadTiles$2(which, url, projection, margin) {
- const tiles = tiler$6.margin(margin).getTiles(projection);
+ var tiles = tiler$6.margin(margin).getTiles(projection);
// abort inflight requests that are no longer needed
- const cache = _ssCache[which];
- Object.keys(cache.inflight).forEach(k => {
- const wanted = tiles.find(tile => k.indexOf(tile.id + ',') === 0);
+ var cache = _ssCache[which];
+ Object.keys(cache.inflight).forEach(function (k) {
+ var wanted = tiles.find(function (tile) { return k.indexOf(tile.id + ',') === 0; });
if (!wanted) {
abortRequest$6(cache.inflight[k]);
delete cache.inflight[k];
}
});
- tiles.forEach(tile => loadNextTilePage$2(which, url, tile));
+ tiles.forEach(function (tile) { return loadNextTilePage$2(which, url, tile); });
}
* loadNextTilePage() load data for the next tile page in line.
*/
function loadNextTilePage$2(which, url, tile) {
- const cache = _ssCache[which];
- const nextPage = cache.nextPage[tile.id] || 0;
- const id = tile.id + ',' + String(nextPage);
- if (cache.loaded[id] || cache.inflight[id]) return;
+ var cache = _ssCache[which];
+ var nextPage = cache.nextPage[tile.id] || 0;
+ var id = tile.id + ',' + String(nextPage);
+ if (cache.loaded[id] || cache.inflight[id]) { return; }
- cache.inflight[id] = getBubbles(url, tile, (bubbles) => {
+ cache.inflight[id] = getBubbles(url, tile, function (bubbles) {
cache.loaded[id] = true;
delete cache.inflight[id];
- if (!bubbles) return;
+ if (!bubbles) { return; }
// [].shift() removes the first element, some statistics info, not a bubble point
bubbles.shift();
- const features = bubbles.map(bubble => {
- if (cache.points[bubble.id]) return null; // skip duplicates
+ var features = bubbles.map(function (bubble) {
+ if (cache.points[bubble.id]) { return null; } // skip duplicates
- const loc = [bubble.lo, bubble.la];
- const d = {
+ var loc = [bubble.lo, bubble.la];
+ var d = {
loc: loc,
key: bubble.id,
ca: bubble.he,
// call this sometimes to connect the bubbles into sequences
function connectSequences() {
- let cache = _ssCache.bubbles;
- let keepLeaders = [];
+ var cache = _ssCache.bubbles;
+ var keepLeaders = [];
- for (let i = 0; i < cache.leaders.length; i++) {
- let bubble = cache.points[cache.leaders[i]];
- let seen = {};
+ for (var i = 0; i < cache.leaders.length; i++) {
+ var bubble = cache.points[cache.leaders[i]];
+ var seen = {};
// try to make a sequence.. use the key of the leader bubble.
- let sequence = { key: bubble.key, bubbles: [] };
- let complete = false;
+ var sequence = { key: bubble.key, bubbles: [] };
+ var complete = false;
do {
sequence.bubbles.push(bubble);
_ssCache.sequences[sequence.key] = sequence;
// assign bubbles to the sequence
- for (let j = 0; j < sequence.bubbles.length; j++) {
+ for (var j = 0; j < sequence.bubbles.length; j++) {
sequence.bubbles[j].sequenceKey = sequence.key;
}
sequence.geojson = {
type: 'LineString',
properties: { key: sequence.key },
- coordinates: sequence.bubbles.map(d => d.loc)
+ coordinates: sequence.bubbles.map(function (d) { return d.loc; })
};
} else {
* getBubbles() handles the request to the server for a tile extent of 'bubbles' (streetside image locations).
*/
function getBubbles(url, tile, callback) {
- let rect = tile.extent.rectangle();
- let urlForRequest = url + utilQsString({
+ var rect = tile.extent.rectangle();
+ var urlForRequest = url + utilQsString({
n: rect[3],
s: rect[1],
e: rect[2],
jsCallback: '{callback}'
});
- return jsonpRequest(urlForRequest, (data) => {
+ return jsonpRequest(urlForRequest, function (data) {
if (!data || data.error) {
callback(null);
} else {
// partition viewport into higher zoom tiles
function partitionViewport$2(projection) {
- let z = geoScaleToZoom(projection.scale());
- let z2 = (Math.ceil(z * 2) / 2) + 2.5; // round to next 0.5 and add 2.5
- let tiler = utilTiler().zoomExtent([z2, z2]);
+ var z = geoScaleToZoom(projection.scale());
+ var z2 = (Math.ceil(z * 2) / 2) + 2.5; // round to next 0.5 and add 2.5
+ var tiler = utilTiler().zoomExtent([z2, z2]);
return tiler.getTiles(projection)
- .map(tile => tile.extent);
+ .map(function (tile) { return tile.extent; });
}
limit = limit || 5;
return partitionViewport$2(projection)
- .reduce((result, extent) => {
- let found = rtree.search(extent.bbox())
+ .reduce(function (result, extent) {
+ var found = rtree.search(extent.bbox())
.slice(0, limit)
- .map(d => d.data);
+ .map(function (d) { return d.data; });
return (found.length ? result.concat(found) : result);
}, []);
* loadImage()
*/
function loadImage(imgInfo) {
- return new Promise(resolve => {
- let img = new Image();
- img.onload = () => {
- let canvas = document.getElementById('ideditor-canvas' + imgInfo.face);
- let ctx = canvas.getContext('2d');
+ return new Promise(function (resolve) {
+ var img = new Image();
+ img.onload = function () {
+ var canvas = document.getElementById('ideditor-canvas' + imgInfo.face);
+ var ctx = canvas.getContext('2d');
ctx.drawImage(img, imgInfo.x, imgInfo.y);
resolve({ imgInfo: imgInfo, status: 'ok' });
};
- img.onerror = () => {
+ img.onerror = function () {
resolve({ data: imgInfo, status: 'error' });
};
img.setAttribute('crossorigin', '');
*/
function loadCanvas(imageGroup) {
return Promise.all(imageGroup.map(loadImage))
- .then((data) => {
- let canvas = document.getElementById('ideditor-canvas' + data[0].imgInfo.face);
- const which = { '01': 0, '02': 1, '03': 2, '10': 3, '11': 4, '12': 5 };
- let face = data[0].imgInfo.face;
+ .then(function (data) {
+ var canvas = document.getElementById('ideditor-canvas' + data[0].imgInfo.face);
+ var which = { '01': 0, '02': 1, '03': 2, '10': 3, '11': 4, '12': 5 };
+ var face = data[0].imgInfo.face;
_dataUrlArray[which[face]] = canvas.toDataURL('image/jpeg', 1.0);
return { status: 'loadCanvas for face ' + data[0].imgInfo.face + 'ok'};
});
*/
function loadFaces(faceGroup) {
return Promise.all(faceGroup.map(loadCanvas))
- .then(() => { return { status: 'loadFaces done' }; });
+ .then(function () { return { status: 'loadFaces done' }; });
}
.data(['canvas01', 'canvas02', 'canvas03', 'canvas10', 'canvas11', 'canvas12'])
.enter()
.append('canvas')
- .attr('id', d => 'ideditor-' + d)
+ .attr('id', function (d) { return 'ideditor-' + d; })
.attr('width', _resolution)
.attr('height', _resolution);
}
function qkToXY(qk) {
- let x = 0;
- let y = 0;
- let scale = 256;
- for (let i = qk.length; i > 0; i--) {
- const key = qk[i-1];
+ var x = 0;
+ var y = 0;
+ var scale = 256;
+ for (var i = qk.length; i > 0; i--) {
+ var key = qk[i-1];
x += (+(key === '1' || key === '3')) * scale;
y += (+(key === '2' || key === '3')) * scale;
scale *= 2;
function getQuadKeys() {
- let dim = _resolution / 256;
- let quadKeys;
+ var dim = _resolution / 256;
+ var quadKeys;
if (dim === 16) {
quadKeys = [
* bubbles()
*/
bubbles: function(projection) {
- const limit = 5;
+ var limit = 5;
return searchLimited$2(limit, projection, _ssCache.bubbles.rtree);
},
sequences: function(projection) {
- const viewport = projection.clipExtent();
- const min = [viewport[0][0], viewport[1][1]];
- const max = [viewport[1][0], viewport[0][1]];
- const bbox = geoExtent(projection.invert(min), projection.invert(max)).bbox();
- let seen = {};
- let results = [];
+ var viewport = projection.clipExtent();
+ var min = [viewport[0][0], viewport[1][1]];
+ var max = [viewport[1][0], viewport[0][1]];
+ var bbox = geoExtent(projection.invert(min), projection.invert(max)).bbox();
+ var seen = {};
+ var results = [];
// all sequences for bubbles in viewport
_ssCache.bubbles.rtree.search(bbox)
- .forEach(d => {
- const key = d.data.sequenceKey;
+ .forEach(function (d) {
+ var key = d.data.sequenceKey;
if (key && !seen[key]) {
seen[key] = true;
results.push(_ssCache.sequences[key].geojson);
*/
loadBubbles: function(projection, margin) {
// by default: request 2 nearby tiles so we can connect sequences.
- if (margin === undefined) margin = 2;
+ if (margin === undefined) { margin = 2; }
loadTiles$2('bubbles', bubbleApi, projection, margin);
},
initViewer: function () {
- if (!window.pannellum) return;
- if (_pannellumViewer) return;
+ if (!window.pannellum) { return; }
+ if (_pannellumViewer) { return; }
- const sceneID = ++_currScene + '';
- const options = {
+ var sceneID = ++_currScene + '';
+ var options = {
'default': { firstScene: sceneID },
scenes: {}
};
* loadViewer() create the streeside viewer.
*/
loadViewer: function(context) {
- let that = this;
+ var that = this;
- let pointerPrefix = 'PointerEvent' in window ? 'pointer' : 'mouse';
+ var pointerPrefix = 'PointerEvent' in window ? 'pointer' : 'mouse';
// create ms-wrapper, a photo wrapper class
- let wrap = context.container().select('.photoviewer').selectAll('.ms-wrapper')
+ var wrap = context.container().select('.photoviewer').selectAll('.ms-wrapper')
.data([0]);
// inject ms-wrapper into the photoviewer div
// (used by all to house each custom photo viewer)
- let wrapEnter = wrap.enter()
+ var wrapEnter = wrap.enter()
.append('div')
.attr('class', 'photo-wrapper ms-wrapper')
.classed('hide', true);
wrapEnter
.append('div')
.attr('id', 'ideditor-viewer-streetside')
- .on(pointerPrefix + 'down.streetside', () => {
+ .on(pointerPrefix + 'down.streetside', function () {
select(window)
- .on(pointerPrefix + 'move.streetside', () => {
+ .on(pointerPrefix + 'move.streetside', function () {
dispatch$7.call('viewerChanged');
}, true);
})
- .on(pointerPrefix + 'up.streetside pointercancel.streetside', () => {
+ .on(pointerPrefix + 'up.streetside pointercancel.streetside', function () {
select(window)
.on(pointerPrefix + 'move.streetside', null);
// continue dispatching events for a few seconds, in case viewer has inertia.
- let t = timer(elapsed => {
+ var t = timer(function (elapsed) {
dispatch$7.call('viewerChanged');
if (elapsed > 2000) {
t.stop();
.append('div')
.attr('class', 'photo-attribution fillD');
- let controlsEnter = wrapEnter
+ var controlsEnter = wrapEnter
.append('div')
.attr('class', 'photo-controls-wrap')
.append('div')
// Register viewer resize handler
- context.ui().photoviewer.on('resize.streetside', () => {
+ context.ui().photoviewer.on('resize.streetside', function () {
if (_pannellumViewer) {
_pannellumViewer.resize();
}
function step(stepBy) {
- return () => {
- let viewer = context.container().select('.photoviewer');
- let selected = viewer.empty() ? undefined : viewer.datum();
- if (!selected) return;
+ return function () {
+ var viewer = context.container().select('.photoviewer');
+ var selected = viewer.empty() ? undefined : viewer.datum();
+ if (!selected) { return; }
- let nextID = (stepBy === 1 ? selected.ne : selected.pr);
- let yaw = _pannellumViewer.getYaw();
- let ca = selected.ca + yaw;
- let origin = selected.loc;
+ var nextID = (stepBy === 1 ? selected.ne : selected.pr);
+ var yaw = _pannellumViewer.getYaw();
+ var ca = selected.ca + yaw;
+ var origin = selected.loc;
// construct a search trapezoid pointing out from current bubble
- const meters = 35;
- let p1 = [
+ var meters = 35;
+ var p1 = [
origin[0] + geoMetersToLon(meters / 5, origin[1]),
origin[1]
];
- let p2 = [
+ var p2 = [
origin[0] + geoMetersToLon(meters / 2, origin[1]),
origin[1] + geoMetersToLat(meters)
];
- let p3 = [
+ var p3 = [
origin[0] - geoMetersToLon(meters / 2, origin[1]),
origin[1] + geoMetersToLat(meters)
];
- let p4 = [
+ var p4 = [
origin[0] - geoMetersToLon(meters / 5, origin[1]),
origin[1]
];
- let poly = [p1, p2, p3, p4, p1];
+ var poly = [p1, p2, p3, p4, p1];
// rotate it to face forward/backward
- let angle = (stepBy === 1 ? ca : ca + 180) * (Math.PI / 180);
+ var angle = (stepBy === 1 ? ca : ca + 180) * (Math.PI / 180);
poly = geoRotate(poly, -angle, origin);
- let extent = poly.reduce((extent, point) => {
+ var extent = poly.reduce(function (extent, point) {
return extent.extend(geoExtent(point));
}, geoExtent());
// find nearest other bubble in the search polygon
- let minDist = Infinity;
+ var minDist = Infinity;
_ssCache.bubbles.rtree.search(extent.bbox())
- .forEach(d => {
- if (d.data.key === selected.key) return;
- if (!geoPointInPolygon(d.data.loc, poly)) return;
+ .forEach(function (d) {
+ if (d.data.key === selected.key) { return; }
+ if (!geoPointInPolygon(d.data.loc, poly)) { return; }
- let dist = geoVecLength(d.data.loc, selected.loc);
- let theta = selected.ca - d.data.ca;
- let minTheta = Math.min(Math.abs(theta), 360 - Math.abs(theta));
+ var dist = geoVecLength(d.data.loc, selected.loc);
+ var theta = selected.ca - d.data.ca;
+ var minTheta = Math.min(Math.abs(theta), 360 - Math.abs(theta));
if (minTheta > 20) {
dist += 5; // penalize distance if camera angles don't match
}
}
});
- let nextBubble = nextID && _ssCache.bubbles.points[nextID];
- if (!nextBubble) return;
+ var nextBubble = nextID && _ssCache.bubbles.points[nextID];
+ if (!nextBubble) { return; }
context.map().centerEase(nextBubble.loc);
that.selectImage(context, nextBubble)
- .then(response => {
+ .then(function (response) {
if (response.status === 'ok') {
_sceneOptions.yaw = yaw;
that.showViewer(context);
* showViewer()
*/
showViewer: function(context, yaw) {
- if (!_sceneOptions) return;
+ if (!_sceneOptions) { return; }
if (yaw !== undefined) {
_sceneOptions.yaw = yaw;
this.initViewer();
} else {
// make a new scene
- let sceneID = ++_currScene + '';
+ var sceneID = ++_currScene + '';
_pannellumViewer
.addScene(sceneID, _sceneOptions)
.loadScene(sceneID);
}
}
- let wrap = context.container().select('.photoviewer')
+ var wrap = context.container().select('.photoviewer')
.classed('hide', false);
- let isHidden = wrap.selectAll('.photo-wrapper.ms-wrapper.hide').size();
+ var isHidden = wrap.selectAll('.photo-wrapper.ms-wrapper.hide').size();
if (isHidden) {
wrap
* hideViewer()
*/
hideViewer: function (context) {
- let viewer = context.container().select('.photoviewer');
- if (!viewer.empty()) viewer.datum(null);
+ var viewer = context.container().select('.photoviewer');
+ if (!viewer.empty()) { viewer.datum(null); }
viewer
.classed('hide', true)
* selectImage().
*/
selectImage: function (context, d) {
- let that = this;
- let viewer = context.container().select('.photoviewer');
- if (!viewer.empty()) viewer.datum(d);
+ var that = this;
+ var viewer = context.container().select('.photoviewer');
+ if (!viewer.empty()) { viewer.datum(d); }
this.setStyles(context, null, true);
- let wrap = context.container().select('.photoviewer .ms-wrapper');
- let attribution = wrap.selectAll('.photo-attribution').html('');
+ var wrap = context.container().select('.photoviewer .ms-wrapper');
+ var attribution = wrap.selectAll('.photo-attribution').html('');
wrap.selectAll('.pnlm-load-box') // display "loading.."
.style('display', 'block');
return Promise.resolve({ status: 'ok' });
}
- let line1 = attribution
+ var line1 = attribution
.append('div')
.attr('class', 'attribution-row');
- const hiresDomId = utilUniqueDomId('streetside-hires');
+ var hiresDomId = utilUniqueDomId('streetside-hires');
// Add hires checkbox
- let label = line1
+ var label = line1
.append('label')
.attr('for', hiresDomId)
.attr('class', 'streetside-hires');
.attr('type', 'checkbox')
.attr('id', hiresDomId)
.property('checked', _hires)
- .on('click', () => {
+ .on('click', function () {
event.stopPropagation();
_hires = !_hires;
_resolution = _hires ? 1024 : 512;
wrap.call(setupCanvas, true);
- let viewstate = {
+ var viewstate = {
yaw: _pannellumViewer.getYaw(),
pitch: _pannellumViewer.getPitch(),
hfov: _pannellumViewer.getHfov()
};
that.selectImage(context, d)
- .then(response => {
+ .then(function (response) {
if (response.status === 'ok') {
_sceneOptions = Object.assign(_sceneOptions, viewstate);
that.showViewer(context);
.text(_t('streetside.hires'));
- let captureInfo = line1
+ var captureInfo = line1
.append('div')
.attr('class', 'attribution-capture-info');
// Add capture date
if (d.captured_by) {
- const yyyy = (new Date()).getFullYear();
+ var yyyy = (new Date()).getFullYear();
captureInfo
.append('a')
}
// Add image links
- let line2 = attribution
+ var line2 = attribution
.append('div')
.attr('class', 'attribution-row');
.text(_t('streetside.report'));
- let bubbleIdQuadKey = d.key.toString(4);
- const paddingNeeded = 16 - bubbleIdQuadKey.length;
- for (let i = 0; i < paddingNeeded; i++) {
+ var bubbleIdQuadKey = d.key.toString(4);
+ var paddingNeeded = 16 - bubbleIdQuadKey.length;
+ for (var i = 0; i < paddingNeeded; i++) {
bubbleIdQuadKey = '0' + bubbleIdQuadKey;
}
- const imgUrlPrefix = streetsideImagesApi + 'hs' + bubbleIdQuadKey;
- const imgUrlSuffix = '.jpg?g=6338&n=z';
+ var imgUrlPrefix = streetsideImagesApi + 'hs' + bubbleIdQuadKey;
+ var imgUrlSuffix = '.jpg?g=6338&n=z';
// Cubemap face code order matters here: front=01, right=02, back=03, left=10, up=11, down=12
- const faceKeys = ['01','02','03','10','11','12'];
+ var faceKeys = ['01','02','03','10','11','12'];
// Map images to cube faces
- let quadKeys = getQuadKeys();
- let faces = faceKeys.map((faceKey) => {
- return quadKeys.map((quadKey) =>{
- const xy = qkToXY(quadKey);
+ var quadKeys = getQuadKeys();
+ var faces = faceKeys.map(function (faceKey) {
+ return quadKeys.map(function (quadKey) {
+ var xy = qkToXY(quadKey);
return {
face: faceKey,
url: imgUrlPrefix + faceKey + quadKey + imgUrlSuffix,
});
return loadFaces(faces)
- .then(() => {
+ .then(function () {
_sceneOptions = {
showFullscreenCtrl: false,
autoLoad: true,
.classed('currentView', false);
}
- let hoveredBubbleKey = hovered && hovered.key;
- let hoveredSequenceKey = this.getSequenceKeyForBubble(hovered);
- let hoveredSequence = hoveredSequenceKey && _ssCache.sequences[hoveredSequenceKey];
- let hoveredBubbleKeys = (hoveredSequence && hoveredSequence.bubbles.map(d => d.key)) || [];
+ var hoveredBubbleKey = hovered && hovered.key;
+ var hoveredSequenceKey = this.getSequenceKeyForBubble(hovered);
+ var hoveredSequence = hoveredSequenceKey && _ssCache.sequences[hoveredSequenceKey];
+ var hoveredBubbleKeys = (hoveredSequence && hoveredSequence.bubbles.map(function (d) { return d.key; })) || [];
- let viewer = context.container().select('.photoviewer');
- let selected = viewer.empty() ? undefined : viewer.datum();
- let selectedBubbleKey = selected && selected.key;
- let selectedSequenceKey = this.getSequenceKeyForBubble(selected);
- let selectedSequence = selectedSequenceKey && _ssCache.sequences[selectedSequenceKey];
- let selectedBubbleKeys = (selectedSequence && selectedSequence.bubbles.map(d => d.key)) || [];
+ var viewer = context.container().select('.photoviewer');
+ var selected = viewer.empty() ? undefined : viewer.datum();
+ var selectedBubbleKey = selected && selected.key;
+ var selectedSequenceKey = this.getSequenceKeyForBubble(selected);
+ var selectedSequence = selectedSequenceKey && _ssCache.sequences[selectedSequenceKey];
+ var selectedBubbleKeys = (selectedSequence && selectedSequence.bubbles.map(function (d) { return d.key; })) || [];
// highlight sibling viewfields on either the selected or the hovered sequences
- let highlightedBubbleKeys = utilArrayUnion(hoveredBubbleKeys, selectedBubbleKeys);
+ var highlightedBubbleKeys = utilArrayUnion(hoveredBubbleKeys, selectedBubbleKeys);
context.container().selectAll('.layer-streetside-images .viewfield-group')
- .classed('highlighted', d => highlightedBubbleKeys.indexOf(d.key) !== -1)
- .classed('hovered', d => d.key === hoveredBubbleKey)
- .classed('currentView', d => d.key === selectedBubbleKey);
+ .classed('highlighted', function (d) { return highlightedBubbleKeys.indexOf(d.key) !== -1; })
+ .classed('hovered', function (d) { return d.key === hoveredBubbleKey; })
+ .classed('currentView', function (d) { return d.key === selectedBubbleKey; });
context.container().selectAll('.layer-streetside-images .sequence')
- .classed('highlighted', d => d.properties.key === hoveredSequenceKey)
- .classed('currentView', d => d.properties.key === selectedSequenceKey);
+ .classed('highlighted', function (d) { return d.properties.key === hoveredSequenceKey; })
+ .classed('currentView', function (d) { return d.properties.key === selectedSequenceKey; });
// update viewfields if needed
context.container().selectAll('.viewfield-group .viewfield')
.attr('d', viewfieldPath);
function viewfieldPath() {
- let d = this.parentNode.__data__;
+ var d = this.parentNode.__data__;
if (d.pano && d.key !== selectedBubbleKey) {
return 'M 8,13 m -10,0 a 10,10 0 1,0 20,0 a 10,10 0 1,0 -20,0';
} else {
function filterValues(allowUpperCase) {
return function(d) {
- if (d.value.match(/[;,]/) !== null) return false; // exclude some punctuation
- if (!allowUpperCase && d.value.match(/[A-Z*]/) !== null) return false; // exclude uppercase letters
+ if (d.value.match(/[;,]/) !== null) { return false; } // exclude some punctuation
+ if (!allowUpperCase && d.value.match(/[A-Z*]/) !== null) { return false; } // exclude uppercase letters
return parseFloat(d.fraction) > 0.0;
};
}
function filterRoles(geometry) {
return function(d) {
- if (d.role === '') return false; // exclude empty role
- if (d.role.match(/[A-Z*;,]/) !== null) return false; // exclude uppercase letters and some punctuation
+ if (d.role === '') { return false; } // exclude empty role
+ if (d.role.match(/[A-Z*;,]/) !== null) { return false; } // exclude uppercase letters and some punctuation
return parseFloat(d[tag_members_fractions[geometry]]) > 0.0;
};
}
var debouncedRequest$1 = debounce(request$1, 300, { leading: false });
function request$1(url, params, exactMatch, callback, loaded) {
- if (_inflight$2[url]) return;
+ if (_inflight$2[url]) { return; }
- if (checkCache(url, params, exactMatch, callback)) return;
+ if (checkCache(url, params, exactMatch, callback)) { return; }
var controller = new AbortController();
_inflight$2[url] = controller;
d3_json(url, { signal: controller.signal })
.then(function(result) {
delete _inflight$2[url];
- if (loaded) loaded(null, result);
+ if (loaded) { loaded(null, result); }
})
.catch(function(err) {
delete _inflight$2[url];
- if (err.name === 'AbortError') return;
- if (loaded) loaded(err.message);
+ if (err.name === 'AbortError') { return; }
+ if (loaded) { loaded(err.message); }
});
}
}
// don't try to shorten the query
- if (exactMatch || !testQuery.length) return false;
+ if (exactMatch || !testQuery.length) { return false; }
// do shorten the query to see if we already have a cached result
// that has returned fewer than max results (rp)
lang: _mainLocalizer.languageCode()
};
this.keys(params, function(err, data) {
- if (err) return;
+ if (err) { return; }
data.forEach(function(d) {
- if (d.value === 'opening_hours') return; // exception
+ if (d.value === 'opening_hours') { return; } // exception
_popularKeys[d.value] = true;
});
});
apibase: function(_) {
- if (!arguments.length) return apibase$4;
+ if (!arguments.length) { return apibase$4; }
apibase$4 = _;
return this;
}
part = [],
i, a, b, codeB, lastCode;
- if (!result) result = [];
+ if (!result) { result = []; }
for (i = 1; i < len; i++) {
a = points[i - 1];
codeA = lastCode;
}
- if (part.length) result.push(part);
+ if (part.length) { result.push(part); }
return result;
}
inside = !(bitCode(p, bbox) & edge);
// if segment goes through the clip window, add an intersection
- if (inside !== prevInside) result.push(intersect(prev, p, edge, bbox));
+ if (inside !== prevInside) { result.push(intersect(prev, p, edge, bbox)); }
- if (inside) result.push(p); // add a point if it's inside
+ if (inside) { result.push(p); } // add a point if it's inside
prev = p;
prevInside = inside;
points = result;
- if (!points.length) break;
+ if (!points.length) { break; }
}
return result;
function bitCode(p, bbox) {
var code = 0;
- if (p[0] < bbox[0]) code |= 1; // left
- else if (p[0] > bbox[2]) code |= 2; // right
+ if (p[0] < bbox[0]) { code |= 1; } // left
+ else if (p[0] > bbox[2]) { code |= 2; } // right
- if (p[1] < bbox[1]) code |= 4; // bottom
- else if (p[1] > bbox[3]) code |= 8; // top
+ if (p[1] < bbox[1]) { code |= 4; } // bottom
+ else if (p[1] > bbox[3]) { code |= 8; } // top
return code;
}
var bboxClip_1 = createCommonjsModule(function (module, exports) {
var __importStar = (commonjsGlobal && commonjsGlobal.__importStar) || function (mod) {
- if (mod && mod.__esModule) return mod;
+ if (mod && mod.__esModule) { return mod; }
var result = {};
- if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];
+ if (mod != null) { for (var k in mod) { if (Object.hasOwnProperty.call(mod, k)) { result[k] = mod[k]; } } }
result["default"] = mod;
return result;
};
}
});
+ var turf_bboxClip = /*@__PURE__*/getDefaultExportFromCjs(bboxClip_1);
+
var fastJsonStableStringify = function (data, opts) {
- if (!opts) opts = {};
- if (typeof opts === 'function') opts = { cmp: opts };
+ if (!opts) { opts = {}; }
+ if (typeof opts === 'function') { opts = { cmp: opts }; }
var cycles = (typeof opts.cycles === 'boolean') ? opts.cycles : false;
var cmp = opts.cmp && (function (f) {
node = node.toJSON();
}
- if (node === undefined) return;
- if (typeof node == 'number') return isFinite(node) ? '' + node : 'null';
- if (typeof node !== 'object') return JSON.stringify(node);
+ if (node === undefined) { return; }
+ if (typeof node == 'number') { return isFinite(node) ? '' + node : 'null'; }
+ if (typeof node !== 'object') { return JSON.stringify(node); }
var i, out;
if (Array.isArray(node)) {
out = '[';
for (i = 0; i < node.length; i++) {
- if (i) out += ',';
+ if (i) { out += ','; }
out += stringify(node[i]) || 'null';
}
return out + ']';
}
- if (node === null) return 'null';
+ if (node === null) { return 'null'; }
if (seen.indexOf(node) !== -1) {
- if (cycles) return JSON.stringify('__cycle__');
+ if (cycles) { return JSON.stringify('__cycle__'); }
throw new TypeError('Converting circular structure to JSON');
}
var key = keys[i];
var value = stringify(node[key]);
- if (!value) continue;
- if (out) out += ',';
+ if (!value) { continue; }
+ if (out) { out += ','; }
out += JSON.stringify(key) + ':' + value;
}
seen.splice(seenIndex, 1);
function DEFAULT_COMPARE (a, b) { return a > b ? 1 : a < b ? -1 : 0; }
- class SplayTree {
+ var SplayTree = function SplayTree(compare, noDuplicates) {
+ if ( compare === void 0 ) compare = DEFAULT_COMPARE;
+ if ( noDuplicates === void 0 ) noDuplicates = false;
- constructor(compare = DEFAULT_COMPARE, noDuplicates = false) {
- this._compare = compare;
- this._root = null;
- this._size = 0;
- this._noDuplicates = !!noDuplicates;
- }
+ this._compare = compare;
+ this._root = null;
+ this._size = 0;
+ this._noDuplicates = !!noDuplicates;
+ };
+ var prototypeAccessors = { size: { configurable: true } };
- rotateLeft(x) {
- var y = x.right;
- if (y) {
- x.right = y.left;
- if (y.left) y.left.parent = x;
- y.parent = x.parent;
- }
- if (!x.parent) this._root = y;
- else if (x === x.parent.left) x.parent.left = y;
- else x.parent.right = y;
- if (y) y.left = x;
- x.parent = y;
+ SplayTree.prototype.rotateLeft = function rotateLeft (x) {
+ var y = x.right;
+ if (y) {
+ x.right = y.left;
+ if (y.left) { y.left.parent = x; }
+ y.parent = x.parent;
}
+ if (!x.parent) { this._root = y; }
+ else if (x === x.parent.left) { x.parent.left = y; }
+ else { x.parent.right = y; }
+ if (y) { y.left = x; }
+ x.parent = y;
+ };
- rotateRight(x) {
- var y = x.left;
- if (y) {
- x.left = y.right;
- if (y.right) y.right.parent = x;
- y.parent = x.parent;
- }
- if (!x.parent) this._root = y;
- else if(x === x.parent.left) x.parent.left = y;
- else x.parent.right = y;
- if (y) y.right = x;
- x.parent = y;
+ SplayTree.prototype.rotateRight = function rotateRight (x) {
+ var y = x.left;
+ if (y) {
+ x.left = y.right;
+ if (y.right) { y.right.parent = x; }
+ y.parent = x.parent;
}
+ if (!x.parent) { this._root = y; }
+ else if(x === x.parent.left) { x.parent.left = y; }
+ else { x.parent.right = y; }
+ if (y) { y.right = x; }
+ x.parent = y;
+ };
- _splay(x) {
- while (x.parent) {
- var p = x.parent;
- if (!p.parent) {
- if (p.left === x) this.rotateRight(p);
- else this.rotateLeft(p);
- } else if (p.left === x && p.parent.left === p) {
- this.rotateRight(p.parent);
- this.rotateRight(p);
- } else if (p.right === x && p.parent.right === p) {
- this.rotateLeft(p.parent);
- this.rotateLeft(p);
- } else if (p.left === x && p.parent.right === p) {
- this.rotateRight(p);
- this.rotateLeft(p);
- } else {
- this.rotateLeft(p);
- this.rotateRight(p);
- }
+
+ SplayTree.prototype._splay = function _splay (x) {
+ while (x.parent) {
+ var p = x.parent;
+ if (!p.parent) {
+ if (p.left === x) { this.rotateRight(p); }
+ else { this.rotateLeft(p); }
+ } else if (p.left === x && p.parent.left === p) {
+ this.rotateRight(p.parent);
+ this.rotateRight(p);
+ } else if (p.right === x && p.parent.right === p) {
+ this.rotateLeft(p.parent);
+ this.rotateLeft(p);
+ } else if (p.left === x && p.parent.right === p) {
+ this.rotateRight(p);
+ this.rotateLeft(p);
+ } else {
+ this.rotateLeft(p);
+ this.rotateRight(p);
}
}
+ };
- splay(x) {
- var p, gp, ggp, l, r;
+ SplayTree.prototype.splay = function splay (x) {
+ var p, gp, ggp, l, r;
- while (x.parent) {
- p = x.parent;
- gp = p.parent;
+ while (x.parent) {
+ p = x.parent;
+ gp = p.parent;
- if (gp && gp.parent) {
- ggp = gp.parent;
- if (ggp.left === gp) ggp.left = x;
- else ggp.right = x;
- x.parent = ggp;
- } else {
- x.parent = null;
- this._root = x;
- }
+ if (gp && gp.parent) {
+ ggp = gp.parent;
+ if (ggp.left === gp) { ggp.left= x; }
+ else { ggp.right = x; }
+ x.parent = ggp;
+ } else {
+ x.parent = null;
+ this._root = x;
+ }
- l = x.left; r = x.right;
+ l = x.left; r = x.right;
- if (x === p.left) { // left
- if (gp) {
- if (gp.left === p) {
- /* zig-zig */
- if (p.right) {
- gp.left = p.right;
- gp.left.parent = gp;
- } else gp.left = null;
+ if (x === p.left) { // left
+ if (gp) {
+ if (gp.left === p) {
+ /* zig-zig */
+ if (p.right) {
+ gp.left = p.right;
+ gp.left.parent = gp;
+ } else { gp.left = null; }
- p.right = gp;
- gp.parent = p;
- } else {
- /* zig-zag */
- if (l) {
- gp.right = l;
- l.parent = gp;
- } else gp.right = null;
-
- x.left = gp;
- gp.parent = x;
- }
- }
- if (r) {
- p.left = r;
- r.parent = p;
- } else p.left = null;
-
- x.right = p;
- p.parent = x;
- } else { // right
- if (gp) {
- if (gp.right === p) {
- /* zig-zig */
- if (p.left) {
- gp.right = p.left;
- gp.right.parent = gp;
- } else gp.right = null;
-
- p.left = gp;
- gp.parent = p;
- } else {
- /* zig-zag */
- if (r) {
- gp.left = r;
- r.parent = gp;
- } else gp.left = null;
-
- x.right = gp;
- gp.parent = x;
- }
- }
- if (l) {
- p.right = l;
- l.parent = p;
- } else p.right = null;
+ p.right = gp;
+ gp.parent = p;
+ } else {
+ /* zig-zag */
+ if (l) {
+ gp.right = l;
+ l.parent = gp;
+ } else { gp.right = null; }
+
+ x.left = gp;
+ gp.parent = x;
+ }
+ }
+ if (r) {
+ p.left = r;
+ r.parent = p;
+ } else { p.left = null; }
+
+ x.right= p;
+ p.parent = x;
+ } else { // right
+ if (gp) {
+ if (gp.right === p) {
+ /* zig-zig */
+ if (p.left) {
+ gp.right = p.left;
+ gp.right.parent = gp;
+ } else { gp.right = null; }
+
+ p.left = gp;
+ gp.parent = p;
+ } else {
+ /* zig-zag */
+ if (r) {
+ gp.left = r;
+ r.parent = gp;
+ } else { gp.left = null; }
- x.left = p;
- p.parent = x;
+ x.right = gp;
+ gp.parent = x;
+ }
}
+ if (l) {
+ p.right = l;
+ l.parent = p;
+ } else { p.right = null; }
+
+ x.left = p;
+ p.parent = x;
}
}
+ };
- replace(u, v) {
- if (!u.parent) this._root = v;
- else if (u === u.parent.left) u.parent.left = v;
- else u.parent.right = v;
- if (v) v.parent = u.parent;
- }
+ SplayTree.prototype.replace = function replace (u, v) {
+ if (!u.parent) { this._root = v; }
+ else if (u === u.parent.left) { u.parent.left = v; }
+ else { u.parent.right = v; }
+ if (v) { v.parent = u.parent; }
+ };
- minNode(u = this._root) {
- if (u) while (u.left) u = u.left;
- return u;
- }
+ SplayTree.prototype.minNode = function minNode (u) {
+ if ( u === void 0 ) u = this._root;
+ if (u) { while (u.left) { u = u.left; } }
+ return u;
+ };
- maxNode(u = this._root) {
- if (u) while (u.right) u = u.right;
- return u;
- }
+ SplayTree.prototype.maxNode = function maxNode (u) {
+ if ( u === void 0 ) u = this._root;
- insert(key, data) {
- var z = this._root;
- var p = null;
- var comp = this._compare;
- var cmp;
+ if (u) { while (u.right) { u = u.right; } }
+ return u;
+ };
- if (this._noDuplicates) {
- while (z) {
- p = z;
- cmp = comp(z.key, key);
- if (cmp === 0) return;
- else if (comp(z.key, key) < 0) z = z.right;
- else z = z.left;
- }
- } else {
- while (z) {
- p = z;
- if (comp(z.key, key) < 0) z = z.right;
- else z = z.left;
- }
+
+ SplayTree.prototype.insert = function insert (key, data) {
+ var z = this._root;
+ var p = null;
+ var comp = this._compare;
+ var cmp;
+
+ if (this._noDuplicates) {
+ while (z) {
+ p = z;
+ cmp = comp(z.key, key);
+ if (cmp === 0) { return; }
+ else if (comp(z.key, key) < 0) { z = z.right; }
+ else { z = z.left; }
}
+ } else {
+ while (z) {
+ p = z;
+ if (comp(z.key, key) < 0) { z = z.right; }
+ else { z = z.left; }
+ }
+ }
- z = { key, data, left: null, right: null, parent: p };
+ z = { key: key, data: data, left: null, right: null, parent: p };
- if (!p) this._root = z;
- else if (comp(p.key, z.key) < 0) p.right = z;
- else p.left = z;
+ if (!p) { this._root = z; }
+ else if (comp(p.key, z.key) < 0) { p.right = z; }
+ else { p.left= z; }
- this.splay(z);
- this._size++;
- return z;
- }
+ this.splay(z);
+ this._size++;
+ return z;
+ };
- find (key) {
- var z = this._root;
- var comp = this._compare;
- while (z) {
- var cmp = comp(z.key, key);
- if (cmp < 0) z = z.right;
- else if (cmp > 0) z = z.left;
- else return z;
- }
- return null;
+ SplayTree.prototype.find = function find (key) {
+ var z = this._root;
+ var comp = this._compare;
+ while (z) {
+ var cmp = comp(z.key, key);
+ if (cmp < 0) { z = z.right; }
+ else if (cmp > 0) { z = z.left; }
+ else { return z; }
}
+ return null;
+ };
- /**
- * Whether the tree contains a node with the given key
- * @param {Key} key
- * @return {boolean} true/false
- */
- contains (key) {
- var node = this._root;
- var comparator = this._compare;
- while (node) {
- var cmp = comparator(key, node.key);
- if (cmp === 0) return true;
- else if (cmp < 0) node = node.left;
- else node = node.right;
- }
-
- return false;
+ /**
+ * Whether the tree contains a node with the given key
+ * @param{Key} key
+ * @return {boolean} true/false
+ */
+ SplayTree.prototype.contains = function contains (key) {
+ var node = this._root;
+ var comparator = this._compare;
+ while (node){
+ var cmp = comparator(key, node.key);
+ if (cmp === 0) { return true; }
+ else if (cmp < 0) { node = node.left; }
+ else { node = node.right; }
}
+ return false;
+ };
- remove (key) {
- var z = this.find(key);
- if (!z) return false;
+ SplayTree.prototype.remove = function remove (key) {
+ var z = this.find(key);
- this.splay(z);
+ if (!z) { return false; }
- if (!z.left) this.replace(z, z.right);
- else if (!z.right) this.replace(z, z.left);
- else {
- var y = this.minNode(z.right);
- if (y.parent !== z) {
- this.replace(y, y.right);
- y.right = z.right;
- y.right.parent = y;
- }
- this.replace(z, y);
- y.left = z.left;
- y.left.parent = y;
- }
+ this.splay(z);
- this._size--;
- return true;
+ if (!z.left) { this.replace(z, z.right); }
+ else if (!z.right) { this.replace(z, z.left); }
+ else {
+ var y = this.minNode(z.right);
+ if (y.parent !== z) {
+ this.replace(y, y.right);
+ y.right = z.right;
+ y.right.parent = y;
+ }
+ this.replace(z, y);
+ y.left = z.left;
+ y.left.parent = y;
}
+ this._size--;
+ return true;
+ };
- removeNode(z) {
- if (!z) return false;
- this.splay(z);
+ SplayTree.prototype.removeNode = function removeNode (z) {
+ if (!z) { return false; }
- if (!z.left) this.replace(z, z.right);
- else if (!z.right) this.replace(z, z.left);
- else {
- var y = this.minNode(z.right);
- if (y.parent !== z) {
- this.replace(y, y.right);
- y.right = z.right;
- y.right.parent = y;
- }
- this.replace(z, y);
- y.left = z.left;
- y.left.parent = y;
- }
+ this.splay(z);
- this._size--;
- return true;
+ if (!z.left) { this.replace(z, z.right); }
+ else if (!z.right) { this.replace(z, z.left); }
+ else {
+ var y = this.minNode(z.right);
+ if (y.parent !== z) {
+ this.replace(y, y.right);
+ y.right = z.right;
+ y.right.parent = y;
+ }
+ this.replace(z, y);
+ y.left = z.left;
+ y.left.parent = y;
}
+ this._size--;
+ return true;
+ };
- erase (key) {
- var z = this.find(key);
- if (!z) return;
- this.splay(z);
+ SplayTree.prototype.erase = function erase (key) {
+ var z = this.find(key);
+ if (!z) { return; }
- var s = z.left;
- var t = z.right;
+ this.splay(z);
- var sMax = null;
- if (s) {
- s.parent = null;
- sMax = this.maxNode(s);
- this.splay(sMax);
- this._root = sMax;
- }
- if (t) {
- if (s) sMax.right = t;
- else this._root = t;
- t.parent = sMax;
- }
+ var s = z.left;
+ var t = z.right;
- this._size--;
+ var sMax = null;
+ if (s) {
+ s.parent = null;
+ sMax = this.maxNode(s);
+ this.splay(sMax);
+ this._root = sMax;
+ }
+ if (t) {
+ if (s) { sMax.right = t; }
+ else { this._root = t; }
+ t.parent = sMax;
}
- /**
- * Removes and returns the node with smallest key
- * @return {?Node}
- */
- pop () {
- var node = this._root, returnValue = null;
- if (node) {
- while (node.left) node = node.left;
- returnValue = { key: node.key, data: node.data };
- this.remove(node.key);
- }
- return returnValue;
+ this._size--;
+ };
+
+ /**
+ * Removes and returns the node with smallest key
+ * @return {?Node}
+ */
+ SplayTree.prototype.pop = function pop () {
+ var node = this._root, returnValue = null;
+ if (node) {
+ while (node.left) { node = node.left; }
+ returnValue = { key: node.key, data: node.data };
+ this.remove(node.key);
}
+ return returnValue;
+ };
- /* eslint-disable class-methods-use-this */
+ /* eslint-disable class-methods-use-this */
- /**
- * Successor node
- * @param {Node} node
- * @return {?Node}
- */
- next (node) {
- var successor = node;
- if (successor) {
- if (successor.right) {
- successor = successor.right;
- while (successor && successor.left) successor = successor.left;
- } else {
- successor = node.parent;
- while (successor && successor.right === node) {
- node = successor; successor = successor.parent;
- }
+ /**
+ * Successor node
+ * @param{Node} node
+ * @return {?Node}
+ */
+ SplayTree.prototype.next = function next (node) {
+ var successor = node;
+ if (successor) {
+ if (successor.right) {
+ successor = successor.right;
+ while (successor && successor.left) { successor = successor.left; }
+ } else {
+ successor = node.parent;
+ while (successor && successor.right === node) {
+ node = successor; successor = successor.parent;
}
}
- return successor;
}
+ return successor;
+ };
- /**
- * Predecessor node
- * @param {Node} node
- * @return {?Node}
- */
- prev (node) {
- var predecessor = node;
- if (predecessor) {
- if (predecessor.left) {
- predecessor = predecessor.left;
- while (predecessor && predecessor.right) predecessor = predecessor.right;
- } else {
- predecessor = node.parent;
- while (predecessor && predecessor.left === node) {
- node = predecessor;
- predecessor = predecessor.parent;
- }
+ /**
+ * Predecessor node
+ * @param{Node} node
+ * @return {?Node}
+ */
+ SplayTree.prototype.prev = function prev (node) {
+ var predecessor = node;
+ if (predecessor) {
+ if (predecessor.left) {
+ predecessor = predecessor.left;
+ while (predecessor && predecessor.right) { predecessor = predecessor.right; }
+ } else {
+ predecessor = node.parent;
+ while (predecessor && predecessor.left === node) {
+ node = predecessor;
+ predecessor = predecessor.parent;
}
}
- return predecessor;
}
- /* eslint-enable class-methods-use-this */
+ return predecessor;
+ };
+ /* eslint-enable class-methods-use-this */
- /**
- * @param {forEachCallback} callback
- * @return {SplayTree}
- */
- forEach(callback) {
- var current = this._root;
- var s = [], done = false, i = 0;
-
- while (!done) {
- // Reach the left most Node of the current Node
- if (current) {
- // Place pointer to a tree node on the stack
- // before traversing the node's left subtree
- s.push(current);
- current = current.left;
- } else {
- // BackTrack from the empty subtree and visit the Node
- // at the top of the stack; however, if the stack is
- // empty you are done
- if (s.length > 0) {
- current = s.pop();
- callback(current, i++);
-
- // We have visited the node and its left
- // subtree. Now, it's right subtree's turn
- current = current.right;
- } else done = true;
- }
+ /**
+ * @param{forEachCallback} callback
+ * @return {SplayTree}
+ */
+ SplayTree.prototype.forEach = function forEach (callback) {
+ var current = this._root;
+ var s = [], done = false, i = 0;
+
+ while (!done) {
+ // Reach the left most Node of the current Node
+ if (current) {
+ // Place pointer to a tree node on the stack
+ // before traversing the node's left subtree
+ s.push(current);
+ current = current.left;
+ } else {
+ // BackTrack from the empty subtree and visit the Node
+ // at the top of the stack; however, if the stack is
+ // empty you are done
+ if (s.length > 0) {
+ current = s.pop();
+ callback(current, i++);
+
+ // We have visited the node and its left
+ // subtree. Now, it's right subtree's turn
+ current = current.right;
+ } else { done = true; }
}
- return this;
}
+ return this;
+ };
- /**
- * Walk key range from `low` to `high`. Stops if `fn` returns a value.
- * @param {Key} low
- * @param {Key} high
- * @param {Function} fn
- * @param {*?} ctx
- * @return {SplayTree}
- */
- range(low, high, fn, ctx) {
- const Q = [];
- const compare = this._compare;
- let node = this._root, cmp;
-
- while (Q.length !== 0 || node) {
- if (node) {
- Q.push(node);
- node = node.left;
- } else {
- node = Q.pop();
- cmp = compare(node.key, high);
- if (cmp > 0) {
- break;
- } else if (compare(node.key, low) >= 0) {
- if (fn.call(ctx, node)) return this; // stop if smth is returned
- }
- node = node.right;
+ /**
+ * Walk key range from `low` to `high`. Stops if `fn` returns a value.
+ * @param{Key} low
+ * @param{Key} high
+ * @param{Function} fn
+ * @param{*?} ctx
+ * @return {SplayTree}
+ */
+ SplayTree.prototype.range = function range (low, high, fn, ctx) {
+ var Q = [];
+ var compare = this._compare;
+ var node = this._root, cmp;
+
+ while (Q.length !== 0 || node) {
+ if (node) {
+ Q.push(node);
+ node = node.left;
+ } else {
+ node = Q.pop();
+ cmp = compare(node.key, high);
+ if (cmp > 0) {
+ break;
+ } else if (compare(node.key, low) >= 0) {
+ if (fn.call(ctx, node)) { return this; } // stop if smth is returned
}
+ node = node.right;
}
- return this;
}
+ return this;
+ };
- /**
- * Returns all keys in order
- * @return {Array<Key>}
- */
- keys () {
- var current = this._root;
- var s = [], r = [], done = false;
-
- while (!done) {
- if (current) {
- s.push(current);
- current = current.left;
- } else {
- if (s.length > 0) {
- current = s.pop();
- r.push(current.key);
- current = current.right;
- } else done = true;
- }
+ /**
+ * Returns all keys in order
+ * @return {Array<Key>}
+ */
+ SplayTree.prototype.keys = function keys () {
+ var current = this._root;
+ var s = [], r = [], done = false;
+
+ while (!done) {
+ if (current) {
+ s.push(current);
+ current = current.left;
+ } else {
+ if (s.length > 0) {
+ current = s.pop();
+ r.push(current.key);
+ current = current.right;
+ } else { done = true; }
}
- return r;
}
+ return r;
+ };
- /**
- * Returns `data` fields of all nodes in order.
- * @return {Array<Value>}
- */
- values () {
- var current = this._root;
- var s = [], r = [], done = false;
-
- while (!done) {
- if (current) {
- s.push(current);
- current = current.left;
- } else {
- if (s.length > 0) {
- current = s.pop();
- r.push(current.data);
- current = current.right;
- } else done = true;
- }
+ /**
+ * Returns `data` fields of all nodes in order.
+ * @return {Array<Value>}
+ */
+ SplayTree.prototype.values = function values () {
+ var current = this._root;
+ var s = [], r = [], done = false;
+
+ while (!done) {
+ if (current) {
+ s.push(current);
+ current = current.left;
+ } else {
+ if (s.length > 0) {
+ current = s.pop();
+ r.push(current.data);
+ current = current.right;
+ } else { done = true; }
}
- return r;
}
+ return r;
+ };
- /**
- * Returns node at given index
- * @param {number} index
- * @return {?Node}
- */
- at (index) {
- // removed after a consideration, more misleading than useful
- // index = index % this.size;
- // if (index < 0) index = this.size - index;
-
- var current = this._root;
- var s = [], done = false, i = 0;
-
- while (!done) {
- if (current) {
- s.push(current);
- current = current.left;
- } else {
- if (s.length > 0) {
- current = s.pop();
- if (i === index) return current;
- i++;
- current = current.right;
- } else done = true;
- }
+ /**
+ * Returns node at given index
+ * @param{number} index
+ * @return {?Node}
+ */
+ SplayTree.prototype.at = function at (index) {
+ // removed after a consideration, more misleading than useful
+ // index = index % this.size;
+ // if (index < 0) index = this.size - index;
+
+ var current = this._root;
+ var s = [], done = false, i = 0;
+
+ while (!done) {
+ if (current) {
+ s.push(current);
+ current = current.left;
+ } else {
+ if (s.length > 0) {
+ current = s.pop();
+ if (i === index) { return current; }
+ i++;
+ current = current.right;
+ } else { done = true; }
}
- return null;
}
+ return null;
+ };
- /**
- * Bulk-load items. Both array have to be same size
- * @param {Array<Key>} keys
- * @param {Array<Value>} [values]
- * @param {Boolean} [presort=false] Pre-sort keys and values, using
- * tree's comparator. Sorting is done
- * in-place
- * @return {AVLTree}
- */
- load(keys = [], values = [], presort = false) {
- if (this._size !== 0) throw new Error('bulk-load: tree is not empty');
- const size = keys.length;
- if (presort) sort(keys, values, 0, size - 1, this._compare);
- this._root = loadRecursive(null, keys, values, 0, size);
- this._size = size;
- return this;
- }
+ /**
+ * Bulk-load items. Both array have to be same size
+ * @param{Array<Key>} keys
+ * @param{Array<Value>}[values]
+ * @param{Boolean} [presort=false] Pre-sort keys and values, using
+ * tree's comparator. Sorting is done
+ * in-place
+ * @return {AVLTree}
+ */
+ SplayTree.prototype.load = function load (keys, values, presort) {
+ if ( keys === void 0 ) keys = [];
+ if ( values === void 0 ) values = [];
+ if ( presort === void 0 ) presort = false;
+
+ if (this._size !== 0) { throw new Error('bulk-load: tree is not empty'); }
+ var size = keys.length;
+ if (presort) { sort(keys, values, 0, size - 1, this._compare); }
+ this._root = loadRecursive(null, keys, values, 0, size);
+ this._size = size;
+ return this;
+ };
- min() {
- var node = this.minNode(this._root);
- if (node) return node.key;
- else return null;
- }
+ SplayTree.prototype.min = function min () {
+ var node = this.minNode(this._root);
+ if (node) { return node.key; }
+ else { return null; }
+ };
- max() {
- var node = this.maxNode(this._root);
- if (node) return node.key;
- else return null;
- }
+ SplayTree.prototype.max = function max () {
+ var node = this.maxNode(this._root);
+ if (node) { return node.key; }
+ else { return null; }
+ };
- isEmpty() { return this._root === null; }
- get size() { return this._size; }
+ SplayTree.prototype.isEmpty = function isEmpty () { return this._root === null; };
+ prototypeAccessors.size.get = function () { return this._size; };
- /**
- * Create a tree and load it with items
- * @param {Array<Key>} keys
- * @param {Array<Value>?} [values]
-
- * @param {Function?} [comparator]
- * @param {Boolean?} [presort=false] Pre-sort keys and values, using
- * tree's comparator. Sorting is done
- * in-place
- * @param {Boolean?} [noDuplicates=false] Allow duplicates
- * @return {SplayTree}
- */
- static createTree(keys, values, comparator, presort, noDuplicates) {
- return new SplayTree(comparator, noDuplicates).load(keys, values, presort);
- }
- }
+ /**
+ * Create a tree and load it with items
+ * @param{Array<Key>} keys
+ * @param{Array<Value>?} [values]
+
+ * @param{Function?} [comparator]
+ * @param{Boolean?} [presort=false] Pre-sort keys and values, using
+ * tree's comparator. Sorting is done
+ * in-place
+ * @param{Boolean?} [noDuplicates=false] Allow duplicates
+ * @return {SplayTree}
+ */
+ SplayTree.createTree = function createTree (keys, values, comparator, presort, noDuplicates) {
+ return new SplayTree(comparator, noDuplicates).load(keys, values, presort);
+ };
+
+ Object.defineProperties( SplayTree.prototype, prototypeAccessors );
function loadRecursive (parent, keys, values, start, end) {
- const size = end - start;
+ var size = end - start;
if (size > 0) {
- const middle = start + Math.floor(size / 2);
- const key = keys[middle];
- const data = values[middle];
- const node = { key, data, parent };
+ var middle = start + Math.floor(size / 2);
+ var key = keys[middle];
+ var data = values[middle];
+ var node = { key: key, data: data, parent: parent };
node.left = loadRecursive(node, keys, values, start, middle);
node.right = loadRecursive(node, keys, values, middle + 1, end);
return node;
function sort(keys, values, left, right, compare) {
- if (left >= right) return;
+ if (left >= right) { return; }
- const pivot = keys[(left + right) >> 1];
- let i = left - 1;
- let j = right + 1;
+ var pivot = keys[(left + right) >> 1];
+ var i = left - 1;
+ var j = right + 1;
while (true) {
- do i++; while (compare(keys[i], pivot) < 0);
- do j--; while (compare(keys[j], pivot) > 0);
- if (i >= j) break;
+ do { i++; } while (compare(keys[i], pivot) < 0);
+ do { j--; } while (compare(keys[j], pivot) > 0);
+ if (i >= j) { break; }
- let tmp = keys[i];
+ var tmp = keys[i];
keys[i] = keys[j];
keys[j] = tmp;
sort(keys, values, j + 1, right, compare);
}
- const NORMAL = 0;
- const NON_CONTRIBUTING = 1;
- const SAME_TRANSITION = 2;
- const DIFFERENT_TRANSITION = 3;
+ var NORMAL = 0;
+ var NON_CONTRIBUTING = 1;
+ var SAME_TRANSITION = 2;
+ var DIFFERENT_TRANSITION = 3;
- const INTERSECTION = 0;
- const UNION = 1;
- const DIFFERENCE = 2;
- const XOR = 3;
+ var INTERSECTION = 0;
+ var UNION = 1;
+ var DIFFERENCE = 2;
+ var XOR = 3;
/**
* @param {SweepEvent} event
}
// check if the line segment belongs to the Boolean operation
- let isInResult = inResult(event, operation);
+ var isInResult = inResult(event, operation);
if (isInResult) {
event.resultTransition = determineResultTransition(event, operation);
} else {
function determineResultTransition(event, operation) {
- let thisIn = !event.inOut;
- let thatIn = !event.otherInOut;
+ var thisIn = !event.inOut;
+ var thatIn = !event.otherInOut;
- let isIn;
+ var isIn;
switch (operation) {
case INTERSECTION:
isIn = thisIn && thatIn; break;
return isIn ? +1 : -1;
}
- class SweepEvent {
+ var SweepEvent = function SweepEvent (point, left, otherEvent, isSubject, edgeType) {
+ /**
+ * Is left endpoint?
+ * @type {Boolean}
+ */
+ this.left = left;
/**
- * Sweepline event
- *
- * @class {SweepEvent}
- * @param {Array.<Number>} point
- * @param {Boolean} left
- * @param {SweepEvent=} otherEvent
- * @param {Boolean} isSubject
- * @param {Number} edgeType
+ * @type {Array.<Number>}
*/
- constructor (point, left, otherEvent, isSubject, edgeType) {
+ this.point = point;
- /**
- * Is left endpoint?
- * @type {Boolean}
- */
- this.left = left;
+ /**
+ * Other edge reference
+ * @type {SweepEvent}
+ */
+ this.otherEvent = otherEvent;
- /**
- * @type {Array.<Number>}
- */
- this.point = point;
+ /**
+ * Belongs to source or clipping polygon
+ * @type {Boolean}
+ */
+ this.isSubject = isSubject;
- /**
- * Other edge reference
- * @type {SweepEvent}
- */
- this.otherEvent = otherEvent;
+ /**
+ * Edge contribution type
+ * @type {Number}
+ */
+ this.type = edgeType || NORMAL;
- /**
- * Belongs to source or clipping polygon
- * @type {Boolean}
- */
- this.isSubject = isSubject;
- /**
- * Edge contribution type
- * @type {Number}
- */
- this.type = edgeType || NORMAL;
+ /**
+ * In-out transition for the sweepline crossing polygon
+ * @type {Boolean}
+ */
+ this.inOut = false;
- /**
- * In-out transition for the sweepline crossing polygon
- * @type {Boolean}
- */
- this.inOut = false;
+ /**
+ * @type {Boolean}
+ */
+ this.otherInOut = false;
+ /**
+ * Previous event in result?
+ * @type {SweepEvent}
+ */
+ this.prevInResult = null;
- /**
- * @type {Boolean}
- */
- this.otherInOut = false;
+ /**
+ * Type of result transition (0 = not in result, +1 = out-in, -1, in-out)
+ * @type {Number}
+ */
+ this.resultTransition = 0;
- /**
- * Previous event in result?
- * @type {SweepEvent}
- */
- this.prevInResult = null;
+ // connection step
- /**
- * Type of result transition (0 = not in result, +1 = out-in, -1, in-out)
- * @type {Number}
- */
- this.resultTransition = 0;
+ /**
+ * @type {Number}
+ */
+ this.otherPos = -1;
- // connection step
+ /**
+ * @type {Number}
+ */
+ this.outputContourId = -1;
- /**
- * @type {Number}
- */
- this.otherPos = -1;
+ this.isExteriorRing = true; // TODO: Looks unused, remove?
+ };
- /**
- * @type {Number}
- */
- this.outputContourId = -1;
+ var prototypeAccessors$1 = { inResult: { configurable: true } };
- this.isExteriorRing = true; // TODO: Looks unused, remove?
- }
+ /**
+ * @param{Array.<Number>}p
+ * @return {Boolean}
+ */
+ SweepEvent.prototype.isBelow = function isBelow (p) {
+ var p0 = this.point, p1 = this.otherEvent.point;
+ return this.left
+ ? (p0[0] - p[0]) * (p1[1] - p[1]) - (p1[0] - p[0]) * (p0[1] - p[1]) > 0
+ // signedArea(this.point, this.otherEvent.point, p) > 0 :
+ : (p1[0] - p[0]) * (p0[1] - p[1]) - (p0[0] - p[0]) * (p1[1] - p[1]) > 0;
+ //signedArea(this.otherEvent.point, this.point, p) > 0;
+ };
- /**
- * @param {Array.<Number>} p
- * @return {Boolean}
- */
- isBelow (p) {
- const p0 = this.point, p1 = this.otherEvent.point;
- return this.left
- ? (p0[0] - p[0]) * (p1[1] - p[1]) - (p1[0] - p[0]) * (p0[1] - p[1]) > 0
- // signedArea(this.point, this.otherEvent.point, p) > 0 :
- : (p1[0] - p[0]) * (p0[1] - p[1]) - (p0[0] - p[0]) * (p1[1] - p[1]) > 0;
- //signedArea(this.otherEvent.point, this.point, p) > 0;
- }
+ /**
+ * @param{Array.<Number>}p
+ * @return {Boolean}
+ */
+ SweepEvent.prototype.isAbove = function isAbove (p) {
+ return !this.isBelow(p);
+ };
- /**
- * @param {Array.<Number>} p
- * @return {Boolean}
- */
- isAbove (p) {
- return !this.isBelow(p);
- }
+ /**
+ * @return {Boolean}
+ */
+ SweepEvent.prototype.isVertical = function isVertical () {
+ return this.point[0] === this.otherEvent.point[0];
+ };
- /**
- * @return {Boolean}
- */
- isVertical () {
- return this.point[0] === this.otherEvent.point[0];
- }
+ /**
+ * Does event belong to result?
+ * @return {Boolean}
+ */
+ prototypeAccessors$1.inResult.get = function () {
+ return this.resultTransition !== 0;
+ };
- /**
- * Does event belong to result?
- * @return {Boolean}
- */
- get inResult() {
- return this.resultTransition !== 0;
- }
+ SweepEvent.prototype.clone = function clone () {
+ var copy = new SweepEvent(
+ this.point, this.left, this.otherEvent, this.isSubject, this.type);
- clone () {
- const copy = new SweepEvent(
- this.point, this.left, this.otherEvent, this.isSubject, this.type);
+ copy.contourId = this.contourId;
+ copy.resultTransition = this.resultTransition;
+ copy.prevInResult = this.prevInResult;
+ copy.isExteriorRing = this.isExteriorRing;
+ copy.inOut = this.inOut;
+ copy.otherInOut = this.otherInOut;
- copy.contourId = this.contourId;
- copy.resultTransition = this.resultTransition;
- copy.prevInResult = this.prevInResult;
- copy.isExteriorRing = this.isExteriorRing;
- copy.inOut = this.inOut;
- copy.otherInOut = this.otherInOut;
+ return copy;
+ };
- return copy;
- }
- }
+ Object.defineProperties( SweepEvent.prototype, prototypeAccessors$1 );
function equals(p1, p2) {
if (p1[0] === p2[0]) {
// return abs(p1[0] - p2[0]) <= EPSILON && abs(p1[1] - p2[1]) <= EPSILON;
// };
- const epsilon$1 = 1.1102230246251565e-16;
- const splitter = 134217729;
- const resulterrbound = (3 + 8 * epsilon$1) * epsilon$1;
+ var epsilon$1 = 1.1102230246251565e-16;
+ var splitter = 134217729;
+ var resulterrbound = (3 + 8 * epsilon$1) * epsilon$1;
// fast_expansion_sum_zeroelim routine from oritinal code
function sum$1(elen, e, flen, f, h) {
- let Q, Qnew, hh, bvirt;
- let enow = e[0];
- let fnow = f[0];
- let eindex = 0;
- let findex = 0;
+ var Q, Qnew, hh, bvirt;
+ var enow = e[0];
+ var fnow = f[0];
+ var eindex = 0;
+ var findex = 0;
if ((fnow > enow) === (fnow > -enow)) {
Q = enow;
enow = e[++eindex];
Q = fnow;
fnow = f[++findex];
}
- let hindex = 0;
+ var hindex = 0;
if (eindex < elen && findex < flen) {
if ((fnow > enow) === (fnow > -enow)) {
Qnew = enow + Q;
}
function estimate(elen, e) {
- let Q = e[0];
- for (let i = 1; i < elen; i++) Q += e[i];
+ var Q = e[0];
+ for (var i = 1; i < elen; i++) { Q += e[i]; }
return Q;
}
return new Float64Array(n);
}
- const ccwerrboundA = (3 + 16 * epsilon$1) * epsilon$1;
- const ccwerrboundB = (2 + 12 * epsilon$1) * epsilon$1;
- const ccwerrboundC = (9 + 64 * epsilon$1) * epsilon$1 * epsilon$1;
+ var ccwerrboundA = (3 + 16 * epsilon$1) * epsilon$1;
+ var ccwerrboundB = (2 + 12 * epsilon$1) * epsilon$1;
+ var ccwerrboundC = (9 + 64 * epsilon$1) * epsilon$1 * epsilon$1;
- const B = vec(4);
- const C1 = vec(8);
- const C2 = vec(12);
- const D = vec(16);
- const u = vec(4);
+ var B = vec(4);
+ var C1 = vec(8);
+ var C2 = vec(12);
+ var D = vec(16);
+ var u = vec(4);
function orient2dadapt(ax, ay, bx, by, cx, cy, detsum) {
- let acxtail, acytail, bcxtail, bcytail;
- let bvirt, c, ahi, alo, bhi, blo, _i, _j, _0, s1, s0, t1, t0, u3;
+ var acxtail, acytail, bcxtail, bcytail;
+ var bvirt, c, ahi, alo, bhi, blo, _i, _j, _0, s1, s0, t1, t0, u3;
- const acx = ax - cx;
- const bcx = bx - cx;
- const acy = ay - cy;
- const bcy = by - cy;
+ var acx = ax - cx;
+ var bcx = bx - cx;
+ var acy = ay - cy;
+ var bcy = by - cy;
s1 = acx * bcy;
c = splitter * acx;
B[2] = _j - (u3 - bvirt) + (_i - bvirt);
B[3] = u3;
- let det = estimate(4, B);
- let errbound = ccwerrboundB * detsum;
+ var det = estimate(4, B);
+ var errbound = ccwerrboundB * detsum;
if (det >= errbound || -det >= errbound) {
return det;
}
errbound = ccwerrboundC * detsum + resulterrbound * Math.abs(det);
det += (acx * bcytail + bcy * acxtail) - (acy * bcxtail + bcx * acytail);
- if (det >= errbound || -det >= errbound) return det;
+ if (det >= errbound || -det >= errbound) { return det; }
s1 = acxtail * bcy;
c = splitter * acxtail;
bvirt = u3 - _j;
u[2] = _j - (u3 - bvirt) + (_i - bvirt);
u[3] = u3;
- const C1len = sum$1(4, B, 4, u, C1);
+ var C1len = sum$1(4, B, 4, u, C1);
s1 = acx * bcytail;
c = splitter * acx;
bvirt = u3 - _j;
u[2] = _j - (u3 - bvirt) + (_i - bvirt);
u[3] = u3;
- const C2len = sum$1(C1len, C1, 4, u, C2);
+ var C2len = sum$1(C1len, C1, 4, u, C2);
s1 = acxtail * bcytail;
c = splitter * acxtail;
bvirt = u3 - _j;
u[2] = _j - (u3 - bvirt) + (_i - bvirt);
u[3] = u3;
- const Dlen = sum$1(C2len, C2, 4, u, D);
+ var Dlen = sum$1(C2len, C2, 4, u, D);
return D[Dlen - 1];
}
function orient2d(ax, ay, bx, by, cx, cy) {
- const detleft = (ay - cy) * (bx - cx);
- const detright = (ax - cx) * (by - cy);
- const det = detleft - detright;
+ var detleft = (ay - cy) * (bx - cx);
+ var detright = (ax - cx) * (by - cy);
+ var det = detleft - detright;
- if (detleft === 0 || detright === 0 || (detleft > 0) !== (detright > 0)) return det;
+ if (detleft === 0 || detright === 0 || (detleft > 0) !== (detright > 0)) { return det; }
- const detsum = Math.abs(detleft + detright);
- if (Math.abs(det) >= ccwerrboundA * detsum) return det;
+ var detsum = Math.abs(detleft + detright);
+ if (Math.abs(det) >= ccwerrboundA * detsum) { return det; }
return -orient2dadapt(ax, ay, bx, by, cx, cy, detsum);
}
* @return {Number}
*/
function signedArea(p0, p1, p2) {
- const res = orient2d(p0[0], p0[1], p1[0], p1[1], p2[0], p2[1]);
- if (res > 0) return -1;
- if (res < 0) return 1;
+ var res = orient2d(p0[0], p0[1], p1[0], p1[1], p2[0], p2[1]);
+ if (res > 0) { return -1; }
+ if (res < 0) { return 1; }
return 0;
}
* @return {Number}
*/
function compareEvents(e1, e2) {
- const p1 = e1.point;
- const p2 = e2.point;
+ var p1 = e1.point;
+ var p2 = e2.point;
// Different x-coordinate
- if (p1[0] > p2[0]) return 1;
- if (p1[0] < p2[0]) return -1;
+ if (p1[0] > p2[0]) { return 1; }
+ if (p1[0] < p2[0]) { return -1; }
// Different points, but same x-coordinate
// Event with lower y-coordinate is processed first
- if (p1[1] !== p2[1]) return p1[1] > p2[1] ? 1 : -1;
+ if (p1[1] !== p2[1]) { return p1[1] > p2[1] ? 1 : -1; }
return specialCases(e1, e2, p1);
}
// Same coordinates, but one is a left endpoint and the other is
// a right endpoint. The right endpoint is processed first
if (e1.left !== e2.left)
- return e1.left ? 1 : -1;
+ { return e1.left ? 1 : -1; }
// const p2 = e1.otherEvent.point, p3 = e2.otherEvent.point;
// const sa = (p1[0] - p3[0]) * (p2[1] - p3[1]) - (p2[0] - p3[0]) * (p1[1] - p3[1])
* @return {Queue}
*/
function divideSegment(se, p, queue) {
- const r = new SweepEvent(p, false, se, se.isSubject);
- const l = new SweepEvent(p, true, se.otherEvent, se.isSubject);
+ var r = new SweepEvent(p, false, se, se.isSubject);
+ var l = new SweepEvent(p, true, se.otherEvent, se.isSubject);
/* eslint-disable no-console */
if (equals(se.point, se.otherEvent.point)) {
// vector, then, could be thought of as the distance (in x and y components)
// from the first point to the second point.
// So first, let's make our vectors:
- const va = [a2[0] - a1[0], a2[1] - a1[1]];
- const vb = [b2[0] - b1[0], b2[1] - b1[1]];
+ var va = [a2[0] - a1[0], a2[1] - a1[1]];
+ var vb = [b2[0] - b1[0], b2[1] - b1[1]];
// We also define a function to convert back to regular point form:
/* eslint-disable arrow-body-style */
/* eslint-enable arrow-body-style */
// The rest is pretty much a straight port of the algorithm.
- const e = [b1[0] - a1[0], b1[1] - a1[1]];
- let kross = crossProduct(va, vb);
- let sqrKross = kross * kross;
- const sqrLenA = dotProduct(va, va);
+ var e = [b1[0] - a1[0], b1[1] - a1[1]];
+ var kross = crossProduct(va, vb);
+ var sqrKross = kross * kross;
+ var sqrLenA = dotProduct(va, va);
//const sqrLenB = dotProduct(vb, vb);
// Check for line intersection. This works because of the properties of the
// If they're not parallel, then (because these are line segments) they
// still might not actually intersect. This code checks that the
// intersection point of the lines is actually on both line segments.
- const s = crossProduct(e, vb) / kross;
+ var s = crossProduct(e, vb) / kross;
if (s < 0 || s > 1) {
// not on line segment a
return null;
}
- const t = crossProduct(e, va) / kross;
+ var t = crossProduct(e, va) / kross;
if (t < 0 || t > 1) {
// not on line segment b
return null;
return null;
}
- const sa = dotProduct(va, e) / sqrLenA;
- const sb = sa + dotProduct(va, vb) / sqrLenA;
- const smin = Math.min(sa, sb);
- const smax = Math.max(sa, sb);
+ var sa = dotProduct(va, e) / sqrLenA;
+ var sb = sa + dotProduct(va, vb) / sqrLenA;
+ var smin = Math.min(sa, sb);
+ var smax = Math.max(sa, sb);
// this is, essentially, the FindIntersection acting on floats from
// Schneider & Eberly, just inlined into this function.
return noEndpointTouch ? null : [toPoint(a1, smax < 1 ? smax : 1, va)];
}
- if (noEndpointTouch && smin === 0 && smax === 1) return null;
+ if (noEndpointTouch && smin === 0 && smax === 1) { return null; }
// There's overlap on a segment -- two points of intersection. Return both.
return [
// did cost us half a day, so I'll leave it
// out of respect
// if (se1.isSubject === se2.isSubject) return;
- const inter = intersection(
+ var inter = intersection(
se1.point, se1.otherEvent.point,
se2.point, se2.otherEvent.point
);
- const nintersections = inter ? inter.length : 0;
- if (nintersections === 0) return 0; // no intersection
+ var nintersections = inter ? inter.length : 0;
+ if (nintersections === 0) { return 0; } // no intersection
// the line segments intersect at an endpoint of both line segments
if ((nintersections === 1) &&
}
// The line segments associated to se1 and se2 overlap
- const events = [];
- let leftCoincide = false;
- let rightCoincide = false;
+ var events = [];
+ var leftCoincide = false;
+ var rightCoincide = false;
if (equals(se1.point, se2.point)) {
leftCoincide = true; // linked
* @return {Number}
*/
function compareSegments(le1, le2) {
- if (le1 === le2) return 0;
+ if (le1 === le2) { return 0; }
// Segments are not collinear
if (signedArea(le1.point, le1.otherEvent.point, le2.point) !== 0 ||
signedArea(le1.point, le1.otherEvent.point, le2.otherEvent.point) !== 0) {
// If they share their left endpoint use the right endpoint to sort
- if (equals(le1.point, le2.point)) return le1.isBelow(le2.otherEvent.point) ? -1 : 1;
+ if (equals(le1.point, le2.point)) { return le1.isBelow(le2.otherEvent.point) ? -1 : 1; }
// Different left endpoint: use the left endpoint to sort
- if (le1.point[0] === le2.point[0]) return le1.point[1] < le2.point[1] ? -1 : 1;
+ if (le1.point[0] === le2.point[0]) { return le1.point[1] < le2.point[1] ? -1 : 1; }
// has the line segment associated to e1 been inserted
// into S after the line segment associated to e2 ?
- if (compareEvents(le1, le2) === 1) return le2.isAbove(le1.point) ? -1 : 1;
+ if (compareEvents(le1, le2) === 1) { return le2.isAbove(le1.point) ? -1 : 1; }
// The line segment associated to e2 has been inserted
// into S after the line segment associated to e1
}
if (le1.isSubject === le2.isSubject) { // same polygon
- let p1 = le1.point, p2 = le2.point;
+ var p1 = le1.point, p2 = le2.point;
if (p1[0] === p2[0] && p1[1] === p2[1]/*equals(le1.point, le2.point)*/) {
p1 = le1.otherEvent.point; p2 = le2.otherEvent.point;
- if (p1[0] === p2[0] && p1[1] === p2[1]) return 0;
- else return le1.contourId > le2.contourId ? 1 : -1;
+ if (p1[0] === p2[0] && p1[1] === p2[1]) { return 0; }
+ else { return le1.contourId > le2.contourId ? 1 : -1; }
}
} else { // Segments are collinear, but belong to separate polygons
return le1.isSubject ? -1 : 1;
}
function subdivide(eventQueue, subject, clipping, sbbox, cbbox, operation) {
- const sweepLine = new SplayTree(compareSegments);
- const sortedEvents = [];
+ var sweepLine = new SplayTree(compareSegments);
+ var sortedEvents = [];
- const rightbound = Math.min(sbbox[2], cbbox[2]);
+ var rightbound = Math.min(sbbox[2], cbbox[2]);
- let prev, next, begin;
+ var prev, next, begin;
while (eventQueue.length !== 0) {
- let event = eventQueue.pop();
+ var event = eventQueue.pop();
sortedEvents.push(event);
// optimization by bboxes for intersection and difference goes here
next = prev = sweepLine.insert(event);
begin = sweepLine.minNode();
- if (prev !== begin) prev = sweepLine.prev(prev);
- else prev = null;
+ if (prev !== begin) { prev = sweepLine.prev(prev); }
+ else { prev = null; }
next = sweepLine.next(next);
- const prevEvent = prev ? prev.key : null;
- let prevprevEvent;
+ var prevEvent = prev ? prev.key : null;
+ var prevprevEvent = (void 0);
computeFields(event, prevEvent, operation);
if (next) {
if (possibleIntersection(event, next.key, eventQueue) === 2) {
if (prev) {
if (possibleIntersection(prev.key, event, eventQueue) === 2) {
- let prevprev = prev;
- if (prevprev !== begin) prevprev = sweepLine.prev(prevprev);
- else prevprev = null;
+ var prevprev = prev;
+ if (prevprev !== begin) { prevprev = sweepLine.prev(prevprev); }
+ else { prevprev = null; }
prevprevEvent = prevprev ? prevprev.key : null;
computeFields(prevEvent, prevprevEvent, operation);
if (prev && next) {
- if (prev !== begin) prev = sweepLine.prev(prev);
- else prev = null;
+ if (prev !== begin) { prev = sweepLine.prev(prev); }
+ else { prev = null; }
next = sweepLine.next(next);
sweepLine.remove(event);
return sortedEvents;
}
- class Contour {
-
- /**
- * Contour
- *
- * @class {Contour}
- */
- constructor() {
- this.points = [];
- this.holeIds = [];
- this.holeOf = null;
- this.depth = null;
- }
-
- isExterior() {
- return this.holeOf == null;
- }
+ var Contour = function Contour() {
+ this.points = [];
+ this.holeIds = [];
+ this.holeOf = null;
+ this.depth = null;
+ };
- }
+ Contour.prototype.isExterior = function isExterior () {
+ return this.holeOf == null;
+ };
/**
* @param {Array.<SweepEvent>} sortedEvents
* @return {Array.<SweepEvent>}
*/
function orderEvents(sortedEvents) {
- let event, i, len, tmp;
- const resultEvents = [];
+ var event, i, len, tmp;
+ var resultEvents = [];
for (i = 0, len = sortedEvents.length; i < len; i++) {
event = sortedEvents[i];
if ((event.left && event.inResult) ||
}
}
// Due to overlapping edges the resultEvents array can be not wholly sorted
- let sorted = false;
+ var sorted = false;
while (!sorted) {
sorted = true;
for (i = 0, len = resultEvents.length; i < len; i++) {
* @return {Number}
*/
function nextPos(pos, resultEvents, processed, origPos) {
- let newPos = pos + 1,
+ var newPos = pos + 1,
p = resultEvents[pos].point,
p1;
- const length = resultEvents.length;
+ var length = resultEvents.length;
if (newPos < length)
- p1 = resultEvents[newPos].point;
+ { p1 = resultEvents[newPos].point; }
while (newPos < length && p1[0] === p[0] && p1[1] === p[1]) {
if (!processed[newPos]) {
function initializeContourFromContext(event, contours, contourId) {
- const contour = new Contour();
+ var contour = new Contour();
if (event.prevInResult != null) {
- const prevInResult = event.prevInResult;
+ var prevInResult = event.prevInResult;
// Note that it is valid to query the "previous in result" for its output contour id,
// because we must have already processed it (i.e., assigned an output contour id)
// in an earlier iteration, otherwise it wouldn't be possible that it is "previous in
// result".
- const lowerContourId = prevInResult.outputContourId;
- const lowerResultTransition = prevInResult.resultTransition;
+ var lowerContourId = prevInResult.outputContourId;
+ var lowerResultTransition = prevInResult.resultTransition;
if (lowerResultTransition > 0) {
// We are inside. Now we have to check if the thing below us is another hole or
// an exterior contour.
- const lowerContour = contours[lowerContourId];
+ var lowerContour = contours[lowerContourId];
if (lowerContour.holeOf != null) {
// The lower contour is a hole => Connect the new contour as a hole to its parent,
// and use same depth.
- const parentContourId = lowerContour.holeOf;
+ var parentContourId = lowerContour.holeOf;
contours[parentContourId].holeIds.push(contourId);
contour.holeOf = parentContourId;
contour.depth = contours[lowerContourId].depth;
* @return {Array.<*>} polygons
*/
function connectEdges(sortedEvents) {
- let i, len;
- const resultEvents = orderEvents(sortedEvents);
+ var i, len;
+ var resultEvents = orderEvents(sortedEvents);
// "false"-filled array
- const processed = {};
- const contours = [];
+ var processed = {};
+ var contours = [];
- for (i = 0, len = resultEvents.length; i < len; i++) {
+ var loop = function ( ) {
if (processed[i]) {
- continue;
+ return;
}
- const contourId = contours.length;
- const contour = initializeContourFromContext(resultEvents[i], contours, contourId);
+ var contourId = contours.length;
+ var contour = initializeContourFromContext(resultEvents[i], contours, contourId);
// Helper function that combines marking an event as processed with assigning its output contour ID
- const markAsProcessed = (pos) => {
+ var markAsProcessed = function (pos) {
processed[pos] = true;
resultEvents[pos].outputContourId = contourId;
};
- let pos = i;
- let origPos = i;
+ var pos = i;
+ var origPos = i;
- const initial = resultEvents[i].point;
+ var initial = resultEvents[i].point;
contour.points.push(initial);
/* eslint no-constant-condition: "off" */
}
contours.push(contour);
- }
+ };
+
+ for (i = 0, len = resultEvents.length; i < len; i++) loop( );
return contours;
}
var _default$1 = TinyQueue;
function TinyQueue(data, compare) {
- if (!(this instanceof TinyQueue)) return new TinyQueue(data, compare);
+ if (!(this instanceof TinyQueue)) { return new TinyQueue(data, compare); }
this.data = data || [];
this.length = this.data.length;
this.compare = compare || defaultCompare$1;
if (this.length > 0) {
- for (var i = (this.length >> 1) - 1; i >= 0; i--) this._down(i);
+ for (var i = (this.length >> 1) - 1; i >= 0; i--) { this._down(i); }
}
}
},
pop: function () {
- if (this.length === 0) return undefined;
+ if (this.length === 0) { return undefined; }
var top = this.data[0];
this.length--;
while (pos > 0) {
var parent = (pos - 1) >> 1;
var current = data[parent];
- if (compare(item, current) >= 0) break;
+ if (compare(item, current) >= 0) { break; }
data[pos] = current;
pos = parent;
}
left = right;
best = data[right];
}
- if (compare(best, item) >= 0) break;
+ if (compare(best, item) >= 0) { break; }
data[pos] = best;
pos = left;
};
tinyqueue.default = _default$1;
- const max$2 = Math.max;
- const min = Math.min;
+ var max$2 = Math.max;
+ var min = Math.min;
- let contourId = 0;
+ var contourId = 0;
function processPolygon(contourOrHole, isSubject, depth, Q, bbox, isExteriorRing) {
- let i, len, s1, s2, e1, e2;
+ var i, len, s1, s2, e1, e2;
for (i = 0, len = contourOrHole.length - 1; i < len; i++) {
s1 = contourOrHole[i];
s2 = contourOrHole[i + 1];
e1.left = true;
}
- const x = s1[0], y = s1[1];
+ var x = s1[0], y = s1[1];
bbox[0] = min(bbox[0], x);
bbox[1] = min(bbox[1], y);
bbox[2] = max$2(bbox[2], x);
function fillQueue(subject, clipping, sbbox, cbbox, operation) {
- const eventQueue = new tinyqueue(null, compareEvents);
- let polygonSet, isExteriorRing, i, ii, j, jj; //, k, kk;
+ var eventQueue = new tinyqueue(null, compareEvents);
+ var polygonSet, isExteriorRing, i, ii, j, jj; //, k, kk;
for (i = 0, ii = subject.length; i < ii; i++) {
polygonSet = subject[i];
for (j = 0, jj = polygonSet.length; j < jj; j++) {
isExteriorRing = j === 0;
- if (isExteriorRing) contourId++;
+ if (isExteriorRing) { contourId++; }
processPolygon(polygonSet[j], true, contourId, eventQueue, sbbox, isExteriorRing);
}
}
polygonSet = clipping[i];
for (j = 0, jj = polygonSet.length; j < jj; j++) {
isExteriorRing = j === 0;
- if (operation === DIFFERENCE) isExteriorRing = false;
- if (isExteriorRing) contourId++;
+ if (operation === DIFFERENCE) { isExteriorRing = false; }
+ if (isExteriorRing) { contourId++; }
processPolygon(polygonSet[j], false, contourId, eventQueue, cbbox, isExteriorRing);
}
}
return eventQueue;
}
- const EMPTY = [];
+ var EMPTY = [];
function trivialOperation(subject, clipping, operation) {
- let result = null;
+ var result = null;
if (subject.length * clipping.length === 0) {
if (operation === INTERSECTION) {
result = EMPTY;
function compareBBoxes(subject, clipping, sbbox, cbbox, operation) {
- let result = null;
+ var result = null;
if (sbbox[0] > cbbox[2] ||
cbbox[0] > sbbox[2] ||
sbbox[1] > cbbox[3] ||
if (typeof clipping[0][0][0] === 'number') {
clipping = [clipping];
}
- let trivial = trivialOperation(subject, clipping, operation);
+ var trivial = trivialOperation(subject, clipping, operation);
if (trivial) {
return trivial === EMPTY ? null : trivial;
}
- const sbbox = [Infinity, Infinity, -Infinity, -Infinity];
- const cbbox = [Infinity, Infinity, -Infinity, -Infinity];
+ var sbbox = [Infinity, Infinity, -Infinity, -Infinity];
+ var cbbox = [Infinity, Infinity, -Infinity, -Infinity];
// console.time('fill queue');
- const eventQueue = fillQueue(subject, clipping, sbbox, cbbox, operation);
+ var eventQueue = fillQueue(subject, clipping, sbbox, cbbox, operation);
//console.timeEnd('fill queue');
trivial = compareBBoxes(subject, clipping, sbbox, cbbox, operation);
return trivial === EMPTY ? null : trivial;
}
// console.time('subdivide edges');
- const sortedEvents = subdivide(eventQueue, subject, clipping, sbbox, cbbox, operation);
+ var sortedEvents = subdivide(eventQueue, subject, clipping, sbbox, cbbox, operation);
//console.timeEnd('subdivide edges');
// console.time('connect vertices');
- const contours = connectEdges(sortedEvents);
+ var contours = connectEdges(sortedEvents);
//console.timeEnd('connect vertices');
// Convert contours to polygons
- const polygons = [];
- for (let i = 0; i < contours.length; i++) {
- let contour = contours[i];
+ var polygons = [];
+ for (var i = 0; i < contours.length; i++) {
+ var contour = contours[i];
if (contour.isExterior()) {
// The exterior ring goes first
- let rings = [contour.points];
+ var rings = [contour.points];
// Followed by holes if any
- for (let j = 0; j < contour.holeIds.length; j++) {
- let holeId = contour.holeIds[j];
+ for (var j = 0; j < contour.holeIds.length; j++) {
+ var holeId = contour.holeIds[j];
rings.push(contours[holeId].points);
}
polygons.push(rings);
this.type = val & 0x7;
readField(tag, result, this);
- if (this.pos === startPos) this.skip(val);
+ if (this.pos === startPos) { this.skip(val); }
}
return result;
},
var buf = this.buf,
val, b;
- b = buf[this.pos++]; val = b & 0x7f; if (b < 0x80) return val;
- b = buf[this.pos++]; val |= (b & 0x7f) << 7; if (b < 0x80) return val;
- b = buf[this.pos++]; val |= (b & 0x7f) << 14; if (b < 0x80) return val;
- b = buf[this.pos++]; val |= (b & 0x7f) << 21; if (b < 0x80) return val;
+ b = buf[this.pos++]; val = b & 0x7f; if (b < 0x80) { return val; }
+ b = buf[this.pos++]; val |= (b & 0x7f) << 7; if (b < 0x80) { return val; }
+ b = buf[this.pos++]; val |= (b & 0x7f) << 14; if (b < 0x80) { return val; }
+ b = buf[this.pos++]; val |= (b & 0x7f) << 21; if (b < 0x80) { return val; }
b = buf[this.pos]; val |= (b & 0x0f) << 28;
return readVarintRemainder(val, isSigned, this);
// verbose for performance reasons; doesn't affect gzipped size
readPackedVarint: function(arr, isSigned) {
- if (this.type !== Pbf.Bytes) return arr.push(this.readVarint(isSigned));
+ if (this.type !== Pbf.Bytes) { return arr.push(this.readVarint(isSigned)); }
var end = readPackedEnd(this);
arr = arr || [];
- while (this.pos < end) arr.push(this.readVarint(isSigned));
+ while (this.pos < end) { arr.push(this.readVarint(isSigned)); }
return arr;
},
readPackedSVarint: function(arr) {
- if (this.type !== Pbf.Bytes) return arr.push(this.readSVarint());
+ if (this.type !== Pbf.Bytes) { return arr.push(this.readSVarint()); }
var end = readPackedEnd(this);
arr = arr || [];
- while (this.pos < end) arr.push(this.readSVarint());
+ while (this.pos < end) { arr.push(this.readSVarint()); }
return arr;
},
readPackedBoolean: function(arr) {
- if (this.type !== Pbf.Bytes) return arr.push(this.readBoolean());
+ if (this.type !== Pbf.Bytes) { return arr.push(this.readBoolean()); }
var end = readPackedEnd(this);
arr = arr || [];
- while (this.pos < end) arr.push(this.readBoolean());
+ while (this.pos < end) { arr.push(this.readBoolean()); }
return arr;
},
readPackedFloat: function(arr) {
- if (this.type !== Pbf.Bytes) return arr.push(this.readFloat());
+ if (this.type !== Pbf.Bytes) { return arr.push(this.readFloat()); }
var end = readPackedEnd(this);
arr = arr || [];
- while (this.pos < end) arr.push(this.readFloat());
+ while (this.pos < end) { arr.push(this.readFloat()); }
return arr;
},
readPackedDouble: function(arr) {
- if (this.type !== Pbf.Bytes) return arr.push(this.readDouble());
+ if (this.type !== Pbf.Bytes) { return arr.push(this.readDouble()); }
var end = readPackedEnd(this);
arr = arr || [];
- while (this.pos < end) arr.push(this.readDouble());
+ while (this.pos < end) { arr.push(this.readDouble()); }
return arr;
},
readPackedFixed32: function(arr) {
- if (this.type !== Pbf.Bytes) return arr.push(this.readFixed32());
+ if (this.type !== Pbf.Bytes) { return arr.push(this.readFixed32()); }
var end = readPackedEnd(this);
arr = arr || [];
- while (this.pos < end) arr.push(this.readFixed32());
+ while (this.pos < end) { arr.push(this.readFixed32()); }
return arr;
},
readPackedSFixed32: function(arr) {
- if (this.type !== Pbf.Bytes) return arr.push(this.readSFixed32());
+ if (this.type !== Pbf.Bytes) { return arr.push(this.readSFixed32()); }
var end = readPackedEnd(this);
arr = arr || [];
- while (this.pos < end) arr.push(this.readSFixed32());
+ while (this.pos < end) { arr.push(this.readSFixed32()); }
return arr;
},
readPackedFixed64: function(arr) {
- if (this.type !== Pbf.Bytes) return arr.push(this.readFixed64());
+ if (this.type !== Pbf.Bytes) { return arr.push(this.readFixed64()); }
var end = readPackedEnd(this);
arr = arr || [];
- while (this.pos < end) arr.push(this.readFixed64());
+ while (this.pos < end) { arr.push(this.readFixed64()); }
return arr;
},
readPackedSFixed64: function(arr) {
- if (this.type !== Pbf.Bytes) return arr.push(this.readSFixed64());
+ if (this.type !== Pbf.Bytes) { return arr.push(this.readSFixed64()); }
var end = readPackedEnd(this);
arr = arr || [];
- while (this.pos < end) arr.push(this.readSFixed64());
+ while (this.pos < end) { arr.push(this.readSFixed64()); }
return arr;
},
skip: function(val) {
var type = val & 0x7;
- if (type === Pbf.Varint) while (this.buf[this.pos++] > 0x7f) {}
- else if (type === Pbf.Bytes) this.pos = this.readVarint() + this.pos;
- else if (type === Pbf.Fixed32) this.pos += 4;
- else if (type === Pbf.Fixed64) this.pos += 8;
- else throw new Error('Unimplemented type: ' + type);
+ if (type === Pbf.Varint) { while (this.buf[this.pos++] > 0x7f) {} }
+ else if (type === Pbf.Bytes) { this.pos = this.readVarint() + this.pos; }
+ else if (type === Pbf.Fixed32) { this.pos += 4; }
+ else if (type === Pbf.Fixed64) { this.pos += 8; }
+ else { throw new Error('Unimplemented type: ' + type); }
},
// === WRITING =================================================================
realloc: function(min) {
var length = this.length || 16;
- while (length < this.pos + min) length *= 2;
+ while (length < this.pos + min) { length *= 2; }
if (length !== this.length) {
var buf = new Uint8Array(length);
this.realloc(4);
- this.buf[this.pos++] = val & 0x7f | (val > 0x7f ? 0x80 : 0); if (val <= 0x7f) return;
- this.buf[this.pos++] = ((val >>>= 7) & 0x7f) | (val > 0x7f ? 0x80 : 0); if (val <= 0x7f) return;
- this.buf[this.pos++] = ((val >>>= 7) & 0x7f) | (val > 0x7f ? 0x80 : 0); if (val <= 0x7f) return;
+ this.buf[this.pos++] = val & 0x7f | (val > 0x7f ? 0x80 : 0); if (val <= 0x7f) { return; }
+ this.buf[this.pos++] = ((val >>>= 7) & 0x7f) | (val > 0x7f ? 0x80 : 0); if (val <= 0x7f) { return; }
+ this.buf[this.pos++] = ((val >>>= 7) & 0x7f) | (val > 0x7f ? 0x80 : 0); if (val <= 0x7f) { return; }
this.buf[this.pos++] = (val >>> 7) & 0x7f;
},
this.pos = writeUtf8(this.buf, str, this.pos);
var len = this.pos - startPos;
- if (len >= 0x80) makeRoomForExtraLength(startPos, len, this);
+ if (len >= 0x80) { makeRoomForExtraLength(startPos, len, this); }
// finally, write the message length in the reserved place and restore the position
this.pos = startPos - 1;
var len = buffer.length;
this.writeVarint(len);
this.realloc(len);
- for (var i = 0; i < len; i++) this.buf[this.pos++] = buffer[i];
+ for (var i = 0; i < len; i++) { this.buf[this.pos++] = buffer[i]; }
},
writeRawMessage: function(fn, obj) {
fn(obj, this);
var len = this.pos - startPos;
- if (len >= 0x80) makeRoomForExtraLength(startPos, len, this);
+ if (len >= 0x80) { makeRoomForExtraLength(startPos, len, this); }
// finally, write the message length in the reserved place and restore the position
this.pos = startPos - 1;
this.writeRawMessage(fn, obj);
},
- writePackedVarint: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedVarint, arr); },
- writePackedSVarint: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedSVarint, arr); },
- writePackedBoolean: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedBoolean, arr); },
- writePackedFloat: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedFloat, arr); },
- writePackedDouble: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedDouble, arr); },
- writePackedFixed32: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedFixed32, arr); },
- writePackedSFixed32: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedSFixed32, arr); },
- writePackedFixed64: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedFixed64, arr); },
- writePackedSFixed64: function(tag, arr) { if (arr.length) this.writeMessage(tag, writePackedSFixed64, arr); },
+ writePackedVarint: function(tag, arr) { if (arr.length) { this.writeMessage(tag, writePackedVarint, arr); } },
+ writePackedSVarint: function(tag, arr) { if (arr.length) { this.writeMessage(tag, writePackedSVarint, arr); } },
+ writePackedBoolean: function(tag, arr) { if (arr.length) { this.writeMessage(tag, writePackedBoolean, arr); } },
+ writePackedFloat: function(tag, arr) { if (arr.length) { this.writeMessage(tag, writePackedFloat, arr); } },
+ writePackedDouble: function(tag, arr) { if (arr.length) { this.writeMessage(tag, writePackedDouble, arr); } },
+ writePackedFixed32: function(tag, arr) { if (arr.length) { this.writeMessage(tag, writePackedFixed32, arr); } },
+ writePackedSFixed32: function(tag, arr) { if (arr.length) { this.writeMessage(tag, writePackedSFixed32, arr); } },
+ writePackedFixed64: function(tag, arr) { if (arr.length) { this.writeMessage(tag, writePackedFixed64, arr); } },
+ writePackedSFixed64: function(tag, arr) { if (arr.length) { this.writeMessage(tag, writePackedSFixed64, arr); } },
writeBytesField: function(tag, buffer) {
this.writeTag(tag, Pbf.Bytes);
var buf = p.buf,
h, b;
- b = buf[p.pos++]; h = (b & 0x70) >> 4; if (b < 0x80) return toNum(l, h, s);
- b = buf[p.pos++]; h |= (b & 0x7f) << 3; if (b < 0x80) return toNum(l, h, s);
- b = buf[p.pos++]; h |= (b & 0x7f) << 10; if (b < 0x80) return toNum(l, h, s);
- b = buf[p.pos++]; h |= (b & 0x7f) << 17; if (b < 0x80) return toNum(l, h, s);
- b = buf[p.pos++]; h |= (b & 0x7f) << 24; if (b < 0x80) return toNum(l, h, s);
- b = buf[p.pos++]; h |= (b & 0x01) << 31; if (b < 0x80) return toNum(l, h, s);
+ b = buf[p.pos++]; h = (b & 0x70) >> 4; if (b < 0x80) { return toNum(l, h, s); }
+ b = buf[p.pos++]; h |= (b & 0x7f) << 3; if (b < 0x80) { return toNum(l, h, s); }
+ b = buf[p.pos++]; h |= (b & 0x7f) << 10; if (b < 0x80) { return toNum(l, h, s); }
+ b = buf[p.pos++]; h |= (b & 0x7f) << 17; if (b < 0x80) { return toNum(l, h, s); }
+ b = buf[p.pos++]; h |= (b & 0x7f) << 24; if (b < 0x80) { return toNum(l, h, s); }
+ b = buf[p.pos++]; h |= (b & 0x01) << 31; if (b < 0x80) { return toNum(l, h, s); }
throw new Error('Expected varint not more than 10 bytes');
}
function writeBigVarintHigh(high, pbf) {
var lsb = (high & 0x07) << 4;
- pbf.buf[pbf.pos++] |= lsb | ((high >>>= 3) ? 0x80 : 0); if (!high) return;
- pbf.buf[pbf.pos++] = high & 0x7f | ((high >>>= 7) ? 0x80 : 0); if (!high) return;
- pbf.buf[pbf.pos++] = high & 0x7f | ((high >>>= 7) ? 0x80 : 0); if (!high) return;
- pbf.buf[pbf.pos++] = high & 0x7f | ((high >>>= 7) ? 0x80 : 0); if (!high) return;
- pbf.buf[pbf.pos++] = high & 0x7f | ((high >>>= 7) ? 0x80 : 0); if (!high) return;
+ pbf.buf[pbf.pos++] |= lsb | ((high >>>= 3) ? 0x80 : 0); if (!high) { return; }
+ pbf.buf[pbf.pos++] = high & 0x7f | ((high >>>= 7) ? 0x80 : 0); if (!high) { return; }
+ pbf.buf[pbf.pos++] = high & 0x7f | ((high >>>= 7) ? 0x80 : 0); if (!high) { return; }
+ pbf.buf[pbf.pos++] = high & 0x7f | ((high >>>= 7) ? 0x80 : 0); if (!high) { return; }
+ pbf.buf[pbf.pos++] = high & 0x7f | ((high >>>= 7) ? 0x80 : 0); if (!high) { return; }
pbf.buf[pbf.pos++] = high & 0x7f;
}
// if 1 byte isn't enough for encoding message length, shift the data to the right
pbf.realloc(extraLen);
- for (var i = pbf.pos - 1; i >= startPos; i--) pbf.buf[i + extraLen] = pbf.buf[i];
+ for (var i = pbf.pos - 1; i >= startPos; i--) { pbf.buf[i + extraLen] = pbf.buf[i]; }
}
- function writePackedVarint(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeVarint(arr[i]); }
- function writePackedSVarint(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeSVarint(arr[i]); }
- function writePackedFloat(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeFloat(arr[i]); }
- function writePackedDouble(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeDouble(arr[i]); }
- function writePackedBoolean(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeBoolean(arr[i]); }
- function writePackedFixed32(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeFixed32(arr[i]); }
- function writePackedSFixed32(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeSFixed32(arr[i]); }
- function writePackedFixed64(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeFixed64(arr[i]); }
- function writePackedSFixed64(arr, pbf) { for (var i = 0; i < arr.length; i++) pbf.writeSFixed64(arr[i]); }
+ function writePackedVarint(arr, pbf) { for (var i = 0; i < arr.length; i++) { pbf.writeVarint(arr[i]); } }
+ function writePackedSVarint(arr, pbf) { for (var i = 0; i < arr.length; i++) { pbf.writeSVarint(arr[i]); } }
+ function writePackedFloat(arr, pbf) { for (var i = 0; i < arr.length; i++) { pbf.writeFloat(arr[i]); } }
+ function writePackedDouble(arr, pbf) { for (var i = 0; i < arr.length; i++) { pbf.writeDouble(arr[i]); } }
+ function writePackedBoolean(arr, pbf) { for (var i = 0; i < arr.length; i++) { pbf.writeBoolean(arr[i]); } }
+ function writePackedFixed32(arr, pbf) { for (var i = 0; i < arr.length; i++) { pbf.writeFixed32(arr[i]); } }
+ function writePackedSFixed32(arr, pbf) { for (var i = 0; i < arr.length; i++) { pbf.writeSFixed32(arr[i]); } }
+ function writePackedFixed64(arr, pbf) { for (var i = 0; i < arr.length; i++) { pbf.writeFixed64(arr[i]); } }
+ function writePackedSFixed64(arr, pbf) { for (var i = 0; i < arr.length; i++) { pbf.writeSFixed64(arr[i]); } }
// Buffer code below from https://github.com/feross/buffer, MIT-licensed
b0 > 0xDF ? 3 :
b0 > 0xBF ? 2 : 1;
- if (i + bytesPerSequence > end) break;
+ if (i + bytesPerSequence > end) { break; }
var b1, b2, b3;
}
function readFeature(tag, feature, pbf) {
- if (tag == 1) feature.id = pbf.readVarint();
- else if (tag == 2) readTag(pbf, feature);
- else if (tag == 3) feature.type = pbf.readVarint();
- else if (tag == 4) feature._geometry = pbf.pos;
+ if (tag == 1) { feature.id = pbf.readVarint(); }
+ else if (tag == 2) { readTag(pbf, feature); }
+ else if (tag == 3) { feature.type = pbf.readVarint(); }
+ else if (tag == 4) { feature._geometry = pbf.pos; }
}
function readTag(pbf, feature) {
y += pbf.readSVarint();
if (cmd === 1) { // moveTo
- if (line) lines.push(line);
+ if (line) { lines.push(line); }
line = [];
}
}
}
- if (line) lines.push(line);
+ if (line) { lines.push(line); }
return lines;
};
if (cmd === 1 || cmd === 2) {
x += pbf.readSVarint();
y += pbf.readSVarint();
- if (x < x1) x1 = x;
- if (x > x2) x2 = x;
- if (y < y1) y1 = y;
- if (y > y2) y2 = y;
+ if (x < x1) { x1 = x; }
+ if (x > x2) { x2 = x; }
+ if (y < y1) { y1 = y; }
+ if (y > y2) { y2 = y; }
} else if (cmd !== 7) {
throw new Error('unknown command ' + cmd);
function classifyRings(rings) {
var len = rings.length;
- if (len <= 1) return [rings];
+ if (len <= 1) { return [rings]; }
var polygons = [],
polygon,
for (var i = 0; i < len; i++) {
var area = signedArea$1(rings[i]);
- if (area === 0) continue;
+ if (area === 0) { continue; }
- if (ccw === undefined) ccw = area < 0;
+ if (ccw === undefined) { ccw = area < 0; }
if (ccw === area < 0) {
- if (polygon) polygons.push(polygon);
+ if (polygon) { polygons.push(polygon); }
polygon = [rings[i]];
} else {
polygon.push(rings[i]);
}
}
- if (polygon) polygons.push(polygon);
+ if (polygon) { polygons.push(polygon); }
return polygons;
}
}
function readLayer(tag, layer, pbf) {
- if (tag === 15) layer.version = pbf.readVarint();
- else if (tag === 1) layer.name = pbf.readString();
- else if (tag === 5) layer.extent = pbf.readVarint();
- else if (tag === 2) layer._features.push(pbf.pos);
- else if (tag === 3) layer._keys.push(pbf.readString());
- else if (tag === 4) layer._values.push(readValueMessage(pbf));
+ if (tag === 15) { layer.version = pbf.readVarint(); }
+ else if (tag === 1) { layer.name = pbf.readString(); }
+ else if (tag === 5) { layer.extent = pbf.readVarint(); }
+ else if (tag === 2) { layer._features.push(pbf.pos); }
+ else if (tag === 3) { layer._keys.push(pbf.readString()); }
+ else if (tag === 4) { layer._values.push(readValueMessage(pbf)); }
}
function readValueMessage(pbf) {
// return feature `i` from this layer as a `VectorTileFeature`
VectorTileLayer.prototype.feature = function(i) {
- if (i < 0 || i >= this._features.length) throw new Error('feature index out of bounds');
+ if (i < 0 || i >= this._features.length) { throw new Error('feature index out of bounds'); }
this._pbf.pos = this._features[i];
function readTile(tag, layers, pbf) {
if (tag === 3) {
var layer = new vectortilelayer(pbf, pbf.readVarint() + pbf.pos);
- if (layer.length) layers[layer.name] = layer;
+ if (layer.length) { layers[layer.name] = layer; }
}
}
// Clip to tile bounds
if (geometry.type === 'MultiPolygon') {
var isClipped = false;
- var featureClip = bboxClip_1(feature, tile.extent.rectangle());
+ var featureClip = turf_bboxClip(feature, tile.extent.rectangle());
if (!fastDeepEqual(feature.geometry, featureClip.geometry)) {
// feature = featureClip;
isClipped = true;
}
- if (!feature.geometry.coordinates.length) continue; // not actually on this tile
- if (!feature.geometry.coordinates[0].length) continue; // not actually on this tile
+ if (!feature.geometry.coordinates.length) { continue; } // not actually on this tile
+ if (!feature.geometry.coordinates[0].length) { continue; } // not actually on this tile
}
// Generate some unique IDs and add some metadata
function loadTile(source, tile) {
- if (source.loaded[tile.id] || source.inflight[tile.id]) return;
+ if (source.loaded[tile.id] || source.inflight[tile.id]) { return; }
var url = source.template
.replace('{x}', tile.xyz[0])
data: function(sourceID, projection) {
var source = _vtCache[sourceID];
- if (!source) return [];
+ if (!source) { return []; }
var tiles = tiler$7.getTiles(projection);
var seen = {};
for (var i = 0; i < tiles.length; i++) {
var features = source.loaded[tiles[i].id];
- if (!features || !features.length) continue;
+ if (!features || !features.length) { continue; }
for (var j = 0; j < features.length; j++) {
var feature = features[j];
var hash = feature.__featurehash__;
- if (seen[hash]) continue;
+ if (seen[hash]) { continue; }
seen[hash] = true;
// return a shallow copy, because the hash may change
// Search for Wikidata items matching the query
itemsForSearchQuery: function(query, callback) {
if (!query) {
- if (callback) callback('No query', {});
+ if (callback) { callback('No query', {}); }
return;
}
type: 'item',
// the language to search
language: lang,
- // the langauge for the label and description in the result
+ // the language for the label and description in the result
uselang: lang,
limit: 10,
origin: '*'
if (result && result.error) {
throw new Error(result.error);
}
- if (callback) callback(null, result.search || {});
+ if (callback) { callback(null, result.search || {}); }
})
.catch(function(err) {
- if (callback) callback(err.message, {});
+ if (callback) { callback(err.message, {}); }
});
},
// return an array of corresponding Wikidata entities.
itemsByTitle: function(lang, title, callback) {
if (!title) {
- if (callback) callback('No title', {});
+ if (callback) { callback('No title', {}); }
return;
}
if (result && result.error) {
throw new Error(result.error);
}
- if (callback) callback(null, result.entities || {});
+ if (callback) { callback(null, result.entities || {}); }
})
.catch(function(err) {
- if (callback) callback(err.message, {});
+ if (callback) { callback(err.message, {}); }
});
},
var localeCode = _mainLocalizer.localeCode().toLowerCase();
// HACK: en-us isn't a wikidata language. We should really be filtering by
// the languages known to be supported by wikidata.
- if (localeCode === 'en-us') localeCode = 'en';
+ if (localeCode === 'en-us') { localeCode = 'en'; }
return utilArrayUniq([
localeCode,
_mainLocalizer.languageCode().toLowerCase(),
return;
}
if (_wikidataCache[qid]) {
- if (callback) callback(null, _wikidataCache[qid]);
+ if (callback) { callback(null, _wikidataCache[qid]); }
return;
}
if (result && result.error) {
throw new Error(result.error);
}
- if (callback) callback(null, result.entities[qid] || {});
+ if (callback) { callback(null, result.entities[qid] || {}); }
})
.catch(function(err) {
- if (callback) callback(err.message, {});
+ if (callback) { callback(err.message, {}); }
});
},
search: function(lang, query, callback) {
if (!query) {
- if (callback) callback('No Query', []);
+ if (callback) { callback('No Query', []); }
return;
}
}
})
.catch(function(err) {
- if (callback) callback(err, []);
+ if (callback) { callback(err, []); }
});
},
suggestions: function(lang, query, callback) {
if (!query) {
- if (callback) callback('', []);
+ if (callback) { callback('', []); }
return;
}
} else if (!result || result.length < 2) {
throw new Error('No Results');
}
- if (callback) callback(null, result[1] || []);
+ if (callback) { callback(null, result[1] || []); }
})
.catch(function(err) {
- if (callback) callback(err.message, []);
+ if (callback) { callback(err.message, []); }
});
},
translations: function(lang, title, callback) {
if (!title) {
- if (callback) callback('No Title');
+ if (callback) { callback('No Title'); }
return;
}
}
})
.catch(function(err) {
- if (callback) callback(err.message);
+ if (callback) { callback(err.message); }
});
}
function noteComments(selection) {
- if (_note.isNew()) return; // don't draw .comments-container
+ if (_note.isNew()) { return; } // don't draw .comments-container
var comments = selection.selectAll('.comments-container')
.data([0]);
mainEnter
.append('div')
.attr('class', 'comment-text')
- .html(function(d) { return d.html; });
+ .html(function(d) { return d.html; })
+ .selectAll('a')
+ .attr('rel', 'noopener nofollow')
+ .attr('target', '_blank');
comments
.call(replaceAvatars);
function replaceAvatars(selection) {
var showThirdPartyIcons = corePreferences('preferences.privacy.thirdpartyicons') || 'true';
var osm = services.osm;
- if (showThirdPartyIcons !== 'true' || !osm) return;
+ if (showThirdPartyIcons !== 'true' || !osm) { return; }
var uids = {}; // gather uids in the comment thread
_note.comments.forEach(function(d) {
- if (d.uid) uids[d.uid] = true;
+ if (d.uid) { uids[d.uid] = true; }
});
Object.keys(uids).forEach(function(uid) {
osm.loadUser(uid, function(err, user) {
- if (!user || !user.image_url) return;
+ if (!user || !user.image_url) { return; }
selection.selectAll('.comment-avatar.user-' + uid)
.html('')
function localeDateString(s) {
- if (!s) return null;
+ if (!s) { return null; }
var options = { day: 'numeric', month: 'short', year: 'numeric' };
s = s.replace(/-/g, '/'); // fix browser-specific Date() issues
var d = new Date(s);
- if (isNaN(d.getTime())) return null;
+ if (isNaN(d.getTime())) { return null; }
return d.toLocaleDateString(_mainLocalizer.localeCode(), options);
}
noteComments.note = function(val) {
- if (!arguments.length) return _note;
+ if (!arguments.length) { return _note; }
_note = val;
return noteComments;
};
noteHeader.note = function(val) {
- if (!arguments.length) return _note;
+ if (!arguments.length) { return _note; }
_note = val;
return noteHeader;
};
noteReport.note = function(val) {
- if (!arguments.length) return _note;
+ if (!arguments.length) { return _note; }
_note = val;
return noteReport;
};
viewOnOSM.what = function(_) {
- if (!arguments.length) return _what;
+ if (!arguments.length) { return _what; }
_what = _;
return viewOnOSM;
};
// fast submit if user presses cmd+enter
function keydown() {
- if (!(event.keyCode === 13 && event.metaKey)) return;
+ if (!(event.keyCode === 13 && event.metaKey)) { return; }
var osm = services.osm;
- if (!osm) return;
+ if (!osm) { return; }
var hasAuth = osm.authenticated();
- if (!hasAuth) return;
+ if (!hasAuth) { return; }
- if (!_note.newComment) return;
+ if (!_note.newComment) { return; }
event.preventDefault();
.merge(detailSection);
var osm = services.osm;
- if (!osm) return;
+ if (!osm) { return; }
// Add warning if user is not logged in
var hasAuth = osm.authenticated();
.merge(prose);
osm.userDetails(function(err, user) {
- if (err) return;
+ if (err) { return; }
var userLink = select(document.createElement('div'));
noteEditor.note = function(val) {
- if (!arguments.length) return _note;
+ if (!arguments.length) { return _note; }
_note = val;
return noteEditor;
};
noteEditor.newNote = function(val) {
- if (!arguments.length) return _newNote;
+ if (!arguments.length) { return _newNote; }
_newNote = val;
return noteEditor;
};
.on('change', function() {
context.map().pan([0,0]); // trigger a redraw
var note = checkSelectedID();
- if (!note) return;
+ if (!note) { return; }
context.ui().sidebar
.show(_noteEditor.note(note));
});
function checkSelectedID() {
- if (!services.osm) return;
+ if (!services.osm) { return; }
var note = services.osm.getNote(selectedNoteID);
if (!note) {
context.enter(modeBrowse(context));
// class the note as selected, or return to browse mode if the note is gone
function selectNote(drawn) {
- if (!checkSelectedID()) return;
+ if (!checkSelectedID()) { return; }
var selection = context.surface().selectAll('.layer-notes .note-' + selectedNoteID);
function esc() {
- if (context.container().select('.combobox').size()) return;
+ if (context.container().select('.combobox').size()) { return; }
context.enter(modeBrowse(context));
}
mode.zoomToSelected = function() {
- if (!services.osm) return;
+ if (!services.osm) { return; }
var note = services.osm.getNote(selectedNoteID);
if (note) {
context.map().centerZoomEase(note.loc, 20);
mode.newFeature = function(val) {
- if (!arguments.length) return _newFeature;
+ if (!arguments.length) { return _newFeature; }
_newFeature = val;
return mode;
};
mode.enter = function() {
var note = checkSelectedID();
- if (!note) return;
+ if (!note) { return; }
_behaviors.forEach(context.install);
function startNudge(nudge) {
- if (_nudgeInterval) window.clearInterval(_nudgeInterval);
+ if (_nudgeInterval) { window.clearInterval(_nudgeInterval); }
_nudgeInterval = window.setInterval(function() {
context.map().pan(nudge);
doMove(nudge);
dataHeader.datum = function(val) {
- if (!arguments.length) return _datum;
+ if (!arguments.length) { return _datum; }
_datum = val;
return this;
};
};
var combobox = function(input, attachTo) {
- if (!input || input.empty()) return;
+ if (!input || input.empty()) { return; }
input
.classed('combobox-input', true)
function mousedown() {
- if (event.button !== 0) return; // left click only
+ if (event.button !== 0) { return; } // left click only
_tDown = +new Date();
// clear selection
function mouseup() {
input.on('mouseup.combo-input', null);
- if (event.button !== 0) return; // left click only
- if (input.node() !== document.activeElement) return; // exit if this input is not focused
+ if (event.button !== 0) { return; } // left click only
+ if (input.node() !== document.activeElement) { return; } // exit if this input is not focused
var start = input.property('selectionStart');
var end = input.property('selectionEnd');
- if (start !== end) return; // exit if user is selecting
+ if (start !== end) { return; } // exit if user is selecting
// not showing or showing for a different field - try to show it.
var combo = container.selectAll('.combobox');
if (combo.empty() || combo.datum() !== input.node()) {
var tOrig = _tDown;
window.setTimeout(function() {
- if (tOrig !== _tDown) return; // exit if user double clicked
+ if (tOrig !== _tDown) { return; } // exit if user double clicked
fetchComboData('', function() {
show();
render();
break;
case 38: // ↑ Up arrow
- if (tagName === 'textarea' && !shown) return;
+ if (tagName === 'textarea' && !shown) { return; }
event.preventDefault();
if (tagName === 'input' && !shown) {
show();
break;
case 40: // ↓ Down arrow
- if (tagName === 'textarea' && !shown) return;
+ if (tagName === 'textarea' && !shown) { return; }
event.preventDefault();
if (tagName === 'input' && !shown) {
show();
function ensureVisible() {
var combo = container.selectAll('.combobox');
- if (combo.empty()) return;
+ if (combo.empty()) { return; }
var containerRect = container.node().getBoundingClientRect();
var comboRect = combo.node().getBoundingClientRect();
_fetcher.call(input, v, function(results) {
// already chose a value, don't overwrite or autocomplete it
- if (_cancelFetch) return;
+ if (_cancelFetch) { return; }
_suggestions = results;
results.forEach(function(d) { _fetched[d.value] = d; });
function tryAutocomplete() {
- if (!_canAutocomplete) return;
+ if (!_canAutocomplete) { return; }
var val = _caseSensitive ? value() : value().toLowerCase();
- if (!val) return;
+ if (!val) { return; }
// Don't autocomplete if user is typing a number - #4935
- if (!isNaN(parseFloat(val)) && isFinite(val)) return;
+ if (!isNaN(parseFloat(val)) && isFinite(val)) { return; }
var bestIndex = -1;
for (var i = 0; i < _suggestions.length; i++) {
}
var shown = !container.selectAll('.combobox').empty();
- if (!shown) return;
+ if (!shown) { return; }
var combo = container.selectAll('.combobox');
var options = combo.selectAll('.combobox-option')
combobox.canAutocomplete = function(val) {
- if (!arguments.length) return _canAutocomplete;
+ if (!arguments.length) { return _canAutocomplete; }
_canAutocomplete = val;
return combobox;
};
combobox.caseSensitive = function(val) {
- if (!arguments.length) return _caseSensitive;
+ if (!arguments.length) { return _caseSensitive; }
_caseSensitive = val;
return combobox;
};
combobox.data = function(val) {
- if (!arguments.length) return _data;
+ if (!arguments.length) { return _data; }
_data = val;
return combobox;
};
combobox.fetcher = function(val) {
- if (!arguments.length) return _fetcher;
+ if (!arguments.length) { return _fetcher; }
_fetcher = val;
return combobox;
};
combobox.minItems = function(val) {
- if (!arguments.length) return _minItems;
+ if (!arguments.length) { return _minItems; }
_minItems = val;
return combobox;
};
combobox.itemsMouseEnter = function(val) {
- if (!arguments.length) return _mouseEnterHandler;
+ if (!arguments.length) { return _mouseEnterHandler; }
_mouseEnterHandler = val;
return combobox;
};
combobox.itemsMouseLeave = function(val) {
- if (!arguments.length) return _mouseLeaveHandler;
+ if (!arguments.length) { return _mouseLeaveHandler; }
_mouseLeaveHandler = val;
return combobox;
};
select(this)
.classed('hide', !show)
.style('opacity', null);
- if (callback) callback.apply(this);
+ if (callback) { callback.apply(this); }
});
};
}
disclosure.title = function(val) {
- if (!arguments.length) return _title;
+ if (!arguments.length) { return _title; }
_title = utilFunctor(val);
return disclosure;
};
disclosure.expanded = function(val) {
- if (!arguments.length) return _expanded;
+ if (!arguments.length) { return _expanded; }
_expanded = val;
return disclosure;
};
disclosure.updatePreference = function(val) {
- if (!arguments.length) return _updatePreference;
+ if (!arguments.length) { return _updatePreference; }
_updatePreference = val;
return disclosure;
};
disclosure.content = function(val) {
- if (!arguments.length) return _content;
+ if (!arguments.length) { return _content; }
_content = val;
return disclosure;
};
};
section.classes = function(val) {
- if (!arguments.length) return _classes;
+ if (!arguments.length) { return _classes; }
_classes = utilFunctor(val);
return section;
};
section.title = function(val) {
- if (!arguments.length) return _title;
+ if (!arguments.length) { return _title; }
_title = utilFunctor(val);
return section;
};
section.expandedByDefault = function(val) {
- if (!arguments.length) return _expandedByDefault;
+ if (!arguments.length) { return _expandedByDefault; }
_expandedByDefault = utilFunctor(val);
return section;
};
section.shouldDisplay = function(val) {
- if (!arguments.length) return _shouldDisplay;
+ if (!arguments.length) { return _shouldDisplay; }
_shouldDisplay = utilFunctor(val);
return section;
};
section.content = function(val) {
- if (!arguments.length) return _content;
+ if (!arguments.length) { return _content; }
_content = val;
return section;
};
section.disclosureContent = function(val) {
- if (!arguments.length) return _disclosureContent;
+ if (!arguments.length) { return _disclosureContent; }
_disclosureContent = val;
return section;
};
section.disclosureExpanded = function(val) {
- if (!arguments.length) return _disclosureExpanded;
+ if (!arguments.length) { return _disclosureExpanded; }
_disclosureExpanded = val;
return section;
};
return section;
}
- // Pass `which` object of the form:
+ // Pass `what` object of the form:
// {
// key: 'string', // required
// value: 'string' // optional
// }
// -or-
// {
- // rtype: 'string' // relation type (e.g. 'multipolygon')
- // }
- // -or-
- // {
// qid: 'string' // brand wikidata (e.g. 'Q37158')
// }
//
function load() {
- if (!wikibase) return;
+ if (!wikibase) { return; }
_button
.classed('tag-reference-loading', true);
tagReference.body = function(selection) {
- var itemID = what.qid || what.rtype || (what.key + '-' + what.value);
+ var itemID = what.qid || (what.key + '-' + (what.value || ''));
_body = selection.selectAll('.tag-reference-body')
.data([itemID], function(d) { return d; });
tagReference.showing = function(val) {
- if (!arguments.length) return _showing;
+ if (!arguments.length) { return _showing; }
_showing = val;
return tagReference;
};
bindTypeahead(key, value);
}
- var reference;
-
- if (typeof d.value !== 'string') {
- reference = uiTagReference({ key: d.key });
- } else {
- var isRelation = _entityIDs && _entityIDs.some(function(entityID) {
- return context.entity(entityID).type === 'relation';
- });
- if (isRelation && d.key === 'type') {
- reference = uiTagReference({ rtype: d.value });
- } else {
- reference = uiTagReference({ key: d.key, value: d.value });
- }
+ var referenceOptions = { key: d.key };
+ if (typeof d.value === 'string') {
+ referenceOptions.value = d.value;
}
+ var reference = uiTagReference(referenceOptions);
if (_state === 'hover') {
reference.showing(false);
}
function setTextareaHeight() {
- if (_tagView !== 'text') return;
+ if (_tagView !== 'text') { return; }
var selection = select(this);
selection.style('height', null);
.filter(function(row) { return row.key && row.key.trim() !== ''; })
.map(function(row) {
var rawVal = row.value;
- if (typeof rawVal !== 'string') rawVal = '*';
+ if (typeof rawVal !== 'string') { rawVal = '*'; }
var val = rawVal ? stringify(rawVal) : '';
return stringify(row.key) + '=' + val;
})
});
var tagDiff = utilTagDiff(_tags, newTags);
- if (!tagDiff.length) return;
+ if (!tagDiff.length) { return; }
_pendingChange = _pendingChange || {};
tagDiff.forEach(function(change) {
- if (isReadOnly({ key: change.key })) return;
+ if (isReadOnly({ key: change.key })) { return; }
// skip unchanged multiselection placeholders
- if (change.newVal === '*' && typeof change.oldVal !== 'string') return;
+ if (change.newVal === '*' && typeof change.oldVal !== 'string') { return; }
if (change.type === '-') {
_pendingChange[change.key] = undefined;
}
function bindTypeahead(key, value) {
- if (isReadOnly(key.datum())) return;
+ if (isReadOnly(key.datum())) { return; }
if (Array.isArray(value.datum().value)) {
value.call(uiCombobox(context, 'tag-value')
.minItems(1)
.fetcher(function(value, callback) {
var keyString = utilGetSetValue(key);
- if (!_tags[keyString]) return;
+ if (!_tags[keyString]) { return; }
var data = _tags[keyString].filter(Boolean).map(function(tagValue) {
return {
value: tagValue,
geometry: geometry,
query: value
}, function(err, data) {
- if (!err) callback(sort(value, data));
+ if (!err) { callback(sort(value, data)); }
});
}));
}
function keyChange(d) {
- if (select(this).attr('readonly')) return;
+ if (select(this).attr('readonly')) { return; }
var kOld = d.key;
// exit if we are currently about to delete this row anyway - #6366
- if (_pendingChange && _pendingChange.hasOwnProperty(kOld) && _pendingChange[kOld] === undefined) return;
+ if (_pendingChange && _pendingChange.hasOwnProperty(kOld) && _pendingChange[kOld] === undefined) { return; }
var kNew = context.cleanTagKey(this.value.trim());
// update the ordered key index so this row doesn't change position
var existingKeyIndex = _orderedKeys.indexOf(kOld);
- if (existingKeyIndex !== -1) _orderedKeys[existingKeyIndex] = kNew;
+ if (existingKeyIndex !== -1) { _orderedKeys[existingKeyIndex] = kNew; }
d.key = kNew; // update datum to avoid exit/enter on tag update
d.value = vNew;
}
function valueChange(d) {
- if (isReadOnly(d)) return;
+ if (isReadOnly(d)) { return; }
// exit if this is a multiselection and no value was entered
- if (typeof d.value !== 'string' && !this.value) return;
+ if (typeof d.value !== 'string' && !this.value) { return; }
// exit if we are currently about to delete this row anyway - #6366
- if (_pendingChange && _pendingChange.hasOwnProperty(d.key) && _pendingChange[d.key] === undefined) return;
+ if (_pendingChange && _pendingChange.hasOwnProperty(d.key) && _pendingChange[d.key] === undefined) { return; }
_pendingChange = _pendingChange || {};
}
function removeTag(d) {
- if (isReadOnly(d)) return;
+ if (isReadOnly(d)) { return; }
if (d.key === '') { // removing the blank row
_showBlank = false;
// Delay change in case this change is blurring an edited combo. - #5878
window.setTimeout(function() {
- if (!_pendingChange) return;
+ if (!_pendingChange) { return; }
dispatch$1.call('change', this, entityIDs, _pendingChange);
_pendingChange = null;
section.state = function(val) {
- if (!arguments.length) return _state;
+ if (!arguments.length) { return _state; }
if (_state !== val) {
_orderedKeys = [];
_state = val;
section.presets = function(val) {
- if (!arguments.length) return _presets;
+ if (!arguments.length) { return _presets; }
_presets = val;
if (_presets && _presets.length && _presets[0].isFallback()) {
section.disclosureExpanded(true);
section.tags = function(val) {
- if (!arguments.length) return _tags;
+ if (!arguments.length) { return _tags; }
_tags = val;
return section;
};
section.entityIDs = function(val) {
- if (!arguments.length) return _entityIDs;
+ if (!arguments.length) { return _entityIDs; }
if (!_entityIDs || !val || !utilArrayIdentical(_entityIDs, val)) {
_entityIDs = val;
_orderedKeys = [];
// pass an array of regular expressions to test against the tag key
section.readOnlyTags = function(val) {
- if (!arguments.length) return _readOnlyTags;
+ if (!arguments.length) { return _readOnlyTags; }
_readOnlyTags = val;
return section;
};
dataEditor.datum = function(val) {
- if (!arguments.length) return _datum;
+ if (!arguments.length) { return _datum; }
_datum = val;
return this;
};
function esc() {
- if (context.container().select('.combobox').size()) return;
+ if (context.container().select('.combobox').size()) { return; }
context.enter(modeBrowse(context));
}
}
function uiImproveOsmComments() {
- let _qaItem;
+ var _qaItem;
function issueComments(selection) {
// make the div immediately so it appears above the buttons
- let comments = selection.selectAll('.comments-container')
+ var comments = selection.selectAll('.comments-container')
.data([0]);
comments = comments.enter()
// must retrieve comments from API before they can be displayed
services.improveOSM.getComments(_qaItem)
- .then(d => {
- if (!d.comments) return; // nothing to do here
+ .then(function (d) {
+ if (!d.comments) { return; } // nothing to do here
- const commentEnter = comments.selectAll('.comment')
+ var commentEnter = comments.selectAll('.comment')
.data(d.comments)
.enter()
.append('div')
.attr('class', 'comment-avatar')
.call(svgIcon('#iD-icon-avatar', 'comment-avatar-icon'));
- const mainEnter = commentEnter
+ var mainEnter = commentEnter
.append('div')
.attr('class', 'comment-main');
- const metadataEnter = mainEnter
+ var metadataEnter = mainEnter
.append('div')
.attr('class', 'comment-metadata');
.append('div')
.attr('class', 'comment-author')
.each(function(d) {
- const osm = services.osm;
- let selection = select(this);
+ var osm = services.osm;
+ var selection = select(this);
if (osm && d.username) {
selection = selection
.append('a')
.attr('target', '_blank');
}
selection
- .text(d => d.username);
+ .text(function (d) { return d.username; });
});
metadataEnter
.append('div')
.attr('class', 'comment-date')
- .text(d => _t('note.status.commented', { when: localeDateString(d.timestamp) }));
+ .text(function (d) { return _t('note.status.commented', { when: localeDateString(d.timestamp) }); });
mainEnter
.append('div')
.attr('class', 'comment-text')
.append('p')
- .text(d => d.text);
+ .text(function (d) { return d.text; });
})
- .catch(err => {
+ .catch(function (err) {
console.log(err); // eslint-disable-line no-console
});
}
function localeDateString(s) {
- if (!s) return null;
- const options = { day: 'numeric', month: 'short', year: 'numeric' };
- const d = new Date(s * 1000); // timestamp is served in seconds, date takes ms
- if (isNaN(d.getTime())) return null;
+ if (!s) { return null; }
+ var options = { day: 'numeric', month: 'short', year: 'numeric' };
+ var d = new Date(s * 1000); // timestamp is served in seconds, date takes ms
+ if (isNaN(d.getTime())) { return null; }
return d.toLocaleDateString(_mainLocalizer.localeCode(), options);
}
issueComments.issue = function(val) {
- if (!arguments.length) return _qaItem;
+ if (!arguments.length) { return _qaItem; }
_qaItem = val;
return issueComments;
};
}
function uiImproveOsmDetails(context) {
- let _qaItem;
+ var _qaItem;
function issueDetail(d) {
- if (d.desc) return d.desc;
- const issueKey = d.issueKey;
+ if (d.desc) { return d.desc; }
+ var issueKey = d.issueKey;
d.replacements = d.replacements || {};
d.replacements.default = _t('inspector.unknown'); // special key `default` works as a fallback string
- return _t(`QA.improveOSM.error_types.${issueKey}.description`, d.replacements);
+ return _t(("QA.improveOSM.error_types." + issueKey + ".description"), d.replacements);
}
function improveOsmDetails(selection) {
- const details = selection.selectAll('.error-details')
+ var details = selection.selectAll('.error-details')
.data(
(_qaItem ? [_qaItem] : []),
- d => `${d.id}-${d.status || 0}`
+ function (d) { return ((d.id) + "-" + (d.status || 0)); }
);
details.exit()
.remove();
- const detailsEnter = details.enter()
+ var detailsEnter = details.enter()
.append('div')
.attr('class', 'error-details qa-details-container');
// description
- const descriptionEnter = detailsEnter
+ var descriptionEnter = detailsEnter
.append('div')
.attr('class', 'qa-details-subsection');
descriptionEnter
.append('h4')
- .text(() => _t('QA.keepRight.detail_description'));
+ .text(function () { return _t('QA.keepRight.detail_description'); });
descriptionEnter
.append('div')
.html(issueDetail);
// If there are entity links in the error message..
- let relatedEntities = [];
+ var relatedEntities = [];
descriptionEnter.selectAll('.error_entity_link, .error_object_link')
.each(function() {
- const link = select(this);
- const isObjectLink = link.classed('error_object_link');
- const entityID = isObjectLink ?
+ var link = select(this);
+ var isObjectLink = link.classed('error_object_link');
+ var entityID = isObjectLink ?
(utilEntityRoot(_qaItem.objectType) + _qaItem.objectId)
: this.textContent;
- const entity = context.hasEntity(entityID);
+ var entity = context.hasEntity(entityID);
relatedEntities.push(entityID);
// Add click handler
link
- .on('mouseenter', () => {
+ .on('mouseenter', function () {
utilHighlightEntities([entityID], true, context);
})
- .on('mouseleave', () => {
+ .on('mouseleave', function () {
utilHighlightEntities([entityID], false, context);
})
- .on('click', () => {
+ .on('click', function () {
event.preventDefault();
utilHighlightEntities([entityID], false, context);
- const osmlayer = context.layers().layer('osm');
+ var osmlayer = context.layers().layer('osm');
if (!osmlayer.enabled()) {
osmlayer.enabled(true);
}
if (entity) {
context.enter(modeSelect(context, [entityID]));
} else {
- context.loadEntity(entityID, () => {
+ context.loadEntity(entityID, function () {
context.enter(modeSelect(context, [entityID]));
});
}
// Replace with friendly name if possible
// (The entity may not yet be loaded into the graph)
if (entity) {
- let name = utilDisplayName(entity); // try to use common name
+ var name = utilDisplayName(entity); // try to use common name
if (!name && !isObjectLink) {
- const preset = _mainPresetIndex.match(entity, context.graph());
+ var preset = _mainPresetIndex.match(entity, context.graph());
name = preset && !preset.isFallback() && preset.name(); // fallback to preset name
}
}
improveOsmDetails.issue = function(val) {
- if (!arguments.length) return _qaItem;
+ if (!arguments.length) { return _qaItem; }
_qaItem = val;
return improveOsmDetails;
};
}
function uiImproveOsmHeader() {
- let _qaItem;
+ var _qaItem;
function issueTitle(d) {
- const issueKey = d.issueKey;
+ var issueKey = d.issueKey;
d.replacements = d.replacements || {};
d.replacements.default = _t('inspector.unknown'); // special key `default` works as a fallback string
- return _t(`QA.improveOSM.error_types.${issueKey}.title`, d.replacements);
+ return _t(("QA.improveOSM.error_types." + issueKey + ".title"), d.replacements);
}
function improveOsmHeader(selection) {
- const header = selection.selectAll('.qa-header')
+ var header = selection.selectAll('.qa-header')
.data(
(_qaItem ? [_qaItem] : []),
- d => `${d.id}-${d.status || 0}`
+ function (d) { return ((d.id) + "-" + (d.status || 0)); }
);
header.exit()
.remove();
- const headerEnter = header.enter()
+ var headerEnter = header.enter()
.append('div')
.attr('class', 'qa-header');
- const svgEnter = headerEnter
+ var svgEnter = headerEnter
.append('div')
.attr('class', 'qa-header-icon')
- .classed('new', d => d.id < 0)
+ .classed('new', function (d) { return d.id < 0; })
.append('svg')
.attr('width', '20px')
.attr('height', '30px')
.attr('viewbox', '0 0 20 30')
- .attr('class', d => `preset-icon-28 qaItem ${d.service} itemId-${d.id} itemType-${d.itemType}`);
+ .attr('class', function (d) { return ("preset-icon-28 qaItem " + (d.service) + " itemId-" + (d.id) + " itemType-" + (d.itemType)); });
svgEnter
.append('polygon')
.attr('width', '13px')
.attr('height', '13px')
.attr('transform', 'translate(3.5, 5)')
- .attr('xlink:href', d => {
- const picon = d.icon;
+ .attr('xlink:href', function (d) {
+ var picon = d.icon;
if (!picon) {
return '';
} else {
- const isMaki = /^maki-/.test(picon);
- return `#${picon}${isMaki ? '-11' : ''}`;
+ var isMaki = /^maki-/.test(picon);
+ return ("#" + picon + (isMaki ? '-11' : ''));
}
});
}
improveOsmHeader.issue = function(val) {
- if (!arguments.length) return _qaItem;
+ if (!arguments.length) { return _qaItem; }
_qaItem = val;
return improveOsmHeader;
};
}
function uiImproveOsmEditor(context) {
- const dispatch$1 = dispatch('change');
- const qaDetails = uiImproveOsmDetails(context);
- const qaComments = uiImproveOsmComments();
- const qaHeader = uiImproveOsmHeader();
+ var dispatch$1 = dispatch('change');
+ var qaDetails = uiImproveOsmDetails(context);
+ var qaComments = uiImproveOsmComments();
+ var qaHeader = uiImproveOsmHeader();
- let _qaItem;
+ var _qaItem;
function improveOsmEditor(selection) {
- const headerEnter = selection.selectAll('.header')
+ var headerEnter = selection.selectAll('.header')
.data([0])
.enter()
.append('div')
headerEnter
.append('button')
.attr('class', 'close')
- .on('click', () => context.enter(modeBrowse(context)))
+ .on('click', function () { return context.enter(modeBrowse(context)); })
.call(svgIcon('#iD-icon-close'));
headerEnter
.append('h3')
.text(_t('QA.improveOSM.title'));
- let body = selection.selectAll('.body')
+ var body = selection.selectAll('.body')
.data([0]);
body = body.enter()
.attr('class', 'body')
.merge(body);
- const editor = body.selectAll('.qa-editor')
+ var editor = body.selectAll('.qa-editor')
.data([0]);
editor.enter()
}
function improveOsmSaveSection(selection) {
- const isSelected = (_qaItem && _qaItem.id === context.selectedErrorID());
- const isShown = (_qaItem && (isSelected || _qaItem.newComment || _qaItem.comment));
- let saveSection = selection.selectAll('.qa-save')
+ var isSelected = (_qaItem && _qaItem.id === context.selectedErrorID());
+ var isShown = (_qaItem && (isSelected || _qaItem.newComment || _qaItem.comment));
+ var saveSection = selection.selectAll('.qa-save')
.data(
(isShown ? [_qaItem] : []),
- d => `${d.id}-${d.status || 0}`
+ function (d) { return ((d.id) + "-" + (d.status || 0)); }
);
// exit
.remove();
// enter
- const saveSectionEnter = saveSection.enter()
+ var saveSectionEnter = saveSection.enter()
.append('div')
.attr('class', 'qa-save save-section cf');
.attr('class', 'new-comment-input')
.attr('placeholder', _t('QA.keepRight.comment_placeholder'))
.attr('maxlength', 1000)
- .property('value', d => d.newComment)
+ .property('value', function (d) { return d.newComment; })
.call(utilNoAuto)
.on('input', changeInput)
.on('blur', changeInput);
.call(qaSaveButtons);
function changeInput() {
- const input = select(this);
- let val = input.property('value').trim();
+ var input = select(this);
+ var val = input.property('value').trim();
if (val === '') {
val = undefined;
// store the unsaved comment with the issue itself
_qaItem = _qaItem.update({ newComment: val });
- const qaService = services.improveOSM;
+ var qaService = services.improveOSM;
if (qaService) {
qaService.replaceItem(_qaItem);
}
}
function qaSaveButtons(selection) {
- const isSelected = (_qaItem && _qaItem.id === context.selectedErrorID());
- let buttonSection = selection.selectAll('.buttons')
- .data((isSelected ? [_qaItem] : []), d => d.status + d.id);
+ var isSelected = (_qaItem && _qaItem.id === context.selectedErrorID());
+ var buttonSection = selection.selectAll('.buttons')
+ .data((isSelected ? [_qaItem] : []), function (d) { return d.status + d.id; });
// exit
buttonSection.exit()
.remove();
// enter
- const buttonEnter = buttonSection.enter()
+ var buttonEnter = buttonSection.enter()
.append('div')
.attr('class', 'buttons');
.merge(buttonEnter);
buttonSection.select('.comment-button')
- .attr('disabled', d => d.newComment ? null : true)
+ .attr('disabled', function (d) { return d.newComment ? null : true; })
.on('click.comment', function(d) {
this.blur(); // avoid keeping focus on the button - #4641
- const qaService = services.improveOSM;
+ var qaService = services.improveOSM;
if (qaService) {
- qaService.postUpdate(d, (err, item) => dispatch$1.call('change', item));
+ qaService.postUpdate(d, function (err, item) { return dispatch$1.call('change', item); });
}
});
buttonSection.select('.close-button')
- .text(d => {
- const andComment = (d.newComment ? '_comment' : '');
- return _t(`QA.keepRight.close${andComment}`);
+ .text(function (d) {
+ var andComment = (d.newComment ? '_comment' : '');
+ return _t(("QA.keepRight.close" + andComment));
})
.on('click.close', function(d) {
this.blur(); // avoid keeping focus on the button - #4641
- const qaService = services.improveOSM;
+ var qaService = services.improveOSM;
if (qaService) {
d.newStatus = 'SOLVED';
- qaService.postUpdate(d, (err, item) => dispatch$1.call('change', item));
+ qaService.postUpdate(d, function (err, item) { return dispatch$1.call('change', item); });
}
});
buttonSection.select('.ignore-button')
- .text(d => {
- const andComment = (d.newComment ? '_comment' : '');
- return _t(`QA.keepRight.ignore${andComment}`);
+ .text(function (d) {
+ var andComment = (d.newComment ? '_comment' : '');
+ return _t(("QA.keepRight.ignore" + andComment));
})
.on('click.ignore', function(d) {
this.blur(); // avoid keeping focus on the button - #4641
- const qaService = services.improveOSM;
+ var qaService = services.improveOSM;
if (qaService) {
d.newStatus = 'INVALID';
- qaService.postUpdate(d, (err, item) => dispatch$1.call('change', item));
+ qaService.postUpdate(d, function (err, item) { return dispatch$1.call('change', item); });
}
});
}
// NOTE: Don't change method name until UI v3 is merged
improveOsmEditor.error = function(val) {
- if (!arguments.length) return _qaItem;
+ if (!arguments.length) { return _qaItem; }
_qaItem = val;
return improveOsmEditor;
};
}
function uiKeepRightDetails(context) {
- let _qaItem;
+ var _qaItem;
function issueDetail(d) {
- const { itemType, parentIssueType } = d;
- const unknown = _t('inspector.unknown');
- let replacements = d.replacements || {};
+ var itemType = d.itemType;
+ var parentIssueType = d.parentIssueType;
+ var unknown = _t('inspector.unknown');
+ var replacements = d.replacements || {};
replacements.default = unknown; // special key `default` works as a fallback string
- let detail = _t(`QA.keepRight.errorTypes.${itemType}.description`, replacements);
+ var detail = _t(("QA.keepRight.errorTypes." + itemType + ".description"), replacements);
if (detail === unknown) {
- detail = _t(`QA.keepRight.errorTypes.${parentIssueType}.description`, replacements);
+ detail = _t(("QA.keepRight.errorTypes." + parentIssueType + ".description"), replacements);
}
return detail;
}
function keepRightDetails(selection) {
- const details = selection.selectAll('.error-details')
+ var details = selection.selectAll('.error-details')
.data(
(_qaItem ? [_qaItem] : []),
- d => `${d.id}-${d.status || 0}`
+ function (d) { return ((d.id) + "-" + (d.status || 0)); }
);
details.exit()
.remove();
- const detailsEnter = details.enter()
+ var detailsEnter = details.enter()
.append('div')
.attr('class', 'error-details qa-details-container');
// description
- const descriptionEnter = detailsEnter
+ var descriptionEnter = detailsEnter
.append('div')
.attr('class', 'qa-details-subsection');
descriptionEnter
.append('h4')
- .text(() => _t('QA.keepRight.detail_description'));
+ .text(function () { return _t('QA.keepRight.detail_description'); });
descriptionEnter
.append('div')
.html(issueDetail);
// If there are entity links in the error message..
- let relatedEntities = [];
+ var relatedEntities = [];
descriptionEnter.selectAll('.error_entity_link, .error_object_link')
.each(function() {
- const link = select(this);
- const isObjectLink = link.classed('error_object_link');
- const entityID = isObjectLink ?
+ var link = select(this);
+ var isObjectLink = link.classed('error_object_link');
+ var entityID = isObjectLink ?
(utilEntityRoot(_qaItem.objectType) + _qaItem.objectId)
: this.textContent;
- const entity = context.hasEntity(entityID);
+ var entity = context.hasEntity(entityID);
relatedEntities.push(entityID);
// Add click handler
link
- .on('mouseenter', () => {
+ .on('mouseenter', function () {
utilHighlightEntities([entityID], true, context);
})
- .on('mouseleave', () => {
+ .on('mouseleave', function () {
utilHighlightEntities([entityID], false, context);
})
- .on('click', () => {
+ .on('click', function () {
event.preventDefault();
utilHighlightEntities([entityID], false, context);
- const osmlayer = context.layers().layer('osm');
+ var osmlayer = context.layers().layer('osm');
if (!osmlayer.enabled()) {
osmlayer.enabled(true);
}
if (entity) {
context.enter(modeSelect(context, [entityID]));
} else {
- context.loadEntity(entityID, () => {
+ context.loadEntity(entityID, function () {
context.enter(modeSelect(context, [entityID]));
});
}
// Replace with friendly name if possible
// (The entity may not yet be loaded into the graph)
if (entity) {
- let name = utilDisplayName(entity); // try to use common name
+ var name = utilDisplayName(entity); // try to use common name
if (!name && !isObjectLink) {
- const preset = _mainPresetIndex.match(entity, context.graph());
+ var preset = _mainPresetIndex.match(entity, context.graph());
name = preset && !preset.isFallback() && preset.name(); // fallback to preset name
}
}
keepRightDetails.issue = function(val) {
- if (!arguments.length) return _qaItem;
+ if (!arguments.length) { return _qaItem; }
_qaItem = val;
return keepRightDetails;
};
}
function uiKeepRightHeader() {
- let _qaItem;
+ var _qaItem;
function issueTitle(d) {
- const { itemType, parentIssueType } = d;
- const unknown = _t('inspector.unknown');
- let replacements = d.replacements || {};
+ var itemType = d.itemType;
+ var parentIssueType = d.parentIssueType;
+ var unknown = _t('inspector.unknown');
+ var replacements = d.replacements || {};
replacements.default = unknown; // special key `default` works as a fallback string
- let title = _t(`QA.keepRight.errorTypes.${itemType}.title`, replacements);
+ var title = _t(("QA.keepRight.errorTypes." + itemType + ".title"), replacements);
if (title === unknown) {
- title = _t(`QA.keepRight.errorTypes.${parentIssueType}.title`, replacements);
+ title = _t(("QA.keepRight.errorTypes." + parentIssueType + ".title"), replacements);
}
return title;
}
function keepRightHeader(selection) {
- const header = selection.selectAll('.qa-header')
+ var header = selection.selectAll('.qa-header')
.data(
(_qaItem ? [_qaItem] : []),
- d => `${d.id}-${d.status || 0}`
+ function (d) { return ((d.id) + "-" + (d.status || 0)); }
);
header.exit()
.remove();
- const headerEnter = header.enter()
+ var headerEnter = header.enter()
.append('div')
.attr('class', 'qa-header');
- const iconEnter = headerEnter
+ var iconEnter = headerEnter
.append('div')
.attr('class', 'qa-header-icon')
- .classed('new', d => d.id < 0);
+ .classed('new', function (d) { return d.id < 0; });
iconEnter
.append('div')
- .attr('class', d => `preset-icon-28 qaItem ${d.service} itemId-${d.id} itemType-${d.parentIssueType}`)
+ .attr('class', function (d) { return ("preset-icon-28 qaItem " + (d.service) + " itemId-" + (d.id) + " itemType-" + (d.parentIssueType)); })
.call(svgIcon('#iD-icon-bolt', 'qaItem-fill'));
headerEnter
keepRightHeader.issue = function(val) {
- if (!arguments.length) return _qaItem;
+ if (!arguments.length) { return _qaItem; }
_qaItem = val;
return keepRightHeader;
};
}
function uiViewOnKeepRight() {
- let _qaItem;
+ var _qaItem;
function viewOnKeepRight(selection) {
- let url;
+ var url;
if (services.keepRight && (_qaItem instanceof QAItem)) {
url = services.keepRight.issueURL(_qaItem);
}
- const link = selection.selectAll('.view-on-keepRight')
+ var link = selection.selectAll('.view-on-keepRight')
.data(url ? [url] : []);
// exit
.remove();
// enter
- const linkEnter = link.enter()
+ var linkEnter = link.enter()
.append('a')
.attr('class', 'view-on-keepRight')
.attr('target', '_blank')
.attr('rel', 'noopener') // security measure
- .attr('href', d => d)
+ .attr('href', function (d) { return d; })
.call(svgIcon('#iD-icon-out-link', 'inline'));
linkEnter
}
viewOnKeepRight.what = function(val) {
- if (!arguments.length) return _qaItem;
+ if (!arguments.length) { return _qaItem; }
_qaItem = val;
return viewOnKeepRight;
};
}
function uiKeepRightEditor(context) {
- const dispatch$1 = dispatch('change');
- const qaDetails = uiKeepRightDetails(context);
- const qaHeader = uiKeepRightHeader();
+ var dispatch$1 = dispatch('change');
+ var qaDetails = uiKeepRightDetails(context);
+ var qaHeader = uiKeepRightHeader();
- let _qaItem;
+ var _qaItem;
function keepRightEditor(selection) {
- const headerEnter = selection.selectAll('.header')
+ var headerEnter = selection.selectAll('.header')
.data([0])
.enter()
.append('div')
headerEnter
.append('button')
.attr('class', 'close')
- .on('click', () => context.enter(modeBrowse(context)))
+ .on('click', function () { return context.enter(modeBrowse(context)); })
.call(svgIcon('#iD-icon-close'));
headerEnter
.text(_t('QA.keepRight.title'));
- let body = selection.selectAll('.body')
+ var body = selection.selectAll('.body')
.data([0]);
body = body.enter()
.attr('class', 'body')
.merge(body);
- const editor = body.selectAll('.qa-editor')
+ var editor = body.selectAll('.qa-editor')
.data([0]);
editor.enter()
.call(keepRightSaveSection);
- const footer = selection.selectAll('.footer')
+ var footer = selection.selectAll('.footer')
.data([0]);
footer.enter()
function keepRightSaveSection(selection) {
- const isSelected = (_qaItem && _qaItem.id === context.selectedErrorID());
- const isShown = (_qaItem && (isSelected || _qaItem.newComment || _qaItem.comment));
- let saveSection = selection.selectAll('.qa-save')
+ var isSelected = (_qaItem && _qaItem.id === context.selectedErrorID());
+ var isShown = (_qaItem && (isSelected || _qaItem.newComment || _qaItem.comment));
+ var saveSection = selection.selectAll('.qa-save')
.data(
(isShown ? [_qaItem] : []),
- d => `${d.id}-${d.status || 0}`
+ function (d) { return ((d.id) + "-" + (d.status || 0)); }
);
// exit
.remove();
// enter
- const saveSectionEnter = saveSection.enter()
+ var saveSectionEnter = saveSection.enter()
.append('div')
.attr('class', 'qa-save save-section cf');
.attr('class', 'new-comment-input')
.attr('placeholder', _t('QA.keepRight.comment_placeholder'))
.attr('maxlength', 1000)
- .property('value', d => d.newComment || d.comment)
+ .property('value', function (d) { return d.newComment || d.comment; })
.call(utilNoAuto)
.on('input', changeInput)
.on('blur', changeInput);
.call(qaSaveButtons);
function changeInput() {
- const input = select(this);
- let val = input.property('value').trim();
+ var input = select(this);
+ var val = input.property('value').trim();
if (val === _qaItem.comment) {
val = undefined;
// store the unsaved comment with the issue itself
_qaItem = _qaItem.update({ newComment: val });
- const qaService = services.keepRight;
+ var qaService = services.keepRight;
if (qaService) {
qaService.replaceItem(_qaItem); // update keepright cache
}
function qaSaveButtons(selection) {
- const isSelected = (_qaItem && _qaItem.id === context.selectedErrorID());
- let buttonSection = selection.selectAll('.buttons')
- .data((isSelected ? [_qaItem] : []), d => d.status + d.id);
+ var isSelected = (_qaItem && _qaItem.id === context.selectedErrorID());
+ var buttonSection = selection.selectAll('.buttons')
+ .data((isSelected ? [_qaItem] : []), function (d) { return d.status + d.id; });
// exit
buttonSection.exit()
.remove();
// enter
- const buttonEnter = buttonSection.enter()
+ var buttonEnter = buttonSection.enter()
.append('div')
.attr('class', 'buttons');
.merge(buttonEnter);
buttonSection.select('.comment-button') // select and propagate data
- .attr('disabled', d => d.newComment ? null : true)
+ .attr('disabled', function (d) { return d.newComment ? null : true; })
.on('click.comment', function(d) {
this.blur(); // avoid keeping focus on the button - #4641
- const qaService = services.keepRight;
+ var qaService = services.keepRight;
if (qaService) {
- qaService.postUpdate(d, (err, item) => dispatch$1.call('change', item));
+ qaService.postUpdate(d, function (err, item) { return dispatch$1.call('change', item); });
}
});
buttonSection.select('.close-button') // select and propagate data
- .text(d => {
- const andComment = (d.newComment ? '_comment' : '');
- return _t(`QA.keepRight.close${andComment}`);
+ .text(function (d) {
+ var andComment = (d.newComment ? '_comment' : '');
+ return _t(("QA.keepRight.close" + andComment));
})
.on('click.close', function(d) {
this.blur(); // avoid keeping focus on the button - #4641
- const qaService = services.keepRight;
+ var qaService = services.keepRight;
if (qaService) {
d.newStatus = 'ignore_t'; // ignore temporarily (item fixed)
- qaService.postUpdate(d, (err, item) => dispatch$1.call('change', item));
+ qaService.postUpdate(d, function (err, item) { return dispatch$1.call('change', item); });
}
});
buttonSection.select('.ignore-button') // select and propagate data
- .text(d => {
- const andComment = (d.newComment ? '_comment' : '');
- return _t(`QA.keepRight.ignore${andComment}`);
+ .text(function (d) {
+ var andComment = (d.newComment ? '_comment' : '');
+ return _t(("QA.keepRight.ignore" + andComment));
})
.on('click.ignore', function(d) {
this.blur(); // avoid keeping focus on the button - #4641
- const qaService = services.keepRight;
+ var qaService = services.keepRight;
if (qaService) {
d.newStatus = 'ignore'; // ignore permanently (false positive)
- qaService.postUpdate(d, (err, item) => dispatch$1.call('change', item));
+ qaService.postUpdate(d, function (err, item) { return dispatch$1.call('change', item); });
}
});
}
// NOTE: Don't change method name until UI v3 is merged
keepRightEditor.error = function(val) {
- if (!arguments.length) return _qaItem;
+ if (!arguments.length) { return _qaItem; }
_qaItem = val;
return keepRightEditor;
};
}
function uiOsmoseDetails(context) {
- let _qaItem;
+ var _qaItem;
function issueString(d, type) {
- if (!d) return '';
+ if (!d) { return ''; }
// Issue strings are cached from Osmose API
- const s = services.osmose.getStrings(d.itemType);
+ var s = services.osmose.getStrings(d.itemType);
return (type in s) ? s[type] : '';
}
function osmoseDetails(selection) {
- const details = selection.selectAll('.error-details')
+ var details = selection.selectAll('.error-details')
.data(
_qaItem ? [_qaItem] : [],
- d => `${d.id}-${d.status || 0}`
+ function (d) { return ((d.id) + "-" + (d.status || 0)); }
);
details.exit()
.remove();
- const detailsEnter = details.enter()
+ var detailsEnter = details.enter()
.append('div')
.attr('class', 'error-details qa-details-container');
// Description
if (issueString(_qaItem, 'detail')) {
- const div = detailsEnter
+ var div = detailsEnter
.append('div')
.attr('class', 'qa-details-subsection');
div
.append('h4')
- .text(() => _t('QA.keepRight.detail_description'));
+ .text(function () { return _t('QA.keepRight.detail_description'); });
div
.append('p')
.attr('class', 'qa-details-description-text')
- .html(d => issueString(d, 'detail'))
+ .html(function (d) { return issueString(d, 'detail'); })
.selectAll('a')
.attr('rel', 'noopener')
.attr('target', '_blank');
}
// Elements (populated later as data is requested)
- const detailsDiv = detailsEnter
+ var detailsDiv = detailsEnter
.append('div')
.attr('class', 'qa-details-subsection');
- const elemsDiv = detailsEnter
+ var elemsDiv = detailsEnter
.append('div')
.attr('class', 'qa-details-subsection');
- // Suggested Fix (musn't exist for every issue type)
+ // Suggested Fix (mustn't exist for every issue type)
if (issueString(_qaItem, 'fix')) {
- const div = detailsEnter
+ var div$1 = detailsEnter
.append('div')
.attr('class', 'qa-details-subsection');
- div
+ div$1
.append('h4')
- .text(() => _t('QA.osmose.fix_title'));
+ .text(function () { return _t('QA.osmose.fix_title'); });
- div
+ div$1
.append('p')
- .html(d => issueString(d, 'fix'))
+ .html(function (d) { return issueString(d, 'fix'); })
.selectAll('a')
.attr('rel', 'noopener')
.attr('target', '_blank');
}
- // Common Pitfalls (musn't exist for every issue type)
+ // Common Pitfalls (mustn't exist for every issue type)
if (issueString(_qaItem, 'trap')) {
- const div = detailsEnter
+ var div$2 = detailsEnter
.append('div')
.attr('class', 'qa-details-subsection');
- div
+ div$2
.append('h4')
- .text(() => _t('QA.osmose.trap_title'));
+ .text(function () { return _t('QA.osmose.trap_title'); });
- div
+ div$2
.append('p')
- .html(d => issueString(d, 'trap'))
+ .html(function (d) { return issueString(d, 'trap'); })
.selectAll('a')
.attr('rel', 'noopener')
.attr('target', '_blank');
}
// Save current item to check if UI changed by time request resolves
- const thisItem = _qaItem;
+ var thisItem = _qaItem;
services.osmose.loadIssueDetail(_qaItem)
- .then(d => {
+ .then(function (d) {
// No details to add if there are no associated issue elements
- if (!d.elems || d.elems.length === 0) return;
+ if (!d.elems || d.elems.length === 0) { return; }
// Do nothing if UI has moved on by the time this resolves
if (
context.selectedErrorID() !== thisItem.id
- && context.container().selectAll(`.qaItem.osmose.hover.itemId-${thisItem.id}`).empty()
- ) return;
+ && context.container().selectAll((".qaItem.osmose.hover.itemId-" + (thisItem.id))).empty()
+ ) { return; }
// Things like keys and values are dynamically added to a subtitle string
if (d.detail) {
detailsDiv
.append('h4')
- .text(() => _t('QA.osmose.detail_title'));
+ .text(function () { return _t('QA.osmose.detail_title'); });
detailsDiv
.append('p')
- .html(d => d.detail)
+ .html(function (d) { return d.detail; })
.selectAll('a')
.attr('rel', 'noopener')
.attr('target', '_blank');
// Create list of linked issue elements
elemsDiv
.append('h4')
- .text(() => _t('QA.osmose.elems_title'));
+ .text(function () { return _t('QA.osmose.elems_title'); });
elemsDiv
.append('ul').selectAll('li')
.append('li')
.append('a')
.attr('class', 'error_entity_link')
- .text(d => d)
+ .text(function (d) { return d; })
.each(function() {
- const link = select(this);
- const entityID = this.textContent;
- const entity = context.hasEntity(entityID);
+ var link = select(this);
+ var entityID = this.textContent;
+ var entity = context.hasEntity(entityID);
// Add click handler
link
- .on('mouseenter', () => {
+ .on('mouseenter', function () {
utilHighlightEntities([entityID], true, context);
})
- .on('mouseleave', () => {
+ .on('mouseleave', function () {
utilHighlightEntities([entityID], false, context);
})
- .on('click', () => {
+ .on('click', function () {
event.preventDefault();
utilHighlightEntities([entityID], false, context);
- const osmlayer = context.layers().layer('osm');
+ var osmlayer = context.layers().layer('osm');
if (!osmlayer.enabled()) {
osmlayer.enabled(true);
}
if (entity) {
context.enter(modeSelect(context, [entityID]));
} else {
- context.loadEntity(entityID, () => {
+ context.loadEntity(entityID, function () {
context.enter(modeSelect(context, [entityID]));
});
}
// Replace with friendly name if possible
// (The entity may not yet be loaded into the graph)
if (entity) {
- let name = utilDisplayName(entity); // try to use common name
+ var name = utilDisplayName(entity); // try to use common name
if (!name) {
- const preset = _mainPresetIndex.match(entity, context.graph());
+ var preset = _mainPresetIndex.match(entity, context.graph());
name = preset && !preset.isFallback() && preset.name(); // fallback to preset name
}
context.features().forceVisible(d.elems);
context.map().pan([0,0]); // trigger a redraw
})
- .catch(err => {
+ .catch(function (err) {
console.log(err); // eslint-disable-line no-console
});
}
osmoseDetails.issue = function(val) {
- if (!arguments.length) return _qaItem;
+ if (!arguments.length) { return _qaItem; }
_qaItem = val;
return osmoseDetails;
};
}
function uiOsmoseHeader() {
- let _qaItem;
+ var _qaItem;
function issueTitle(d) {
- const unknown = _t('inspector.unknown');
+ var unknown = _t('inspector.unknown');
- if (!d) return unknown;
+ if (!d) { return unknown; }
// Issue titles supplied by Osmose
- const s = services.osmose.getStrings(d.itemType);
+ var s = services.osmose.getStrings(d.itemType);
return ('title' in s) ? s.title : unknown;
}
function osmoseHeader(selection) {
- const header = selection.selectAll('.qa-header')
+ var header = selection.selectAll('.qa-header')
.data(
(_qaItem ? [_qaItem] : []),
- d => `${d.id}-${d.status || 0}`
+ function (d) { return ((d.id) + "-" + (d.status || 0)); }
);
header.exit()
.remove();
- const headerEnter = header.enter()
+ var headerEnter = header.enter()
.append('div')
.attr('class', 'qa-header');
- const svgEnter = headerEnter
+ var svgEnter = headerEnter
.append('div')
.attr('class', 'qa-header-icon')
- .classed('new', d => d.id < 0)
+ .classed('new', function (d) { return d.id < 0; })
.append('svg')
.attr('width', '20px')
.attr('height', '30px')
.attr('viewbox', '0 0 20 30')
- .attr('class', d => `preset-icon-28 qaItem ${d.service} itemId-${d.id} itemType-${d.itemType}`);
+ .attr('class', function (d) { return ("preset-icon-28 qaItem " + (d.service) + " itemId-" + (d.id) + " itemType-" + (d.itemType)); });
svgEnter
.append('polygon')
- .attr('fill', d => services.osmose.getColor(d.item))
+ .attr('fill', function (d) { return services.osmose.getColor(d.item); })
.attr('class', 'qaItem-fill')
.attr('points', '16,3 4,3 1,6 1,17 4,20 7,20 10,27 13,20 16,20 19,17.033 19,6');
.attr('width', '13px')
.attr('height', '13px')
.attr('transform', 'translate(3.5, 5)')
- .attr('xlink:href', d => {
- const picon = d.icon;
+ .attr('xlink:href', function (d) {
+ var picon = d.icon;
if (!picon) {
return '';
} else {
- const isMaki = /^maki-/.test(picon);
- return `#${picon}${isMaki ? '-11' : ''}`;
+ var isMaki = /^maki-/.test(picon);
+ return ("#" + picon + (isMaki ? '-11' : ''));
}
});
}
osmoseHeader.issue = function(val) {
- if (!arguments.length) return _qaItem;
+ if (!arguments.length) { return _qaItem; }
_qaItem = val;
return osmoseHeader;
};
}
function uiViewOnOsmose() {
- let _qaItem;
+ var _qaItem;
function viewOnOsmose(selection) {
- let url;
+ var url;
if (services.osmose && (_qaItem instanceof QAItem)) {
url = services.osmose.itemURL(_qaItem);
}
- const link = selection.selectAll('.view-on-osmose')
+ var link = selection.selectAll('.view-on-osmose')
.data(url ? [url] : []);
// exit
.remove();
// enter
- const linkEnter = link.enter()
+ var linkEnter = link.enter()
.append('a')
.attr('class', 'view-on-osmose')
.attr('target', '_blank')
.attr('rel', 'noopener') // security measure
- .attr('href', d => d)
+ .attr('href', function (d) { return d; })
.call(svgIcon('#iD-icon-out-link', 'inline'));
linkEnter
}
viewOnOsmose.what = function(val) {
- if (!arguments.length) return _qaItem;
+ if (!arguments.length) { return _qaItem; }
_qaItem = val;
return viewOnOsmose;
};
}
function uiOsmoseEditor(context) {
- const dispatch$1 = dispatch('change');
- const qaDetails = uiOsmoseDetails(context);
- const qaHeader = uiOsmoseHeader();
+ var dispatch$1 = dispatch('change');
+ var qaDetails = uiOsmoseDetails(context);
+ var qaHeader = uiOsmoseHeader();
- let _qaItem;
+ var _qaItem;
function osmoseEditor(selection) {
- const header = selection.selectAll('.header')
+ var header = selection.selectAll('.header')
.data([0]);
- const headerEnter = header.enter()
+ var headerEnter = header.enter()
.append('div')
.attr('class', 'header fillL');
headerEnter
.append('button')
.attr('class', 'close')
- .on('click', () => context.enter(modeBrowse(context)))
+ .on('click', function () { return context.enter(modeBrowse(context)); })
.call(svgIcon('#iD-icon-close'));
headerEnter
.append('h3')
.text(_t('QA.osmose.title'));
- let body = selection.selectAll('.body')
+ var body = selection.selectAll('.body')
.data([0]);
body = body.enter()
.attr('class', 'body')
.merge(body);
- let editor = body.selectAll('.qa-editor')
+ var editor = body.selectAll('.qa-editor')
.data([0]);
editor.enter()
.call(qaDetails.issue(_qaItem))
.call(osmoseSaveSection);
- const footer = selection.selectAll('.footer')
+ var footer = selection.selectAll('.footer')
.data([0]);
footer.enter()
}
function osmoseSaveSection(selection) {
- const isSelected = (_qaItem && _qaItem.id === context.selectedErrorID());
- const isShown = (_qaItem && isSelected);
- let saveSection = selection.selectAll('.qa-save')
+ var isSelected = (_qaItem && _qaItem.id === context.selectedErrorID());
+ var isShown = (_qaItem && isSelected);
+ var saveSection = selection.selectAll('.qa-save')
.data(
(isShown ? [_qaItem] : []),
- d => `${d.id}-${d.status || 0}`
+ function (d) { return ((d.id) + "-" + (d.status || 0)); }
);
// exit
.remove();
// enter
- const saveSectionEnter = saveSection.enter()
+ var saveSectionEnter = saveSection.enter()
.append('div')
.attr('class', 'qa-save save-section cf');
}
function qaSaveButtons(selection) {
- const isSelected = (_qaItem && _qaItem.id === context.selectedErrorID());
- let buttonSection = selection.selectAll('.buttons')
- .data((isSelected ? [_qaItem] : []), d => d.status + d.id);
+ var isSelected = (_qaItem && _qaItem.id === context.selectedErrorID());
+ var buttonSection = selection.selectAll('.buttons')
+ .data((isSelected ? [_qaItem] : []), function (d) { return d.status + d.id; });
// exit
buttonSection.exit()
.remove();
// enter
- const buttonEnter = buttonSection.enter()
+ var buttonEnter = buttonSection.enter()
.append('div')
.attr('class', 'buttons');
.merge(buttonEnter);
buttonSection.select('.close-button')
- .text(() => _t('QA.keepRight.close'))
+ .text(function () { return _t('QA.keepRight.close'); })
.on('click.close', function(d) {
this.blur(); // avoid keeping focus on the button - #4641
- const qaService = services.osmose;
+ var qaService = services.osmose;
if (qaService) {
d.newStatus = 'done';
- qaService.postUpdate(d, (err, item) => dispatch$1.call('change', item));
+ qaService.postUpdate(d, function (err, item) { return dispatch$1.call('change', item); });
}
});
buttonSection.select('.ignore-button')
- .text(() => _t('QA.keepRight.ignore'))
+ .text(function () { return _t('QA.keepRight.ignore'); })
.on('click.ignore', function(d) {
this.blur(); // avoid keeping focus on the button - #4641
- const qaService = services.osmose;
+ var qaService = services.osmose;
if (qaService) {
d.newStatus = 'false';
- qaService.postUpdate(d, (err, item) => dispatch$1.call('change', item));
+ qaService.postUpdate(d, function (err, item) { return dispatch$1.call('change', item); });
}
});
}
// NOTE: Don't change method name until UI v3 is merged
osmoseEditor.error = function(val) {
- if (!arguments.length) return _qaItem;
+ if (!arguments.length) { return _qaItem; }
_qaItem = val;
return osmoseEditor;
};
.on('change', function() {
context.map().pan([0,0]); // trigger a redraw
var error = checkSelectedID();
- if (!error) return;
+ if (!error) { return; }
context.ui().sidebar
.show(errorEditor.error(error));
});
.on('change', function() {
context.map().pan([0,0]); // trigger a redraw
var error = checkSelectedID();
- if (!error) return;
+ if (!error) { return; }
context.ui().sidebar
.show(errorEditor.error(error));
});
.on('change', function() {
context.map().pan([0,0]); // trigger a redraw
var error = checkSelectedID();
- if (!error) return;
+ if (!error) { return; }
context.ui().sidebar
.show(errorEditor.error(error));
});
function checkSelectedID() {
- if (!errorService) return;
+ if (!errorService) { return; }
var error = errorService.getError(selectedErrorID);
if (!error) {
context.enter(modeBrowse(context));
mode.zoomToSelected = function() {
- if (!errorService) return;
+ if (!errorService) { return; }
var error = errorService.getError(selectedErrorID);
if (error) {
context.map().centerZoomEase(error.loc, 20);
mode.enter = function() {
var error = checkSelectedID();
- if (!error) return;
+ if (!error) { return; }
behaviors.forEach(context.install);
keybinding
// class the error as selected, or return to browse mode if the error is gone
function selectError(drawn) {
- if (!checkSelectedID()) return;
+ if (!checkSelectedID()) { return; }
var selection = context.surface()
.selectAll('.itemId-' + selectedErrorID + '.' + selectedErrorService);
}
function esc() {
- if (context.container().select('.combobox').size()) return;
+ if (context.container().select('.combobox').size()) { return; }
context.enter(modeBrowse(context));
}
};
if (event.keyCode === 32) {
// don't react to spacebar events during text input
var activeNode = document.activeElement;
- if (activeNode && new Set(['INPUT', 'TEXTAREA']).has(activeNode.nodeName)) return;
+ if (activeNode && new Set(['INPUT', 'TEXTAREA']).has(activeNode.nodeName)) { return; }
}
if (event.keyCode === 93 || // context menu key
event.preventDefault();
}
- if (event.repeat) return; // ignore repeated events for held keys
+ if (event.repeat) { return; } // ignore repeated events for held keys
// if any key is pressed the user is probably doing something other than long-pressing
cancelLongPress();
if (pointer) {
delete _downPointers.spacebar;
- if (pointer.done) return;
+ if (pointer.done) { return; }
event.preventDefault();
_lastInteractionType = 'spacebar';
cancelLongPress();
- if (event.buttons && event.buttons !== 1) return;
+ if (event.buttons && event.buttons !== 1) { return; }
context.ui().closeEditMenu();
function didLongPress(id, interactionType) {
var pointer = _downPointers[id];
- if (!pointer) return;
+ if (!pointer) { return; }
for (var i in _downPointers) {
// don't allow this or any currently down pointer to trigger another click
function pointerup() {
var id = (event.pointerId || 'mouse').toString();
var pointer = _downPointers[id];
- if (!pointer) return;
+ if (!pointer) { return; }
delete _downPointers[id];
_multiselectionPointerId = null;
}
- if (pointer.done) return;
+ if (pointer.done) { return; }
click(pointer.firstEvent, event, id);
}
function pointercancel() {
var id = (event.pointerId || 'mouse').toString();
- if (!_downPointers[id]) return;
+ if (!_downPointers[id]) { return; }
delete _downPointers[id];
var mode = context.mode();
var selectedIDs = mode.id === 'select' ? mode.selectedIDs() : [];
for (var pointerId in _downPointers) {
- if (pointerId === 'spacebar' || pointerId === skipPointerId) continue;
+ if (pointerId === 'spacebar' || pointerId === skipPointerId) { continue; }
var pointerInfo = _downPointers[pointerId];
var p1 = pointGetter(pointerInfo.firstEvent);
var p2 = pointGetter(pointerInfo.lastEvent);
- if (geoVecLength(p1, p2) > _tolerancePx) continue;
+ if (geoVecLength(p1, p2) > _tolerancePx) { continue; }
var datum = pointerInfo.firstEvent.target.__data__;
var entity = (datum && datum.properties && datum.properties.entity) || datum;
- if (context.graph().hasEntity(entity.id)) return {
+ if (context.graph().hasEntity(entity.id)) { return {
pointerId: pointerId,
entityId: entity.id,
selected: selectedIDs.indexOf(entity.id) !== -1
- };
+ }; }
}
return null;
}
var interactionType = _lastInteractionType;
var entity = datum && datum.properties && datum.properties.entity;
- if (entity) datum = entity;
+ if (entity) { datum = entity; }
if (datum && datum.type === 'midpoint') {
// treat targeting midpoints as if targeting the parent way
selectedIDs.length <= 1 ||
selectedIDs.indexOf(datum.id) === -1) {
- if (alsoSelectId === datum.id) alsoSelectId = null;
+ if (alsoSelectId === datum.id) { alsoSelectId = null; }
selectedIDs = (alsoSelectId ? [alsoSelectId] : []).concat([datum.id]);
// always enter modeSelect even if the entity is already
context.ui().closeEditMenu();
// always request to show the edit menu in case the mode needs it
- if (showMenu) context.ui().showEditMenu(point, interactionType);
+ if (showMenu) { context.ui().showEditMenu(point, interactionType); }
resetProperties();
}
function cancelLongPress() {
- if (_longPressTimeout) window.clearTimeout(_longPressTimeout);
+ if (_longPressTimeout) { window.clearTimeout(_longPressTimeout); }
_longPressTimeout = null;
}
var loc = context.map().mouseCoordinates();
- if (!_drawNode) createDrawNode(loc);
+ if (!_drawNode) { createDrawNode(loc); }
context.surface().classed('nope-disabled', event.altKey);
if (includeDrawNode) {
if (parentWay.isClosed()) {
// don't test the last segment for closed ways - #4655
- // (still test the first segement)
+ // (still test the first segment)
nodes.pop();
}
} else { // discount the draw node
if (parentWay.isClosed()) {
- if (nodes.length < 3) return false;
- if (_drawNode) nodes.splice(-2, 1);
+ if (nodes.length < 3) { return false; }
+ if (_drawNode) { nodes.splice(-2, 1); }
testNode = nodes[nodes.length - 2];
} else {
// there's nothing we need to test if we ignore the draw node on open ways
var nextMode;
- if (context.graph() === startGraph) { // we've undone back to the beginning
+ if (context.graph() === startGraph) {
+ // We've undone back to the initial state before we started drawing.
+ // Just exit the draw mode without undoing whatever we did before
+ // we entered the draw mode.
nextMode = modeSelect(context, [wayID]);
} else {
- context.history()
- .on('undone.draw', null);
- // remove whatever segment was drawn previously
- context.undo();
+ // The `undo` only removed the temporary edit, so here we have to
+ // manually undo to actually remove the last node we added. We can't
+ // use the `undo` function since the initial "add" graph doesn't have
+ // an annotation and so cannot be undone to.
+ context.pop(1);
- if (context.graph() === startGraph) { // we've undone back to the beginning
- nextMode = modeSelect(context, [wayID]);
- } else {
- // continue drawing
- nextMode = mode;
- }
+ // continue drawing
+ nextMode = mode;
}
- // clear the redo stack by adding and removing an edit
+ // clear the redo stack by adding and removing a blank edit
context.perform(actionNoop());
context.pop(1);
function setActiveElements() {
- if (!_drawNode) return;
+ if (!_drawNode) { return; }
context.surface().selectAll('.' + _drawNode.id)
.classed('active', true);
_headNodeID = typeof _nodeIndex === 'number' ? _origWay.nodes[_nodeIndex] :
(_origWay.isClosed() ? _origWay.nodes[_origWay.nodes.length - 2] : _origWay.nodes[_origWay.nodes.length - 1]);
_wayGeometry = _origWay.geometry(context.graph());
- _annotation = _t((_origWay.isDegenerate() ?
+ _annotation = _t((_origWay.nodes.length === (_origWay.isClosed() ? 2 : 1) ?
'operations.start.annotation.' :
'operations.continue.annotation.') + _wayGeometry
);
move.apply(this, arguments);
})
.on('downcancel', function() {
- if (_drawNode) removeDrawNode();
+ if (_drawNode) { removeDrawNode(); }
})
.on('click', drawWay.add)
.on('clickWay', drawWay.addWay)
drawWay.nodeIndex = function(val) {
- if (!arguments.length) return _nodeIndex;
+ if (!arguments.length) { return _nodeIndex; }
_nodeIndex = val;
return drawWay;
};
drawWay.activeID = function() {
- if (!arguments.length) return _drawNode && _drawNode.id;
+ if (!arguments.length) { return _drawNode && _drawNode.id; }
// no assign
return drawWay;
};
var operation = function() {
- if (!getSelectionText()) {
- event.preventDefault();
- }
-
var graph = context.graph();
var selected = groupEntities(getFilteredIdsToCopy(), graph);
var canCopy = [];
}
- function getSelectionText() {
- return window.getSelection().toString();
- }
-
-
operation.available = function() {
return getFilteredIdsToCopy().length > 0;
};
};
+ operation.availableForKeypress = function() {
+ var selection = window.getSelection && window.getSelection();
+ // if the user has text selected then let them copy that, not the selected feature
+ return !selection || !selection.toString();
+ };
+
+
operation.tooltip = function() {
var disable = operation.disabled();
return disable ?
});
_nodes = utilGetAllNodes(_wayIDs, context.graph());
_coords = _nodes.map(function(n) { return n.loc; });
- _extent = utilTotalExtent(ways, context.graph());
// actions for connected nodes shared by at least two selected ways
var sharedActions = [];
+ var sharedNodes = [];
// actions for connected nodes
var unsharedActions = [];
+ var unsharedNodes = [];
_nodes.forEach(function(node) {
var action = actionDisconnect(node.id).limitWays(_wayIDs);
if (way.nodes.indexOf(node.id) !== -1) {
count += 1;
}
- if (count > 1) break;
+ if (count > 1) { break; }
}
if (count > 1) {
sharedActions.push(action);
+ sharedNodes.push(node);
} else {
unsharedActions.push(action);
+ unsharedNodes.push(node);
}
}
});
if (sharedActions.length) {
// if any nodes are shared, only disconnect the selected ways from each other
_actions = sharedActions;
+ _extent = utilTotalExtent(sharedNodes, context.graph());
_descriptionID += 'conjoined';
_annotationID = 'from_each_other';
} else {
// if no nodes are shared, disconnect the selected ways from all connected ways
_actions = unsharedActions;
+ _extent = utilTotalExtent(unsharedNodes, context.graph());
if (_wayIDs.length === 1) {
_descriptionID += context.graph().geometry(_wayIDs[0]);
} else {
operation.available = function() {
- if (_actions.length === 0) return false;
- if (_otherIDs.length !== 0) return false;
+ if (_actions.length === 0) { return false; }
+ if (_otherIDs.length !== 0) { return false; }
if (_vertexIDs.length !== 0 && _wayIDs.length !== 0 && !_wayIDs.every(function(wayID) {
return _vertexIDs.some(function(vertexID) {
var way = context.entity(wayID);
return way.nodes.indexOf(vertexID) !== -1;
});
- })) return false;
+ })) { return false; }
return true;
};
var reason;
for (var actionIndex in _actions) {
reason = _actions[actionIndex].disabled(context.graph());
- if (reason) return reason;
+ if (reason) { return reason; }
}
if (_extent && _extent.percentContainedIn(context.map().extent()) < 0.8) {
function someMissing() {
- if (context.inIntro()) return false;
+ if (context.inIntro()) { return false; }
var osm = context.connection();
if (osm) {
var missing = _coords.filter(function(loc) { return !osm.isDataLoaded(loc); });
var entity = graph.entity(entityID);
var preset = _mainPresetIndex.match(entity, graph);
- if (!preset || preset.isFallback()) return null;
+ if (!preset || preset.isFallback()) { return null; }
if (entity.type === 'node' &&
preset.id !== 'address' &&
for (var i in selectedIDs) {
var entityID = selectedIDs[i];
var type = downgradeTypeForEntityID(entityID);
- if (!type) continue;
+ if (!type) { continue; }
var tags = Object.assign({}, graph.entity(entityID).tags); // shallow copy
for (var key in tags) {
- if (type === 'address' && addressKeysToKeep.indexOf(key) !== -1) continue;
+ if (type === 'address' && addressKeysToKeep.indexOf(key) !== -1) { continue; }
if (type === 'building') {
if (buildingKeysToKeep.indexOf(key) !== -1 ||
key.match(/^building:.{1,}/) ||
- key.match(/^roof:.{1,}/)) continue;
+ key.match(/^roof:.{1,}/)) { continue; }
}
// keep address tags for buildings too
- if (key.match(/^addr:.{1,}/)) continue;
+ if (key.match(/^addr:.{1,}/)) { continue; }
delete tags[key];
}
var _actions = selectedIDs.map(function(entityID) {
var graph = context.graph();
var entity = graph.hasEntity(entityID);
- if (!entity || !entity.hasInterestingTags()) return;
+ if (!entity || !entity.hasInterestingTags()) { return; }
- if (entity.type === 'node' && graph.parentWays(entity).length === 0) return;
+ if (entity.type === 'node' && graph.parentWays(entity).length === 0) { return; }
if (entity.type !== 'node') {
var preset = _mainPresetIndex.match(entity, graph);
// only allow extraction from ways/relations if the preset supports points
- if (preset.geometry.indexOf('point') === -1) return;
+ if (preset.geometry.indexOf('point') === -1) { return; }
}
_extent = _extent ? _extent.extend(entity.extent(graph)) : entity.extent(graph);
function getAction() {
// prefer a non-disabled action first
var join = actionJoin(selectedIDs);
- if (!join.disabled(context.graph())) return join;
+ if (!join.disabled(context.graph())) { return join; }
var merge = actionMerge(selectedIDs);
- if (!merge.disabled(context.graph())) return merge;
+ if (!merge.disabled(context.graph())) { return merge; }
var mergePolygon = actionMergePolygon(selectedIDs);
- if (!mergePolygon.disabled(context.graph())) return mergePolygon;
+ if (!mergePolygon.disabled(context.graph())) { return mergePolygon; }
var mergeNodes = actionMergeNodes(selectedIDs);
- if (!mergeNodes.disabled(context.graph())) return mergeNodes;
+ if (!mergeNodes.disabled(context.graph())) { return mergeNodes; }
// otherwise prefer an action with an interesting disabled reason
- if (join.disabled(context.graph()) !== 'not_eligible') return join;
- if (merge.disabled(context.graph()) !== 'not_eligible') return merge;
- if (mergePolygon.disabled(context.graph()) !== 'not_eligible') return mergePolygon;
+ if (join.disabled(context.graph()) !== 'not_eligible') { return join; }
+ if (merge.disabled(context.graph()) !== 'not_eligible') { return merge; }
+ if (mergePolygon.disabled(context.graph()) !== 'not_eligible') { return mergePolygon; }
return mergeNodes;
}
var operation = function() {
- if (operation.disabled()) return;
+ if (operation.disabled()) { return; }
context.perform(_action, operation.annotation());
var interestingIDs = resultIDs.filter(function(id) {
return context.entity(id).hasInterestingTags();
});
- if (interestingIDs.length) resultIDs = interestingIDs;
+ if (interestingIDs.length) { resultIDs = interestingIDs; }
}
context.enter(modeSelect(context, resultIDs));
};
operation.disabled = function() {
var actionDisabled = _action.disabled(context.graph());
- if (actionDisabled) return actionDisabled;
+ if (actionDisabled) { return actionDisabled; }
var osm = context.connection();
if (osm &&
var operation = function() {
- if (!_pastePoint) return;
+ if (!_pastePoint) { return; }
var oldIDs = context.copyIDs();
- if (!oldIDs.length) return;
+ if (!oldIDs.length) { return; }
var projection = context.projection;
var extent = geoExtent();
function actions(situation) {
return selectedIDs.map(function(entityID) {
var entity = context.hasEntity(entityID);
- if (!entity) return;
+ if (!entity) { return; }
if (situation === 'toolbar') {
if (entity.type === 'way' &&
- (!entity.isOneWay() && !entity.isSided())) return;
+ (!entity.isOneWay() && !entity.isSided())) { return; }
}
var geometry = entity.geometry(context.graph());
- if (entity.type !== 'node' && geometry !== 'line') return;
+ if (entity.type !== 'node' && geometry !== 'line') { return; }
var action = actionReverse(entityID);
- if (action.disabled(context.graph())) return;
+ if (action.disabled(context.graph())) { return; }
return action;
}).filter(Boolean);
return entity && entity.type === 'node';
}).length;
var typeID = nodeActionCount === 0 ? 'line' : (nodeActionCount === acts.length ? 'point' : 'features');
- if (typeID !== 'features' && acts.length > 1) typeID += 's';
+ if (typeID !== 'features' && acts.length > 1) { typeID += 's'; }
return typeID;
}
// Ensure all ways are connected (i.e. only 2 unique endpoints/startpoints)
if (utilArrayDifference(startNodeIDs, endNodeIDs).length +
- utilArrayDifference(endNodeIDs, startNodeIDs).length !== 2) return null;
+ utilArrayDifference(endNodeIDs, startNodeIDs).length !== 2) { return null; }
// Ensure path contains at least 3 unique nodes
var wayNodeIDs = utilGetAllNodes(_wayIDs, context.graph())
.map(function(node) { return node.id; });
- if (wayNodeIDs.length <= 2) return null;
+ if (wayNodeIDs.length <= 2) { return null; }
// If range of 2 selected nodes is supplied, ensure nodes lie on the selected path
if (_nodeIDs.length === 2 && (
wayNodeIDs.indexOf(_nodeIDs[0]) === -1 || wayNodeIDs.indexOf(_nodeIDs[1]) === -1
- )) return null;
+ )) { return null; }
if (_nodeIDs.length) {
// If we're only straightenting between two points, we only need that extent visible
function operation() {
- if (!_action) return;
+ if (!_action) { return; }
context.perform(_action, operation.annotation());
function someMissing() {
- if (context.inIntro()) return false;
+ if (context.inIntro()) { return false; }
var osm = context.connection();
if (osm) {
var missing = _coords.filter(function(loc) { return !osm.isDataLoaded(loc); });
for (var i = 0; i < selectedIDs.length; i++) {
var entity = context.hasEntity(selectedIDs[i]);
if (!entity || entity.geometry(graph) !== 'vertex') {
- return []; // selection includes some not vertexes
+ return []; // selection includes some not vertices
}
var currParents = graph.parentWays(entity).map(function(w) { return w.id; });
mode.selectedIDs = function(val) {
- if (!arguments.length) return selectedIDs;
+ if (!arguments.length) { return selectedIDs; }
selectedIDs = val;
return mode;
};
mode.newFeature = function(val) {
- if (!arguments.length) return _newFeature;
+ if (!arguments.length) { return _newFeature; }
_newFeature = val;
return mode;
};
mode.selectBehavior = function(val) {
- if (!arguments.length) return _selectBehavior;
+ if (!arguments.length) { return _selectBehavior; }
_selectBehavior = val;
return mode;
};
mode.follow = function(val) {
- if (!arguments.length) return _follow;
+ if (!arguments.length) { return _follow; }
_follow = val;
return mode;
};
mode.enter = function() {
- if (!checkSelectedIDs()) return;
+ if (!checkSelectedIDs()) { return; }
context.features().forceVisible(selectedIDs);
loadOperations();
if (!_behaviors.length) {
- if (!_selectBehavior) _selectBehavior = behaviorSelect(context);
+ if (!_selectBehavior) { _selectBehavior = behaviorSelect(context); }
_behaviors = [
behaviorPaste(context),
var loc = extent.center();
context.map().centerEase(loc);
+ // we could enter the mode multiple times, so reset follow for next time
+ _follow = false;
}
function nudgeSelection(delta) {
return function() {
// prevent nudging during low zoom selection
- if (!context.map().withinEditableZoom()) return;
+ if (!context.map().withinEditableZoom()) { return; }
var moveOp = operationMove(context, selectedIDs);
if (moveOp.disabled()) {
function didDoubleUp(loc) {
- if (!context.map().withinEditableZoom()) return;
+ if (!context.map().withinEditableZoom()) { return; }
var target = select(event.target);
var datum = target.datum();
var entity = datum && datum.properties && datum.properties.entity;
- if (!entity) return;
+ if (!entity) { return; }
if (entity instanceof osmWay && target.classed('target')) {
var choice = geoChooseEdge(context.graph().childNodes(entity), loc, context.projection);
function selectElements() {
- if (!checkSelectedIDs()) return;
+ if (!checkSelectedIDs()) { return; }
var surface = context.surface();
function esc() {
- if (context.container().select('.combobox').size()) return;
+ if (context.container().select('.combobox').size()) { return; }
context.enter(modeBrowse(context));
}
function previousVertex() {
event.preventDefault();
var parent = singularParent();
- if (!parent) return;
+ if (!parent) { return; }
var way = context.entity(parent);
var length = way.nodes.length;
function nextVertex() {
event.preventDefault();
var parent = singularParent();
- if (!parent) return;
+ if (!parent) { return; }
var way = context.entity(parent);
var length = way.nodes.length;
function nextParent() {
event.preventDefault();
var parents = commonParents();
- if (!parents || parents.length < 2) return;
+ if (!parents || parents.length < 2) { return; }
var index = parents.indexOf(_relatedParent);
if (index < 0 || index > parents.length - 2) {
lasso.p = function(_) {
- if (!arguments.length) return lasso;
+ if (!arguments.length) { return lasso; }
lasso.coordinates.push(_);
draw();
return lasso;
function lassoed() {
- if (!lasso) return [];
+ if (!lasso) { return []; }
var graph = context.graph();
var limitToNodes;
.on(_pointerPrefix + 'move.lasso', null)
.on(_pointerPrefix + 'up.lasso', null);
- if (!lasso) return;
+ if (!lasso) { return; }
var ids = lassoed();
lasso.close();
mode.selectBehavior = function(val) {
- if (!arguments.length) return _selectBehavior;
+ if (!arguments.length) { return _selectBehavior; }
_selectBehavior = val;
return mode;
};
mode.enter = function() {
if (!_behaviors.length) {
- if (!_selectBehavior) _selectBehavior = behaviorSelect(context);
+ if (!_selectBehavior) { _selectBehavior = behaviorSelect(context); }
_behaviors = [
behaviorPaste(context),
behaviorHover(context).on('hover', context.ui().sidebar.hover),
mode.sidebar = function(_) {
- if (!arguments.length) return sidebar;
+ if (!arguments.length) { return sidebar; }
sidebar = _;
return mode;
};
}
function updateTitle(includeChangeCount) {
- if (!context.setsDocumentTitle()) return;
+ if (!context.setsDocumentTitle()) { return; }
var newTitle = computedTitle(includeChangeCount);
if (document.title !== newTitle) {
}
function updateHashIfNeeded() {
- if (context.inIntro()) return;
+ if (context.inIntro()) { return; }
var latestHash = computedHash();
if (_cachedHash !== latestHash) {
function hashchange() {
// ignore spurious hashchange events
- if (window.location.hash === _cachedHash) return;
+ if (window.location.hash === _cachedHash) { return; }
_cachedHash = window.location.hash;
} else {
// don't update if the new hash already reflects the state of iD
- if (_cachedHash === computedHash()) return;
+ if (_cachedHash === computedHash()) { return; }
var mode = context.mode();
var maxdist = 500;
// Don't allow the hash location to change too much while drawing
- // This can happen if the user accidently hit the back button. #3996
+ // This can happen if the user accidentally hit the back button. #3996
if (mode && mode.id.match(/^draw/) !== null && dist > maxdist) {
context.enter(modeBrowse(context));
return;
var h = head.entities[id];
var b = base.entities[id];
- if (h === b) return;
- if (_changes[id]) return;
+ if (h === b) { return; }
+ if (_changes[id]) { return; }
if (!h && b) {
_changes[id] = { base: b, head: h };
if (extent &&
(!h || !h.intersects(extent, head)) &&
(!b || !b.intersects(extent, base)))
- continue;
+ { continue; }
result[id] = h;
var ids = utilArrayUnion(mh, mb);
for (i = 0; i < ids.length; i++) {
var member = head.hasEntity(ids[i]);
- if (!member) continue; // not downloaded
- if (extent && !member.intersects(extent, head)) continue; // not visible
+ if (!member) { continue; } // not downloaded
+ if (extent && !member.intersects(extent, head)) { continue; } // not visible
result[ids[i]] = member;
}
}
function addParents(parents, result) {
for (var i = 0; i < parents.length; i++) {
var parent = parents[i];
- if (parent.id in result) continue;
+ if (parent.id in result) { continue; }
result[parent.id] = parent;
addParents(head.parentRelations(parent), result);
function segmentBBox(segment) {
var extent = segment.extent(head);
- // extent can be null if the node entites aren't in the graph for some reason
- if (!extent) return null;
+ // extent can be null if the node entities aren't in the graph for some reason
+ if (!extent) { return null; }
var bbox = extent.bbox();
bbox.segment = segment;
segments = segments.concat(entitySegments);
}
});
- if (segments.length) _segmentsRTree.load(segments.map(segmentBBox).filter(Boolean));
+ if (segments.length) { _segmentsRTree.load(segments.map(segmentBBox).filter(Boolean)); }
}
});
head.parentRelations(entity).forEach(function(relation) {
- if (memo[entity.id]) return;
+ if (memo[entity.id]) { return; }
memo[entity.id] = true;
if (_bboxes[relation.id]) {
removeEntity(relation);
for (var i = 0; i < entities.length; i++) {
var entity = entities[i];
- if (!entity.visible) continue;
+ if (!entity.visible) { continue; }
if (head.entities.hasOwnProperty(entity.id) || _bboxes[entity.id]) {
if (!force) {
function updateToGraph(graph) {
- if (graph === head) return;
+ if (graph === head) { return; }
var diff = coreDifference(head, graph);
head = graph;
var changed = diff.didChange;
- if (!changed.addition && !changed.deletion && !changed.geometry) return;
+ if (!changed.addition && !changed.deletion && !changed.geometry) { return; }
var insertions = {};
}
function uiModal(selection, blocking) {
- let keybinding = utilKeybinding('modal');
- let previous = selection.select('div.modal');
- let animate = previous.empty();
+ var this$1 = this;
+
+ var keybinding = utilKeybinding('modal');
+ var previous = selection.select('div.modal');
+ var animate = previous.empty();
previous.transition()
.duration(200)
.style('opacity', 0)
.remove();
- let shaded = selection
+ var shaded = selection
.append('div')
.attr('class', 'shaded')
.style('opacity', 0);
- shaded.close = () => {
+ shaded.close = function () {
shaded
.transition()
.duration(200)
};
- let modal = shaded
+ var modal = shaded
.append('div')
.attr('class', 'modal fillL');
if (!blocking) {
- shaded.on('click.remove-modal', () => {
- if (event.target === this) {
+ shaded.on('click.remove-modal', function () {
+ if (event.target === this$1) {
shaded.close();
}
});
}
function uiLoading(context) {
- let _modalSelection = select(null);
- let _message = '';
- let _blocking = false;
+ var _modalSelection = select(null);
+ var _message = '';
+ var _blocking = false;
- let loading = (selection) => {
+ var loading = function (selection) {
_modalSelection = uiModal(selection, _blocking);
- let loadertext = _modalSelection.select('.content')
+ var loadertext = _modalSelection.select('.content')
.classed('loading-modal', true)
.append('div')
.attr('class', 'modal-section fillL');
loading.message = function(val) {
- if (!arguments.length) return _message;
+ if (!arguments.length) { return _message; }
_message = val;
return loading;
};
loading.blocking = function(val) {
- if (!arguments.length) return _blocking;
+ if (!arguments.length) { return _blocking; }
_blocking = val;
return loading;
};
- loading.close = () => {
+ loading.close = function () {
_modalSelection.remove();
};
- loading.isShown = () => {
+ loading.isShown = function () {
return _modalSelection && !_modalSelection.empty() && _modalSelection.node().parentNode;
};
.ease(linear$1)
.tween('history.tween', function() {
return function(t) {
- if (t < 1) _overwrite([action0], t);
+ if (t < 1) { _overwrite([action0], t); }
};
})
.on('start', function() {
var previous = previousStack.graph;
while (_index > 0) {
_index--;
- if (_stack[_index].annotation) break;
+ if (_stack[_index].annotation) { break; }
}
dispatch$1.call('undone', this, _stack[_index], previousStack);
undoAnnotation: function() {
var i = _index;
while (i >= 0) {
- if (_stack[i].annotation) return _stack[i].annotation;
+ if (_stack[i].annotation) { return _stack[i].annotation; }
i--;
}
},
redoAnnotation: function() {
var i = _index + 1;
while (i <= _stack.length - 1) {
- if (_stack[i].annotation) return _stack[i].annotation;
+ if (_stack[i].annotation) { return _stack[i].annotation; }
i++;
}
},
toJSON: function() {
- if (!this.hasChanges()) return;
+ if (!this.hasChanges()) { return; }
var allEntities = {};
var baseEntities = {};
var x = {};
- if (modified.length) x.modified = modified;
- if (deleted.length) x.deleted = deleted;
- if (i.imageryUsed) x.imageryUsed = i.imageryUsed;
- if (i.photoOverlaysUsed) x.photoOverlaysUsed = i.photoOverlaysUsed;
- if (i.annotation) x.annotation = i.annotation;
- if (i.transform) x.transform = i.transform;
- if (i.selectedIDs) x.selectedIDs = i.selectedIDs;
+ if (modified.length) { x.modified = modified; }
+ if (deleted.length) { x.deleted = deleted; }
+ if (i.imageryUsed) { x.imageryUsed = i.imageryUsed; }
+ if (i.photoOverlaysUsed) { x.photoOverlaysUsed = i.photoOverlaysUsed; }
+ if (i.annotation) { x.annotation = i.annotation; }
+ if (i.transform) { x.transform = i.transform; }
+ if (i.selectedIDs) { x.selectedIDs = i.selectedIDs; }
return x;
});
if (lock.locked()) {
_hasUnresolvedRestorableChanges = false;
var json = this.savedHistoryJSON();
- if (json) history.fromJSON(json, true);
+ if (json) { history.fromJSON(json, true); }
}
},
* Look for roads that can be connected to other roads with a short extension
*/
function validationAlmostJunction(context) {
- const type = 'almost_junction';
- const EXTEND_TH_METERS = 5;
- const WELD_TH_METERS = 0.75;
+ var type = 'almost_junction';
+ var EXTEND_TH_METERS = 5;
+ var WELD_TH_METERS = 0.75;
// Comes from considering bounding case of parallel ways
- const CLOSE_NODE_TH = EXTEND_TH_METERS - WELD_TH_METERS;
+ var CLOSE_NODE_TH = EXTEND_TH_METERS - WELD_TH_METERS;
// Comes from considering bounding case of perpendicular ways
- const SIG_ANGLE_TH = Math.atan(WELD_TH_METERS / EXTEND_TH_METERS);
+ var SIG_ANGLE_TH = Math.atan(WELD_TH_METERS / EXTEND_TH_METERS);
function isHighway(entity) {
return entity.type === 'way'
}
- const validation = function checkAlmostJunction(entity, graph) {
- if (!isHighway(entity)) return [];
- if (entity.isDegenerate()) return [];
+ var validation = function checkAlmostJunction(entity, graph) {
+ if (!isHighway(entity)) { return []; }
+ if (entity.isDegenerate()) { return []; }
- const tree = context.history().tree();
- const extendableNodeInfos = findConnectableEndNodesByExtension(entity);
+ var tree = context.history().tree();
+ var extendableNodeInfos = findConnectableEndNodesByExtension(entity);
- let issues = [];
+ var issues = [];
- extendableNodeInfos.forEach(extendableNodeInfo => {
+ extendableNodeInfos.forEach(function (extendableNodeInfo) {
issues.push(new validationIssue({
- type,
+ type: type,
subtype: 'highway-highway',
severity: 'warning',
- message(context) {
- const entity1 = context.hasEntity(this.entityIds[0]);
+ message: function message(context) {
+ var entity1 = context.hasEntity(this.entityIds[0]);
if (this.entityIds[0] === this.entityIds[2]) {
return entity1 ? _t('issues.almost_junction.self.message', {
feature: utilDisplayLabel(entity1, context.graph())
}) : '';
} else {
- const entity2 = context.hasEntity(this.entityIds[2]);
+ var entity2 = context.hasEntity(this.entityIds[2]);
return (entity1 && entity2) ? _t('issues.almost_junction.message', {
feature: utilDisplayLabel(entity1, context.graph()),
feature2: utilDisplayLabel(entity2, context.graph())
entityIds: [
entity.id,
extendableNodeInfo.node.id,
- extendableNodeInfo.wid,
- ],
+ extendableNodeInfo.wid ],
loc: extendableNodeInfo.node.loc,
hash: JSON.stringify(extendableNodeInfo.node.loc),
data: {
return issues;
function makeFixes(context) {
- let fixes = [new validationIssueFix({
+ var fixes = [new validationIssueFix({
icon: 'iD-icon-abutment',
title: _t('issues.fix.connect_features.title'),
- onClick(context) {
- const annotation = _t('issues.fix.connect_almost_junction.annotation');
- const [, endNodeId, crossWayId] = this.issue.entityIds;
- const midNode = context.entity(this.issue.data.midId);
- const endNode = context.entity(endNodeId);
- const crossWay = context.entity(crossWayId);
+ onClick: function onClick(context) {
+ var annotation = _t('issues.fix.connect_almost_junction.annotation');
+ var ref = this.issue.entityIds;
+ var endNodeId = ref[1];
+ var crossWayId = ref[2];
+ var midNode = context.entity(this.issue.data.midId);
+ var endNode = context.entity(endNodeId);
+ var crossWay = context.entity(crossWayId);
// When endpoints are close, just join if resulting small change in angle (#7201)
- const nearEndNodes = findNearbyEndNodes(endNode, crossWay);
+ var nearEndNodes = findNearbyEndNodes(endNode, crossWay);
if (nearEndNodes.length > 0) {
- const collinear = findSmallJoinAngle(midNode, endNode, nearEndNodes);
+ var collinear = findSmallJoinAngle(midNode, endNode, nearEndNodes);
if (collinear) {
context.perform(
actionMergeNodes([collinear.id, endNode.id], collinear.loc),
}
}
- const targetEdge = this.issue.data.edge;
- const crossLoc = this.issue.data.cross_loc;
- const edgeNodes = [context.entity(targetEdge[0]), context.entity(targetEdge[1])];
- const closestNodeInfo = geoSphericalClosestNode(edgeNodes, crossLoc);
+ var targetEdge = this.issue.data.edge;
+ var crossLoc = this.issue.data.cross_loc;
+ var edgeNodes = [context.entity(targetEdge[0]), context.entity(targetEdge[1])];
+ var closestNodeInfo = geoSphericalClosestNode(edgeNodes, crossLoc);
// already a point nearby, just connect to that
if (closestNodeInfo.distance < WELD_TH_METERS) {
}
})];
- const node = context.hasEntity(this.entityIds[1]);
+ var node = context.hasEntity(this.entityIds[1]);
if (node && !node.hasInterestingTags()) {
// node has no descriptive tags, suggest noexit fix
fixes.push(new validationIssueFix({
icon: 'maki-barrier',
title: _t('issues.fix.tag_as_disconnected.title'),
- onClick(context) {
- const nodeID = this.issue.entityIds[1];
- const tags = Object.assign({}, context.entity(nodeID).tags);
+ onClick: function onClick(context) {
+ var nodeID = this.issue.entityIds[1];
+ var tags = Object.assign({}, context.entity(nodeID).tags);
tags.noexit = 'yes';
context.perform(
actionChangeTags(nodeID, tags),
function isExtendableCandidate(node, way) {
// can not accurately test vertices on tiles not downloaded from osm - #5938
- const osm = services.osm;
+ var osm = services.osm;
if (osm && !osm.isDataLoaded(node.loc)) {
return false;
}
return false;
}
- let occurences = 0;
- for (const index in way.nodes) {
+ var occurences = 0;
+ for (var index in way.nodes) {
if (way.nodes[index] === node.id) {
occurences += 1;
if (occurences > 1) {
}
function findConnectableEndNodesByExtension(way) {
- let results = [];
- if (way.isClosed()) return results;
+ var results = [];
+ if (way.isClosed()) { return results; }
- let testNodes;
- const indices = [0, way.nodes.length - 1];
- indices.forEach(nodeIndex => {
- const nodeID = way.nodes[nodeIndex];
- const node = graph.entity(nodeID);
+ var testNodes;
+ var indices = [0, way.nodes.length - 1];
+ indices.forEach(function (nodeIndex) {
+ var nodeID = way.nodes[nodeIndex];
+ var node = graph.entity(nodeID);
- if (!isExtendableCandidate(node, way)) return;
+ if (!isExtendableCandidate(node, way)) { return; }
- const connectionInfo = canConnectByExtend(way, nodeIndex);
- if (!connectionInfo) return;
+ var connectionInfo = canConnectByExtend(way, nodeIndex);
+ if (!connectionInfo) { return; }
testNodes = graph.childNodes(way).slice(); // shallow copy
testNodes[nodeIndex] = testNodes[nodeIndex].move(connectionInfo.cross_loc);
// don't flag issue if connecting the ways would cause self-intersection
- if (geoHasSelfIntersections(testNodes, nodeID)) return;
+ if (geoHasSelfIntersections(testNodes, nodeID)) { return; }
results.push(connectionInfo);
});
return [
way.nodes[0],
way.nodes[way.nodes.length - 1]
- ].map(d => graph.entity(d))
- .filter(d => {
+ ].map(function (d) { return graph.entity(d); })
+ .filter(function (d) {
// Node cannot be near to itself, but other endnode of same way could be
return d.id !== node.id
&& geoSphericalDistance(node.loc, d.loc) <= CLOSE_NODE_TH;
function findSmallJoinAngle(midNode, tipNode, endNodes) {
// Both nodes could be close, so want to join whichever is closest to collinear
- let joinTo;
- let minAngle = Infinity;
+ var joinTo;
+ var minAngle = Infinity;
// Checks midNode -> tipNode -> endNode for collinearity
- endNodes.forEach(endNode => {
- const a1 = geoAngle(midNode, tipNode, context.projection) + Math.PI;
- const a2 = geoAngle(midNode, endNode, context.projection) + Math.PI;
- const diff = Math.max(a1, a2) - Math.min(a1, a2);
+ endNodes.forEach(function (endNode) {
+ var a1 = geoAngle(midNode, tipNode, context.projection) + Math.PI;
+ var a2 = geoAngle(midNode, endNode, context.projection) + Math.PI;
+ var diff = Math.max(a1, a2) - Math.min(a1, a2);
if (diff < minAngle) {
joinTo = endNode;
/* Threshold set by considering right angle triangle
based on node joining threshold and extension distance */
- if (minAngle <= SIG_ANGLE_TH) return joinTo;
+ if (minAngle <= SIG_ANGLE_TH) { return joinTo; }
return null;
}
function canConnectWays(way, way2) {
// allow self-connections
- if (way.id === way2.id) return true;
+ if (way.id === way2.id) { return true; }
// if one is bridge or tunnel, both must be bridge or tunnel
if ((hasTag(way.tags, 'bridge') || hasTag(way2.tags, 'bridge')) &&
- !(hasTag(way.tags, 'bridge') && hasTag(way2.tags, 'bridge'))) return false;
+ !(hasTag(way.tags, 'bridge') && hasTag(way2.tags, 'bridge'))) { return false; }
if ((hasTag(way.tags, 'tunnel') || hasTag(way2.tags, 'tunnel')) &&
- !(hasTag(way.tags, 'tunnel') && hasTag(way2.tags, 'tunnel'))) return false;
+ !(hasTag(way.tags, 'tunnel') && hasTag(way2.tags, 'tunnel'))) { return false; }
// must have equivalent layers and levels
- const layer1 = way.tags.layer || '0',
+ var layer1 = way.tags.layer || '0',
layer2 = way2.tags.layer || '0';
- if (layer1 !== layer2) return false;
+ if (layer1 !== layer2) { return false; }
- const level1 = way.tags.level || '0',
+ var level1 = way.tags.level || '0',
level2 = way2.tags.level || '0';
- if (level1 !== level2) return false;
+ if (level1 !== level2) { return false; }
return true;
}
function canConnectByExtend(way, endNodeIdx) {
- const tipNid = way.nodes[endNodeIdx]; // the 'tip' node for extension point
- const midNid = endNodeIdx === 0 ? way.nodes[1] : way.nodes[way.nodes.length - 2]; // the other node of the edge
- const tipNode = graph.entity(tipNid);
- const midNode = graph.entity(midNid);
- const lon = tipNode.loc[0];
- const lat = tipNode.loc[1];
- const lon_range = geoMetersToLon(EXTEND_TH_METERS, lat) / 2;
- const lat_range = geoMetersToLat(EXTEND_TH_METERS) / 2;
- const queryExtent = geoExtent([
+ var tipNid = way.nodes[endNodeIdx]; // the 'tip' node for extension point
+ var midNid = endNodeIdx === 0 ? way.nodes[1] : way.nodes[way.nodes.length - 2]; // the other node of the edge
+ var tipNode = graph.entity(tipNid);
+ var midNode = graph.entity(midNid);
+ var lon = tipNode.loc[0];
+ var lat = tipNode.loc[1];
+ var lon_range = geoMetersToLon(EXTEND_TH_METERS, lat) / 2;
+ var lat_range = geoMetersToLat(EXTEND_TH_METERS) / 2;
+ var queryExtent = geoExtent([
[lon - lon_range, lat - lat_range],
[lon + lon_range, lat + lat_range]
]);
// first, extend the edge of [midNode -> tipNode] by EXTEND_TH_METERS and find the "extended tip" location
- const edgeLen = geoSphericalDistance(midNode.loc, tipNode.loc);
- const t = EXTEND_TH_METERS / edgeLen + 1.0;
- const extTipLoc = geoVecInterp(midNode.loc, tipNode.loc, t);
+ var edgeLen = geoSphericalDistance(midNode.loc, tipNode.loc);
+ var t = EXTEND_TH_METERS / edgeLen + 1.0;
+ var extTipLoc = geoVecInterp(midNode.loc, tipNode.loc, t);
// then, check if the extension part [tipNode.loc -> extTipLoc] intersects any other ways
- const segmentInfos = tree.waySegments(queryExtent, graph);
- for (let i = 0; i < segmentInfos.length; i++) {
- let segmentInfo = segmentInfos[i];
+ var segmentInfos = tree.waySegments(queryExtent, graph);
+ for (var i = 0; i < segmentInfos.length; i++) {
+ var segmentInfo = segmentInfos[i];
- let way2 = graph.entity(segmentInfo.wayId);
+ var way2 = graph.entity(segmentInfo.wayId);
- if (!isHighway(way2)) continue;
+ if (!isHighway(way2)) { continue; }
- if (!canConnectWays(way, way2)) continue;
+ if (!canConnectWays(way, way2)) { continue; }
- let nAid = segmentInfo.nodes[0],
+ var nAid = segmentInfo.nodes[0],
nBid = segmentInfo.nodes[1];
- if (nAid === tipNid || nBid === tipNid) continue;
+ if (nAid === tipNid || nBid === tipNid) { continue; }
- let nA = graph.entity(nAid),
+ var nA = graph.entity(nAid),
nB = graph.entity(nBid);
- let crossLoc = geoLineIntersection([tipNode.loc, extTipLoc], [nA.loc, nB.loc]);
+ var crossLoc = geoLineIntersection([tipNode.loc, extTipLoc], [nA.loc, nB.loc]);
if (crossLoc) {
return {
mid: midNode,
function wayTypeFor(way) {
- if (way.tags.boundary && way.tags.boundary !== 'no') return 'boundary';
- if (way.tags.indoor && way.tags.indoor !== 'no') return 'indoor';
+ if (way.tags.boundary && way.tags.boundary !== 'no') { return 'boundary'; }
+ if (way.tags.indoor && way.tags.indoor !== 'no') { return 'indoor'; }
if ((way.tags.building && way.tags.building !== 'no') ||
- (way.tags['building:part'] && way.tags['building:part'] !== 'no')) return 'building';
- if (osmPathHighwayTagValues[way.tags.highway]) return 'path';
+ (way.tags['building:part'] && way.tags['building:part'] !== 'no')) { return 'building'; }
+ if (osmPathHighwayTagValues[way.tags.highway]) { return 'path'; }
var parentRelations = graph.parentRelations(way);
for (var i in parentRelations) {
var relation = parentRelations[i];
- if (relation.tags.type === 'boundary') return 'boundary';
+ if (relation.tags.type === 'boundary') { return 'boundary'; }
if (relation.isMultipolygon()) {
- if (relation.tags.indoor && relation.tags.indoor !== 'no') return 'indoor';
+ if (relation.tags.indoor && relation.tags.indoor !== 'no') { return 'indoor'; }
if ((relation.tags.building && relation.tags.building !== 'no') ||
- (relation.tags['building:part'] && relation.tags['building:part'] !== 'no')) return 'building';
+ (relation.tags['building:part'] && relation.tags['building:part'] !== 'no')) { return 'building'; }
}
}
// don't flag issues where merging would create degenerate ways
if (way.nodes.length <= 2 ||
- (way.isClosed() && way.nodes.length <= 4)) return false;
+ (way.isClosed() && way.nodes.length <= 4)) { return false; }
var bbox = way.extent(graph).bbox();
var hypotenuseMeters = geoSphericalDistance([bbox.minX, bbox.minY], [bbox.maxX, bbox.maxY]);
// don't flag close nodes in very small ways
- if (hypotenuseMeters < 1.5) return false;
+ if (hypotenuseMeters < 1.5) { return false; }
return true;
}
function getIssuesForWay(way) {
- if (!shouldCheckWay(way)) return [];
+ if (!shouldCheckWay(way)) { return []; }
var issues = [],
nodes = graph.childNodes(way);
var node2 = nodes[i+1];
var issue = getWayIssueIfAny(node1, node2, way);
- if (issue) issues.push(issue);
+ if (issue) { issues.push(issue); }
}
return issues;
}
function checkForCloseness(node1, node2, way) {
var issue = getWayIssueIfAny(node1, node2, way);
- if (issue) issues.push(issue);
+ if (issue) { issues.push(issue); }
}
for (var i = 0; i < parentWays.length; i++) {
var parentWay = parentWays[i];
- if (!shouldCheckWay(parentWay)) continue;
+ if (!shouldCheckWay(parentWay)) { continue; }
var lastIndex = parentWay.nodes.length - 1;
for (var j = 0; j < parentWay.nodes.length; j++) {
}
function thresholdMetersForWay(way) {
- if (!shouldCheckWay(way)) return 0;
+ if (!shouldCheckWay(way)) { return 0; }
var wayType = wayTypeFor(way);
// don't flag boundaries since they might be highly detailed and can't be easily verified
- if (wayType === 'boundary') return 0;
+ if (wayType === 'boundary') { return 0; }
// expect some features to be mapped with higher levels of detail
- if (wayType === 'indoor') return 0.01;
- if (wayType === 'building') return 0.05;
- if (wayType === 'path') return 0.1;
+ if (wayType === 'indoor') { return 0.01; }
+ if (wayType === 'building') { return 0.05; }
+ if (wayType === 'path') { return 0.1; }
return 0.2;
}
for (var j = 0; j < intersected.length; j++) {
var nearby = intersected[j];
- if (nearby.id === node.id) continue;
- if (nearby.type !== 'node' || nearby.geometry(graph) !== 'point') continue;
+ if (nearby.id === node.id) { continue; }
+ if (nearby.type !== 'node' || nearby.geometry(graph) !== 'point') { continue; }
if (nearby.loc === node.loc ||
geoSphericalDistance(node.loc, nearby.loc) < pointThresholdMeters) {
break;
}
}
- if (zAxisDifferentiates) continue;
+ if (zAxisDifferentiates) { continue; }
issues.push(new validationIssue({
type: type,
return thresholdMetersForWay(parentWay);
});
- var threshold = Math.min(...thresholds);
+ var threshold = Math.min.apply(Math, thresholds);
var distance = geoSphericalDistance(node1.loc, node2.loc);
- if (distance > threshold) return null;
+ if (distance > threshold) { return null; }
}
return new validationIssue({
return featureType === 'highway' || featureType === 'railway' || featureType === 'waterway';
}
-
- function getFeatureTypeForCrossingCheck(way, graph) {
- var feature = getFeatureWithFeatureTypeTagsForWay(way, graph);
- return getFeatureType(feature, graph);
- }
-
// discard
var ignoredBuildings = {
demolished: true, dismantled: true, proposed: true, razed: true
function getFeatureType(entity, graph) {
var geometry = entity.geometry(graph);
- if (geometry !== 'line' && geometry !== 'area') return null;
+ if (geometry !== 'line' && geometry !== 'area') { return null; }
var tags = entity.tags;
- if (hasTag(tags, 'building') && !ignoredBuildings[tags.building]) return 'building';
- if (hasTag(tags, 'highway') && osmRoutableHighwayTagValues[tags.highway]) return 'highway';
+ if (hasTag(tags, 'building') && !ignoredBuildings[tags.building]) { return 'building'; }
+ if (hasTag(tags, 'highway') && osmRoutableHighwayTagValues[tags.highway]) { return 'highway'; }
// don't check railway or waterway areas
- if (geometry !== 'line') return null;
+ if (geometry !== 'line') { return null; }
- if (hasTag(tags, 'railway') && osmRailwayTrackTagValues[tags.railway]) return 'railway';
- if (hasTag(tags, 'waterway') && osmFlowingWaterwayTagValues[tags.waterway]) return 'waterway';
+ if (hasTag(tags, 'railway') && osmRailwayTrackTagValues[tags.railway]) { return 'railway'; }
+ if (hasTag(tags, 'waterway') && osmFlowingWaterwayTagValues[tags.waterway]) { return 'waterway'; }
return null;
}
- function isLegitCrossing(way1, featureType1, way2, featureType2) {
- var tags1 = way1.tags;
- var tags2 = way2.tags;
+ function isLegitCrossing(tags1, featureType1, tags2, featureType2) {
// assume 0 by default
var level1 = tags1.level || '0';
var layer2 = tags2.layer || '0';
if (allowsBridge(featureType1) && allowsBridge(featureType2)) {
- if (hasTag(tags1, 'bridge') && !hasTag(tags2, 'bridge')) return true;
- if (!hasTag(tags1, 'bridge') && hasTag(tags2, 'bridge')) return true;
+ if (hasTag(tags1, 'bridge') && !hasTag(tags2, 'bridge')) { return true; }
+ if (!hasTag(tags1, 'bridge') && hasTag(tags2, 'bridge')) { return true; }
// crossing bridges must use different layers
- if (hasTag(tags1, 'bridge') && hasTag(tags2, 'bridge') && layer1 !== layer2) return true;
- } else if (allowsBridge(featureType1) && hasTag(tags1, 'bridge')) return true;
- else if (allowsBridge(featureType2) && hasTag(tags2, 'bridge')) return true;
+ if (hasTag(tags1, 'bridge') && hasTag(tags2, 'bridge') && layer1 !== layer2) { return true; }
+ } else if (allowsBridge(featureType1) && hasTag(tags1, 'bridge')) { return true; }
+ else if (allowsBridge(featureType2) && hasTag(tags2, 'bridge')) { return true; }
if (allowsTunnel(featureType1) && allowsTunnel(featureType2)) {
- if (hasTag(tags1, 'tunnel') && !hasTag(tags2, 'tunnel')) return true;
- if (!hasTag(tags1, 'tunnel') && hasTag(tags2, 'tunnel')) return true;
+ if (hasTag(tags1, 'tunnel') && !hasTag(tags2, 'tunnel')) { return true; }
+ if (!hasTag(tags1, 'tunnel') && hasTag(tags2, 'tunnel')) { return true; }
// crossing tunnels must use different layers
- if (hasTag(tags1, 'tunnel') && hasTag(tags2, 'tunnel') && layer1 !== layer2) return true;
- } else if (allowsTunnel(featureType1) && hasTag(tags1, 'tunnel')) return true;
- else if (allowsTunnel(featureType2) && hasTag(tags2, 'tunnel')) return true;
+ if (hasTag(tags1, 'tunnel') && hasTag(tags2, 'tunnel') && layer1 !== layer2) { return true; }
+ } else if (allowsTunnel(featureType1) && hasTag(tags1, 'tunnel')) { return true; }
+ else if (allowsTunnel(featureType2) && hasTag(tags2, 'tunnel')) { return true; }
// don't flag crossing waterways and pier/highways
- if (featureType1 === 'waterway' && featureType2 === 'highway' && tags2.man_made === 'pier') return true;
- if (featureType2 === 'waterway' && featureType1 === 'highway' && tags1.man_made === 'pier') return true;
+ if (featureType1 === 'waterway' && featureType2 === 'highway' && tags2.man_made === 'pier') { return true; }
+ if (featureType2 === 'waterway' && featureType1 === 'highway' && tags1.man_made === 'pier') { return true; }
if (featureType1 === 'building' || featureType2 === 'building') {
// for building crossings, different layers are enough
- if (layer1 !== layer2) return true;
+ if (layer1 !== layer2) { return true; }
}
return false;
}
}
return {};
}
- if (featureType1 === 'waterway') return {};
- if (featureType1 === 'railway') return {};
+ if (featureType1 === 'waterway') { return {}; }
+ if (featureType1 === 'railway') { return {}; }
} else {
var featureTypes = [featureType1, featureType2];
if (featureTypes.indexOf('highway') !== -1) {
if (featureTypes.indexOf('railway') !== -1) {
+ if (!bothLines) { return {}; }
+
+ var isTram = entity1.tags.railway === 'tram' || entity2.tags.railway === 'tram';
+
if (osmPathHighwayTagValues[entity1.tags.highway] ||
osmPathHighwayTagValues[entity2.tags.highway]) {
- // path-rail connections use this tag
- return bothLines ? { railway: 'crossing' } : {};
+
+ // path-tram connections use this tag
+ if (isTram) { return { railway: 'tram_crossing' }; }
+
+ // other path-rail connections use this tag
+ return { railway: 'crossing' };
} else {
- // road-rail connections use this tag
- return bothLines ? { railway: 'level_crossing' } : {};
+ // path-tram connections use this tag
+ if (isTram) { return { railway: 'tram_level_crossing' }; }
+
+ // other road-rail connections use this tag
+ return { railway: 'level_crossing' };
}
}
if (featureTypes.indexOf('waterway') !== -1) {
// do not allow fords on structures
- if (hasTag(entity1.tags, 'tunnel') && hasTag(entity2.tags, 'tunnel')) return null;
- if (hasTag(entity1.tags, 'bridge') && hasTag(entity2.tags, 'bridge')) return null;
+ if (hasTag(entity1.tags, 'tunnel') && hasTag(entity2.tags, 'tunnel')) { return null; }
+ if (hasTag(entity1.tags, 'bridge') && hasTag(entity2.tags, 'bridge')) { return null; }
if (highwaysDisallowingFords[entity1.tags.highway] ||
highwaysDisallowingFords[entity2.tags.highway]) {
function findCrossingsByWay(way1, graph, tree) {
var edgeCrossInfos = [];
- if (way1.type !== 'way') return edgeCrossInfos;
+ if (way1.type !== 'way') { return edgeCrossInfos; }
- var way1FeatureType = getFeatureTypeForCrossingCheck(way1, graph);
- if (way1FeatureType === null) return edgeCrossInfos;
+ var taggedFeature1 = getFeatureWithFeatureTypeTagsForWay(way1, graph);
+ var way1FeatureType = getFeatureType(taggedFeature1, graph);
+ if (way1FeatureType === null) { return edgeCrossInfos; }
var checkedSingleCrossingWays = {};
var n1, n2, nA, nB, nAId, nBId;
var segment1, segment2;
var oneOnly;
- var segmentInfos, segment2Info, way2, way2FeatureType;
+ var segmentInfos, segment2Info, way2, taggedFeature2, way2FeatureType;
var way1Nodes = graph.childNodes(way1);
var comparedWays = {};
for (i = 0; i < way1Nodes.length - 1; i++) {
segment2Info = segmentInfos[j];
// don't check for self-intersection in this validation
- if (segment2Info.wayId === way1.id) continue;
+ if (segment2Info.wayId === way1.id) { continue; }
// skip if this way was already checked and only one issue is needed
- if (checkedSingleCrossingWays[segment2Info.wayId]) continue;
+ if (checkedSingleCrossingWays[segment2Info.wayId]) { continue; }
// mark this way as checked even if there are no crossings
comparedWays[segment2Info.wayId] = true;
way2 = graph.hasEntity(segment2Info.wayId);
- if (!way2) continue;
-
+ if (!way2) { continue; }
+ taggedFeature2 = getFeatureWithFeatureTypeTagsForWay(way2, graph);
// only check crossing highway, waterway, building, and railway
- way2FeatureType = getFeatureTypeForCrossingCheck(way2, graph);
+ way2FeatureType = getFeatureType(taggedFeature2, graph);
+
if (way2FeatureType === null ||
- isLegitCrossing(way1, way1FeatureType, way2, way2FeatureType)) {
+ isLegitCrossing(taggedFeature1.tags, way1FeatureType, taggedFeature2.tags, way2FeatureType)) {
continue;
}
continue;
}
nA = graph.hasEntity(nAId);
- if (!nA) continue;
+ if (!nA) { continue; }
nB = graph.hasEntity(nBId);
- if (!nB) continue;
+ if (!nB) { continue; }
segment1 = [n1.loc, n2.loc];
segment2 = [nA.loc, nB.loc];
function waysToCheck(entity, graph) {
var featureType = getFeatureType(entity, graph);
- if (!featureType) return [];
+ if (!featureType) { return []; }
if (entity.type === 'way') {
return [entity];
loc: crossing.crossPoint,
dynamicFixes: function(context) {
var mode = context.mode();
- if (!mode || mode.id !== 'select' || mode.selectedIDs().length !== 1) return [];
+ if (!mode || mode.id !== 'select' || mode.selectedIDs().length !== 1) { return []; }
var selectedIndex = this.entityIds[0] === mode.selectedIDs()[0] ? 0 : 1;
var selectedFeatureType = this.data.featureTypes[selectedIndex];
} else if (context.graph().geometry(this.entityIds[0]) === 'line' &&
context.graph().geometry(this.entityIds[1]) === 'line') {
- // don't recommend adding bridges to waterways since they're uncommmon
+ // don't recommend adding bridges to waterways since they're uncommon
if (allowsBridge(selectedFeatureType) && selectedFeatureType !== 'waterway') {
fixes.push(makeAddBridgeOrTunnelFix('add_a_bridge', 'temaki-bridge', 'bridge'));
}
- // don't recommend adding tunnels under waterways since they're uncommmon
+ // don't recommend adding tunnels under waterways since they're uncommon
var skipTunnelFix = otherFeatureType === 'waterway' && selectedFeatureType !== 'waterway';
if (allowsTunnel(selectedFeatureType) && !skipTunnelFix) {
fixes.push(makeAddBridgeOrTunnelFix('add_a_tunnel', 'temaki-tunnel', 'tunnel'));
title: _t('issues.fix.' + fixTitleID + '.title'),
onClick: function(context) {
var mode = context.mode();
- if (!mode || mode.id !== 'select') return;
+ if (!mode || mode.id !== 'select') { return; }
var selectedIDs = mode.selectedIDs();
- if (selectedIDs.length !== 1) return;
+ if (selectedIDs.length !== 1) { return; }
var selectedWayID = selectedIDs[0];
- if (!context.hasEntity(selectedWayID)) return;
+ if (!context.hasEntity(selectedWayID)) { return; }
var resultWayIDs = [selectedWayID];
var a1 = geoAngle(edgeNodes[0], edgeNodes[1], projection) + Math.PI;
var a2 = geoAngle(graph.entity(crossedEdge[0]), graph.entity(crossedEdge[1]), projection) + Math.PI;
var crossingAngle = Math.max(a1, a2) - Math.min(a1, a2);
- if (crossingAngle > Math.PI) crossingAngle -= Math.PI;
+ if (crossingAngle > Math.PI) { crossingAngle -= Math.PI; }
// lengthen the structure to account for the angle of the crossing
structLengthMeters = ((structLengthMeters / 2) / Math.sin(crossingAngle)) * 2;
// if the edge is too short to subdivide as desired, then
// just bound the structure at the existing end node
- if (!newNode) newNode = endNode;
+ if (!newNode) { newNode = endNode; }
var splitAction = actionSplit(newNode.id)
.limitWays(resultWayIDs); // only split selected or created ways
onClick: function(context) {
var mode = context.mode();
- if (!mode || mode.id !== 'select') return;
+ if (!mode || mode.id !== 'select') { return; }
var selectedIDs = mode.selectedIDs();
- if (selectedIDs.length !== 1) return;
+ if (selectedIDs.length !== 1) { return; }
var selectedID = selectedIDs[0];
if (!this.issue.entityIds.some(function(entityId) {
return entityId === selectedID;
- })) return;
+ })) { return; }
var entity = context.hasEntity(selectedID);
- if (!entity) return;
+ if (!entity) { return; }
var tags = Object.assign({}, entity.tags); // shallow copy
var layer = tags.layer && Number(tags.layer);
var validation = function checkDisconnectedWay(entity, graph) {
var routingIslandWays = routingIslandForEntity(entity);
- if (!routingIslandWays) return [];
+ if (!routingIslandWays) { return []; }
return [new validationIssue({
type: type,
var textDirection = _mainLocalizer.textDirection();
var startFix = makeContinueDrawingFixIfAllowed(textDirection, singleEntity.first(), 'start');
- if (startFix) fixes.push(startFix);
+ if (startFix) { fixes.push(startFix); }
var endFix = makeContinueDrawingFixIfAllowed(textDirection, singleEntity.last(), 'end');
- if (endFix) fixes.push(endFix);
+ if (endFix) { fixes.push(endFix); }
}
if (!fixes.length) {
fixes.push(new validationIssueFix({
function isConnectedVertex(vertex) {
// assume ways overlapping unloaded tiles are connected to the wider road network - #5938
var osm = services.osm;
- if (osm && !osm.isDataLoaded(vertex.loc)) return true;
+ if (osm && !osm.isDataLoaded(vertex.loc)) { return true; }
// entrances are considered connected
if (vertex.tags.entrance &&
- vertex.tags.entrance !== 'no') return true;
- if (vertex.tags.amenity === 'parking_entrance') return true;
+ vertex.tags.entrance !== 'no') { return true; }
+ if (vertex.tags.amenity === 'parking_entrance') { return true; }
return false;
}
function isRoutableNode(node) {
// treat elevators as distinct features in the highway network
- if (node.tags.highway === 'elevator') return true;
+ if (node.tags.highway === 'elevator') { return true; }
return false;
}
function isRoutableWay(way, ignoreInnerWays) {
- if (isTaggedAsHighway(way) || way.tags.route === 'ferry') return true;
+ if (isTaggedAsHighway(way) || way.tags.route === 'ferry') { return true; }
return graph.parentRelations(way).some(function(parentRelation) {
if (parentRelation.tags.type === 'route' &&
- parentRelation.tags.route === 'ferry') return true;
+ parentRelation.tags.route === 'ferry') { return true; }
if (parentRelation.isMultipolygon() &&
isTaggedAsHighway(parentRelation) &&
- (!ignoreInnerWays || parentRelation.memberById(way.id).role !== 'inner')) return true;
+ (!ignoreInnerWays || parentRelation.memberById(way.id).role !== 'inner')) { return true; }
});
}
function makeContinueDrawingFixIfAllowed(textDirection, vertexID, whichEnd) {
var vertex = graph.hasEntity(vertexID);
- if (!vertex || vertex.tags.noexit === 'yes') return null;
+ if (!vertex || vertex.tags.noexit === 'yes') { return null; }
var useLeftContinue = (whichEnd === 'start' && textDirection === 'ltr') ||
(whichEnd === 'end' && textDirection === 'rtl');
var vertexId = this.entityIds[0];
var vertex = context.hasEntity(vertexId);
- if (!way || !vertex) return;
+ if (!way || !vertex) { return; }
// make sure the vertex is actually visible and editable
var map = context.map();
var validation = function checkFixmeTag(entity) {
- if (!entity.tags.fixme) return [];
+ if (!entity.tags.fixme) { return []; }
// don't flag fixmes on features added by the user
- if (entity.version === undefined) return [];
+ if (entity.version === undefined) { return []; }
if (entity.v !== undefined) {
var baseEntity = context.history().base().hasEntity(entity.id);
// don't flag fixmes added by the user on existing features
- if (!baseEntity || !baseEntity.tags.fixme) return [];
+ if (!baseEntity || !baseEntity.tags.fixme) { return []; }
}
return [new validationIssue({
var validation = function checkImpossibleOneway(entity, graph) {
- if (entity.type !== 'way' || entity.geometry(graph) !== 'line') return [];
+ if (entity.type !== 'way' || entity.geometry(graph) !== 'line') { return []; }
- if (entity.isClosed()) return [];
+ if (entity.isClosed()) { return []; }
- if (!typeForWay(entity)) return [];
+ if (!typeForWay(entity)) { return []; }
- if (!isOneway(entity)) return [];
+ if (!isOneway(entity)) { return []; }
var firstIssues = issuesForNode(entity, entity.first());
var lastIssues = issuesForNode(entity, entity.last());
return firstIssues.concat(lastIssues);
function typeForWay(way) {
- if (way.geometry(graph) !== 'line') return null;
+ if (way.geometry(graph) !== 'line') { return null; }
- if (osmRoutableHighwayTagValues[way.tags.highway]) return 'highway';
- if (osmFlowingWaterwayTagValues[way.tags.waterway]) return 'waterway';
+ if (osmRoutableHighwayTagValues[way.tags.highway]) { return 'highway'; }
+ if (osmFlowingWaterwayTagValues[way.tags.waterway]) { return 'waterway'; }
return null;
}
function isOneway(way) {
- if (way.tags.oneway === 'yes') return true;
- if (way.tags.oneway) return false;
+ if (way.tags.oneway === 'yes') { return true; }
+ if (way.tags.oneway) { return false; }
for (var key in way.tags) {
if (osmOneWayTags[key] && osmOneWayTags[key][way.tags[key]]) {
for (var index in way.nodes) {
if (way.nodes[index] === nodeID) {
occurences += 1;
- if (occurences > 1) return true;
+ if (occurences > 1) { return true; }
}
}
return false;
if (wayType === 'highway') {
// entrances are considered connected
- if (node.tags.entrance && node.tags.entrance !== 'no') return true;
- if (node.tags.amenity === 'parking_entrance') return true;
+ if (node.tags.entrance && node.tags.entrance !== 'no') { return true; }
+ if (node.tags.amenity === 'parking_entrance') { return true; }
} else if (wayType === 'waterway') {
if (node.id === way.first()) {
// multiple waterways may start at the same spring
- if (node.tags.natural === 'spring') return true;
+ if (node.tags.natural === 'spring') { return true; }
} else {
// multiple waterways may end at the same drain
- if (node.tags.manhole === 'drain') return true;
+ if (node.tags.manhole === 'drain') { return true; }
}
}
return graph.parentWays(node).some(function(parentWay) {
- if (parentWay.id === way.id) return false;
+ if (parentWay.id === way.id) { return false; }
if (wayType === 'highway') {
// allow connections to highway areas
if (parentWay.geometry(graph) === 'area' &&
- osmRoutableHighwayTagValues[parentWay.tags.highway]) return true;
+ osmRoutableHighwayTagValues[parentWay.tags.highway]) { return true; }
// count connections to ferry routes as connected
- if (parentWay.tags.route === 'ferry') return true;
+ if (parentWay.tags.route === 'ferry') { return true; }
return graph.parentRelations(parentWay).some(function(parentRelation) {
if (parentRelation.tags.type === 'route' &&
- parentRelation.tags.route === 'ferry') return true;
+ parentRelation.tags.route === 'ferry') { return true; }
// allow connections to highway multipolygons
return parentRelation.isMultipolygon() && osmRoutableHighwayTagValues[parentRelation.tags.highway];
} else if (wayType === 'waterway') {
// multiple waterways may start or end at a water body at the same node
if (parentWay.tags.natural === 'water' ||
- parentWay.tags.natural === 'coastline') return true;
+ parentWay.tags.natural === 'coastline') { return true; }
}
return false;
});
var wayType = typeForWay(way);
// ignore if this way is self-connected at this node
- if (nodeOccursMoreThanOnce(way, nodeID)) return [];
+ if (nodeOccursMoreThanOnce(way, nodeID)) { return []; }
var osm = services.osm;
- if (!osm) return [];
+ if (!osm) { return []; }
var node = graph.hasEntity(nodeID);
// ignore if this node or its tile are unloaded
- if (!node || !osm.isDataLoaded(node.loc)) return [];
+ if (!node || !osm.isDataLoaded(node.loc)) { return []; }
- if (isConnectedViaOtherTypes(way, node)) return [];
+ if (isConnectedViaOtherTypes(way, node)) { return []; }
var attachedWaysOfSameType = graph.parentWays(node).filter(function(parentWay) {
- if (parentWay.id === way.id) return false;
+ if (parentWay.id === way.id) { return false; }
return typeForWay(parentWay) === wayType;
});
// assume it's okay for waterways to start or end disconnected for now
- if (wayType === 'waterway' && attachedWaysOfSameType.length === 0) return [];
+ if (wayType === 'waterway' && attachedWaysOfSameType.length === 0) { return []; }
var attachedOneways = attachedWaysOfSameType.filter(function(attachedWay) {
return isOneway(attachedWay);
});
// ignore if the way is connected to some non-oneway features
- if (attachedOneways.length < attachedWaysOfSameType.length) return [];
+ if (attachedOneways.length < attachedWaysOfSameType.length) { return []; }
if (attachedOneways.length) {
var connectedEndpointsOkay = attachedOneways.some(function(attachedOneway) {
- if ((isFirst ? attachedOneway.first() : attachedOneway.last()) !== nodeID) return true;
- if (nodeOccursMoreThanOnce(attachedOneway, nodeID)) return true;
+ if ((isFirst ? attachedOneway.first() : attachedOneway.last()) !== nodeID) { return true; }
+ if (nodeOccursMoreThanOnce(attachedOneway, nodeID)) { return true; }
return false;
});
- if (connectedEndpointsOkay) return [];
+ if (connectedEndpointsOkay) { return []; }
}
var placement = isFirst ? 'start' : 'end',
var entitySources = entity.tags && entity.tags.source && entity.tags.source.split(';');
- if (!entitySources) return [];
+ if (!entitySources) { return []; }
var issues = [];
invalidSources.forEach(function(invalidSource) {
var hasInvalidSource = entitySources.some(function(source) {
- if (!source.match(new RegExp(invalidSource.regex, 'i'))) return false;
- if (invalidSource.exceptRegex && source.match(new RegExp(invalidSource.exceptRegex, 'i'))) return false;
+ if (!source.match(new RegExp(invalidSource.regex, 'i'))) { return false; }
+ if (invalidSource.exceptRegex && source.match(new RegExp(invalidSource.exceptRegex, 'i'))) { return false; }
return true;
});
- if (!hasInvalidSource) return;
+ if (!hasInvalidSource) { return; }
issues.push(new validationIssue({
type: type,
var type = 'maprules';
var validation = function checkMaprules(entity, graph) {
- if (!services.maprules) return [];
+ if (!services.maprules) { return []; }
var rules = services.maprules.validationRules();
var issues = [];
var type = 'mismatched_geometry';
function tagSuggestingLineIsArea(entity) {
- if (entity.type !== 'way' || entity.isClosed()) return null;
+ if (entity.type !== 'way' || entity.isClosed()) { return null; }
var tagSuggestingArea = entity.tagSuggestingArea();
if (!tagSuggestingArea) {
function makeConnectEndpointsFixOnClick(way, graph) {
// must have at least three nodes to close this automatically
- if (way.nodes.length < 3) return null;
+ if (way.nodes.length < 3) { return null; }
var nodes = graph.childNodes(way), testNodes;
var firstToLastDistanceMeters = geoSphericalDistance(nodes[0].loc, nodes[nodes.length-1].loc);
function lineTaggedAsAreaIssue(entity) {
var tagSuggestingArea = tagSuggestingLineIsArea(entity);
- if (!tagSuggestingArea) return null;
+ if (!tagSuggestingArea) { return null; }
return new validationIssue({
type: type,
function vertexTaggedAsPointIssue(entity, graph) {
// we only care about nodes
- if (entity.type !== 'node') return null;
+ if (entity.type !== 'node') { return null; }
// ignore tagless points
- if (Object.keys(entity.tags).length === 0) return null;
+ if (Object.keys(entity.tags).length === 0) { return null; }
// address lines are special so just ignore them
- if (entity.isOnAddressLine(graph)) return null;
+ if (entity.isOnAddressLine(graph)) { return null; }
var geometry = entity.geometry(graph);
var allowedGeometries = osmNodeGeometriesForTags(entity.tags);
!entity.isMultipolygon() ||
entity.isDegenerate() ||
// cannot determine issues for incompletely-downloaded relations
- !entity.isComplete(graph)) return null;
+ !entity.isComplete(graph)) { return null; }
var sequences = osmJoinWays(entity.members, graph);
for (var i in sequences) {
var sequence = sequences[i];
- if (!sequence.nodes) continue;
+ if (!sequence.nodes) { continue; }
var firstNode = sequence.nodes[0];
var lastNode = sequence.nodes[sequence.nodes.length - 1];
// part is closed if the first and last nodes are the same
- if (firstNode === lastNode) continue;
+ if (firstNode === lastNode) { continue; }
var issue = new validationIssue({
type: type,
var issues = [];
if (entity.type === 'way') {
graph.parentRelations(entity).forEach(function(relation) {
- if (!relation.isMultipolygon()) return;
+ if (!relation.isMultipolygon()) { return; }
var member = relation.memberById(entity.id);
if (member && isMissingRole(member)) {
subtype = 'highway_classification';
}
- if (!subtype) return [];
+ if (!subtype) { return []; }
var messageID = subtype === 'highway_classification' ? 'unknown_road' : 'missing_tag.' + subtype;
var referenceID = subtype === 'highway_classification' ? 'unknown_road' : 'missing_tag';
}
// remove spaces, punctuation, diacritics
- var simplify = (str) => {
+ var simplify = function (str) {
return diacritics.remove(
str
.replace(/&/g, 'and')
// nsimple: "thaiexpress",
// kvnnsimple: "amenity/fast_food|thaiexpress"
// }
- var to_parts = (kvnd) => {
- const parts = {};
+ var to_parts = function (kvnd) {
+ var parts = {};
parts.kvnd = kvnd;
- const kvndparts = kvnd.split('~', 2);
- if (kvndparts.length > 1) parts.d = kvndparts[1];
+ var kvndparts = kvnd.split('~', 2);
+ if (kvndparts.length > 1) { parts.d = kvndparts[1]; }
parts.kvn = kvndparts[0];
- const kvnparts = parts.kvn.split('|', 2);
- if (kvnparts.length > 1) parts.n = kvnparts[1];
+ var kvnparts = parts.kvn.split('|', 2);
+ if (kvnparts.length > 1) { parts.n = kvnparts[1]; }
parts.kv = kvnparts[0];
- const kvparts = parts.kv.split('/', 2);
+ var kvparts = parts.kv.split('/', 2);
parts.k = kvparts[0];
parts.v = kvparts[1];
};
var matchGroups = {adult_gaming_centre:["amenity/casino","amenity/gambling","leisure/adult_gaming_centre"],beauty:["shop/beauty","shop/hairdresser_supply"],bed:["shop/bed","shop/furniture"],beverages:["shop/alcohol","shop/beverages"],camping:["leisure/park","tourism/camp_site","tourism/caravan_site"],car_parts:["shop/car_parts","shop/car_repair","shop/tires","shop/tyres"],confectionery:["shop/candy","shop/chocolate","shop/confectionery"],convenience:["shop/beauty","shop/chemist","shop/convenience","shop/cosmetics","shop/newsagent"],coworking:["amenity/coworking_space","office/coworking","office/coworking_space"],electronics:["office/telecommunication","shop/computer","shop/electronics","shop/hifi","shop/mobile","shop/mobile_phone","shop/telecommunication"],fashion:["shop/accessories","shop/bag","shop/botique","shop/clothes","shop/department_store","shop/fashion","shop/fashion_accessories","shop/sports","shop/shoes"],financial:["amenity/bank","office/accountant","office/financial","office/financial_advisor","office/tax_advisor","shop/tax"],fitness:["leisure/fitness_centre","leisure/fitness_center","leisure/sports_centre","leisure/sports_center"],food:["amenity/cafe","amenity/fast_food","amenity/ice_cream","amenity/restaurant","shop/bakery","shop/ice_cream","shop/pastry","shop/tea","shop/coffee"],fuel:["amenity/fuel","shop/gas","shop/convenience;gas","shop/gas;convenience"],gift:["shop/gift","shop/card","shop/cards","shop/stationery"],hardware:["shop/carpet","shop/diy","shop/doityourself","shop/doors","shop/electrical","shop/flooring","shop/hardware","shop/power_tools","shop/tool_hire","shop/tools","shop/trade"],health_food:["shop/health","shop/health_food","shop/herbalist","shop/nutrition_supplements"],houseware:["shop/houseware","shop/interior_decoration"],lodging:["tourism/hotel","tourism/motel"],money_transfer:["amenity/money_transfer","shop/money_transfer"],outdoor:["shop/outdoor","shop/sports"],rental:["amenity/bicycle_rental","amenity/boat_rental","amenity/car_rental","amenity/truck_rental","amenity/vehicle_rental","shop/rental"],school:["amenity/childcare","amenity/college","amenity/kindergarten","amenity/language_school","amenity/prep_school","amenity/school","amenity/university"],supermarket:["shop/food","shop/frozen_food","shop/greengrocer","shop/grocery","shop/supermarket","shop/wholesale"],variety_store:["shop/variety_store","shop/supermarket","shop/discount","shop/convenience"],vending:["amenity/vending_machine","shop/vending_machine"],wholesale:["shop/wholesale","shop/supermarket","shop/department_store"]};
- var match_groups = {
+ var require$$0 = {
matchGroups: matchGroups
};
- var match_groups$1 = /*#__PURE__*/Object.freeze({
- __proto__: null,
- matchGroups: matchGroups,
- 'default': match_groups
- });
-
- var require$$0 = getCjsExportFromNamespace(match_groups$1);
+ var matchGroups$1 = require$$0.matchGroups;
- const matchGroups$1 = require$$0.matchGroups;
-
- var matcher$1 = () => {
- let _warnings = []; // array of match conflict pairs
- let _ambiguous = {};
- let _matchIndex = {};
- let matcher = {};
+ var matcher$1 = function () {
+ var _warnings = []; // array of match conflict pairs
+ var _ambiguous = {};
+ var _matchIndex = {};
+ var matcher = {};
// Create an index of all the keys/simplenames for fast matching
- matcher.buildMatchIndex = (brands) => {
+ matcher.buildMatchIndex = function (brands) {
// two passes - once for primary names, once for secondary/alternate names
- Object.keys(brands).forEach(kvnd => insertNames(kvnd, 'primary'));
- Object.keys(brands).forEach(kvnd => insertNames(kvnd, 'secondary'));
+ Object.keys(brands).forEach(function (kvnd) { return insertNames(kvnd, 'primary'); });
+ Object.keys(brands).forEach(function (kvnd) { return insertNames(kvnd, 'secondary'); });
function insertNames(kvnd, which) {
- const obj = brands[kvnd];
- const parts = to_parts(kvnd);
+ var obj = brands[kvnd];
+ var parts = to_parts(kvnd);
// Exit early for ambiguous names in the second pass.
// They were collected in the first pass and we don't gather alt names for them.
- if (which === 'secondary' && parts.d) return;
+ if (which === 'secondary' && parts.d) { return; }
if (obj.countryCodes) {
parts.countryCodes = obj.countryCodes.slice(); // copy
}
- const nomatches = (obj.nomatch || []);
- if (nomatches.some(s => s === kvnd)) {
- console.log(`WARNING match/nomatch conflict for ${kvnd}`);
+ var nomatches = (obj.nomatch || []);
+ if (nomatches.some(function (s) { return s === kvnd; })) {
+ console.log(("WARNING match/nomatch conflict for " + kvnd));
return;
}
- const match_kv = [parts.kv]
+ var match_kv = [parts.kv]
.concat(obj.matchTags || [])
- .concat([`${parts.k}/yes`, `building/yes`]) // #3454 - match some generic tags
- .map(s => s.toLowerCase());
+ .concat([((parts.k) + "/yes"), "building/yes"]) // #3454 - match some generic tags
+ .map(function (s) { return s.toLowerCase(); });
- let match_nsimple = [];
+ var match_nsimple = [];
if (which === 'primary') {
match_nsimple = [parts.n]
.concat(obj.matchNames || [])
.map(simplify);
}
- if (!match_nsimple.length) return; // nothing to do
+ if (!match_nsimple.length) { return; } // nothing to do
- match_kv.forEach(kv => {
- match_nsimple.forEach(nsimple => {
+ match_kv.forEach(function (kv) {
+ match_nsimple.forEach(function (nsimple) {
if (parts.d) {
// Known ambiguous names with disambiguation string ~(USA) / ~(Canada)
// FIXME: Name collisions will overwrite the initial entry (ok for now)
- if (!_ambiguous[kv]) _ambiguous[kv] = {};
+ if (!_ambiguous[kv]) { _ambiguous[kv] = {}; }
_ambiguous[kv][nsimple] = parts;
} else {
// Names we mostly expect to be unique..
- if (!_matchIndex[kv]) _matchIndex[kv] = {};
+ if (!_matchIndex[kv]) { _matchIndex[kv] = {}; }
- const m = _matchIndex[kv][nsimple];
+ var m = _matchIndex[kv][nsimple];
if (m) { // There already is a match for this name, skip it
// Warn if we detect collisions in a primary name.
// Skip warning if a secondary name or a generic `*=yes` tag - #2972 / #3454
if (which === 'primary' && !/\/yes$/.test(kv)) {
- _warnings.push([m.kvnd, `${kvnd} (${kv}/${nsimple})`]);
+ _warnings.push([m.kvnd, (kvnd + " (" + kv + "/" + nsimple + ")")]);
}
} else {
_matchIndex[kv][nsimple] = parts; // insert
// pass a `key`, `value`, `name` and return the best match,
// `countryCode` optional (if supplied, must match that too)
- matcher.matchKVN = (key, value, name, countryCode) => {
- return matcher.matchParts(to_parts(`${key}/${value}|${name}`), countryCode);
+ matcher.matchKVN = function (key, value, name, countryCode) {
+ return matcher.matchParts(to_parts((key + "/" + value + "|" + name)), countryCode);
};
// pass a parts object and return the best match,
// `countryCode` optional (if supplied, must match that too)
- matcher.matchParts = (parts, countryCode) => {
- let match = null;
- let inGroup = false;
+ matcher.matchParts = function (parts, countryCode) {
+ var match = null;
+ var inGroup = false;
// fixme: we currently return a single match for ambiguous
match = _ambiguous[parts.kv] && _ambiguous[parts.kv][parts.nsimple];
- if (match && matchesCountryCode(match)) return match;
+ if (match && matchesCountryCode(match)) { return match; }
// try to return an exact match
match = _matchIndex[parts.kv] && _matchIndex[parts.kv][parts.nsimple];
- if (match && matchesCountryCode(match)) return match;
+ if (match && matchesCountryCode(match)) { return match; }
// look in match groups
- for (let mg in matchGroups$1) {
- const matchGroup = matchGroups$1[mg];
+ for (var mg in matchGroups$1) {
+ var matchGroup = matchGroups$1[mg];
match = null;
inGroup = false;
- for (let i = 0; i < matchGroup.length; i++) {
- const otherkv = matchGroup[i].toLowerCase();
+ for (var i = 0; i < matchGroup.length; i++) {
+ var otherkv = matchGroup[i].toLowerCase();
if (!inGroup) {
inGroup = otherkv === parts.kv;
}
return null;
function matchesCountryCode(match) {
- if (!countryCode) return true;
- if (!match.countryCodes) return true;
+ if (!countryCode) { return true; }
+ if (!match.countryCodes) { return true; }
return match.countryCodes.indexOf(countryCode) !== -1;
}
};
- matcher.getWarnings = () => _warnings;
+ matcher.getWarnings = function () { return _warnings; };
return matcher;
};
var j = right;
swap(arr, left, k);
- if (compare(arr[right], t) > 0) swap(arr, left, right);
+ if (compare(arr[right], t) > 0) { swap(arr, left, right); }
while (i < j) {
swap(arr, i, j);
i++;
j--;
- while (compare(arr[i], t) < 0) i++;
- while (compare(arr[j], t) > 0) j--;
+ while (compare(arr[i], t) < 0) { i++; }
+ while (compare(arr[j], t) > 0) { j--; }
}
- if (compare(arr[left], t) === 0) swap(arr, left, j);
+ if (compare(arr[left], t) === 0) { swap(arr, left, j); }
else {
j++;
swap(arr, j, right);
}
- if (j <= k) left = j + 1;
- if (k <= j) right = j - 1;
+ if (j <= k) { left = j + 1; }
+ if (k <= j) { right = j - 1; }
}
}
function rbush(maxEntries, format) {
- if (!(this instanceof rbush)) return new rbush(maxEntries, format);
+ if (!(this instanceof rbush)) { return new rbush(maxEntries, format); }
// max entries in a node is 9 by default; min node fill is 40% for best performance
this._maxEntries = Math.max(4, maxEntries || 9);
result = [],
toBBox = this.toBBox;
- if (!intersects$1(bbox, node)) return result;
+ if (!intersects$1(bbox, node)) { return result; }
var nodesToSearch = [],
i, len, child, childBBox;
childBBox = node.leaf ? toBBox(child) : child;
if (intersects$1(bbox, childBBox)) {
- if (node.leaf) result.push(child);
- else if (contains$2(bbox, childBBox)) this._all(child, result);
- else nodesToSearch.push(child);
+ if (node.leaf) { result.push(child); }
+ else if (contains$2(bbox, childBBox)) { this._all(child, result); }
+ else { nodesToSearch.push(child); }
}
}
node = nodesToSearch.pop();
var node = this.data,
toBBox = this.toBBox;
- if (!intersects$1(bbox, node)) return false;
+ if (!intersects$1(bbox, node)) { return false; }
var nodesToSearch = [],
i, len, child, childBBox;
childBBox = node.leaf ? toBBox(child) : child;
if (intersects$1(bbox, childBBox)) {
- if (node.leaf || contains$2(bbox, childBBox)) return true;
+ if (node.leaf || contains$2(bbox, childBBox)) { return true; }
nodesToSearch.push(child);
}
}
},
load: function (data) {
- if (!(data && data.length)) return this;
+ if (!(data && data.length)) { return this; }
if (data.length < this._minEntries) {
for (var i = 0, len = data.length; i < len; i++) {
},
insert: function (item) {
- if (item) this._insert(item, this.data.height - 1);
+ if (item) { this._insert(item, this.data.height - 1); }
return this;
},
},
remove: function (item, equalsFn) {
- if (!item) return this;
+ if (!item) { return this; }
var node = this.data,
bbox = this.toBBox(item),
node = parent.children[i];
goingUp = false;
- } else node = null; // nothing found
+ } else { node = null; } // nothing found
}
return this;
_all: function (node, result) {
var nodesToSearch = [];
while (node) {
- if (node.leaf) result.push.apply(result, node.children);
- else nodesToSearch.push.apply(nodesToSearch, node.children);
+ if (node.leaf) { result.push.apply(result, node.children); }
+ else { nodesToSearch.push.apply(nodesToSearch, node.children); }
node = nodesToSearch.pop();
}
while (true) {
path.push(node);
- if (node.leaf || path.length - 1 === level) break;
+ if (node.leaf || path.length - 1 === level) { break; }
minArea = minEnlargement = Infinity;
if (insertPath[level].children.length > this._maxEntries) {
this._split(insertPath, level);
level--;
- } else break;
+ } else { break; }
}
// adjust bboxes along the insertion path
calcBBox$1(node, this.toBBox);
calcBBox$1(newNode, this.toBBox);
- if (level) insertPath[level - 1].children.push(newNode);
- else this._splitRoot(node, newNode);
+ if (level) { insertPath[level - 1].children.push(newNode); }
+ else { this._splitRoot(node, newNode); }
},
_splitRoot: function (node, newNode) {
// if total distributions margin value is minimal for x, sort by minX,
// otherwise it's already sorted by minY
- if (xMargin < yMargin) node.children.sort(compareMinX);
+ if (xMargin < yMargin) { node.children.sort(compareMinX); }
},
// total margin of all possible split distributions where each node is at least m full
siblings = path[i - 1].children;
siblings.splice(siblings.indexOf(path[i]), 1);
- } else this.clear();
+ } else { this.clear(); }
- } else calcBBox$1(path[i], this.toBBox);
+ } else { calcBBox$1(path[i], this.toBBox); }
}
},
};
function findItem$1(item, items, equalsFn) {
- if (!equalsFn) return items.indexOf(item);
+ if (!equalsFn) { return items.indexOf(item); }
for (var i = 0; i < items.length; i++) {
- if (equalsFn(item, items[i])) return i;
+ if (equalsFn(item, items[i])) { return i; }
}
return -1;
}
// min bounding rectangle of node children from k to p-1
function distBBox$1(node, k, p, toBBox, destNode) {
- if (!destNode) destNode = createNode$1(null);
+ if (!destNode) { destNode = createNode$1(null); }
destNode.minX = Infinity;
destNode.minY = Infinity;
destNode.maxX = -Infinity;
right = stack.pop();
left = stack.pop();
- if (right - left <= n) continue;
+ if (right - left <= n) { continue; }
mid = left + Math.ceil((right - left) / n / 2) * n;
quickselect$1(arr, mid, left, right, compare);
part = [],
i, a, b, codeB, lastCode;
- if (!result) result = [];
+ if (!result) { result = []; }
for (i = 1; i < len; i++) {
a = points[i - 1];
codeA = lastCode;
}
- if (part.length) result.push(part);
+ if (part.length) { result.push(part); }
return result;
}
inside = !(bitCode$1(p, bbox) & edge);
// if segment goes through the clip window, add an intersection
- if (inside !== prevInside) result.push(intersect$1(prev, p, edge, bbox));
+ if (inside !== prevInside) { result.push(intersect$1(prev, p, edge, bbox)); }
- if (inside) result.push(p); // add a point if it's inside
+ if (inside) { result.push(p); } // add a point if it's inside
prev = p;
prevInside = inside;
points = result;
- if (!points.length) break;
+ if (!points.length) { break; }
}
return result;
function bitCode$1(p, bbox) {
var code = 0;
- if (p[0] < bbox[0]) code |= 1; // left
- else if (p[0] > bbox[2]) code |= 2; // right
+ if (p[0] < bbox[0]) { code |= 1; } // left
+ else if (p[0] > bbox[2]) { code |= 2; } // right
- if (p[1] < bbox[1]) code |= 4; // bottom
- else if (p[1] > bbox[3]) code |= 8; // top
+ if (p[1] < bbox[1]) { code |= 4; } // bottom
+ else if (p[1] > bbox[3]) { code |= 8; } // top
return code;
}
for (var i = 0; i < result.length; i++) {
if (insidePolygon(result[i].coords, p)) {
if (multi)
- output.push(result[i].props);
+ { output.push(result[i].props); }
else
- return result[i].props;
+ { return result[i].props; }
}
}
return multi && output.length ? output : null;
(bbox[0] + bbox[2]) / 2,
(bbox[1] + bbox[3]) / 2
];
- if (insidePolygon(polygon, bboxCenter)) return true;
+ if (insidePolygon(polygon, bboxCenter)) { return true; }
for (var i = 0; i < polygon.length; i++) {
- if (lineclip_1$1(polygon[i], bbox).length > 0) return true;
+ if (lineclip_1$1(polygon[i], bbox).length > 0) { return true; }
}
return false;
}
for (var i = 0, len = rings.length; i < len; i++) {
var ring = rings[i];
for (var j = 0, len2 = ring.length, k = len2 - 1; j < len2; k = j++) {
- if (rayIntersect(p, ring[j], ring[k])) inside = !inside;
+ if (rayIntersect(p, ring[j], ring[k])) { inside = !inside; }
}
}
return inside;
features: features
};
- let borders = rawBorders;
- let whichPolygonGetter = {};
- let featuresByCode = {};
- let idFilterRegex = /\bThe\b|\bthe\b|\band\b|\bof\b|[-_ .,()&[\]/]/g;
- let levels = [
+ var borders = rawBorders;
+ var whichPolygonGetter = {};
+ var featuresByCode = {};
+ var idFilterRegex = /\bThe\b|\bthe\b|\band\b|\bof\b|[-_ .,()&[\]/]/g;
+ var levels = [
'subterritory',
'territory',
'country',
];
loadDerivedDataAndCaches(borders);
function loadDerivedDataAndCaches(borders) {
- let identifierProps = ['iso1A2', 'iso1A3', 'm49', 'wikidata', 'emojiFlag', 'nameEn'];
- let geometryFeatures = [];
- for (let i in borders.features) {
- let feature = borders.features[i];
+ var identifierProps = ['iso1A2', 'iso1A3', 'm49', 'wikidata', 'emojiFlag', 'nameEn'];
+ var geometryFeatures = [];
+ for (var i in borders.features) {
+ var feature = borders.features[i];
feature.properties.id = feature.properties.iso1A2 || feature.properties.m49;
loadM49(feature);
loadIsoStatus(feature);
loadDriveSide(feature);
loadFlag(feature);
cacheFeatureByIDs(feature);
- if (feature.geometry) geometryFeatures.push(feature);
+ if (feature.geometry) { geometryFeatures.push(feature); }
}
- for (let i in borders.features) {
- let feature = borders.features[i];
- feature.properties.groups.sort(function(groupID1, groupID2) {
+ for (var i$1 in borders.features) {
+ var feature$1 = borders.features[i$1];
+ feature$1.properties.groups.sort(function(groupID1, groupID2) {
return (
levels.indexOf(featuresByCode[groupID1].properties.level) -
levels.indexOf(featuresByCode[groupID2].properties.level)
);
});
- loadMembersForGroupsOf(feature);
+ loadMembersForGroupsOf(feature$1);
}
- let geometryOnlyCollection = {
+ var geometryOnlyCollection = {
type: 'RegionFeatureCollection',
features: geometryFeatures
};
whichPolygonGetter = whichPolygon_1(geometryOnlyCollection);
function loadGroups(feature) {
- let props = feature.properties;
+ var props = feature.properties;
if (!props.groups) {
props.groups = [];
}
}
}
function loadM49(feature) {
- let props = feature.properties;
+ var props = feature.properties;
if (!props.m49 && props.iso1N3) {
props.m49 = props.iso1N3;
}
}
function loadIsoStatus(feature) {
- let props = feature.properties;
+ var props = feature.properties;
if (!props.isoStatus && props.iso1A2) {
props.isoStatus = 'official';
}
}
function loadLevel(feature) {
- let props = feature.properties;
- if (props.level) return;
+ var props = feature.properties;
+ if (props.level) { return; }
if (!props.country) {
props.level = 'country';
} else if (props.isoStatus === 'official') {
}
}
function loadRoadSpeedUnit(feature) {
- let props = feature.properties;
+ var props = feature.properties;
if (props.roadSpeedUnit === undefined && props.iso1A2 && props.iso1A2 !== 'EU') {
props.roadSpeedUnit = 'km/h';
}
}
function loadDriveSide(feature) {
- let props = feature.properties;
+ var props = feature.properties;
if (props.driveSide === undefined && props.iso1A2 && props.iso1A2 !== 'EU') {
props.driveSide = 'right';
}
}
function loadFlag(feature) {
- if (!feature.properties.iso1A2) return;
- let flag = feature.properties.iso1A2.replace(/./g, function(char) {
+ if (!feature.properties.iso1A2) { return; }
+ var flag = feature.properties.iso1A2.replace(/./g, function(char) {
return String.fromCodePoint(char.charCodeAt(0) + 127397);
});
feature.properties.emojiFlag = flag;
}
function loadMembersForGroupsOf(feature) {
- let featureID = feature.properties.id;
- let standardizedGroupIDs = [];
- for (let j in feature.properties.groups) {
- let groupID = feature.properties.groups[j];
- let groupFeature = featuresByCode[groupID];
+ var featureID = feature.properties.id;
+ var standardizedGroupIDs = [];
+ for (var j in feature.properties.groups) {
+ var groupID = feature.properties.groups[j];
+ var groupFeature = featuresByCode[groupID];
standardizedGroupIDs.push(groupFeature.properties.id);
if (groupFeature.properties.members) {
groupFeature.properties.members.push(featureID);
feature.properties.groups = standardizedGroupIDs;
}
function cacheFeatureByIDs(feature) {
- for (let k in identifierProps) {
- let prop = identifierProps[k];
- let id = prop && feature.properties[prop];
+ for (var k in identifierProps) {
+ var prop = identifierProps[k];
+ var id = prop && feature.properties[prop];
if (id) {
id = id.replace(idFilterRegex, '').toUpperCase();
featuresByCode[id] = feature;
}
}
if (feature.properties.aliases) {
- for (let j in feature.properties.aliases) {
- let alias = feature.properties.aliases[j].replace(idFilterRegex, '').toUpperCase();
+ for (var j in feature.properties.aliases) {
+ var alias = feature.properties.aliases[j].replace(idFilterRegex, '').toUpperCase();
featuresByCode[alias] = feature;
}
}
return loc.geometry.coordinates;
}
function smallestFeature(loc) {
- let query = locArray(loc);
- let featureProperties = whichPolygonGetter(query);
- if (!featureProperties) return null;
+ var query = locArray(loc);
+ var featureProperties = whichPolygonGetter(query);
+ if (!featureProperties) { return null; }
return featuresByCode[featureProperties.id];
}
function countryFeature(loc) {
- let feature = smallestFeature(loc);
- if (!feature) return null;
- let countryCode = feature.properties.country || feature.properties.iso1A2;
+ var feature = smallestFeature(loc);
+ if (!feature) { return null; }
+ var countryCode = feature.properties.country || feature.properties.iso1A2;
return featuresByCode[countryCode];
}
function featureForLoc(loc, opts) {
if (opts && opts.level && opts.level !== 'country') {
- let features = featuresContaining(loc);
- let targetLevel = opts.level;
- let targetLevelIndex = levels.indexOf(targetLevel);
- if (targetLevelIndex === -1) return null;
- for (let i in features) {
- let feature = features[i];
+ var features = featuresContaining(loc);
+ var targetLevel = opts.level;
+ var targetLevelIndex = levels.indexOf(targetLevel);
+ if (targetLevelIndex === -1) { return null; }
+ for (var i in features) {
+ var feature = features[i];
if (
feature.properties.level === targetLevel ||
levels.indexOf(feature.properties.level) > targetLevelIndex
return countryFeature(loc);
}
function featureForID(id) {
- let stringID;
+ var stringID;
if (typeof id === 'number') {
stringID = id.toString();
if (stringID.length === 1) {
return featureForID(query);
}
function iso1A2Code(query, opts) {
- let match = feature(query, opts);
- if (!match) return null;
+ var match = feature(query, opts);
+ if (!match) { return null; }
return match.properties.iso1A2 || null;
}
function featuresContaining(query, strict) {
- let feature = smallestOrMatchingFeature(query);
- if (!feature) return [];
- let features = [];
+ var feature = smallestOrMatchingFeature(query);
+ if (!feature) { return []; }
+ var features = [];
if (!strict || typeof query === 'object') {
features.push(feature);
}
- let properties = feature.properties;
- for (let i in properties.groups) {
- let groupID = properties.groups[i];
+ var properties = feature.properties;
+ for (var i in properties.groups) {
+ var groupID = properties.groups[i];
features.push(featuresByCode[groupID]);
}
return features;
}
function roadSpeedUnit(query) {
- let feature = smallestOrMatchingFeature(query);
+ var feature = smallestOrMatchingFeature(query);
return (feature && feature.properties.roadSpeedUnit) || null;
}
- let _dataDeprecated;
- let _nsi;
+ var _dataDeprecated;
+ var _nsi;
function validationOutdatedTags() {
- const type = 'outdated_tags';
- const nsiKeys = ['amenity', 'shop', 'tourism', 'leisure', 'office'];
+ var type = 'outdated_tags';
+ var nsiKeys = ['amenity', 'shop', 'tourism', 'leisure', 'office'];
// A concern here in switching to async data means that `_dataDeprecated`
// and `_nsi` will not be available at first, so the data on early tiles
// initialize deprecated tags array
_mainFileFetcher.get('deprecated')
- .then(d => _dataDeprecated = d)
- .catch(() => { /* ignore */ });
+ .then(function (d) { return _dataDeprecated = d; })
+ .catch(function () { /* ignore */ });
_mainFileFetcher.get('nsi_brands')
- .then(d => {
+ .then(function (d) {
_nsi = {
brands: d.brands,
matcher: matcher$1(),
_nsi.matcher.buildMatchIndex(d.brands);
// index all known wikipedia and wikidata tags
- Object.keys(d.brands).forEach(kvnd => {
- const brand = d.brands[kvnd];
- const wd = brand.tags['brand:wikidata'];
- const wp = brand.tags['brand:wikipedia'];
+ Object.keys(d.brands).forEach(function (kvnd) {
+ var brand = d.brands[kvnd];
+ var wd = brand.tags['brand:wikidata'];
+ var wp = brand.tags['brand:wikipedia'];
if (wd) { _nsi.wikidata[wd] = kvnd; }
if (wp) { _nsi.wikipedia[wp] = kvnd; }
});
return _nsi;
})
- .catch(() => { /* ignore */ });
+ .catch(function () { /* ignore */ });
function oldTagIssues(entity, graph) {
- const oldTags = Object.assign({}, entity.tags); // shallow copy
- let preset = _mainPresetIndex.match(entity, graph);
- let subtype = 'deprecated_tags';
- if (!preset) return [];
+ var oldTags = Object.assign({}, entity.tags); // shallow copy
+ var preset = _mainPresetIndex.match(entity, graph);
+ var subtype = 'deprecated_tags';
+ if (!preset) { return []; }
// upgrade preset..
if (preset.replacement) {
- const newPreset = _mainPresetIndex.item(preset.replacement);
+ var newPreset = _mainPresetIndex.item(preset.replacement);
graph = actionChangePreset(entity.id, preset, newPreset, true /* skip field defaults */)(graph);
entity = graph.entity(entity.id);
preset = newPreset;
// upgrade tags..
if (_dataDeprecated) {
- const deprecatedTags = entity.deprecatedTags(_dataDeprecated);
+ var deprecatedTags = entity.deprecatedTags(_dataDeprecated);
if (deprecatedTags.length) {
- deprecatedTags.forEach(tag => {
+ deprecatedTags.forEach(function (tag) {
graph = actionUpgradeTags(entity.id, tag.old, tag.replace)(graph);
});
entity = graph.entity(entity.id);
}
// add missing addTags..
- let newTags = Object.assign({}, entity.tags); // shallow copy
+ var newTags = Object.assign({}, entity.tags); // shallow copy
if (preset.tags !== preset.addTags) {
- Object.keys(preset.addTags).forEach(k => {
+ Object.keys(preset.addTags).forEach(function (k) {
if (!newTags[k]) {
if (preset.addTags[k] === '*') {
newTags[k] = 'yes';
if (_nsi) {
// Do `wikidata` or `wikipedia` identify this entity as a brand? #6416
// If so, these tags can be swapped to `brand:wikidata`/`brand:wikipedia`
- let isBrand;
+ var isBrand;
if (newTags.wikidata) { // try matching `wikidata`
isBrand = _nsi.wikidata[newTags.wikidata];
}
// try key/value|name match against name-suggestion-index
if (newTags.name) {
- for (let i = 0; i < nsiKeys.length; i++) {
- const k = nsiKeys[i];
- if (!newTags[k]) continue;
+ for (var i = 0; i < nsiKeys.length; i++) {
+ var k = nsiKeys[i];
+ if (!newTags[k]) { continue; }
- const center = entity.extent(graph).center();
- const countryCode = iso1A2Code(center);
- const match = _nsi.matcher.matchKVN(k, newTags[k], newTags.name, countryCode && countryCode.toLowerCase());
- if (!match) continue;
+ var center = entity.extent(graph).center();
+ var countryCode = iso1A2Code(center);
+ var match = _nsi.matcher.matchKVN(k, newTags[k], newTags.name, countryCode && countryCode.toLowerCase());
+ if (!match) { continue; }
// for now skip ambiguous matches (like Target~(USA) vs Target~(Australia))
- if (match.d) continue;
+ if (match.d) { continue; }
- const brand = _nsi.brands[match.kvnd];
+ var brand = _nsi.brands[match.kvnd];
if (brand && brand.tags['brand:wikidata'] &&
brand.tags['brand:wikidata'] !== entity.tags['not:brand:wikidata']) {
subtype = 'noncanonical_brand';
- const keepTags = ['takeaway'].reduce((acc, k) => {
+ var keepTags = ['takeaway'].reduce(function (acc, k) {
if (newTags[k]) {
acc[k] = newTags[k];
}
return acc;
}, {});
- nsiKeys.forEach(k => delete newTags[k]);
+ nsiKeys.forEach(function (k) { return delete newTags[k]; });
Object.assign(newTags, brand.tags, keepTags);
break;
}
}
// determine diff
- const tagDiff = utilTagDiff(oldTags, newTags);
- if (!tagDiff.length) return [];
+ var tagDiff = utilTagDiff(oldTags, newTags);
+ if (!tagDiff.length) { return []; }
- const isOnlyAddingTags = tagDiff.every(d => d.type === '+');
+ var isOnlyAddingTags = tagDiff.every(function (d) { return d.type === '+'; });
- let prefix = '';
+ var prefix = '';
if (subtype === 'noncanonical_brand') {
prefix = 'noncanonical_brand.';
} else if (subtype === 'deprecated_tags' && isOnlyAddingTags) {
}
// don't allow autofixing brand tags
- let autoArgs = subtype !== 'noncanonical_brand' ? [doUpgrade, _t('issues.fix.upgrade_tags.annotation')] : null;
+ var autoArgs = subtype !== 'noncanonical_brand' ? [doUpgrade, _t('issues.fix.upgrade_tags.annotation')] : null;
return [new validationIssue({
type: type,
reference: showReference,
entityIds: [entity.id],
hash: JSON.stringify(tagDiff),
- dynamicFixes: () => {
+ dynamicFixes: function () {
return [
new validationIssueFix({
autoArgs: autoArgs,
title: _t('issues.fix.upgrade_tags.title'),
- onClick: (context) => {
+ onClick: function (context) {
context.perform(doUpgrade, _t('issues.fix.upgrade_tags.annotation'));
}
})
function doUpgrade(graph) {
- const currEntity = graph.hasEntity(entity.id);
- if (!currEntity) return graph;
+ var currEntity = graph.hasEntity(entity.id);
+ if (!currEntity) { return graph; }
- let newTags = Object.assign({}, currEntity.tags); // shallow copy
- tagDiff.forEach(diff => {
+ var newTags = Object.assign({}, currEntity.tags); // shallow copy
+ tagDiff.forEach(function (diff) {
if (diff.type === '-') {
delete newTags[diff.key];
} else if (diff.type === '+') {
function showMessage(context) {
- const currEntity = context.hasEntity(entity.id);
- if (!currEntity) return '';
+ var currEntity = context.hasEntity(entity.id);
+ if (!currEntity) { return ''; }
- let messageID = `issues.outdated_tags.${prefix}message`;
+ var messageID = "issues.outdated_tags." + prefix + "message";
if (subtype === 'noncanonical_brand' && isOnlyAddingTags) {
messageID += '_incomplete';
}
function showReference(selection) {
- let enter = selection.selectAll('.issue-reference')
+ var enter = selection.selectAll('.issue-reference')
.data([0])
.enter();
enter
.append('div')
.attr('class', 'issue-reference')
- .text(_t(`issues.outdated_tags.${prefix}reference`));
+ .text(_t(("issues.outdated_tags." + prefix + "reference")));
enter
.append('strong')
.append('tr')
.attr('class', 'tagDiff-row')
.append('td')
- .attr('class', d => {
- let klass = d.type === '+' ? 'add' : 'remove';
- return `tagDiff-cell tagDiff-cell-${klass}`;
+ .attr('class', function (d) {
+ var klass = d.type === '+' ? 'add' : 'remove';
+ return ("tagDiff-cell tagDiff-cell-" + klass);
})
- .text(d => d.display);
+ .text(function (d) { return d.display; });
}
}
function oldMultipolygonIssues(entity, graph) {
- let multipolygon, outerWay;
+ var multipolygon, outerWay;
if (entity.type === 'relation') {
outerWay = osmOldMultipolygonOuterMemberOfRelation(entity, graph);
multipolygon = entity;
return [];
}
- if (!multipolygon || !outerWay) return [];
+ if (!multipolygon || !outerWay) { return []; }
return [new validationIssue({
type: type,
message: showMessage,
reference: showReference,
entityIds: [outerWay.id, multipolygon.id],
- dynamicFixes: () => {
+ dynamicFixes: function () {
return [
new validationIssueFix({
autoArgs: [doUpgrade, _t('issues.fix.move_tags.annotation')],
title: _t('issues.fix.move_tags.title'),
- onClick: (context) => {
+ onClick: function (context) {
context.perform(doUpgrade, _t('issues.fix.move_tags.annotation'));
}
})
function doUpgrade(graph) {
- let currMultipolygon = graph.hasEntity(multipolygon.id);
- let currOuterWay = graph.hasEntity(outerWay.id);
- if (!currMultipolygon || !currOuterWay) return graph;
+ var currMultipolygon = graph.hasEntity(multipolygon.id);
+ var currOuterWay = graph.hasEntity(outerWay.id);
+ if (!currMultipolygon || !currOuterWay) { return graph; }
currMultipolygon = currMultipolygon.mergeTags(currOuterWay.tags);
graph = graph.replace(currMultipolygon);
function showMessage(context) {
- let currMultipolygon = context.hasEntity(multipolygon.id);
- if (!currMultipolygon) return '';
+ var currMultipolygon = context.hasEntity(multipolygon.id);
+ if (!currMultipolygon) { return ''; }
return _t('issues.old_multipolygon.message',
{ multipolygon: utilDisplayLabel(currMultipolygon, context.graph()) }
}
- let validation = function checkOutdatedTags(entity, graph) {
- let issues = oldMultipolygonIssues(entity, graph);
- if (!issues.length) issues = oldTagIssues(entity, graph);
+ var validation = function checkOutdatedTags(entity, graph) {
+ var issues = oldMultipolygonIssues(entity, graph);
+ if (!issues.length) { issues = oldTagIssues(entity, graph); }
return issues;
};
var validation = function checkPrivateData(entity) {
var tags = entity.tags;
- if (!tags.building || !privateBuildingValues[tags.building]) return [];
+ if (!tags.building || !privateBuildingValues[tags.building]) { return []; }
var keepTags = {};
for (var k in tags) {
- if (publicKeys[k]) return []; // probably a public feature
+ if (publicKeys[k]) { return []; } // probably a public feature
if (!personalTags[k]) {
keepTags[k] = tags[k];
}
}
var tagDiff = utilTagDiff(tags, keepTags);
- if (!tagDiff.length) return [];
+ if (!tagDiff.length) { return []; }
var fixID = tagDiff.length === 1 ? 'remove_tag' : 'remove_tags';
function doUpgrade(graph) {
var currEntity = graph.hasEntity(entity.id);
- if (!currEntity) return graph;
+ if (!currEntity) { return graph; }
var newTags = Object.assign({}, currEntity.tags); // shallow copy
tagDiff.forEach(function(diff) {
function showMessage(context) {
var currEntity = context.hasEntity(this.entityIds[0]);
- if (!currEntity) return '';
+ if (!currEntity) { return ''; }
return _t('issues.private_data.contact.message',
{ feature: utilDisplayLabel(currEntity, context.graph()) }
return validation;
}
- let _discardNameRegexes = [];
+ var _discardNameRegexes = [];
function validationSuspiciousName() {
- const type = 'suspicious_name';
- const keysToTestForGenericValues = [
+ var type = 'suspicious_name';
+ var keysToTestForGenericValues = [
'aerialway', 'aeroway', 'amenity', 'building', 'craft', 'highway',
'leisure', 'railway', 'man_made', 'office', 'shop', 'tourism', 'waterway'
];
// be available at first, so the data on early tiles may not have tags validated fully.
_mainFileFetcher.get('nsi_filters')
- .then(filters => {
+ .then(function (filters) {
// known list of generic names (e.g. "bar")
_discardNameRegexes = filters.discardNames
- .map(discardName => new RegExp(discardName, 'i'));
+ .map(function (discardName) { return new RegExp(discardName, 'i'); });
})
- .catch(() => { /* ignore */ });
+ .catch(function () { /* ignore */ });
function isDiscardedSuggestionName(lowercaseName) {
- return _discardNameRegexes.some(regex => regex.test(lowercaseName));
+ return _discardNameRegexes.some(function (regex) { return regex.test(lowercaseName); });
}
// test if the name is just the key or tag value (e.g. "park")
function nameMatchesRawTag(lowercaseName, tags) {
- for (let i = 0; i < keysToTestForGenericValues.length; i++) {
- let key = keysToTestForGenericValues[i];
- let val = tags[key];
+ for (var i = 0; i < keysToTestForGenericValues.length; i++) {
+ var key = keysToTestForGenericValues[i];
+ var val = tags[key];
if (val) {
val = val.toLowerCase();
if (key === lowercaseName ||
subtype: 'generic_name',
severity: 'warning',
message: function(context) {
- let entity = context.hasEntity(this.entityIds[0]);
- if (!entity) return '';
- let preset = _mainPresetIndex.match(entity, context.graph());
- let langName = langCode && _mainLocalizer.languageName(langCode);
+ var entity = context.hasEntity(this.entityIds[0]);
+ if (!entity) { return ''; }
+ var preset = _mainPresetIndex.match(entity, context.graph());
+ var langName = langCode && _mainLocalizer.languageName(langCode);
return _t('issues.generic_name.message' + (langName ? '_language' : ''),
{ feature: preset.name(), name: genericName, language: langName }
);
icon: 'iD-operation-delete',
title: _t('issues.fix.remove_the_name.title'),
onClick: function(context) {
- let entityId = this.issue.entityIds[0];
- let entity = context.entity(entityId);
- let tags = Object.assign({}, entity.tags); // shallow copy
+ var entityId = this.issue.entityIds[0];
+ var entity = context.entity(entityId);
+ var tags = Object.assign({}, entity.tags); // shallow copy
delete tags[nameKey];
context.perform(
actionChangeTags(entityId, tags), _t('issues.fix.remove_generic_name.annotation')
subtype: 'not_name',
severity: 'warning',
message: function(context) {
- const entity = context.hasEntity(this.entityIds[0]);
- if (!entity) return '';
- const preset = _mainPresetIndex.match(entity, context.graph());
- const langName = langCode && _mainLocalizer.languageName(langCode);
+ var entity = context.hasEntity(this.entityIds[0]);
+ if (!entity) { return ''; }
+ var preset = _mainPresetIndex.match(entity, context.graph());
+ var langName = langCode && _mainLocalizer.languageName(langCode);
return _t('issues.incorrect_name.message' + (langName ? '_language' : ''),
{ feature: preset.name(), name: incorrectName, language: langName }
);
icon: 'iD-operation-delete',
title: _t('issues.fix.remove_the_name.title'),
onClick: function(context) {
- const entityId = this.issue.entityIds[0];
- const entity = context.entity(entityId);
- let tags = Object.assign({}, entity.tags); // shallow copy
+ var entityId = this.issue.entityIds[0];
+ var entity = context.entity(entityId);
+ var tags = Object.assign({}, entity.tags); // shallow copy
delete tags[nameKey];
context.perform(
actionChangeTags(entityId, tags), _t('issues.fix.remove_mistaken_name.annotation')
}
- let validation = function checkGenericName(entity) {
+ var validation = function checkGenericName(entity) {
// a generic name is okay if it's a known brand or entity
- if (entity.hasWikidata()) return [];
+ if (entity.hasWikidata()) { return []; }
- let issues = [];
- const notNames = (entity.tags['not:name'] || '').split(';');
+ var issues = [];
+ var notNames = (entity.tags['not:name'] || '').split(';');
- for (let key in entity.tags) {
- const m = key.match(/^name(?:(?::)([a-zA-Z_-]+))?$/);
- if (!m) continue;
+ for (var key in entity.tags) {
+ var m = key.match(/^name(?:(?::)([a-zA-Z_-]+))?$/);
+ if (!m) { continue; }
- const langCode = m.length >= 2 ? m[1] : null;
- const value = entity.tags[key];
+ var langCode = m.length >= 2 ? m[1] : null;
+ var value = entity.tags[key];
if (notNames.length) {
- for (let i in notNames) {
- const notName = notNames[i];
+ for (var i in notNames) {
+ var notName = notNames[i];
if (notName && value === notName) {
issues.push(makeIncorrectNameIssue(entity.id, key, value, langCode));
continue;
var nodeThreshold = 10;
function isBuilding(entity, graph) {
- if (entity.type !== 'way' || entity.geometry(graph) !== 'area') return false;
+ if (entity.type !== 'way' || entity.geometry(graph) !== 'area') { return false; }
return entity.tags.building && entity.tags.building !== 'no';
}
var validation = function checkUnsquareWay(entity, graph) {
- if (!isBuilding(entity, graph)) return [];
+ if (!isBuilding(entity, graph)) { return []; }
// don't flag ways marked as physically unsquare
- if (entity.tags.nonsquare === 'yes') return [];
+ if (entity.tags.nonsquare === 'yes') { return []; }
var isClosed = entity.isClosed();
- if (!isClosed) return []; // this building has bigger problems
+ if (!isClosed) { return []; } // this building has bigger problems
// don't flag ways with lots of nodes since they are likely detail-mapped
var nodes = graph.childNodes(entity).slice(); // shallow copy
- if (nodes.length > nodeThreshold + 1) return []; // +1 because closing node appears twice
+ if (nodes.length > nodeThreshold + 1) { return []; } // +1 because closing node appears twice
// ignore if not all nodes are fully downloaded
var osm = services.osm;
- if (!osm || nodes.some(function(node) { return !osm.isDataLoaded(node.loc); })) return [];
+ if (!osm || nodes.some(function(node) { return !osm.isDataLoaded(node.loc); })) { return []; }
// don't flag connected ways to avoid unresolvable unsquare loops
var hasConnectedSquarableWays = nodes.some(function(node) {
return graph.parentWays(node).some(function(way) {
- if (way.id === entity.id) return false;
- if (isBuilding(way, graph)) return true;
+ if (way.id === entity.id) { return false; }
+ if (isBuilding(way, graph)) { return true; }
return graph.parentRelations(way).some(function(parentRelation) {
return parentRelation.isMultipolygon() &&
parentRelation.tags.building &&
});
});
});
- if (hasConnectedSquarableWays) return [];
+ if (hasConnectedSquarableWays) { return []; }
// user-configurable square threshold
var degreeThreshold = isNaN(storedDegreeThreshold) ? DEFAULT_DEG_THRESHOLD : parseFloat(storedDegreeThreshold);
var points = nodes.map(function(node) { return context.projection(node.loc); });
- if (!geoOrthoCanOrthogonalize(points, isClosed, epsilon, degreeThreshold, true)) return [];
+ if (!geoOrthoCanOrthogonalize(points, isClosed, epsilon, degreeThreshold, true)) { return []; }
var autoArgs;
// don't allow autosquaring features linked to wikidata
// run after the squaring transition (currently 150ms)
window.setTimeout(function() { completionHandler(); }, 175);
}
- }),
- /*
- new validationIssueFix({
- title: t('issues.fix.tag_as_unsquare.title'),
- onClick: function(context) {
- var entityId = this.issue.entityIds[0];
- var entity = context.entity(entityId);
- var tags = Object.assign({}, entity.tags); // shallow copy
- tags.nonsquare = 'yes';
- context.perform(
- actionChangeTags(entityId, tags),
- t('issues.fix.tag_as_unsquare.annotation')
- );
- }
- })
- */
- ];
+ }) ];
}
})];
//
validator.init = function() {
Object.values(Validations).forEach(function(validation) {
- if (typeof validation !== 'function') return;
+ if (typeof validation !== 'function') { return; }
var fn = validation(context);
var key = fn.type;
function reloadUnsquareIssues(cache, graph) {
var checkUnsquareWay = _rules.unsquare_way;
- if (typeof checkUnsquareWay !== 'function') return;
+ if (typeof checkUnsquareWay !== 'function') { return; }
// uncache existing
cache.uncacheIssuesOfType('unsquare_way');
// rerun for all buildings
buildings.forEach(function(entity) {
var detected = checkUnsquareWay(entity, graph);
- if (detected.length !== 1) return;
+ if (detected.length !== 1) { return; }
var issue = detected[0];
if (!cache.issuesByEntityID[entity.id]) {
cache.issuesByEntityID[entity.id] = new Set();
var view = context.map().extent();
return issues.filter(function(issue) {
- if (!issue) return false;
- if (opts.includeDisabledRules === 'only' && !_disabledRules[issue.type]) return false;
- if (!opts.includeDisabledRules && _disabledRules[issue.type]) return false;
+ if (!issue) { return false; }
+ if (opts.includeDisabledRules === 'only' && !_disabledRules[issue.type]) { return false; }
+ if (!opts.includeDisabledRules && _disabledRules[issue.type]) { return false; }
- if (opts.includeIgnored === 'only' && !_ignoredIssueIDs[issue.id]) return false;
- if (!opts.includeIgnored && _ignoredIssueIDs[issue.id]) return false;
+ if (opts.includeIgnored === 'only' && !_ignoredIssueIDs[issue.id]) { return false; }
+ if (!opts.includeIgnored && _ignoredIssueIDs[issue.id]) { return false; }
// Sanity check: This issue may be for an entity that not longer exists.
// If we detect this, uncache and return false so it is not included..
}
}
- if (opts.what === 'edited' && _baseCache.issuesByIssueID[issue.id]) return false;
+ if (opts.what === 'edited' && _baseCache.issuesByIssueID[issue.id]) { return false; }
if (opts.where === 'visible') {
var extent = issue.extent(context.graph());
- if (!view.intersects(extent)) return false;
+ if (!view.intersects(extent)) { return false; }
}
return true;
if (!acc) {
return new Set(entityIssueIDs);
}
- return new Set([...acc].filter(function(elem) {
+ return new Set([].concat( acc ).filter(function(elem) {
return entityIssueIDs.has(elem);
}));
}, null) || [];
return Array.from(issueIDs)
.map(function(id) { return cache.issuesByIssueID[id]; })
.filter(function(issue) {
- if (!issue) return false;
- if (opts.includeDisabledRules === 'only' && !_disabledRules[issue.type]) return false;
- if (!opts.includeDisabledRules && _disabledRules[issue.type]) return false;
+ if (!issue) { return false; }
+ if (opts.includeDisabledRules === 'only' && !_disabledRules[issue.type]) { return false; }
+ if (!opts.includeDisabledRules && _disabledRules[issue.type]) { return false; }
- if (opts.includeIgnored === 'only' && !_ignoredIssueIDs[issue.id]) return false;
- if (!opts.includeIgnored && _ignoredIssueIDs[issue.id]) return false;
+ if (opts.includeIgnored === 'only' && !_ignoredIssueIDs[issue.id]) { return false; }
+ if (!opts.includeIgnored && _ignoredIssueIDs[issue.id]) { return false; }
return true;
}).sort(function(issue1, issue2) {
return entityIDs.reduce(function(acc, entityID) {
// keep redundancy check separate from `acc` because an `entityID`
// could have been added to `acc` as a related entity through an earlier pass
- if (processedIDs.has(entityID)) return acc;
+ if (processedIDs.has(entityID)) { return acc; }
processedIDs.add(entityID);
var entity = graph.hasEntity(entityID);
- if (!entity) return acc;
+ if (!entity) { return acc; }
acc.add(entityID);
entityIDs.forEach(function(entityID) {
var entity = graph.hasEntity(entityID);
// don't validate deleted entities
- if (!entity) return;
+ if (!entity) { return; }
var issues = validateEntity(entity, graph);
cache.cacheIssues(issues);
.on('redone.validator', validator.validate); // redo
// but not on 'change' (e.g. while drawing)
- // When user chages editing modes:
+ // When user changes editing modes:
context
.on('exit.validator', validator.validate);
// When merging fetched data:
context.history()
.on('merge.validator', function(entities) {
- if (!entities) return;
+ if (!entities) { return; }
var handle = window.requestIdleCallback(function() {
var entityIDs = entities.map(function(entity) { return entity.id; });
var headGraph = context.graph();
//
cache.uncacheEntityID = function(entityID) {
var issueIDs = cache.issuesByEntityID[entityID];
- if (!issueIDs) return;
+ if (!issueIDs) { return; }
issueIDs.forEach(function(issueID) {
var issue = cache.issuesByIssueID[issueID];
}
var osm = context.connection();
- if (!osm) return;
+ if (!osm) { return; }
// If user somehow got logged out mid-save, try to reauthenticate..
// This can happen if they were logged in from before, but the tokens are no longer valid.
function performFullConflictCheck(changeset) {
var osm = context.connection();
- if (!osm) return;
+ if (!osm) { return; }
var history = context.history();
var s = new Set(ids);
ids.forEach(function(id) {
var entity = graph.entity(id);
- if (entity.type !== 'way') return;
+ if (entity.type !== 'way') { return; }
graph.childNodes(entity).forEach(function(child) {
if (child.version !== undefined) {
// Reload modified entities into an alternate graph and check for conflicts..
function loaded(err, result) {
- if (_errors.length) return;
+ if (_errors.length) { return; }
if (err) {
_errors.push({
_loaded[entity.id] = true;
_toLoad = _toLoad.filter(function(val) { return val !== entity.id; });
- if (!entity.visible) return;
+ if (!entity.visible) { return; }
// Because loadMultiple doesn't download /full like loadEntity,
// need to also load children that aren't already being checked..
}
function sameVersions(local, remote) {
- if (local.version !== remote.version) return false;
+ if (local.version !== remote.version) { return false; }
if (local.type === 'way') {
var children = utilArrayUnion(local.nodes, remote.nodes);
for (var i = 0; i < children.length; i++) {
var a = localGraph.hasEntity(children[i]);
var b = remoteGraph.hasEntity(children[i]);
- if (a && b && a.version !== b.version) return false;
+ if (a && b && a.version !== b.version) { return false; }
}
}
var local = localGraph.entity(id);
var remote = remoteGraph.entity(id);
- if (sameVersions(local, remote)) return;
+ if (sameVersions(local, remote)) { return; }
var merge = actionMergeRemoteChanges(id, localGraph, remoteGraph, _discardTags, formatUser);
history.replace(merge);
var mergeConflicts = merge.conflicts();
- if (!mergeConflicts.length) return; // merged safely
+ if (!mergeConflicts.length) { return; } // merged safely
var forceLocal = actionMergeRemoteChanges(id, localGraph, remoteGraph, _discardTags).withOption('force_local');
var forceRemote = actionMergeRemoteChanges(id, localGraph, remoteGraph, _discardTags).withOption('force_remote');
var isRetina = window.devicePixelRatio && window.devicePixelRatio >= 2;
// listen for DPI change, e.g. when dragging a browser window from a retina to non-retina screen
- window.matchMedia(`
- (-webkit-min-device-pixel-ratio: 2), /* Safari */
- (min-resolution: 2dppx), /* standard */
- (min-resolution: 192dpi) /* fallback */
- `).addListener(function() {
+ window.matchMedia("\n (-webkit-min-device-pixel-ratio: 2), /* Safari */\n (min-resolution: 2dppx), /* standard */\n (min-resolution: 192dpi) /* fallback */\n ").addListener(function() {
isRetina = window.devicePixelRatio && window.devicePixelRatio >= 2;
});
function localeDateString(s) {
- if (!s) return null;
+ if (!s) { return null; }
var options = { day: 'numeric', month: 'short', year: 'numeric' };
var d = new Date(s);
- if (isNaN(d.getTime())) return null;
+ if (isNaN(d.getTime())) { return null; }
return d.toLocaleDateString(_mainLocalizer.localeCode(), options);
}
source.overzoom = data.overzoom !== false;
source.offset = function(val) {
- if (!arguments.length) return _offset;
+ if (!arguments.length) { return _offset; }
_offset = val;
return source;
};
source.area = function() {
- if (!data.polygon) return Number.MAX_VALUE; // worldwide
+ if (!data.polygon) { return Number.MAX_VALUE; } // worldwide
var area = d3_geoArea({ type: 'MultiPolygon', coordinates: [ data.polygon ] });
return isNaN(area) ? 0 : area;
};
source.template = function(val) {
- if (!arguments.length) return _template;
+ if (!arguments.length) { return _template; }
if (source.id === 'custom') {
_template = val;
}
source.url = function(coord) {
var result = _template;
- if (result === '') return result; // source 'none'
+ if (result === '') { return result; } // source 'none'
// Guess a type based on the tokens present in the template
// (This is for 'custom' source, where we don't know)
if (!source.type) {
- if (/\{(proj|wkid|bbox)\}/.test(_template)) {
+ if (/SERVICE=WMS|\{(proj|wkid|bbox)\}/.test(_template)) {
source.type = 'wms';
source.projection = 'EPSG:3857'; // guess
} else if (/\{(x|y)\}/.test(_template)) {
switch (key) {
case 'width':
case 'height':
- return tileSize;
+ return tileSize;
case 'proj':
- return projection;
+ return projection;
case 'wkid':
- return projection.replace(/^EPSG:/, '');
+ return projection.replace(/^EPSG:/, '');
case 'bbox':
- return minXmaxY.x + ',' + maxXminY.y + ',' + maxXminY.x + ',' + minXmaxY.y;
+ // WMS 1.3 flips x/y for some coordinate systems including EPSG:4326 - #7557
+ if (projection === 'EPSG:4326' &&
+ // The CRS parameter implies version 1.3 (prior versions use SRS)
+ /VERSION=1.3|CRS={proj}/.test(source.template())) {
+ return maxXminY.y + ',' + minXmaxY.x + ',' + minXmaxY.y + ',' + maxXminY.x;
+ } else {
+ return minXmaxY.x + ',' + maxXminY.y + ',' + maxXminY.x + ',' + minXmaxY.y;
+ }
case 'w':
- return minXmaxY.x;
+ return minXmaxY.x;
case 's':
- return maxXminY.y;
+ return maxXminY.y;
case 'n':
- return maxXminY.x;
+ return maxXminY.x;
case 'e':
- return minXmaxY.y;
+ return minXmaxY.y;
default:
- return token;
+ return token;
}
});
for (var zoom = coord[2]; zoom > 0; zoom--) {
var b = 0;
var mask = 1 << (zoom - 1);
- if ((coord[0] & mask) !== 0) b++;
- if ((coord[1] & mask) !== 0) b += 2;
+ if ((coord[0] & mask) !== 0) { b++; }
+ if ((coord[1] & mask) !== 0) { b += 2; }
u += b.toString();
}
return u;
var url = 'https://dev.virtualearth.net/REST/v1/Imagery/Metadata/Aerial/' + centerPoint +
'?zl=' + zoom + '&key=' + key;
- if (inflight[tileID]) return;
+ if (inflight[tileID]) { return; }
if (!cache[tileID]) {
cache[tileID] = {};
var metadata = { vintage: vintage };
cache[tileID].metadata = metadata;
- if (callback) callback(null, metadata);
+ if (callback) { callback(null, metadata); }
})
.catch(function(err) {
delete inflight[tileID];
- if (callback) callback(err.message);
+ if (callback) { callback(err.message); }
});
};
// https://developers.arcgis.com/documentation/tiled-elevation-service/
esri.fetchTilemap = function(center) {
// skip if we have already fetched a tilemap within 5km
- if (_prevCenter && geoSphericalDistance(center, _prevCenter) < 5000) return;
+ if (_prevCenter && geoSphericalDistance(center, _prevCenter) < 5000) { return; }
_prevCenter = center;
// tiles are available globally to zoom level 19, afterward they may or may not be present
var vintage = {};
var metadata = {};
- if (inflight[tileID]) return;
+ if (inflight[tileID]) { return; }
switch (true) {
case (zoom >= 20 && esri.id === 'EsriWorldImageryClarity'):
}
cache[tileID].metadata = metadata;
- if (callback) callback(null, metadata);
+ if (callback) { callback(null, metadata); }
})
.catch(function(err) {
delete inflight[tileID];
- if (callback) callback(err.message);
+ if (callback) { callback(err.message); }
});
}
// Important that this part not depend on `_projection` because it's
// rentered when tiles load/error (see #644).
function render(selection) {
- if (!_source) return;
+ if (!_source) { return; }
var requests = [];
var showDebug = context.getDebug('tile') && !_source.overlay;
tiler().forEach(function(d) {
addSource(d);
- if (d[3] === '') return;
- if (typeof d[3] !== 'string') return; // Workaround for #2295
+ if (d[3] === '') { return; }
+ if (typeof d[3] !== 'string') { return; } // Workaround for #2295
requests.push(d);
if (_cache[d[3]] === false && lookUp(d)) {
requests.push(addSource(lookUp(d)));
background.projection = function(val) {
- if (!arguments.length) return _projection;
+ if (!arguments.length) { return _projection; }
_projection = val;
return background;
};
background.dimensions = function(val) {
- if (!arguments.length) return tiler.size();
+ if (!arguments.length) { return tiler.size(); }
tiler.size(val);
return background;
};
background.source = function(val) {
- if (!arguments.length) return _source;
+ if (!arguments.length) { return _source; }
_source = val;
_tileSize = _source.tileSize;
_cache = {};
return background;
}
- let _imageryIndex = null;
+ var _imageryIndex = null;
function rendererBackground(context) {
- const dispatch$1 = dispatch('change');
- const detected = utilDetect();
- const baseLayer = rendererTileLayer(context).projection(context.projection);
- let _isValid = true;
- let _overlayLayers = [];
- let _brightness = 1;
- let _contrast = 1;
- let _saturation = 1;
- let _sharpness = 1;
+ var dispatch$1 = dispatch('change');
+ var detected = utilDetect();
+ var baseLayer = rendererTileLayer(context).projection(context.projection);
+ var _isValid = true;
+ var _overlayLayers = [];
+ var _brightness = 1;
+ var _contrast = 1;
+ var _saturation = 1;
+ var _sharpness = 1;
function ensureImageryIndex() {
return _mainFileFetcher.get('imagery')
- .then(sources => {
- if (_imageryIndex) return _imageryIndex;
+ .then(function (sources) {
+ if (_imageryIndex) { return _imageryIndex; }
_imageryIndex = {
imagery: sources,
};
// use which-polygon to support efficient index and querying for imagery
- const features = sources.map(source => {
- if (!source.polygon) return null;
+ var features = sources.map(function (source) {
+ if (!source.polygon) { return null; }
// workaround for editor-layer-index weirdness..
// Add an extra array nest to each element in `source.polygon`
// so the rings are not treated as a bunch of holes:
// what we have: [ [[outer],[hole],[hole]] ]
// what we want: [ [[outer]],[[outer]],[[outer]] ]
- const rings = source.polygon.map(ring => [ring]);
+ var rings = source.polygon.map(function (ring) { return [ring]; });
- const feature = {
+ var feature = {
type: 'Feature',
properties: { id: source.id },
geometry: { type: 'MultiPolygon', coordinates: rings }
// Instantiate `rendererBackgroundSource` objects for each source
- _imageryIndex.backgrounds = sources.map(source => {
+ _imageryIndex.backgrounds = sources.map(function (source) {
if (source.type === 'bing') {
return rendererBackgroundSource.Bing(source, dispatch$1);
} else if (/^EsriWorldImagery/.test(source.id)) {
_imageryIndex.backgrounds.unshift(rendererBackgroundSource.None());
// Add 'Custom'
- let template = corePreferences('background-custom-template') || '';
- const custom = rendererBackgroundSource.Custom(template);
+ var template = corePreferences('background-custom-template') || '';
+ var custom = rendererBackgroundSource.Custom(template);
_imageryIndex.backgrounds.unshift(custom);
return _imageryIndex;
function background(selection) {
- const currSource = baseLayer.source();
+ var currSource = baseLayer.source();
// If we are displaying an Esri basemap at high zoom,
// check its tilemap to see how high the zoom can go
if (context.map().zoom() > 18) {
if (currSource && /^EsriWorldImagery/.test(currSource.id)) {
- const center = context.map().center();
+ var center = context.map().center();
currSource.fetchTilemap(center);
}
}
// Is the imagery valid here? - #4827
- const sources = background.sources(context.map().extent());
- const wasValid = _isValid;
- _isValid = !!sources.filter(d => d === currSource).length;
+ var sources = background.sources(context.map().extent());
+ var wasValid = _isValid;
+ _isValid = !!sources.filter(function (d) { return d === currSource; }).length;
if (wasValid !== _isValid) { // change in valid status
background.updateImagery();
}
- let baseFilter = '';
+ var baseFilter = '';
if (detected.cssfilters) {
if (_brightness !== 1) {
- baseFilter += ` brightness(${_brightness})`;
+ baseFilter += " brightness(" + _brightness + ")";
}
if (_contrast !== 1) {
- baseFilter += ` contrast(${_contrast})`;
+ baseFilter += " contrast(" + _contrast + ")";
}
if (_saturation !== 1) {
- baseFilter += ` saturate(${_saturation})`;
+ baseFilter += " saturate(" + _saturation + ")";
}
if (_sharpness < 1) { // gaussian blur
- const blur = d3_interpolateNumber(0.5, 5)(1 - _sharpness);
- baseFilter += ` blur(${blur}px)`;
+ var blur = d3_interpolateNumber(0.5, 5)(1 - _sharpness);
+ baseFilter += " blur(" + blur + "px)";
}
}
- let base = selection.selectAll('.layer-background')
+ var base = selection.selectAll('.layer-background')
.data([0]);
base = base.enter()
}
- let imagery = base.selectAll('.layer-imagery')
+ var imagery = base.selectAll('.layer-imagery')
.data([0]);
imagery.enter()
.call(baseLayer);
- let maskFilter = '';
- let mixBlendMode = '';
+ var maskFilter = '';
+ var mixBlendMode = '';
if (detected.cssfilters && _sharpness > 1) { // apply unsharp mask
mixBlendMode = 'overlay';
maskFilter = 'saturate(0) blur(3px) invert(1)';
- let contrast = _sharpness - 1;
- maskFilter += ` contrast(${contrast})`;
+ var contrast = _sharpness - 1;
+ maskFilter += " contrast(" + contrast + ")";
- let brightness = d3_interpolateNumber(1, 0.85)(_sharpness - 1);
- maskFilter += ` brightness(${brightness})`;
+ var brightness = d3_interpolateNumber(1, 0.85)(_sharpness - 1);
+ maskFilter += " brightness(" + brightness + ")";
}
- let mask = base.selectAll('.layer-unsharp-mask')
+ var mask = base.selectAll('.layer-unsharp-mask')
.data(detected.cssfilters && _sharpness > 1 ? [0] : []);
mask.exit()
.style('mix-blend-mode', mixBlendMode || null);
- let overlays = selection.selectAll('.layer-overlay')
- .data(_overlayLayers, d => d.source().name());
+ var overlays = selection.selectAll('.layer-overlay')
+ .data(_overlayLayers, function (d) { return d.source().name(); });
overlays.exit()
.remove();
.insert('div', '.layer-data')
.attr('class', 'layer layer-overlay')
.merge(overlays)
- .each((layer, i, nodes) => select(nodes[i]).call(layer));
+ .each(function (layer, i, nodes) { return select(nodes[i]).call(layer); });
}
background.updateImagery = function() {
- let currSource = baseLayer.source();
- if (context.inIntro() || !currSource) return;
+ var currSource = baseLayer.source();
+ if (context.inIntro() || !currSource) { return; }
- let o = _overlayLayers
- .filter(d => !d.source().isLocatorOverlay() && !d.source().isHidden())
- .map(d => d.source().id)
+ var o = _overlayLayers
+ .filter(function (d) { return !d.source().isLocatorOverlay() && !d.source().isHidden(); })
+ .map(function (d) { return d.source().id; })
.join(',');
- const meters = geoOffsetToMeters(currSource.offset());
- const EPSILON = 0.01;
- const x = +meters[0].toFixed(2);
- const y = +meters[1].toFixed(2);
- let hash = utilStringQs(window.location.hash);
+ var meters = geoOffsetToMeters(currSource.offset());
+ var EPSILON = 0.01;
+ var x = +meters[0].toFixed(2);
+ var y = +meters[1].toFixed(2);
+ var hash = utilStringQs(window.location.hash);
- let id = currSource.id;
+ var id = currSource.id;
if (id === 'custom') {
- id = `custom:${currSource.template()}`;
+ id = "custom:" + (currSource.template());
}
if (id) {
}
if (Math.abs(x) > EPSILON || Math.abs(y) > EPSILON) {
- hash.offset = `${x},${y}`;
+ hash.offset = x + "," + y;
} else {
delete hash.offset;
}
window.location.replace('#' + utilQsString(hash, true));
}
- let imageryUsed = [];
- let photoOverlaysUsed = [];
+ var imageryUsed = [];
+ var photoOverlaysUsed = [];
- const currUsed = currSource.imageryUsed();
+ var currUsed = currSource.imageryUsed();
if (currUsed && _isValid) {
imageryUsed.push(currUsed);
}
_overlayLayers
- .filter(d => !d.source().isLocatorOverlay() && !d.source().isHidden())
- .forEach(d => imageryUsed.push(d.source().imageryUsed()));
+ .filter(function (d) { return !d.source().isLocatorOverlay() && !d.source().isHidden(); })
+ .forEach(function (d) { return imageryUsed.push(d.source().imageryUsed()); });
- const dataLayer = context.layers().layer('data');
+ var dataLayer = context.layers().layer('data');
if (dataLayer && dataLayer.enabled() && dataLayer.hasData()) {
imageryUsed.push(dataLayer.getSrc());
}
- const photoOverlayLayers = {
+ var photoOverlayLayers = {
streetside: 'Bing Streetside',
mapillary: 'Mapillary Images',
'mapillary-map-features': 'Mapillary Map Features',
openstreetcam: 'OpenStreetCam Images'
};
- for (let layerID in photoOverlayLayers) {
- const layer = context.layers().layer(layerID);
+ for (var layerID in photoOverlayLayers) {
+ var layer = context.layers().layer(layerID);
if (layer && layer.enabled()) {
photoOverlaysUsed.push(layerID);
imageryUsed.push(photoOverlayLayers[layerID]);
context.history().photoOverlaysUsed(photoOverlaysUsed);
};
+ var _checkedBlocklists;
- background.sources = (extent, zoom, includeCurrent) => {
- if (!_imageryIndex) return []; // called before init()?
+ background.sources = function (extent, zoom, includeCurrent) {
+ if (!_imageryIndex) { return []; } // called before init()?
- let visible = {};
+ var visible = {};
(_imageryIndex.query.bbox(extent.rectangle(), true) || [])
- .forEach(d => visible[d.id] = true);
+ .forEach(function (d) { return visible[d.id] = true; });
- const currSource = baseLayer.source();
+ var currSource = baseLayer.source();
- return _imageryIndex.backgrounds.filter(source => {
- if (!source.polygon) return true; // always include imagery with worldwide coverage
- if (includeCurrent && currSource === source) return true; // optionally include the current imagery
- if (zoom && zoom < 6) return false; // optionally exclude local imagery at low zooms
+ var osm = context.connection();
+ var blocklists = osm && osm.imageryBlocklists();
+
+ if (blocklists && blocklists !== _checkedBlocklists) {
+ _imageryIndex.backgrounds.forEach(function (source) {
+ source.isBlocked = blocklists.some(function(blocklist) {
+ return blocklist.test(source.template());
+ });
+ });
+ _checkedBlocklists = blocklists;
+ }
+
+ return _imageryIndex.backgrounds.filter(function (source) {
+ if (includeCurrent && currSource === source) { return true; } // optionally always include the current imagery
+ if (source.isBlocked) { return false; } // even bundled sources may be blocked - #7905
+ if (!source.polygon) { return true; } // always include imagery with worldwide coverage
+ if (zoom && zoom < 6) { return false; } // optionally exclude local imagery at low zooms
return visible[source.id]; // include imagery visible in given extent
});
};
- background.dimensions = (val) => {
- if (!val) return;
+ background.dimensions = function (val) {
+ if (!val) { return; }
baseLayer.dimensions(val);
- _overlayLayers.forEach(layer => layer.dimensions(val));
+ _overlayLayers.forEach(function (layer) { return layer.dimensions(val); });
};
background.baseLayerSource = function(d) {
- if (!arguments.length) return baseLayer.source();
+ if (!arguments.length) { return baseLayer.source(); }
- // test source against OSM imagery blacklists..
- const osm = context.connection();
- if (!osm) return background;
+ // test source against OSM imagery blocklists..
+ var osm = context.connection();
+ if (!osm) { return background; }
- const blacklists = osm.imageryBlacklists();
- const template = d.template();
- let fail = false;
- let tested = 0;
- let regex;
+ var blocklists = osm.imageryBlocklists();
+ var template = d.template();
+ var fail = false;
+ var tested = 0;
+ var regex;
- for (let i = 0; i < blacklists.length; i++) {
- try {
- regex = new RegExp(blacklists[i]);
- fail = regex.test(template);
- tested++;
- if (fail) break;
- } catch (e) {
- /* noop */
- }
+ for (var i = 0; i < blocklists.length; i++) {
+ regex = blocklists[i];
+ fail = regex.test(template);
+ tested++;
+ if (fail) { break; }
}
// ensure at least one test was run.
if (!tested) {
- regex = new RegExp('.*\.google(apis)?\..*/(vt|kh)[\?/].*([xyz]=.*){3}.*');
+ regex = /.*\.google(apis)?\..*\/(vt|kh)[\?\/].*([xyz]=.*){3}.*/;
fail = regex.test(template);
}
};
- background.findSource = (id) => {
- if (!id || !_imageryIndex) return null; // called before init()?
- return _imageryIndex.backgrounds.find(d => d.id && d.id === id);
+ background.findSource = function (id) {
+ if (!id || !_imageryIndex) { return null; } // called before init()?
+ return _imageryIndex.backgrounds.find(function (d) { return d.id && d.id === id; });
};
- background.bing = () => {
+ background.bing = function () {
background.baseLayerSource(background.findSource('Bing'));
};
- background.showsLayer = (d) => {
- const currSource = baseLayer.source();
- if (!d || !currSource) return false;
- return d.id === currSource.id || _overlayLayers.some(layer => d.id === layer.source().id);
+ background.showsLayer = function (d) {
+ var currSource = baseLayer.source();
+ if (!d || !currSource) { return false; }
+ return d.id === currSource.id || _overlayLayers.some(function (layer) { return d.id === layer.source().id; });
};
- background.overlayLayerSources = () => {
- return _overlayLayers.map(layer => layer.source());
+ background.overlayLayerSources = function () {
+ return _overlayLayers.map(function (layer) { return layer.source(); });
};
- background.toggleOverlayLayer = (d) => {
- let layer;
- for (let i = 0; i < _overlayLayers.length; i++) {
+ background.toggleOverlayLayer = function (d) {
+ var layer;
+ for (var i = 0; i < _overlayLayers.length; i++) {
layer = _overlayLayers[i];
if (layer.source() === d) {
_overlayLayers.splice(i, 1);
};
- background.nudge = (d, zoom) => {
- const currSource = baseLayer.source();
+ background.nudge = function (d, zoom) {
+ var currSource = baseLayer.source();
if (currSource) {
currSource.nudge(d, zoom);
dispatch$1.call('change');
background.offset = function(d) {
- const currSource = baseLayer.source();
+ var currSource = baseLayer.source();
if (!arguments.length) {
return (currSource && currSource.offset()) || [0, 0];
}
background.brightness = function(d) {
- if (!arguments.length) return _brightness;
+ if (!arguments.length) { return _brightness; }
_brightness = d;
- if (context.mode()) dispatch$1.call('change');
+ if (context.mode()) { dispatch$1.call('change'); }
return background;
};
background.contrast = function(d) {
- if (!arguments.length) return _contrast;
+ if (!arguments.length) { return _contrast; }
_contrast = d;
- if (context.mode()) dispatch$1.call('change');
+ if (context.mode()) { dispatch$1.call('change'); }
return background;
};
background.saturation = function(d) {
- if (!arguments.length) return _saturation;
+ if (!arguments.length) { return _saturation; }
_saturation = d;
- if (context.mode()) dispatch$1.call('change');
+ if (context.mode()) { dispatch$1.call('change'); }
return background;
};
background.sharpness = function(d) {
- if (!arguments.length) return _sharpness;
+ if (!arguments.length) { return _sharpness; }
_sharpness = d;
- if (context.mode()) dispatch$1.call('change');
+ if (context.mode()) { dispatch$1.call('change'); }
return background;
};
- let _loadPromise;
+ var _loadPromise;
- background.ensureLoaded = () => {
+ background.ensureLoaded = function () {
- if (_loadPromise) return _loadPromise;
+ if (_loadPromise) { return _loadPromise; }
function parseMapParams(qmap) {
- if (!qmap) return false;
- const params = qmap.split('/').map(Number);
- if (params.length < 3 || params.some(isNaN)) return false;
+ if (!qmap) { return false; }
+ var params = qmap.split('/').map(Number);
+ if (params.length < 3 || params.some(isNaN)) { return false; }
return geoExtent([params[2], params[1]]); // lon,lat
}
- const hash = utilStringQs(window.location.hash);
- const requested = hash.background || hash.layer;
- let extent = parseMapParams(hash.map);
+ var hash = utilStringQs(window.location.hash);
+ var requested = hash.background || hash.layer;
+ var extent = parseMapParams(hash.map);
return _loadPromise = ensureImageryIndex()
- .then(imageryIndex => {
- const first = imageryIndex.backgrounds.length && imageryIndex.backgrounds[0];
+ .then(function (imageryIndex) {
+ var first = imageryIndex.backgrounds.length && imageryIndex.backgrounds[0];
- let best;
+ var best;
if (!requested && extent) {
- best = background.sources(extent).find(s => s.best());
+ best = background.sources(extent).find(function (s) { return s.best(); });
}
// Decide which background layer to display
if (requested && requested.indexOf('custom:') === 0) {
- const template = requested.replace(/^custom:/, '');
- const custom = background.findSource('custom');
+ var template = requested.replace(/^custom:/, '');
+ var custom = background.findSource('custom');
background.baseLayerSource(custom.template(template));
corePreferences('background-custom-template', template);
} else {
);
}
- const locator = imageryIndex.backgrounds.find(d => d.overlay && d.default);
+ var locator = imageryIndex.backgrounds.find(function (d) { return d.overlay && d.default; });
if (locator) {
background.toggleOverlayLayer(locator);
}
- const overlays = (hash.overlays || '').split(',');
- overlays.forEach(overlay => {
+ var overlays = (hash.overlays || '').split(',');
+ overlays.forEach(function (overlay) {
overlay = background.findSource(overlay);
if (overlay) {
background.toggleOverlayLayer(overlay);
});
if (hash.gpx) {
- const gpx = context.layers().layer('data');
+ var gpx = context.layers().layer('data');
if (gpx) {
gpx.url(hash.gpx, '.gpx');
}
}
if (hash.offset) {
- const offset = hash.offset
+ var offset = hash.offset
.replace(/;/g, ',')
.split(',')
- .map(n => !isNaN(n) && n);
+ .map(function (n) { return !isNaN(n) && n; });
if (offset.length === 2) {
background.offset(geoMetersToOffset(offset));
}
}
})
- .catch(() => { /* ignore */ });
+ .catch(function () { /* ignore */ });
};
_rules[k].enable();
}
}
- if (didEnable) update();
+ if (didEnable) { update(); }
};
_rules[k].disable();
}
}
- if (didDisable) update();
+ if (didDisable) { update(); }
};
features.getMatches = function(entity, resolver, geometry) {
if (geometry === 'vertex' ||
- (geometry === 'relation' && !relationShouldBeChecked(entity))) return {};
+ (geometry === 'relation' && !relationShouldBeChecked(entity))) { return {}; }
var ent = osmEntity.key(entity);
if (!_cache[ent]) {
for (var i = 0; i < _keys.length; i++) {
if (_keys[i] === 'others') {
- if (hasMatch) continue;
+ if (hasMatch) { continue; }
// If an entity...
// 1. is a way that hasn't matched other 'interesting' feature rules,
features.getParents = function(entity, resolver, geometry) {
- if (geometry === 'point') return [];
+ if (geometry === 'point') { return []; }
var ent = osmEntity.key(entity);
if (!_cache[ent]) {
features.isHiddenPreset = function(preset, geometry) {
- if (!_hidden.length) return false;
- if (!preset.tags) return false;
+ if (!_hidden.length) { return false; }
+ if (!preset.tags) { return false; }
var test = preset.setTags({}, geometry);
for (var key in _rules) {
features.isHiddenFeature = function(entity, resolver, geometry) {
- if (!_hidden.length) return false;
- if (!entity.version) return false;
- if (_forceVisible[entity.id]) return false;
+ if (!_hidden.length) { return false; }
+ if (!entity.version) { return false; }
+ if (_forceVisible[entity.id]) { return false; }
var matches = Object.keys(features.getMatches(entity, resolver, geometry));
return matches.length && matches.every(function(k) { return features.hidden(k); });
features.isHiddenChild = function(entity, resolver, geometry) {
- if (!_hidden.length) return false;
- if (!entity.version || geometry === 'point') return false;
- if (_forceVisible[entity.id]) return false;
+ if (!_hidden.length) { return false; }
+ if (!entity.version || geometry === 'point') { return false; }
+ if (_forceVisible[entity.id]) { return false; }
var parents = features.getParents(entity, resolver, geometry);
- if (!parents.length) return false;
+ if (!parents.length) { return false; }
for (var i = 0; i < parents.length; i++) {
if (!features.isHidden(parents[i], resolver, parents[i].geometry(resolver))) {
features.hasHiddenConnections = function(entity, resolver) {
- if (!_hidden.length) return false;
+ if (!_hidden.length) { return false; }
var childNodes, connections;
if (entity.type === 'midpoint') {
features.isHidden = function(entity, resolver, geometry) {
- if (!_hidden.length) return false;
- if (!entity.version) return false;
+ if (!_hidden.length) { return false; }
+ if (!entity.version) { return false; }
var fn = (geometry === 'vertex' ? features.isHiddenChild : features.isHiddenFeature);
return fn(entity, resolver, geometry);
features.filter = function(d, resolver) {
- if (!_hidden.length) return d;
+ if (!_hidden.length) { return d; }
var result = [];
for (var i = 0; i < d.length; i++) {
features.forceVisible = function(entityIDs) {
- if (!arguments.length) return Object.keys(_forceVisible);
+ if (!arguments.length) { return Object.keys(_forceVisible); }
_forceVisible = {};
for (var i = 0; i < entityIDs.length; i++) {
// warm up the feature matching cache upon merging fetched data
context.history().on('merge.features', function(newEntities) {
- if (!newEntities) return;
+ if (!newEntities) { return; }
var handle = window.requestIdleCallback(function() {
var graph = context.graph();
var types = utilArrayGroupBy(newEntities, 'type');
// 2 = adjacent vertex - yes but pay attention segmenting a line here
//
function svgPassiveVertex(node, graph, activeID) {
- if (!activeID) return 1;
- if (activeID === node.id) return 0;
+ if (!activeID) { return 1; }
+ if (activeID === node.id) { return 0; }
var parents = graph.parentWays(node);
if (isClosed) { // wraparound if needed
max = nodes.length - 1;
- if (ix1 < 0) ix1 = max + ix1;
- if (ix2 < 0) ix2 = max + ix2;
- if (ix3 > max) ix3 = ix3 - max;
- if (ix4 > max) ix4 = ix4 - max;
+ if (ix1 < 0) { ix1 = max + ix1; }
+ if (ix2 < 0) { ix2 = max + ix2; }
+ if (ix3 > max) { ix3 = ix3 - max; }
+ if (ix4 > max) { ix4 = ix4 - max; }
}
- if (nodes[ix1] === activeID) return 0; // no - prevent self intersect
- else if (nodes[ix2] === activeID) return 2; // ok - adjacent
- else if (nodes[ix3] === activeID) return 2; // ok - adjacent
- else if (nodes[ix4] === activeID) return 0; // no - prevent self intersect
- else if (isClosed && nodes.indexOf(activeID) !== -1) return 0; // no - prevent self intersect
+ if (nodes[ix1] === activeID) { return 0; } // no - prevent self intersect
+ else if (nodes[ix2] === activeID) { return 2; } // ok - adjacent
+ else if (nodes[ix3] === activeID) { return 2; } // ok - adjacent
+ else if (nodes[ix4] === activeID) { return 0; } // no - prevent self intersect
+ else if (isClosed && nodes.indexOf(activeID) !== -1) { return 0; } // no - prevent self intersect
}
}
}
for (i = 0; i < primaries.length; i++) {
k = primaries[i];
v = t[k];
- if (!v || v === 'no') continue;
+ if (!v || v === 'no') { continue; }
if (k === 'piste:type') { // avoid a ':' in the class name
k = 'piste';
for (j = 0; j < primaries.length; j++) {
k = statuses[i] + ':' + primaries[j]; // e.g. `demolished:building=yes`
v = t[k];
- if (!v || v === 'no') continue;
+ if (!v || v === 'no') { continue; }
status = statuses[i];
break;
for (i = 0; i < statuses.length; i++) {
k = statuses[i];
v = t[k];
- if (!v || v === 'no') continue;
+ if (!v || v === 'no') { continue; }
if (v === 'yes') { // e.g. `railway=rail + abandoned=yes`
status = k;
classes.push('tag-' + v);
} // else ignore e.g. `highway=path + abandoned=railway`
- if (status) break;
+ if (status) { break; }
}
}
for (i = 0; i < secondaries.length; i++) {
k = secondaries[i];
v = t[k];
- if (!v || v === 'no' || k === primary) continue;
+ if (!v || v === 'no' || k === primary) { continue; }
classes.push('tag-' + k);
classes.push('tag-' + k + '-' + v);
}
tagClasses.tags = function(val) {
- if (!arguments.length) return _tags;
+ if (!arguments.length) { return _tags; }
_tags = val;
return tagClasses;
};
grave_yard: 'cemetery',
grass: [
{ golf: 'green', pattern: 'golf_green' },
- { pattern: 'grass' },
- ],
+ { pattern: 'grass' } ],
landfill: 'landfill',
meadow: 'meadow',
military: 'construction',
},
traffic_calming: {
island: [
- { surface: 'grass', pattern: 'grass' },
- ],
+ { surface: 'grass', pattern: 'grass' } ],
chicane: [
- { surface: 'grass', pattern: 'grass' },
- ],
+ { surface: 'grass', pattern: 'grass' } ],
choker: [
- { surface: 'grass', pattern: 'grass' },
- ]
+ { surface: 'grass', pattern: 'grass' } ]
}
};
for (var tag in patterns) {
var entityValue = tags[tag];
- if (!entityValue) continue;
+ if (!entityValue) { continue; }
if (typeof patterns[tag] === 'string') { // extra short syntax (just tag) - pattern name
return 'pattern-' + patterns[tag];
} else {
var values = patterns[tag];
for (var value in values) {
- if (entityValue !== value) continue;
+ if (entityValue !== value) { continue; }
var rules = values[value];
if (typeof rules === 'string') { // short syntax - pattern name
for (var i = 0; i < entities.length; i++) {
var entity = entities[i];
- if (entity.geometry(graph) !== 'area') continue;
+ if (entity.geometry(graph) !== 'area') { continue; }
multipolygon = osmIsOldMultipolygonOuterMember(entity, graph);
if (multipolygon) {
reg.exec(source);//skip <
while(match = reg.exec(source)){
buf.push(match);
- if(match[1])return buf;
+ if(match[1]){ return buf; }
}
}
error = this;
Error.call(this, ExceptionMessage[code]);
this.message = ExceptionMessage[code];
- if(Error.captureStackTrace) Error.captureStackTrace(this, DOMException$2);
+ if(Error.captureStackTrace) { Error.captureStackTrace(this, DOMException$2); }
}
error.code = code;
- if(message) this.message = this.message + ": " + message;
+ if(message) { this.message = this.message + ": " + message; }
return error;
}DOMException$2.prototype = Error.prototype;
copy$2(ExceptionCode,DOMException$2);
if(prefix == null){
//isHTML = true;
var visibleNamespaces=[
- {namespace:uri,prefix:null}
- //{namespace:uri,prefix:''}
- ];
+ {namespace:uri,prefix:null} ];
}
}
serializeToString(this,buf,isHtml,nodeFilter,visibleNamespaces);
}
switch(node.nodeType){
case ELEMENT_NODE:
- if (!visibleNamespaces) visibleNamespaces = [];
+ if (!visibleNamespaces) { visibleNamespaces = []; }
var startVisibleNamespaces = visibleNamespaces.length;
var attrs = node.attributes;
var len = attrs.length;
splitSpace = /\s+/;
// generate a short, numeric hash of a string
function okhash(x) {
- if (!x || !x.length) return 0;
+ if (!x || !x.length) { return 0; }
for (var i = 0, h = 0; i < x.length; i++) {
h = ((h << 5) - h) + x.charCodeAt(i) | 0;
} return h;
var o = {}, n, k;
for (k = 0; k < ys.length; k++) {
n = get1(x, ys[k]);
- if (n) o[ys[k]] = nodeVal(n);
+ if (n) { o[ys[k]] = nodeVal(n); }
}
return o;
}
// add properties of Y to X, overwriting if present in both
- function extend(x, y) { for (var k in y) x[k] = y[k]; }
+ function extend(x, y) { for (var k in y) { x[k] = y[k]; } }
// get one coordinate from a coordinate array, if any
function coord1(v) { return numarray(v.replace(removeSpace, '').split(',')); }
// get all coordinates from a coordinate array as [[],[]]
// IE9 will create a new XMLSerializer but it'll crash immediately.
// This line is ignored because we don't run coverage tests in IE9
/* istanbul ignore next */
- if (str.xml !== undefined) return str.xml;
+ if (str.xml !== undefined) { return str.xml; }
return serializer.serializeToString(str);
}
function gxCoord(v) { return numarray(v.split(' ')); }
function gxCoords(root) {
var elems = get(root, 'coord'), coords = [], times = [];
- if (elems.length === 0) elems = get(root, 'gx:coord');
- for (var i = 0; i < elems.length; i++) coords.push(gxCoord(nodeVal(elems[i])));
+ if (elems.length === 0) { elems = get(root, 'gx:coord'); }
+ for (var i = 0; i < elems.length; i++) { coords.push(gxCoord(nodeVal(elems[i]))); }
var timeElems = get(root, 'when');
- for (var j = 0; j < timeElems.length; j++) times.push(nodeVal(timeElems[j]));
+ for (var j = 0; j < timeElems.length; j++) { times.push(nodeVal(timeElems[j])); }
return {
coords: coords,
times: times
type: 'LineString',
coordinates: track.coords
});
- if (track.times.length) coordTimes.push(track.times);
+ if (track.times.length) { coordTimes.push(track.times); }
}
}
}
polyStyle = get1(root, 'PolyStyle'),
visibility = get1(root, 'visibility');
- if (!geomsAndTimes.geoms.length) return [];
- if (name) properties.name = name;
- if (address) properties.address = address;
+ if (!geomsAndTimes.geoms.length) { return []; }
+ if (name) { properties.name = name; }
+ if (address) { properties.address = address; }
if (styleUrl) {
if (styleUrl[0] !== '#') {
styleUrl = '#' + styleUrl;
// Try to populate the lineStyle or polyStyle since we got the style hash
var style = styleByHash[properties.styleHash];
if (style) {
- if (!lineStyle) lineStyle = get1(style, 'LineStyle');
- if (!polyStyle) polyStyle = get1(style, 'PolyStyle');
+ if (!lineStyle) { lineStyle = get1(style, 'LineStyle'); }
+ if (!polyStyle) { polyStyle = get1(style, 'PolyStyle'); }
}
}
- if (description) properties.description = description;
+ if (description) { properties.description = description; }
if (timeSpan) {
var begin = nodeVal(get1(timeSpan, 'begin'));
var end = nodeVal(get1(timeSpan, 'end'));
color = linestyles[0],
opacity = linestyles[1],
width = parseFloat(nodeVal(get1(lineStyle, 'width')));
- if (color) properties.stroke = color;
- if (!isNaN(opacity)) properties['stroke-opacity'] = opacity;
- if (!isNaN(width)) properties['stroke-width'] = width;
+ if (color) { properties.stroke = color; }
+ if (!isNaN(opacity)) { properties['stroke-opacity'] = opacity; }
+ if (!isNaN(width)) { properties['stroke-width'] = width; }
}
if (polyStyle) {
var polystyles = kmlColor(nodeVal(get1(polyStyle, 'color'))),
popacity = polystyles[1],
fill = nodeVal(get1(polyStyle, 'fill')),
outline = nodeVal(get1(polyStyle, 'outline'));
- if (pcolor) properties.fill = pcolor;
- if (!isNaN(popacity)) properties['fill-opacity'] = popacity;
- if (fill) properties['fill-opacity'] = fill === '1' ? properties['fill-opacity'] || 1 : 0;
- if (outline) properties['stroke-opacity'] = outline === '1' ? properties['stroke-opacity'] || 1 : 0;
+ if (pcolor) { properties.fill = pcolor; }
+ if (!isNaN(popacity)) { properties['fill-opacity'] = popacity; }
+ if (fill) { properties['fill-opacity'] = fill === '1' ? properties['fill-opacity'] || 1 : 0; }
+ if (outline) { properties['stroke-opacity'] = outline === '1' ? properties['stroke-opacity'] || 1 : 0; }
}
if (extendedData) {
var datas = get(extendedData, 'Data'),
},
properties: properties
};
- if (attr(root, 'id')) feature.id = attr(root, 'id');
+ if (attr(root, 'id')) { feature.id = attr(root, 'id'); }
return [feature];
}
return gj;
feature;
for (i = 0; i < tracks.length; i++) {
feature = getTrack(tracks[i]);
- if (feature) gj.features.push(feature);
+ if (feature) { gj.features.push(feature); }
}
for (i = 0; i < routes.length; i++) {
feature = getRoute(routes[i]);
- if (feature) gj.features.push(feature);
+ if (feature) { gj.features.push(feature); }
}
for (i = 0; i < waypoints.length; i++) {
gj.features.push(getPoint(waypoints[i]));
times = [],
heartRates = [],
l = pts.length;
- if (l < 2) return {}; // Invalid line in GeoJSON
+ if (l < 2) { return {}; } // Invalid line in GeoJSON
for (var i = 0; i < l; i++) {
var c = coordPair(pts[i]);
line.push(c.coordinates);
- if (c.time) times.push(c.time);
- if (c.heartRate) heartRates.push(c.heartRate);
+ if (c.time) { times.push(c.time); }
+ if (c.heartRate) { heartRates.push(c.heartRate); }
}
return {
line: line,
for (var i = 0; i < segments.length; i++) {
line = getPoints(segments[i], 'trkpt');
if (line) {
- if (line.line) track.push(line.line);
- if (line.times && line.times.length) times.push(line.times);
- if (line.heartRates && line.heartRates.length) heartRates.push(line.heartRates);
+ if (line.line) { track.push(line.line); }
+ if (line.times && line.times.length) { times.push(line.times); }
+ if (line.heartRates && line.heartRates.length) { heartRates.push(line.heartRates); }
}
}
- if (track.length === 0) return;
+ if (track.length === 0) { return; }
var properties = getProperties(node);
extend(properties, getLineStyle(get1(node, 'extensions')));
- if (times.length) properties.coordTimes = track.length === 1 ? times[0] : times;
- if (heartRates.length) properties.heartRates = track.length === 1 ? heartRates[0] : heartRates;
+ if (times.length) { properties.coordTimes = track.length === 1 ? times[0] : times; }
+ if (heartRates.length) { properties.heartRates = track.length === 1 ? heartRates[0] : heartRates; }
return {
type: 'Feature',
properties: properties,
}
function getRoute(node) {
var line = getPoints(node, 'rtept');
- if (!line.line) return;
+ if (!line.line) { return; }
var prop = getProperties(node);
extend(prop, getLineStyle(get1(node, 'extensions')));
var routeObj = {
var color = nodeVal(get1(lineStyle, 'color')),
opacity = parseFloat(nodeVal(get1(lineStyle, 'opacity'))),
width = parseFloat(nodeVal(get1(lineStyle, 'width')));
- if (color) style.stroke = color;
- if (!isNaN(opacity)) style['stroke-opacity'] = opacity;
+ if (color) { style.stroke = color; }
+ if (!isNaN(opacity)) { style['stroke-opacity'] = opacity; }
// GPX width is in mm, convert to px with 96 px per inch
- if (!isNaN(width)) style['stroke-width'] = width * 96 / 25.4;
+ if (!isNaN(width)) { style['stroke-width'] = width * 96 / 25.4; }
}
}
return style;
function getProperties(node) {
var prop = getMulti(node, ['name', 'cmt', 'desc', 'type', 'time', 'keywords']),
links = get(node, 'link');
- if (links.length) prop.links = [];
+ if (links.length) { prop.links = []; }
for (var i = 0, link; i < links.length; i++) {
link = { href: attr(links[i], 'href') };
extend(link, getMulti(links[i], ['text', 'type']));
return t;
})();
- module.exports = toGeoJSON;
+ { module.exports = toGeoJSON; }
});
var _initialized = false;
function init() {
- if (_initialized) return; // run once
+ if (_initialized) { return; } // run once
_geojson = {};
_enabled = true;
.on('drop.svgData', function() {
event.stopPropagation();
event.preventDefault();
- if (!detected.filedrop) return;
+ if (!detected.filedrop) { return; }
drawData.fileList(event.dataTransfer.files);
})
.on('dragenter.svgData', over)
// ensure that all geojson features in a collection have IDs
function ensureIDs(gj) {
- if (!gj) return null;
+ if (!gj) { return null; }
if (gj.type === 'FeatureCollection') {
for (var i = 0; i < gj.features.length; i++) {
// ensure that each single Feature object has a unique ID
function ensureFeatureID(feature) {
- if (!feature) return;
+ if (!feature) { return; }
feature.__featurehash__ = utilHashcode(fastJsonStableStringify(feature));
return feature;
}
// Prefer an array of Features instead of a FeatureCollection
function getFeatures(gj) {
- if (!gj) return [];
+ if (!gj) { return []; }
if (gj.type === 'FeatureCollection') {
return gj.features;
.merge(layer);
var surface = context.surface();
- if (!surface || surface.empty()) return; // not ready to draw yet, starting up
+ if (!surface || surface.empty()) { return; } // not ready to draw yet, starting up
// Gather data
function getExtension(fileName) {
- if (!fileName) return;
+ if (!fileName) { return; }
var re = /\.(gpx|kml|(geo)?json)$/i;
var match = fileName.toLowerCase().match(re);
drawData.showLabels = function(val) {
- if (!arguments.length) return _showLabels;
+ if (!arguments.length) { return _showLabels; }
_showLabels = val;
return this;
drawData.enabled = function(val) {
- if (!arguments.length) return _enabled;
+ if (!arguments.length) { return _enabled; }
_enabled = val;
if (_enabled) {
drawData.template = function(val, src) {
- if (!arguments.length) return _template;
+ if (!arguments.length) { return _template; }
- // test source against OSM imagery blacklists..
+ // test source against OSM imagery blocklists..
var osm = context.connection();
if (osm) {
- var blacklists = osm.imageryBlacklists();
+ var blocklists = osm.imageryBlocklists();
var fail = false;
var tested = 0;
var regex;
- for (var i = 0; i < blacklists.length; i++) {
- try {
- regex = new RegExp(blacklists[i]);
- fail = regex.test(val);
- tested++;
- if (fail) break;
- } catch (e) {
- /* noop */
- }
+ for (var i = 0; i < blocklists.length; i++) {
+ regex = blocklists[i];
+ fail = regex.test(val);
+ tested++;
+ if (fail) { break; }
}
// ensure at least one test was run.
if (!tested) {
- regex = new RegExp('.*\.google(apis)?\..*/(vt|kh)[\?/].*([xyz]=.*){3}.*');
+ regex = /.*\.google(apis)?\..*\/(vt|kh)[\?\/].*([xyz]=.*){3}.*/;
fail = regex.test(val);
}
}
drawData.geojson = function(gj, src) {
- if (!arguments.length) return _geojson;
+ if (!arguments.length) { return _geojson; }
_template = null;
_fileList = null;
drawData.fileList = function(fileList) {
- if (!arguments.length) return _fileList;
+ if (!arguments.length) { return _fileList; }
_template = null;
_fileList = fileList;
_geojson = null;
_src = null;
- if (!fileList || !fileList.length) return this;
+ if (!fileList || !fileList.length) { return this; }
var f = fileList[0];
var extension = getExtension(f.name);
var reader = new FileReader();
drawData.fitZoom = function() {
var features = getFeatures(_geojson);
- if (!features.length) return;
+ if (!features.length) { return; }
var map = context.map();
var viewport = map.trimmedExtent().polygon();
var coords = features.reduce(function(coords, feature) {
var geom = feature.geometry;
- if (!geom) return coords;
+ if (!geom) { return coords; }
var c = geom.coordinates;
function svgDebug(projection, context) {
function drawDebug(selection) {
- const showTile = context.getDebug('tile');
- const showCollision = context.getDebug('collision');
- const showImagery = context.getDebug('imagery');
- const showTouchTargets = context.getDebug('target');
- const showDownloaded = context.getDebug('downloaded');
+ var showTile = context.getDebug('tile');
+ var showCollision = context.getDebug('collision');
+ var showImagery = context.getDebug('imagery');
+ var showTouchTargets = context.getDebug('target');
+ var showDownloaded = context.getDebug('downloaded');
- let debugData = [];
+ var debugData = [];
if (showTile) {
debugData.push({ class: 'red', label: 'tile' });
}
}
- let legend = context.container().select('.main-content')
+ var legend = context.container().select('.main-content')
.selectAll('.debug-legend')
.data(debugData.length ? [0] : []);
.merge(legend);
- let legendItems = legend.selectAll('.debug-legend-item')
- .data(debugData, d => d.label);
+ var legendItems = legend.selectAll('.debug-legend-item')
+ .data(debugData, function (d) { return d.label; });
legendItems.exit()
.remove();
legendItems.enter()
.append('span')
- .attr('class', d => `debug-legend-item ${d.class}`)
- .text(d => d.label);
+ .attr('class', function (d) { return ("debug-legend-item " + (d.class)); })
+ .text(function (d) { return d.label; });
- let layer = selection.selectAll('.layer-debug')
+ var layer = selection.selectAll('.layer-debug')
.data(showImagery || showDownloaded ? [0] : []);
layer.exit()
// imagery
- const extent = context.map().extent();
+ var extent = context.map().extent();
_mainFileFetcher.get('imagery')
- .then(d => {
- const hits = (showImagery && d.query.bbox(extent.rectangle(), true)) || [];
- const features = hits.map(d => d.features[d.id]);
+ .then(function (d) {
+ var hits = (showImagery && d.query.bbox(extent.rectangle(), true)) || [];
+ var features = hits.map(function (d) { return d.features[d.id]; });
- let imagery = layer.selectAll('path.debug-imagery')
+ var imagery = layer.selectAll('path.debug-imagery')
.data(features);
imagery.exit()
.append('path')
.attr('class', 'debug-imagery debug orange');
})
- .catch(() => { /* ignore */ });
+ .catch(function () { /* ignore */ });
// downloaded
- const osm = context.connection();
- let dataDownloaded = [];
+ var osm = context.connection();
+ var dataDownloaded = [];
if (osm && showDownloaded) {
- const rtree = osm.caches('get').tile.rtree;
- dataDownloaded = rtree.all().map(bbox => {
+ var rtree = osm.caches('get').tile.rtree;
+ dataDownloaded = rtree.all().map(function (bbox) {
return {
type: 'Feature',
properties: { id: bbox.id },
});
}
- let downloaded = layer
+ var downloaded = layer
.selectAll('path.debug-downloaded')
.data(showDownloaded ? dataDownloaded : []);
return drawDebug;
}
- let _layerEnabled = false;
- let _qaService;
+ var _layerEnabled = false;
+ var _qaService;
function svgKeepRight(projection, context, dispatch) {
- const throttledRedraw = throttle(() => dispatch.call('change'), 1000);
- const minZoom = 12;
+ var throttledRedraw = throttle(function () { return dispatch.call('change'); }, 1000);
+ var minZoom = 12;
- let touchLayer = select(null);
- let drawLayer = select(null);
- let layerVisible = false;
+ var touchLayer = select(null);
+ var drawLayer = select(null);
+ var layerVisible = false;
function markerPath(selection, klass) {
selection
.transition()
.duration(250)
.style('opacity', 1)
- .on('end interrupt', () => dispatch.call('change'));
+ .on('end interrupt', function () { return dispatch.call('change'); });
}
// Disable the layer. This transitions the layer invisible and then hides the markers.
.transition()
.duration(250)
.style('opacity', 0)
- .on('end interrupt', () => {
+ .on('end interrupt', function () {
editOff();
dispatch.call('change');
});
// Update the issue markers
function updateMarkers() {
- if (!layerVisible || !_layerEnabled) return;
+ if (!layerVisible || !_layerEnabled) { return; }
- const service = getService();
- const selectedID = context.selectedErrorID();
- const data = (service ? service.getItems(projection) : []);
- const getTransform = svgPointTransform(projection);
+ var service = getService();
+ var selectedID = context.selectedErrorID();
+ var data = (service ? service.getItems(projection) : []);
+ var getTransform = svgPointTransform(projection);
// Draw markers..
- const markers = drawLayer.selectAll('.qaItem.keepRight')
- .data(data, d => d.id);
+ var markers = drawLayer.selectAll('.qaItem.keepRight')
+ .data(data, function (d) { return d.id; });
// exit
markers.exit()
.remove();
// enter
- const markersEnter = markers.enter()
+ var markersEnter = markers.enter()
.append('g')
- .attr('class', d => `qaItem ${d.service} itemId-${d.id} itemType-${d.parentIssueType}`);
+ .attr('class', function (d) { return ("qaItem " + (d.service) + " itemId-" + (d.id) + " itemType-" + (d.parentIssueType)); });
markersEnter
.append('ellipse')
markers
.merge(markersEnter)
.sort(sortY)
- .classed('selected', d => d.id === selectedID)
+ .classed('selected', function (d) { return d.id === selectedID; })
.attr('transform', getTransform);
// Draw targets..
- if (touchLayer.empty()) return;
- const fillClass = context.getDebug('target') ? 'pink ' : 'nocolor ';
+ if (touchLayer.empty()) { return; }
+ var fillClass = context.getDebug('target') ? 'pink ' : 'nocolor ';
- const targets = touchLayer.selectAll('.qaItem.keepRight')
- .data(data, d => d.id);
+ var targets = touchLayer.selectAll('.qaItem.keepRight')
+ .data(data, function (d) { return d.id; });
// exit
targets.exit()
.attr('y', '-22px')
.merge(targets)
.sort(sortY)
- .attr('class', d => `qaItem ${d.service} target ${fillClass} itemId-${d.id}`)
+ .attr('class', function (d) { return ("qaItem " + (d.service) + " target " + fillClass + " itemId-" + (d.id)); })
.attr('transform', getTransform);
// Draw the keepRight layer and schedule loading issues and updating markers.
function drawKeepRight(selection) {
- const service = getService();
+ var service = getService();
- const surface = context.surface();
+ var surface = context.surface();
if (surface && !surface.empty()) {
touchLayer = surface.selectAll('.data-layer.touch .layer-touch.markers');
}
// Toggles the layer on and off
drawKeepRight.enabled = function(val) {
- if (!arguments.length) return _layerEnabled;
+ if (!arguments.length) { return _layerEnabled; }
_layerEnabled = val;
if (_layerEnabled) {
return this;
};
- drawKeepRight.supported = () => !!getService();
+ drawKeepRight.supported = function () { return !!getService(); };
return drawKeepRight;
}
function init() {
- if (svgGeolocate.initialized) return; // run once
+ if (svgGeolocate.initialized) { return; } // run once
svgGeolocate.enabled = false;
svgGeolocate.initialized = true;
}
}
drawLocation.enabled = function (position, enabled) {
- if (!arguments.length) return svgGeolocate.enabled;
+ if (!arguments.length) { return svgGeolocate.enabled; }
_position = position;
svgGeolocate.enabled = enabled;
if (svgGeolocate.enabled) {
function textWidth(text, size, elem) {
var c = _textWidthCache[size];
- if (!c) c = _textWidthCache[size] = {};
+ if (!c) { c = _textWidthCache[size] = {}; }
if (c[text]) {
return c[text];
var icon = preset && !shouldSkipIcon(preset) && preset.icon;
if (!icon && !utilDisplayName(entity))
- continue;
+ { continue; }
for (k = 0; k < labelStack.length; k++) {
var matchGeom = labelStack[k][0];
if (geometry === 'point' || geometry === 'vertex') {
// no point or vertex labels in wireframe mode
// no vertex labels at low zooms (vertices have no icons)
- if (wireframe) continue;
+ if (wireframe) { continue; }
var renderAs = renderNodeAs[entity.id];
- if (renderAs === 'vertex' && zoom < 17) continue;
+ if (renderAs === 'vertex' && zoom < 17) { continue; }
p = getPointLabel(entity, width, fontSize, renderAs);
.map(function(node) { return projection(node.loc); });
var length = geoPathLength(points);
- if (length < width + 20) return;
+ if (length < width + 20) { return; }
// % along the line to attempt to place the label
var lineOffsets = [50, 45, 55, 40, 60, 35, 65, 30, 70,
var middle = offset / 100 * length;
var start = middle - width / 2;
- if (start < 0 || start + width > length) continue;
+ if (start < 0 || start + width > length) { continue; }
// generate subpath and ignore paths that are invalid or don't cross viewport.
var sub = subpath(points, start, start + width);
var extent = entity.extent(graph);
var areaWidth = projection(extent[1])[0] - projection(extent[0])[0];
- if (isNaN(centroid[0]) || areaWidth < 20) return;
+ if (isNaN(centroid[0]) || areaWidth < 20) { return; }
var preset = _mainPresetIndex.match(entity, context.graph());
var picon = preset && preset.icon;
return drawLabels;
}
- let _layerEnabled$1 = false;
- let _qaService$1;
+ var _layerEnabled$1 = false;
+ var _qaService$1;
function svgImproveOSM(projection, context, dispatch) {
- const throttledRedraw = throttle(() => dispatch.call('change'), 1000);
- const minZoom = 12;
+ var throttledRedraw = throttle(function () { return dispatch.call('change'); }, 1000);
+ var minZoom = 12;
- let touchLayer = select(null);
- let drawLayer = select(null);
- let layerVisible = false;
+ var touchLayer = select(null);
+ var drawLayer = select(null);
+ var layerVisible = false;
function markerPath(selection, klass) {
selection
.transition()
.duration(250)
.style('opacity', 1)
- .on('end interrupt', () => dispatch.call('change'));
+ .on('end interrupt', function () { return dispatch.call('change'); });
}
// Disable the layer. This transitions the layer invisible and then hides the markers.
.transition()
.duration(250)
.style('opacity', 0)
- .on('end interrupt', () => {
+ .on('end interrupt', function () {
editOff();
dispatch.call('change');
});
// Update the issue markers
function updateMarkers() {
- if (!layerVisible || !_layerEnabled$1) return;
+ if (!layerVisible || !_layerEnabled$1) { return; }
- const service = getService();
- const selectedID = context.selectedErrorID();
- const data = (service ? service.getItems(projection) : []);
- const getTransform = svgPointTransform(projection);
+ var service = getService();
+ var selectedID = context.selectedErrorID();
+ var data = (service ? service.getItems(projection) : []);
+ var getTransform = svgPointTransform(projection);
// Draw markers..
- const markers = drawLayer.selectAll('.qaItem.improveOSM')
- .data(data, d => d.id);
+ var markers = drawLayer.selectAll('.qaItem.improveOSM')
+ .data(data, function (d) { return d.id; });
// exit
markers.exit()
.remove();
// enter
- const markersEnter = markers.enter()
+ var markersEnter = markers.enter()
.append('g')
- .attr('class', d => `qaItem ${d.service} itemId-${d.id} itemType-${d.itemType}`);
+ .attr('class', function (d) { return ("qaItem " + (d.service) + " itemId-" + (d.id) + " itemType-" + (d.itemType)); });
markersEnter
.append('polygon')
.attr('class', 'icon-annotation')
.attr('width', '13px')
.attr('height', '13px')
- .attr('xlink:href', d => {
- const picon = d.icon;
+ .attr('xlink:href', function (d) {
+ var picon = d.icon;
if (!picon) {
return '';
} else {
- const isMaki = /^maki-/.test(picon);
- return `#${picon}${isMaki ? '-11' : ''}`;
+ var isMaki = /^maki-/.test(picon);
+ return ("#" + picon + (isMaki ? '-11' : ''));
}
});
markers
.merge(markersEnter)
.sort(sortY)
- .classed('selected', d => d.id === selectedID)
+ .classed('selected', function (d) { return d.id === selectedID; })
.attr('transform', getTransform);
// Draw targets..
- if (touchLayer.empty()) return;
- const fillClass = context.getDebug('target') ? 'pink ' : 'nocolor ';
+ if (touchLayer.empty()) { return; }
+ var fillClass = context.getDebug('target') ? 'pink ' : 'nocolor ';
- const targets = touchLayer.selectAll('.qaItem.improveOSM')
- .data(data, d => d.id);
+ var targets = touchLayer.selectAll('.qaItem.improveOSM')
+ .data(data, function (d) { return d.id; });
// exit
targets.exit()
.attr('y', '-28px')
.merge(targets)
.sort(sortY)
- .attr('class', d => `qaItem ${d.service} target ${fillClass} itemId-${d.id}`)
+ .attr('class', function (d) { return ("qaItem " + (d.service) + " target " + fillClass + " itemId-" + (d.id)); })
.attr('transform', getTransform);
function sortY(a, b) {
// Draw the ImproveOSM layer and schedule loading issues and updating markers.
function drawImproveOSM(selection) {
- const service = getService();
+ var service = getService();
- const surface = context.surface();
+ var surface = context.surface();
if (surface && !surface.empty()) {
touchLayer = surface.selectAll('.data-layer.touch .layer-touch.markers');
}
// Toggles the layer on and off
drawImproveOSM.enabled = function(val) {
- if (!arguments.length) return _layerEnabled$1;
+ if (!arguments.length) { return _layerEnabled$1; }
_layerEnabled$1 = val;
if (_layerEnabled$1) {
return this;
};
- drawImproveOSM.supported = () => !!getService();
+ drawImproveOSM.supported = function () { return !!getService(); };
return drawImproveOSM;
}
- let _layerEnabled$2 = false;
- let _qaService$2;
+ var _layerEnabled$2 = false;
+ var _qaService$2;
function svgOsmose(projection, context, dispatch) {
- const throttledRedraw = throttle(() => dispatch.call('change'), 1000);
- const minZoom = 12;
+ var throttledRedraw = throttle(function () { return dispatch.call('change'); }, 1000);
+ var minZoom = 12;
- let touchLayer = select(null);
- let drawLayer = select(null);
- let layerVisible = false;
+ var touchLayer = select(null);
+ var drawLayer = select(null);
+ var layerVisible = false;
function markerPath(selection, klass) {
selection
.transition()
.duration(250)
.style('opacity', 1)
- .on('end interrupt', () => dispatch.call('change'));
+ .on('end interrupt', function () { return dispatch.call('change'); });
}
// Disable the layer. This transitions the layer invisible and then hides the markers.
.transition()
.duration(250)
.style('opacity', 0)
- .on('end interrupt', () => {
+ .on('end interrupt', function () {
editOff();
dispatch.call('change');
});
// Update the issue markers
function updateMarkers() {
- if (!layerVisible || !_layerEnabled$2) return;
+ if (!layerVisible || !_layerEnabled$2) { return; }
- const service = getService();
- const selectedID = context.selectedErrorID();
- const data = (service ? service.getItems(projection) : []);
- const getTransform = svgPointTransform(projection);
+ var service = getService();
+ var selectedID = context.selectedErrorID();
+ var data = (service ? service.getItems(projection) : []);
+ var getTransform = svgPointTransform(projection);
// Draw markers..
- const markers = drawLayer.selectAll('.qaItem.osmose')
- .data(data, d => d.id);
+ var markers = drawLayer.selectAll('.qaItem.osmose')
+ .data(data, function (d) { return d.id; });
// exit
markers.exit()
.remove();
// enter
- const markersEnter = markers.enter()
+ var markersEnter = markers.enter()
.append('g')
- .attr('class', d => `qaItem ${d.service} itemId-${d.id} itemType-${d.itemType}`);
+ .attr('class', function (d) { return ("qaItem " + (d.service) + " itemId-" + (d.id) + " itemType-" + (d.itemType)); });
markersEnter
.append('polygon')
markersEnter
.append('polygon')
- .attr('fill', d => service.getColor(d.item))
+ .attr('fill', function (d) { return service.getColor(d.item); })
.call(markerPath, 'qaItem-fill');
markersEnter
.attr('class', 'icon-annotation')
.attr('width', '13px')
.attr('height', '13px')
- .attr('xlink:href', d => {
- const picon = d.icon;
+ .attr('xlink:href', function (d) {
+ var picon = d.icon;
if (!picon) {
return '';
} else {
- const isMaki = /^maki-/.test(picon);
- return `#${picon}${isMaki ? '-11' : ''}`;
+ var isMaki = /^maki-/.test(picon);
+ return ("#" + picon + (isMaki ? '-11' : ''));
}
});
markers
.merge(markersEnter)
.sort(sortY)
- .classed('selected', d => d.id === selectedID)
+ .classed('selected', function (d) { return d.id === selectedID; })
.attr('transform', getTransform);
// Draw targets..
- if (touchLayer.empty()) return;
- const fillClass = context.getDebug('target') ? 'pink' : 'nocolor';
+ if (touchLayer.empty()) { return; }
+ var fillClass = context.getDebug('target') ? 'pink' : 'nocolor';
- const targets = touchLayer.selectAll('.qaItem.osmose')
- .data(data, d => d.id);
+ var targets = touchLayer.selectAll('.qaItem.osmose')
+ .data(data, function (d) { return d.id; });
// exit
targets.exit()
.attr('y', '-28px')
.merge(targets)
.sort(sortY)
- .attr('class', d => `qaItem ${d.service} target ${fillClass} itemId-${d.id}`)
+ .attr('class', function (d) { return ("qaItem " + (d.service) + " target " + fillClass + " itemId-" + (d.id)); })
.attr('transform', getTransform);
function sortY(a, b) {
// Draw the Osmose layer and schedule loading issues and updating markers.
function drawOsmose(selection) {
- const service = getService();
+ var service = getService();
- const surface = context.surface();
+ var surface = context.surface();
if (surface && !surface.empty()) {
touchLayer = surface.selectAll('.data-layer.touch .layer-touch.markers');
}
// Toggles the layer on and off
drawOsmose.enabled = function(val) {
- if (!arguments.length) return _layerEnabled$2;
+ if (!arguments.length) { return _layerEnabled$2; }
_layerEnabled$2 = val;
if (_layerEnabled$2) {
// Also, If layer is toggled quickly multiple requests are sent
getService().loadStrings()
.then(layerOn)
- .catch(err => {
+ .catch(function (err) {
console.log(err); // eslint-disable-line no-console
});
} else {
return this;
};
- drawOsmose.supported = () => !!getService();
+ drawOsmose.supported = function () { return !!getService(); };
return drawOsmose;
}
* init().
*/
function init() {
- if (svgStreetside.initialized) return; // run once
+ if (svgStreetside.initialized) { return; } // run once
svgStreetside.enabled = false;
svgStreetside.initialized = true;
}
*/
function showLayer() {
var service = getService();
- if (!service) return;
+ if (!service) { return; }
editOn();
*/
function click(d) {
var service = getService();
- if (!service) return;
+ if (!service) { return; }
// try to preserve the viewer rotation when staying on the same sequence
if (d.sequenceKey !== _selectedSequence) {
service
.selectImage(context, d)
- .then(response => {
+ .then(function (response) {
if (response.status === 'ok'){
service.showViewer(context, _viewerYaw);
}
*/
function mouseover(d) {
var service = getService();
- if (service) service.setStyles(context, d);
+ if (service) { service.setStyles(context, d); }
}
/**
*/
function mouseout() {
var service = getService();
- if (service) service.setStyles(context, null);
+ if (service) { service.setStyles(context, null); }
}
/**
function viewerChanged() {
var service = getService();
- if (!service) return;
+ if (!service) { return; }
var viewer = service.viewer();
- if (!viewer) return;
+ if (!viewer) { return; }
// update viewfield rotation
_viewerYaw = viewer.getYaw();
// avoid updating if the map is currently transformed
// e.g. during drags or easing.
- if (context.map().isTransformed()) return;
+ if (context.map().isTransformed()) { return; }
layer.selectAll('.viewfield-group.currentView')
.attr('transform', transform);
/**
* drawImages()
- * drawImages is the method that is returned (and that runs) everytime 'svgStreetside()' is called.
+ * drawImages is the method that is returned (and that runs) every time 'svgStreetside()' is called.
* 'svgStreetside()' is called from index.js
*/
function drawImages(selection) {
* drawImages.enabled().
*/
drawImages.enabled = function(_) {
- if (!arguments.length) return svgStreetside.enabled;
+ if (!arguments.length) { return svgStreetside.enabled; }
svgStreetside.enabled = _;
if (svgStreetside.enabled) {
showLayer();
function init() {
- if (svgMapillaryImages.initialized) return; // run once
+ if (svgMapillaryImages.initialized) { return; } // run once
svgMapillaryImages.enabled = false;
svgMapillaryImages.initialized = true;
}
// avoid updating if the map is currently transformed
// e.g. during drags or easing.
- if (context.map().isTransformed()) return;
+ if (context.map().isTransformed()) { return; }
layer.selectAll('.viewfield-group.currentView')
.filter(function(d) {
function showLayer() {
var service = getService();
- if (!service) return;
+ if (!service) { return; }
editOn();
function click(d) {
var service = getService();
- if (!service) return;
+ if (!service) { return; }
service
.selectImage(context, d.key)
function mouseover(d) {
var service = getService();
- if (service) service.setStyles(context, d);
+ if (service) { service.setStyles(context, d); }
}
function mouseout() {
var service = getService();
- if (service) service.setStyles(context, null);
+ if (service) { service.setStyles(context, null); }
}
var showsFlat = context.photos().showsFlat();
if (!showsPano || !showsFlat) {
images = images.filter(function(image) {
- if (image.pano) return showsPano;
+ if (image.pano) { return showsPano; }
return showsFlat;
});
}
if (!showsPano || !showsFlat) {
sequences = sequences.filter(function(sequence) {
if (sequence.properties.hasOwnProperty('pano')) {
- if (sequence.properties.pano) return showsPano;
+ if (sequence.properties.pano) { return showsPano; }
return showsFlat;
} else {
// if the sequence doesn't specify pano or not, search its images
var imageKey = cProps.image_keys[index];
var image = service.cachedImage(imageKey);
if (image && image.hasOwnProperty('pano')) {
- if (image.pano) return showsPano;
+ if (image.pano) { return showsPano; }
return showsFlat;
}
}
drawImages.enabled = function(_) {
- if (!arguments.length) return svgMapillaryImages.enabled;
+ if (!arguments.length) { return svgMapillaryImages.enabled; }
svgMapillaryImages.enabled = _;
if (svgMapillaryImages.enabled) {
showLayer();
function init() {
- if (svgMapillarySigns.initialized) return; // run once
+ if (svgMapillarySigns.initialized) { return; } // run once
svgMapillarySigns.enabled = false;
svgMapillarySigns.initialized = true;
}
function showLayer() {
var service = getService();
- if (!service) return;
+ if (!service) { return; }
editOn();
}
function click(d) {
var service = getService();
- if (!service) return;
+ if (!service) { return; }
context.map().centerEase(d.loc);
drawSigns.enabled = function(_) {
- if (!arguments.length) return svgMapillarySigns.enabled;
+ if (!arguments.length) { return svgMapillarySigns.enabled; }
svgMapillarySigns.enabled = _;
if (svgMapillarySigns.enabled) {
showLayer();
function init() {
- if (svgMapillaryMapFeatures.initialized) return; // run once
+ if (svgMapillaryMapFeatures.initialized) { return; } // run once
svgMapillaryMapFeatures.enabled = false;
svgMapillaryMapFeatures.initialized = true;
}
function showLayer() {
var service = getService();
- if (!service) return;
+ if (!service) { return; }
editOn();
}
function click(d) {
var service = getService();
- if (!service) return;
+ if (!service) { return; }
context.map().centerEase(d.loc);
drawMapFeatures.enabled = function(_) {
- if (!arguments.length) return svgMapillaryMapFeatures.enabled;
+ if (!arguments.length) { return svgMapillaryMapFeatures.enabled; }
svgMapillaryMapFeatures.enabled = _;
if (svgMapillaryMapFeatures.enabled) {
showLayer();
function init() {
- if (svgOpenstreetcamImages.initialized) return; // run once
+ if (svgOpenstreetcamImages.initialized) { return; } // run once
svgOpenstreetcamImages.enabled = false;
svgOpenstreetcamImages.initialized = true;
}
function showLayer() {
var service = getService();
- if (!service) return;
+ if (!service) { return; }
editOn();
function click(d) {
var service = getService();
- if (!service) return;
+ if (!service) { return; }
service
.selectImage(context, d)
function mouseover(d) {
var service = getService();
- if (service) service.setStyles(context, d);
+ if (service) { service.setStyles(context, d); }
}
function mouseout() {
var service = getService();
- if (service) service.setStyles(context, null);
+ if (service) { service.setStyles(context, null); }
}
drawImages.enabled = function(_) {
- if (!arguments.length) return svgOpenstreetcamImages.enabled;
+ if (!arguments.length) { return svgOpenstreetcamImages.enabled; }
svgOpenstreetcamImages.enabled = _;
if (svgOpenstreetcamImages.enabled) {
showLayer();
drawOsm.enabled = function(val) {
- if (!arguments.length) return enabled;
+ if (!arguments.length) { return enabled; }
enabled = val;
if (enabled) {
// Update the note markers
function updateMarkers() {
- if (!_notesVisible || !_notesEnabled) return;
+ if (!_notesVisible || !_notesEnabled) { return; }
var service = getService();
var selectedID = context.selectedNoteID();
// Draw targets..
- if (touchLayer.empty()) return;
+ if (touchLayer.empty()) { return; }
var fillClass = context.getDebug('target') ? 'pink ' : 'nocolor ';
var targets = touchLayer.selectAll('.note')
// Toggles the layer on and off
drawNotes.enabled = function(val) {
- if (!arguments.length) return _notesEnabled;
+ if (!arguments.length) { return _notesEnabled; }
_notesEnabled = val;
if (_notesEnabled) {
drawLayers.dimensions = function(val) {
- if (!arguments.length) return utilGetDimensions(svg);
+ if (!arguments.length) { return utilGetDimensions(svg); }
utilSetDimensions(svg, val);
return this;
};
var data = pathdata[layer] || [];
return data.filter(function(d) {
if (isSelected)
- return context.selectedIDs().indexOf(d.id) !== -1;
+ { return context.selectedIDs().indexOf(d.id) !== -1; }
else
- return context.selectedIDs().indexOf(d.id) === -1;
+ { return context.selectedIDs().indexOf(d.id) === -1; }
});
};
}
for (var i = 0; i < entities.length; i++) {
var entity = entities[i];
- if (entity.type !== 'way') continue;
- if (!filter(entity)) continue;
- if (context.selectedIDs().indexOf(entity.id) < 0) continue;
+ if (entity.type !== 'way') { continue; }
+ if (!filter(entity)) { continue; }
+ if (context.selectedIDs().indexOf(entity.id) < 0) { continue; }
var nodes = graph.childNodes(entity);
for (var j = 0; j < nodes.length - 1; j++) {
function midpointFilter(d) {
if (midpoints[d.id])
- return true;
+ { return true; }
for (var i = 0; i < d.parents.length; i++) {
if (filter(d.parents[i])) {
var data = [];
entities.forEach(function(node) {
- if (activeID === node.id) return; // draw no target on the activeID
+ if (activeID === node.id) { return; } // draw no target on the activeID
data.push({
type: 'Feature',
function icon(turn) {
var u = turn.u ? '-u' : '';
- if (turn.no) return '#iD-turn-no' + u;
- if (turn.only) return '#iD-turn-only' + u;
+ if (turn.no) { return '#iD-turn-no' + u; }
+ if (turn.only) { return '#iD-turn-only' + u; }
return '#iD-turn-yes' + u;
}
function getIcon(d) {
// always check latest entity, as fastEntityKey avoids enter/exit now
var entity = graph.entity(d.id);
- if (entity.id in icons) return icons[entity.id];
+ if (entity.id in icons) { return icons[entity.id]; }
icons[entity.id] =
entity.hasInterestingTags() &&
// memoize directions results, return false for empty arrays (for use in filter)
function getDirections(entity) {
- if (entity.id in directions) return directions[entity.id];
+ if (entity.id in directions) { return directions[entity.id]; }
var angles = entity.directions(graph, projection);
directions[entity.id] = angles.length ? angles : false;
var data = { targets: [], nopes: [] };
entities.forEach(function(node) {
- if (activeID === node.id) return; // draw no target on the activeID
+ if (activeID === node.id) { return; } // draw no target on the activeID
var vertexType = svgPassiveVertex(node, graph, activeID);
if (vertexType !== 0) { // passive or adjacent - allow to connect
function addChildVertices(entity) {
- // avoid redunant work and infinite recursion of circular relations
- if (seenIds[entity.id]) return;
+ // avoid redundant work and infinite recursion of circular relations
+ if (seenIds[entity.id]) { return; }
seenIds[entity.id] = true;
var geometry = entity.geometry(graph);
ids.forEach(function(id) {
var entity = graph.hasEntity(id);
- if (!entity) return;
+ if (!entity) { return; }
if (entity.type === 'node') {
if (renderAsVertex(entity, graph, wireframe, zoom)) {
}
// Collect important vertices from the `entities` list..
- // (during a paritial redraw, it will not contain everything)
+ // (during a partial redraw, it will not contain everything)
for (var i = 0; i < entities.length; i++) {
var entity = entities[i];
var geometry = entity.geometry(graph);
_currSelected = {};
context.selectedIDs().forEach(function(id) {
var entity = graph.hasEntity(id);
- if (!entity) return;
+ if (!entity) { return; }
if (entity.type === 'node') {
if (renderAsVertex(entity, graph, wireframe, zoom)) {
// partial redraw - only update the hovered items..
drawVertices.drawHover = function(selection, graph, target, extent) {
- if (target === _currHoverTarget) return; // continue only if something changed
+ if (target === _currHoverTarget) { return; } // continue only if something changed
var wireframe = context.surface().classed('fill-wireframe');
var zoom = geoScaleToZoom(projection.scale());
b = typeof transform === 'function' ? transform.apply(that, args) : transform,
i = interpolate(a.invert(p).concat(w / a.k), b.invert(p).concat(w / b.k));
return function(t) {
- if (t === 1) t = b; // Avoid rounding error on end.
+ if (t === 1) { t = b; } // Avoid rounding error on end.
else { var l = i(t), k = w / l[2]; t = new Transform(k, p[0] - l[0] * k, p[1] - l[1] * k); }
g.zoom(null, t);
};
return this;
},
zoom: function(key, transform) {
- if (this.mouse && key !== 'mouse') this.mouse[1] = transform.invert(this.mouse[0]);
- if (this.pointer0 && key !== 'touch') this.pointer0[1] = transform.invert(this.pointer0[0]);
- if (this.pointer1 && key !== 'touch') this.pointer1[1] = transform.invert(this.pointer1[0]);
+ if (this.mouse && key !== 'mouse') { this.mouse[1] = transform.invert(this.mouse[0]); }
+ if (this.pointer0 && key !== 'touch') { this.pointer0[1] = transform.invert(this.pointer0[0]); }
+ if (this.pointer1 && key !== 'touch') { this.pointer1[1] = transform.invert(this.pointer1[0]); }
_transform = transform;
this.emit('zoom');
return this;
};
function wheeled() {
- if (!filter.apply(this, arguments)) return;
+ if (!filter.apply(this, arguments)) { return; }
var g = gesture(this, arguments),
t = _transform,
k = Math.max(scaleExtent[0], Math.min(scaleExtent[1], t.k * Math.pow(2, wheelDelta.apply(this, arguments)))),
function pointerdown() {
_downPointerIDs.add(event.pointerId);
- if (!filter.apply(this, arguments)) return;
+ if (!filter.apply(this, arguments)) { return; }
var g = gesture(this, arguments, _downPointerIDs.size === 1);
var started;
}
function pointermove() {
- if (!_downPointerIDs.has(event.pointerId)) return;
+ if (!_downPointerIDs.has(event.pointerId)) { return; }
- if (!_activeGesture || !_pointerLocGetter) return;
+ if (!_activeGesture || !_pointerLocGetter) { return; }
var g = gesture(this, arguments);
if ((isPointer0 || isPointer1) && 'buttons' in event && !event.buttons) {
// The pointer went up without ending the gesture somehow, e.g.
// a down mouse was moved off the map and released. End it here.
- if (g.pointer0) _downPointerIDs.delete(g.pointer0[2]);
- if (g.pointer1) _downPointerIDs.delete(g.pointer1[2]);
+ if (g.pointer0) { _downPointerIDs.delete(g.pointer0[2]); }
+ if (g.pointer1) { _downPointerIDs.delete(g.pointer1[2]); }
g.end();
return;
}
var loc = _pointerLocGetter(event);
var t, p, l;
- if (isPointer0) g.pointer0[0] = loc;
- else if (isPointer1) g.pointer1[0] = loc;
+ if (isPointer0) { g.pointer0[0] = loc; }
+ else if (isPointer1) { g.pointer1[0] = loc; }
t = _transform;
if (g.pointer1) {
p = g.pointer0[0];
l = g.pointer0[1];
}
- else return;
+ else { return; }
g.zoom('touch', constrain(translate(t, p, l), g.extent, translateExtent));
}
function pointerup() {
- if (!_downPointerIDs.has(event.pointerId)) return;
+ if (!_downPointerIDs.has(event.pointerId)) { return; }
_downPointerIDs.delete(event.pointerId);
- if (!_activeGesture) return;
+ if (!_activeGesture) { return; }
var g = gesture(this, arguments);
event.stopImmediatePropagation();
- if (g.pointer0 && g.pointer0[2] === event.pointerId) delete g.pointer0;
- else if (g.pointer1 && g.pointer1[2] === event.pointerId) delete g.pointer1;
+ if (g.pointer0 && g.pointer0[2] === event.pointerId) { delete g.pointer0; }
+ else if (g.pointer1 && g.pointer1[2] === event.pointerId) { delete g.pointer1; }
if (g.pointer1 && !g.pointer0) {
g.pointer0 = g.pointer1;
delete g.pointer1;
}
- if (g.pointer0) g.pointer0[1] = _transform.invert(g.pointer0[0]);
+ if (g.pointer0) { g.pointer0[1] = _transform.invert(g.pointer0[0]); }
else {
g.end();
}
function pointerdown() {
// ignore right-click
- if (event.ctrlKey || event.button === 2) return;
+ if (event.ctrlKey || event.button === 2) { return; }
var loc = [event.clientX, event.clientY];
function pointerup() {
// ignore right-click
- if (event.ctrlKey || event.button === 2) return;
+ if (event.ctrlKey || event.button === 2) { return; }
- if (!_pointer || _pointer.pointerId !== event.pointerId) return;
+ if (!_pointer || _pointer.pointerId !== event.pointerId) { return; }
_pointer.upCount += 1;
function didUndoOrRedo(targetTransform) {
var mode = context.mode().id;
- if (mode !== 'browse' && mode !== 'select') return;
+ if (mode !== 'browse' && mode !== 'select') { return; }
if (targetTransform) {
map.transformEase(targetTransform);
}
updateAreaFill();
_doubleUpHandler.on('doubleUp.map', function(p0) {
- if (!_dblClickZoomEnabled) return;
+ if (!_dblClickZoomEnabled) { return; }
// don't zoom if targeting something other than the map itself
if (typeof event.target.__data__ === 'object' &&
// or area fills
- !select(event.target).classed('fill')) return;
+ !select(event.target).classed('fill')) { return; }
var zoomOut = event.shiftKey;
});
context.on('enter.map', function() {
- if (!map.editableDataEnabled(true /* skip zoom check */)) return;
+ if (!map.editableDataEnabled(true /* skip zoom check */)) { return; }
// redraw immediately any objects affected by a change in selectedIDs.
var graph = context.graph();
data = [];
utilEntityAndDeepMemberIDs(mode.selectedIDs(), context.graph()).forEach(function(id) {
var entity = context.hasEntity(id);
- if (entity) data.push(entity);
+ if (entity) { data.push(entity); }
});
fullRedraw = true;
filter = utilFunctor(true);
if (source && source.type === 'wheel') {
// assume that the gesture is already handled by pointer events
- if (_pointerDown) return;
+ if (_pointerDown) { return; }
var detected = utilDetect();
var dX = source.deltaX;
);
// On Firefox Windows and Linux we always get +/- the scroll line amount (default 3)
- // There doesn't seem to be any scroll accelleration.
+ // There doesn't seem to be any scroll acceleration.
// This multiplier increases the speed a little bit - #5512
if (detected.os !== 'mac') {
dY *= 5;
function resetTransform() {
- if (!_isTransformed) return false;
+ if (!_isTransformed) { return false; }
utilSetTransform(supersurface, 0, 0);
_isTransformed = false;
function redraw(difference, extent) {
- if (surface.empty() || !_redrawEnabled) return;
+ if (surface.empty() || !_redrawEnabled) { return; }
// If we are in the middle of a zoom/pan, we can't do differenced redraws.
// It would result in artifacts where differenced entities are redrawn with
var immediateRedraw = function(difference, extent) {
- if (!difference && !extent) cancelPendingRedraw();
+ if (!difference && !extent) { cancelPendingRedraw(); }
redraw(difference, extent);
};
map.dblclickZoomEnable = function(val) {
- if (!arguments.length) return _dblClickZoomEnabled;
+ if (!arguments.length) { return _dblClickZoomEnabled; }
_dblClickZoomEnabled = val;
return map;
};
map.redrawEnable = function(val) {
- if (!arguments.length) return _redrawEnabled;
+ if (!arguments.length) { return _redrawEnabled; }
_redrawEnabled = val;
return map;
};
function setTransform(t2, duration, force) {
var t = projection.transform();
- if (!force && t2.k === t.k && t2.x === t.x && t2.y === t.y) return false;
+ if (!force && t2.k === t.k && t2.x === t.x && t2.y === t.y) { return false; }
if (duration) {
_selection
function setCenterZoom(loc2, z2, duration, force) {
var c = map.center();
var z = map.zoom();
- if (loc2[0] === c[0] && loc2[1] === c[1] && z2 === z && !force) return false;
+ if (loc2[0] === c[0] && loc2[1] === c[1] && z2 === z && !force) { return false; }
var proj = geoRawMercator().transform(projection.transform()); // copy projection
map.dimensions = function(val) {
- if (!arguments.length) return _dimensions;
+ if (!arguments.length) { return _dimensions; }
_dimensions = val;
drawLayers.dimensions(_dimensions);
map.zoomTo = function(entity) {
var extent = entity.extent(context.graph());
- if (!isFinite(extent.area())) return map;
+ if (!isFinite(extent.area())) { return map; }
var z2 = clamp(map.trimmedExtentZoom(extent), 0, 20);
return map.centerZoom(extent.center(), z2);
} else {
extent = obj.extent(context.graph());
}
- if (!isFinite(extent.area())) return map;
+ if (!isFinite(extent.area())) { return map; }
var z2 = clamp(map.trimmedExtentZoom(extent), 0, 20);
return map.centerZoomEase(extent.center(), z2, duration);
map.editableDataEnabled = function(skipZoomCheck) {
var layer = context.layers().layer('osm');
- if (!layer || !layer.enabled()) return false;
+ if (!layer || !layer.enabled()) { return false; }
return skipZoomCheck || map.withinEditableZoom();
};
map.notesEditable = function() {
var layer = context.layers().layer('notes');
- if (!layer || !layer.enabled()) return false;
+ if (!layer || !layer.enabled()) { return false; }
return map.withinEditableZoom();
};
map.minzoom = function(val) {
- if (!arguments.length) return _minzoom;
+ if (!arguments.length) { return _minzoom; }
_minzoom = val;
return map;
};
map.areaFillOptions = ['wireframe', 'partial', 'full'];
map.activeAreaFill = function(val) {
- if (!arguments.length) return corePreferences('area-fill') || 'partial';
+ if (!arguments.length) { return corePreferences('area-fill') || 'partial'; }
corePreferences('area-fill', val);
if (val !== 'wireframe') {
}
- map.layers = () => drawLayers;
+ map.layers = function () { return drawLayers; };
map.doubleUpHandler = function() {
function photos() {}
function updateStorage() {
- if (window.mocha) return;
+ if (window.mocha) { return; }
var hash = utilStringQs(window.location.hash);
var enabled = context.layers().all().filter(function(d) {
};
photos.showsPhotoType = function(val) {
- if (!photos.shouldFilterByPhotoType()) return true;
+ if (!photos.shouldFilterByPhotoType()) { return true; }
return _shownPhotoTypes.indexOf(val) !== -1;
};
var hashOverlayIDs = hash.photo_overlay.replace(/;/g, ',').split(',');
hashOverlayIDs.forEach(function(id) {
var layer = context.layers().layer(id);
- if (layer) layer.enabled(true);
+ if (layer) { layer.enabled(true); }
});
}
function update(selection) {
- if (!osm) return;
+ if (!osm) { return; }
if (!osm.authenticated()) {
selection.selectAll('.userLink, .logoutLink')
userLink.html('');
logoutLink.html('');
- if (err || !details) return;
+ if (err || !details) { return; }
selection.selectAll('.userLink, .logoutLink')
.classed('hide', false);
}
function uiAttribution(context) {
- let _selection = select(null);
+ var _selection = select(null);
function render(selection, data, klass) {
- let div = selection.selectAll(`.${klass}`)
+ var div = selection.selectAll(("." + klass))
.data([0]);
div = div.enter()
.merge(div);
- let attributions = div.selectAll('.attribution')
- .data(data, d => d.id);
+ var attributions = div.selectAll('.attribution')
+ .data(data, function (d) { return d.id; });
attributions.exit()
.remove();
attributions = attributions.enter()
.append('span')
.attr('class', 'attribution')
- .each((d, i, nodes) => {
- let attribution = select(nodes[i]);
+ .each(function (d, i, nodes) {
+ var attribution = select(nodes[i]);
if (d.terms_html) {
attribution.html(d.terms_html);
.attr('target', '_blank');
}
- const sourceID = d.id.replace(/\./g, '<TX_DOT>');
- const terms_text = _t(`imagery.${sourceID}.attribution.text`,
+ var sourceID = d.id.replace(/\./g, '<TX_DOT>');
+ var terms_text = _t(("imagery." + sourceID + ".attribution.text"),
{ default: d.terms_text || d.id || d.name() }
);
.merge(attributions);
- let copyright = attributions.selectAll('.copyright-notice')
- .data(d => {
- let notice = d.copyrightNotices(context.map().zoom(), context.map().extent());
+ var copyright = attributions.selectAll('.copyright-notice')
+ .data(function (d) {
+ var notice = d.copyrightNotices(context.map().zoom(), context.map().extent());
return notice ? [notice] : [];
});
function update() {
- let baselayer = context.background().baseLayerSource();
+ var baselayer = context.background().baseLayerSource();
_selection
.call(render, (baselayer ? [baselayer] : []), 'base-layer-attribution');
- const z = context.map().zoom();
- let overlays = context.background().overlayLayerSources() || [];
+ var z = context.map().zoom();
+ var overlays = context.background().overlayLayerSources() || [];
_selection
- .call(render, overlays.filter(s => s.validZoom(z)), 'overlay-layer-attribution');
+ .call(render, overlays.filter(function (s) { return s.validZoom(z); }), 'overlay-layer-attribution');
}
function update() {
- if (!osm) return;
+ if (!osm) { return; }
var users = {},
entities = context.history().intersects(context.map().extent());
entities.forEach(function(entity) {
- if (entity && entity.user) users[entity.user] = true;
+ if (entity && entity.user) { users[entity.user] = true; }
});
var u = Object.keys(users),
return function(selection) {
- if (!osm) return;
+ if (!osm) { return; }
wrap = selection;
update();
}
// don't show if buttons are pressed, e.g. during click and drag of map
- if (event.buttons !== 0) return;
+ if (event.buttons !== 0) { return; }
show.apply(this, arguments);
});
var _keys = utilFunctor(null);
tooltip.title = function(val) {
- if (!arguments.length) return _title;
+ if (!arguments.length) { return _title; }
_title = utilFunctor(val);
return tooltip;
};
tooltip.heading = function(val) {
- if (!arguments.length) return _heading;
+ if (!arguments.length) { return _heading; }
_heading = utilFunctor(val);
return tooltip;
};
tooltip.keys = function(val) {
- if (!arguments.length) return _keys;
+ if (!arguments.length) { return _keys; }
_keys = utilFunctor(val);
return tooltip;
};
return !isTouchMenu || !op.mouseOnly;
});
- if (!ops.length) return;
+ if (!ops.length) { return; }
_tooltips = [];
}
})
.on('drawn.edit-menu', function(info) {
- if (info.full) updatePosition();
+ if (info.full) { updatePosition(); }
});
var lastPointerUpType;
function updatePosition() {
- if (!_menu || _menu.empty()) return;
+ if (!_menu || _menu.empty()) { return; }
var anchorLoc = context.projection(_anchorLocLonLat);
};
editMenu.anchorLoc = function(val) {
- if (!arguments.length) return _anchorLoc;
+ if (!arguments.length) { return _anchorLoc; }
_anchorLoc = val;
_anchorLocLonLat = context.projection.invert(_anchorLoc);
return editMenu;
};
editMenu.triggerType = function(val) {
- if (!arguments.length) return _triggerType;
+ if (!arguments.length) { return _triggerType; }
_triggerType = val;
return editMenu;
};
editMenu.operations = function(val) {
- if (!arguments.length) return _operations;
+ if (!arguments.length) { return _operations; }
_operations = val;
return editMenu;
};
flash.duration = function(_) {
- if (!arguments.length) return _duration;
+ if (!arguments.length) { return _duration; }
_duration = _;
return flash;
};
flash.text = function(_) {
- if (!arguments.length) return _text;
+ if (!arguments.length) { return _text; }
_text = _;
return flash;
};
flash.textClass = function(_) {
- if (!arguments.length) return _textClass;
+ if (!arguments.length) { return _textClass; }
_textClass = _;
return flash;
};
flash.iconName = function(_) {
- if (!arguments.length) return _iconName;
+ if (!arguments.length) { return _iconName; }
_iconName = _;
return flash;
};
flash.iconClass = function(_) {
- if (!arguments.length) return _iconClass;
+ if (!arguments.length) { return _iconClass; }
_iconClass = _;
return flash;
};
return function() { // selection) {
- if (!isSupported()) return;
+ if (!isSupported()) { return; }
// button = selection.append('button')
// .attr('title', t('full_screen'))
var _button = select(null);
function click() {
- if (context.inIntro()) return;
+ if (context.inIntro()) { return; }
if (!_layer.enabled() && !_locating.isShown()) {
// This timeout ensures that we still call finish() even if
}
return function(selection) {
- if (!navigator.geolocation || !navigator.geolocation.getCurrentPosition) return;
+ if (!navigator.geolocation || !navigator.geolocation.getCurrentPosition) { return; }
_button = selection
.append('button')
function redraw(selection) {
var source = background.baseLayerSource();
- if (!source) return;
+ if (!source) { return; }
var isDG = (source.id.match(/^DigitalGlobe/i) !== null);
metadataKeys.forEach(function(k) {
// DigitalGlobe vintage is available in raster layers for now.
- if (isDG && k === 'vintage') return;
+ if (isDG && k === 'vintage') { return; }
list
.append('li')
function getMetadata(selection) {
var tile = context.container().select('.layer-background img.tile-center'); // tile near viewport center
- if (tile.empty()) return;
+ if (tile.empty()) { return; }
var sourceName = currSourceName;
var d = tile.datum();
.selectAll('.background-info-span-zoom')
.text(metadata.zoom);
- if (!d || !d.length >= 3) return;
+ if (!d || !d.length >= 3) { return; }
background.baseLayerSource().getMetadata(center, d, function(err, result) {
- if (err || currSourceName !== sourceName) return;
+ if (err || currSourceName !== sourceName) { return; }
// update vintage
var vintage = result.vintage;
.selectAll('.background-info-span-vintage')
.text(metadata.vintage);
- // update other metdata
+ // update other metadata
metadataKeys.forEach(function(k) {
- if (k === 'zoom' || k === 'vintage') return; // done already
+ if (k === 'zoom' || k === 'vintage') { return; } // done already
var val = result[k];
metadata[k] = val;
selection.selectAll('.background-info-list-' + k)
var osm;
function displayTimestamp(timestamp) {
- if (!timestamp) return _t('info_panels.history.unknown');
+ if (!timestamp) { return _t('info_panels.history.unknown'); }
var options = {
day: 'numeric', month: 'short', year: 'numeric',
hour: 'numeric', minute: 'numeric', second: 'numeric'
};
var d = new Date(timestamp);
- if (isNaN(d.getTime())) return _t('info_panels.history.unknown');
+ if (isNaN(d.getTime())) { return _t('info_panels.history.unknown'); }
return d.toLocaleString(_mainLocalizer.localeCode(), options);
}
.attr('class', 'history-heading')
.text(singular || _t('info_panels.history.selected', { n: selected.length }));
- if (!singular) return;
+ if (!singular) { return; }
if (entity) {
selection.call(redrawEntity, entity);
function toLineString(feature) {
- if (feature.type === 'LineString') return feature;
+ if (feature.type === 'LineString') { return feature; }
var result = { type: 'LineString', coordinates: [] };
if (feature.type === 'Polygon') {
ids.forEach(function(k) {
var key = _t('info_panels.' + k + '.key', { default: null });
- if (!key) return;
+ if (!key) { return; }
context.keybinding()
.on(uiCmd('⌘⇧' + key), function() { info.toggle(k); });
});
// with custom `replacements`
function helpString(id, replacements) {
// only load these the first time
- if (!helpStringReplacements) helpStringReplacements = {
+ if (!helpStringReplacements) { helpStringReplacements = {
// insert icons corresponding to various UI elements
point_icon: icon('#iD-icon-point', 'pre-text'),
line_icon: icon('#iD-icon-line', 'pre-text'),
point: _t('modes.add_point.title'),
line: _t('modes.add_line.title'),
area: _t('modes.add_area.title'),
- note: _t('modes.add_note.title'),
+ note: _t('modes.add_note.label'),
delete: _t('operations.delete.title'),
move: _t('operations.move.title'),
orthogonalize: _t('operations.orthogonalize.title'),
start_the_walkthrough: _t('splash.walkthrough'),
help: _t('help.title'),
ok: _t('intro.ok')
- };
+ }; }
var reps;
if (replacements) {
var missingStrings = {};
function checkKey(key, text) {
if (_t(key, { default: undefined}) === undefined) {
- if (missingStrings.hasOwnProperty(key)) return; // warn once
+ if (missingStrings.hasOwnProperty(key)) { return; } // warn once
missingStrings[key] = text;
var missing = key + ': ' + text;
- if (typeof console !== 'undefined') console.log(missing); // eslint-disable-line
+ if (typeof console !== 'undefined') { console.log(missing); } // eslint-disable-line
}
}
function transitionTime(point1, point2) {
var distance = geoSphericalDistance(point1, point2);
if (distance === 0)
- return 0;
+ { return 0; }
else if (distance < 80)
- return 500;
+ { return 500; }
else
- return 1000;
+ { return 1000; }
}
// Tooltips and svg mask used to highlight certain features
containerWidth + ',' + containerHeight + 'L' +
containerWidth + ',0 Z';
- if (!d) return string;
+ if (!d) { return string; }
return string + 'M' +
d.left + ',' + d.top + 'L' +
d.left + ',' + (d.top + d.height) + 'L' +
context.history().reset('initial');
var entity = context.hasEntity(hallId);
- if (!entity) return;
+ if (!entity) { return; }
reveal(null, null, { duration: 0 });
context.map().centerZoomEase(entity.loc, 19, 500);
timeout(function() {
var entity = context.hasEntity(hallId);
- if (!entity) return;
+ if (!entity) { return; }
var box = pointBox(entity.loc, context);
var textId = context.lastPointerType() === 'mouse' ? 'click_townhall' : 'tap_townhall';
reveal(box, helpString('intro.navigation.' + textId));
context.map().on('move.intro drawn.intro', function() {
var entity = context.hasEntity(hallId);
- if (!entity) return;
+ if (!entity) { return; }
var box = pointBox(entity.loc, context);
reveal(box, helpString('intro.navigation.' + textId), { duration: 0 });
});
context.on('enter.intro', function() {
- if (isTownHallSelected()) continueTo(selectedTownHall);
+ if (isTownHallSelected()) { continueTo(selectedTownHall); }
});
}, 550); // after centerZoomEase
function selectedTownHall() {
- if (!isTownHallSelected()) return clickTownHall();
+ if (!isTownHallSelected()) { return clickTownHall(); }
var entity = context.hasEntity(hallId);
- if (!entity) return clickTownHall();
+ if (!entity) { return clickTownHall(); }
var box = pointBox(entity.loc, context);
var onClick = function() { continueTo(editorTownHall); };
context.map().on('move.intro drawn.intro', function() {
var entity = context.hasEntity(hallId);
- if (!entity) return;
+ if (!entity) { return; }
var box = pointBox(entity.loc, context);
reveal(box, helpString('intro.navigation.selected_townhall'),
{ duration: 0, buttonText: _t('intro.ok'), buttonCallback: onClick }
function editorTownHall() {
- if (!isTownHallSelected()) return clickTownHall();
+ if (!isTownHallSelected()) { return clickTownHall(); }
// disallow scrolling
context.container().select('.inspector-wrap').on('wheel.intro', eventCancel);
function presetTownHall() {
- if (!isTownHallSelected()) return clickTownHall();
+ if (!isTownHallSelected()) { return clickTownHall(); }
// reset pane, in case user happened to change it..
context.container().select('.inspector-wrap .panewrap').style('right', '0%');
function fieldsTownHall() {
- if (!isTownHallSelected()) return clickTownHall();
+ if (!isTownHallSelected()) { return clickTownHall(); }
// reset pane, in case user happened to change it..
context.container().select('.inspector-wrap .panewrap').style('right', '0%');
function closeTownHall() {
- if (!isTownHallSelected()) return clickTownHall();
+ if (!isTownHallSelected()) { return clickTownHall(); }
var selector = '.entity-editor-pane button.close svg use';
var href = select(selector).attr('href') || '#iD-icon-close';
timeout(function() {
context.map().on('move.intro drawn.intro', function() {
var entity = context.hasEntity(springStreetEndId);
- if (!entity) return;
+ if (!entity) { return; }
var box = pointBox(entity.loc, context);
box.height = 500;
reveal(box,
.attr('xlink:href', '#iD-graphic-points');
context.on('enter.intro', function(mode) {
- if (mode.id !== 'add-point') return;
+ if (mode.id !== 'add-point') { return; }
continueTo(placePoint);
});
}, msec + 100);
});
context.on('enter.intro', function(mode) {
- if (mode.id !== 'select') return chapter.restart();
+ if (mode.id !== 'select') { return chapter.restart(); }
_pointID = context.mode().selectedIDs()[0];
continueTo(searchPreset);
});
function reselectPoint() {
- if (!_pointID) return chapter.restart();
+ if (!_pointID) { return chapter.restart(); }
var entity = context.hasEntity(_pointID);
- if (!entity) return chapter.restart();
+ if (!entity) { return chapter.restart(); }
// make sure it's still a cafe, in case user somehow changed it..
var oldPreset = _mainPresetIndex.match(entity, context.graph());
timeout(function() {
context.map().on('move.intro drawn.intro', function() {
var entity = context.hasEntity(_pointID);
- if (!entity) return chapter.restart();
+ if (!entity) { return chapter.restart(); }
var box = pointBox(entity.loc, context);
reveal(box, helpString('intro.points.reselect'), { duration: 0 });
});
}, 600); // after reveal..
context.on('enter.intro', function(mode) {
- if (mode.id !== 'select') return;
+ if (mode.id !== 'select') { return; }
continueTo(updatePoint);
});
function rightClickPoint() {
- if (!_pointID) return chapter.restart();
+ if (!_pointID) { return chapter.restart(); }
var entity = context.hasEntity(_pointID);
- if (!entity) return chapter.restart();
+ if (!entity) { return chapter.restart(); }
context.enter(modeBrowse(context));
timeout(function() {
context.map().on('move.intro', function() {
var entity = context.hasEntity(_pointID);
- if (!entity) return chapter.restart();
+ if (!entity) { return chapter.restart(); }
var box = pointBox(entity.loc, context);
reveal(box, helpString('intro.points.' + textId), { duration: 0 });
});
}, 600); // after reveal
context.on('enter.intro', function(mode) {
- if (mode.id !== 'select') return;
+ if (mode.id !== 'select') { return; }
var ids = context.selectedIDs();
- if (ids.length !== 1 || ids[0] !== _pointID) return;
+ if (ids.length !== 1 || ids[0] !== _pointID) { return; }
timeout(function() {
var node = selectMenuItem(context, 'delete').node();
- if (!node) return;
+ if (!node) { return; }
continueTo(enterDelete);
}, 50); // after menu visible
});
function enterDelete() {
- if (!_pointID) return chapter.restart();
+ if (!_pointID) { return chapter.restart(); }
var entity = context.hasEntity(_pointID);
- if (!entity) return chapter.restart();
+ if (!entity) { return chapter.restart(); }
var node = selectMenuItem(context, 'delete').node();
if (!node) { return continueTo(rightClickPoint); }
}, 300); // after menu visible
context.on('exit.intro', function() {
- if (!_pointID) return chapter.restart();
+ if (!_pointID) { return chapter.restart(); }
var entity = context.hasEntity(_pointID);
- if (entity) return continueTo(rightClickPoint); // point still exists
+ if (entity) { return continueTo(rightClickPoint); } // point still exists
});
context.history().on('change.intro', function(changed) {
.attr('xlink:href', '#iD-graphic-areas');
context.on('enter.intro', function(mode) {
- if (mode.id !== 'add-area') return;
+ if (mode.id !== 'add-area') { return; }
continueTo(startPlayground);
});
}, msec + 100);
);
});
context.on('enter.intro', function(mode) {
- if (mode.id !== 'draw-area') return chapter.restart();
+ if (mode.id !== 'draw-area') { return chapter.restart(); }
continueTo(continuePlayground);
});
}, 250); // after reveal
});
function continueTo(nextStep) {
- if (watcher) window.clearInterval(watcher);
+ if (watcher) { window.clearInterval(watcher); }
context.on('exit.intro', null);
nextStep();
}
.attr('xlink:href', '#iD-graphic-lines');
context.on('enter.intro', function(mode) {
- if (mode.id !== 'add-line') return;
+ if (mode.id !== 'add-line') { return; }
continueTo(startLine);
});
}, msec + 100);
function startLine() {
- if (context.mode().id !== 'add-line') return chapter.restart();
+ if (context.mode().id !== 'add-line') { return chapter.restart(); }
_tulipRoadID = null;
});
context.on('enter.intro', function(mode) {
- if (mode.id !== 'draw-line') return chapter.restart();
+ if (mode.id !== 'draw-line') { return chapter.restart(); }
continueTo(drawLine);
});
function drawLine() {
- if (context.mode().id !== 'draw-line') return chapter.restart();
+ if (context.mode().id !== 'draw-line') { return chapter.restart(); }
_tulipRoadID = context.mode().selectedIDs()[0];
context.map().centerEase(tulipRoadMidpoint, 500);
function isLineConnected() {
var entity = _tulipRoadID && context.hasEntity(_tulipRoadID);
- if (!entity) return false;
+ if (!entity) { return false; }
var drawNodes = context.graph().childNodes(entity);
return drawNodes.some(function(node) {
function continueLine() {
- if (context.mode().id !== 'draw-line') return chapter.restart();
+ if (context.mode().id !== 'draw-line') { return chapter.restart(); }
var entity = _tulipRoadID && context.hasEntity(_tulipRoadID);
- if (!entity) return chapter.restart();
+ if (!entity) { return chapter.restart(); }
context.map().centerEase(tulipRoadIntersection, 500);
context.on('enter.intro', function(mode) {
if (mode.id === 'draw-line')
- return;
+ { return; }
else if (mode.id === 'select')
- return continueTo(chooseCategoryRoad);
+ { return continueTo(chooseCategoryRoad); }
else
- return chapter.restart();
+ { return chapter.restart(); }
});
function continueTo(nextStep) {
function chooseCategoryRoad() {
- if (context.mode().id !== 'select') return chapter.restart();
+ if (context.mode().id !== 'select') { return chapter.restart(); }
context.on('exit.intro', function() {
return chapter.restart();
});
var button = context.container().select('.preset-category-road_minor .preset-list-button');
- if (button.empty()) return chapter.restart();
+ if (button.empty()) { return chapter.restart(); }
// disallow scrolling
context.container().select('.inspector-wrap').on('wheel.intro', eventCancel);
function choosePresetResidential() {
- if (context.mode().id !== 'select') return chapter.restart();
+ if (context.mode().id !== 'select') { return chapter.restart(); }
context.on('exit.intro', function() {
return chapter.restart();
});
var subgrid = context.container().select('.preset-category-road_minor .subgrid');
- if (subgrid.empty()) return chapter.restart();
+ if (subgrid.empty()) { return chapter.restart(); }
subgrid.selectAll(':not(.preset-highway-residential) .preset-list-button')
.on('click.intro', function() {
// selected wrong road type
function retryPresetResidential() {
- if (context.mode().id !== 'select') return chapter.restart();
+ if (context.mode().id !== 'select') { return chapter.restart(); }
context.on('exit.intro', function() {
return chapter.restart();
});
context.on('enter.intro', function(mode) {
- if (mode.id !== 'select') return;
+ if (mode.id !== 'select') { return; }
var ids = context.selectedIDs();
- if (ids.length !== 1 || ids[0] !== eleventhAvenueEndID) return;
+ if (ids.length !== 1 || ids[0] !== eleventhAvenueEndID) { return; }
timeout(function() {
var node = selectMenuItem(context, 'split').node();
- if (!node) return;
+ if (!node) { return; }
continueTo(splitIntersection);
}, 50); // after menu visible
});
});
context.ui().editMenu().on('toggled.intro', function(open) {
- if (!open) return;
+ if (!open) { return; }
timeout(function() {
var ids = context.selectedIDs();
ids.indexOf(twelfthAvenueID) !== -1 &&
ids.indexOf(_washingtonSegmentID) !== -1) {
var node = selectMenuItem(context, 'delete').node();
- if (!node) return;
+ if (!node) { return; }
continueTo(multiDelete);
} else if (ids.length === 1 &&
ids.indexOf(_washingtonSegmentID) !== -1) {
}
var node = selectMenuItem(context, 'delete').node();
- if (!node) return continueTo(multiRightClick);
+ if (!node) { return continueTo(multiRightClick); }
reveal('.edit-menu',
helpString('intro.lines.multi_delete'),
.attr('xlink:href', '#iD-graphic-buildings');
context.on('enter.intro', function(mode) {
- if (mode.id !== 'add-area') return;
+ if (mode.id !== 'add-area') { return; }
continueTo(startHouse);
});
}, msec + 100);
});
context.on('enter.intro', function(mode) {
- if (mode.id !== 'draw-area') return chapter.restart();
+ if (mode.id !== 'draw-area') { return chapter.restart(); }
continueTo(continueHouse);
});
function rightClickHouse() {
- if (!_houseID) return chapter.restart();
+ if (!_houseID) { return chapter.restart(); }
context.enter(modeBrowse(context));
context.history().reset('hasHouse');
context.map().centerZoomEase(house, zoom, 500);
context.on('enter.intro', function(mode) {
- if (mode.id !== 'select') return;
+ if (mode.id !== 'select') { return; }
var ids = context.selectedIDs();
- if (ids.length !== 1 || ids[0] !== _houseID) return;
+ if (ids.length !== 1 || ids[0] !== _houseID) { return; }
timeout(function() {
var node = selectMenuItem(context, 'orthogonalize').node();
- if (!node) return;
+ if (!node) { return; }
continueTo(clickSquare);
}, 50); // after menu visible
});
function clickSquare() {
- if (!_houseID) return chapter.restart();
+ if (!_houseID) { return chapter.restart(); }
var entity = context.hasEntity(_houseID);
- if (!entity) return continueTo(rightClickHouse);
+ if (!entity) { return continueTo(rightClickHouse); }
var node = selectMenuItem(context, 'orthogonalize').node();
if (!node) { return continueTo(rightClickHouse); }
);
context.on('enter.intro', function(mode) {
- if (mode.id !== 'add-area') return;
+ if (mode.id !== 'add-area') { return; }
continueTo(startTank);
});
}, msec + 100);
});
context.on('enter.intro', function(mode) {
- if (mode.id !== 'draw-area') return chapter.restart();
+ if (mode.id !== 'draw-area') { return chapter.restart(); }
continueTo(continueTank);
});
function rightClickTank() {
- if (!_tankID) return continueTo(addTank);
+ if (!_tankID) { return continueTo(addTank); }
context.enter(modeBrowse(context));
context.history().reset('hasTank');
timeout(function() {
context.on('enter.intro', function(mode) {
- if (mode.id !== 'select') return;
+ if (mode.id !== 'select') { return; }
var ids = context.selectedIDs();
- if (ids.length !== 1 || ids[0] !== _tankID) return;
+ if (ids.length !== 1 || ids[0] !== _tankID) { return; }
timeout(function() {
var node = selectMenuItem(context, 'circularize').node();
- if (!node) return;
+ if (!node) { return; }
continueTo(clickCircle);
}, 50); // after menu visible
});
function clickCircle() {
- if (!_tankID) return chapter.restart();
+ if (!_tankID) { return chapter.restart(); }
var entity = context.hasEntity(_tankID);
- if (!entity) return continueTo(rightClickTank);
+ if (!entity) { return continueTo(rightClickTank); }
var node = selectMenuItem(context, 'circularize').node();
if (!node) { return continueTo(rightClickTank); }
return utilRebind(chapter, dispatch$1, 'on');
}
- const chapterUi = {
+ var chapterUi = {
welcome: uiIntroWelcome,
navigation: uiIntroNavigation,
point: uiIntroPoint,
startEditing: uiIntroStartEditing
};
- const chapterFlow = [
+ var chapterFlow = [
'welcome',
'navigation',
'point',
function uiIntro(context) {
- const INTRO_IMAGERY = 'EsriWorldImageryClarity';
- let _introGraph = {};
- let _currChapter;
+ var INTRO_IMAGERY = 'EsriWorldImageryClarity';
+ var _introGraph = {};
+ var _currChapter;
function intro(selection) {
_mainFileFetcher.get('intro_graph')
- .then(dataIntroGraph => {
+ .then(function (dataIntroGraph) {
// create entities for intro graph and localize names
- for (let id in dataIntroGraph) {
+ for (var id in dataIntroGraph) {
if (!_introGraph[id]) {
_introGraph[id] = osmEntity(localize(dataIntroGraph[id]));
}
context.enter(modeBrowse(context));
// Save current map state
- let osm = context.connection();
- let history = context.history().toJSON();
- let hash = window.location.hash;
- let center = context.map().center();
- let zoom = context.map().zoom();
- let background = context.background().baseLayerSource();
- let overlays = context.background().overlayLayerSources();
- let opacity = context.container().selectAll('.main-map .layer-background').style('opacity');
- let caches = osm && osm.caches();
- let baseEntities = context.history().graph().base().entities;
+ var osm = context.connection();
+ var history = context.history().toJSON();
+ var hash = window.location.hash;
+ var center = context.map().center();
+ var zoom = context.map().zoom();
+ var background = context.background().baseLayerSource();
+ var overlays = context.background().overlayLayerSources();
+ var opacity = context.container().selectAll('.main-map .layer-background').style('opacity');
+ var caches = osm && osm.caches();
+ var baseEntities = context.history().graph().base().entities;
// Show sidebar and disable the sidebar resizing button
// (this needs to be before `context.inIntro(true)`)
context.history().checkpoint('initial');
// Setup imagery
- let imagery = context.background().findSource(INTRO_IMAGERY);
+ var imagery = context.background().findSource(INTRO_IMAGERY);
if (imagery) {
context.background().baseLayerSource(imagery);
} else {
context.background().bing();
}
- overlays.forEach(d => context.background().toggleOverlayLayer(d));
+ overlays.forEach(function (d) { return context.background().toggleOverlayLayer(d); });
// Setup data layers (only OSM)
- let layers = context.layers();
- layers.all().forEach(item => {
+ var layers = context.layers();
+ layers.all().forEach(function (item) {
// if the layer has the function `enabled`
if (typeof item.layer.enabled === 'function') {
item.layer.enabled(item.id === 'osm');
context.container().selectAll('.main-map .layer-background').style('opacity', 1);
- let curtain = uiCurtain(context.container().node());
+ var curtain = uiCurtain(context.container().node());
selection.call(curtain);
// Store that the user started the walkthrough..
corePreferences('walkthrough_started', 'yes');
// Restore previous walkthrough progress..
- let storedProgress = corePreferences('walkthrough_progress') || '';
- let progress = storedProgress.split(';').filter(Boolean);
+ var storedProgress = corePreferences('walkthrough_progress') || '';
+ var progress = storedProgress.split(';').filter(Boolean);
- let chapters = chapterFlow.map((chapter, i) => {
- let s = chapterUi[chapter](context, curtain.reveal)
- .on('done', () => {
+ var chapters = chapterFlow.map(function (chapter, i) {
+ var s = chapterUi[chapter](context, curtain.reveal)
+ .on('done', function () {
buttons
- .filter(d => d.title === s.title)
+ .filter(function (d) { return d.title === s.title; })
.classed('finished', true);
if (i < chapterFlow.length - 1) {
- const next = chapterFlow[i + 1];
- context.container().select(`button.chapter-${next}`)
+ var next = chapterFlow[i + 1];
+ context.container().select(("button.chapter-" + next))
.classed('next', true);
}
return s;
});
- chapters[chapters.length - 1].on('startEditing', () => {
+ chapters[chapters.length - 1].on('startEditing', function () {
// Store walkthrough progress..
progress.push('startEditing');
corePreferences('walkthrough_progress', utilArrayUniq(progress).join(';'));
// Store if walkthrough is completed..
- let incomplete = utilArrayDifference(chapterFlow, progress);
+ var incomplete = utilArrayDifference(chapterFlow, progress);
if (!incomplete.length) {
corePreferences('walkthrough_completed', 'yes');
}
if (osm) { osm.toggle(true).reset().caches(caches); }
context.history().reset().merge(Object.values(baseEntities));
context.background().baseLayerSource(background);
- overlays.forEach(d => context.background().toggleOverlayLayer(d));
+ overlays.forEach(function (d) { return context.background().toggleOverlayLayer(d); });
if (history) { context.history().fromJSON(history, false); }
context.map().centerZoom(center, zoom);
window.location.replace(hash);
context.inIntro(false);
});
- let navwrap = selection
+ var navwrap = selection
.append('div')
.attr('class', 'intro-nav-wrap fillD');
.append('use')
.attr('xlink:href', '#iD-logo-walkthrough');
- let buttonwrap = navwrap
+ var buttonwrap = navwrap
.append('div')
.attr('class', 'joined')
.selectAll('button.chapter');
- let buttons = buttonwrap
+ var buttons = buttonwrap
.data(chapters)
.enter()
.append('button')
- .attr('class', (d, i) => `chapter chapter-${chapterFlow[i]}`)
+ .attr('class', function (d, i) { return ("chapter chapter-" + (chapterFlow[i])); })
.on('click', enterChapter);
buttons
.append('span')
- .text(d => _t(d.title));
+ .text(function (d) { return _t(d.title); });
buttons
.append('span')
buttons
.classed('next', false)
- .classed('active', d => d.title === _currChapter.title);
+ .classed('active', function (d) { return d.title === _currChapter.title; });
}
}
function zoomStarted() {
- if (_skipEvents) return;
+ if (_skipEvents) { return; }
_tStart = _tCurr = projection.transform();
_gesture = null;
}
function zoomed() {
- if (_skipEvents) return;
+ if (_skipEvents) { return; }
var x = event.transform.x;
var y = event.transform.y;
function zoomEnded() {
- if (_skipEvents) return;
- if (_gesture !== 'pan') return;
+ if (_skipEvents) { return; }
+ if (_gesture !== 'pan') { return; }
updateProjection();
_gesture = null;
function redraw() {
clearTimeout(_timeoutID);
- if (_isHidden) return;
+ if (_isHidden) { return; }
updateProjection();
var zMini = geoScaleToZoom(projection.scale());
var activeOverlayLayers = [];
for (var i = 0; i < overlaySources.length; i++) {
if (overlaySources[i].validZoom(zMini)) {
- if (!overlayLayers[i]) overlayLayers[i] = rendererTileLayer(context);
+ if (!overlayLayers[i]) { overlayLayers[i] = rendererTileLayer(context); }
activeOverlayLayers.push(overlayLayers[i]
.source(overlaySources[i])
.projection(projection)
function toggle() {
- if (event) event.preventDefault();
+ if (event) { event.preventDefault(); }
_isHidden = !_isHidden;
var startHeight;
function startResize() {
- if (pointerId !== (event.pointerId || 'mouse')) return;
+ if (pointerId !== (event.pointerId || 'mouse')) { return; }
event.preventDefault();
event.stopPropagation();
}
function stopResize() {
- if (pointerId !== (event.pointerId || 'mouse')) return;
+ if (pointerId !== (event.pointerId || 'mouse')) { return; }
event.preventDefault();
event.stopPropagation();
if (photoDimensions[0] > mapDimensions[0] || photoDimensions[1] > (mapDimensions[1] - 90)) {
var setPhotoDimensions = [
Math.min(photoDimensions[0], mapDimensions[0]),
- Math.min(photoDimensions[1], mapDimensions[1] - 90),
- ];
+ Math.min(photoDimensions[1], mapDimensions[1] - 90) ];
photoviewer
.style('width', setPhotoDimensions[0] + 'px')
function uiRestore(context) {
return function(selection) {
- if (!context.history().hasRestorableChanges()) return;
+ if (!context.history().hasRestorableChanges()) { return; }
- let modalSelection = uiModal(selection, true);
+ var modalSelection = uiModal(selection, true);
modalSelection.select('.modal')
.attr('class', 'modal fillL');
- let introModal = modalSelection.select('.content');
+ var introModal = modalSelection.select('.content');
introModal
.append('div')
.append('p')
.text(_t('restore.description'));
- let buttonWrap = introModal
+ var buttonWrap = introModal
.append('div')
.attr('class', 'modal-actions');
- let restore = buttonWrap
+ var restore = buttonWrap
.append('button')
.attr('class', 'restore')
- .on('click', () => {
+ .on('click', function () {
context.history().restore();
modalSelection.remove();
});
.append('div')
.text(_t('restore.restore'));
- let reset = buttonWrap
+ var reset = buttonWrap
.append('button')
.attr('class', 'reset')
- .on('click', () => {
+ .on('click', function () {
context.history().clearSaved();
modalSelection.remove();
});
function search(input, dims) {
- if (!dims) dims = 'NSEW';
- if (typeof input !== 'string') return null;
+ if (!dims) { dims = 'NSEW'; }
+ if (typeof input !== 'string') { return null; }
input = input.toUpperCase();
var regex = /^[\s\,]*([NSEW])?\s*([\-|\—|\―]?[0-9.]+)[°º˚]?\s*(?:([0-9.]+)['’′‘]\s*)?(?:([0-9.]+)(?:''|"|”|″)\s*)?([NSEW])?/;
var m = input.match(regex);
- if (!m) return null; // no match
+ if (!m) { return null; } // no match
var matched = m[0];
}
// if unrecognized dimension
- if (dim && dims.indexOf(dim) === -1) return null;
+ if (dim && dims.indexOf(dim) === -1) { return null; }
// extract DMS
var deg = m[2] ? parseFloat(m[2]) : 0;
var min = m[3] ? parseFloat(m[3]) / 60 : 0;
var sec = m[4] ? parseFloat(m[4]) / 3600 : 0;
var sign = (deg < 0) ? -1 : 1;
- if (dim === 'S' || dim === 'W') sign *= -1;
+ if (dim === 'S' || dim === 'W') { sign *= -1; }
return {
val: (Math.abs(deg) + min + sec) * sign,
function pair(input, dims) {
input = input.trim();
var one = search(input, dims);
- if (!one) return null;
+ if (!one) { return null; }
input = one.remain.trim();
var two = search(input, dims);
- if (!two || two.remain) return null;
+ if (!two || two.remain) { return null; }
if (one.dim) {
return swapdim(one.val, two.val, one.dim);
function swapdim(a, b, dim) {
- if (dim === 'N' || dim === 'S') return [a, b];
- if (dim === 'W' || dim === 'E') return [b, a];
+ if (dim === 'N' || dim === 'S') { return [a, b]; }
+ if (dim === 'W' || dim === 'E') { return [b, a]; }
}
function uiFeatureList(context) {
function focusSearch() {
var mode = context.mode() && context.mode().id;
- if (mode !== 'browse') return;
+ if (mode !== 'browse') { return; }
event.preventDefault();
search.node().focus();
var visibleCenter = context.map().extent().center();
var q = search.property('value').toLowerCase();
- if (!q) return result;
+ if (!q) { return result; }
var idMatch = q.match(/(?:^|\W)(node|way|relation|[nwr])\W?0*([1-9]\d*)(?:\W|$)/i);
var localResults = [];
for (var id in allEntities) {
var entity = allEntities[id];
- if (!entity) continue;
+ if (!entity) { continue; }
var name = utilDisplayName(entity) || '';
- if (name.toLowerCase().indexOf(q) < 0) continue;
+ if (name.toLowerCase().indexOf(q) < 0) { continue; }
var matched = _mainPresetIndex.match(entity, graph);
var type = (matched && matched.name()) || utilDisplayType(entity.id);
distance: distance
});
- if (localResults.length > 100) break;
+ if (localResults.length > 100) { break; }
}
localResults = localResults.sort(function byDistance(a, b) {
return a.distance - b.distance;
function mouseover(d) {
- if (d.id === -1) return;
+ if (d.id === -1) { return; }
utilHighlightEntities([d.id], true, context);
}
function mouseout(d) {
- if (d.id === -1) return;
+ if (d.id === -1) { return; }
utilHighlightEntities([d.id], false, context);
}
.attr('class', 'issue-fix-item')
.on('click', function(d) {
// not all fixes are actionable
- if (!select(this).classed('actionable') || !d.onClick) return;
+ if (!select(this).classed('actionable') || !d.onClick) { return; }
// Don't run another fix for this issue within a second of running one
// (Necessary for "Select a feature type" fix. Most fixes should only ever run once)
- if (d.issue.dateLastRanFix && new Date() - d.issue.dateLastRanFix < 1000) return;
+ if (d.issue.dateLastRanFix && new Date() - d.issue.dateLastRanFix < 1000) { return; }
d.issue.dateLastRanFix = new Date();
// remove hover-highlighting
}
section.entityIDs = function(val) {
- if (!arguments.length) return _entityIDs;
+ if (!arguments.length) { return _entityIDs; }
if (!_entityIDs || !val || !utilArrayIdentical(_entityIDs, val)) {
_entityIDs = val;
_activeIssueID = null;
}
function uiPresetIcon() {
- let _preset;
- let _geometry;
- let _sizeClass = 'medium';
+ var _preset;
+ var _geometry;
+ var _sizeClass = 'medium';
function isSmall() {
function getIcon(p, geom) {
if (isSmall() && p.isFallback && p.isFallback())
- return 'iD-icon-' + p.id;
+ { return 'iD-icon-' + p.id; }
else if (p.icon)
- return p.icon;
+ { return p.icon; }
else if (geom === 'line')
- return 'iD-other-line';
+ { return 'iD-other-line'; }
else if (geom === 'vertex')
- return p.isFallback() ? '' : 'temaki-vertex';
+ { return p.isFallback() ? '' : 'temaki-vertex'; }
else if (isSmall() && geom === 'point')
- return '';
+ { return ''; }
else
- return 'maki-marker-stroked';
+ { return 'maki-marker-stroked'; }
}
function renderPointBorder(enter) {
- const w = 40;
- const h = 40;
+ var w = 40;
+ var h = 40;
enter
.append('svg')
.attr('class', 'preset-icon-fill preset-icon-point-border')
.attr('width', w)
.attr('height', h)
- .attr('viewBox', `0 0 ${w} ${h}`)
+ .attr('viewBox', ("0 0 " + w + " " + h))
.append('path')
.attr('transform', 'translate(11.5, 8)')
.attr('d', 'M 17,8 C 17,13 11,21 8.5,23.5 C 6,21 0,13 0,8 C 0,4 4,-0.5 8.5,-0.5 C 13,-0.5 17,4 17,8 z');
function renderCircleFill(fillEnter) {
- const w = 60;
- const h = 60;
- const d = 40;
+ var w = 60;
+ var h = 60;
+ var d = 40;
fillEnter
.append('svg')
.attr('class', 'preset-icon-fill preset-icon-fill-vertex')
.attr('width', w)
.attr('height', h)
- .attr('viewBox', `0 0 ${w} ${h}`)
+ .attr('viewBox', ("0 0 " + w + " " + h))
.append('circle')
.attr('cx', w / 2)
.attr('cy', h / 2)
function renderSquareFill(fillEnter) {
- const d = isSmall() ? 40 : 60;
- const w = d;
- const h = d;
- const l = d * 2/3;
- const c1 = (w-l) / 2;
- const c2 = c1 + l;
+ var d = isSmall() ? 40 : 60;
+ var w = d;
+ var h = d;
+ var l = d * 2/3;
+ var c1 = (w-l) / 2;
+ var c2 = c1 + l;
fillEnter = fillEnter
.append('svg')
.attr('class', 'preset-icon-fill preset-icon-fill-area')
.attr('width', w)
.attr('height', h)
- .attr('viewBox', `0 0 ${w} ${h}`);
+ .attr('viewBox', ("0 0 " + w + " " + h));
- ['fill', 'stroke'].forEach(klass => {
+ ['fill', 'stroke'].forEach(function (klass) {
fillEnter
.append('path')
- .attr('d', `M${c1} ${c1} L${c1} ${c2} L${c2} ${c2} L${c2} ${c1} Z`)
- .attr('class', `line area ${klass}`);
+ .attr('d', ("M" + c1 + " " + c1 + " L" + c1 + " " + c2 + " L" + c2 + " " + c2 + " L" + c2 + " " + c1 + " Z"))
+ .attr('class', ("line area " + klass));
});
- const rVertex = 2.5;
- [[c1, c1], [c1, c2], [c2, c2], [c2, c1]].forEach(point => {
+ var rVertex = 2.5;
+ [[c1, c1], [c1, c2], [c2, c2], [c2, c1]].forEach(function (point) {
fillEnter
.append('circle')
.attr('class', 'vertex')
});
if (!isSmall()) {
- const rMidpoint = 1.25;
- [[c1, w/2], [c2, w/2], [h/2, c1], [h/2, c2]].forEach(point => {
+ var rMidpoint = 1.25;
+ [[c1, w/2], [c2, w/2], [h/2, c1], [h/2, c2]].forEach(function (point) {
fillEnter
.append('circle')
.attr('class', 'midpoint')
function renderLine(lineEnter) {
- const d = isSmall() ? 40 : 60;
+ var d = isSmall() ? 40 : 60;
// draw the line parametrically
- const w = d;
- const h = d;
- const y = Math.round(d * 0.72);
- const l = Math.round(d * 0.6);
- const r = 2.5;
- const x1 = (w - l) / 2;
- const x2 = x1 + l;
+ var w = d;
+ var h = d;
+ var y = Math.round(d * 0.72);
+ var l = Math.round(d * 0.6);
+ var r = 2.5;
+ var x1 = (w - l) / 2;
+ var x2 = x1 + l;
lineEnter = lineEnter
.append('svg')
.attr('class', 'preset-icon-line')
.attr('width', w)
.attr('height', h)
- .attr('viewBox', `0 0 ${w} ${h}`);
+ .attr('viewBox', ("0 0 " + w + " " + h));
- ['casing', 'stroke'].forEach(klass => {
+ ['casing', 'stroke'].forEach(function (klass) {
lineEnter
.append('path')
- .attr('d', `M${x1} ${y} L${x2} ${y}`)
- .attr('class', `line ${klass}`);
+ .attr('d', ("M" + x1 + " " + y + " L" + x2 + " " + y))
+ .attr('class', ("line " + klass));
});
- [[x1-1, y], [x2+1, y]].forEach(point => {
+ [[x1-1, y], [x2+1, y]].forEach(function (point) {
lineEnter
.append('circle')
.attr('class', 'vertex')
function renderRoute(routeEnter) {
- const d = isSmall() ? 40 : 60;
+ var d = isSmall() ? 40 : 60;
// draw the route parametrically
- const w = d;
- const h = d;
- const y1 = Math.round(d * 0.80);
- const y2 = Math.round(d * 0.68);
- const l = Math.round(d * 0.6);
- const r = 2;
- const x1 = (w - l) / 2;
- const x2 = x1 + l / 3;
- const x3 = x2 + l / 3;
- const x4 = x3 + l / 3;
+ var w = d;
+ var h = d;
+ var y1 = Math.round(d * 0.80);
+ var y2 = Math.round(d * 0.68);
+ var l = Math.round(d * 0.6);
+ var r = 2;
+ var x1 = (w - l) / 2;
+ var x2 = x1 + l / 3;
+ var x3 = x2 + l / 3;
+ var x4 = x3 + l / 3;
routeEnter = routeEnter
.append('svg')
.attr('class', 'preset-icon-route')
.attr('width', w)
.attr('height', h)
- .attr('viewBox', `0 0 ${w} ${h}`);
+ .attr('viewBox', ("0 0 " + w + " " + h));
- ['casing', 'stroke'].forEach(klass => {
+ ['casing', 'stroke'].forEach(function (klass) {
routeEnter
.append('path')
- .attr('d', `M${x1} ${y1} L${x2} ${y2}`)
- .attr('class', `segment0 line ${klass}`);
+ .attr('d', ("M" + x1 + " " + y1 + " L" + x2 + " " + y2))
+ .attr('class', ("segment0 line " + klass));
routeEnter
.append('path')
- .attr('d', `M${x2} ${y2} L${x3} ${y1}`)
- .attr('class', `segment1 line ${klass}`);
+ .attr('d', ("M" + x2 + " " + y2 + " L" + x3 + " " + y1))
+ .attr('class', ("segment1 line " + klass));
routeEnter
.append('path')
- .attr('d', `M${x3} ${y1} L${x4} ${y2}`)
- .attr('class', `segment2 line ${klass}`);
+ .attr('d', ("M" + x3 + " " + y1 + " L" + x4 + " " + y2))
+ .attr('class', ("segment2 line " + klass));
});
- [[x1, y1], [x2, y2], [x3, y1], [x4, y2]].forEach(point => {
+ [[x1, y1], [x2, y2], [x3, y1], [x4, y2]].forEach(function (point) {
routeEnter
.append('circle')
.attr('class', 'vertex')
// / \ /
// o o
// This dataset defines the styles that are used to draw the zigzag segments.
- const routeSegments = {
+ var routeSegments = {
bicycle: ['highway/cycleway', 'highway/cycleway', 'highway/cycleway'],
bus: ['highway/unclassified', 'highway/secondary', 'highway/primary'],
trolleybus: ['highway/unclassified', 'highway/secondary', 'highway/primary'],
function render() {
- let p = _preset.apply(this, arguments);
- let geom = _geometry ? _geometry.apply(this, arguments) : null;
+ var p = _preset.apply(this, arguments);
+ var geom = _geometry ? _geometry.apply(this, arguments) : null;
if (geom === 'relation' && p.tags && ((p.tags.type === 'route' && p.tags.route && routeSegments[p.tags.route]) || p.tags.type === 'waterway')) {
geom = 'route';
}
- const showThirdPartyIcons = corePreferences('preferences.privacy.thirdpartyicons') || 'true';
- const isFallback = isSmall() && p.isFallback && p.isFallback();
- const imageURL = (showThirdPartyIcons === 'true') && p.imageURL;
- const picon = getIcon(p, geom);
- const isMaki = picon && /^maki-/.test(picon);
- const isTemaki = picon && /^temaki-/.test(picon);
- const isFa = picon && /^fa[srb]-/.test(picon);
- const isTnp = picon && /^tnp-/.test(picon);
- const isiDIcon = picon && !(isMaki || isTemaki || isFa || isTnp);
- const isCategory = !p.setTags;
- const drawPoint = picon && geom === 'point' && isSmall() && !isFallback;
- const drawVertex = picon !== null && geom === 'vertex' && (!isSmall() || !isFallback);
- const drawLine = picon && geom === 'line' && !isFallback && !isCategory;
- const drawArea = picon && geom === 'area' && !isFallback;
- const drawRoute = picon && geom === 'route';
- const isFramed = (drawVertex || drawArea || drawLine || drawRoute);
-
- let tags = !isCategory ? p.setTags({}, geom) : {};
- for (let k in tags) {
+ var showThirdPartyIcons = corePreferences('preferences.privacy.thirdpartyicons') || 'true';
+ var isFallback = isSmall() && p.isFallback && p.isFallback();
+ var imageURL = (showThirdPartyIcons === 'true') && p.imageURL;
+ var picon = getIcon(p, geom);
+ var isMaki = picon && /^maki-/.test(picon);
+ var isTemaki = picon && /^temaki-/.test(picon);
+ var isFa = picon && /^fa[srb]-/.test(picon);
+ var isTnp = picon && /^tnp-/.test(picon);
+ var isiDIcon = picon && !(isMaki || isTemaki || isFa || isTnp);
+ var isCategory = !p.setTags;
+ var drawPoint = picon && geom === 'point' && isSmall() && !isFallback;
+ var drawVertex = picon !== null && geom === 'vertex' && (!isSmall() || !isFallback);
+ var drawLine = picon && geom === 'line' && !isFallback && !isCategory;
+ var drawArea = picon && geom === 'area' && !isFallback;
+ var drawRoute = picon && geom === 'route';
+ var isFramed = (drawVertex || drawArea || drawLine || drawRoute);
+
+ var tags = !isCategory ? p.setTags({}, geom) : {};
+ for (var k in tags) {
if (tags[k] === '*') {
tags[k] = 'yes';
}
}
- let tagClasses = svgTagClasses().getClassesString(tags, '');
- let selection = select(this);
+ var tagClasses = svgTagClasses().getClassesString(tags, '');
+ var selection = select(this);
- let container = selection.selectAll('.preset-icon-container')
+ var container = selection.selectAll('.preset-icon-container')
.data([0]);
container = container.enter()
.append('div')
- .attr('class', `preset-icon-container ${_sizeClass}`)
+ .attr('class', ("preset-icon-container " + _sizeClass))
.merge(container);
container
.classed('fallback', isFallback);
- let pointBorder = container.selectAll('.preset-icon-point-border')
+ var pointBorder = container.selectAll('.preset-icon-point-border')
.data(drawPoint ? [0] : []);
pointBorder.exit()
.remove();
- let pointBorderEnter = pointBorder.enter();
+ var pointBorderEnter = pointBorder.enter();
renderPointBorder(pointBorderEnter);
pointBorder = pointBorderEnter.merge(pointBorder);
- let vertexFill = container.selectAll('.preset-icon-fill-vertex')
+ var vertexFill = container.selectAll('.preset-icon-fill-vertex')
.data(drawVertex ? [0] : []);
vertexFill.exit()
.remove();
- let vertexFillEnter = vertexFill.enter();
+ var vertexFillEnter = vertexFill.enter();
renderCircleFill(vertexFillEnter);
vertexFill = vertexFillEnter.merge(vertexFill);
- let fill = container.selectAll('.preset-icon-fill-area')
+ var fill = container.selectAll('.preset-icon-fill-area')
.data(drawArea ? [0] : []);
fill.exit()
.remove();
- let fillEnter = fill.enter();
+ var fillEnter = fill.enter();
renderSquareFill(fillEnter);
fill = fillEnter.merge(fill);
fill.selectAll('path.stroke')
- .attr('class', `area stroke ${tagClasses}`);
+ .attr('class', ("area stroke " + tagClasses));
fill.selectAll('path.fill')
- .attr('class', `area fill ${tagClasses}`);
+ .attr('class', ("area fill " + tagClasses));
- let line = container.selectAll('.preset-icon-line')
+ var line = container.selectAll('.preset-icon-line')
.data(drawLine ? [0] : []);
line.exit()
.remove();
- let lineEnter = line.enter();
+ var lineEnter = line.enter();
renderLine(lineEnter);
line = lineEnter.merge(line);
line.selectAll('path.stroke')
- .attr('class', `line stroke ${tagClasses}`);
+ .attr('class', ("line stroke " + tagClasses));
line.selectAll('path.casing')
- .attr('class', `line casing ${tagClasses}`);
+ .attr('class', ("line casing " + tagClasses));
- let route = container.selectAll('.preset-icon-route')
+ var route = container.selectAll('.preset-icon-route')
.data(drawRoute ? [0] : []);
route.exit()
.remove();
- let routeEnter = route.enter();
+ var routeEnter = route.enter();
renderRoute(routeEnter);
route = routeEnter.merge(route);
if (drawRoute) {
- let routeType = p.tags.type === 'waterway' ? 'waterway' : p.tags.route;
- const segmentPresetIDs = routeSegments[routeType];
- for (let i in segmentPresetIDs) {
- const segmentPreset = _mainPresetIndex.item(segmentPresetIDs[i]);
- const segmentTagClasses = svgTagClasses().getClassesString(segmentPreset.tags, '');
- route.selectAll(`path.stroke.segment${i}`)
- .attr('class', `segment${i} line stroke ${segmentTagClasses}`);
- route.selectAll(`path.casing.segment${i}`)
- .attr('class', `segment${i} line casing ${segmentTagClasses}`);
+ var routeType = p.tags.type === 'waterway' ? 'waterway' : p.tags.route;
+ var segmentPresetIDs = routeSegments[routeType];
+ for (var i in segmentPresetIDs) {
+ var segmentPreset = _mainPresetIndex.item(segmentPresetIDs[i]);
+ var segmentTagClasses = svgTagClasses().getClassesString(segmentPreset.tags, '');
+ route.selectAll(("path.stroke.segment" + i))
+ .attr('class', ("segment" + i + " line stroke " + segmentTagClasses));
+ route.selectAll(("path.casing.segment" + i))
+ .attr('class', ("segment" + i + " line casing " + segmentTagClasses));
}
}
- let icon = container.selectAll('.preset-icon')
+ var icon = container.selectAll('.preset-icon')
.data(picon ? [0] : []);
icon.exit()
icon.selectAll('use')
.attr('href', '#' + picon + (isMaki ? (isSmall() && geom === 'point' ? '-11' : '-15') : ''));
- let imageIcon = container.selectAll('img.image-icon')
+ var imageIcon = container.selectAll('img.image-icon')
.data(imageURL ? [0] : []);
imageIcon.exit()
imageIcon = imageIcon.enter()
.append('img')
.attr('class', 'image-icon')
- .on('load', () => container.classed('showing-img', true) )
- .on('error', () => container.classed('showing-img', false) )
+ .on('load', function () { return container.classed('showing-img', true); } )
+ .on('error', function () { return container.classed('showing-img', false); } )
.merge(imageIcon);
imageIcon
presetIcon.preset = function(val) {
- if (!arguments.length) return _preset;
+ if (!arguments.length) { return _preset; }
_preset = utilFunctor(val);
return presetIcon;
};
presetIcon.geometry = function(val) {
- if (!arguments.length) return _geometry;
+ if (!arguments.length) { return _geometry; }
_geometry = utilFunctor(val);
return presetIcon;
};
presetIcon.sizeClass = function(val) {
- if (!arguments.length) return _sizeClass;
+ if (!arguments.length) { return _sizeClass; }
_sizeClass = val;
return presetIcon;
};
.preset(_presets.length === 1 ? _presets[0] : _mainPresetIndex.item('point'))
);
- // NOTE: split on en-dash, not a hypen (to avoid conflict with hyphenated names)
+ // NOTE: split on en-dash, not a hyphen (to avoid conflict with hyphenated names)
var names = _presets.length === 1 ? _presets[0].name().split(' – ') : [_t('inspector.multiple_types')];
var label = selection.select('.label-inner');
}
section.entityIDs = function(val) {
- if (!arguments.length) return _entityIDs;
+ if (!arguments.length) { return _entityIDs; }
_entityIDs = val;
return section;
};
section.presets = function(val) {
- if (!arguments.length) return _presets;
+ if (!arguments.length) { return _presets; }
// don't reload the same preset
if (!utilArrayIdentical(val, _presets)) {
_presets = val;
- var geometries = entityGeometries();
- if (_presets.length === 1 && geometries.length) {
- _tagReference = uiTagReference(_presets[0].reference(geometries[0]))
+ if (_presets.length === 1) {
+ _tagReference = uiTagReference(_presets[0].reference())
.showing(false);
}
}
for (var i in _entityIDs) {
var geometry = context.graph().geometry(_entityIDs[i]);
- if (!counts[geometry]) counts[geometry] = 0;
+ if (!counts[geometry]) { counts[geometry] = 0; }
counts[geometry] += 1;
}
fieldHelp.button = function(selection) {
- if (_body.empty()) return;
+ if (_body.empty()) { return; }
var button = selection.selectAll('.field-help-button')
.data([0]);
fieldHelp.body = function(selection) {
// This control expects the field to have a form-field-input-wrap div
_wrap = selection.selectAll('.form-field-input-wrap');
- if (_wrap.empty()) return;
+ if (_wrap.empty()) { return; }
// absolute position relative to the inspector, so it "floats" above the fields
_inspector = context.container().select('.sidebar .entity-editor-pane .inspector-body');
- if (_inspector.empty()) return;
+ if (_inspector.empty()) { return; }
_body = _inspector.selectAll('.field-help-body')
.data([0]);
function reverserHidden() {
- if (!context.container().select('div.inspector-hover').empty()) return true;
+ if (!context.container().select('div.inspector-hover').empty()) { return true; }
return !(_value === 'yes' || (_impliedYes && !_value));
}
function reverserSetText(selection) {
var entity = _entityIDs.length && context.hasEntity(_entityIDs[0]);
- if (reverserHidden() || !entity) return selection;
+ if (reverserHidden() || !entity) { return selection; }
var first = entity.first();
var last = entity.isClosed() ? entity.nodes[entity.nodes.length - 2] : entity.last();
check.entityIDs = function(val) {
- if (!arguments.length) return _entityIDs;
+ if (!arguments.length) { return _entityIDs; }
_entityIDs = val;
return check;
};
}
function textFor(val) {
- if (val === '') val = undefined;
+ if (val === '') { val = undefined; }
var index = values.indexOf(val);
return (index !== -1 ? texts[index] : ('"' + val + '"'));
}
function setStaticValues(callback) {
- if (!(optstrings || optarray)) return;
+ if (!(optstrings || optarray)) { return; }
if (optstrings) {
_comboData = Object.keys(optstrings).map(function(k) {
}
combobox.data(objectDifference(_comboData, _multiData));
- if (callback) callback(_comboData);
+ if (callback) { callback(_comboData); }
}
}
taginfo[fn](params, function(err, data) {
- if (err) return;
+ if (err) { return; }
data = data.filter(function(d) {
_comboData = data.map(function(d) {
var k = d.value;
- if (isMulti) k = k.replace(field.key, '');
+ if (isMulti) { k = k.replace(field.key, ''); }
var v = snake_case ? unsnake(k) : k;
return {
key: k,
});
_comboData = objectDifference(_comboData, _multiData);
- if (callback) callback(_comboData);
+ if (callback) { callback(_comboData); }
});
}
utilGetSetValue(input, '');
var vals = val.split(';').filter(Boolean);
- if (!vals.length) return;
+ if (!vals.length) { return; }
if (isMulti) {
utilArrayUniq(vals).forEach(function(v) {
// don't set a multicombo value to 'yes' if it already has a non-'no' value
// e.g. `language:de=main`
var old = _tags[key];
- if (typeof old === 'string' && old.toLowerCase() !== 'no') return;
+ if (typeof old === 'string' && old.toLowerCase() !== 'no') { return; }
}
key = context.cleanTagKey(key);
field.keys.push(key);
var rawValue = utilGetSetValue(input);
// don't override multiple values with blank string
- if (!rawValue && Array.isArray(_tags[field.key])) return;
+ if (!rawValue && Array.isArray(_tags[field.key])) { return; }
val = context.cleanTagValue(tagValue(rawValue));
t[field.key] = val || undefined;
if (isMulti) {
// Build _multiData array containing keys already set..
for (var k in tags) {
- if (k.indexOf(field.key) !== 0) continue;
+ if (k.indexOf(field.key) !== 0) { continue; }
var v = tags[k];
- if (!v || (typeof v === 'string' && v.toLowerCase() === 'no')) continue;
+ if (!v || (typeof v === 'string' && v.toLowerCase() === 'no')) { continue; }
var suffix = k.substring(field.key.length);
_multiData.push({
if (!commonValues) {
commonValues = thisVals;
} else {
- commonValues = commonValues.filter(value => thisVals.includes(value));
+ commonValues = commonValues.filter(function (value) { return thisVals.includes(value); });
}
});
allValues = utilArrayUniq(allValues).filter(Boolean);
if (!select(this).classed('dragging') &&
// don't display drag until dragging beyond a distance threshold
- Math.sqrt(Math.pow(x, 2) + Math.pow(y, 2)) <= 5) return;
+ Math.sqrt(Math.pow(x, 2) + Math.pow(y, 2)) <= 5) { return; }
select(this)
.classed('dragging', true);
combo.entityIDs = function(val) {
- if (!arguments.length) return _entityIDs;
+ if (!arguments.length) { return _entityIDs; }
_entityIDs = val;
return combo;
};
function updatePhonePlaceholder() {
- if (input.empty() || !Object.keys(_phoneFormats).length) return;
+ if (input.empty() || !Object.keys(_phoneFormats).length) { return; }
var extent = combinedEntityExtent();
var countryCode = extent && iso1A2Code(extent.center());
var format = countryCode && _phoneFormats[countryCode.toLowerCase()];
- if (format) input.attr('placeholder', format);
+ if (format) { input.attr('placeholder', format); }
}
return function() {
var t = {};
var val = utilGetSetValue(input);
- if (!onInput) val = context.cleanTagValue(val);
+ if (!onInput) { val = context.cleanTagValue(val); }
// don't override multiple values with blank string
- if (!val && Array.isArray(_tags[field.key])) return;
+ if (!val && Array.isArray(_tags[field.key])) { return; }
if (!onInput) {
if (field.type === 'number' && val) {
i.entityIDs = function(val) {
- if (!arguments.length) return _entityIDs;
+ if (!arguments.length) { return _entityIDs; }
_entityIDs = val;
return i;
};
i.focus = function() {
var node = input.node();
- if (node) node.focus();
+ if (node) { node.focus(); }
};
function combinedEntityExtent() {
var value = context.cleanTagValue(utilGetSetValue(select(this)));
// don't override multiple values with blank string
- if (!value && typeof _tags[d] !== 'string') return;
+ if (!value && typeof _tags[d] !== 'string') { return; }
tag[d] = value || undefined;
dispatch$1.call('change', this, tag);
function isAddressable(d) {
if (d.tags.name) {
if (d.tags.admin_level === '8' && d.tags.boundary === 'administrative')
- return true;
+ { return true; }
if (d.tags.border_type === 'city')
- return true;
+ { return true; }
if (d.tags.place === 'city' || d.tags.place === 'town' || d.tags.place === 'village')
- return true;
+ { return true; }
}
if (d.tags['addr:city'])
- return true;
+ { return true; }
return false;
}
function updateForCountryCode() {
- if (!_countryCode) return;
+ if (!_countryCode) { return; }
var addressFormat;
for (var i = 0; i < _addressFormats.length; i++) {
function addDropdown(d) {
- if (dropdowns.indexOf(d.id) === -1) return; // not a dropdown
+ if (dropdowns.indexOf(d.id) === -1) { return; } // not a dropdown
var nearValues = (d.id === 'street') ? getNearStreets
: (d.id === 'city') ? getNearCities
_wrap.selectAll('input:not(.combobox-input)')
.on('input', change(true));
- if (_tags) updateTags(_tags);
+ if (_tags) { updateTags(_tags); }
}
var key = field.key + ':' + subfield.id;
var value = this.value;
- if (!onInput) value = context.cleanTagValue(value);
+ if (!onInput) { value = context.cleanTagValue(value); }
// don't override multiple values with blank string
- if (Array.isArray(_tags[key]) && !value) return;
+ if (Array.isArray(_tags[key]) && !value) { return; }
tags[key] = value || undefined;
});
address.entityIDs = function(val) {
- if (!arguments.length) return _entityIDs;
+ if (!arguments.length) { return _entityIDs; }
_entityIDs = val;
return address;
};
address.focus = function() {
var node = _wrap.selectAll('input').node();
- if (node) node.focus();
+ if (node) { node.focus(); }
};
var newValue = context.cleanTagValue(utilGetSetValue(select(this)));
// don't override multiple values with blank string
- if (!newValue && (Array.isArray(_tags.cycleway) || Array.isArray(_tags[key]))) return;
+ if (!newValue && (Array.isArray(_tags.cycleway) || Array.isArray(_tags[key]))) { return; }
if (newValue === 'none' || newValue === '') { newValue = undefined; }
var commonValue = typeof tags.cycleway === 'string' && tags.cycleway;
utilGetSetValue(items.selectAll('.preset-input-cycleway'), function(d) {
- if (commonValue) return commonValue;
+ if (commonValue) { return commonValue; }
return !tags.cycleway && typeof tags[d] === 'string' ? tags[d] : '';
})
.attr('title', function(d) {
cycleway.focus = function() {
var node = wrap.selectAll('input').node();
- if (node) node.focus();
+ if (node) { node.focus(); }
};
function loadLanguagesArray(dataLanguages) {
- if (_languagesArray.length !== 0) return;
+ if (_languagesArray.length !== 0) { return; }
// some conversion is needed to ensure correct OSM tags are used
var replacements = {
};
for (var code in dataLanguages) {
- if (replacements[code] === false) continue;
+ if (replacements[code] === false) { continue; }
var metaCode = code;
- if (replacements[code]) metaCode = replacements[code];
+ if (replacements[code]) { metaCode = replacements[code]; }
_languagesArray.push({
localName: _mainLocalizer.languageName(metaCode, { localOnly: true }),
_entityIDs.some(function(entityID) {
var entity = context.graph().hasEntity(entityID);
- if (!entity) return false;
+ if (!entity) { return false; }
var original = context.graph().base().entities[_entityIDs[0]];
var hasOriginalName = original && entity.tags.name && entity.tags.name === original.tags.name;
// if the name was already edited manually then allow further editing
- if (!hasOriginalName) return false;
+ if (!hasOriginalName) { return false; }
// features linked to Wikidata are likely important and should be protected
- if (entity.tags.wikidata) return true;
+ if (entity.tags.wikidata) { return true; }
// assume the name has already been confirmed if its source has been researched
- if (entity.tags['name:etymology:wikidata']) return true;
+ if (entity.tags['name:etymology:wikidata']) { return true; }
var preset = _mainPresetIndex.match(entity, context.graph());
var isSuggestion = preset && preset.suggestion;
// - false = churches, parks, hospitals, etc. (things not in the index)
var isFallback = preset.isFallback();
var goodSuggestions = allSuggestions.filter(function(s) {
- if (isFallback) return true;
+ if (isFallback) { return true; }
var sTag = s.id.split('/', 2);
var sKey = sTag[0];
var sValue = sTag[1];
// So compare the current field value against the suggestions one last time.
function checkBrandOnBlur() {
var latest = _entityIDs.length === 1 && context.hasEntity(_entityIDs[0]);
- if (!latest) return; // deleting the entity blurred the field?
+ if (!latest) { return; } // deleting the entity blurred the field?
var preset = _mainPresetIndex.match(latest, context.graph());
- if (preset && preset.suggestion) return; // already accepted
+ if (preset && preset.suggestion) { return; } // already accepted
// note: here we are testing against "decorated" names, i.e. 'Starbucks – Cafe'
var name = utilGetSetValue(input).trim();
}
// Remove whatever is after the last ' – '
- // NOTE: split/join on en-dash, not a hypen (to avoid conflict with fr - nl names in Brussels etc)
+ // NOTE: split/join on en-dash, not a hyphen (to avoid conflict with fr - nl names in Brussels etc)
function cleanName(name) {
var parts = name.split(' – ');
if (parts.length > 1) {
// don't suggest brands from incompatible countries
if (_countryCode && s.countryCodes &&
- s.countryCodes.indexOf(_countryCode) === -1) continue;
+ s.countryCodes.indexOf(_countryCode) === -1) { continue; }
var sTag = s.id.split('/', 2);
var sKey = sTag[0];
function addNew() {
event.preventDefault();
- if (field.locked()) return;
+ if (field.locked()) { return; }
var defaultLang = _mainLocalizer.languageCode().toLowerCase();
var langExists = _multilingual.find(function(datum) { return datum.lang === defaultLang; });
}
var val = utilGetSetValue(select(this));
- if (!onInput) val = context.cleanTagValue(val);
+ if (!onInput) { val = context.cleanTagValue(val); }
// don't override multiple values with blank string
- if (!val && Array.isArray(_tags[field.key])) return;
+ if (!val && Array.isArray(_tags[field.key])) { return; }
var t = {};
(d.localName && d.localName.toLowerCase() === lang) ||
(d.nativeName && d.nativeName.toLowerCase() === lang);
});
- if (language) lang = language.code;
+ if (language) { lang = language.code; }
if (d.lang && d.lang !== lang) {
tags[key(d.lang)] = undefined;
function changeValue(d) {
- if (!d.lang) return;
+ if (!d.lang) { return; }
var value = context.cleanTagValue(utilGetSetValue(select(this))) || undefined;
// don't override multiple values with blank string
- if (!value && Array.isArray(d.value)) return;
+ if (!value && Array.isArray(d.value)) { return; }
var t = {};
t[key(d.lang)] = value;
var langItem = _languagesArray.find(function(item) {
return item.code === code;
});
- if (langItem) langItems.push(langItem);
+ if (langItem) { langItems.push(langItem); }
});
langItems = utilArrayUniq(langItems.concat(_languagesArray));
.append('button')
.attr('class', 'remove-icon-multilingual')
.on('click', function(d, index) {
- if (field.locked()) return;
+ if (field.locked()) { return; }
event.preventDefault();
if (!d.lang || !d.value) {
var wm = tags.wikipedia.match(/([^:]+):(.+)/);
if (wm && wm[0] && wm[1]) {
wikipedia.translations(wm[1], wm[2], function(err, d) {
- if (err || !d) return;
+ if (err || !d) { return; }
_wikiTitles = d;
});
}
localized.entityIDs = function(val) {
- if (!arguments.length) return _entityIDs;
+ if (!arguments.length) { return _entityIDs; }
_entityIDs = val;
_multilingual = [];
loadCountryCode();
var value = utilGetSetValue(input).trim();
// don't override multiple values with blank string
- if (!value && Array.isArray(_tags[field.key])) return;
+ if (!value && Array.isArray(_tags[field.key])) { return; }
if (!value) {
tag[field.key] = undefined;
function changeType(t, onInput) {
var key = selectedKey();
- if (!key) return;
+ if (!key) { return; }
var val = t[key];
if (val !== 'no') {
radios.each(function(d) {
var active = select(this).property('checked');
- if (active) activeKey = d;
+ if (active) { activeKey = d; }
if (field.key) {
- if (active) t[field.key] = d;
+ if (active) { t[field.key] = d; }
} else {
var val = _oldType[activeKey] || 'yes';
t[d] = active ? val : undefined;
radio.entityIDs = function(val) {
- if (!arguments.length) return _entityIDs;
+ if (!arguments.length) { return _entityIDs; }
_entityIDs = val;
_oldType = {};
return radio;
function renderViewer(selection) {
- if (!_intersection) return;
+ if (!_intersection) { return; }
var vgraph = _intersection.graph;
var filter = utilFunctor(true);
_oldTurns = [];
for (i = 0; i < turns.length; i++) {
var turn = turns[i];
- if (seen[turn.restrictionID]) continue; // avoid deleting the turn twice (#4968, #4928)
+ if (seen[turn.restrictionID]) { continue; } // avoid deleting the turn twice (#4968, #4928)
if (turn.direct && turn.path[1] === datum.path[1]) {
seen[turns[i].restrictionID] = true;
var prev = names[names.length - 1];
var curr = displayName(datum.via.ways[i], vgraph);
if (!prev || curr !== prev) // collapse identical names
- names.push(curr);
+ { names.push(curr); }
}
help
restrictions.off = function(selection) {
- if (!_initialized) return;
+ if (!_initialized) { return; }
selection.selectAll('.surface')
.call(breathe.off)
return function() {
var val = utilGetSetValue(input);
- if (!onInput) val = context.cleanTagValue(val);
+ if (!onInput) { val = context.cleanTagValue(val); }
// don't override multiple values with blank string
- if (!val && Array.isArray(_tags[field.key])) return;
+ if (!val && Array.isArray(_tags[field.key])) { return; }
var t = {};
t[field.key] = val || undefined;
.call(svgIcon('#iD-icon-out-link'))
.on('click', function() {
event.preventDefault();
- if (_wikiURL) window.open(_wikiURL, '_blank');
+ if (_wikiURL) { window.open(_wikiURL, '_blank'); }
});
searchRow = searchRow.merge(searchRowEnter);
}
wikidata.itemsForSearchQuery(q, function(err, data) {
- if (err) return;
+ if (err) { return; }
for (var i in data) {
data[i].value = data[i].label + ' (' + data[i].id + ')';
data[i].title = data[i].description;
}
- if (callback) callback(data);
+ if (callback) { callback(data); }
});
}
var initEntityIDs = _entityIDs;
wikidata.entityByQID(_qid, function(err, entity) {
- if (err) return;
+ if (err) { return; }
// If graph has changed, we can't apply this update.
- if (context.graph() !== initGraph) return;
+ if (context.graph() !== initGraph) { return; }
- if (!entity.sitelinks) return;
+ if (!entity.sitelinks) { return; }
var langs = wikidata.languagesToQuery();
// use the label and description languages as fallbacks
['labels', 'descriptions'].forEach(function(key) {
- if (!entity[key]) return;
+ if (!entity[key]) { return; }
var valueLangs = Object.keys(entity[key]);
- if (valueLangs.length === 0) return;
+ if (valueLangs.length === 0) { return; }
var valueLang = valueLangs[0];
if (langs.indexOf(valueLang) === -1) {
newWikipediaValue = context.cleanTagValue(newWikipediaValue);
}
- if (typeof newWikipediaValue === 'undefined') return;
+ if (typeof newWikipediaValue === 'undefined') { return; }
var actions = initEntityIDs.map(function(entityID) {
var entity = context.hasEntity(entityID);
- if (!entity) return;
+ if (!entity) { return; }
var currTags = Object.assign({}, entity.tags); // shallow copy
if (newWikipediaValue === null) {
- if (!currTags[_wikipediaKey]) return;
+ if (!currTags[_wikipediaKey]) { return; }
delete currTags[_wikipediaKey];
} else {
return actionChangeTags(entityID, currTags);
}).filter(Boolean);
- if (!actions.length) return;
+ if (!actions.length) { return; }
// Coalesce the update of wikidata tag into the previous tag change
context.overwrite(
};
function entityPropertyForDisplay(wikidataEntity, propKey) {
- if (!wikidataEntity[propKey]) return '';
+ if (!wikidataEntity[propKey]) { return ''; }
var propObj = wikidataEntity[propKey];
var langKeys = Object.keys(propObj);
- if (langKeys.length === 0) return '';
+ if (langKeys.length === 0) { return ''; }
// sorted by priority, since we want to show the user's language first if possible
var langs = wikidata.languagesToQuery();
for (var i in langs) {
var lang = langs[i];
var valueObj = propObj[lang];
- if (valueObj && valueObj.value && valueObj.value.length > 0) return valueObj.value;
+ if (valueObj && valueObj.value && valueObj.value.length > 0) { return valueObj.value; }
}
// default to any available value
return propObj[langKeys[0]].value;
wiki.entityIDs = function(val) {
- if (!arguments.length) return _entityIDs;
+ if (!arguments.length) { return _entityIDs; }
_entityIDs = val;
return wiki;
};
}
function uiFieldWikipedia(field, context) {
- const dispatch$1 = dispatch('change');
- const wikipedia = services.wikipedia;
- const wikidata = services.wikidata;
- let _langInput = select(null);
- let _titleInput = select(null);
- let _wikiURL = '';
- let _entityIDs;
- let _tags;
-
- let _dataWikipedia = [];
+ var arguments$1 = arguments;
+
+ var dispatch$1 = dispatch('change');
+ var wikipedia = services.wikipedia;
+ var wikidata = services.wikidata;
+ var _langInput = select(null);
+ var _titleInput = select(null);
+ var _wikiURL = '';
+ var _entityIDs;
+ var _tags;
+
+ var _dataWikipedia = [];
_mainFileFetcher.get('wmf_sitematrix')
- .then(d => {
+ .then(function (d) {
_dataWikipedia = d;
- if (_tags) updateForTags(_tags);
+ if (_tags) { updateForTags(_tags); }
})
- .catch(() => { /* ignore */ });
+ .catch(function () { /* ignore */ });
- const langCombo = uiCombobox(context, 'wikipedia-lang')
- .fetcher((value, callback) => {
- const v = value.toLowerCase();
+ var langCombo = uiCombobox(context, 'wikipedia-lang')
+ .fetcher(function (value, callback) {
+ var v = value.toLowerCase();
callback(_dataWikipedia
- .filter(d => {
+ .filter(function (d) {
return d[0].toLowerCase().indexOf(v) >= 0 ||
d[1].toLowerCase().indexOf(v) >= 0 ||
d[2].toLowerCase().indexOf(v) >= 0;
})
- .map(d => ({ value: d[1] }))
+ .map(function (d) { return ({ value: d[1] }); })
);
});
- const titleCombo = uiCombobox(context, 'wikipedia-title')
- .fetcher((value, callback) => {
+ var titleCombo = uiCombobox(context, 'wikipedia-title')
+ .fetcher(function (value, callback) {
if (!value) {
value = '';
- for (let i in _entityIDs) {
- let entity = context.hasEntity(_entityIDs[i]);
+ for (var i in _entityIDs) {
+ var entity = context.hasEntity(_entityIDs[i]);
if (entity.tags.name) {
value = entity.tags.name;
break;
}
}
}
- const searchfn = value.length > 7 ? wikipedia.search : wikipedia.suggestions;
- searchfn(language()[2], value, (query, data) => {
- callback( data.map(d => ({ value: d })) );
+ var searchfn = value.length > 7 ? wikipedia.search : wikipedia.suggestions;
+ searchfn(language()[2], value, function (query, data) {
+ callback( data.map(function (d) { return ({ value: d }); }) );
});
});
function wiki(selection) {
- let wrap = selection.selectAll('.form-field-input-wrap')
+ var wrap = selection.selectAll('.form-field-input-wrap')
.data([0]);
wrap = wrap.enter()
.append('div')
- .attr('class', `form-field-input-wrap form-field-input-${field.type}`)
+ .attr('class', ("form-field-input-wrap form-field-input-" + (field.type)))
.merge(wrap);
- let langContainer = wrap.selectAll('.wiki-lang-container')
+ var langContainer = wrap.selectAll('.wiki-lang-container')
.data([0]);
langContainer = langContainer.enter()
.call(langCombo)
.merge(_langInput);
- utilGetSetValue(_langInput, language()[1]);
-
_langInput
.on('blur', changeLang)
.on('change', changeLang);
- let titleContainer = wrap.selectAll('.wiki-title-container')
+ var titleContainer = wrap.selectAll('.wiki-title-container')
.data([0]);
titleContainer = titleContainer.enter()
.on('change', change);
- let link = titleContainer.selectAll('.wiki-link')
+ var link = titleContainer.selectAll('.wiki-link')
.data([0]);
link = link.enter()
.merge(link);
link
- .on('click', () => {
+ .on('click', function () {
event.preventDefault();
- if (_wikiURL) window.open(_wikiURL, '_blank');
+ if (_wikiURL) { window.open(_wikiURL, '_blank'); }
});
}
- function language() {
- const value = utilGetSetValue(_langInput).toLowerCase();
- const locale = _mainLocalizer.localeCode().toLowerCase();
- let localeLanguage;
- return _dataWikipedia.find(d => {
- if (d[2] === locale) localeLanguage = d;
- return d[0].toLowerCase() === value || d[1].toLowerCase() === value || d[2] === value;
- }) || localeLanguage || ['English', 'English', 'en'];
+ function defaultLanguageInfo(skipEnglishFallback) {
+ var langCode = _mainLocalizer.languageCode().toLowerCase();
+
+ for (var i in _dataWikipedia) {
+ var d = _dataWikipedia[i];
+ // default to the language of iD's current locale
+ if (d[2] === langCode) { return d; }
+ }
+
+ // fallback to English
+ return skipEnglishFallback ? ['', '', ''] : ['English', 'English', 'en'];
+ }
+
+
+ function language(skipEnglishFallback) {
+ var value = utilGetSetValue(_langInput).toLowerCase();
+
+ for (var i in _dataWikipedia) {
+ var d = _dataWikipedia[i];
+ // return the language already set in the UI, if supported
+ if (d[0].toLowerCase() === value ||
+ d[1].toLowerCase() === value ||
+ d[2] === value) { return d; }
+ }
+
+ // fallback to English
+ return defaultLanguageInfo(skipEnglishFallback);
}
function change(skipWikidata) {
- let value = utilGetSetValue(_titleInput);
- const m = value.match(/https?:\/\/([-a-z]+)\.wikipedia\.org\/(?:wiki|\1-[-a-z]+)\/([^#]+)(?:#(.+))?/);
- const l = m && _dataWikipedia.find(d => m[1] === d[2]);
- let syncTags = {};
+ var value = utilGetSetValue(_titleInput);
+ var m = value.match(/https?:\/\/([-a-z]+)\.wikipedia\.org\/(?:wiki|\1-[-a-z]+)\/([^#]+)(?:#(.+))?/);
+ var langInfo = m && _dataWikipedia.find(function (d) { return m[1] === d[2]; });
+ var syncTags = {};
- if (l) {
+ if (langInfo) {
+ var nativeLangName = langInfo[1];
// Normalize title http://www.mediawiki.org/wiki/API:Query#Title_normalization
value = decodeURIComponent(m[2]).replace(/_/g, ' ');
if (m[3]) {
- let anchor;
+ var anchor;
// try {
// leave this out for now - #6232
// Best-effort `anchordecode:` implementation
value += '#' + anchor.replace(/_/g, ' ');
}
value = value.slice(0, 1).toUpperCase() + value.slice(1);
- utilGetSetValue(_langInput, l[1]);
+ utilGetSetValue(_langInput, nativeLangName);
utilGetSetValue(_titleInput, value);
}
dispatch$1.call('change', this, syncTags);
- if (skipWikidata || !value || !language()[2]) return;
+ if (skipWikidata || !value || !language()[2]) { return; }
// attempt asynchronous update of wikidata tag..
- const initGraph = context.graph();
- const initEntityIDs = _entityIDs;
+ var initGraph = context.graph();
+ var initEntityIDs = _entityIDs;
- wikidata.itemsByTitle(language()[2], value, (err, data) => {
- if (err || !data || !Object.keys(data).length) return;
+ wikidata.itemsByTitle(language()[2], value, function (err, data) {
+ if (err || !data || !Object.keys(data).length) { return; }
// If graph has changed, we can't apply this update.
- if (context.graph() !== initGraph) return;
+ if (context.graph() !== initGraph) { return; }
- const qids = Object.keys(data);
- const value = qids && qids.find(id => id.match(/^Q\d+$/));
+ var qids = Object.keys(data);
+ var value = qids && qids.find(function (id) { return id.match(/^Q\d+$/); });
- let actions = initEntityIDs.map((entityID) => {
- let entity = context.entity(entityID).tags;
- let currTags = Object.assign({}, entity); // shallow copy
+ var actions = initEntityIDs.map(function (entityID) {
+ var entity = context.entity(entityID).tags;
+ var currTags = Object.assign({}, entity); // shallow copy
if (currTags.wikidata !== value) {
currTags.wikidata = value;
return actionChangeTags(entityID, currTags);
}
}).filter(Boolean);
- if (!actions.length) return;
+ if (!actions.length) { return; }
// Coalesce the update of wikidata tag into the previous tag change
context.overwrite(
}
- wiki.tags = (tags) => {
+ wiki.tags = function (tags) {
_tags = tags;
updateForTags(tags);
};
function updateForTags(tags) {
- const value = typeof tags[field.key] === 'string' ? tags[field.key] : '';
- const m = value.match(/([^:]+):([^#]+)(?:#(.+))?/);
- const l = m && _dataWikipedia.find(d => m[1] === d[2]);
- let anchor = m && m[3];
+ var value = typeof tags[field.key] === 'string' ? tags[field.key] : '';
+ // Expect tag format of `tagLang:tagArticleTitle`, e.g. `fr:Paris`, with
+ // optional suffix of `#anchor`
+ var m = value.match(/([^:]+):([^#]+)(?:#(.+))?/);
+ var tagLang = m && m[1];
+ var tagArticleTitle = m && m[2];
+ var anchor = m && m[3];
+ var tagLangInfo = tagLang && _dataWikipedia.find(function (d) { return tagLang === d[2]; });
// value in correct format
- if (l) {
- utilGetSetValue(_langInput, l[1]);
- utilGetSetValue(_titleInput, m[2] + (anchor ? ('#' + anchor) : ''));
+ if (tagLangInfo) {
+ var nativeLangName = tagLangInfo[1];
+ utilGetSetValue(_langInput, nativeLangName);
+ utilGetSetValue(_titleInput, tagArticleTitle + (anchor ? ('#' + anchor) : ''));
if (anchor) {
try {
// Best-effort `anchorencode:` implementation
anchor = anchor.replace(/ /g, '_');
}
}
- _wikiURL = 'https://' + m[1] + '.wikipedia.org/wiki/' +
- m[2].replace(/ /g, '_') + (anchor ? ('#' + anchor) : '');
+ _wikiURL = 'https://' + tagLang + '.wikipedia.org/wiki/' +
+ tagArticleTitle.replace(/ /g, '_') + (anchor ? ('#' + anchor) : '');
// unrecognized value format
} else {
utilGetSetValue(_titleInput, value);
if (value && value !== '') {
utilGetSetValue(_langInput, '');
- _wikiURL = `https://en.wikipedia.org/wiki/Special:Search?search=${value}`;
+ var defaultLangInfo = defaultLanguageInfo();
+ _wikiURL = "https://" + (defaultLangInfo[2]) + ".wikipedia.org/w/index.php?fulltext=1&search=" + value;
} else {
+ var shownOrDefaultLangInfo = language(true /* skipEnglishFallback */);
+ utilGetSetValue(_langInput, shownOrDefaultLangInfo[1]);
_wikiURL = '';
}
}
}
- wiki.entityIDs = (val) => {
- if (!arguments.length) return _entityIDs;
+ wiki.entityIDs = function (val) {
+ if (!arguments$1.length) { return _entityIDs; }
_entityIDs = val;
return wiki;
};
- wiki.focus = () => {
+ wiki.focus = function () {
_titleInput.node().focus();
};
function isModified() {
- if (!entityIDs || !entityIDs.length) return false;
+ if (!entityIDs || !entityIDs.length) { return false; }
return entityIDs.some(function(entityID) {
var original = context.graph().base().entities[entityID];
var latest = context.graph().entity(entityID);
function revert(d) {
event.stopPropagation();
event.preventDefault();
- if (!entityIDs || _locked) return;
+ if (!entityIDs || _locked) { return; }
dispatch$1.call('revert', d, d.keys);
}
function remove(d) {
event.stopPropagation();
event.preventDefault();
- if (_locked) return;
+ if (_locked) { return; }
var t = {};
d.keys.forEach(function(key) {
field.state = function(val) {
- if (!arguments.length) return _state;
+ if (!arguments.length) { return _state; }
_state = val;
return field;
};
field.tags = function(val) {
- if (!arguments.length) return _tags;
+ if (!arguments.length) { return _tags; }
_tags = val;
if (tagsContainFieldKey() && !_show) {
field.locked = function(val) {
- if (!arguments.length) return _locked;
+ if (!arguments.length) { return _locked; }
_locked = val;
return field;
};
if (entityIDs &&
entityIDs.length > 1 &&
- uiFields[field.type].supportsMultiselection === false) return false;
+ uiFields[field.type].supportsMultiselection === false) { return false; }
if (field.geometry && !entityIDs.every(function(entityID) {
return field.matchGeometry(context.graph().geometry(entityID));
- })) return false;
+ })) { return false; }
if (field.countryCodes || field.notCountryCodes) {
var extent = combinedEntityExtent();
- if (!extent) return true;
+ if (!extent) { return true; }
var center = extent.center();
var countryCode = iso1A2Code(center);
- if (!countryCode) return false;
+ if (!countryCode) { return false; }
countryCode = countryCode.toLowerCase();
var entity = context.graph().entity(entityID);
if (prerequisiteTag.key) {
var value = entity.tags[prerequisiteTag.key];
- if (!value) return false;
+ if (!value) { return false; }
if (prerequisiteTag.valueNot) {
return prerequisiteTag.valueNot !== value;
return prerequisiteTag.value === value;
}
} else if (prerequisiteTag.keyNot) {
- if (entity.tags[prerequisiteTag.keyNot]) return false;
+ if (entity.tags[prerequisiteTag.keyNot]) { return false; }
}
return true;
- })) return false;
+ })) { return false; }
}
return true;
titles.push(label);
var terms = field.terms();
- if (field.key) terms.push(field.key);
- if (field.keys) terms = terms.concat(field.keys);
+ if (field.key) { terms.push(field.key); }
+ if (field.keys) { terms = terms.concat(field.keys); }
return {
title: label,
.call(moreCombo
.data(moreFields)
.on('accept', function (d) {
- if (!d) return; // user entered something that was not matched
+ if (!d) { return; } // user entered something that was not matched
var field = d.field;
field.show();
selection.call(formFields); // rerender
formFields.fieldsArr = function(val) {
- if (!arguments.length) return _fieldsArr;
+ if (!arguments.length) { return _fieldsArr; }
_fieldsArr = val || [];
return formFields;
};
formFields.state = function(val) {
- if (!arguments.length) return _state;
+ if (!arguments.length) { return _state; }
_state = val;
return formFields;
};
formFields.klass = function(val) {
- if (!arguments.length) return _klass;
+ if (!arguments.length) { return _klass; }
_klass = val;
return formFields;
};
var graph = context.graph();
var geometries = Object.keys(_entityIDs.reduce(function(geoms, entityID) {
- return geoms[graph.entity(entityID).geometry(graph)] = true;
+ geoms[graph.entity(entityID).geometry(graph)] = true;
+ return geoms;
}, {}));
var presetsManager = _mainPresetIndex;
}
section.presets = function(val) {
- if (!arguments.length) return _presets;
+ if (!arguments.length) { return _presets; }
if (!_presets || !val || !utilArrayIdentical(_presets, val)) {
_presets = val;
_fieldsArr = null;
};
section.state = function(val) {
- if (!arguments.length) return _state;
+ if (!arguments.length) { return _state; }
_state = val;
return section;
};
section.tags = function(val) {
- if (!arguments.length) return _tags;
+ if (!arguments.length) { return _tags; }
_tags = val;
// Don't reset _fieldsArr here.
return section;
};
section.entityIDs = function(val) {
- if (!arguments.length) return _entityIDs;
+ if (!arguments.length) { return _entityIDs; }
if (!val || !_entityIDs || !utilArrayIdentical(_entityIDs, val)) {
_entityIDs = val;
_fieldsArr = null;
var section = uiSection('raw-member-editor', context)
.shouldDisplay(function() {
- if (!_entityIDs || _entityIDs.length !== 1) return false;
+ if (!_entityIDs || _entityIDs.length !== 1) { return false; }
var entity = context.hasEntity(_entityIDs[0]);
return entity && entity.type === 'relation';
})
.title(function() {
var entity = context.hasEntity(_entityIDs[0]);
- if (!entity) return '';
+ if (!entity) { return ''; }
var gt = entity.members.length > _maxMembers ? '>' : '';
var count = gt + entity.members.slice(0, _maxMembers).length;
if (!select(this).classed('dragging') &&
// don't display drag until dragging beyond a distance threshold
- Math.sqrt(Math.pow(x, 2) + Math.pow(y, 2)) <= 5) return;
+ Math.sqrt(Math.pow(x, 2) + Math.pow(y, 2)) <= 5) { return; }
select(this)
.classed('dragging', true);
geometry: geometry,
query: role
}, function(err, data) {
- if (!err) callback(sort(role, data));
+ if (!err) { callback(sort(role, data)); }
});
})
.on('cancel', function() {
}
section.entityIDs = function(val) {
- if (!arguments.length) return _entityIDs;
+ if (!arguments.length) { return _entityIDs; }
_entityIDs = val;
return section;
};
})
.title(function() {
var entity = context.hasEntity(_entityIDs[0]);
- if (!entity) return '';
+ if (!entity) { return ''; }
var parents = context.graph().parentRelations(entity);
var gt = parents.length > _maxMemberships ? '>' : '';
.minItems(1)
.fetcher(fetchNearbyRelations)
.itemsMouseEnter(function(d) {
- if (d.relation) utilHighlightEntities([d.relation.id], true, context);
+ if (d.relation) { utilHighlightEntities([d.relation.id], true, context); }
})
.itemsMouseLeave(function(d) {
- if (d.relation) utilHighlightEntities([d.relation.id], false, context);
+ if (d.relation) { utilHighlightEntities([d.relation.id], false, context); }
});
var _inChange = false;
var _entityIDs = [];
function changeRole(d) {
- if (d === 0) return; // called on newrow (shoudn't happen)
- if (_inChange) return; // avoid accidental recursive call #5731
+ if (d === 0) { return; } // called on newrow (shouldn't happen)
+ if (_inChange) { return; } // avoid accidental recursive call #5731
var oldRole = d.member.role;
var newRole = context.cleanRelationRole(select(this).property('value'));
function deleteMembership(d) {
this.blur(); // avoid keeping focus on the button
- if (d === 0) return; // called on newrow (shoudn't happen)
+ if (d === 0) { return; } // called on newrow (shouldn't happen)
// remove the hover-highlight styling
utilHighlightEntities([d.relation.id], false, context);
} else {
context.history().intersects(context.map().extent()).forEach(function(entity) {
- if (entity.type !== 'relation' || entity.id === entityID) return;
+ if (entity.type !== 'relation' || entity.id === entityID) { return; }
var value = baseDisplayLabel(entity);
- if (q && (value + ' ' + entity.id).toLowerCase().indexOf(q.toLowerCase()) === -1) return;
+ if (q && (value + ' ' + entity.id).toLowerCase().indexOf(q.toLowerCase()) === -1) { return; }
result.push({ relation: entity, value: value });
});
return;
}
// remove hover-higlighting
- if (d.relation) utilHighlightEntities([d.relation.id], false, context);
+ if (d.relation) { utilHighlightEntities([d.relation.id], false, context); }
var role = context.cleanRelationRole(list.selectAll('.member-row-new .member-role').property('value'));
addMembership(d, role);
geometry: context.graph().geometry(entityID),
query: role
}, function(err, data) {
- if (!err) callback(sort(role, data));
+ if (!err) { callback(sort(role, data)); }
});
})
.on('cancel', function() {
section.entityIDs = function(val) {
- if (!arguments.length) return _entityIDs;
+ if (!arguments.length) { return _entityIDs; }
_entityIDs = val;
_showBlank = false;
return section;
});
section.entityIDs = function(val) {
- if (!arguments.length) return _selectedIDs;
+ if (!arguments.length) { return _selectedIDs; }
_selectedIDs = val;
return section;
};
.on('change.entity-editor', historyChanged);
function historyChanged(difference) {
- if (selection.selectAll('.entity-editor').empty()) return;
- if (_state === 'hide') return;
+ if (selection.selectAll('.entity-editor').empty()) { return; }
+ if (_state === 'hide') { return; }
var significant = !difference ||
difference.didChange.properties ||
difference.didChange.addition ||
difference.didChange.deletion;
- if (!significant) return;
+ if (!significant) { return; }
_entityIDs = _entityIDs.filter(context.hasEntity);
- if (!_entityIDs.length) return;
+ if (!_entityIDs.length) { return; }
var priorActivePreset = _activePresets.length === 1 && _activePresets[0];
var tags = Object.assign({}, entity.tags); // shallow copy
for (var k in changed) {
- if (!k) continue;
+ if (!k) { continue; }
var v = changed[k];
if (v !== undefined || tags.hasOwnProperty(k)) {
tags[k] = v;
var tags = Object.assign({}, entity.tags); // shallow copy
for (var k in changed) {
- if (!k) continue;
+ if (!k) { continue; }
var v = changed[k];
if (v !== undefined || tags.hasOwnProperty(k)) {
tags[k] = v;
entityEditor.modified = function(val) {
- if (!arguments.length) return _modified;
+ if (!arguments.length) { return _modified; }
_modified = val;
return entityEditor;
};
entityEditor.state = function(val) {
- if (!arguments.length) return _state;
+ if (!arguments.length) { return _state; }
_state = val;
return entityEditor;
};
entityEditor.entityIDs = function(val) {
- if (!arguments.length) return _entityIDs;
- if (val && _entityIDs && utilArrayIdentical(_entityIDs, val)) return entityEditor; // exit early if no change
+ if (!arguments.length) { return _entityIDs; }
+ if (val && _entityIDs && utilArrayIdentical(_entityIDs, val)) { return entityEditor; } // exit early if no change
_entityIDs = val;
_base = context.graph();
_coalesceChanges = false;
- loadActivePresets();
+ loadActivePresets(true);
return entityEditor
.modified(false);
entityEditor.newFeature = function(val) {
- if (!arguments.length) return _newFeature;
+ if (!arguments.length) { return _newFeature; }
_newFeature = val;
return entityEditor;
};
- function loadActivePresets() {
+ function loadActivePresets(isForNewSelection) {
var graph = context.graph();
for (var i in _entityIDs) {
var entity = graph.hasEntity(_entityIDs[i]);
- if (!entity) return;
+ if (!entity) { return; }
var match = _mainPresetIndex.match(entity, graph);
- if (!counts[match.id]) counts[match.id] = 0;
+ if (!counts[match.id]) { counts[match.id] = 0; }
counts[match.id] += 1;
}
return _mainPresetIndex.item(pID);
});
- // A "weak" preset doesn't set any tags. (e.g. "Address")
- var weakPreset = _activePresets.length === 1 &&
- Object.keys(_activePresets[0].addTags || {}).length === 0;
- // Don't replace a weak preset with a fallback preset (e.g. "Point")
- if (weakPreset && matches.length === 1 && matches[0].isFallback()) return;
+ if (!isForNewSelection) {
+ // A "weak" preset doesn't set any tags. (e.g. "Address")
+ var weakPreset = _activePresets.length === 1 &&
+ !_activePresets[0].isFallback() &&
+ Object.keys(_activePresets[0].addTags || {}).length === 0;
+ // Don't replace a weak preset with a fallback preset (e.g. "Point")
+ if (weakPreset && matches.length === 1 && matches[0].isFallback()) { return; }
+ }
entityEditor.presets(matches);
}
entityEditor.presets = function(val) {
- if (!arguments.length) return _activePresets;
+ if (!arguments.length) { return _activePresets; }
// don't reload the same preset
if (!utilArrayIdentical(val, _activePresets)) {
function presetList(selection) {
- if (!_entityIDs) return;
+ if (!_entityIDs) { return; }
var presets = _mainPresetIndex.matchAllGeometry(entityGeometries());
event.stopPropagation();
// move focus to the first item in the preset list
var buttons = list.selectAll('.preset-list-button');
- if (!buttons.empty()) buttons.nodes()[0].focus();
+ if (!buttons.empty()) { buttons.nodes()[0].focus(); }
}
}
function drawList(list, presets) {
presets = presets.matchAllGeometry(entityGeometries());
var collection = presets.collection.reduce(function(collection, preset) {
- if (!preset) return collection;
+ if (!preset) { return collection; }
if (preset.members) {
if (preset.members.collection.filter(function(preset) {
item.choose = function() {
- if (!box || !sublist) return;
+ if (!box || !sublist) { return; }
if (shown) {
shown = false;
.append('div')
.attr('class', 'label-inner');
- // NOTE: split/join on en-dash, not a hypen (to avoid conflict with fr - nl names in Brussels etc)
+ // NOTE: split/join on en-dash, not a hyphen (to avoid conflict with fr - nl names in Brussels etc)
label.selectAll('.namepart')
.data(preset.name().split(' – '))
.enter()
}
item.choose = function() {
- if (select(this).classed('disabled')) return;
+ if (select(this).classed('disabled')) { return; }
if (!context.inIntro()) {
_mainPresetIndex.setMostRecent(preset, entityGeometries()[0]);
}
};
item.preset = preset;
- item.reference = uiTagReference(preset.reference(entityGeometries()[0]));
+ item.reference = uiTagReference(preset.reference());
return item;
}
function updateForFeatureHiddenState() {
- if (!_entityIDs.every(context.hasEntity)) return;
+ if (!_entityIDs.every(context.hasEntity)) { return; }
var geometries = entityGeometries();
var button = context.container().selectAll('.preset-list .preset-list-button');
var hiddenPresetFeaturesId;
for (var i in geometries) {
hiddenPresetFeaturesId = context.features().isHiddenPreset(item.preset, geometries[i]);
- if (hiddenPresetFeaturesId) break;
+ if (hiddenPresetFeaturesId) { break; }
}
var isHiddenPreset = !context.inIntro() &&
!!hiddenPresetFeaturesId &&
}
presetList.autofocus = function(val) {
- if (!arguments.length) return _autofocus;
+ if (!arguments.length) { return _autofocus; }
_autofocus = val;
return presetList;
};
presetList.entityIDs = function(val) {
- if (!arguments.length) return _entityIDs;
+ if (!arguments.length) { return _entityIDs; }
_entityIDs = val;
if (_entityIDs && _entityIDs.length) {
var presets = _entityIDs.map(function(entityID) {
};
presetList.presets = function(val) {
- if (!arguments.length) return _currentPresets;
+ if (!arguments.length) { return _currentPresets; }
_currentPresets = val;
return presetList;
};
geometry = 'point';
}
- if (!counts[geometry]) counts[geometry] = 0;
+ if (!counts[geometry]) { counts[geometry] = 0; }
counts[geometry] += 1;
}
function shouldDefaultToPresetList() {
// always show the inspector on hover
- if (_state !== 'select') return false;
+ if (_state !== 'select') { return false; }
// can only change preset on single selection
- if (_entityIDs.length !== 1) return false;
+ if (_entityIDs.length !== 1) { return false; }
var entityID = _entityIDs[0];
var entity = context.hasEntity(entityID);
- if (!entity) return false;
+ if (!entity) { return false; }
// default to inspector if there are already tags
- if (entity.hasNonGeometryTags()) return false;
+ if (entity.hasNonGeometryTags()) { return false; }
// prompt to select preset if feature is new and untagged
- if (_newFeature) return true;
+ if (_newFeature) { return true; }
// all existing features except vertices should default to inspector
- if (entity.geometry(context.graph()) !== 'vertex') return false;
+ if (entity.geometry(context.graph()) !== 'vertex') { return false; }
// show vertex relations if any
- if (context.graph().parentRelations(entity).length) return false;
+ if (context.graph().parentRelations(entity).length) { return false; }
// show vertex issues if there are any
- if (context.validator().getEntityIssues(entityID).length) return false;
+ if (context.validator().getEntityIssues(entityID).length) { return false; }
// show turn retriction editor for junction vertices
- if (entity.isHighwayIntersection(context.graph())) return false;
+ if (entity.isHighwayIntersection(context.graph())) { return false; }
// otherwise show preset list for uninteresting vertices
return true;
};
inspector.state = function(val) {
- if (!arguments.length) return _state;
+ if (!arguments.length) { return _state; }
_state = val;
entityEditor.state(_state);
inspector.entityIDs = function(val) {
- if (!arguments.length) return _entityIDs;
+ if (!arguments.length) { return _entityIDs; }
_entityIDs = val;
return inspector;
};
inspector.newFeature = function(val) {
- if (!arguments.length) return _newFeature;
+ if (!arguments.length) { return _newFeature; }
_newFeature = val;
return inspector;
};
var downPointerId, lastClientX, containerLocGetter;
function pointerdown() {
- if (downPointerId) return;
+ if (downPointerId) { return; }
- if ('button' in event && event.button !== 0) return;
+ if ('button' in event && event.button !== 0) { return; }
downPointerId = event.pointerId || 'mouse';
function pointermove() {
- if (downPointerId !== (event.pointerId || 'mouse')) return;
+ if (downPointerId !== (event.pointerId || 'mouse')) { return; }
event.preventDefault();
}
function pointerup() {
- if (downPointerId !== (event.pointerId || 'mouse')) return;
+ if (downPointerId !== (event.pointerId || 'mouse')) { return; }
downPointerId = null;
.classed('inspector-hover', true);
} else if (datum instanceof osmNote) {
- if (context.mode().id === 'drag-note') return;
+ if (context.mode().id === 'drag-note') { return; }
_wasNote = true;
var osm = services.osm;
.classed('inspector-hidden', false)
.classed('inspector-hover', false);
- if (!inspector.entityIDs() || !utilArrayIdentical(inspector.entityIDs(), ids) || inspector.state() !== 'select') {
- inspector
- .state('select')
- .entityIDs(ids)
- .newFeature(newFeature);
+ // reload the UI even if the ids are the same since the entities
+ // themselves may have changed
+ inspector
+ .state('select')
+ .entityIDs(ids)
+ .newFeature(newFeature);
- inspectorWrap
- .call(inspector);
- }
+ inspectorWrap
+ .call(inspector);
} else {
inspector
inspectorWrap
.classed('inspector-hidden', true);
- if (_current) _current.remove();
+ if (_current) { _current.remove(); }
_current = selection
.append('div')
.attr('class', 'sidebar-component')
inspectorWrap
.classed('inspector-hidden', true);
- if (_current) _current.remove();
+ if (_current) { _current.remove(); }
_current = null;
};
}
// Don't allow sidebar to toggle when the user is in the walkthrough.
- if (context.inIntro()) return;
+ if (context.inIntro()) { return; }
var isCollapsed = selection.classed('collapsed');
var isCollapsing = !isCollapsed;
event.preventDefault();
var osm = context.connection();
- if (!osm) return;
+ if (!osm) { return; }
- if (context.inIntro()) return;
+ if (context.inIntro()) { return; }
if (context.history().hasChanges() &&
- !window.confirm(_t('source_switch.lose_changes'))) return;
+ !window.confirm(_t('source_switch.lose_changes'))) { return; }
var isLive = select(this)
.classed('live');
sourceSwitch.keys = function(_) {
- if (!arguments.length) return keys;
+ if (!arguments.length) { return keys; }
keys = _;
return sourceSwitch;
};
}
function uiSplash(context) {
- return (selection) => {
+ return function (selection) {
// Exception - if there are restorable changes, skip this splash screen.
// This is because we currently only support one `uiModal` at a time
// and we need to show them `uiRestore`` instead of this one.
- if (context.history().hasRestorableChanges()) return;
+ if (context.history().hasRestorableChanges()) { return; }
// If user has not seen this version of the privacy policy, show the splash again.
- let updateMessage = '';
- const sawPrivacyVersion = corePreferences('sawPrivacyVersion');
- let showSplash = !corePreferences('sawSplash');
+ var updateMessage = '';
+ var sawPrivacyVersion = corePreferences('sawPrivacyVersion');
+ var showSplash = !corePreferences('sawSplash');
if (sawPrivacyVersion !== context.privacyVersion) {
updateMessage = _t('splash.privacy_update');
showSplash = true;
}
- if (!showSplash) return;
+ if (!showSplash) { return; }
corePreferences('sawSplash', true);
corePreferences('sawPrivacyVersion', context.privacyVersion);
// fetch intro graph data now, while user is looking at the splash screen
_mainFileFetcher.get('intro_graph');
- let modalSelection = uiModal(selection);
+ var modalSelection = uiModal(selection);
modalSelection.select('.modal')
.attr('class', 'modal-splash modal');
- let introModal = modalSelection.select('.content')
+ var introModal = modalSelection.select('.content')
.append('div')
.attr('class', 'fillL');
.append('h3')
.text(_t('splash.welcome'));
- let modalSection = introModal
+ var modalSection = introModal
.append('div')
.attr('class','modal-section');
_t('splash.privacy_policy') + '</a>'
}));
- let buttonWrap = introModal
+ var buttonWrap = introModal
.append('div')
.attr('class', 'modal-actions');
- let walkthrough = buttonWrap
+ var walkthrough = buttonWrap
.append('button')
.attr('class', 'walkthrough')
- .on('click', () => {
+ .on('click', function () {
context.container().call(uiIntro(context));
modalSelection.close();
});
.append('div')
.text(_t('splash.walkthrough'));
- let startEditing = buttonWrap
+ var startEditing = buttonWrap
.append('button')
.attr('class', 'start-editing')
.on('click', modalSelection.close);
return function(selection) {
- if (!osm) return;
+ if (!osm) { return; }
function update(err, apiStatus) {
selection.html('');
.on('startFromNode', startFromNode);
var defaultTags = { area: 'yes' };
- if (mode.preset) defaultTags = mode.preset.setTags(defaultTags, 'area');
+ if (mode.preset) { defaultTags = mode.preset.setTags(defaultTags, 'area'); }
function actionClose(wayId) {
.on('startFromNode', startFromNode);
var defaultTags = {};
- if (mode.preset) defaultTags = mode.preset.setTags(defaultTags, 'line');
+ if (mode.preset) { defaultTags = mode.preset.setTags(defaultTags, 'line'); }
function start(loc) {
.on('finish', cancel);
var defaultTags = {};
- if (mode.preset) defaultTags = mode.preset.setTags(defaultTags, 'point');
+ if (mode.preset) { defaultTags = mode.preset.setTags(defaultTags, 'point'); }
function add(loc) {
function add(loc) {
var osm = services.osm;
- if (!osm) return;
+ if (!osm) { return; }
var note = osmNote({ loc: loc, status: 'open', comments: [] });
osm.replaceNote(note);
function choose(ul, datum) {
- if (event) event.preventDefault();
+ if (event) { event.preventDefault(); }
select(ul)
.selectAll('li')
var entity;
entity = context.graph().hasEntity(datum.id);
- if (entity) extent._extend(entity.extent(context.graph()));
+ if (entity) { extent._extend(entity.extent(context.graph())); }
datum.action();
entity = context.graph().hasEntity(datum.id);
- if (entity) extent._extend(entity.extent(context.graph()));
+ if (entity) { extent._extend(entity.extent(context.graph())); }
zoomToEntity(datum.id, extent);
}
// ]
// }
conflicts.conflictList = function(_) {
- if (!arguments.length) return _conflictList;
+ if (!arguments.length) { return _conflictList; }
_conflictList = _;
return conflicts;
};
conflicts.origChanges = function(_) {
- if (!arguments.length) return _origChanges;
+ if (!arguments.length) { return _origChanges; }
_origChanges = _;
return conflicts;
};
_fieldsArr = [
uiField(context, presets.field('comment'), null, { show: true, revert: false }),
uiField(context, presets.field('source'), null, { show: false, revert: false }),
- uiField(context, presets.field('hashtags'), null, { show: false, revert: false }),
- ];
+ uiField(context, presets.field('hashtags'), null, { show: false, revert: false }) ];
_fieldsArr.forEach(function(field) {
field
var osm = context.connection();
if (osm) {
osm.userChangesets(function (err, changesets) {
- if (err) return;
+ if (err) { return; }
var comments = changesets.map(function(changeset) {
var comment = changeset.tags.comment;
changesetEditor.tags = function(_) {
- if (!arguments.length) return _tags;
+ if (!arguments.length) { return _tags; }
_tags = _;
// Don't reset _fieldsArr here.
return changesetEditor;
changesetEditor.changesetID = function(_) {
- if (!arguments.length) return _changesetID;
- if (_changesetID === _) return changesetEditor;
+ if (!arguments.length) { return _changesetID; }
+ if (_changesetID === _) { return changesetEditor; }
_changesetID = _;
_fieldsArr = null;
return changesetEditor;
_selection = selection;
// Initialize changeset if one does not exist yet.
- if (!context.changeset) initChangeset();
+ if (!context.changeset) { initChangeset(); }
loadDerivedChangesetTags();
function loadDerivedChangesetTags() {
var osm = context.connection();
- if (!osm) return;
+ if (!osm) { return; }
var tags = Object.assign({}, context.changeset.tags); // shallow copy
function render(selection) {
var osm = context.connection();
- if (!osm) return;
+ if (!osm) { return; }
var header = selection.selectAll('.header')
.data([0]);
// always check if this has changed, but only update prose.html()
// if needed, because it can trigger a style recalculation
osm.userDetails(function(err, user) {
- if (err) return;
+ if (err) { return; }
- if (_userDetails === user) return; // no change
+ if (_userDetails === user) { return; } // no change
_userDetails = user;
var userLink = select(document.createElement('div'));
function isReviewRequested(tags) {
var rr = tags.review_requested;
- if (rr === undefined) return false;
+ if (rr === undefined) { return false; }
rr = rr.trim().toLowerCase();
return !(rr === '' || rr === 'no');
}
Object.keys(changed).forEach(function(k) {
var v = changed[k];
k = context.cleanTagKey(k);
- if (readOnlyTags.indexOf(k) !== -1) return;
+ if (readOnlyTags.indexOf(k) !== -1) { return; }
if (k !== '' && v !== undefined) {
if (onInput) {
}
function validateCenter(center) {
- const validCenterLengths = [2, 3];
+ var validCenterLengths = [2, 3];
if (!Array.isArray(center) || !validCenterLengths.includes(center.length)) {
throw new Error("ERROR! Center has to be an array of length two or three");
}
- const [lng, lat] = center;
+ var lng = center[0];
+ var lat = center[1];
if (typeof lng !== "number" || typeof lat !== "number") {
throw new Error(
- `ERROR! Longitude and Latitude has to be numbers but where ${typeof lng} and ${typeof lat}`
+ ("ERROR! Longitude and Latitude has to be numbers but where " + (typeof lng) + " and " + (typeof lat))
);
}
if (lng > 180 || lng < -180) {
throw new Error(
- `ERROR! Longitude has to be between -180 and 180 but was ${lng}`
+ ("ERROR! Longitude has to be between -180 and 180 but was " + lng)
);
}
if (lat > 90 || lat < -90) {
throw new Error(
- `ERROR! Latitude has to be between -90 and 90 but was ${lat}`
+ ("ERROR! Latitude has to be between -90 and 90 but was " + lat)
);
}
}
function validateRadius(radius) {
if (typeof radius !== "number") {
throw new Error(
- `ERROR! Radius has to be a positive number but was: ${typeof radius}`
+ ("ERROR! Radius has to be a positive number but was: " + (typeof radius))
);
}
if (radius <= 0) {
throw new Error(
- `ERROR! Radius has to be a positive number but was: ${radius}`
+ ("ERROR! Radius has to be a positive number but was: " + radius)
);
}
}
function validateNumberOfSegments(numberOfSegments) {
if (typeof numberOfSegments !== "number" && numberOfSegments !== undefined) {
throw new Error(
- `ERROR! Number of segments has to be a number but was: ${typeof numberOfSegments}`
+ ("ERROR! Number of segments has to be a number but was: " + (typeof numberOfSegments))
);
}
if (numberOfSegments < 3) {
throw new Error(
- `ERROR! Number of segments has to be at least 3 but was: ${numberOfSegments}`
+ ("ERROR! Number of segments has to be at least 3 but was: " + numberOfSegments)
);
}
}
- function validateInput({ center, radius, numberOfSegments }) {
+ function validateInput(ref) {
+ var center = ref.center;
+ var radius = ref.radius;
+ var numberOfSegments = ref.numberOfSegments;
+
validateCenter(center);
validateRadius(radius);
validateNumberOfSegments(numberOfSegments);
var n = numberOfSegments ? numberOfSegments : 32;
// validateInput() throws error on invalid input and do nothing on valid input
- validateInput({ center, radius, numberOfSegments });
+ validateInput({ center: center, radius: radius, numberOfSegments: numberOfSegments });
var coordinates = [];
for (var i = 0; i < n; ++i) {
this.stack = (new Error()).stack;
}
- if ( Error ) IllegalArgumentException.__proto__ = Error;
+ if ( Error ) { IllegalArgumentException.__proto__ = Error; }
IllegalArgumentException.prototype = Object.create( Error && Error.prototype );
IllegalArgumentException.prototype.constructor = IllegalArgumentException;
Exception$$1.call(this, 'Projective point not representable on the Cartesian plane.');
}
- if ( Exception$$1 ) NotRepresentableException.__proto__ = Exception$$1;
+ if ( Exception$$1 ) { NotRepresentableException.__proto__ = Exception$$1; }
NotRepresentableException.prototype = Object.create( Exception$$1 && Exception$$1.prototype );
NotRepresentableException.prototype.constructor = NotRepresentableException;
NotRepresentableException.prototype.interfaces_ = function interfaces_ () {
this.stack = (new Error()).stack;
}
- if ( Error ) RuntimeException.__proto__ = Error;
+ if ( Error ) { RuntimeException.__proto__ = Error; }
RuntimeException.prototype = Object.create( Error && Error.prototype );
RuntimeException.prototype.constructor = RuntimeException;
}
}
- if ( RuntimeException$$1 ) AssertionFailedException.__proto__ = RuntimeException$$1;
+ if ( RuntimeException$$1 ) { AssertionFailedException.__proto__ = RuntimeException$$1; }
AssertionFailedException.prototype = Object.create( RuntimeException$$1 && RuntimeException$$1.prototype );
AssertionFailedException.prototype.constructor = AssertionFailedException;
AssertionFailedException.prototype.interfaces_ = function interfaces_ () {
LineIntersector$$1.apply(this, arguments);
}
- if ( LineIntersector$$1 ) RobustLineIntersector.__proto__ = LineIntersector$$1;
+ if ( LineIntersector$$1 ) { RobustLineIntersector.__proto__ = LineIntersector$$1; }
RobustLineIntersector.prototype = Object.create( LineIntersector$$1 && LineIntersector$$1.prototype );
RobustLineIntersector.prototype.constructor = RobustLineIntersector;
Collection$$1.apply(this, arguments);
}
- if ( Collection$$1 ) List.__proto__ = Collection$$1;
+ if ( Collection$$1 ) { List.__proto__ = Collection$$1; }
List.prototype = Object.create( Collection$$1 && Collection$$1.prototype );
List.prototype.constructor = List;
}
}
- if ( List$$1 ) ArrayList.__proto__ = List$$1;
+ if ( List$$1 ) { ArrayList.__proto__ = List$$1; }
ArrayList.prototype = Object.create( List$$1 && List$$1.prototype );
ArrayList.prototype.constructor = ArrayList;
this.position_ = 0;
}
- if ( Iterator$$1 ) Iterator_.__proto__ = Iterator$$1;
+ if ( Iterator$$1 ) { Iterator_.__proto__ = Iterator$$1; }
Iterator_.prototype = Object.create( Iterator$$1 && Iterator$$1.prototype );
Iterator_.prototype.constructor = Iterator_;
}
}
- if ( ArrayList$$1 ) CoordinateList.__proto__ = ArrayList$$1;
+ if ( ArrayList$$1 ) { CoordinateList.__proto__ = ArrayList$$1; }
CoordinateList.prototype = Object.create( ArrayList$$1 && ArrayList$$1.prototype );
CoordinateList.prototype.constructor = CoordinateList;
var SortedMap = (function (Map) {
function SortedMap () {
Map.apply(this, arguments);
- }if ( Map ) SortedMap.__proto__ = Map;
+ }if ( Map ) { SortedMap.__proto__ = Map; }
SortedMap.prototype = Object.create( Map && Map.prototype );
SortedMap.prototype.constructor = SortedMap;
}
}
- if ( Set$$1 ) HashSet.__proto__ = Set$$1;
+ if ( Set$$1 ) { HashSet.__proto__ = Set$$1; }
HashSet.prototype = Object.create( Set$$1 && Set$$1.prototype );
HashSet.prototype.constructor = HashSet;
this.position_ = 0;
}
- if ( Iterator$$1 ) Iterator_.__proto__ = Iterator$$1;
+ if ( Iterator$$1 ) { Iterator_.__proto__ = Iterator$$1; }
Iterator_.prototype = Object.create( Iterator$$1 && Iterator$$1.prototype );
Iterator_.prototype.constructor = Iterator_;
}
}
- if ( Geometry$$1 ) GeometryCollection.__proto__ = Geometry$$1;
+ if ( Geometry$$1 ) { GeometryCollection.__proto__ = Geometry$$1; }
GeometryCollection.prototype = Object.create( Geometry$$1 && Geometry$$1.prototype );
GeometryCollection.prototype.constructor = GeometryCollection;
GeometryCollection$$1.apply(this, arguments);
}
- if ( GeometryCollection$$1 ) MultiLineString.__proto__ = GeometryCollection$$1;
+ if ( GeometryCollection$$1 ) { MultiLineString.__proto__ = GeometryCollection$$1; }
MultiLineString.prototype = Object.create( GeometryCollection$$1 && GeometryCollection$$1.prototype );
MultiLineString.prototype.constructor = MultiLineString;
this.init(points);
}
- if ( Geometry$$1 ) LineString.__proto__ = Geometry$$1;
+ if ( Geometry$$1 ) { LineString.__proto__ = Geometry$$1; }
LineString.prototype = Object.create( Geometry$$1 && Geometry$$1.prototype );
LineString.prototype.constructor = LineString;
this.init(this._coordinates);
}
- if ( Geometry$$1 ) Point.__proto__ = Geometry$$1;
+ if ( Geometry$$1 ) { Point.__proto__ = Geometry$$1; }
Point.prototype = Object.create( Geometry$$1 && Geometry$$1.prototype );
Point.prototype.constructor = Point;
this._holes = holes;
}
- if ( Geometry$$1 ) Polygon.__proto__ = Geometry$$1;
+ if ( Geometry$$1 ) { Polygon.__proto__ = Geometry$$1; }
Polygon.prototype = Object.create( Geometry$$1 && Geometry$$1.prototype );
Polygon.prototype.constructor = Polygon;
GeometryCollection$$1.apply(this, arguments);
}
- if ( GeometryCollection$$1 ) MultiPoint.__proto__ = GeometryCollection$$1;
+ if ( GeometryCollection$$1 ) { MultiPoint.__proto__ = GeometryCollection$$1; }
MultiPoint.prototype = Object.create( GeometryCollection$$1 && GeometryCollection$$1.prototype );
MultiPoint.prototype.constructor = MultiPoint;
this.validateConstruction();
}
- if ( LineString$$1 ) LinearRing.__proto__ = LineString$$1;
+ if ( LineString$$1 ) { LinearRing.__proto__ = LineString$$1; }
LinearRing.prototype = Object.create( LineString$$1 && LineString$$1.prototype );
LinearRing.prototype.constructor = LinearRing;
GeometryCollection$$1.apply(this, arguments);
}
- if ( GeometryCollection$$1 ) MultiPolygon.__proto__ = GeometryCollection$$1;
+ if ( GeometryCollection$$1 ) { MultiPolygon.__proto__ = GeometryCollection$$1; }
MultiPolygon.prototype = Object.create( GeometryCollection$$1 && GeometryCollection$$1.prototype );
MultiPolygon.prototype.constructor = MultiPolygon;
this.map_ = new Map();
}
- if ( MapInterface ) HashMap.__proto__ = MapInterface;
+ if ( MapInterface ) { HashMap.__proto__ = MapInterface; }
HashMap.prototype = Object.create( MapInterface && MapInterface.prototype );
HashMap.prototype.constructor = HashMap;
/**
this.name = 'TopologyException';
}
- if ( RuntimeException$$1 ) TopologyException.__proto__ = RuntimeException$$1;
+ if ( RuntimeException$$1 ) { TopologyException.__proto__ = RuntimeException$$1; }
TopologyException.prototype = Object.create( RuntimeException$$1 && RuntimeException$$1.prototype );
TopologyException.prototype.constructor = TopologyException;
TopologyException.prototype.getCoordinate = function getCoordinate () {
EdgeRing$$1.call(this, start, geometryFactory);
}
- if ( EdgeRing$$1 ) MinimalEdgeRing.__proto__ = EdgeRing$$1;
+ if ( EdgeRing$$1 ) { MinimalEdgeRing.__proto__ = EdgeRing$$1; }
MinimalEdgeRing.prototype = Object.create( EdgeRing$$1 && EdgeRing$$1.prototype );
MinimalEdgeRing.prototype.constructor = MinimalEdgeRing;
MinimalEdgeRing.prototype.setEdgeRing = function setEdgeRing (de, er) {
EdgeRing$$1.call(this, start, geometryFactory);
}
- if ( EdgeRing$$1 ) MaximalEdgeRing.__proto__ = EdgeRing$$1;
+ if ( EdgeRing$$1 ) { MaximalEdgeRing.__proto__ = EdgeRing$$1; }
MaximalEdgeRing.prototype = Object.create( EdgeRing$$1 && EdgeRing$$1.prototype );
MaximalEdgeRing.prototype.constructor = MaximalEdgeRing;
MaximalEdgeRing.prototype.buildMinimalRings = function buildMinimalRings () {
this._label = new Label(0, Location.NONE);
}
- if ( GraphComponent$$1 ) Node.__proto__ = GraphComponent$$1;
+ if ( GraphComponent$$1 ) { Node.__proto__ = GraphComponent$$1; }
Node.prototype = Object.create( GraphComponent$$1 && GraphComponent$$1.prototype );
Node.prototype.constructor = Node;
Node.prototype.isIncidentEdgeInResult = function isIncidentEdgeInResult () {
this.computeDirectedLabel();
}
- if ( EdgeEnd$$1 ) DirectedEdge.__proto__ = EdgeEnd$$1;
+ if ( EdgeEnd$$1 ) { DirectedEdge.__proto__ = EdgeEnd$$1; }
DirectedEdge.prototype = Object.create( EdgeEnd$$1 && EdgeEnd$$1.prototype );
DirectedEdge.prototype.constructor = DirectedEdge;
DirectedEdge.prototype.getNextMin = function getNextMin () {
AbstractSTRtree$$1.call(this, nodeCapacity);
}
- if ( AbstractSTRtree$$1 ) STRtree.__proto__ = AbstractSTRtree$$1;
+ if ( AbstractSTRtree$$1 ) { STRtree.__proto__ = AbstractSTRtree$$1; }
STRtree.prototype = Object.create( AbstractSTRtree$$1 && AbstractSTRtree$$1.prototype );
STRtree.prototype.constructor = STRtree;
AbstractNode$$1.call(this, level);
}
- if ( AbstractNode$$1 ) STRtreeNode.__proto__ = AbstractNode$$1;
+ if ( AbstractNode$$1 ) { STRtreeNode.__proto__ = AbstractNode$$1; }
STRtreeNode.prototype = Object.create( AbstractNode$$1 && AbstractNode$$1.prototype );
STRtreeNode.prototype.constructor = STRtreeNode;
STRtreeNode.prototype.computeBounds = function computeBounds () {
this._nOverlaps = 0;
}
- if ( SinglePassNoder$$1 ) MCIndexNoder.__proto__ = SinglePassNoder$$1;
+ if ( SinglePassNoder$$1 ) { MCIndexNoder.__proto__ = SinglePassNoder$$1; }
MCIndexNoder.prototype = Object.create( SinglePassNoder$$1 && SinglePassNoder$$1.prototype );
MCIndexNoder.prototype.constructor = MCIndexNoder;
this._si = si;
}
- if ( MonotoneChainOverlapAction$$1 ) SegmentOverlapAction.__proto__ = MonotoneChainOverlapAction$$1;
+ if ( MonotoneChainOverlapAction$$1 ) { SegmentOverlapAction.__proto__ = MonotoneChainOverlapAction$$1; }
SegmentOverlapAction.prototype = Object.create( MonotoneChainOverlapAction$$1 && MonotoneChainOverlapAction$$1.prototype );
SegmentOverlapAction.prototype.constructor = SegmentOverlapAction;
SegmentOverlapAction.prototype.overlap = function overlap () {
this._LINKING_TO_OUTGOING = 2;
}
- if ( EdgeEndStar$$1 ) DirectedEdgeStar.__proto__ = EdgeEndStar$$1;
+ if ( EdgeEndStar$$1 ) { DirectedEdgeStar.__proto__ = EdgeEndStar$$1; }
DirectedEdgeStar.prototype = Object.create( EdgeEndStar$$1 && EdgeEndStar$$1.prototype );
DirectedEdgeStar.prototype.constructor = DirectedEdgeStar;
DirectedEdgeStar.prototype.linkResultDirectedEdges = function linkResultDirectedEdges () {
NodeFactory$$1.apply(this, arguments);
}
- if ( NodeFactory$$1 ) OverlayNodeFactory.__proto__ = NodeFactory$$1;
+ if ( NodeFactory$$1 ) { OverlayNodeFactory.__proto__ = NodeFactory$$1; }
OverlayNodeFactory.prototype = Object.create( NodeFactory$$1 && NodeFactory$$1.prototype );
OverlayNodeFactory.prototype.constructor = OverlayNodeFactory;
}
}
- if ( GraphComponent$$1 ) Edge.__proto__ = GraphComponent$$1;
+ if ( GraphComponent$$1 ) { Edge.__proto__ = GraphComponent$$1; }
Edge.prototype = Object.create( GraphComponent$$1 && GraphComponent$$1.prototype );
Edge.prototype.constructor = Edge;
Edge.prototype.getDepth = function getDepth () {
this._hotPixelVertexIndex = hotPixelVertexIndex;
}
- if ( MonotoneChainSelectAction$$1 ) HotPixelSnapAction.__proto__ = MonotoneChainSelectAction$$1;
+ if ( MonotoneChainSelectAction$$1 ) { HotPixelSnapAction.__proto__ = MonotoneChainSelectAction$$1; }
HotPixelSnapAction.prototype = Object.create( MonotoneChainSelectAction$$1 && MonotoneChainSelectAction$$1.prototype );
HotPixelSnapAction.prototype.constructor = HotPixelSnapAction;
HotPixelSnapAction.prototype.isNodeAdded = function isNodeAdded () {
this._isSelfSnap = (isSelfSnap !== undefined) ? isSelfSnap : false;
}
- if ( GeometryTransformer$$1 ) SnapTransformer.__proto__ = GeometryTransformer$$1;
+ if ( GeometryTransformer$$1 ) { SnapTransformer.__proto__ = GeometryTransformer$$1; }
SnapTransformer.prototype = Object.create( GeometryTransformer$$1 && GeometryTransformer$$1.prototype );
SnapTransformer.prototype.constructor = SnapTransformer;
SnapTransformer.prototype.snapLine = function snapLine (srcPts, snapPts) {
if (!isSuccess) {
try {
result = SnapOverlayOp.overlayOp(this._geom[0], this._geom[1], opCode);
- } catch (ex) {
- if (ex instanceof RuntimeException) {
+ } catch (ex$1) {
+ if (ex$1 instanceof RuntimeException) {
throw savedException
- } else { throw ex }
+ } else { throw ex$1 }
} finally {}
}
return result
this.nOverlaps = null;
}
- if ( EdgeSetIntersector$$1 ) SimpleMCSweepLineIntersector.__proto__ = EdgeSetIntersector$$1;
+ if ( EdgeSetIntersector$$1 ) { SimpleMCSweepLineIntersector.__proto__ = EdgeSetIntersector$$1; }
SimpleMCSweepLineIntersector.prototype = Object.create( EdgeSetIntersector$$1 && EdgeSetIntersector$$1.prototype );
SimpleMCSweepLineIntersector.prototype.constructor = SimpleMCSweepLineIntersector;
SimpleMCSweepLineIntersector.prototype.prepareEvents = function prepareEvents () {
this._item = item;
}
- if ( IntervalRTreeNode$$1 ) IntervalRTreeLeafNode.__proto__ = IntervalRTreeNode$$1;
+ if ( IntervalRTreeNode$$1 ) { IntervalRTreeLeafNode.__proto__ = IntervalRTreeNode$$1; }
IntervalRTreeLeafNode.prototype = Object.create( IntervalRTreeNode$$1 && IntervalRTreeNode$$1.prototype );
IntervalRTreeLeafNode.prototype.constructor = IntervalRTreeLeafNode;
IntervalRTreeLeafNode.prototype.query = function query (queryMin, queryMax, visitor) {
this.buildExtent(this._node1, this._node2);
}
- if ( IntervalRTreeNode$$1 ) IntervalRTreeBranchNode.__proto__ = IntervalRTreeNode$$1;
+ if ( IntervalRTreeNode$$1 ) { IntervalRTreeBranchNode.__proto__ = IntervalRTreeNode$$1; }
IntervalRTreeBranchNode.prototype = Object.create( IntervalRTreeNode$$1 && IntervalRTreeNode$$1.prototype );
IntervalRTreeBranchNode.prototype.constructor = IntervalRTreeBranchNode;
IntervalRTreeBranchNode.prototype.buildExtent = function buildExtent (n1, n2) {
}
}
- if ( PlanarGraph$$1 ) GeometryGraph.__proto__ = PlanarGraph$$1;
+ if ( PlanarGraph$$1 ) { GeometryGraph.__proto__ = PlanarGraph$$1; }
GeometryGraph.prototype = Object.create( PlanarGraph$$1 && PlanarGraph$$1.prototype );
GeometryGraph.prototype.constructor = GeometryGraph;
GeometryGraph.prototype.insertBoundaryPoint = function insertBoundaryPoint (argIndex, coord) {
this._geomFact = g0.getFactory();
}
- if ( GeometryGraphOp ) OverlayOp.__proto__ = GeometryGraphOp;
+ if ( GeometryGraphOp ) { OverlayOp.__proto__ = GeometryGraphOp; }
OverlayOp.prototype = Object.create( GeometryGraphOp && GeometryGraphOp.prototype );
OverlayOp.prototype.constructor = OverlayOp;
OverlayOp.prototype.insertUniqueEdge = function insertUniqueEdge (e) {
function feature$1(geometry, properties, options) {
// Optional Parameters
options = options || {};
- if (!isObject$4(options)) throw new Error('options is invalid');
+ if (!isObject$4(options)) { throw new Error('options is invalid'); }
var bbox = options.bbox;
var id = options.id;
// Validation
- if (geometry === undefined) throw new Error('geometry is required');
- if (properties && properties.constructor !== Object) throw new Error('properties must be an Object');
- if (bbox) validateBBox(bbox);
- if (id) validateId(id);
+ if (geometry === undefined) { throw new Error('geometry is required'); }
+ if (properties && properties.constructor !== Object) { throw new Error('properties must be an Object'); }
+ if (bbox) { validateBBox(bbox); }
+ if (id) { validateId(id); }
// Main
var feat = {type: 'Feature'};
- if (id) feat.id = id;
- if (bbox) feat.bbox = bbox;
+ if (id) { feat.id = id; }
+ if (bbox) { feat.bbox = bbox; }
feat.properties = properties || {};
feat.geometry = geometry;
return feat;
* //=Error
*/
function validateBBox(bbox) {
- if (!bbox) throw new Error('bbox is required');
- if (!Array.isArray(bbox)) throw new Error('bbox must be an Array');
- if (bbox.length !== 4 && bbox.length !== 6) throw new Error('bbox must be an Array of 4 or 6 numbers');
+ if (!bbox) { throw new Error('bbox is required'); }
+ if (!Array.isArray(bbox)) { throw new Error('bbox must be an Array'); }
+ if (bbox.length !== 4 && bbox.length !== 6) { throw new Error('bbox must be an Array of 4 or 6 numbers'); }
bbox.forEach(function (num) {
- if (!isNumber$1(num)) throw new Error('bbox must only contain numbers');
+ if (!isNumber$1(num)) { throw new Error('bbox must only contain numbers'); }
});
}
* //=Error
*/
function validateId(id) {
- if (!id) throw new Error('id is required');
- if (['string', 'number'].indexOf(typeof id) === -1) throw new Error('id must be a number or a string');
+ if (!id) { throw new Error('id is required'); }
+ if (['string', 'number'].indexOf(typeof id) === -1) { throw new Error('id must be a number or a string'); }
}
/**
// Handle null Geometry
if (geometry === null) {
- if (callback(null, featureIndex, featureProperties, featureBBox, featureId) === false) return false;
+ if (callback(null, featureIndex, featureProperties, featureBBox, featureId) === false) { return false; }
continue;
}
switch (geometry.type) {
case 'Polygon':
case 'MultiLineString':
case 'MultiPolygon': {
- if (callback(geometry, featureIndex, featureProperties, featureBBox, featureId) === false) return false;
+ if (callback(geometry, featureIndex, featureProperties, featureBBox, featureId) === false) { return false; }
break;
}
case 'GeometryCollection': {
for (j = 0; j < geometry.geometries.length; j++) {
- if (callback(geometry.geometries[j], featureIndex, featureProperties, featureBBox, featureId) === false) return false;
+ if (callback(geometry.geometries[j], featureIndex, featureProperties, featureBBox, featureId) === false) { return false; }
}
break;
}
function geomReduce(geojson, callback, initialValue) {
var previousValue = initialValue;
geomEach(geojson, function (currentGeometry, featureIndex, featureProperties, featureBBox, featureId) {
- if (featureIndex === 0 && initialValue === undefined) previousValue = currentGeometry;
- else previousValue = callback(previousValue, currentGeometry, featureIndex, featureProperties, featureBBox, featureId);
+ if (featureIndex === 0 && initialValue === undefined) { previousValue = currentGeometry; }
+ else { previousValue = callback(previousValue, currentGeometry, featureIndex, featureProperties, featureBBox, featureId); }
});
return previousValue;
}
case 'Point':
case 'LineString':
case 'Polygon':
- if (callback(feature$1(geometry, properties, {bbox: bbox, id: id}), featureIndex, 0) === false) return false;
+ if (callback(feature$1(geometry, properties, {bbox: bbox, id: id}), featureIndex, 0) === false) { return false; }
return;
}
type: geomType,
coordinates: coordinate
};
- if (callback(feature$1(geom, properties), featureIndex, multiFeatureIndex) === false) return false;
+ if (callback(feature$1(geom, properties), featureIndex, multiFeatureIndex) === false) { return false; }
}
});
}
* //={"type": "Point", "coordinates": [110, 40]}
*/
function getGeom(geojson) {
- if (!geojson) throw new Error('geojson is required');
- if (geojson.geometry !== undefined) return geojson.geometry;
- if (geojson.coordinates || geojson.geometries) return geojson;
+ if (!geojson) { throw new Error('geojson is required'); }
+ if (geojson.geometry !== undefined) { return geojson.geometry; }
+ if (geojson.coordinates || geojson.geometries) { return geojson; }
throw new Error('geojson must be a valid Feature or Geometry Object');
}
// Issue #721 - JSTS can't handle empty polygons
geom1 = removeEmptyPolygon(geom1);
geom2 = removeEmptyPolygon(geom2);
- if (!geom1) return null;
- if (!geom2) return feature$1(geom1, properties);
+ if (!geom1) { return null; }
+ if (!geom2) { return feature$1(geom1, properties); }
// JSTS difference operation
var reader = new GeoJSONReader();
var a = reader.read(geom1);
var b = reader.read(geom2);
var differenced = OverlayOp.difference(a, b);
- if (differenced.isEmpty()) return null;
+ if (differenced.isEmpty()) { return null; }
var writer = new GeoJSONWriter();
var geom = writer.write(differenced);
function removeEmptyPolygon(geom) {
switch (geom.type) {
case 'Polygon':
- if (area(geom) > 1) return geom;
+ if (area(geom) > 1) { return geom; }
return null;
case 'MultiPolygon':
var coordinates = [];
flattenEach(geom, function (feature$$1) {
- if (area(feature$$1) > 1) coordinates.push(feature$$1.geometry.coordinates);
+ if (area(feature$$1) > 1) { coordinates.push(feature$$1.geometry.coordinates); }
});
- if (coordinates.length) return {type: 'MultiPolygon', coordinates: coordinates};
+ if (coordinates.length) { return {type: 'MultiPolygon', coordinates: coordinates}; }
}
}
* var addToMap = [poly1, poly2, union];
*/
function union$1() {
+ var arguments$1 = arguments;
+
var reader = new GeoJSONReader();
var result = reader.read(JSON.stringify(arguments[0].geometry));
for (var i = 1; i < arguments.length; i++) {
- result = UnionOp.union(result, reader.read(JSON.stringify(arguments[i].geometry)));
+ result = UnionOp.union(result, reader.read(JSON.stringify(arguments$1[i].geometry)));
}
var writer = new GeoJSONWriter();
// Reduce an array of locations into a single GeoJSON feature
function _locationReducer(accumulator, location) {
/* eslint-disable no-console, no-invalid-this */
- let result;
+ var result;
try {
- let resolved = this.resolveLocation(location);
+ var resolved = this.resolveLocation(location);
if (!resolved || !resolved.feature) {
- console.warn(`Warning: Couldn't resolve location "${location}"`);
+ console.warn(("Warning: Couldn't resolve location \"" + location + "\""));
return accumulator;
}
result = !accumulator ? resolved.feature : union$1(accumulator, resolved.feature);
} catch (e) {
- console.warn(`Warning: Error resolving location "${location}"`);
+ console.warn(("Warning: Error resolving location \"" + location + "\""));
console.warn(e);
result = accumulator;
}
}
- class LocationConflation {
-
- // constructor
- //
- // Optionally pass a GeoJSON FeatureCollection of known features which we can refer to later.
- // Each feature must have a filename-like `id`, for example: `something.geojson`
- //
- // {
- // "type": "FeatureCollection"
- // "features": [
- // {
- // "type": "Feature",
- // "id": "philly_metro.geojson",
- // "properties": { … },
- // "geometry": { … }
- // }
- // ]
- // }
- constructor(fc) {
- this._cache = {};
+ var defaultExport = function defaultExport(fc) {
+ var this$1 = this;
- // process input FeatureCollection
- if (fc && fc.type === 'FeatureCollection' && Array.isArray(fc.features)) {
- fc.features.forEach(feature => {
- feature.properties = feature.properties || {};
- let props = feature.properties;
+ this._cache = {};
- // get `id` from either `id` or `properties`
- let id = feature.id || props.id;
- if (!id || !/^\S+\.geojson$/i.test(id)) return;
+ // process input FeatureCollection
+ if (fc && fc.type === 'FeatureCollection' && Array.isArray(fc.features)) {
+ fc.features.forEach(function (feature) {
+ feature.properties = feature.properties || {};
+ var props = feature.properties;
- // ensure id exists and is lowercase
- id = id.toLowerCase();
- feature.id = id;
- props.id = id;
+ // get `id` from either `id` or `properties`
+ var id = feature.id || props.id;
+ if (!id || !/^\S+\.geojson$/i.test(id)) { return; }
- // ensure area property exists
- if (!props.area) {
- const area = geojsonArea.geometry(feature.geometry) / 1e6; // m² to km²
- props.area = Number(area.toFixed(2));
- }
+ // ensure id exists and is lowercase
+ id = id.toLowerCase();
+ feature.id = id;
+ props.id = id;
- this._cache[id] = feature;
- });
- }
+ // ensure area property exists
+ if (!props.area) {
+ var area = geojsonArea.geometry(feature.geometry) / 1e6;// m² to km²
+ props.area = Number(area.toFixed(2));
+ }
- // Replace CountryCoder world geometry to have a polygon covering the world.
- let world = _cloneDeep(feature('Q2'));
- world.geometry = {
- type: 'Polygon',
- coordinates: [[[-180, -90], [180, -90], [180, 90], [-180, 90], [-180, -90]]]
- };
- world.id = 'Q2';
- world.properties.id = 'Q2';
- world.properties.area = geojsonArea.geometry(world.geometry) / 1e6; // m² to km²
- this._cache.Q2 = world;
+ this$1._cache[id] = feature;
+ });
}
+ // Replace CountryCoder world geometry to have a polygon covering the world.
+ var world = _cloneDeep(feature('Q2'));
+ world.geometry = {
+ type: 'Polygon',
+ coordinates: [[[-180, -90], [180, -90], [180, 90], [-180, 90], [-180, -90]]]
+ };
+ world.id = 'Q2';
+ world.properties.id = 'Q2';
+ world.properties.area = geojsonArea.geometry(world.geometry) / 1e6;// m² to km²
+ this._cache.Q2 = world;
+ };
- // validateLocation
- //
- // Pass a `location` identifier
- // Returns a result like
- // {
- // type: 'point', 'geojson', or 'countrycoder'
- // location: the queried location
- // id: a unique identifier
- // }
- // or `null` if the location is invalid
- //
- validateLocation(location) {
- if (Array.isArray(location)) { // a [lon,lat] coordinate pair?
- if (location.length === 2 && Number.isFinite(location[0]) && Number.isFinite(location[1]) &&
- location[0] >= -180 && location[0] <= 180 && location[1] >= -90 && location[1] <= 90
- ) {
- const id = '[' + location.toString() + ']';
- return { type: 'point', location: location, id: id };
- }
- } else if (typeof location === 'string' && /^\S+\.geojson$/i.test(location)) { // a .geojson filename?
- const id = location.toLowerCase();
- if (this._cache[id]) {
- return { type: 'geojson', location: location, id: id };
- }
+ // validateLocation
+ //
+ // Pass a `location` identifier
+ // Returns a result like
+ // {
+ // type: 'point', 'geojson', or 'countrycoder'
+ // location:the queried location
+ // id: a unique identifier
+ // }
+ //or `null` if the location is invalid
+ //
+ defaultExport.prototype.validateLocation = function validateLocation (location) {
+ if (Array.isArray(location)) { // a [lon,lat] coordinate pair?
+ if (location.length === 2 && Number.isFinite(location[0]) && Number.isFinite(location[1]) &&
+ location[0] >= -180 && location[0] <= 180 && location[1] >= -90 && location[1] <= 90
+ ) {
+ var id = '[' + location.toString() + ']';
+ return { type: 'point', location: location, id: id };
+ }
- } else if (typeof location === 'string' || typeof location === 'number') { // a country-coder value?
- const feature$1 = feature(location);
- if (feature$1) {
- // Use wikidata QID as the identifier, since that seems to be the only
- // property that everything in CountryCoder is guaranteed to have.
- const id = feature$1.properties.wikidata;
- return { type: 'countrycoder', location: location, id: id };
- }
+ } else if (typeof location === 'string' && /^\S+\.geojson$/i.test(location)) { // a .geojson filename?
+ var id$1 = location.toLowerCase();
+ if (this._cache[id$1]) {
+ return { type: 'geojson', location: location, id: id$1 };
}
- return null;
+ } else if (typeof location === 'string' || typeof location === 'number') { // a country-coder value?
+ var feature$1 = feature(location);
+ if (feature$1) {
+ // Use wikidata QID as the identifier, since that seems to be the only
+ // property that everything in CountryCoder is guaranteed to have.
+ var id$2 = feature$1.properties.wikidata;
+ return { type: 'countrycoder', location: location, id: id$2 };
+ }
}
+ return null;
+ };
- // resolveLocation
- //
- // Pass a `location` identifier
- // Returns a result like
- // {
- // type: 'point', 'geojson', or 'countrycoder'
- // location: the queried location
- // id: a unique identifier
- // feature: the geojson feature
- // }
- // or `null` if the location is invalid
- //
- resolveLocation(location) {
- const valid = this.validateLocation(location);
- if (!valid) return null;
-
- // return a result from cache if we can
- if (this._cache[valid.id]) {
- return Object.assign(valid, { feature: this._cache[valid.id] });
- }
-
- // a [lon,lat] coordinate pair?
- if (valid.type === 'point') {
- const RADIUS = 25000; // meters
- const EDGES = 10;
- const PRECISION = 3;
- const area = Math.PI * RADIUS * RADIUS / 1e6; // m² to km²
- const feature = this._cache[valid.id] = geojsonPrecision({
- type: 'Feature',
- id: valid.id,
- properties: { id: valid.id, area: Number(area.toFixed(2)) },
- geometry: circleToPolygon(location, RADIUS, EDGES)
- }, PRECISION);
- return Object.assign(valid, { feature: feature });
-
- // a .geojson filename?
- } else if (valid.type === 'geojson') ; else if (valid.type === 'countrycoder') {
- let feature$1 = _cloneDeep(feature(valid.id));
- let props = feature$1.properties;
-
- // -> This block of code is weird and requires some explanation. <-
- // CountryCoder includes higher level features which are made up of members.
- // These features don't have their own geometry, but CountryCoder provides an
- // `aggregateFeature` method to combine these members into a MultiPolygon.
- // BUT, when we try to actually work with these aggregated MultiPolygons,
- // Turf/JSTS gets crashy because of topography bugs.
- // SO, we'll aggregate the features ourselves by unioning them together.
- // This approach also has the benefit of removing all the internal boaders and
- // simplifying the regional polygons a lot.
- if (Array.isArray(props.members)) {
- let seed = feature$1.geometry ? feature$1 : null;
- let aggregate = props.members.reduce(_locationReducer.bind(this), seed);
- feature$1.geometry = aggregate.geometry;
- }
-
- // ensure area property exists
- if (!props.area) {
- const area = geojsonArea.geometry(feature$1.geometry) / 1e6; // m² to km²
- props.area = Number(area.toFixed(2));
- }
-
- // ensure id property exists
- feature$1.id = valid.id;
- props.id = valid.id;
-
- this._cache[valid.id] = feature$1;
- return Object.assign(valid, { feature: feature$1 });
- }
- return null;
+ // resolveLocation
+ //
+ // Pass a `location` identifier
+ // Returns a result like
+ // {
+ // type: 'point', 'geojson', or 'countrycoder'
+ // location:the queried location
+ // id: a unique identifier
+ // feature: the geojson feature
+ // }
+ //or `null` if the location is invalid
+ //
+ defaultExport.prototype.resolveLocation = function resolveLocation (location) {
+ var valid = this.validateLocation(location);
+ if (!valid) { return null; }
+
+ // return a result from cache if we can
+ if (this._cache[valid.id]) {
+ return Object.assign(valid, { feature: this._cache[valid.id] });
+ }
+
+ // a [lon,lat] coordinate pair?
+ if (valid.type === 'point') {
+ var RADIUS = 25000;// meters
+ var EDGES = 10;
+ var PRECISION = 3;
+ var area = Math.PI * RADIUS * RADIUS / 1e6; // m² to km²
+ var feature$1 = this._cache[valid.id] = geojsonPrecision({
+ type: 'Feature',
+ id: valid.id,
+ properties: { id: valid.id, area: Number(area.toFixed(2)) },
+ geometry: circleToPolygon(location, RADIUS, EDGES)
+ }, PRECISION);
+ return Object.assign(valid, { feature: feature$1 });
+
+ // a .geojson filename?
+ } else if (valid.type === 'geojson') ; else if (valid.type === 'countrycoder') {
+ var feature$1$1 = _cloneDeep(feature(valid.id));
+ var props = feature$1$1.properties;
+
+ // -> This block of code is weird and requires some explanation. <-
+ // CountryCoder includes higher level features which are made up of members.
+ // These features don't have their own geometry, but CountryCoder provides an
+ // `aggregateFeature` method to combine these members into a MultiPolygon.
+ // BUT, when we try to actually work with these aggregated MultiPolygons,
+ // Turf/JSTS gets crashy because of topography bugs.
+ // SO, we'll aggregate the features ourselves by unioning them together.
+ // This approach also has the benefit of removing all the internal boaders and
+ // simplifying the regional polygons a lot.
+ if (Array.isArray(props.members)) {
+ var seed = feature$1$1.geometry ? feature$1$1 : null;
+ var aggregate = props.members.reduce(_locationReducer.bind(this), seed);
+ feature$1$1.geometry = aggregate.geometry;
+ }
+
+ // ensure area property exists
+ if (!props.area) {
+ var area$1 = geojsonArea.geometry(feature$1$1.geometry) / 1e6;// m² to km²
+ props.area = Number(area$1.toFixed(2));
+ }
+
+ // ensure id property exists
+ feature$1$1.id = valid.id;
+ props.id = valid.id;
+
+ this._cache[valid.id] = feature$1$1;
+ return Object.assign(valid, { feature: feature$1$1 });
}
+ return null;
+ };
- // resolveLocationSet
- //
- // Pass a `locationSet` Object like:
- // `{ include: [ Array ], exclude: [ Array ] }`
- // Returns a stable identifier string of the form:
- // "+[included]-[excluded]"
- //
- resolveLocationSet(locationSet) {
- locationSet = locationSet || {};
- const resolve = this.resolveLocation.bind(this);
- let include = (locationSet.include || []).map(resolve).filter(Boolean);
- let exclude = (locationSet.exclude || []).map(resolve).filter(Boolean);
- if (!include.length) {
- include = [resolve('Q2')]; // default to 'the world'
- }
+ // resolveLocationSet
+ //
+ // Pass a `locationSet` Object like:
+ // `{ include: [ Array ], exclude: [ Array ] }`
+ // Returns a stable identifier string of the form:
+ // "+[included]-[excluded]"
+ //
+ defaultExport.prototype.resolveLocationSet = function resolveLocationSet (locationSet) {
+ locationSet = locationSet || {};
+ var resolve = this.resolveLocation.bind(this);
+ var include = (locationSet.include || []).map(resolve).filter(Boolean);
+ var exclude = (locationSet.exclude || []).map(resolve).filter(Boolean);
- // return quickly if it's a single included location..
- if (include.length === 1 && exclude.length === 0) {
- return include[0].feature;
- }
+ if (!include.length) {
+ include = [resolve('Q2')]; // default to 'the world'
+ }
- // generate stable identifier
- include.sort(sortFeatures);
- let id = '+[' + include.map(d => d.id).join(',') + ']';
- if (exclude.length) {
- exclude.sort(sortFeatures);
- id += '-[' + exclude.map(d => d.id).join(',') + ']';
- }
+ // return quickly if it's a single included location..
+ if (include.length === 1 && exclude.length === 0) {
+ return include[0].feature;
+ }
- // return cached?
- if (this._cache[id]) {
- return this._cache[id];
- }
+ // generate stable identifier
+ include.sort(sortFeatures);
+ var id = '+[' + include.map(function (d) { return d.id; }).join(',') + ']';
+ if (exclude.length) {
+ exclude.sort(sortFeatures);
+ id += '-[' + exclude.map(function (d) { return d.id; }).join(',') + ']';
+ }
- // calculate unions
- let includeGeoJSON = include.map(d => d.location).reduce(_locationReducer.bind(this), null);
- let excludeGeoJSON = exclude.map(d => d.location).reduce(_locationReducer.bind(this), null);
+ // return cached?
+ if (this._cache[id]) {
+ return this._cache[id];
+ }
- // calculate difference, update area and return result
- let resultGeoJSON = excludeGeoJSON ? difference(includeGeoJSON, excludeGeoJSON) : includeGeoJSON;
- const area = geojsonArea.geometry(resultGeoJSON.geometry) / 1e6; // m² to km²
- resultGeoJSON.id = id;
- resultGeoJSON.properties = { id: id, area: Number(area.toFixed(2)) };
+ // calculate unions
+ var includeGeoJSON = include.map(function (d) { return d.location; }).reduce(_locationReducer.bind(this), null);
+ var excludeGeoJSON = exclude.map(function (d) { return d.location; }).reduce(_locationReducer.bind(this), null);
- return this._cache[id] = resultGeoJSON;
+ // calculate difference, update area and return result
+ var resultGeoJSON = excludeGeoJSON ? difference(includeGeoJSON, excludeGeoJSON) : includeGeoJSON;
+ var area = geojsonArea.geometry(resultGeoJSON.geometry) / 1e6;// m² to km²
+ resultGeoJSON.id = id;
+ resultGeoJSON.properties = { id: id, area: Number(area.toFixed(2)) };
+ return this._cache[id] = resultGeoJSON;
- // Sorting the location lists is ok because they end up unioned together.
- // This sorting makes it possible to generate a deterministic id.
- function sortFeatures(a, b) {
- const rank = { countrycoder: 1, geojson: 2, point: 3 };
- const aRank = rank[a.type];
- const bRank = rank[b.type];
- return (aRank > bRank) ? 1
- : (aRank < bRank) ? -1
- : a.id.localeCompare(b.id);
- }
+ // Sorting the location lists is ok because they end up unioned together.
+ // This sorting makes it possible to generate a deterministic id.
+ function sortFeatures(a, b) {
+ var rank = { countrycoder: 1, geojson: 2, point: 3 };
+ var aRank = rank[a.type];
+ var bRank = rank[b.type];
+
+ return (aRank > bRank) ? 1
+ : (aRank < bRank) ? -1
+ : a.id.localeCompare(b.id);
}
+ };
- cache() {
- return this._cache;
- }
- }
+ defaultExport.prototype.cache = function cache () {
+ return this._cache;
+ };
- let _oci = null;
+ var _oci = null;
function uiSuccess(context) {
- const MAXEVENTS = 2;
- const dispatch$1 = dispatch('cancel');
- let _changeset;
- let _location;
+ var MAXEVENTS = 2;
+ var dispatch$1 = dispatch('cancel');
+ var _changeset;
+ var _location;
ensureOSMCommunityIndex(); // start fetching the data
function ensureOSMCommunityIndex() {
- const data = _mainFileFetcher;
+ var data = _mainFileFetcher;
return Promise.all([ data.get('oci_resources'), data.get('oci_features') ])
- .then(vals => {
- if (_oci) return _oci;
+ .then(function (vals) {
+ if (_oci) { return _oci; }
- const ociResources = vals[0].resources;
- const loco = new LocationConflation(vals[1]);
- let ociFeatures = {};
+ var ociResources = vals[0].resources;
+ var loco = new defaultExport(vals[1]);
+ var ociFeatures = {};
- Object.values(ociResources).forEach(resource => {
- const feature = loco.resolveLocationSet(resource.locationSet);
- let ociFeature = ociFeatures[feature.id];
+ Object.values(ociResources).forEach(function (resource) {
+ var feature = loco.resolveLocationSet(resource.locationSet);
+ var ociFeature = ociFeatures[feature.id];
if (!ociFeature) {
ociFeature = JSON.parse(JSON.stringify(feature)); // deep clone
ociFeature.properties.resourceIDs = new Set();
// string-to-date parsing in JavaScript is weird
function parseEventDate(when) {
- if (!when) return;
+ if (!when) { return; }
- let raw = when.trim();
- if (!raw) return;
+ var raw = when.trim();
+ if (!raw) { return; }
if (!/Z$/.test(raw)) { // if no trailing 'Z', add one
raw += 'Z'; // this forces date to be parsed as a UTC date
}
- const parsed = new Date(raw);
+ var parsed = new Date(raw);
return new Date(parsed.toUTCString().substr(0, 25)); // convert to local timezone
}
function success(selection) {
- let header = selection
+ var header = selection
.append('div')
.attr('class', 'header fillL');
header
.append('button')
.attr('class', 'close')
- .on('click', () => dispatch$1.call('cancel'))
+ .on('click', function () { return dispatch$1.call('cancel'); })
.call(svgIcon('#iD-icon-close'));
- let body = selection
+ var body = selection
.append('div')
.attr('class', 'body save-success fillL');
- let summary = body
+ var summary = body
.append('div')
.attr('class', 'save-summary');
.append('span')
.text(_t('success.help_link_text'));
- let osm = context.connection();
- if (!osm) return;
+ var osm = context.connection();
+ if (!osm) { return; }
- let changesetURL = osm.changesetURL(_changeset.id);
+ var changesetURL = osm.changesetURL(_changeset.id);
- let table = summary
+ var table = summary
.append('table')
.attr('class', 'summary-table');
- let row = table
+ var row = table
.append('tr')
.attr('class', 'summary-row');
.append('use')
.attr('xlink:href', '#iD-logo-osm');
- let summaryDetail = row
+ var summaryDetail = row
.append('td')
.attr('class', 'cell-detail summary-detail');
summaryDetail
.append('div')
.html(_t('success.changeset_id', {
- changeset_id: `<a href="${changesetURL}" target="_blank">${_changeset.id}</a>`
+ changeset_id: ("<a href=\"" + changesetURL + "\" target=\"_blank\">" + (_changeset.id) + "</a>")
}));
// Get OSM community index features intersecting the map..
ensureOSMCommunityIndex()
- .then(oci => {
- let communities = [];
- const properties = oci.query(context.map().center(), true) || [];
+ .then(function (oci) {
+ var communities = [];
+ var properties = oci.query(context.map().center(), true) || [];
// Gather the communities from the result
- properties.forEach(props => {
- const resourceIDs = Array.from(props.resourceIDs);
- resourceIDs.forEach(resourceID => {
- const resource = oci.resources[resourceID];
+ properties.forEach(function (props) {
+ var resourceIDs = Array.from(props.resourceIDs);
+ resourceIDs.forEach(function (resourceID) {
+ var resource = oci.resources[resourceID];
communities.push({
area: props.area || Infinity,
order: resource.order || 0,
});
// sort communities by feature area ascending, community order descending
- communities.sort((a, b) => a.area - b.area || b.order - a.order);
+ communities.sort(function (a, b) { return a.area - b.area || b.order - a.order; });
body
- .call(showCommunityLinks, communities.map(c => c.resource));
+ .call(showCommunityLinks, communities.map(function (c) { return c.resource; }));
});
}
function showCommunityLinks(selection, resources) {
- let communityLinks = selection
+ var communityLinks = selection
.append('div')
.attr('class', 'save-communityLinks');
.append('h3')
.text(_t('success.like_osm'));
- let table = communityLinks
+ var table = communityLinks
.append('table')
.attr('class', 'community-table');
- let row = table.selectAll('.community-row')
+ var row = table.selectAll('.community-row')
.data(resources);
- let rowEnter = row.enter()
+ var rowEnter = row.enter()
.append('tr')
.attr('class', 'community-row');
.attr('class', 'cell-icon community-icon')
.append('a')
.attr('target', '_blank')
- .attr('href', d => d.url)
+ .attr('href', function (d) { return d.url; })
.append('svg')
.attr('class', 'logo-small')
.append('use')
- .attr('xlink:href', d => `#community-${d.type}`);
+ .attr('xlink:href', function (d) { return ("#community-" + (d.type)); });
- let communityDetail = rowEnter
+ var communityDetail = rowEnter
.append('td')
.attr('class', 'cell-detail community-detail');
function showCommunityDetails(d) {
- let selection = select(this);
- let communityID = d.id;
- let replacements = {
+ var selection = select(this);
+ var communityID = d.id;
+ var replacements = {
url: linkify(d.url),
signupUrl: linkify(d.signupUrl || d.url)
};
.append('a')
.attr('target', '_blank')
.attr('href', d.url)
- .text(_t(`community.${d.id}.name`));
+ .text(_t(("community." + (d.id) + ".name")));
- let descriptionHTML = _t(`community.${d.id}.description`, replacements);
+ var descriptionHTML = _t(("community." + (d.id) + ".description"), replacements);
if (d.type === 'reddit') { // linkify subreddits #4997
descriptionHTML = descriptionHTML
- .replace(/(\/r\/\w*\/*)/i, match => linkify(d.url, match));
+ .replace(/(\/r\/\w*\/*)/i, function (match) { return linkify(d.url, match); });
}
selection
if (d.extendedDescription || (d.languageCodes && d.languageCodes.length)) {
selection
.append('div')
- .call(uiDisclosure(context, `community-more-${d.id}`, false)
+ .call(uiDisclosure(context, ("community-more-" + (d.id)), false)
.expanded(false)
.updatePreference(false)
.title(_t('success.more'))
);
}
- let nextEvents = (d.events || [])
- .map(event => {
+ var nextEvents = (d.events || [])
+ .map(function (event) {
event.date = parseEventDate(event.when);
return event;
})
- .filter(event => { // date is valid and future (or today)
- const t = event.date.getTime();
- const now = (new Date()).setHours(0,0,0,0);
+ .filter(function (event) { // date is valid and future (or today)
+ var t = event.date.getTime();
+ var now = (new Date()).setHours(0,0,0,0);
return !isNaN(t) && t >= now;
})
- .sort((a, b) => { // sort by date ascending
+ .sort(function (a, b) { // sort by date ascending
return a.date < b.date ? -1 : a.date > b.date ? 1 : 0;
})
.slice(0, MAXEVENTS); // limit number of events shown
if (nextEvents.length) {
selection
.append('div')
- .call(uiDisclosure(context, `community-events-${d.id}`, false)
+ .call(uiDisclosure(context, ("community-events-" + (d.id)), false)
.expanded(false)
.updatePreference(false)
.title(_t('success.events'))
function showMore(selection) {
- let more = selection.selectAll('.community-more')
+ var more = selection.selectAll('.community-more')
.data([0]);
- let moreEnter = more.enter()
+ var moreEnter = more.enter()
.append('div')
.attr('class', 'community-more');
moreEnter
.append('div')
.attr('class', 'community-extended-description')
- .html(_t(`community.${d.id}.extendedDescription`, replacements));
+ .html(_t(("community." + (d.id) + ".extendedDescription"), replacements));
}
if (d.languageCodes && d.languageCodes.length) {
- const languageList = d.languageCodes
- .map(code => _mainLocalizer.languageName(code))
+ var languageList = d.languageCodes
+ .map(function (code) { return _mainLocalizer.languageName(code); })
.join(', ');
moreEnter
function showNextEvents(selection) {
- let events = selection
+ var events = selection
.append('div')
.attr('class', 'community-events');
- let item = events.selectAll('.community-event')
+ var item = events.selectAll('.community-event')
.data(nextEvents);
- let itemEnter = item.enter()
+ var itemEnter = item.enter()
.append('div')
.attr('class', 'community-event');
.attr('class', 'community-event-name')
.append('a')
.attr('target', '_blank')
- .attr('href', d => d.url)
- .text(d => {
- let name = d.name;
+ .attr('href', function (d) { return d.url; })
+ .text(function (d) {
+ var name = d.name;
if (d.i18n && d.id) {
- name = _t(`community.${communityID}.events.${d.id}.name`, { default: name });
+ name = _t(("community." + communityID + ".events." + (d.id) + ".name"), { default: name });
}
return name;
});
itemEnter
.append('div')
.attr('class', 'community-event-when')
- .text(d => {
- let options = { weekday: 'short', day: 'numeric', month: 'short', year: 'numeric' };
+ .text(function (d) {
+ var options = { weekday: 'short', day: 'numeric', month: 'short', year: 'numeric' };
if (d.date.getHours() || d.date.getMinutes()) { // include time if it has one
options.hour = 'numeric';
options.minute = 'numeric';
itemEnter
.append('div')
.attr('class', 'community-event-where')
- .text(d => {
- let where = d.where;
+ .text(function (d) {
+ var where = d.where;
if (d.i18n && d.id) {
- where = _t(`community.${communityID}.events.${d.id}.where`, { default: where });
+ where = _t(("community." + communityID + ".events." + (d.id) + ".where"), { default: where });
}
return where;
});
itemEnter
.append('div')
.attr('class', 'community-event-description')
- .text(d => {
- let description = d.description;
+ .text(function (d) {
+ var description = d.description;
if (d.i18n && d.id) {
- description = _t(`community.${communityID}.events.${d.id}.description`, { default: description });
+ description = _t(("community." + communityID + ".events." + (d.id) + ".description"), { default: description });
}
return description;
});
function linkify(url, text) {
text = text || url;
- return `<a target="_blank" href="${url}">${text}</a>`;
+ return ("<a target=\"_blank\" href=\"" + url + "\">" + text + "</a>");
}
}
success.changeset = function(val) {
- if (!arguments.length) return _changeset;
+ if (!arguments.length) { return _changeset; }
_changeset = val;
return success;
};
success.location = function(val) {
- if (!arguments.length) return _location;
+ if (!arguments.length) { return _location; }
_location = val;
return success;
};
function prepareForSuccess() {
_success = uiSuccess(context);
_location = null;
- if (!services.geocoder) return;
+ if (!services.geocoder) { return; }
services.geocoder.reverse(context.map().center(), function(err, result) {
- if (err || !result || !result.address) return;
+ if (err || !result || !result.address) { return; }
var addr = result.address;
var place = (addr && (addr.town || addr.city || addr.county)) || '';
modes.forEach(function(mode) {
context.keybinding().on(mode.key, function() {
- if (!enabled()) return;
+ if (!enabled()) { return; }
if (mode.id === context.mode().id) {
context.enter(modeBrowse(context));
.append('button')
.attr('class', function(d) { return d.id + ' add-button bar-button'; })
.on('click.mode-buttons', function(d) {
- if (!enabled()) return;
+ if (!enabled()) { return; }
// When drawing, ignore accidental clicks on mode buttons - #4042
var currMode = context.mode().id;
- if (/^draw/.test(currMode)) return;
+ if (/^draw/.test(currMode)) { return; }
if (d.id === currMode) {
context.enter(modeBrowse(context));
}
context.keybinding().on(mode.key, function() {
- if (!enabled()) return;
+ if (!enabled()) { return; }
if (mode.id === context.mode().id) {
context.enter(modeBrowse(context));
.attr('tabindex', -1)
.attr('class', function(d) { return d.id + ' add-button bar-button'; })
.on('click.notes', function(d) {
- if (!enabled()) return;
+ if (!enabled()) { return; }
// When drawing, ignore accidental clicks on mode buttons - #4042
var currMode = context.mode().id;
- if (/^draw/.test(currMode)) return;
+ if (/^draw/.test(currMode)) { return; }
if (d.id === currMode) {
context.enter(modeBrowse(context));
function updateCount() {
var val = history.difference().summary().length;
- if (val === _numChanges) return;
+ if (val === _numChanges) { return; }
_numChanges = val;
context.keybinding()
.on(commands[0].cmd, function() {
event.preventDefault();
- if (editable()) commands[0].action();
+ if (editable()) { commands[0].action(); }
})
.on(commands[1].cmd, function() {
event.preventDefault();
- if (editable()) commands[1].action();
+ if (editable()) { commands[1].action(); }
});
context.history()
.on('change.undo_redo', function(difference) {
- if (difference) update();
+ if (difference) { update(); }
});
context
.append('div')
.attr('class', function(d) {
var classes = 'toolbar-item ' + (d.id || d).replace('_', '-');
- if (d.klass) classes += ' ' + d.klass;
+ if (d.klass) { classes += ' ' + d.klass; }
return classes;
});
if (sawVersion === null && matchedVersion !== null) {
if (corePreferences('sawVersion')) {
isNewUser = false;
- isNewVersion = corePreferences('sawVersion') !== currVersion;
+ isNewVersion = corePreferences('sawVersion') !== currVersion && currVersion.indexOf('-') === -1;
} else {
isNewUser = true;
isNewVersion = true;
};
pane.title = function(val) {
- if (!arguments.length) return _title;
+ if (!arguments.length) { return _title; }
_title = val;
return pane;
};
pane.key = function(val) {
- if (!arguments.length) return _key;
+ if (!arguments.length) { return _key; }
_key = val;
return pane;
};
pane.description = function(val) {
- if (!arguments.length) return _description;
+ if (!arguments.length) { return _description; }
_description = val;
return pane;
};
pane.iconName = function(val) {
- if (!arguments.length) return _iconName;
+ if (!arguments.length) { return _iconName; }
_iconName = val;
return pane;
};
pane.sections = function(val) {
- if (!arguments.length) return _sections;
+ if (!arguments.length) { return _sections; }
_sections = val;
return pane;
};
}
pane.togglePane = function() {
- if (event) event.preventDefault();
+ if (event) { event.preventDefault(); }
_paneTooltip.hide();
context.ui().togglePanes(!_paneSelection.classed('shown') ? _paneSelection : undefined);
};
.attr('title', _t('background.reset'))
.attr('class', function(d) { return 'display-option-reset display-option-reset-' + d; })
.on('click', function(d) {
- if (event.button !== 0) return;
+ if (event.button !== 0) { return; }
updateValue(d, 1);
})
.call(svgIcon('#iD-icon-' + (_mainLocalizer.textDirection() === 'rtl' ? 'redo' : 'undo')));
var textSection = modal.select('.modal-section.message-text');
var instructions =
- `${_t('settings.custom_background.instructions.info')}\n` +
+ (_t('settings.custom_background.instructions.info')) + "\n" +
'\n' +
- `#### ${_t('settings.custom_background.instructions.wms.tokens_label')}\n` +
- `* ${_t('settings.custom_background.instructions.wms.tokens.proj')}\n` +
- `* ${_t('settings.custom_background.instructions.wms.tokens.wkid')}\n` +
- `* ${_t('settings.custom_background.instructions.wms.tokens.dimensions')}\n` +
- `* ${_t('settings.custom_background.instructions.wms.tokens.bbox')}\n` +
+ "#### " + (_t('settings.custom_background.instructions.wms.tokens_label')) + "\n" +
+ "* " + (_t('settings.custom_background.instructions.wms.tokens.proj')) + "\n" +
+ "* " + (_t('settings.custom_background.instructions.wms.tokens.wkid')) + "\n" +
+ "* " + (_t('settings.custom_background.instructions.wms.tokens.dimensions')) + "\n" +
+ "* " + (_t('settings.custom_background.instructions.wms.tokens.bbox')) + "\n" +
'\n' +
- `#### ${_t('settings.custom_background.instructions.tms.tokens_label')}\n` +
- `* ${_t('settings.custom_background.instructions.tms.tokens.xyz')}\n` +
- `* ${_t('settings.custom_background.instructions.tms.tokens.flipped_y')}\n` +
- `* ${_t('settings.custom_background.instructions.tms.tokens.switch')}\n` +
- `* ${_t('settings.custom_background.instructions.tms.tokens.quadtile')}\n` +
- `* ${_t('settings.custom_background.instructions.tms.tokens.scale_factor')}\n` +
+ "#### " + (_t('settings.custom_background.instructions.tms.tokens_label')) + "\n" +
+ "* " + (_t('settings.custom_background.instructions.tms.tokens.xyz')) + "\n" +
+ "* " + (_t('settings.custom_background.instructions.tms.tokens.flipped_y')) + "\n" +
+ "* " + (_t('settings.custom_background.instructions.tms.tokens.switch')) + "\n" +
+ "* " + (_t('settings.custom_background.instructions.tms.tokens.quadtile')) + "\n" +
+ "* " + (_t('settings.custom_background.instructions.tms.tokens.scale_factor')) + "\n" +
'\n' +
- `#### ${_t('settings.custom_background.instructions.example')}\n` +
- `\`${example}\``;
+ "#### " + (_t('settings.custom_background.instructions.example')) + "\n" +
+ "`" + example + "`";
textSection
.append('div')
var input = select(this);
var d = input.node().value;
- if (d === '') return resetOffset();
+ if (d === '') { return resetOffset(); }
d = d.replace(/;/g, ',').split(',').map(function(n) {
// if n is NaN, it will always get mapped to false.
function dragOffset() {
- if (event.button !== 0) return;
+ if (event.button !== 0) { return; }
var origin = [event.clientX, event.clientY];
}
function pointermove() {
- if (pointerId !== (event.pointerId || 'mouse')) return;
+ if (pointerId !== (event.pointerId || 'mouse')) { return; }
var latest = [event.clientX, event.clientY];
var d = [
}
function pointerup() {
- if (pointerId !== (event.pointerId || 'mouse')) return;
- if (event.button !== 0) return;
+ if (pointerId !== (event.pointerId || 'mouse')) { return; }
+ if (event.button !== 0) { return; }
context.container().selectAll('.nudge-surface')
.remove();
.attr('class', function(d) { return d[0] + ' nudge'; })
.on('contextmenu', cancelEvent)
.on(_pointerPrefix + 'down', function(d) {
- if (event.button !== 0) return;
+ if (event.button !== 0) { return; }
pointerdownNudgeButton(d[1]);
});
.on('contextmenu', cancelEvent)
.on('click', function() {
event.preventDefault();
- if (event.button !== 0) return;
+ if (event.button !== 0) { return; }
resetOffset();
})
.call(svgIcon('#iD-icon-' + (_mainLocalizer.textDirection() === 'rtl' ? 'redo' : 'undo')));
function clickWalkthrough() {
- if (context.inIntro()) return;
+ if (context.inIntro()) { return; }
context.container().call(uiIntro(context));
context.ui().togglePanes();
}
var section = uiSection(id, context)
.title(function() {
- if (!_issues) return '';
+ if (!_issues) { return ''; }
var issueCountText = _issues.length > 1000 ? '1000+' : String(_issues.length);
return _t('issues.' + severity + 's.list_title', { count: issueCountText });
})
function setLayer(which, enabled) {
// Don't allow layer changes while drawing - #6584
var mode = context.mode();
- if (mode && /^draw/.test(mode.id)) return;
+ if (mode && /^draw/.test(mode.id)) { return; }
var layer = layers.layer(which);
if (layer) {
})
.keys(function(d) {
var key = (d === 'wireframe' ? _t('area_fill.wireframe.key') : null);
- if (d === 'highlight_edits') key = _t('map_data.highlight_edits.key');
+ if (d === 'highlight_edits') { key = _t('map_data.highlight_edits.key'); }
return key ? [key] : null;
})
.placement('top')
.append('label')
.each(function(d) {
var titleID;
- if (d.id === 'mapillary-signs') titleID = 'mapillary.signs.tooltip';
- else if (d.id === 'mapillary') titleID = 'mapillary_images.tooltip';
- else if (d.id === 'openstreetcam') titleID = 'openstreetcam_images.tooltip';
- else titleID = d.id.replace(/-/g, '_') + '.tooltip';
+ if (d.id === 'mapillary-signs') { titleID = 'mapillary.signs.tooltip'; }
+ else if (d.id === 'mapillary') { titleID = 'mapillary_images.tooltip'; }
+ else if (d.id === 'openstreetcam') { titleID = 'openstreetcam_images.tooltip'; }
+ else { titleID = d.id.replace(/-/g, '_') + '.tooltip'; }
select(this)
.call(uiTooltip()
.title(_t(titleID))
.append('span')
.text(function(d) {
var id = d.id;
- if (id === 'mapillary-signs') id = 'photo_overlays.traffic_signs';
+ if (id === 'mapillary-signs') { id = 'photo_overlays.traffic_signs'; }
return _t(id.replace(/-/g, '_') + '.title');
});
function uiSectionPrivacy(context) {
- let section = uiSection('preferences-third-party', context)
+ var section = uiSection('preferences-third-party', context)
.title(_t('preferences.privacy.title'))
.disclosureContent(renderDisclosureContent);
- let _showThirdPartyIcons = corePreferences('preferences.privacy.thirdpartyicons') || 'true';
+ var _showThirdPartyIcons = corePreferences('preferences.privacy.thirdpartyicons') || 'true';
function renderDisclosureContent(selection) {
// enter
- let privacyOptionsListEnter = selection.selectAll('.privacy-options-list')
+ var privacyOptionsListEnter = selection.selectAll('.privacy-options-list')
.data([0])
.enter()
.append('ul')
.attr('class', 'layer-list privacy-options-list');
- let thirdPartyIconsEnter = privacyOptionsListEnter
+ var thirdPartyIconsEnter = privacyOptionsListEnter
.append('li')
.attr('class', 'privacy-third-party-icons-item')
.append('label')
thirdPartyIconsEnter
.append('input')
.attr('type', 'checkbox')
- .on('change', () => {
+ .on('change', function () {
event.preventDefault();
_showThirdPartyIcons = (_showThirdPartyIcons === 'true') ? 'false' : 'true';
corePreferences('preferences.privacy.thirdpartyicons', _showThirdPartyIcons);
function uiPanePreferences(context) {
- let preferencesPane = uiPane('preferences', context)
+ var preferencesPane = uiPane('preferences', context)
.key(_t('preferences.key'))
.title(_t('preferences.title'))
.description(_t('preferences.description'))
container
.on('click.ui', function() {
// we're only concerned with the primary mouse button
- if (event.button !== 0) return;
+ if (event.button !== 0) { return; }
- if (!event.composedPath) return;
+ if (!event.composedPath) { return; }
// some targets have default click events we don't want to override
var isOkayTarget = event.composedPath().some(function(node) {
- // clicking <label> affects its <input> by default
- return node.nodeName === 'LABEL' ||
+ // we only care about element nodes
+ return node.nodeType === 1 &&
+ // clicking <input> focuses it and/or changes a value
+ (node.nodeName === 'INPUT' ||
+ // clicking <label> affects its <input> by default
+ node.nodeName === 'LABEL' ||
// clicking <a> opens a hyperlink by default
- node.nodeName === 'A';
+ node.nodeName === 'A');
});
- if (isOkayTarget) return;
+ if (isOkayTarget) { return; }
// disable double-tap-to-zoom on touchscreens
event.preventDefault();
// Don't allow layer changes while drawing - #6584
var mode = context.mode();
- if (mode && /^draw/.test(mode.id)) return;
+ if (mode && /^draw/.test(mode.id)) { return; }
var layer = context.layers().layer('osm');
if (layer) {
function pan(d) {
return function() {
- if (event.shiftKey) return;
- if (context.container().select('.combobox').size()) return;
+ if (event.shiftKey) { return; }
+ if (context.container().select('.combobox').size()) { return; }
event.preventDefault();
context.map().pan(d, 100);
};
}
- let ui = {};
+ var ui = {};
- let _loadPromise;
+ var _loadPromise;
// renders the iD interface into the container node
- ui.ensureLoaded = () => {
+ ui.ensureLoaded = function () {
- if (_loadPromise) return _loadPromise;
+ if (_loadPromise) { return _loadPromise; }
return _loadPromise = Promise.all([
// must have strings and presets before loading the UI
_mainLocalizer.ensureLoaded(),
_mainPresetIndex.ensureLoaded()
])
- .then(() => {
- if (!context.container().empty()) render(context.container());
+ .then(function () {
+ if (!context.container().empty()) { render(context.container()); }
})
- .catch(err => console.error(err)); // eslint-disable-line
+ .catch(function (err) { return console.error(err); }); // eslint-disable-line
};
// remove any displayed menu
ui.closeEditMenu();
- if (!operations && context.mode().operations) operations = context.mode().operations();
- if (!operations || !operations.length) return;
+ if (!operations && context.mode().operations) { operations = context.mode().operations(); }
+ if (!operations || !operations.length) { return; }
// disable menu if in wide selection, for example
- if (!context.map().editableDataEnabled()) return;
+ if (!context.map().editableDataEnabled()) { return; }
var surfaceNode = context.surface().node();
if (surfaceNode.focus) { // FF doesn't support it
}
operations.forEach(function(operation) {
- if (operation.point) operation.point(anchorPoint);
+ if (operation.point) { operation.point(anchorPoint); }
});
_editMenu
}
function coreContext() {
- const dispatch$1 = dispatch('enter', 'exit', 'change');
- let context = utilRebind({}, dispatch$1, 'on');
- let _deferred = new Set();
+ var this$1 = this;
+
+ var dispatch$1 = dispatch('enter', 'exit', 'change');
+ var context = utilRebind({}, dispatch$1, 'on');
+ var _deferred = new Set();
- context.version = '2.18.0';
+ context.version = '2.18.5';
context.privacyVersion = '20200407';
// iD will alter the hash so cache the parameters intended to setup the session
// An osmChangeset object. Not loaded until needed.
context.changeset = null;
- let _defaultChangesetComment = context.initialHashParams.comment;
- let _defaultChangesetSource = context.initialHashParams.source;
- let _defaultChangesetHashtags = context.initialHashParams.hashtags;
+ var _defaultChangesetComment = context.initialHashParams.comment;
+ var _defaultChangesetSource = context.initialHashParams.source;
+ var _defaultChangesetHashtags = context.initialHashParams.hashtags;
context.defaultChangesetComment = function(val) {
- if (!arguments.length) return _defaultChangesetComment;
+ if (!arguments.length) { return _defaultChangesetComment; }
_defaultChangesetComment = val;
return context;
};
context.defaultChangesetSource = function(val) {
- if (!arguments.length) return _defaultChangesetSource;
+ if (!arguments.length) { return _defaultChangesetSource; }
_defaultChangesetSource = val;
return context;
};
context.defaultChangesetHashtags = function(val) {
- if (!arguments.length) return _defaultChangesetHashtags;
+ if (!arguments.length) { return _defaultChangesetHashtags; }
_defaultChangesetHashtags = val;
return context;
};
/* (typically shown as the label for the browser window/tab) */
// If true, iD will update the title based on what the user is doing
- let _setsDocumentTitle = true;
+ var _setsDocumentTitle = true;
context.setsDocumentTitle = function(val) {
- if (!arguments.length) return _setsDocumentTitle;
+ if (!arguments.length) { return _setsDocumentTitle; }
_setsDocumentTitle = val;
return context;
};
// The part of the title that is always the same
- let _documentTitleBase = document.title;
+ var _documentTitleBase = document.title;
context.documentTitleBase = function(val) {
- if (!arguments.length) return _documentTitleBase;
+ if (!arguments.length) { return _documentTitleBase; }
_documentTitleBase = val;
return context;
};
/* User interface and keybinding */
- let _ui;
- context.ui = () => _ui;
- context.lastPointerType = () => _ui.lastPointerType();
+ var _ui;
+ context.ui = function () { return _ui; };
+ context.lastPointerType = function () { return _ui.lastPointerType(); };
- let _keybinding = utilKeybinding('context');
- context.keybinding = () => _keybinding;
+ var _keybinding = utilKeybinding('context');
+ context.keybinding = function () { return _keybinding; };
select(document).call(_keybinding);
/* Straight accessors. Avoid using these if you can. */
- let _connection;
- let _history;
- let _validator;
- let _uploader;
- context.connection = () => _connection;
- context.history = () => _history;
- context.validator = () => _validator;
- context.uploader = () => _uploader;
+ // Instantiate the connection here because it doesn't require passing in
+ // `context` and it's needed for pre-init calls like `preauth`
+ var _connection = services.osm;
+ var _history;
+ var _validator;
+ var _uploader;
+ context.connection = function () { return _connection; };
+ context.history = function () { return _history; };
+ context.validator = function () { return _validator; };
+ context.uploader = function () { return _uploader; };
/* Connection */
- context.preauth = (options) => {
+ context.preauth = function (options) {
if (_connection) {
_connection.switch(options);
}
};
/* connection options for source switcher (optional) */
- let _apiConnections;
+ var _apiConnections;
context.apiConnections = function(val) {
- if (!arguments.length) return _apiConnections;
+ if (!arguments.length) { return _apiConnections; }
_apiConnections = val;
return context;
};
+ // A string or array or locale codes to prefer over the browser's settings
+ context.locale = function(locale) {
+ if (!arguments.length) { return _mainLocalizer.localeCode(); }
+ _mainLocalizer.preferredLocaleCodes(locale);
+ return context;
+ };
+
+
function afterLoad(cid, callback) {
- return (err, result) => {
+ return function (err, result) {
if (err) {
// 400 Bad Request, 401 Unauthorized, 403 Forbidden..
if (err.status === 400 || err.status === 401 || err.status === 403) {
}
- context.loadTiles = (projection, callback) => {
- const handle = window.requestIdleCallback(() => {
+ context.loadTiles = function (projection, callback) {
+ var handle = window.requestIdleCallback(function () {
_deferred.delete(handle);
if (_connection && context.editableDataEnabled()) {
- const cid = _connection.getConnectionId();
+ var cid = _connection.getConnectionId();
_connection.loadTiles(projection, afterLoad(cid, callback));
}
});
_deferred.add(handle);
};
- context.loadTileAtLoc = (loc, callback) => {
- const handle = window.requestIdleCallback(() => {
+ context.loadTileAtLoc = function (loc, callback) {
+ var handle = window.requestIdleCallback(function () {
_deferred.delete(handle);
if (_connection && context.editableDataEnabled()) {
- const cid = _connection.getConnectionId();
+ var cid = _connection.getConnectionId();
_connection.loadTileAtLoc(loc, afterLoad(cid, callback));
}
});
_deferred.add(handle);
};
- context.loadEntity = (entityID, callback) => {
+ context.loadEntity = function (entityID, callback) {
if (_connection) {
- const cid = _connection.getConnectionId();
+ var cid = _connection.getConnectionId();
_connection.loadEntity(entityID, afterLoad(cid, callback));
}
};
- context.zoomToEntity = (entityID, zoomTo) => {
+ context.zoomToEntity = function (entityID, zoomTo) {
if (zoomTo !== false) {
- context.loadEntity(entityID, (err, result) => {
- if (err) return;
- const entity = result.data.find(e => e.id === entityID);
+ context.loadEntity(entityID, function (err, result) {
+ if (err) { return; }
+ var entity = result.data.find(function (e) { return e.id === entityID; });
if (entity) {
_map.zoomTo(entity);
}
});
}
- _map.on('drawn.zoomToEntity', () => {
- if (!context.hasEntity(entityID)) return;
+ _map.on('drawn.zoomToEntity', function () {
+ if (!context.hasEntity(entityID)) { return; }
_map.on('drawn.zoomToEntity', null);
context.on('enter.zoomToEntity', null);
context.enter(modeSelect(context, [entityID]));
});
- context.on('enter.zoomToEntity', () => {
+ context.on('enter.zoomToEntity', function () {
if (_mode.id !== 'browse') {
_map.on('drawn.zoomToEntity', null);
context.on('enter.zoomToEntity', null);
});
};
- let _minEditableZoom = 16;
+ var _minEditableZoom = 16;
context.minEditableZoom = function(val) {
- if (!arguments.length) return _minEditableZoom;
+ if (!arguments.length) { return _minEditableZoom; }
_minEditableZoom = val;
if (_connection) {
_connection.tileZoom(val);
};
// String length limits in Unicode characters, not JavaScript UTF-16 code units
- context.maxCharsForTagKey = () => 255;
- context.maxCharsForTagValue = () => 255;
- context.maxCharsForRelationRole = () => 255;
+ context.maxCharsForTagKey = function () { return 255; };
+ context.maxCharsForTagValue = function () { return 255; };
+ context.maxCharsForRelationRole = function () { return 255; };
function cleanOsmString(val, maxChars) {
// be lenient with input
val = val.trim();
// use the canonical form of the string
- if (val.normalize) val = val.normalize('NFC');
+ if (val.normalize) { val = val.normalize('NFC'); }
// trim to the number of allowed characters
return utilUnicodeCharsTruncated(val, maxChars);
}
- context.cleanTagKey = (val) => cleanOsmString(val, context.maxCharsForTagKey());
- context.cleanTagValue = (val) => cleanOsmString(val, context.maxCharsForTagValue());
- context.cleanRelationRole = (val) => cleanOsmString(val, context.maxCharsForRelationRole());
+ context.cleanTagKey = function (val) { return cleanOsmString(val, context.maxCharsForTagKey()); };
+ context.cleanTagValue = function (val) { return cleanOsmString(val, context.maxCharsForTagValue()); };
+ context.cleanRelationRole = function (val) { return cleanOsmString(val, context.maxCharsForRelationRole()); };
/* History */
- let _inIntro = false;
+ var _inIntro = false;
context.inIntro = function(val) {
- if (!arguments.length) return _inIntro;
+ if (!arguments.length) { return _inIntro; }
_inIntro = val;
return context;
};
// Immediately save the user's history to localstorage, if possible
// This is called someteimes, but also on the `window.onbeforeunload` handler
- context.save = () => {
+ context.save = function () {
// no history save, no message onbeforeunload
- if (_inIntro || context.container().select('.modal').size()) return;
+ if (_inIntro || context.container().select('.modal').size()) { return; }
- let canSave;
+ var canSave;
if (_mode && _mode.id === 'save') {
canSave = false;
}
} else {
- canSave = context.selectedIDs().every(id => {
- const entity = context.hasEntity(id);
+ canSave = context.selectedIDs().every(function (id) {
+ var entity = context.hasEntity(id);
return entity && !entity.isDegenerate();
});
}
function withDebouncedSave(fn) {
return function() {
- const result = fn.apply(_history, arguments);
+ var result = fn.apply(_history, arguments);
context.debouncedSave();
return result;
};
/* Graph */
- context.hasEntity = (id) => _history.graph().hasEntity(id);
- context.entity = (id) => _history.graph().entity(id);
+ context.hasEntity = function (id) { return _history.graph().hasEntity(id); };
+ context.entity = function (id) { return _history.graph().entity(id); };
/* Modes */
- let _mode;
- context.mode = () => _mode;
- context.enter = (newMode) => {
+ var _mode;
+ context.mode = function () { return _mode; };
+ context.enter = function (newMode) {
if (_mode) {
_mode.exit();
- dispatch$1.call('exit', this, _mode);
+ dispatch$1.call('exit', this$1, _mode);
}
_mode = newMode;
_mode.enter();
- dispatch$1.call('enter', this, _mode);
+ dispatch$1.call('enter', this$1, _mode);
};
- context.selectedIDs = () => (_mode && _mode.selectedIDs && _mode.selectedIDs()) || [];
- context.activeID = () => _mode && _mode.activeID && _mode.activeID();
+ context.selectedIDs = function () { return (_mode && _mode.selectedIDs && _mode.selectedIDs()) || []; };
+ context.activeID = function () { return _mode && _mode.activeID && _mode.activeID(); };
- let _selectedNoteID;
+ var _selectedNoteID;
context.selectedNoteID = function(noteID) {
- if (!arguments.length) return _selectedNoteID;
+ if (!arguments.length) { return _selectedNoteID; }
_selectedNoteID = noteID;
return context;
};
// NOTE: Don't change the name of this until UI v3 is merged
- let _selectedErrorID;
+ var _selectedErrorID;
context.selectedErrorID = function(errorID) {
- if (!arguments.length) return _selectedErrorID;
+ if (!arguments.length) { return _selectedErrorID; }
_selectedErrorID = errorID;
return context;
};
/* Behaviors */
- context.install = (behavior) => context.surface().call(behavior);
- context.uninstall = (behavior) => context.surface().call(behavior.off);
+ context.install = function (behavior) { return context.surface().call(behavior); };
+ context.uninstall = function (behavior) { return context.surface().call(behavior.off); };
/* Copy/Paste */
- let _copyGraph;
- context.copyGraph = () => _copyGraph;
+ var _copyGraph;
+ context.copyGraph = function () { return _copyGraph; };
- let _copyIDs = [];
+ var _copyIDs = [];
context.copyIDs = function(val) {
- if (!arguments.length) return _copyIDs;
+ if (!arguments.length) { return _copyIDs; }
_copyIDs = val;
_copyGraph = _history.graph();
return context;
};
- let _copyLonLat;
+ var _copyLonLat;
context.copyLonLat = function(val) {
- if (!arguments.length) return _copyLonLat;
+ if (!arguments.length) { return _copyLonLat; }
_copyLonLat = val;
return context;
};
/* Background */
- let _background;
- context.background = () => _background;
+ var _background;
+ context.background = function () { return _background; };
/* Features */
- let _features;
- context.features = () => _features;
- context.hasHiddenConnections = (id) => {
- const graph = _history.graph();
- const entity = graph.entity(id);
+ var _features;
+ context.features = function () { return _features; };
+ context.hasHiddenConnections = function (id) {
+ var graph = _history.graph();
+ var entity = graph.entity(id);
return _features.hasHiddenConnections(entity, graph);
};
/* Photos */
- let _photos;
- context.photos = () => _photos;
+ var _photos;
+ context.photos = function () { return _photos; };
/* Map */
- let _map;
- context.map = () => _map;
- context.layers = () => _map.layers();
- context.surface = () => _map.surface;
- context.editableDataEnabled = () => _map.editableDataEnabled();
- context.surfaceRect = () => _map.surface.node().getBoundingClientRect();
- context.editable = () => {
+ var _map;
+ context.map = function () { return _map; };
+ context.layers = function () { return _map.layers(); };
+ context.surface = function () { return _map.surface; };
+ context.editableDataEnabled = function () { return _map.editableDataEnabled(); };
+ context.surfaceRect = function () { return _map.surface.node().getBoundingClientRect(); };
+ context.editable = function () {
// don't allow editing during save
- const mode = context.mode();
- if (!mode || mode.id === 'save') return false;
+ var mode = context.mode();
+ if (!mode || mode.id === 'save') { return false; }
return _map.editableDataEnabled();
};
/* Debug */
- let _debugFlags = {
+ var _debugFlags = {
tile: false, // tile boundaries
collision: false, // label collision bounding boxes
imagery: false, // imagery bounding polygons
target: false, // touch targets
downloaded: false // downloaded data from osm
};
- context.debugFlags = () => _debugFlags;
- context.getDebug = (flag) => flag && _debugFlags[flag];
+ context.debugFlags = function () { return _debugFlags; };
+ context.getDebug = function (flag) { return flag && _debugFlags[flag]; };
context.setDebug = function(flag, val) {
- if (arguments.length === 1) val = true;
+ if (arguments.length === 1) { val = true; }
_debugFlags[flag] = val;
dispatch$1.call('change');
return context;
/* Container */
- let _container = select(null);
+ var _container = select(null);
context.container = function(val) {
- if (!arguments.length) return _container;
+ if (!arguments.length) { return _container; }
_container = val;
_container.classed('ideditor', true);
return context;
};
context.containerNode = function(val) {
- if (!arguments.length) return context.container().node();
+ if (!arguments.length) { return context.container().node(); }
context.container(select(val));
return context;
};
- let _embed;
+ var _embed;
context.embed = function(val) {
- if (!arguments.length) return _embed;
+ if (!arguments.length) { return _embed; }
_embed = val;
return context;
};
/* Assets */
- let _assetPath = '';
+ var _assetPath = '';
context.assetPath = function(val) {
- if (!arguments.length) return _assetPath;
+ if (!arguments.length) { return _assetPath; }
_assetPath = val;
_mainFileFetcher.assetPath(val);
return context;
};
- let _assetMap = {};
+ var _assetMap = {};
context.assetMap = function(val) {
- if (!arguments.length) return _assetMap;
+ if (!arguments.length) { return _assetMap; }
_assetMap = val;
_mainFileFetcher.assetMap(val);
return context;
};
- context.asset = (val) => {
- if (/^http(s)?:\/\//i.test(val)) return val;
- const filename = _assetPath + val;
+ context.asset = function (val) {
+ if (/^http(s)?:\/\//i.test(val)) { return val; }
+ var filename = _assetPath + val;
return _assetMap[filename] || filename;
};
- context.imagePath = (val) => context.asset(`img/${val}`);
+ context.imagePath = function (val) { return context.asset(("img/" + val)); };
/* reset (aka flush) */
- context.reset = context.flush = () => {
+ context.reset = context.flush = function () {
context.debouncedSave.cancel();
- Array.from(_deferred).forEach(handle => {
+ Array.from(_deferred).forEach(function (handle) {
window.cancelIdleCallback(handle);
_deferred.delete(handle);
});
- Object.values(services).forEach(service => {
+ Object.values(services).forEach(function (service) {
if (service && typeof service.reset === 'function') {
service.reset(context);
}
/* Init */
- context.init = () => {
+ context.init = function () {
instantiateInternal();
_photos = rendererPhotos(context);
_ui = uiInit(context);
-
- _connection = services.osm;
}
// Set up objects that might need to access properties of `context`. The order
_mainPresetIndex.addablePresetIDs(new Set(context.initialHashParams.presets.split(',')));
}
+ if (context.initialHashParams.locale) {
+ _mainLocalizer.preferredLocaleCodes(context.initialHashParams.locale);
+ }
+
// kick off some async work
_mainLocalizer.ensureLoaded();
_background.ensureLoaded();
_mainPresetIndex.ensureLoaded();
- Object.values(services).forEach(service => {
+ Object.values(services).forEach(function (service) {
if (service && typeof service.init === 'function') {
service.init();
}
if (services.maprules && context.initialHashParams.maprules) {
d3_json(context.initialHashParams.maprules)
- .then(mapcss => {
+ .then(function (mapcss) {
services.maprules.init();
- mapcss.forEach(mapcssSelector => services.maprules.addRule(mapcssSelector));
+ mapcss.forEach(function (mapcssSelector) { return services.maprules.addRule(mapcssSelector); });
})
- .catch(() => { /* ignore */ });
+ .catch(function () { /* ignore */ });
}
// if the container isn't available, e.g. when testing, don't load the UI
- if (!context.container().empty()) _ui.ensureLoaded();
+ if (!context.container().empty()) { _ui.ensureLoaded(); }
}
};
// When `debug = true`, we use `Object.freeze` on immutables in iD.
// This is only done in testing because of the performance penalty.
- let debug = false;
- let d3 = {
+ var debug = false;
+ var d3 = {
customEvent: customEvent,
dispatch: dispatch,
event: event,
window.iD = iD;
}());
-//# sourceMappingURL=iD.js.map