Spaces:
Configuration error
Configuration error
import * as DomUtils from "domutils"; | |
import boolbase from "boolbase"; | |
import { compile as compileRaw, compileUnsafe, compileToken, } from "./compile.js"; | |
import { getNextSiblings } from "./pseudo-selectors/subselects.js"; | |
const defaultEquals = (a, b) => a === b; | |
const defaultOptions = { | |
adapter: DomUtils, | |
equals: defaultEquals, | |
}; | |
function convertOptionFormats(options) { | |
var _a, _b, _c, _d; | |
/* | |
* We force one format of options to the other one. | |
*/ | |
// @ts-expect-error Default options may have incompatible `Node` / `ElementNode`. | |
const opts = options !== null && options !== void 0 ? options : defaultOptions; | |
// @ts-expect-error Same as above. | |
(_a = opts.adapter) !== null && _a !== void 0 ? _a : (opts.adapter = DomUtils); | |
// @ts-expect-error `equals` does not exist on `Options` | |
(_b = opts.equals) !== null && _b !== void 0 ? _b : (opts.equals = (_d = (_c = opts.adapter) === null || _c === void 0 ? void 0 : _c.equals) !== null && _d !== void 0 ? _d : defaultEquals); | |
return opts; | |
} | |
function wrapCompile(func) { | |
return function addAdapter(selector, options, context) { | |
const opts = convertOptionFormats(options); | |
return func(selector, opts, context); | |
}; | |
} | |
/** | |
* Compiles the query, returns a function. | |
*/ | |
export const compile = wrapCompile(compileRaw); | |
export const _compileUnsafe = wrapCompile(compileUnsafe); | |
export const _compileToken = wrapCompile(compileToken); | |
function getSelectorFunc(searchFunc) { | |
return function select(query, elements, options) { | |
const opts = convertOptionFormats(options); | |
if (typeof query !== "function") { | |
query = compileUnsafe(query, opts, elements); | |
} | |
const filteredElements = prepareContext(elements, opts.adapter, query.shouldTestNextSiblings); | |
return searchFunc(query, filteredElements, opts); | |
}; | |
} | |
export function prepareContext(elems, adapter, shouldTestNextSiblings = false) { | |
/* | |
* Add siblings if the query requires them. | |
* See https://github.com/fb55/css-select/pull/43#issuecomment-225414692 | |
*/ | |
if (shouldTestNextSiblings) { | |
elems = appendNextSiblings(elems, adapter); | |
} | |
return Array.isArray(elems) | |
? adapter.removeSubsets(elems) | |
: adapter.getChildren(elems); | |
} | |
function appendNextSiblings(elem, adapter) { | |
// Order matters because jQuery seems to check the children before the siblings | |
const elems = Array.isArray(elem) ? elem.slice(0) : [elem]; | |
const elemsLength = elems.length; | |
for (let i = 0; i < elemsLength; i++) { | |
const nextSiblings = getNextSiblings(elems[i], adapter); | |
elems.push(...nextSiblings); | |
} | |
return elems; | |
} | |
/** | |
* @template Node The generic Node type for the DOM adapter being used. | |
* @template ElementNode The Node type for elements for the DOM adapter being used. | |
* @param elems Elements to query. If it is an element, its children will be queried.. | |
* @param query can be either a CSS selector string or a compiled query function. | |
* @param [options] options for querying the document. | |
* @see compile for supported selector queries. | |
* @returns All matching elements. | |
* | |
*/ | |
export const selectAll = getSelectorFunc((query, elems, options) => query === boolbase.falseFunc || !elems || elems.length === 0 | |
? [] | |
: options.adapter.findAll(query, elems)); | |
/** | |
* @template Node The generic Node type for the DOM adapter being used. | |
* @template ElementNode The Node type for elements for the DOM adapter being used. | |
* @param elems Elements to query. If it is an element, its children will be queried.. | |
* @param query can be either a CSS selector string or a compiled query function. | |
* @param [options] options for querying the document. | |
* @see compile for supported selector queries. | |
* @returns the first match, or null if there was no match. | |
*/ | |
export const selectOne = getSelectorFunc((query, elems, options) => query === boolbase.falseFunc || !elems || elems.length === 0 | |
? null | |
: options.adapter.findOne(query, elems)); | |
/** | |
* Tests whether or not an element is matched by query. | |
* | |
* @template Node The generic Node type for the DOM adapter being used. | |
* @template ElementNode The Node type for elements for the DOM adapter being used. | |
* @param elem The element to test if it matches the query. | |
* @param query can be either a CSS selector string or a compiled query function. | |
* @param [options] options for querying the document. | |
* @see compile for supported selector queries. | |
* @returns | |
*/ | |
export function is(elem, query, options) { | |
const opts = convertOptionFormats(options); | |
return (typeof query === "function" ? query : compileRaw(query, opts))(elem); | |
} | |
/** | |
* Alias for selectAll(query, elems, options). | |
* @see [compile] for supported selector queries. | |
*/ | |
export default selectAll; | |
// Export filters, pseudos and aliases to allow users to supply their own. | |
/** @deprecated Use the `pseudos` option instead. */ | |
export { filters, pseudos, aliases } from "./pseudo-selectors/index.js"; | |
//# sourceMappingURL=index.js.map |