mirror of
https://github.com/FoggedLens/iD.git
synced 2026-05-18 14:45:12 +02:00
@@ -56,10 +56,6 @@
|
||||
"t": false,
|
||||
"bootstrap": false,
|
||||
"Diff3": false,
|
||||
"JXON": false,
|
||||
"osmAuth": false,
|
||||
"toGeoJSON": false,
|
||||
"marked": false,
|
||||
"Mapillary": false,
|
||||
},
|
||||
|
||||
|
||||
@@ -72,7 +72,6 @@ dist/iD.js: \
|
||||
js/lib/d3.curtain.js \
|
||||
js/lib/d3.value.js \
|
||||
js/lib/diff3.js \
|
||||
js/lib/jxon.js \
|
||||
js/lib/lodash.js \
|
||||
js/id/start.js \
|
||||
js/id/id.js \
|
||||
|
||||
@@ -14,7 +14,6 @@
|
||||
|
||||
<script src='js/lib/lodash.js'></script>
|
||||
<script src='js/lib/d3.v3.js'></script>
|
||||
<script src='js/lib/jxon.js'></script>
|
||||
<script src='js/lib/d3.combobox.js'></script>
|
||||
<script src='js/lib/d3.geo.tile.js'></script>
|
||||
<script src='js/lib/d3.dimensions.js'></script>
|
||||
|
||||
@@ -4191,6 +4191,149 @@
|
||||
|
||||
var osmAuth = (index && typeof index === 'object' && 'default' in index ? index['default'] : index);
|
||||
|
||||
var JXON = new (function () {
|
||||
var
|
||||
sValueProp = 'keyValue', sAttributesProp = 'keyAttributes', sAttrPref = '@', /* you can customize these values */
|
||||
aCache = [], rIsNull = /^\s*$/, rIsBool = /^(?:true|false)$/i;
|
||||
|
||||
function parseText (sValue) {
|
||||
if (rIsNull.test(sValue)) { return null; }
|
||||
if (rIsBool.test(sValue)) { return sValue.toLowerCase() === 'true'; }
|
||||
if (isFinite(sValue)) { return parseFloat(sValue); }
|
||||
if (isFinite(Date.parse(sValue))) { return new Date(sValue); }
|
||||
return sValue;
|
||||
}
|
||||
|
||||
function EmptyTree () { }
|
||||
EmptyTree.prototype.toString = function () { return 'null'; };
|
||||
EmptyTree.prototype.valueOf = function () { return null; };
|
||||
|
||||
function objectify (vValue) {
|
||||
return vValue === null ? new EmptyTree() : vValue instanceof Object ? vValue : new vValue.constructor(vValue);
|
||||
}
|
||||
|
||||
function createObjTree (oParentNode, nVerb, bFreeze, bNesteAttr) {
|
||||
var
|
||||
nLevelStart = aCache.length, bChildren = oParentNode.hasChildNodes(),
|
||||
bAttributes = oParentNode.hasAttributes(), bHighVerb = Boolean(nVerb & 2);
|
||||
|
||||
var
|
||||
sProp, vContent, nLength = 0, sCollectedTxt = '',
|
||||
vResult = bHighVerb ? {} : /* put here the default value for empty nodes: */ true;
|
||||
|
||||
if (bChildren) {
|
||||
for (var oNode, nItem = 0; nItem < oParentNode.childNodes.length; nItem++) {
|
||||
oNode = oParentNode.childNodes.item(nItem);
|
||||
if (oNode.nodeType === 4) { sCollectedTxt += oNode.nodeValue; } /* nodeType is 'CDATASection' (4) */
|
||||
else if (oNode.nodeType === 3) { sCollectedTxt += oNode.nodeValue.trim(); } /* nodeType is 'Text' (3) */
|
||||
else if (oNode.nodeType === 1 && !oNode.prefix) { aCache.push(oNode); } /* nodeType is 'Element' (1) */
|
||||
}
|
||||
}
|
||||
|
||||
var nLevelEnd = aCache.length, vBuiltVal = parseText(sCollectedTxt);
|
||||
|
||||
if (!bHighVerb && (bChildren || bAttributes)) { vResult = nVerb === 0 ? objectify(vBuiltVal) : {}; }
|
||||
|
||||
for (var nElId = nLevelStart; nElId < nLevelEnd; nElId++) {
|
||||
sProp = aCache[nElId].nodeName.toLowerCase();
|
||||
vContent = createObjTree(aCache[nElId], nVerb, bFreeze, bNesteAttr);
|
||||
if (vResult.hasOwnProperty(sProp)) {
|
||||
if (vResult[sProp].constructor !== Array) { vResult[sProp] = [vResult[sProp]]; }
|
||||
vResult[sProp].push(vContent);
|
||||
} else {
|
||||
vResult[sProp] = vContent;
|
||||
nLength++;
|
||||
}
|
||||
}
|
||||
|
||||
if (bAttributes) {
|
||||
var
|
||||
nAttrLen = oParentNode.attributes.length,
|
||||
sAPrefix = bNesteAttr ? '' : sAttrPref, oAttrParent = bNesteAttr ? {} : vResult;
|
||||
|
||||
for (var oAttrib, nAttrib = 0; nAttrib < nAttrLen; nLength++, nAttrib++) {
|
||||
oAttrib = oParentNode.attributes.item(nAttrib);
|
||||
oAttrParent[sAPrefix + oAttrib.name.toLowerCase()] = parseText(oAttrib.value.trim());
|
||||
}
|
||||
|
||||
if (bNesteAttr) {
|
||||
if (bFreeze) { Object.freeze(oAttrParent); }
|
||||
vResult[sAttributesProp] = oAttrParent;
|
||||
nLength -= nAttrLen - 1;
|
||||
}
|
||||
}
|
||||
|
||||
if (nVerb === 3 || (nVerb === 2 || nVerb === 1 && nLength > 0) && sCollectedTxt) {
|
||||
vResult[sValueProp] = vBuiltVal;
|
||||
} else if (!bHighVerb && nLength === 0 && sCollectedTxt) {
|
||||
vResult = vBuiltVal;
|
||||
}
|
||||
|
||||
if (bFreeze && (bHighVerb || nLength > 0)) { Object.freeze(vResult); }
|
||||
|
||||
aCache.length = nLevelStart;
|
||||
|
||||
return vResult;
|
||||
}
|
||||
|
||||
function loadObjTree (oXMLDoc, oParentEl, oParentObj) {
|
||||
var vValue, oChild;
|
||||
|
||||
if (oParentObj instanceof String || oParentObj instanceof Number || oParentObj instanceof Boolean) {
|
||||
oParentEl.appendChild(oXMLDoc.createTextNode(oParentObj.toString())); /* verbosity level is 0 */
|
||||
} else if (oParentObj.constructor === Date) {
|
||||
oParentEl.appendChild(oXMLDoc.createTextNode(oParentObj.toGMTString()));
|
||||
}
|
||||
|
||||
for (var sName in oParentObj) {
|
||||
vValue = oParentObj[sName];
|
||||
if (isFinite(sName) || vValue instanceof Function) { continue; } /* verbosity level is 0 */
|
||||
if (sName === sValueProp) {
|
||||
if (vValue !== null && vValue !== true) { oParentEl.appendChild(oXMLDoc.createTextNode(vValue.constructor === Date ? vValue.toGMTString() : String(vValue))); }
|
||||
} else if (sName === sAttributesProp) { /* verbosity level is 3 */
|
||||
for (var sAttrib in vValue) { oParentEl.setAttribute(sAttrib, vValue[sAttrib]); }
|
||||
} else if (sName.charAt(0) === sAttrPref) {
|
||||
oParentEl.setAttribute(sName.slice(1), vValue);
|
||||
} else if (vValue.constructor === Array) {
|
||||
for (var nItem = 0; nItem < vValue.length; nItem++) {
|
||||
oChild = oXMLDoc.createElement(sName);
|
||||
loadObjTree(oXMLDoc, oChild, vValue[nItem]);
|
||||
oParentEl.appendChild(oChild);
|
||||
}
|
||||
} else {
|
||||
oChild = oXMLDoc.createElement(sName);
|
||||
if (vValue instanceof Object) {
|
||||
loadObjTree(oXMLDoc, oChild, vValue);
|
||||
} else if (vValue !== null && vValue !== true) {
|
||||
oChild.appendChild(oXMLDoc.createTextNode(vValue.toString()));
|
||||
}
|
||||
oParentEl.appendChild(oChild);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
this.build = function (oXMLParent, nVerbosity /* optional */, bFreeze /* optional */, bNesteAttributes /* optional */) {
|
||||
var _nVerb = arguments.length > 1 && typeof nVerbosity === 'number' ? nVerbosity & 3 : /* put here the default verbosity level: */ 1;
|
||||
return createObjTree(oXMLParent, _nVerb, bFreeze || false, arguments.length > 3 ? bNesteAttributes : _nVerb === 3);
|
||||
};
|
||||
|
||||
this.unbuild = function (oObjTree) {
|
||||
var oNewDoc = document.implementation.createDocument('', '', null);
|
||||
loadObjTree(oNewDoc, oNewDoc, oObjTree);
|
||||
return oNewDoc;
|
||||
};
|
||||
|
||||
this.stringify = function (oObjTree) {
|
||||
return (new XMLSerializer()).serializeToString(JXON.unbuild(oObjTree));
|
||||
};
|
||||
})();
|
||||
|
||||
// var myObject = JXON.build(doc);
|
||||
// we got our javascript object! try: alert(JSON.stringify(myObject));
|
||||
|
||||
// var newDoc = JXON.unbuild(myObject);
|
||||
// we got our Document instance! try: alert((new XMLSerializer()).serializeToString(newDoc));
|
||||
|
||||
function Connection(useHttps) {
|
||||
if (typeof useHttps !== 'boolean') {
|
||||
useHttps = window.location.protocol === 'https:';
|
||||
|
||||
@@ -4,6 +4,7 @@ import { Relation } from './relation';
|
||||
import { Node } from './node';
|
||||
import { Extent } from '../geo/index';
|
||||
import osmAuth from 'osm-auth';
|
||||
import { JXON } from '../util/jxon';
|
||||
|
||||
export function Connection(useHttps) {
|
||||
if (typeof useHttps !== 'boolean') {
|
||||
|
||||
@@ -3,6 +3,7 @@ import { displayName, displayType } from '../util/index';
|
||||
import { Browse } from './index';
|
||||
import { DiscardTags, Noop, MergeRemoteChanges, Revert } from '../actions/index';
|
||||
import { Commit, Loading, Success, Conflicts } from '../ui/index';
|
||||
import { JXON } from '../util/jxon';
|
||||
|
||||
export function Save(context) {
|
||||
var ui = Commit(context)
|
||||
|
||||
@@ -1,18 +1,18 @@
|
||||
var JXON = new (function () {
|
||||
export var JXON = new (function () {
|
||||
var
|
||||
sValueProp = "keyValue", sAttributesProp = "keyAttributes", sAttrPref = "@", /* you can customize these values */
|
||||
sValueProp = 'keyValue', sAttributesProp = 'keyAttributes', sAttrPref = '@', /* you can customize these values */
|
||||
aCache = [], rIsNull = /^\s*$/, rIsBool = /^(?:true|false)$/i;
|
||||
|
||||
function parseText (sValue) {
|
||||
if (rIsNull.test(sValue)) { return null; }
|
||||
if (rIsBool.test(sValue)) { return sValue.toLowerCase() === "true"; }
|
||||
if (rIsBool.test(sValue)) { return sValue.toLowerCase() === 'true'; }
|
||||
if (isFinite(sValue)) { return parseFloat(sValue); }
|
||||
if (isFinite(Date.parse(sValue))) { return new Date(sValue); }
|
||||
return sValue;
|
||||
}
|
||||
|
||||
function EmptyTree () { }
|
||||
EmptyTree.prototype.toString = function () { return "null"; };
|
||||
EmptyTree.prototype.toString = function () { return 'null'; };
|
||||
EmptyTree.prototype.valueOf = function () { return null; };
|
||||
|
||||
function objectify (vValue) {
|
||||
@@ -25,15 +25,15 @@ var JXON = new (function () {
|
||||
bAttributes = oParentNode.hasAttributes(), bHighVerb = Boolean(nVerb & 2);
|
||||
|
||||
var
|
||||
sProp, vContent, nLength = 0, sCollectedTxt = "",
|
||||
sProp, vContent, nLength = 0, sCollectedTxt = '',
|
||||
vResult = bHighVerb ? {} : /* put here the default value for empty nodes: */ true;
|
||||
|
||||
if (bChildren) {
|
||||
for (var oNode, nItem = 0; nItem < oParentNode.childNodes.length; nItem++) {
|
||||
oNode = oParentNode.childNodes.item(nItem);
|
||||
if (oNode.nodeType === 4) { sCollectedTxt += oNode.nodeValue; } /* nodeType is "CDATASection" (4) */
|
||||
else if (oNode.nodeType === 3) { sCollectedTxt += oNode.nodeValue.trim(); } /* nodeType is "Text" (3) */
|
||||
else if (oNode.nodeType === 1 && !oNode.prefix) { aCache.push(oNode); } /* nodeType is "Element" (1) */
|
||||
if (oNode.nodeType === 4) { sCollectedTxt += oNode.nodeValue; } /* nodeType is 'CDATASection' (4) */
|
||||
else if (oNode.nodeType === 3) { sCollectedTxt += oNode.nodeValue.trim(); } /* nodeType is 'Text' (3) */
|
||||
else if (oNode.nodeType === 1 && !oNode.prefix) { aCache.push(oNode); } /* nodeType is 'Element' (1) */
|
||||
}
|
||||
}
|
||||
|
||||
@@ -56,7 +56,7 @@ var JXON = new (function () {
|
||||
if (bAttributes) {
|
||||
var
|
||||
nAttrLen = oParentNode.attributes.length,
|
||||
sAPrefix = bNesteAttr ? "" : sAttrPref, oAttrParent = bNesteAttr ? {} : vResult;
|
||||
sAPrefix = bNesteAttr ? '' : sAttrPref, oAttrParent = bNesteAttr ? {} : vResult;
|
||||
|
||||
for (var oAttrib, nAttrib = 0; nAttrib < nAttrLen; nLength++, nAttrib++) {
|
||||
oAttrib = oParentNode.attributes.item(nAttrib);
|
||||
@@ -120,12 +120,12 @@ var JXON = new (function () {
|
||||
}
|
||||
|
||||
this.build = function (oXMLParent, nVerbosity /* optional */, bFreeze /* optional */, bNesteAttributes /* optional */) {
|
||||
var _nVerb = arguments.length > 1 && typeof nVerbosity === "number" ? nVerbosity & 3 : /* put here the default verbosity level: */ 1;
|
||||
var _nVerb = arguments.length > 1 && typeof nVerbosity === 'number' ? nVerbosity & 3 : /* put here the default verbosity level: */ 1;
|
||||
return createObjTree(oXMLParent, _nVerb, bFreeze || false, arguments.length > 3 ? bNesteAttributes : _nVerb === 3);
|
||||
};
|
||||
|
||||
this.unbuild = function (oObjTree) {
|
||||
var oNewDoc = document.implementation.createDocument("", "", null);
|
||||
var oNewDoc = document.implementation.createDocument('', '', null);
|
||||
loadObjTree(oNewDoc, oNewDoc, oObjTree);
|
||||
return oNewDoc;
|
||||
};
|
||||
@@ -134,6 +134,7 @@ var JXON = new (function () {
|
||||
return (new XMLSerializer()).serializeToString(JXON.unbuild(oObjTree));
|
||||
};
|
||||
})();
|
||||
|
||||
// var myObject = JXON.build(doc);
|
||||
// we got our javascript object! try: alert(JSON.stringify(myObject));
|
||||
|
||||
@@ -24,7 +24,6 @@
|
||||
<!-- include source files here... -->
|
||||
<script src='../js/lib/lodash.js'></script>
|
||||
<script src='../js/lib/d3.v3.js'></script>
|
||||
<script src='../js/lib/jxon.js'></script>
|
||||
<script src='../js/lib/d3.combobox.js'></script>
|
||||
<script src='../js/lib/d3.geo.tile.js'></script>
|
||||
<script src='../js/lib/d3.dimensions.js'></script>
|
||||
|
||||
Reference in New Issue
Block a user