2021-11-24 19:46:47 +11:00
|
|
|
"use strict";
|
2022-09-03 17:12:22 +10:00
|
|
|
var __assign = (this && this.__assign) || function () {
|
|
|
|
__assign = Object.assign || function(t) {
|
|
|
|
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
|
|
s = arguments[i];
|
|
|
|
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
|
|
t[p] = s[p];
|
|
|
|
}
|
|
|
|
return t;
|
|
|
|
};
|
|
|
|
return __assign.apply(this, arguments);
|
|
|
|
};
|
|
|
|
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
|
|
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
|
|
}) : function(o, v) {
|
|
|
|
o["default"] = v;
|
|
|
|
});
|
|
|
|
var __importStar = (this && this.__importStar) || function (mod) {
|
|
|
|
if (mod && mod.__esModule) return mod;
|
|
|
|
var result = {};
|
|
|
|
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
|
|
__setModuleDefault(result, mod);
|
|
|
|
return result;
|
|
|
|
};
|
2021-11-24 19:46:47 +11:00
|
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
|
exports.merge = exports.contains = exports.root = exports.parseHTML = exports.text = exports.xml = exports.html = void 0;
|
2022-09-03 17:12:22 +10:00
|
|
|
var domutils_1 = require("domutils");
|
|
|
|
var options_js_1 = __importStar(require("./options.js"));
|
2021-11-24 19:46:47 +11:00
|
|
|
/**
|
|
|
|
* Helper function to render a DOM.
|
|
|
|
*
|
|
|
|
* @param that - Cheerio instance to render.
|
|
|
|
* @param dom - The DOM to render. Defaults to `that`'s root.
|
|
|
|
* @param options - Options for rendering.
|
|
|
|
* @returns The rendered document.
|
|
|
|
*/
|
|
|
|
function render(that, dom, options) {
|
2022-09-03 17:12:22 +10:00
|
|
|
if (!that)
|
2021-11-24 19:46:47 +11:00
|
|
|
return '';
|
2022-09-03 17:12:22 +10:00
|
|
|
return that(dom !== null && dom !== void 0 ? dom : that._root.children, null, undefined, options).toString();
|
2021-11-24 19:46:47 +11:00
|
|
|
}
|
|
|
|
/**
|
|
|
|
* Checks if a passed object is an options object.
|
|
|
|
*
|
|
|
|
* @param dom - Object to check if it is an options object.
|
|
|
|
* @returns Whether the object is an options object.
|
|
|
|
*/
|
2022-09-03 17:12:22 +10:00
|
|
|
function isOptions(dom, options) {
|
|
|
|
return (!options &&
|
|
|
|
typeof dom === 'object' &&
|
2021-11-24 19:46:47 +11:00
|
|
|
dom != null &&
|
|
|
|
!('length' in dom) &&
|
|
|
|
!('type' in dom));
|
|
|
|
}
|
|
|
|
function html(dom, options) {
|
|
|
|
/*
|
|
|
|
* Be flexible about parameters, sometimes we call html(),
|
|
|
|
* with options as only parameter
|
|
|
|
* check dom argument for dom element specific properties
|
|
|
|
* assume there is no 'length' or 'type' properties in the options object
|
|
|
|
*/
|
2022-09-03 17:12:22 +10:00
|
|
|
var toRender = isOptions(dom) ? ((options = dom), undefined) : dom;
|
2021-11-24 19:46:47 +11:00
|
|
|
/*
|
|
|
|
* Sometimes `$.html()` is used without preloading html,
|
|
|
|
* so fallback non-existing options to the default ones.
|
|
|
|
*/
|
2022-09-03 17:12:22 +10:00
|
|
|
var opts = __assign(__assign(__assign({}, options_js_1.default), this === null || this === void 0 ? void 0 : this._options), (0, options_js_1.flatten)(options !== null && options !== void 0 ? options : {}));
|
|
|
|
return render(this, toRender, opts);
|
2021-11-24 19:46:47 +11:00
|
|
|
}
|
|
|
|
exports.html = html;
|
|
|
|
/**
|
|
|
|
* Render the document as XML.
|
|
|
|
*
|
|
|
|
* @param dom - Element to render.
|
|
|
|
* @returns THe rendered document.
|
|
|
|
*/
|
|
|
|
function xml(dom) {
|
2022-09-03 17:12:22 +10:00
|
|
|
var options = __assign(__assign({}, this._options), { xmlMode: true });
|
2021-11-24 19:46:47 +11:00
|
|
|
return render(this, dom, options);
|
|
|
|
}
|
|
|
|
exports.xml = xml;
|
|
|
|
/**
|
|
|
|
* Render the document as text.
|
|
|
|
*
|
2022-09-03 17:12:22 +10:00
|
|
|
* This returns the `textContent` of the passed elements. The result will
|
|
|
|
* include the contents of `script` and `stype` elements. To avoid this, use
|
|
|
|
* `.prop('innerText')` instead.
|
|
|
|
*
|
2021-11-24 19:46:47 +11:00
|
|
|
* @param elements - Elements to render.
|
|
|
|
* @returns The rendered document.
|
|
|
|
*/
|
|
|
|
function text(elements) {
|
|
|
|
var elems = elements ? elements : this ? this.root() : [];
|
|
|
|
var ret = '';
|
|
|
|
for (var i = 0; i < elems.length; i++) {
|
2022-09-03 17:12:22 +10:00
|
|
|
ret += (0, domutils_1.textContent)(elems[i]);
|
2021-11-24 19:46:47 +11:00
|
|
|
}
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
exports.text = text;
|
|
|
|
function parseHTML(data, context, keepScripts) {
|
|
|
|
if (keepScripts === void 0) { keepScripts = typeof context === 'boolean' ? context : false; }
|
|
|
|
if (!data || typeof data !== 'string') {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
if (typeof context === 'boolean') {
|
|
|
|
keepScripts = context;
|
|
|
|
}
|
2022-09-03 17:12:22 +10:00
|
|
|
var parsed = this.load(data, options_js_1.default, false);
|
2021-11-24 19:46:47 +11:00
|
|
|
if (!keepScripts) {
|
|
|
|
parsed('script').remove();
|
|
|
|
}
|
|
|
|
/*
|
|
|
|
* The `children` array is used by Cheerio internally to group elements that
|
|
|
|
* share the same parents. When nodes created through `parseHTML` are
|
|
|
|
* inserted into previously-existing DOM structures, they will be removed
|
|
|
|
* from the `children` array. The results of `parseHTML` should remain
|
|
|
|
* constant across these operations, so a shallow copy should be returned.
|
|
|
|
*/
|
|
|
|
return parsed.root()[0].children.slice();
|
|
|
|
}
|
|
|
|
exports.parseHTML = parseHTML;
|
|
|
|
/**
|
|
|
|
* Sometimes you need to work with the top-level root element. To query it, you
|
|
|
|
* can use `$.root()`.
|
|
|
|
*
|
|
|
|
* @example
|
|
|
|
*
|
|
|
|
* ```js
|
|
|
|
* $.root().append('<ul id="vegetables"></ul>').html();
|
|
|
|
* //=> <ul id="fruits">...</ul><ul id="vegetables"></ul>
|
|
|
|
* ```
|
|
|
|
*
|
|
|
|
* @returns Cheerio instance wrapping the root node.
|
|
|
|
* @alias Cheerio.root
|
|
|
|
*/
|
|
|
|
function root() {
|
|
|
|
return this(this._root);
|
|
|
|
}
|
|
|
|
exports.root = root;
|
|
|
|
/**
|
|
|
|
* Checks to see if the `contained` DOM element is a descendant of the
|
|
|
|
* `container` DOM element.
|
|
|
|
*
|
|
|
|
* @param container - Potential parent node.
|
|
|
|
* @param contained - Potential child node.
|
|
|
|
* @returns Indicates if the nodes contain one another.
|
|
|
|
* @alias Cheerio.contains
|
|
|
|
* @see {@link https://api.jquery.com/jQuery.contains/}
|
|
|
|
*/
|
|
|
|
function contains(container, contained) {
|
|
|
|
// According to the jQuery API, an element does not "contain" itself
|
|
|
|
if (contained === container) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
/*
|
|
|
|
* Step up the descendants, stopping when the root element is reached
|
|
|
|
* (signaled by `.parent` returning a reference to the same object)
|
|
|
|
*/
|
|
|
|
var next = contained;
|
|
|
|
while (next && next !== next.parent) {
|
|
|
|
next = next.parent;
|
|
|
|
if (next === container) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
exports.contains = contains;
|
|
|
|
/**
|
|
|
|
* $.merge().
|
|
|
|
*
|
|
|
|
* @param arr1 - First array.
|
|
|
|
* @param arr2 - Second array.
|
|
|
|
* @returns `arr1`, with elements of `arr2` inserted.
|
|
|
|
* @alias Cheerio.merge
|
|
|
|
* @see {@link https://api.jquery.com/jQuery.merge/}
|
|
|
|
*/
|
|
|
|
function merge(arr1, arr2) {
|
|
|
|
if (!isArrayLike(arr1) || !isArrayLike(arr2)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
var newLength = arr1.length;
|
|
|
|
var len = +arr2.length;
|
|
|
|
for (var i = 0; i < len; i++) {
|
|
|
|
arr1[newLength++] = arr2[i];
|
|
|
|
}
|
|
|
|
arr1.length = newLength;
|
|
|
|
return arr1;
|
|
|
|
}
|
|
|
|
exports.merge = merge;
|
|
|
|
/**
|
2022-09-03 17:12:22 +10:00
|
|
|
* Checks if an object is array-like.
|
|
|
|
*
|
2021-11-24 19:46:47 +11:00
|
|
|
* @param item - Item to check.
|
|
|
|
* @returns Indicates if the item is array-like.
|
|
|
|
*/
|
|
|
|
function isArrayLike(item) {
|
|
|
|
if (Array.isArray(item)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
if (typeof item !== 'object' ||
|
|
|
|
!Object.prototype.hasOwnProperty.call(item, 'length') ||
|
|
|
|
typeof item.length !== 'number' ||
|
|
|
|
item.length < 0) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
for (var i = 0; i < item.length; i++) {
|
|
|
|
if (!(i in item)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
2022-09-03 17:12:22 +10:00
|
|
|
//# sourceMappingURL=static.js.map
|