Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@journeyapps/core-xml

Package Overview
Dependencies
Maintainers
2
Versions
244
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@journeyapps/core-xml - npm Package Compare versions

Comparing version 0.0.0-dev.ae608c2.224c284 to 0.0.0-dev.afc96e8

12

dist/@types/src/OrderedIncrementalUpdater.d.ts

@@ -26,5 +26,17 @@ import { XMLElement } from '@journeyapps/domparser/types';

private tagMap;
/**
* null means clear; undefined means unchanged.
*/
private textContent;
constructor(sourceElement: XMLElement, handledTags: string[]);
append(sourceElement: XMLElement | null, builder: ElementBuilder): void;
/**
* If there is an existing text node, replace it.
* If there are multiple text nodes, remove all after the first one.
* If there are no text nodes, append one.
*
* @param text The text, or null to clear.
*/
setTextContent(text: string | null): void;
update(element: XMLElement): void;
}

5

dist/src/domparser.js

@@ -10,6 +10,7 @@ "use strict";

// and @journeyapps/domparser for parsing.
//@ts-ignore
const implementation = document.implementation;
const parser = new domparser_1.DOMParser({ implementation });
const serializer = new XMLSerializer();
xml_1.configureParser({
(0, xml_1.configureParser)({
implementation,

@@ -28,3 +29,3 @@ parser,

const serializer = new xmldom.XMLSerializer();
xml_1.configureParser({
(0, xml_1.configureParser)({
implementation,

@@ -31,0 +32,0 @@ parser,

28

dist/src/index.js
"use strict";
function __export(m) {
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];
}
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __exportStar = (this && this.__exportStar) || function(m, exports) {
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
};
Object.defineProperty(exports, "__esModule", { value: true });
__export(require("./xml"));
__export(require("./utils"));
__export(require("./OrderedIncrementalUpdater"));
__export(require("./UnorderedIncrementalUpdater"));
__export(require("./pretty"));
__exportStar(require("./xml"), exports);
__exportStar(require("./utils"), exports);
__exportStar(require("./OrderedIncrementalUpdater"), exports);
__exportStar(require("./UnorderedIncrementalUpdater"), exports);
__exportStar(require("./pretty"), exports);
__exportStar(require("./ElementBuilder"), exports);
//# sourceMappingURL=index.js.map
"use strict";
// This is the default import for NodeJS.
function __export(m) {
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];
}
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __exportStar = (this && this.__exportStar) || function(m, exports) {
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
};
Object.defineProperty(exports, "__esModule", { value: true });
// Export the same values as for browsers.
__export(require("./index"));
__exportStar(require("./index"), exports);
// Auto-configure the parser
require("./domparser");
//# sourceMappingURL=node.js.map
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.OrderedIncrementalUpdater = void 0;
const index_1 = require("./index");

@@ -35,2 +36,12 @@ /**

}
/**
* If there is an existing text node, replace it.
* If there are multiple text nodes, remove all after the first one.
* If there are no text nodes, append one.
*
* @param text The text, or null to clear.
*/
setTextContent(text) {
this.textContent = text;
}
update(element) {

@@ -58,2 +69,3 @@ const doc = element.ownerDocument;

// 2. Merge source elements.
let seenSourceText = false;
if (this.sourceElement) {

@@ -68,6 +80,22 @@ const sourceNodes = this.sourceElement.childNodes;

}
else if (index_1.isElement(child) && this.tagMap[child.tagName]) {
else if ((0, index_1.isElement)(child) && this.tagMap[child.tagName]) {
// A known element that isn't inserted already.
// Skip it.
}
else if ((0, index_1.isText)(child) && this.textContent !== undefined) {
// Skip any nodes after the first one.
if (!seenSourceText) {
if (this.textContent !== null) {
// Replace the text
const textNode = doc.createTextNode(this.textContent);
if (insertBefore) {
element.insertBefore(textNode, insertBefore);
}
else {
element.appendChild(textNode);
}
}
seenSourceText = true;
}
}
else {

@@ -86,2 +114,6 @@ // Insert before the last known one

}
if (!seenSourceText && this.textContent !== undefined && this.textContent !== null) {
// No source text found - append text
element.appendChild(doc.createTextNode(this.textContent));
}
}

@@ -88,0 +120,0 @@ }

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.stripWhitespace = exports.serializeToString = exports.prettyText = exports.pretty = void 0;
const types_1 = require("@journeyapps/domparser/types");

@@ -13,9 +14,6 @@ const utils_1 = require("./utils");

const newDoc = document.implementation.createDocument(document.documentElement.tagName, null, null);
const actualOptions = {
indentSpaces: 4,
...options
};
const actualOptions = Object.assign({ indentSpaces: 4 }, options);
for (let i = 0; i < document.childNodes.length; i++) {
const child = document.childNodes.item(i);
if (utils_1.isText(child)) {
if ((0, utils_1.isText)(child)) {
// workaround for xmldom that has text nodes in the document

@@ -35,10 +33,6 @@ continue;

const doc = pretty(node, options);
// TODO: close tags with " />".
return serializeToString(doc);
}
else {
const actualOptions = {
indentSpaces: 4,
...options
};
const actualOptions = Object.assign({ indentSpaces: 4 }, options);
const prettyElement = prettyNode(node.ownerDocument, node, actualOptions, 0);

@@ -58,4 +52,3 @@ return serializeToString(prettyElement);

let result = '';
if (node.firstChild &&
node.firstChild.nodeType == types_1.PROCESSING_INSTRUCTION_NODE) {
if (node.firstChild && node.firstChild.nodeType == types_1.PROCESSING_INSTRUCTION_NODE) {
// Has a processing instruction.

@@ -70,3 +63,3 @@ }

const child = children[i];
if (utils_1.isText(child)) {
if ((0, utils_1.isText)(child)) {
// Workaround for xmldom inserting extra newlines

@@ -116,3 +109,3 @@ continue;

let newNode = node.cloneNode(false);
if (utils_1.isText(node)) {
if ((0, utils_1.isText)(node)) {
const trimmedText = node.nodeValue.trim();

@@ -135,3 +128,3 @@ const newLines = node.nodeValue.split('\n').length - 1;

}
else if (utils_1.isElement(node)) {
else if ((0, utils_1.isElement)(node)) {
let filteredChildren = [];

@@ -142,4 +135,4 @@ for (let i = 0; i < node.childNodes.length; i++) {

}
filteredChildren = filteredChildren.filter(node => node != null);
if (filteredChildren.length == 1 && utils_1.isText(filteredChildren[0])) {
filteredChildren = filteredChildren.filter((node) => node != null);
if (filteredChildren.length == 1 && (0, utils_1.isText)(filteredChildren[0])) {
// Text on its own. Preserve whitespace.

@@ -170,3 +163,3 @@ newNode.appendChild(filteredChildren[0]);

else {
if (utils_1.isText(child)) {
if ((0, utils_1.isText)(child)) {
// Text in mixed-mode.

@@ -173,0 +166,0 @@ // We currently preserve whitespace _before_ the text element, but not _after_.

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.serialize = exports.serializer = void 0;
const types_1 = require("@journeyapps/domparser/types");

@@ -30,4 +31,3 @@ const utils_1 = require("./utils");

}
if ((prefix === 'xml' && uri === 'http://www.w3.org/XML/1998/namespace') ||
uri == 'http://www.w3.org/2000/xmlns/') {
if ((prefix === 'xml' && uri === 'http://www.w3.org/XML/1998/namespace') || uri == 'http://www.w3.org/2000/xmlns/') {
return false;

@@ -60,3 +60,3 @@ }

}
if (utils_1.isElement(node)) {
if ((0, utils_1.isElement)(node)) {
if (!visibleNamespaces) {

@@ -115,4 +115,3 @@ visibleNamespaces = [];

}
else if (node.nodeType == types_1.DOCUMENT_NODE ||
node.nodeType == types_1.DOCUMENT_FRAGMENT_NODE) {
else if (node.nodeType == types_1.DOCUMENT_NODE || node.nodeType == types_1.DOCUMENT_FRAGMENT_NODE) {
let child = node.firstChild;

@@ -124,12 +123,12 @@ while (child) {

}
else if (utils_1.isAttribute(node)) {
else if ((0, utils_1.isAttribute)(node)) {
buf.push(' ', node.name, '="', node.value.replace(/[<&"]/g, _xmlEncoder), '"');
}
else if (utils_1.isText(node)) {
else if ((0, utils_1.isText)(node)) {
buf.push(node.data.replace(/[<&]/g, _xmlEncoder));
}
else if (utils_1.isCdataNode(node)) {
else if ((0, utils_1.isCdataNode)(node)) {
buf.push('<![CDATA[', node.data, ']]>');
}
else if (utils_1.isCommentNode(node)) {
else if ((0, utils_1.isCommentNode)(node)) {
buf.push('<!--', node.data, '-->');

@@ -136,0 +135,0 @@ }

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.UnorderedIncrementalUpdater = void 0;
const index_1 = require("./index");

@@ -61,4 +62,4 @@ /**

// Copy existing children
for (let child of index_1.iter(this.sourceElement.childNodes)) {
if (index_1.isElement(child) && child.tagName in this.sourceElements) {
for (let child of (0, index_1.iter)(this.sourceElement.childNodes)) {
if ((0, index_1.isElement)(child) && child.tagName in this.sourceElements) {
if (this.sourceElements[child.tagName].has(child)) {

@@ -65,0 +66,0 @@ // Present - update!

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.iter = exports.setAttributes = exports.isCommentNode = exports.isCdataNode = exports.isText = exports.isElement = exports.isAttribute = exports.DOCUMENT_NODE = exports.TEXT_NODE = exports.ATTRIBUTE_NODE = exports.ELEMENT_NODE = void 0;
const types_1 = require("@journeyapps/domparser/types");

@@ -13,4 +14,3 @@ // From: http://www.w3.org/TR/2000/REC-DOM-Level-2-Core-20001113/core.html#ID-1950641247

return (node.nodeType == exports.ATTRIBUTE_NODE ||
(typeof node.name == 'string' &&
typeof node.ownerElement == 'object'));
(typeof node.name == 'string' && typeof node.ownerElement == 'object'));
}

@@ -17,0 +17,0 @@ exports.isAttribute = isAttribute;

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.childContent = exports.childNode = exports.documentToText = exports.createDocument = exports.parse = exports.configureParser = exports.getParser = exports.validateChildren = exports.children = exports.attribute = exports.parseElement = exports.warning = exports.error = exports.attributeNode = exports.elementTextPosition = exports.attributeValuePosition = exports.getPosition = exports.getAttribute = void 0;
const utils_1 = require("./utils");

@@ -48,3 +49,3 @@ let configuredParser = null;

var owner;
if (utils_1.isAttribute(node)) {
if ((0, utils_1.isAttribute)(node)) {
owner = node.ownerElement.ownerDocument;

@@ -61,5 +62,3 @@ }

}
else if (utils_1.isElement(node) &&
node.openStart != null &&
node.nameEnd != null) {
else if ((0, utils_1.isElement)(node) && node.openStart != null && node.nameEnd != null) {
// This is an element

@@ -69,10 +68,6 @@ position.start = locator.position(node.openStart + 1);

}
else if (utils_1.isAttribute(node)) {
else if ((0, utils_1.isAttribute)(node)) {
// This is an attribute
var attrPosition = node.ownerElement.attributePositions == null
? null
: node.ownerElement.attributePositions[node.name];
if (attrPosition != null &&
attrPosition.valueStart != null &&
attrPosition.end != null) {
var attrPosition = node.ownerElement.attributePositions == null ? null : node.ownerElement.attributePositions[node.name];
if (attrPosition != null && attrPosition.valueStart != null && attrPosition.end != null) {
if (attrPosition.end - attrPosition.valueStart > 2) {

@@ -98,4 +93,3 @@ // Exclude quotes

if (locator) {
if (element.attributePositions != null &&
element.attributePositions.hasOwnProperty(attributeName)) {
if (element.attributePositions != null && element.attributePositions.hasOwnProperty(attributeName)) {
var p = element.attributePositions[attributeName];

@@ -119,4 +113,3 @@ return {

if (locator) {
if (element.attributePositions != null &&
element.attributePositions.hasOwnProperty(attributeName)) {
if (element.attributePositions != null && element.attributePositions.hasOwnProperty(attributeName)) {
var p = element.attributePositions[attributeName];

@@ -209,3 +202,4 @@ if (start == end) {

};
if (type == null) {
// The specific tag exclusions if for the specs
if (type == null && tag != 'context-menu' && tag != 'button') {
result.type = null;

@@ -278,5 +272,3 @@ result.errors.push(warning(element, "Invalid element '" + tag + "'"));

if (options.indexOf(value) == -1) {
var message = customMessage == null
? element.name + ' must be one of ' + options
: customMessage;
var message = customMessage == null ? element.name + ' must be one of ' + options : customMessage;
throw new Error(message);

@@ -294,5 +286,3 @@ }

if (options.indexOf(value) == -1) {
var message = customMessage == null
? element.name + ' must be one of ' + options
: customMessage;
var message = customMessage == null ? element.name + ' must be one of ' + options : customMessage;
throw new Error(message);

@@ -305,21 +295,31 @@ }

return function (valuesString, element) {
var values = valuesString.split(',');
var invalidValues = [];
Array.prototype.forEach.call(values, function (value) {
if (options.indexOf(value) == -1) {
invalidValues.push(value);
}
});
if (invalidValues.length === 0) {
return validateMultiOptions(valuesString, element, options, customMessage);
};
};
exports.attribute.multiOptionListWithFunctions = function multiOptionList(options, functionPrefix, customMessage) {
return function (valuesString, element) {
if (valuesString.indexOf(functionPrefix) === 0) {
// function token expression, therefore allow
return valuesString;
}
else {
var message = 'Invalid values: ' + invalidValues + '. ';
var extraMessage = customMessage == null
? element.name + ' values must be from ' + options
: customMessage;
throw new Error(message + extraMessage);
}
return validateMultiOptions(valuesString, element, options, customMessage);
};
};
function validateMultiOptions(valuesString, element, options, customMessage) {
var values = valuesString.split(',');
var invalidValues = [];
values.forEach((value) => {
if (options.indexOf(value) == -1) {
invalidValues.push(value);
}
});
if (invalidValues.length === 0) {
return valuesString;
}
else {
var message = 'Invalid values: ' + invalidValues + '. ';
var extraMessage = customMessage == null ? element.name + ' values must be from ' + options : customMessage;
throw new Error(message + extraMessage);
}
}
// filter can be an array of strings, or a comma-separated list

@@ -344,3 +344,3 @@ function children(element, filter) {

var child = all[i];
if (utils_1.isElement(child) &&
if ((0, utils_1.isElement)(child) &&
child.tagName != null &&

@@ -358,3 +358,3 @@ (allowedNames == null || allowedNames.indexOf(child.tagName) != -1)) {

Array.prototype.forEach.call(element.childNodes, function (child) {
if (utils_1.isElement(child)) {
if ((0, utils_1.isElement)(child)) {
var tag = child.tagName;

@@ -390,6 +390,7 @@ var order = tagNames[tag];

function loadDefaultParser() {
if (typeof document != 'undefined' &&
typeof document.implementation != 'undefined') {
if (typeof document != 'undefined' && typeof document.implementation != 'undefined') {
configureParser({
//@ts-ignore
implementation: document.implementation,
//@ts-ignore
parser: new DOMParser(),

@@ -428,3 +429,3 @@ serializer: new XMLSerializer()

var child = element.childNodes[i];
if (utils_1.isElement(child) && child.tagName == childName) {
if ((0, utils_1.isElement)(child) && child.tagName == childName) {
return child;

@@ -431,0 +432,0 @@ }

{
"name": "@journeyapps/core-xml",
"version": "0.0.0-dev.ae608c2.224c284",
"version": "0.0.0-dev.afc96e8",
"description": "Journey JS library",

@@ -10,3 +10,3 @@ "main": "./dist/src/node.js",

"build": "../node_modules/.bin/tsc --build",
"test": "yarn build && yarn test:node && yarn test:browser",
"test": "pnpm build && pnpm test:node && pnpm test:browser",
"test:browser": "karma start karma.conf.js --single-run",

@@ -16,6 +16,7 @@ "test:node": "jasmine dist/test/unit/all.js"

"dependencies": {
"@journeyapps/domparser": "^0.3.0"
"@journeyapps/domparser": "^0.3.0",
"xmldom": "^0.6.0"
},
"devDependencies": {
"@journeyapps/core-test-helpers": "0.0.0-dev.ae608c2.224c284"
"@journeyapps/core-test-helpers": "^4.1.1"
},

@@ -27,3 +28,7 @@ "files": [

],
"gitHead": "e1cedf0b9f9515cbca7436ed517e9bbdad9560b4"
"pnpm": {
"overrides": {
"@journeyapps/core-test-helpers": "link:../test-helpers"
}
}
}

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc